using Application.Domain.Entities; using Application.Models; using Infrastructure.Application; using Infrastructure.Data; using Infrastructure.Extensions; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using Microsoft.EntityFrameworkCore; using NPOI.SS.Formula.Functions; using System; using System.Linq; namespace IoT.Shared.Areas.Admin.Controlls { [Authorize] [Area(nameof(Admin))] public class SceneTiggerController : SharedController { private readonly IRepository _nodeRepo; private readonly IRepository _deviceRepo; private readonly IRepository _dataRepo; private readonly AjaxController _ajax; public SceneTiggerController(IRepository nodeRepo, IRepository repo, IRepository deviceRepo, IRepository dataRepo, AjaxController ajax, IServiceProvider sp) : base(repo, sp) { this._nodeRepo = nodeRepo; this._deviceRepo = deviceRepo; this._dataRepo = dataRepo; this._ajax = ajax; } public override IQueryable Include(IQueryable query) { return query.Include(o => o.Scene).ThenInclude(o => o.Node).Include(o => o.Data).ThenInclude(o => o.Device); } public override IQueryable Query(PagedListModel model, IQueryable query) { return query.Where(o => o.Scene.NodeId != null) .WhereIf(model.Query.NodeId.HasValue, o => o.Scene.NodeId == model.Query.NodeId) .WhereIf(model.Query.SceneId.HasValue, o => o.SceneId == model.Query.SceneId) .WhereIf(model.Query.DeviceId.HasValue, o => o.Data.DeviceId == model.Query.DeviceId.Value) .WhereIf(model.Query.DataId.HasValue, o => o.DataId == model.Query.DataId.Value) .WhereIf(!string.IsNullOrEmpty(model.Query.Condition), o => o.Condition.Contains(model.Query.Condition, StringComparison.OrdinalIgnoreCase)) .WhereIf(!string.IsNullOrEmpty(model.Query.Name), o => o.Name.Contains(model.Query.Name, StringComparison.OrdinalIgnoreCase)) .WhereIf(model.Query.Disabled.HasValue, o => o.Disabled == model.Query.Disabled.Value) .OrderBy(o => o.SceneId); } public override void ToEditModel(SceneTigger entity, EditSceneTiggerModel model) { this.ToDisplayModel(entity, model); ViewData.SelectList(o => model.NodeId, () => this._ajax.GetNodeSelectList(model.NodeId)); ViewData.SelectList(o => model.SceneId, () => this._ajax.GetSceneSelectList(model.NodeId.Value), model.NodeId.HasValue); ViewData.SelectList(o => model.DeviceId, () => this._ajax.GetDeviceSelectList(model.NodeId.Value), model.NodeId.HasValue); ViewData.SelectList(o => model.DataId, () => this._ajax.GetDataSelectList(model.DeviceId.Value), model.DeviceId.HasValue); } public override void ToDisplayModel(SceneTigger entity, EditSceneTiggerModel model) { if (entity != null) { model.NodeId = entity.Data.Device.NodeId; model.DeviceId = entity.Data.DeviceId; ViewData.Add(model.SceneId, entity.Scene.Name); ViewData.Add(model.NodeId, entity.Scene.Node.Name); ViewData.Add(model.DataId, entity.Data.Name); ViewData.Add(model.DeviceId, entity.Data.Device.DisplayName); } } public override string GetNodeNumber(EditSceneTiggerModel model) { return this._nodeRepo.ReadOnlyTable().Where(o => o.Id == model.NodeId).Select(o => o.Number).FirstOrDefault(); } } }