PurchaseOrderService.cs 9.6 KB

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