AdoS0MfgStandardOperationsController.cs 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. using Admin.NET.Plugin.AiDOP.Dto.S0.Manufacturing;
  2. using Admin.NET.Plugin.AiDOP.Entity.S0.Manufacturing;
  3. using Admin.NET.Plugin.AiDOP.Infrastructure;
  4. namespace Admin.NET.Plugin.AiDOP.Controllers.S0.Manufacturing;
  5. /// <summary>
  6. /// 标准工序维护(StdOpMaster 语义,表 ado_s0_mfg_std_op_master)。
  7. /// </summary>
  8. [ApiController]
  9. [Route("api/s0/manufacturing/standard-operations")]
  10. [AllowAnonymous]
  11. [NonUnify]
  12. public class AdoS0MfgStandardOperationsController : ControllerBase
  13. {
  14. private readonly SqlSugarRepository<AdoS0StdOpMaster> _rep;
  15. public AdoS0MfgStandardOperationsController(SqlSugarRepository<AdoS0StdOpMaster> rep)
  16. {
  17. _rep = rep;
  18. }
  19. [HttpGet]
  20. public async Task<IActionResult> GetPagedAsync([FromQuery] AdoS0StdOpMasterQueryDto q)
  21. {
  22. var page = q.EffectivePage;
  23. var pageSize = q.PageSize;
  24. (page, pageSize) = PagingGuard.Normalize(page, pageSize);
  25. var query = _rep.AsQueryable()
  26. .WhereIF(q.CompanyRefId.HasValue, x => x.CompanyRefId == q.CompanyRefId!.Value)
  27. .WhereIF(q.FactoryRefId.HasValue, x => x.FactoryRefId == q.FactoryRefId!.Value)
  28. .WhereIF(!string.IsNullOrWhiteSpace(q.Keyword), x => x.StdOp.Contains(q.Keyword!) || (x.StdOpCode != null && x.StdOpCode.Contains(q.Keyword!)))
  29. .WhereIF(!string.IsNullOrWhiteSpace(q.StdOpCode), x => x.StdOpCode != null && x.StdOpCode.Contains(q.StdOpCode!))
  30. .WhereIF(!string.IsNullOrWhiteSpace(q.StdOp), x => x.StdOp.Contains(q.StdOp!))
  31. .WhereIF(!string.IsNullOrWhiteSpace(q.MilestoneOp), x => x.MilestoneOp != null && x.MilestoneOp.Contains(q.MilestoneOp!));
  32. var total = await query.CountAsync();
  33. var list = await query
  34. .OrderByDescending(x => x.Id)
  35. .Skip((page - 1) * pageSize)
  36. .Take(pageSize)
  37. .ToListAsync();
  38. return Ok(new { total, page, pageSize, list });
  39. }
  40. [HttpGet("{id:long}")]
  41. public async Task<IActionResult> GetAsync(long id)
  42. {
  43. var item = await _rep.GetByIdAsync(id);
  44. return item == null ? NotFound() : Ok(item);
  45. }
  46. [HttpPost]
  47. public async Task<IActionResult> CreateAsync([FromBody] AdoS0StdOpMasterUpsertDto dto)
  48. {
  49. var stdOpCode = dto.StdOpCode.Trim();
  50. if (await _rep.IsAnyAsync(x => x.CompanyRefId == dto.CompanyRefId && x.FactoryRefId == dto.FactoryRefId && x.StdOpCode == stdOpCode))
  51. return AdoS0ApiErrors.Conflict(AdoS0ErrorCodes.DuplicateCode, "标准工序编码已存在");
  52. var now = DateTime.Now;
  53. var entity = new AdoS0StdOpMaster
  54. {
  55. CompanyRefId = dto.CompanyRefId,
  56. FactoryRefId = dto.FactoryRefId,
  57. Domain = dto.Domain.Trim(),
  58. StdOp = dto.StdOp.Trim(),
  59. StdOpCode = stdOpCode,
  60. MilestoneOp = string.IsNullOrWhiteSpace(dto.MilestoneOp) ? null : dto.MilestoneOp.Trim(),
  61. CreateUser = dto.CreateUser,
  62. CreateTime = now,
  63. UpdateUser = null,
  64. UpdateTime = null
  65. };
  66. await _rep.AsInsertable(entity).ExecuteReturnEntityAsync();
  67. return Ok(entity);
  68. }
  69. [HttpPut("{id:long}")]
  70. public async Task<IActionResult> UpdateAsync(long id, [FromBody] AdoS0StdOpMasterUpsertDto dto)
  71. {
  72. var entity = await _rep.GetByIdAsync(id);
  73. if (entity == null) return NotFound();
  74. var stdOpCode = dto.StdOpCode.Trim();
  75. if (await _rep.IsAnyAsync(x => x.Id != id && x.CompanyRefId == dto.CompanyRefId && x.FactoryRefId == dto.FactoryRefId && x.StdOpCode == stdOpCode))
  76. return AdoS0ApiErrors.Conflict(AdoS0ErrorCodes.DuplicateCode, "标准工序编码已存在");
  77. entity.CompanyRefId = dto.CompanyRefId;
  78. entity.FactoryRefId = dto.FactoryRefId;
  79. entity.Domain = dto.Domain.Trim();
  80. entity.StdOp = dto.StdOp.Trim();
  81. entity.StdOpCode = stdOpCode;
  82. entity.MilestoneOp = string.IsNullOrWhiteSpace(dto.MilestoneOp) ? null : dto.MilestoneOp.Trim();
  83. entity.UpdateUser = dto.UpdateUser;
  84. entity.UpdateTime = DateTime.Now;
  85. await _rep.AsUpdateable(entity).ExecuteCommandAsync();
  86. return Ok(entity);
  87. }
  88. [HttpDelete("{id:long}")]
  89. public async Task<IActionResult> DeleteAsync(long id)
  90. {
  91. var item = await _rep.GetByIdAsync(id);
  92. if (item == null) return NotFound();
  93. await _rep.DeleteAsync(item);
  94. return Ok(new { message = "删除成功" });
  95. }
  96. }