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/IoT.Shared/Areas/Admin/Controlls/DataController.cs

62 lines
2.5 KiB

using Application.Domain.Entities;
using Application.Models;
using Infrastructure.Data;
using Infrastructure.Extensions;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using Microsoft.EntityFrameworkCore;
using System;
using System.Linq;
namespace IoT.Shared.Areas.Admin.Controlls
{
[Authorize]
[Area(nameof(Admin))]
public class DataController : SharedController<Data, SearchDataModel, EditDataModel, EditDataModel>
{
private readonly IRepository<Node> _nodeRepo;
private readonly AjaxController _ajax;
public DataController(IRepository<Node> nodeRepo, IRepository<Data> repo, AjaxController ajax, IServiceProvider sp) : base(repo, sp)
{
this._nodeRepo = nodeRepo;
this._ajax = ajax;
}
public override IQueryable<Data> Include(IQueryable<Data> query)
{
return query.Include(o => o.Device).ThenInclude(o => o.Node);
}
public override IQueryable<Data> Query(SearchDataModel model, IQueryable<Data> query)
{
ViewData.SelectList(o => model.NodeId, () => this._ajax.GetNodeSelectList(model.NodeId));
ViewData.SelectList(o => model.DeviceId, () => this._ajax.GetDeviceSelectList(model.NodeId.Value, model.DeviceId), model.NodeId.HasValue);
return query.WhereIf(model.NodeId.HasValue, o => o.Device.NodeId == model.NodeId.Value)
.WhereIf(model.DeviceId.HasValue, o => o.DeviceId == model.DeviceId.Value)
.WhereIf(!string.IsNullOrEmpty(model.Keyword), o => o.Name.Contains(model.Keyword));
}
public override void ToDisplayModel(Data entity, EditDataModel model)
{
model.NodeId = entity?.Device?.NodeId;
ViewData.Add(model.DeviceId, entity.Device.Name);
ViewData.Add(model.NodeId, entity.Device.Node.Name);
}
public override void ToEditModel(Data entity, EditDataModel model)
{
if (entity != null)
{
this.ToDisplayModel(entity, model);
}
ViewData.SelectList(o => model.NodeId, () => this._ajax.GetNodeSelectList(model.NodeId));
ViewData.SelectList(o => model.DeviceId, () => this._ajax.GetDeviceSelectList(model.NodeId.Value, model.DeviceId), model.NodeId.HasValue);
}
public override string GetNodeNumber(EditDataModel model)
{
return this._nodeRepo.ReadOnlyTable().Where(o => o.Id == model.NodeId).Select(o => o.Number).FirstOrDefault();
}
}
}