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; using Furion.DataValidation; namespace IStation.Application { /// /// CorpDictData /// [Route("Basic/CorpDictData")] [ApiDescriptionSettings("Basic", Name = "客户字典值", Order = 989)] public class CorpDictData_Controller : IDynamicApiController { private readonly Service.CorpDictData _service = new Service.CorpDictData(); #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 => new CorpDictDataDto(x)).ToList(); return vm_list; } /// /// 通过 ID 获取 /// [Route("GetByID@V1.0")] [HttpGet] public CorpDictDataDto GetByID([FromQuery][Required] IDUnderCorpInput input) { var model = _service.GetByID(input.CorpID, input.ID); return model == null ? null : new CorpDictDataDto(model); } /// /// 通过 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 => new CorpDictDataDto(x)).ToList(); return vm_list; } /// /// 通过 TypeID 获取 /// [Route("GetByTypeID@V1.0")] [HttpGet] public List GetByTypeID ( [Required,Range(1,long.MaxValue,ErrorMessage ="CorpID 必须大于0")] long CorpID, [Required,Range(1,long.MaxValue,ErrorMessage ="TypeID 必须大于0")] long TypeID ) { var list=_service.GetByTypeID(CorpID, TypeID); var vm_list = list?.Select(x => new CorpDictDataDto(x)).ToList(); return vm_list; } /// /// 通过 TypeID 获取在用 /// [Route("GetUseByTypeID@V1.0")] [HttpGet] public List GetUseByTypeID ( [Required,Range(1,long.MaxValue,ErrorMessage ="CorpID 必须大于0")] long CorpID, [Required,Range(1,long.MaxValue,ErrorMessage ="TypeID 必须大于0")] long TypeID ) { var list = _service.GetUseByTypeID(CorpID, TypeID); var vm_list = list?.Select(x => new CorpDictDataDto(x)).ToList(); return vm_list; } /// /// 通过类型 Code 获取 /// [Route("GetByTypeCode@V1.0")] [HttpGet] public List GetByTypeCode ( [Required,Range(1,long.MaxValue,ErrorMessage ="CorpID 必须大于0")] long CorpID, [Required,DataValidation(AllowEmptyStrings =false)] string Code ) { var list = _service.GetByTypeCode(CorpID, Code); var vm_list = list?.Select(x => new CorpDictDataDto(x)).ToList(); return vm_list; } /// /// 通过类型 Code 获取 /// [Route("GetUseByTypeCode@V1.0")] [HttpGet] public List GetUseByTypeCode ( [Required,Range(1,long.MaxValue,ErrorMessage ="CorpID 必须大于0")] long CorpID, [Required,DataValidation(AllowEmptyStrings =false)] string Code ) { var list = _service.GetUseByTypeCode(CorpID, Code); var vm_list = list?.Select(x => new CorpDictDataDto(x)).ToList(); return vm_list; } /// /// 通过 TypeID 获取分页列表 /// [Route("GetPageListByTypeID@V1.0")] [HttpGet] public PageListOutput GetPageListByTypeID ( [Required,Range(1,long.MaxValue,ErrorMessage ="CorpID 必须大于0")] long CorpID, [Required, Range(1, long.MaxValue, ErrorMessage = "TypeID 必须大于0")] long TypeID, [Required, Range(1, int.MaxValue, ErrorMessage = "PageIndex 必须大于0")] int PageIndex, [Required, Range(1, int.MaxValue, ErrorMessage = "PageSize 必须大于0")] int PageSize ) { var list = _service.GetPageListByTypeID(CorpID, TypeID,PageIndex,PageSize,out int Total); var vm_list = list?.Select(x => new CorpDictDataDto(x)).ToList(); return new PageListOutput() { Total=Total,List=vm_list}; } /// /// 通过 TypeID 获取在用分页列表 /// [Route("GetUsePageListByTypeID@V1.0")] [HttpGet] public PageListOutput GetUsePageListByTypeID ( [Required,Range(1,long.MaxValue,ErrorMessage ="CorpID 必须大于0")] long CorpID, [Required, Range(1, long.MaxValue, ErrorMessage = "TypeID 必须大于0")] long TypeID, [Required, Range(1, int.MaxValue, ErrorMessage = "PageIndex 必须大于0")] int PageIndex, [Required, Range(1, int.MaxValue, ErrorMessage = "PageSize 必须大于0")] int PageSize ) { var list = _service.GetUsePageListByTypeID(CorpID, TypeID, PageIndex, PageSize, out int Total); var vm_list = list?.Select(x => new CorpDictDataDto(x)).ToList(); return new PageListOutput() { Total = Total, List = vm_list }; } #endregion #region Insert /// /// 插入一条 /// [Route("Insert@V1.0")] [HttpPost] public long Insert(AddCorpDictDataInput 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(UpdateCorpDictDataInput input) { if (input == null) return false; var model = _service.GetByID(input.CorpID, input.ID); if (model == null) return false; var rhs = new Model.CorpDictData(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 || corpIds[0] < 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.CorpDictData(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(UpdateSortCodeUnderCorpInput input) { if (input == null) return false; var bol = _service.UpdateSortCode(input.CorpID, input.ID, input.SortCode); return bol; } /// /// 更新排序 /// [Route("UpdateSorter@V1.0")] [HttpPut] public bool UpdateSorter(List inputList) { if (inputList == null || inputList.Count() < 1) { return false; } var corpIds = inputList.Select(x => x.CorpID).Distinct().ToList(); if (corpIds.Count != 1 || corpIds[0] < 1) return false; var list = inputList.Select(x => x.Adapt()).ToList(); var bol = _service.UpdateSorter(corpIds[0], list); return bol; } /// /// 更新使用状态 /// [Route("UpdateUseStatus@V1.0")] [HttpPut] public bool UpdateUseStatus([Required] UpdateUseStatusUnderCorpInput input) { var bol = _service.UpdateUseStatus(input.CorpID, input.ID, input.UseStatus); return bol; } #endregion #region Exist /// /// 判断 Code 是否存在 /// [Route("IsExistCode@V1.0")] [HttpGet] public bool IsExistCode ( [Required,Range(1,long.MaxValue,ErrorMessage ="CorpID 必须大于0")] long CorpID, [Required,DataValidation(AllowEmptyStrings =false)] string Code ) { var bol = _service.IsExistCode(CorpID, Code); return bol; } /// /// 判断 Code 是否存在 ExceptID /// [Route("IsExistCodeExceptID@V1.0")] [HttpGet] public bool IsExistCodeExceptID ( [Required,Range(1,long.MaxValue,ErrorMessage ="CorpID 必须大于0")] long CorpID, [Required,DataValidation(AllowEmptyStrings =false)] string Code, [Required,Range(1,long.MaxValue,ErrorMessage ="ExceptID 必须大于0")] long ExceptID ) { var bol = _service.IsExistCodeExceptID(CorpID, Code, ExceptID); 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 }; } /// /// 通过 TypeID 删除 /// [Route("DeleteByTypeID@V1.0")] [HttpDelete] public DeleteReasonOutput DeleteByTypeID ( [Required,Range(1,long.MaxValue,ErrorMessage ="CorpID 必须大于0")] long CorpID, [Required, Range(1, long.MaxValue, ErrorMessage = "TypeID 必须大于0")] long TypeID ) { var bol = _service.DeleteByTypeID(CorpID, TypeID, out string msg); return new DeleteReasonOutput() { Success = bol, Reason = msg }; } #endregion } }