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;
}
#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
#region Set
///
/// 设置
///
[Route("SetOfObject@V1.0")]
[HttpPost]
public bool SetOfObject([Required] SetObjectPumpCurveMappingInput input)
{
var 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.SetOfObject(input.CorpID, input.CurveID, list);
return bol;
}
#endregion
}
}