PurchaseOrderService.cs 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261
  1. namespace Admin.NET.Plugin.AiDOP.Supply;
  2. /// <summary>
  3. /// 物料采购订单服务
  4. /// </summary>
  5. [ApiDescriptionSettings(Order = 309, Description = "物料采购订单")]
  6. [Route("api/Supply")]
  7. [AllowAnonymous]
  8. [NonUnify]
  9. public class PurchaseOrderService : IDynamicApiController, ITransient
  10. {
  11. private readonly ISqlSugarClient _db;
  12. private readonly UserManager _userManager;
  13. public PurchaseOrderService(ISqlSugarClient db, UserManager userManager)
  14. {
  15. _db = db;
  16. _userManager = userManager;
  17. }
  18. [DisplayName("物料采购订单列表")]
  19. [HttpGet("purchase-order/list")]
  20. public async Task<object> GetList([FromQuery] PurchaseOrderListInput input)
  21. {
  22. var page = input.Page <= 0 ? 1 : input.Page;
  23. var pageSize = input.PageSize <= 0 ? 10 : input.PageSize;
  24. var offset = (page - 1) * pageSize;
  25. if (await ShouldUseDwdAsync())
  26. {
  27. return await GetDwdListAsync(input, page, pageSize, offset);
  28. }
  29. var where = new List<string> { "1=1" };
  30. var pars = new List<SugarParameter>();
  31. if (_userManager.TenantId > 0)
  32. {
  33. where.Add("a.tenant_id = @TenantId");
  34. pars.Add(new SugarParameter("@TenantId", _userManager.TenantId));
  35. }
  36. if (!string.IsNullOrWhiteSpace(input.Cgdd))
  37. {
  38. where.Add("a.cgdd LIKE @Cgdd");
  39. pars.Add(new SugarParameter("@Cgdd", $"%{input.Cgdd.Trim()}%"));
  40. }
  41. if (!string.IsNullOrWhiteSpace(input.Wlbm))
  42. {
  43. where.Add("a.wlbm LIKE @Wlbm");
  44. pars.Add(new SugarParameter("@Wlbm", $"%{input.Wlbm.Trim()}%"));
  45. }
  46. if (!string.IsNullOrWhiteSpace(input.Gysdm))
  47. {
  48. where.Add("a.gysdm LIKE @Gysdm");
  49. pars.Add(new SugarParameter("@Gysdm", $"%{input.Gysdm.Trim()}%"));
  50. }
  51. if (!string.IsNullOrWhiteSpace(input.Sffbcx))
  52. {
  53. where.Add("(CASE WHEN b2.b2id IS NULL THEN 'X' ELSE 'V' END)=@Sffbcx");
  54. pars.Add(new SugarParameter("@Sffbcx", input.Sffbcx.Trim().ToUpperInvariant()));
  55. }
  56. var fromSql = $"""
  57. FROM (
  58. SELECT
  59. a.id, a.wlbm, a.wlms, a.wlgg, a.cgdd, a.jhdsl, a.wjhsl, a.jhd, a.yjjhrq, a.gysdm, a.gysmc,
  60. DATE_FORMAT(DATE(a.yjjhrq), '%Y-%m-%d') AS jhrq,
  61. CASE
  62. WHEN IFNULL(b.jqhf,'')='' AND IFNULL(b.qhdj,'')='' THEN 'wait'
  63. WHEN IFNULL(b.jqhf,'')='' AND IFNULL(b.qhdj,'')<>'' THEN 'refuse'
  64. WHEN b.jqhf IS NOT NULL AND DATEDIFF(DATE(a.yjjhrq), DATE(b.jqhf))>=0 THEN 'OK'
  65. ELSE 'NO'
  66. END AS sfyq,
  67. b.jqhf, a.ddhh, a.th, a.bbh, a.StdCost, a.PurCost, a.PurCost * a.jhdsl AS je,
  68. a.createtime, a.buyer, a.type AS ddlx, a.dw, a.payumconv, a.orddate
  69. FROM vscm_jhjh a
  70. LEFT JOIN (
  71. SELECT glid, MAX(jqhf) AS jqhf, GROUP_CONCAT(qhdj SEPARATOR '') AS qhdj
  72. FROM scm_jhjh_jq
  73. WHERE flag = 0
  74. GROUP BY glid
  75. ) b ON a.id = b.glid
  76. ) a
  77. LEFT JOIN (
  78. SELECT OrdNbr, OrdLine, SUM(ReceiptQty + yssl) AS zshl, SUM(yssl) AS rksl, SUM(QtyReturn) AS bhgsl, SUM(QtyReturned) AS thsl
  79. FROM vscm_cgshrk
  80. GROUP BY OrdNbr, OrdLine
  81. ) b ON a.cgdd = b.OrdNbr AND a.ddhh = b.OrdLine
  82. LEFT JOIN (
  83. SELECT po_bill, po_billline, SUM(sh_delivery_quantity) AS zfhl
  84. FROM scm_shdzb a
  85. INNER JOIN scm_shd b ON a.glid = b.id
  86. WHERE b.state = 0
  87. GROUP BY po_bill, po_billline
  88. ) c ON a.cgdd = c.po_bill AND a.ddhh = c.po_billline
  89. LEFT JOIN (
  90. SELECT cgdd, ddhh, MIN(id) AS b2id, MIN(hfsj) AS hfsj
  91. FROM scm_jhjh_jq
  92. WHERE flag = 2
  93. GROUP BY cgdd, ddhh
  94. ) b2 ON a.cgdd = b2.cgdd AND a.ddhh = b2.ddhh
  95. WHERE {string.Join(" AND ", where)}
  96. """;
  97. var orderBy = BuildOrderBy(input.SortField, input.SortOrder);
  98. var total = await _db.Ado.GetIntAsync($"SELECT COUNT(1) {fromSql}", pars);
  99. var list = await _db.Ado.SqlQueryAsync<PurchaseOrderListRow>(
  100. $"""
  101. SELECT
  102. a.gysdm AS Gysdm,
  103. a.gysmc AS Gysmc,
  104. a.cgdd AS Cgdd,
  105. a.ddhh AS Ddhh,
  106. a.buyer AS Buyer,
  107. a.orddate AS Orddate,
  108. a.wlbm AS Wlbm,
  109. a.wlms AS Wlms,
  110. a.ddlx AS Ddlx,
  111. a.jhdsl AS Jhdsl,
  112. a.wjhsl AS Wjhsl,
  113. a.jhrq AS Jhrq,
  114. a.th AS Th,
  115. CASE WHEN b2.b2id IS NULL THEN 'X' ELSE DATE_FORMAT(b2.hfsj, '%Y.%m.%d') END AS Sffb,
  116. CASE WHEN b2.b2id IS NULL THEN 'X' ELSE 'V' END AS Sffbcx
  117. {fromSql}
  118. ORDER BY {orderBy}
  119. LIMIT {pageSize} OFFSET {offset}
  120. """,
  121. pars);
  122. return new { total, page, pageSize, list };
  123. }
  124. private async Task<bool> ShouldUseDwdAsync()
  125. {
  126. return await _db.Ado.GetIntAsync("SELECT COUNT(1) FROM dwd_supplier_delivery LIMIT 1") > 0;
  127. }
  128. private async Task<object> GetDwdListAsync(PurchaseOrderListInput input, int page, int pageSize, int offset)
  129. {
  130. var where = new List<string> { "1=1" };
  131. var pars = new List<SugarParameter>();
  132. if (_userManager.TenantId > 0)
  133. {
  134. where.Add("a.tenant_id = @TenantId");
  135. pars.Add(new SugarParameter("@TenantId", _userManager.TenantId));
  136. }
  137. if (!string.IsNullOrWhiteSpace(input.Cgdd))
  138. {
  139. where.Add("a.po_no LIKE @Cgdd");
  140. pars.Add(new SugarParameter("@Cgdd", $"%{input.Cgdd.Trim()}%"));
  141. }
  142. if (!string.IsNullOrWhiteSpace(input.Wlbm))
  143. {
  144. where.Add("a.item_code LIKE @Wlbm");
  145. pars.Add(new SugarParameter("@Wlbm", $"%{input.Wlbm.Trim()}%"));
  146. }
  147. if (!string.IsNullOrWhiteSpace(input.Gysdm))
  148. {
  149. where.Add("a.supplier_code LIKE @Gysdm");
  150. pars.Add(new SugarParameter("@Gysdm", $"%{input.Gysdm.Trim()}%"));
  151. }
  152. if (!string.IsNullOrWhiteSpace(input.Sffbcx))
  153. {
  154. where.Add("CASE WHEN IFNULL(a.delivery_status,'')='OPEN' THEN 'X' ELSE 'V' END = @Sffbcx");
  155. pars.Add(new SugarParameter("@Sffbcx", input.Sffbcx.Trim().ToUpperInvariant()));
  156. }
  157. var fromSql = $"FROM dwd_supplier_delivery a WHERE {string.Join(" AND ", where)}";
  158. var total = await _db.Ado.GetIntAsync($"SELECT COUNT(1) {fromSql}", pars);
  159. var orderBy = BuildDwdOrderBy(input.SortField, input.SortOrder);
  160. var list = await _db.Ado.SqlQueryAsync<PurchaseOrderListRow>(
  161. $"""
  162. SELECT
  163. a.supplier_code AS Gysdm,
  164. a.supplier_name AS Gysmc,
  165. a.po_no AS Cgdd,
  166. a.po_line AS Ddhh,
  167. NULL AS Buyer,
  168. NULL AS Orddate,
  169. a.item_code AS Wlbm,
  170. a.item_name AS Wlms,
  171. a.po_type AS Ddlx,
  172. a.order_qty AS Jhdsl,
  173. a.remaining_qty AS Wjhsl,
  174. DATE_FORMAT(DATE(COALESCE(a.need_date, a.due_date)), '%Y-%m-%d') AS Jhrq,
  175. NULL AS Th,
  176. CASE WHEN IFNULL(a.delivery_status,'')='OPEN' THEN 'X' ELSE 'V' END AS Sffb,
  177. CASE WHEN IFNULL(a.delivery_status,'')='OPEN' THEN 'X' ELSE 'V' END AS Sffbcx
  178. {fromSql}
  179. ORDER BY {orderBy}
  180. LIMIT {pageSize} OFFSET {offset}
  181. """,
  182. pars);
  183. return new { total, page, pageSize, list, source = "dwd_supplier_delivery" };
  184. }
  185. private static string BuildDwdOrderBy(string? sortField, string? sortOrder)
  186. {
  187. var dir = string.Equals(sortOrder, "asc", StringComparison.OrdinalIgnoreCase) ? "ASC" : "DESC";
  188. return sortField?.ToLowerInvariant() switch
  189. {
  190. "gysdm" => $"a.supplier_code {dir}",
  191. "gysmc" => $"a.supplier_name {dir}",
  192. "cgdd" => $"a.po_no {dir}",
  193. "ddhh" => $"a.po_line {dir}",
  194. "orddate" => $"a.stat_date {dir}",
  195. "wlbm" => $"a.item_code {dir}",
  196. "wlms" => $"a.item_name {dir}",
  197. "ddlx" => $"a.po_type {dir}",
  198. "jhdsl" => $"a.order_qty {dir}",
  199. "wjhsl" => $"a.remaining_qty {dir}",
  200. "jhrq" => $"a.need_date {dir}",
  201. _ => "a.stat_date DESC, a.po_no DESC, a.po_line ASC"
  202. };
  203. }
  204. private static string BuildOrderBy(string? sortField, string? sortOrder)
  205. {
  206. var dir = string.Equals(sortOrder, "asc", StringComparison.OrdinalIgnoreCase) ? "ASC" : "DESC";
  207. return sortField?.ToLowerInvariant() switch
  208. {
  209. "gysdm" => $"a.gysdm {dir}",
  210. "gysmc" => $"a.gysmc {dir}",
  211. "cgdd" => $"a.cgdd {dir}",
  212. "ddhh" => $"a.ddhh {dir}",
  213. "buyer" => $"a.buyer {dir}",
  214. "orddate" => $"a.orddate {dir}",
  215. "wlbm" => $"a.wlbm {dir}",
  216. "wlms" => $"a.wlms {dir}",
  217. "ddlx" => $"a.ddlx {dir}",
  218. "jhdsl" => $"a.jhdsl {dir}",
  219. "wjhsl" => $"a.wjhsl {dir}",
  220. "jhrq" => $"a.jhrq {dir}",
  221. "th" => $"a.th {dir}",
  222. "sffb" => $"b2.hfsj {dir}",
  223. _ => "a.id DESC"
  224. };
  225. }
  226. private sealed class PurchaseOrderListRow
  227. {
  228. public string? Gysdm { get; set; }
  229. public string? Gysmc { get; set; }
  230. public string? Cgdd { get; set; }
  231. public string? Ddhh { get; set; }
  232. public string? Buyer { get; set; }
  233. public DateTime? Orddate { get; set; }
  234. public string? Wlbm { get; set; }
  235. public string? Wlms { get; set; }
  236. public string? Ddlx { get; set; }
  237. public decimal? Jhdsl { get; set; }
  238. public decimal? Wjhsl { get; set; }
  239. public string? Jhrq { get; set; }
  240. public string? Th { get; set; }
  241. public string? Sffb { get; set; }
  242. public string? Sffbcx { get; set; }
  243. }
  244. }