AdoS0MaterialsController.cs 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  1. using Admin.NET.Plugin.AiDOP.Dto.S0.Sales;
  2. using Admin.NET.Plugin.AiDOP.Entity.S0.Sales;
  3. using Admin.NET.Plugin.AiDOP.Infrastructure;
  4. namespace Admin.NET.Plugin.AiDOP.Controllers.S0.Sales;
  5. /// <summary>
  6. /// S0 物料主数据(ItemMaster 语义)
  7. /// </summary>
  8. [ApiController]
  9. [Route("api/s0/sales/materials")]
  10. [AllowAnonymous]
  11. [NonUnify]
  12. public class AdoS0MaterialsController : ControllerBase
  13. {
  14. private readonly SqlSugarRepository<AdoS0ItemMaster> _rep;
  15. public AdoS0MaterialsController(SqlSugarRepository<AdoS0ItemMaster> rep)
  16. {
  17. _rep = rep;
  18. }
  19. [HttpGet]
  20. public async Task<IActionResult> GetPagedAsync([FromQuery] AdoS0ItemMasterQueryDto q)
  21. {
  22. (q.Page, q.PageSize) = PagingGuard.Normalize(q.Page, q.PageSize);
  23. var query = _rep.AsQueryable()
  24. .WhereIF(q.CompanyRefId.HasValue, x => x.CompanyRefId == q.CompanyRefId.Value)
  25. .WhereIF(q.FactoryRefId.HasValue, x => x.FactoryRefId == q.FactoryRefId.Value)
  26. .WhereIF(!string.IsNullOrWhiteSpace(q.DomainCode), x => x.DomainCode == q.DomainCode)
  27. .WhereIF(!string.IsNullOrWhiteSpace(q.ItemNum), x => x.ItemNum.Contains(q.ItemNum!))
  28. .WhereIF(!string.IsNullOrWhiteSpace(q.Descr), x => x.Descr.Contains(q.Descr!))
  29. .WhereIF(!string.IsNullOrWhiteSpace(q.Descr1), x => x.Descr1 != null && x.Descr1.Contains(q.Descr1!))
  30. .WhereIF(!string.IsNullOrWhiteSpace(q.ItemType), x => x.ItemType == q.ItemType)
  31. .WhereIF(!string.IsNullOrWhiteSpace(q.PurMfg), x => x.PurMfg == q.PurMfg)
  32. .WhereIF(!string.IsNullOrWhiteSpace(q.Location), x => x.Location != null && x.Location.Contains(q.Location!))
  33. .WhereIF(!string.IsNullOrWhiteSpace(q.Status), x => x.Status == q.Status)
  34. .WhereIF(q.IsActive.HasValue, x => x.IsActive == q.IsActive.Value)
  35. .WhereIF(q.IsConfirm.HasValue, x => x.IsConfirm == q.IsConfirm.Value)
  36. .WhereIF(
  37. !string.IsNullOrWhiteSpace(q.Keyword),
  38. x => x.ItemNum.Contains(q.Keyword!) || x.Descr.Contains(q.Keyword!));
  39. var total = await query.CountAsync();
  40. var list = await query
  41. .OrderByDescending(x => x.CreateTime)
  42. .Skip((q.Page - 1) * q.PageSize)
  43. .Take(q.PageSize)
  44. .ToListAsync();
  45. foreach (var x in list)
  46. x.LocationDescr = FormatLocationDescr(x.Location, null);
  47. return Ok(new { total, page = q.Page, pageSize = q.PageSize, list });
  48. }
  49. [HttpGet("{id:long}")]
  50. public async Task<IActionResult> GetAsync(long id)
  51. {
  52. var item = await _rep.GetByIdAsync(id);
  53. if (item == null) return NotFound();
  54. item.LocationDescr = FormatLocationDescr(item.Location, null);
  55. return Ok(item);
  56. }
  57. [HttpPost]
  58. public async Task<IActionResult> CreateAsync([FromBody] AdoS0ItemMasterUpsertDto dto)
  59. {
  60. if (await _rep.IsAnyAsync(x =>
  61. x.CompanyRefId == dto.CompanyRefId &&
  62. x.FactoryRefId == dto.FactoryRefId &&
  63. x.ItemNum == dto.ItemNum))
  64. {
  65. return AdoS0ApiErrors.Conflict(AdoS0ErrorCodes.MaterialCodeExists, "物料编码已存在");
  66. }
  67. var now = DateTime.Now;
  68. var entity = MapDtoToNewEntity(dto, now);
  69. entity.Status = ResolveStatus(dto);
  70. await _rep.AsInsertable(entity).ExecuteReturnEntityAsync();
  71. return Ok(entity);
  72. }
  73. [HttpPut("{id:long}")]
  74. public async Task<IActionResult> UpdateAsync(long id, [FromBody] AdoS0ItemMasterUpsertDto dto)
  75. {
  76. var entity = await _rep.GetByIdAsync(id);
  77. if (entity == null) return NotFound();
  78. if (await _rep.IsAnyAsync(x =>
  79. x.Id != id &&
  80. x.CompanyRefId == dto.CompanyRefId &&
  81. x.FactoryRefId == dto.FactoryRefId &&
  82. x.ItemNum == dto.ItemNum))
  83. {
  84. return AdoS0ApiErrors.Conflict(AdoS0ErrorCodes.MaterialCodeExists, "物料编码已存在");
  85. }
  86. ApplyDtoToEntity(entity, dto);
  87. entity.Status = ResolveStatus(dto);
  88. entity.UpdateTime = DateTime.Now;
  89. await _rep.AsUpdateable(entity).ExecuteCommandAsync();
  90. return Ok(entity);
  91. }
  92. [HttpPatch("{id:long}/toggle-enabled")]
  93. public async Task<IActionResult> ToggleActiveAsync(long id, [FromBody] AdoS0ItemMasterToggleActiveDto dto)
  94. {
  95. var entity = await _rep.GetByIdAsync(id);
  96. if (entity == null) return NotFound();
  97. entity.IsActive = dto.IsActive;
  98. entity.Status = AdoS0SalesRules.ForbidStatusFromIsEnabled(dto.IsActive);
  99. entity.UpdateTime = DateTime.Now;
  100. await _rep.AsUpdateable(entity).ExecuteCommandAsync();
  101. return Ok(entity);
  102. }
  103. [HttpDelete("{id:long}")]
  104. public async Task<IActionResult> DeleteAsync(long id)
  105. {
  106. var item = await _rep.GetByIdAsync(id);
  107. if (item == null) return NotFound();
  108. await _rep.DeleteAsync(item);
  109. return Ok(new { message = "删除成功" });
  110. }
  111. private static string ResolveStatus(AdoS0ItemMasterUpsertDto dto) =>
  112. string.IsNullOrWhiteSpace(dto.Status)
  113. ? AdoS0SalesRules.ForbidStatusFromIsEnabled(dto.IsActive)
  114. : dto.Status!;
  115. private static string FormatLocationDescr(string? location, string? locationMasterDescr)
  116. {
  117. var a = location?.Trim();
  118. var b = locationMasterDescr?.Trim();
  119. if (string.IsNullOrEmpty(a)) return b ?? string.Empty;
  120. if (string.IsNullOrEmpty(b)) return a;
  121. return $"{a} {b}".Trim();
  122. }
  123. private static AdoS0ItemMaster MapDtoToNewEntity(AdoS0ItemMasterUpsertDto dto, DateTime now) => new()
  124. {
  125. CompanyRefId = dto.CompanyRefId,
  126. FactoryRefId = dto.FactoryRefId,
  127. DomainCode = dto.DomainCode,
  128. ItemNum = dto.ItemNum,
  129. Descr = dto.Descr,
  130. Descr1 = dto.Descr1,
  131. PkgCode = dto.PkgCode,
  132. UM = dto.UM,
  133. PurMfg = dto.PurMfg,
  134. Drawing = dto.Drawing,
  135. ItemType = dto.ItemType,
  136. Location = dto.Location,
  137. DefaultShelf = dto.DefaultShelf,
  138. KeyItem = dto.KeyItem,
  139. NetWeight = dto.NetWeight,
  140. NetWeightUM = dto.NetWeightUM,
  141. Inspect = dto.Inspect,
  142. PurLT = dto.PurLT,
  143. InsLT = dto.InsLT,
  144. MfgLT = dto.MfgLT,
  145. Length = dto.Length,
  146. Size = dto.Size,
  147. SizeUM = dto.SizeUM,
  148. IssuePolicy = dto.IssuePolicy,
  149. MfgMttr = dto.MfgMttr,
  150. LocationType = dto.LocationType,
  151. CommodityCode = dto.CommodityCode,
  152. Rev = dto.Rev,
  153. MaxOrd = dto.MaxOrd,
  154. MinOrd = dto.MinOrd,
  155. OrdMult = dto.OrdMult,
  156. MinOrdSales = dto.MinOrdSales,
  157. AutoLotNums = dto.AutoLotNums,
  158. Install = dto.Install,
  159. SafetyStk = dto.SafetyStk,
  160. DaysBetweenPM = dto.DaysBetweenPM,
  161. ExpireAlarmDay = dto.ExpireAlarmDay,
  162. StockTurnOver = dto.StockTurnOver,
  163. LotSerialControl = dto.LotSerialControl,
  164. AllocateSingleLot = dto.AllocateSingleLot,
  165. Planner = dto.Planner,
  166. TraceDetail = dto.TraceDetail,
  167. IsMainMas = dto.IsMainMas,
  168. Remark = dto.Remark,
  169. EMTType = dto.EMTType,
  170. OwnerApplication = dto.OwnerApplication,
  171. BOMDesign = dto.BOMDesign,
  172. RoutingDes = dto.RoutingDes,
  173. IsActive = dto.IsActive,
  174. IsConfirm = dto.IsConfirm,
  175. CreateUser = dto.CreateUser,
  176. CreateTime = now,
  177. UpdateUser = dto.UpdateUser,
  178. UpdateTime = null
  179. };
  180. private static void ApplyDtoToEntity(AdoS0ItemMaster entity, AdoS0ItemMasterUpsertDto dto)
  181. {
  182. entity.CompanyRefId = dto.CompanyRefId;
  183. entity.FactoryRefId = dto.FactoryRefId;
  184. entity.DomainCode = dto.DomainCode;
  185. entity.ItemNum = dto.ItemNum;
  186. entity.Descr = dto.Descr;
  187. entity.Descr1 = dto.Descr1;
  188. entity.PkgCode = dto.PkgCode;
  189. entity.UM = dto.UM;
  190. entity.PurMfg = dto.PurMfg;
  191. entity.Drawing = dto.Drawing;
  192. entity.ItemType = dto.ItemType;
  193. entity.Location = dto.Location;
  194. entity.DefaultShelf = dto.DefaultShelf;
  195. entity.KeyItem = dto.KeyItem;
  196. entity.NetWeight = dto.NetWeight;
  197. entity.NetWeightUM = dto.NetWeightUM;
  198. entity.Inspect = dto.Inspect;
  199. entity.PurLT = dto.PurLT;
  200. entity.InsLT = dto.InsLT;
  201. entity.MfgLT = dto.MfgLT;
  202. entity.Length = dto.Length;
  203. entity.Size = dto.Size;
  204. entity.SizeUM = dto.SizeUM;
  205. entity.IssuePolicy = dto.IssuePolicy;
  206. entity.MfgMttr = dto.MfgMttr;
  207. entity.LocationType = dto.LocationType;
  208. entity.CommodityCode = dto.CommodityCode;
  209. entity.Rev = dto.Rev;
  210. entity.MaxOrd = dto.MaxOrd;
  211. entity.MinOrd = dto.MinOrd;
  212. entity.OrdMult = dto.OrdMult;
  213. entity.MinOrdSales = dto.MinOrdSales;
  214. entity.AutoLotNums = dto.AutoLotNums;
  215. entity.Install = dto.Install;
  216. entity.SafetyStk = dto.SafetyStk;
  217. entity.DaysBetweenPM = dto.DaysBetweenPM;
  218. entity.ExpireAlarmDay = dto.ExpireAlarmDay;
  219. entity.StockTurnOver = dto.StockTurnOver;
  220. entity.LotSerialControl = dto.LotSerialControl;
  221. entity.AllocateSingleLot = dto.AllocateSingleLot;
  222. entity.Planner = dto.Planner;
  223. entity.TraceDetail = dto.TraceDetail;
  224. entity.IsMainMas = dto.IsMainMas;
  225. entity.Remark = dto.Remark;
  226. entity.EMTType = dto.EMTType;
  227. entity.OwnerApplication = dto.OwnerApplication;
  228. entity.BOMDesign = dto.BOMDesign;
  229. entity.RoutingDes = dto.RoutingDes;
  230. entity.IsActive = dto.IsActive;
  231. entity.IsConfirm = dto.IsConfirm;
  232. entity.UpdateUser = dto.UpdateUser;
  233. }
  234. }