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
}
}