SapBomRecordController.cs 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. using Infrastructure;
  2. using Infrastructure.Attribute;
  3. using Infrastructure.Enums;
  4. using Infrastructure.Model;
  5. using Mapster;
  6. using Microsoft.AspNetCore.Mvc;
  7. using ZR.Model.Dto;
  8. using ZR.Model.Models;
  9. using ZR.Service.Business.IBusinessService;
  10. using ZR.Admin.WebApi.Extensions;
  11. using ZR.Admin.WebApi.Filters;
  12. using ZR.Common;
  13. using MiniExcelLibs;
  14. using ZR.Service.Business;
  15. namespace ZR.Admin.WebApi.Controllers
  16. {
  17. /// <summary>
  18. /// 接口管理/SAP关键件清单记录表Controller
  19. ///
  20. /// @tableName sap_bom_record
  21. /// @author admin
  22. /// @date 2023-05-05
  23. /// </summary>
  24. [Verify]
  25. [Route("business/SapBomRecord")]
  26. public class SapBomRecordController : BaseController
  27. {
  28. /// <summary>
  29. /// 接口管理/SAP关键件清单记录表接口
  30. /// </summary>
  31. private readonly ISapBomRecordService _SapBomRecordService;
  32. public SapBomRecordController(ISapBomRecordService SapBomRecordService)
  33. {
  34. _SapBomRecordService = SapBomRecordService;
  35. }
  36. /// <summary>
  37. /// 查询接口管理/SAP关键件清单记录表列表
  38. /// </summary>
  39. /// <param name="parm"></param>
  40. /// <returns></returns>
  41. [HttpGet("list")]
  42. [ActionPermissionFilter(Permission = "business:sapbomrecord:list")]
  43. public IActionResult QuerySapBomRecord([FromQuery] SapBomRecordQueryDto parm)
  44. {
  45. var response = _SapBomRecordService.GetList(parm);
  46. return SUCCESS(response);
  47. }
  48. /// <summary>
  49. /// 查询接口管理/SAP关键件清单记录表详情
  50. /// </summary>
  51. /// <param name="Id"></param>
  52. /// <returns></returns>
  53. [HttpGet("{Id}")]
  54. [ActionPermissionFilter(Permission = "business:sapbomrecord:query")]
  55. public IActionResult GetSapBomRecord(int Id)
  56. {
  57. var response = _SapBomRecordService.GetFirst(x => x.Id == Id);
  58. return SUCCESS(response);
  59. }
  60. /// <summary>
  61. /// 添加接口管理/SAP关键件清单记录表
  62. /// </summary>
  63. /// <returns></returns>
  64. [HttpPost]
  65. [ActionPermissionFilter(Permission = "business:sapbomrecord:add")]
  66. [Log(Title = "接口管理/SAP关键件清单记录表", BusinessType = BusinessType.INSERT)]
  67. public IActionResult AddSapBomRecord([FromBody] SapBomRecordDto parm)
  68. {
  69. if (parm == null)
  70. {
  71. throw new CustomException("请求参数错误");
  72. }
  73. var modal = parm.Adapt<SapBomRecord>().ToCreate(HttpContext);
  74. var response = _SapBomRecordService.AddSapBomRecord(modal);
  75. return ToResponse(response);
  76. }
  77. /// <summary>
  78. /// 更新接口管理/SAP关键件清单记录表
  79. /// </summary>
  80. /// <returns></returns>
  81. [HttpPut]
  82. [ActionPermissionFilter(Permission = "business:sapbomrecord:edit")]
  83. [Log(Title = "接口管理/SAP关键件清单记录表", BusinessType = BusinessType.UPDATE)]
  84. public IActionResult UpdateSapBomRecord([FromBody] SapBomRecordDto parm)
  85. {
  86. if (parm == null)
  87. {
  88. throw new CustomException("请求实体不能为空");
  89. }
  90. var modal = parm.Adapt<SapBomRecord>().ToUpdate(HttpContext);
  91. var response = _SapBomRecordService.UpdateSapBomRecord(modal);
  92. return ToResponse(response);
  93. }
  94. /// <summary>
  95. /// 删除接口管理/SAP关键件清单记录表
  96. /// </summary>
  97. /// <returns></returns>
  98. [HttpDelete("{ids}")]
  99. [ActionPermissionFilter(Permission = "business:sapbomrecord:delete")]
  100. [Log(Title = "接口管理/SAP关键件清单记录表", BusinessType = BusinessType.DELETE)]
  101. public IActionResult DeleteSapBomRecord(string ids)
  102. {
  103. int[] idsArr = Tools.SpitIntArrary(ids);
  104. if (idsArr.Length <= 0) { return ToResponse(ApiResult.Error($"删除失败Id 不能为空")); }
  105. var response = _SapBomRecordService.Delete(idsArr);
  106. return ToResponse(response);
  107. }
  108. /// <summary>
  109. /// 导入
  110. /// </summary>
  111. /// <param name="formFile">使用IFromFile必须使用name属性否则获取不到文件</param>
  112. /// <returns></returns>
  113. [HttpPost("importData")]
  114. [Log(Title = "关键件导入", BusinessType = BusinessType.IMPORT, IsSaveRequestData = false, IsSaveResponseData = false)]
  115. [ActionPermissionFilter(Permission = "business:sapbomrecord:import")]
  116. public IActionResult ImportData([FromForm(Name = "file")] IFormFile formFile)
  117. {
  118. List<dynamic>? list = new();
  119. //读取上传文件内容。
  120. using (var stream = formFile.OpenReadStream())
  121. {
  122. list = stream.Query().ToList();
  123. }
  124. string bomNo = list[2].H;
  125. if (string.IsNullOrEmpty(bomNo))
  126. {
  127. return SUCCESS("未找到生产令号,导入文件格式错误");
  128. }
  129. string equipmentName = list[2].D;
  130. string makeBy = list[3].D;
  131. DateTime makeTime = list[3].H;
  132. List<SapBomRecord> sapBomRecords = new();
  133. for (int i = 5; i < list.Count; i++)
  134. {
  135. if (string.IsNullOrEmpty($"{list[i].B}"))
  136. {
  137. break;//序号一列出现空,即表单内容结束
  138. }
  139. SapBomRecord sapBomRecord = new()
  140. {
  141. BomNo = bomNo,
  142. EquipmentName = equipmentName,
  143. MakeBy = makeBy,
  144. MakeTime = makeTime,
  145. Category = list[i].C,
  146. MaterialCode = list[i].D,
  147. MaterialName = list[i].E,
  148. MaterialSpec = list[i].F,
  149. KeyFlag = (i % 2) > 0,//非空 模拟数据
  150. Qty = Convert.ToInt32(list[i].H),
  151. Result = 99,//非空 模拟数据
  152. CreateBy = HttpContext.GetName(),
  153. CreateTime = DateTime.Now,
  154. Remark = "导入数据"
  155. };
  156. sapBomRecords.Add(sapBomRecord);
  157. }
  158. string msg = _SapBomRecordService.ImportDatas(sapBomRecords);
  159. //TODO 业务逻辑,自行插入数据到db
  160. return SUCCESS(list);
  161. }
  162. }
  163. }