using Microsoft.AspNetCore.Mvc; using System.Net; using System.Net.Http.Headers; using Microsoft.Extensions.Hosting.Internal; using Microsoft.AspNetCore.Http.Extensions; using IStation.Untity; using Furion.DynamicApiController; using System.ComponentModel.DataAnnotations; using Mapster; namespace IStation.Application { /// /// PumpCurveMapping /// [Route("Product/PumpCurveMapping")] [ApiDescriptionSettings("Product", Name = "泵曲线映射", Order = 390)] public partial class PumpCurveMapping_Controller : IDynamicApiController { private readonly Service.PumpCurveMapping _service = new Service.PumpCurveMapping(); #region Query /// /// 通过 CorpID 获取 /// [Route("GetByCorpID@V1.0")] [HttpGet] public List GetByCorpID([FromQuery][Required] CorpIDInput input) { var list = _service.GetByCorpID(input.CorpID); var vm_list = list?.Select(x => x.Adapt()).ToList(); return vm_list; } /// /// 通过 ID 获取 /// [Route("GetByID@V1.0")] [HttpGet] public PumpCurveMappingDto GetByID([FromQuery][Required] IDUnderCorpInput input) { var model = _service.GetByID(input.CorpID, input.ID); return model?.Adapt(); } /// /// 通过 Ids 获取 /// [Route("GetByIds@V1.0")] [HttpGet] public List GetByIds([FromQuery][Required] IdsUnderCorpInput input) { var ids = LongListHelper.ToList(input.Ids); var list = _service.GetByIds(input.CorpID, ids); var vm_list = list?.Select(x => x.Adapt()).ToList(); return vm_list; } /// /// 通过 PumpID 获取 /// [Route("GetByPumpID@V1.0")] [HttpGet] public List GetByPumpID ( [Required, Range(1, long.MaxValue, ErrorMessage = "CorpID 必须大于0")] long CorpID, [Required, Range(1, long.MaxValue, ErrorMessage = "PumpID 必须大于0")] long PumpID ) { var list = _service.GetByPumpID(CorpID, PumpID); var vm_list = list?.Select(x => x.Adapt()).ToList(); return vm_list; } /// /// 通过 CurveID 获取 /// [Route("GetByCurveID@V1.0")] [HttpGet] public List GetByCurveID ( [Required, Range(1, long.MaxValue, ErrorMessage = "CorpID 必须大于0")] long CorpID, [Required, Range(1, long.MaxValue, ErrorMessage = "CurveID 必须大于0")] long CurveID ) { var list = _service.GetByCurveID(CorpID, CurveID); var vm_list = list?.Select(x => x.Adapt()).ToList(); return vm_list; } /// /// 通过 PumpID 获取 /// [Route("IsExistByPumpID@V1.0")] [HttpGet] public bool IsExistByPumpID ( [Required, Range(1, long.MaxValue, ErrorMessage = "CorpID 必须大于0")] long CorpID, [Required, Range(1, long.MaxValue, ErrorMessage = "PumpID 必须大于0")] long PumpID ) { var bol = _service.IsExistByPumpID(CorpID, PumpID); return bol; } /// /// 通过 CurveID 获取 /// [Route("IsExistByCurveID@V1.0")] [HttpGet] public bool IsExistByCurveID ( [Required, Range(1, long.MaxValue, ErrorMessage = "CorpID 必须大于0")] long CorpID, [Required, Range(1, long.MaxValue, ErrorMessage = "CurveID 必须大于0")] long CurveID ) { var bol = _service.IsExistByCurveID(CorpID, CurveID); return bol; } #endregion #region Insert /// /// 插入一条 /// [Route("Insert@V1.0")] [HttpPost] public long Insert(AddPumpCurveMappingInput input) { if (input == null) return default; var model = input.Adapt(); var id = _service.Insert(model); return id; } /// /// 插入多条 /// [Route("Inserts@V1.0")] [HttpPost] public bool Inserts(List inputList) { if (inputList == null || inputList.Count < 1) return false; var list = inputList.Select(x => x.Adapt()).ToList(); var bol = _service.Inserts(list); return bol; } #endregion #region Update /// /// 更新一条 /// [Route("Update@V1.0")] [HttpPut] public bool Update(UpdatePumpCurveMappingInput input) { if (input == null) return false; var model = _service.GetByID(input.CorpID, input.ID); if (model == null) return false; var rhs = new Model.PumpCurveMapping(model); input.Adapt(rhs); var bol = _service.Update(rhs); return bol; } /// /// 更新多条 /// [Route("Updates@V1.0")] [HttpPut] public bool Updates(List inputList) { if (inputList == null || inputList.Count() < 1) { return false; } var corpIds = inputList.Select(x => x.CorpID).Distinct().ToList(); if (corpIds.Count > 1) return false; var modelList = _service.GetByIds(corpIds[0], inputList.Select(x => x.ID).ToList()); if (modelList == null || modelList.Count < 1) return false; var rhsList = new List(); modelList.ForEach(x => { var input = inputList.Find(t => t.ID == x.ID); if (input != null) { var rhs = new Model.PumpCurveMapping(x); input.Adapt(rhs); rhsList.Add(rhs); } }); if (rhsList.Count < 1) return false; var bol = _service.Updates(rhsList); return bol; } /// /// 更新排序码 /// [Route("UpdateSortCode@V1.0")] [HttpPut] public bool UpdateSortCode([Required] UpdateSortCodeUnderCorpInput input) { var bol = _service.UpdateSortCode(input.CorpID, input.ID, input.SortCode); return bol; } /// /// 更新排序 /// [Route("UpdateSorter@V1.0")] [HttpPut] public bool UpdateSorter([Required] UpdateSorterUnderCorpInput input) { if (input.Sorters == null || input.Sorters.Count < 1) return false; var list = input.Sorters.Select(x => x.Adapt()).ToList(); var bol = _service.UpdateSorter(input.CorpID, list); return bol; } #endregion #region Set /// /// 设置工作曲线 /// [Route("SetWorkingCurve@V1.0")] [HttpPost] public bool SetWorkingCurve([Required] SetWorkingCurveInput input) { var bol = _service.SetWorkingCurve(input.CorpID, input.PumpID, input.ID) ; return bol; } /// /// 设置 /// [Route("SetByCurveID@V1.0")] [HttpPost] public bool SetByCurveID([Required] SetObjectPumpCurveMappingInput input) { var list = new List(); if (input.Items != null && input.Items.Count > 0) { if (input.Items.GroupBy(x => x.PumpID).Count() > 1) { throw new Exception("PumpID存在重复项"); } list = input.Items.Select(x => new Model.PumpCurveMapping() { CorpID = input.CorpID, CurveID = input.CorpID, ID = x.ID, PumpID = x.PumpID, OtherName = x.OtherName, IsWorking = x.IsWorking, SortCode = x.SortCode, }).ToList(); } var bol = _service.SetByCurveID(input.CorpID, input.CurveID, list); return bol; } #endregion #region Delete /// /// 通过 ID 删除 /// [Route("DeleteByID@V1.0")] [HttpDelete] public DeleteReasonOutput DeleteByID([FromQuery][Required] IDUnderCorpInput input) { var bol = _service.DeleteByID(input.CorpID, input.ID, out string Msg); return new DeleteReasonOutput() { Success = bol, Reason = Msg }; } /// /// 通过 ID 删除 同时删除曲线 /// [Route("DeleteWithCurveByID@V1.0")] [HttpDelete] public DeleteReasonOutput DeleteWithCurveByID([FromQuery][Required] IDUnderCorpInput input) { var bol = _service.DeleteWithCurveByID(input.CorpID, input.ID, out string Msg); return new DeleteReasonOutput() { Success = bol, Reason = Msg }; } #endregion } }