AdoS0MfgLineMaterialsController.cs 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. using Admin.NET.Plugin.AiDOP.Dto.S0.Manufacturing;
  2. using Admin.NET.Plugin.AiDOP.Dto.S0.Sales;
  3. using Admin.NET.Plugin.AiDOP.Entity.S0.Manufacturing;
  4. using Admin.NET.Plugin.AiDOP.Infrastructure;
  5. namespace Admin.NET.Plugin.AiDOP.Controllers.S0.Manufacturing;
  6. [ApiController]
  7. [Route("api/s0/manufacturing/line-materials")]
  8. [AllowAnonymous]
  9. [NonUnify]
  10. public class AdoS0MfgLineMaterialsController : ControllerBase
  11. {
  12. private readonly SqlSugarRepository<AdoS0MfgLineMaterial> _rep;
  13. public AdoS0MfgLineMaterialsController(SqlSugarRepository<AdoS0MfgLineMaterial> rep)
  14. {
  15. _rep = rep;
  16. }
  17. [HttpGet]
  18. public async Task<IActionResult> GetPagedAsync([FromQuery] AdoS0MfgLineMaterialQueryDto q)
  19. {
  20. var page = q.EffectivePage;
  21. var pageSize = q.PageSize;
  22. (page, pageSize) = PagingGuard.Normalize(page, 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.Keyword),
  27. x => (x.EquipmentCode != null && x.EquipmentCode.Contains(q.Keyword!))
  28. || (x.RequiredSkillCode != null && x.RequiredSkillCode.Contains(q.Keyword!))
  29. || (x.Remark != null && x.Remark.Contains(q.Keyword!)))
  30. .WhereIF(q.IsEnabled.HasValue, x => x.IsEnabled == q.IsEnabled!.Value);
  31. var total = await query.CountAsync();
  32. var list = await query.OrderByDescending(x => x.CreatedAt).Skip((page - 1) * pageSize).Take(pageSize).ToListAsync();
  33. return Ok(new { total, page, pageSize, list });
  34. }
  35. [HttpGet("{id:long}")]
  36. public async Task<IActionResult> GetAsync(long id)
  37. {
  38. var item = await _rep.GetByIdAsync(id);
  39. return item == null ? NotFound() : Ok(item);
  40. }
  41. [HttpPost]
  42. public async Task<IActionResult> CreateAsync([FromBody] AdoS0MfgLineMaterialUpsertDto dto)
  43. {
  44. var entity = new AdoS0MfgLineMaterial
  45. {
  46. CompanyRefId = dto.CompanyRefId,
  47. FactoryRefId = dto.FactoryRefId,
  48. ProductionLineId = dto.ProductionLineId,
  49. MaterialId = dto.MaterialId,
  50. OperationId = dto.OperationId,
  51. WorkCenterId = dto.WorkCenterId,
  52. EquipmentCode = dto.EquipmentCode,
  53. StdCapacityPerUnit = dto.StdCapacityPerUnit,
  54. ChangeoverTime = dto.ChangeoverTime,
  55. EquipmentTypeCode = dto.EquipmentTypeCode,
  56. MoldTypeCode = dto.MoldTypeCode,
  57. RequiredSkillCode = dto.RequiredSkillCode,
  58. MaterialRole = dto.MaterialRole,
  59. Remark = dto.Remark,
  60. IsEnabled = dto.IsEnabled,
  61. CreatedAt = DateTime.Now
  62. };
  63. await _rep.AsInsertable(entity).ExecuteReturnEntityAsync();
  64. return Ok(entity);
  65. }
  66. [HttpPut("{id:long}")]
  67. public async Task<IActionResult> UpdateAsync(long id, [FromBody] AdoS0MfgLineMaterialUpsertDto dto)
  68. {
  69. var entity = await _rep.GetByIdAsync(id);
  70. if (entity == null) return NotFound();
  71. entity.CompanyRefId = dto.CompanyRefId;
  72. entity.FactoryRefId = dto.FactoryRefId;
  73. entity.ProductionLineId = dto.ProductionLineId;
  74. entity.MaterialId = dto.MaterialId;
  75. entity.OperationId = dto.OperationId;
  76. entity.WorkCenterId = dto.WorkCenterId;
  77. entity.EquipmentCode = dto.EquipmentCode;
  78. entity.StdCapacityPerUnit = dto.StdCapacityPerUnit;
  79. entity.ChangeoverTime = dto.ChangeoverTime;
  80. entity.EquipmentTypeCode = dto.EquipmentTypeCode;
  81. entity.MoldTypeCode = dto.MoldTypeCode;
  82. entity.RequiredSkillCode = dto.RequiredSkillCode;
  83. entity.MaterialRole = dto.MaterialRole;
  84. entity.Remark = dto.Remark;
  85. entity.IsEnabled = dto.IsEnabled;
  86. entity.UpdatedAt = DateTime.Now;
  87. await _rep.AsUpdateable(entity).ExecuteCommandAsync();
  88. return Ok(entity);
  89. }
  90. [HttpPatch("{id:long}/toggle-enabled")]
  91. public async Task<IActionResult> ToggleEnabledAsync(long id, [FromBody] AdoS0ToggleEnabledDto dto)
  92. {
  93. var entity = await _rep.GetByIdAsync(id);
  94. if (entity == null) return NotFound();
  95. entity.IsEnabled = dto.IsEnabled;
  96. entity.UpdatedAt = DateTime.Now;
  97. await _rep.AsUpdateable(entity).ExecuteCommandAsync();
  98. return Ok(entity);
  99. }
  100. [HttpDelete("{id:long}")]
  101. public async Task<IActionResult> DeleteAsync(long id)
  102. {
  103. var item = await _rep.GetByIdAsync(id);
  104. if (item == null) return NotFound();
  105. await _rep.DeleteAsync(item);
  106. return Ok(new { message = "删除成功" });
  107. }
  108. }