report.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Mai
  6. * @date
  7. * @version
  8. */
  9. module.exports = app => {
  10. class Report extends app.BaseService {
  11. /**
  12. * 构造函数
  13. *
  14. * @param {Object} ctx - egg全局context
  15. * @return {void}
  16. */
  17. constructor(ctx) {
  18. super(ctx);
  19. }
  20. async checkStg(ctx, params) {
  21. if (ctx.stage === null || ctx.stage === undefined || parseInt(ctx.stage.id) !== parseInt(params.stage_id)) {
  22. await ctx.service.stage.checkStage(params.stage_id);
  23. if (ctx.stage) {
  24. params.stage_order = ctx.stage.curOrder;
  25. }
  26. }
  27. }
  28. async getReportData(params, filters, memFieldKeys, customDefine, customSelect) {
  29. const service = this.ctx.service;
  30. const rst = {};
  31. const runnableRst = [];
  32. const runnableKey = []; // 这个配合runnableRst用,未来考虑并行查询优化
  33. for (const filter of filters) {
  34. if (runnableKey.indexOf(filter) < 0) {
  35. switch (filter) {
  36. case 'project' :
  37. runnableRst.push(service.project.getProjectById(params.project_id));
  38. runnableKey.push(filter);
  39. break;
  40. case 'tender_info' :
  41. runnableRst.push(service.tenderInfo.getTenderInfoEx(params.tender_id));
  42. runnableKey.push(filter);
  43. break;
  44. case 'advance_pay':
  45. runnableRst.push(service.advance.getAllDataByCondition({ where: { tid: params.tender_id } }));
  46. runnableKey.push(filter);
  47. break;
  48. case 'deal_bills' :
  49. runnableRst.push(service.dealBills.getDataByTenderId(params.tender_id));
  50. runnableKey.push('deal_bills');
  51. break;
  52. case 'ledger' :
  53. runnableRst.push(service.ledger.getData(params.tender_id, 0));
  54. runnableKey.push(filter);
  55. break;
  56. case 'stage_bills':
  57. runnableRst.push(service.stageBills.getLastestStageData(params.tender_id, params.stage_id));
  58. runnableKey.push(filter);
  59. break;
  60. case 'stage_bills_final':
  61. await this.checkStg(this.ctx, params);
  62. runnableRst.push(service.stageBillsFinal.getFinalDataEx(params.tender_id, params.stage_order));
  63. runnableKey.push(filter);
  64. break;
  65. case 'stage':
  66. runnableRst.push(service.stage.getStageById(params.stage_id));
  67. runnableKey.push(filter);
  68. break;
  69. case 'stage_pay':
  70. await this.checkStg(this.ctx, params);
  71. runnableRst.push(service.stagePay.getAuditorStageData(params.stage_id, params.stage_times, params.stage_order));
  72. runnableKey.push(filter);
  73. break;
  74. case 'mem_stage_im_zl':
  75. runnableRst.push(service.reportMemory.getStageImZlData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  76. runnableKey.push(filter);
  77. break;
  78. case 'mem_month_progress':
  79. runnableRst.push(service.reportMemory.getMonthProgress(params.tender_id, memFieldKeys[filter]));
  80. runnableKey.push(filter);
  81. break;
  82. case 'stage_audit':
  83. runnableRst.push(service.reportMemory.getStageAuditors(params.tender_id, params.stage_id));
  84. runnableKey.push(filter);
  85. break;
  86. case 'mem_stage_bills':
  87. runnableRst.push(service.reportMemory.getStageBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  88. runnableKey.push(filter);
  89. break;
  90. case 'mem_stage_pos':
  91. runnableRst.push(service.reportMemory.getStagePosData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  92. runnableKey.push(filter);
  93. break;
  94. case 'mem_stage_pos_compare':
  95. runnableRst.push(service.reportMemory.getStagePosCompareData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  96. runnableKey.push(filter);
  97. break;
  98. case 'mem_stage_bills_compare':
  99. runnableRst.push(service.reportMemory.getStageBillsCompareData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  100. runnableKey.push(filter);
  101. break;
  102. case 'mem_stage_pay':
  103. runnableRst.push(service.reportMemory.getStagePayData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  104. runnableKey.push(filter);
  105. break;
  106. case 'change':
  107. runnableRst.push(service.change.getListByStatus(params.tender_id, 3)); // 获取所有审核通过的变更主信息
  108. runnableKey.push(filter);
  109. break;
  110. case 'change_audit_list':
  111. runnableRst.push(service.changeAuditList.getChangeAuditBills(params.tender_id)); // 获取所有审核通过的变更清单
  112. runnableKey.push(filter);
  113. console.log(filter);
  114. break;
  115. case 'mem_stage_jgcl':
  116. runnableRst.push(service.reportMemory.getStageJgcl(params.tender_id, params.stage_id, memFieldKeys[filter]));
  117. runnableKey.push(filter);
  118. break;
  119. case 'mem_stage_bonus':
  120. runnableRst.push(service.reportMemory.getStageBonus(params.tender_id, params.stage_id, memFieldKeys[filter]));
  121. runnableKey.push(filter);
  122. break;
  123. case 'mem_stage_other':
  124. runnableRst.push(service.reportMemory.getStageOther(params.tender_id, params.stage_id, memFieldKeys[filter]));
  125. runnableKey.push(filter);
  126. break;
  127. case 'mem_gather_stage_bills':
  128. runnableRst.push(service.rptGatherMemory.getGatherStageBills(memFieldKeys[filter],
  129. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  130. runnableKey.push(filter);
  131. break;
  132. case 'mem_gather_tender_info':
  133. runnableRst.push(service.rptGatherMemory.getGatherTenderInfo(memFieldKeys[filter],
  134. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  135. runnableKey.push(filter);
  136. break;
  137. case 'mem_gather_stage_pay':
  138. runnableRst.push(service.rptGatherMemory.getGatherStagePay(memFieldKeys[filter],
  139. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  140. runnableKey.push(filter);
  141. break;
  142. case 'mem_gather_deal_bills':
  143. runnableRst.push(service.rptGatherMemory.getGatherDealBills(memFieldKeys[filter],
  144. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  145. runnableKey.push(filter);
  146. break;
  147. case 'mem_material':
  148. runnableRst.push(service.reportMemory.getMaterial(params.tender_id, params.material_order, memFieldKeys[filter]));
  149. runnableKey.push(filter);
  150. break;
  151. case 'mem_material_gl':
  152. runnableRst.push(service.reportMemory.getMaterialGl(params.tender_id, params.material_order, memFieldKeys[filter]));
  153. runnableKey.push(filter);
  154. break;
  155. case 'mem_stage_sum_bills':
  156. runnableRst.push(service.rptStageSumMemory.getStageSumBills(params.tender_id, memFieldKeys[filter],
  157. customDefine.stage_select, customSelect ? customSelect.stage_select : null));
  158. runnableKey.push(filter);
  159. break;
  160. case 'mem_stage_sum_pay':
  161. runnableRst.push(service.rptStageSumMemory.getStageSumPay(params.tender_id, memFieldKeys[filter],
  162. customDefine.stage_select, customSelect ? customSelect.stage_select : null));
  163. runnableKey.push(filter);
  164. break;
  165. case 'ledger_cooperation':
  166. runnableRst.push(service.ledgerCooperation.getValidData(params.tender_id));
  167. runnableKey.push(filter);
  168. break;
  169. case 'mem_sign_select':
  170. runnableRst.push(service.reportMemory.getSignSelect(params.tender_id, params.stage_id, customSelect));
  171. runnableKey.push(filter);
  172. break;
  173. case 'mem_stage_change_bills':
  174. runnableRst.push(service.stageChangeFinal.getFinalData(params.tender_id));
  175. runnableKey.push(filter);
  176. break;
  177. default:
  178. break;
  179. }
  180. }
  181. }
  182. const queryRst = await Promise.all(runnableRst);
  183. for (let idx = 0; idx < runnableKey.length; idx++) {
  184. rst[runnableKey[idx]] = queryRst[idx];
  185. }
  186. for (const filter of filters) {
  187. switch (filter) {
  188. case 'mem_stage_im_tz':
  189. rst[filter] = await service.reportMemory.getStageImTzData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  190. break;
  191. case 'mem_stage_im_tz_bills':
  192. rst[filter] = await service.reportMemory.getStageImTzBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  193. break;
  194. case 'mem_union_data':
  195. rst[filter] = [];
  196. break;
  197. case 'mem_change':
  198. rst[filter] = await service.reportMemory.getChangeData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  199. break;
  200. case 'mem_change_bills':
  201. rst[filter] = await service.reportMemory.getChangeBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  202. break;
  203. case 'mem_material_bills':
  204. rst[filter] = await service.rptGatherMemory.getMaterialBills(params.tender_id, params.material_order, memFieldKeys[filter]);
  205. break;
  206. case 'mem_material_bills_gl':
  207. rst[filter] = await service.rptGatherMemory.getMaterialBillsGl(params.tender_id, params.material_order, memFieldKeys[filter]);
  208. break;
  209. default:
  210. break;
  211. }
  212. }
  213. return rst;
  214. }
  215. }
  216. return Report;
  217. };