You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
iot/projects/IoTCenter/Areas/Admin/Controllers/OrganSceneTiggerController.cs

75 lines
3.7 KiB

using Application.Domain.Entities;
using Infrastructure.Application;
using Infrastructure.Data;
using Infrastructure.Extensions;
using Infrastructure.Web.Mvc;
using IoT.Shared.Areas.Admin.Controlls;
using IoTCenter.Application.Models;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.DependencyInjection;
using System;
using System.Linq;
namespace IoTCenter.Areas.Admin.Controllers
{
[Authorize]
[Area(nameof(Admin))]
public class OrganSceneTiggerController : CrudController<OrganSceneTigger, EditOrganSceneTiggerModel>
{
private readonly AjaxController _ajax;
private readonly IServiceProvider _sp;
public OrganSceneTiggerController(IRepository<OrganSceneTigger> repo, AjaxController ajax, IServiceProvider sp) : base(repo)
{
this._ajax = ajax;
this._sp = sp;
}
public override IQueryable<OrganSceneTigger> Include(IQueryable<OrganSceneTigger> query)
{
return query
.Include(o => o.OrganScene)
.Include(o => o.Data).ThenInclude(o => o.Device).ThenInclude(o => o.Node);
}
public override IQueryable<OrganSceneTigger> Query(PagedListModel<EditOrganSceneTiggerModel> model, IQueryable<OrganSceneTigger> query)
{
return query
.WhereIf(model.Query.OrganId.HasValue, o => o.OrganScene.OrganId == model.Query.OrganId.Value)
.WhereIf(model.Query.NodeId.HasValue, o => o.Data.Device.NodeId == model.Query.NodeId.Value)
.WhereIf(model.Query.OrganSceneId.HasValue, o => o.OrganSceneId == model.Query.OrganSceneId.Value)
.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))
.WhereIf(!string.IsNullOrEmpty(model.Query.Name), o => o.Name.Contains(model.Query.Name))
.WhereIf(model.Query.Disabled.HasValue, o => o.Disabled == model.Query.Disabled.Value)
.OrderBy(o => o.OrganSceneId);
}
public override void ToEditModel(OrganSceneTigger entity, EditOrganSceneTiggerModel model)
{
this.ToDisplayModel(entity, model);
ViewData.SelectList(o => model.OrganId, () => this._ajax.GetOrganSelectList(model.OrganId));
ViewData.SelectList(o => model.NodeId, () => this._ajax.GetNodeSelectList(model.NodeId), model.OrganId.HasValue);
ViewData.SelectList(o => model.OrganSceneId, () => this._ajax.GetOrganSceneSelectList(model.OrganId.Value, model.OrganSceneId), model.OrganId.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(OrganSceneTigger entity, EditOrganSceneTiggerModel model)
{
if (entity != null)
{
model.OrganId = entity.OrganScene.OrganId;
model.DeviceId = entity.Data.DeviceId;
model.NodeId = entity.Data.Device.NodeId;
ViewData.Add(model.NodeId, entity.Data.Device.Node.Name);
ViewData.Add(model.OrganSceneId, entity.OrganScene.Name);
ViewData.Add(model.DataId, entity.Data.Name);
ViewData.Add(model.DeviceId, entity.Data.Device.DisplayName);
}
}
}
}