report.js 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  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. await service.tender.checkTender(params.tender_id);
  31. const rst = {};
  32. const runnableRst = [];
  33. const runnableKey = []; // 这个配合runnableRst用,未来考虑并行查询优化
  34. for (const filter of filters) {
  35. if (runnableKey.indexOf(filter) < 0) {
  36. switch (filter) {
  37. case 'project' :
  38. runnableRst.push(service.project.getProjectById(params.project_id));
  39. runnableKey.push(filter);
  40. break;
  41. case 'tender_info' :
  42. runnableRst.push(service.tenderInfo.getTenderInfoEx(params.tender_id));
  43. runnableKey.push(filter);
  44. break;
  45. case 'advance_pay':
  46. runnableRst.push(service.advance.getAllDataByCondition({ where: { tid: params.tender_id } }));
  47. runnableKey.push(filter);
  48. break;
  49. case 'deal_bills' :
  50. runnableRst.push(service.dealBills.getDataByTenderId(params.tender_id));
  51. runnableKey.push('deal_bills');
  52. break;
  53. case 'ledger' :
  54. runnableRst.push(service.ledger.getData(params.tender_id, 0));
  55. runnableKey.push(filter);
  56. break;
  57. case 'stage_bills':
  58. runnableRst.push(service.stageBills.getLastestStageData(params.tender_id, params.stage_id));
  59. runnableKey.push(filter);
  60. break;
  61. case 'stage_bills_final':
  62. await this.checkStg(this.ctx, params);
  63. runnableRst.push(service.stageBillsFinal.getFinalDataEx(params.tender_id, params.stage_order));
  64. runnableKey.push(filter);
  65. break;
  66. case 'stage':
  67. runnableRst.push(service.stage.getStageById(params.stage_id));
  68. runnableKey.push(filter);
  69. break;
  70. case 'stage_pay':
  71. await this.checkStg(this.ctx, params);
  72. runnableRst.push(service.stagePay.getAuditorStageData(params.stage_id, params.stage_times, params.stage_order));
  73. runnableKey.push(filter);
  74. break;
  75. case 'mem_stage_im_zl':
  76. runnableRst.push(service.reportMemory.getStageImZlData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  77. runnableKey.push(filter);
  78. break;
  79. case 'mem_month_progress':
  80. runnableRst.push(service.reportMemory.getMonthProgress(params.tender_id, memFieldKeys[filter]));
  81. runnableKey.push(filter);
  82. break;
  83. case 'stage_audit':
  84. runnableRst.push(service.reportMemory.getStageAuditors(params.tender_id, params.stage_id));
  85. runnableKey.push(filter);
  86. break;
  87. case 'mem_stage_bills':
  88. runnableRst.push(service.reportMemory.getStageBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  89. runnableKey.push(filter);
  90. break;
  91. case 'mem_stage_pos':
  92. runnableRst.push(service.reportMemory.getStagePosData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  93. runnableKey.push(filter);
  94. break;
  95. case 'mem_stage_pos_compare':
  96. runnableRst.push(service.reportMemory.getStagePosCompareData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  97. runnableKey.push(filter);
  98. break;
  99. case 'mem_stage_bills_compare':
  100. runnableRst.push(service.reportMemory.getStageBillsCompareData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  101. runnableKey.push(filter);
  102. break;
  103. case 'mem_stage_pay':
  104. runnableRst.push(service.reportMemory.getStagePayData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  105. runnableKey.push(filter);
  106. break;
  107. case 'change':
  108. runnableRst.push(service.change.getListByStatus(params.tender_id, 3)); // 获取所有审核通过的变更主信息
  109. runnableKey.push(filter);
  110. break;
  111. case 'change_audit_list':
  112. runnableRst.push(service.changeAuditList.getChangeAuditBills(params.tender_id)); // 获取所有审核通过的变更清单
  113. runnableKey.push(filter);
  114. console.log(filter);
  115. break;
  116. case 'mem_stage_jgcl':
  117. runnableRst.push(service.reportMemory.getStageJgcl(params.tender_id, params.stage_id, memFieldKeys[filter]));
  118. runnableKey.push(filter);
  119. break;
  120. case 'mem_stage_bonus':
  121. runnableRst.push(service.reportMemory.getStageBonus(params.tender_id, params.stage_id, memFieldKeys[filter]));
  122. runnableKey.push(filter);
  123. break;
  124. case 'mem_stage_other':
  125. runnableRst.push(service.reportMemory.getStageOther(params.tender_id, params.stage_id, memFieldKeys[filter]));
  126. runnableKey.push(filter);
  127. break;
  128. case 'mem_gather_stage_bills':
  129. runnableRst.push(service.rptGatherMemory.getGatherStageBills(memFieldKeys[filter],
  130. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  131. runnableKey.push(filter);
  132. break;
  133. case 'mem_gather_tender_info':
  134. runnableRst.push(service.rptGatherMemory.getGatherTenderInfo(memFieldKeys[filter],
  135. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  136. runnableKey.push(filter);
  137. break;
  138. case 'mem_gather_stage_pay':
  139. runnableRst.push(service.rptGatherMemory.getGatherStagePay(memFieldKeys[filter],
  140. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  141. runnableKey.push(filter);
  142. break;
  143. case 'mem_gather_deal_bills':
  144. runnableRst.push(service.rptGatherMemory.getGatherDealBills(memFieldKeys[filter],
  145. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  146. runnableKey.push(filter);
  147. break;
  148. case 'mem_material':
  149. runnableRst.push(service.reportMemory.getMaterial(params.tender_id, params.material_order, memFieldKeys[filter]));
  150. runnableKey.push(filter);
  151. break;
  152. case 'mem_material_gl':
  153. runnableRst.push(service.reportMemory.getMaterialGl(params.tender_id, params.material_order, memFieldKeys[filter]));
  154. runnableKey.push(filter);
  155. break;
  156. case 'mem_material_gl_detail':
  157. runnableRst.push(service.reportMemory.getMaterialGlDetail(params.tender_id, params.material_order, memFieldKeys[filter]));
  158. runnableKey.push(filter);
  159. break;
  160. case 'mem_material_bills':
  161. runnableRst.push(service.reportMemory.getMaterialBills(params.tender_id, params.material_order, memFieldKeys[filter]));
  162. runnableKey.push(filter);
  163. break;
  164. case 'mem_material_pos':
  165. runnableRst.push(service.reportMemory.getMaterialPos(params.tender_id, params.material_order, memFieldKeys[filter]));
  166. runnableKey.push(filter);
  167. break;
  168. case 'mem_stage_sum_bills':
  169. runnableRst.push(service.rptStageSumMemory.getStageSumBills(params.tender_id, memFieldKeys[filter],
  170. customDefine.stage_select, customSelect ? customSelect.stage_select : null));
  171. runnableKey.push(filter);
  172. break;
  173. case 'mem_stage_sum_pay':
  174. runnableRst.push(service.rptStageSumMemory.getStageSumPay(params.tender_id, memFieldKeys[filter],
  175. customDefine.stage_select, customSelect ? customSelect.stage_select : null));
  176. runnableKey.push(filter);
  177. break;
  178. case 'ledger_cooperation':
  179. runnableRst.push(service.ledgerCooperation.getValidData(params.tender_id));
  180. runnableKey.push(filter);
  181. break;
  182. case 'mem_sign_select':
  183. runnableRst.push(service.reportMemory.getSignSelect(params.tender_id, params.stage_id, customSelect));
  184. runnableKey.push(filter);
  185. break;
  186. case 'mem_stage_change':
  187. runnableRst.push(service.stageChange.getAllDataByCondition({ where: { tid: params.tender_id, sid: params.stage_id } }));
  188. runnableKey.push(filter);
  189. break;
  190. case 'mem_stage_change_bills':
  191. runnableRst.push(service.stageChangeFinal.getFinalData(params.tender_id));
  192. runnableKey.push(filter);
  193. break;
  194. case 'mem_ledger_tag':
  195. runnableRst.push(service.ledgerTag.getDatas(params.tender_id));
  196. runnableKey.push(filter);
  197. break;
  198. case 'mem_stage_tag':
  199. runnableRst.push(service.ledgerTag.getDatas(params.tender_id, params.stage_id));
  200. runnableKey.push(filter);
  201. break;
  202. case 'mem_all_tag':
  203. runnableRst.push(service.ledgerTag.getAllDataByCondition({ where: { tid: params.tender_id } }));
  204. runnableKey.push(filter);
  205. break;
  206. default:
  207. break;
  208. }
  209. }
  210. }
  211. const queryRst = await Promise.all(runnableRst);
  212. for (let idx = 0; idx < runnableKey.length; idx++) {
  213. rst[runnableKey[idx]] = queryRst[idx];
  214. }
  215. for (const filter of filters) {
  216. switch (filter) {
  217. case 'mem_stage_im_tz':
  218. rst[filter] = await service.reportMemory.getStageImTzData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  219. break;
  220. case 'mem_stage_im_tz_bills':
  221. rst[filter] = await service.reportMemory.getStageImTzBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  222. break;
  223. case 'mem_union_data':
  224. rst[filter] = [];
  225. break;
  226. case 'mem_change':
  227. rst[filter] = await service.reportMemory.getChangeData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  228. break;
  229. case 'mem_change_bills':
  230. rst[filter] = await service.reportMemory.getChangeBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  231. break;
  232. case 'mem_jh_im_change':
  233. const rptCustomData = require('../lib/rptCustomData');
  234. const jhHelper = new rptCustomData.jhHelper(this.ctx);
  235. rst[filter] = await jhHelper.convert(params.tender_id, params.stage_id, memFieldKeys[filter], customDefine.setting);
  236. break;
  237. case 'mem_jh_gather_im_change':
  238. const rptCustomData = require('../lib/rptCustomData');
  239. const jhHelper = new rptCustomData.jhHelper(this.ctx);
  240. rst[filter] = await jhHelper.gather(memFieldKeys[filter], customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  241. break;
  242. // case 'mem_material_bills':
  243. // rst[filter] = await service.rptGatherMemory.getMaterialBills(params.tender_id, params.material_order, memFieldKeys[filter]);
  244. // break;
  245. // case 'mem_material_bills_gl':
  246. // rst[filter] = await service.rptGatherMemory.getMaterialBillsGl(params.tender_id, params.material_order, memFieldKeys[filter]);
  247. // break;
  248. default:
  249. break;
  250. }
  251. }
  252. return rst;
  253. }
  254. }
  255. return Report;
  256. };