| | | 1 | | using System; |
| | | 2 | | using System.Collections.Generic; |
| | | 3 | | using System.Linq; |
| | | 4 | | using System.Threading.Tasks; |
| | | 5 | | using Microsoft.AspNetCore.Authorization; |
| | | 6 | | using Microsoft.AspNetCore.Http; |
| | | 7 | | using Microsoft.AspNetCore.Mvc; |
| | | 8 | | using Microsoft.EntityFrameworkCore; |
| | | 9 | | using Microsoft.Extensions.Logging; |
| | | 10 | | using SVETA.Api.Data.DTO; |
| | | 11 | | using SVETA.Api.Services.Interfaces; |
| | | 12 | | using WinSolutions.Sveta.Server.Data.DataModel.Entities; |
| | | 13 | | using WinSolutions.Sveta.Server.Data.DataModel.Extensions; |
| | | 14 | | using WinSolutions.Sveta.Server.Services.Interfaces; |
| | | 15 | | |
| | | 16 | | namespace SVETA.Api.Controllers |
| | | 17 | | { |
| | | 18 | | [Route("api/v1/CatalogFilters")] |
| | | 19 | | [ApiController] |
| | | 20 | | [Authorize] |
| | | 21 | | public class CatalogFiltersController : SvetaController |
| | | 22 | | { |
| | | 23 | | private readonly IDepartmentService _departmentService; |
| | | 24 | | private readonly IShowcaseWorker _goodWorker; |
| | | 25 | | private readonly ILogger<CatalogFiltersController> _logger; |
| | | 26 | | |
| | | 27 | | public CatalogFiltersController( |
| | | 28 | | IShowcaseWorker worker, |
| | | 29 | | IDepartmentService departmentService, |
| | 0 | 30 | | ILogger<CatalogFiltersController> logger): base(logger) |
| | 0 | 31 | | { |
| | 0 | 32 | | _departmentService = departmentService; |
| | 0 | 33 | | _goodWorker = worker; |
| | 0 | 34 | | _logger = logger; |
| | 0 | 35 | | } |
| | | 36 | | |
| | | 37 | | /// <summary> |
| | | 38 | | /// Возвращает объект для построения sidebar |
| | | 39 | | /// </summary> |
| | | 40 | | /// <remarks>author: aabelentsov</remarks> |
| | | 41 | | /// <param name="categoryId">Категория для построения фильтра.await 0 - по всем категориям</param> |
| | | 42 | | /// <param name="departmentId">Магазин</param> |
| | | 43 | | /// <returns></returns> |
| | | 44 | | [AllowAnonymous] |
| | | 45 | | [HttpGet("Category/{categoryId}/Department/{departmentId}")] |
| | | 46 | | [ProducesResponseType(typeof(IEnumerable<CatalogFiltersDTO>), 200)] |
| | | 47 | | public async Task<IActionResult> GetCatalogFilter(long categoryId, long departmentId) |
| | | 48 | | { |
| | | 49 | | List<CatalogFiltersDTO> cFilters = new List<CatalogFiltersDTO>(); |
| | | 50 | | var shopDep = await _departmentService.GetDepartment(departmentId) ?? |
| | | 51 | | throw new KeyNotFoundException($"Не найден магазин"); |
| | | 52 | | if (shopDep.Cluster == null) |
| | | 53 | | throw new ArgumentException($"Не найден кластер для магазина {shopDep.Name}"); |
| | | 54 | | var goods = await _goodWorker.GetShowcaseGoodsBaseQuery(categoryId > 0 ? categoryId : (long?)null, departmen |
| | | 55 | | |
| | | 56 | | if (await goods.CountAsync() == 0) |
| | | 57 | | { |
| | | 58 | | return Ok(cFilters); |
| | | 59 | | } |
| | | 60 | | // бренды |
| | | 61 | | var brands = await goods.Select(d => d.Brand).Distinct().OrderBy(d => d.Name).ToListAsync(); |
| | | 62 | | if (brands.Count > 0 && brands.First() != null) |
| | | 63 | | { |
| | | 64 | | var brandFilters = CreateCatalogFilters("brands", "Бренд", GroupType.verticalGroup); |
| | 0 | 65 | | brandFilters.FieldGroup.AddRange(brands.Where(d => d != null).Select(d => new FieldGroupDTO |
| | 0 | 66 | | { |
| | 0 | 67 | | Type = FieldType.checkbox, |
| | 0 | 68 | | Key = d.Id.ToString(), |
| | 0 | 69 | | TemplateOptions = new FieldGroupTemplateOptions |
| | 0 | 70 | | { |
| | 0 | 71 | | Label = d.Name |
| | 0 | 72 | | } |
| | 0 | 73 | | }).ToList()); |
| | | 74 | | if (brandFilters != null && brandFilters?.FieldGroup.Count > 1) |
| | | 75 | | cFilters.Add(brandFilters); |
| | | 76 | | } |
| | | 77 | | |
| | | 78 | | // страны |
| | | 79 | | /*var countries = await goods.Select(d => d.Country).Distinct().ToListAsync(); |
| | | 80 | | if (countries.Count > 0 && countries.First() != null) |
| | | 81 | | { |
| | | 82 | | var countryFilters = CreateCatalogFilters("country", "Страна", GroupType.verticalGroup); |
| | | 83 | | countryFilters.FieldGroup.AddRange(countries.Where(d => d != null).Select(d => new FieldGroupDTO |
| | | 84 | | { |
| | | 85 | | Type = FieldType.checkbox, |
| | | 86 | | Key = d.Id.ToString(), |
| | | 87 | | TemplateOptions = new FieldGroupTemplateOptions |
| | | 88 | | { |
| | | 89 | | Label = d.Name |
| | | 90 | | } |
| | | 91 | | }).ToList()); |
| | | 92 | | cFilters.Add(countryFilters); |
| | | 93 | | }*/ |
| | | 94 | | |
| | | 95 | | // цены |
| | | 96 | | var priceFilter = CreateCatalogFilters("price", "цена", GroupType.horizontalGroup); |
| | | 97 | | var goodsPrices = goods.Select(d => d.Prices.Where(x => |
| | | 98 | | !x.IsDeleted |
| | | 99 | | && x.PriceTrend.SupplierDepartment.Id == shopDep.Cluster.WarehouseId |
| | | 100 | | && x.PriceTrend.BeginDate <= DateTime.Now) |
| | | 101 | | .OrderByDescending(x => x.PriceTrend.BeginDate).FirstOrDefault()) |
| | | 102 | | .Where(d => d != null) |
| | | 103 | | .Select(d => d.PriceNew) |
| | | 104 | | .ToList() |
| | 0 | 105 | | .Select(x => (int)Math.Ceiling(x)); |
| | | 106 | | var field = new FieldGroupDTO |
| | | 107 | | { |
| | | 108 | | Type = FieldType.input, |
| | | 109 | | Key = "price_from", |
| | | 110 | | TemplateOptions = new FieldPriceGroupTemplateOptions |
| | | 111 | | { |
| | | 112 | | Label = "", |
| | | 113 | | Placeholder = "от", |
| | | 114 | | PriceCount = goodsPrices.Min() |
| | | 115 | | } |
| | | 116 | | }; |
| | | 117 | | priceFilter.FieldGroup.Add(field); |
| | | 118 | | priceFilter.FieldGroup.Add(new FieldGroupDTO |
| | | 119 | | { |
| | | 120 | | Type = FieldType.input, |
| | | 121 | | Key = "price_to", |
| | | 122 | | TemplateOptions = new FieldPriceGroupTemplateOptions |
| | | 123 | | { |
| | | 124 | | Label = "", |
| | | 125 | | Placeholder = "до", |
| | | 126 | | PriceCount = goodsPrices.Max() |
| | | 127 | | } |
| | | 128 | | }); |
| | | 129 | | if (priceFilter != null && priceFilter?.FieldGroup.Count > 1) |
| | | 130 | | cFilters.Add(priceFilter); |
| | | 131 | | |
| | | 132 | | // минимальная партия |
| | | 133 | | // var distinctMinDelivery = await goods |
| | | 134 | | // .Select(d => d.DepartmentGoodSettings.FirstOrDefault(setting => !setting.IsDeleted && setting.Departm |
| | | 135 | | // .Select(d => d.MinQuantity) |
| | | 136 | | // .Distinct() |
| | | 137 | | // .OrderBy(d => d) |
| | | 138 | | // .ToListAsync(); |
| | | 139 | | // if (distinctMinDelivery.Count > 0) |
| | | 140 | | // { |
| | | 141 | | // var quantityFilter = CreateCatalogFilters("minQuantity", "Мин. партия", GroupType.verticalGroup); |
| | | 142 | | // |
| | | 143 | | // quantityFilter.FieldGroup.AddRange(distinctMinDelivery.Where(d => d != 0).Select(d => new FieldGroupD |
| | | 144 | | // { |
| | | 145 | | // Type = FieldType.checkbox, |
| | | 146 | | // Key = d.ToString(), |
| | | 147 | | // TemplateOptions = new FieldGroupTemplateOptions |
| | | 148 | | // { |
| | | 149 | | // Label = d.ToString() |
| | | 150 | | // } |
| | | 151 | | // }).ToList()); |
| | | 152 | | // if (quantityFilter != null && quantityFilter?.FieldGroup.Count > 1) |
| | | 153 | | // cFilters.Add(quantityFilter); |
| | | 154 | | // } |
| | | 155 | | //var volumeFilter = CreateCatalogFilters("volume", "Объем", GroupType.verticalGroup); |
| | | 156 | | |
| | | 157 | | return Ok(cFilters); |
| | | 158 | | } |
| | 0 | 159 | | private CatalogFiltersDTO CreateCatalogFilters(string key, string label, string groupType) => new CatalogFilters |
| | 0 | 160 | | { |
| | 0 | 161 | | Key = key, |
| | 0 | 162 | | Wrappers = new string[] { "form-group-collapse-title" }, |
| | 0 | 163 | | TemplateOptions = new TemplateOptionDTO |
| | 0 | 164 | | { |
| | 0 | 165 | | Label = label |
| | 0 | 166 | | }, |
| | 0 | 167 | | FieldGroupClassName = groupType, |
| | 0 | 168 | | FieldGroup = new List<FieldGroupDTO>() |
| | 0 | 169 | | }; |
| | | 170 | | } |
| | | 171 | | } |