using Infrastructure.Data; using Infrastructure.Extensions; using IoT.Shared.Application.Domain.Entities; using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Mvc.Rendering; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Logging; using System; using System.Collections.Generic; using System.Linq; namespace Platform.Areas.IoTCenter.Controllers { [Area("IoTCenter")] public class AjaxController : IoT.Shared.Areas.IoTCenter.Controlls.AjaxBaseController { private readonly IRepository _roleRepo; public AjaxController(IServiceProvider services, ILogger logger, IRepository categoryRepo, IRepository productRepo, IRepository organRepo, IRepository buildingIoTGatewayRepo, IRepository organSceneRepo, IRepository nodeRepo, IRepository sceneRepo, IRepository commandRepo, IRepository deviceRepo, IRepository dataRepo, IRepository apiRepo, IRepository sceneTiggerRepo) : base(services, logger, categoryRepo, productRepo, organRepo, buildingIoTGatewayRepo, organSceneRepo, nodeRepo, sceneRepo, commandRepo, deviceRepo, dataRepo, apiRepo, sceneTiggerRepo) { } public JsonResult GetArea(Guid? selected = null, Guid? currentId = null, string search = null) { using var scope = this._services.CreateScope(); var repo = scope.ServiceProvider.GetRequiredService>(); var list = repo.ReadOnlyTable() .Where(o => o.ParentId != null) .WhereIf(selected.HasValue, o => o.Id == selected.Value) .WhereIf(!string.IsNullOrEmpty(search), o => o.Name.Contains(search) || o.Number.Contains(search)) .WhereIf(currentId.HasValue, o => o.Id != currentId.Value) .OrderBy(o => o.Parent) .ThenBy(o => o.DisplayOrder) .Select(o => new { o.Id, Name = $"{o.Name}:{o.Number}" }) .Take(20) .ToList(); return new JsonResult(new SelectList(list, "Id", "Name", selected)); } public JsonResult GetOrganBuilding(Guid parentId, Guid? selected = null, Guid? currentId = null) { using var scope = this._services.CreateScope(); var repo = scope.ServiceProvider.GetRequiredService>(); var list = repo.ReadOnlyTable() .Where(o => o.ParentId != null) .Where(o => o.OrganId == parentId) .WhereIf(currentId.HasValue, o => o.Id != currentId.Value) .OrderBy(o => o.Parent) .ThenBy(o => o.DisplayOrder) .Select(o => new { o.Id, Name = $"{o.Name}({o.Number})" }) .ToList(); return new JsonResult(new SelectList(list, "Id", "Name", selected)); } public MultiSelectList GetOrganMultiSelectList(List selected) { if (selected == null) { selected = new List(); } var list = this._organRepo.ReadOnlyTable() .Where(o => o.ParentId != null) .Select(o => new { o.Id, o.Name }) .ToList(); return new MultiSelectList(list, "Id", "Name", selected); } [ApiExplorerSettings(IgnoreApi = true)] public MultiSelectList GetRoleMultiSelectList(IEnumerable selected) { if (selected == null) { selected = new List(); } var list = this._roleRepo.ReadOnlyTable() .Select(o => new { o.Id, o.Name }) .ToList(); return new MultiSelectList(list, "Id", "Name", selected); } } }