in src/Modules/SimplCommerce.Module.Catalog/Areas/Catalog/Controllers/BrandController.cs [42:115]
public IActionResult BrandDetail(long id, SearchOption searchOption)
{
var brand = _brandRepository.Query().FirstOrDefault(x => x.Id == id);
if (brand == null)
{
return Redirect("~/Error/FindNotFound");
}
var model = new ProductsByBrand
{
BrandId = id,
BrandName = brand.Name,
BrandSlug = brand.Slug,
CurrentSearchOption = searchOption,
FilterOption = new FilterOption()
};
var query = _productRepository.Query().Where(x => x.BrandId == id && x.IsPublished && x.IsVisibleIndividually);
if (query.Count() == 0)
{
model.TotalProduct = 0;
return View(model);
}
AppendFilterOptionsToModel(model, query);
if (searchOption.MinPrice.HasValue)
{
query = query.Where(x => x.Price >= searchOption.MinPrice.Value);
}
if (searchOption.MaxPrice.HasValue)
{
query = query.Where(x => x.Price <= searchOption.MaxPrice.Value);
}
var categories = searchOption.GetCategories().ToArray();
if (categories.Any())
{
query = query.Where(x => x.Categories.Any(c => categories.Contains(c.Category.Slug)));
}
model.TotalProduct = query.Count();
var currentPageNum = searchOption.Page <= 0 ? 1 : searchOption.Page;
var offset = (_pageSize * currentPageNum) - _pageSize;
while (currentPageNum > 1 && offset >= model.TotalProduct)
{
currentPageNum--;
offset = (_pageSize * currentPageNum) - _pageSize;
}
query = ApplySort(searchOption, query);
var products = query
.Include(x => x.ThumbnailImage)
.Skip(offset)
.Take(_pageSize)
.Select(x => ProductThumbnail.FromProduct(x))
.ToList();
foreach (var product in products)
{
product.Name = _contentLocalizationService.GetLocalizedProperty(nameof(Product), product.Id, nameof(product.Name), product.Name);
product.ThumbnailUrl = _mediaService.GetThumbnailUrl(product.ThumbnailImage);
product.CalculatedProductPrice = _productPricingService.CalculateProductPrice(product);
}
model.Products = products;
model.CurrentSearchOption.PageSize = _pageSize;
model.CurrentSearchOption.Page = currentPageNum;
return View(model);
}