report.js 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Mai
  6. * @date
  7. * @version
  8. */
  9. const rptCustomData = require('../lib/rptCustomData');
  10. module.exports = app => {
  11. class Report extends app.BaseService {
  12. /**
  13. * 构造函数
  14. *
  15. * @param {Object} ctx - egg全局context
  16. * @return {void}
  17. */
  18. constructor(ctx) {
  19. super(ctx);
  20. }
  21. async checkStg(ctx, params) {
  22. if (ctx.stage === null || ctx.stage === undefined || parseInt(ctx.stage.id) !== parseInt(params.stage_id)) {
  23. await ctx.service.stage.checkStage(params.stage_id);
  24. if (ctx.stage) {
  25. params.stage_order = ctx.stage.curOrder;
  26. }
  27. }
  28. }
  29. async getReportData(params, filters, memFieldKeys, customDefine, customSelect) {
  30. const service = this.ctx.service;
  31. await service.tender.checkTender(params.tender_id);
  32. const rst = {};
  33. const runnableRst = [];
  34. const runnableKey = []; // 这个配合runnableRst用,未来考虑并行查询优化
  35. for (const filter of filters) {
  36. if (runnableKey.indexOf(filter) < 0) {
  37. switch (filter) {
  38. case 'project' :
  39. runnableRst.push(service.project.getProjectById(params.project_id));
  40. runnableKey.push(filter);
  41. break;
  42. case 'tender_info' :
  43. runnableRst.push(service.tenderInfo.getTenderInfoEx(params.tender_id));
  44. runnableKey.push(filter);
  45. break;
  46. case 'advance_pay':
  47. runnableRst.push(service.advance.getAllDataByCondition({ where: { tid: params.tender_id } }));
  48. runnableKey.push(filter);
  49. break;
  50. case 'deal_bills' :
  51. runnableRst.push(service.dealBills.getDataByTenderId(params.tender_id));
  52. runnableKey.push('deal_bills');
  53. break;
  54. case 'ledger' :
  55. runnableRst.push(service.ledger.getData(params.tender_id, 0));
  56. runnableKey.push(filter);
  57. break;
  58. case 'stage_bills':
  59. runnableRst.push(service.stageBills.getLastestStageData2(params.tender_id, params.stage_id));
  60. runnableKey.push(filter);
  61. break;
  62. case 'stage_bills_final':
  63. await this.checkStg(this.ctx, params);
  64. runnableRst.push(service.stageBillsFinal.getFinalDataEx(params.tender_id, params.stage_order));
  65. runnableKey.push(filter);
  66. break;
  67. case 'stage':
  68. runnableRst.push(service.stage.getStageById(params.stage_id));
  69. runnableKey.push(filter);
  70. break;
  71. case 'stage_pay':
  72. await this.checkStg(this.ctx, params);
  73. runnableRst.push(service.stagePay.getAuditorStageData(params.stage_id, params.stage_times, params.stage_order));
  74. runnableKey.push(filter);
  75. break;
  76. case 'mem_stage_im_zl':
  77. runnableRst.push(service.reportMemory.getStageImZlData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  78. runnableKey.push(filter);
  79. break;
  80. case 'mem_month_progress':
  81. runnableRst.push(service.reportMemory.getMonthProgress(params.tender_id, memFieldKeys[filter]));
  82. runnableKey.push(filter);
  83. break;
  84. case 'stage_audit':
  85. runnableRst.push(service.reportMemory.getStageAuditors(params.tender_id, params.stage_id));
  86. runnableKey.push(filter);
  87. break;
  88. case 'mem_stage_bills':
  89. runnableRst.push(service.reportMemory.getStageBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  90. runnableKey.push(filter);
  91. break;
  92. case 'mem_stage_pos':
  93. runnableRst.push(service.reportMemory.getStagePosData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  94. runnableKey.push(filter);
  95. break;
  96. case 'mem_stage_pos_compare':
  97. runnableRst.push(service.reportMemory.getStagePosCompareData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  98. runnableKey.push(filter);
  99. break;
  100. case 'mem_stage_bills_compare':
  101. runnableRst.push(service.reportMemory.getStageBillsCompareData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  102. runnableKey.push(filter);
  103. break;
  104. case 'mem_stage_pay':
  105. runnableRst.push(service.reportMemory.getStagePayData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  106. runnableKey.push(filter);
  107. break;
  108. case 'change':
  109. runnableRst.push(service.change.getListByStatus(params.tender_id, 3)); // 获取所有审核通过的变更主信息
  110. runnableKey.push(filter);
  111. break;
  112. case 'change_audit_list':
  113. runnableRst.push(service.changeAuditList.getChangeAuditBills(params.tender_id)); // 获取所有审核通过的变更清单
  114. runnableKey.push(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_stage_safe_prod':
  129. runnableRst.push(service.reportMemory.getStageSafeProd(params.tender_id, params.stage_id, memFieldKeys[filter]));
  130. runnableKey.push(filter);
  131. break;
  132. case 'mem_stage_temp_land':
  133. runnableRst.push(service.reportMemory.getStageTempLand(params.tender_id, params.stage_id, memFieldKeys[filter]));
  134. runnableKey.push(filter);
  135. break;
  136. case 'mem_gather_stage_bills':
  137. runnableRst.push(service.rptGatherMemory.getGatherStageBills(memFieldKeys[filter],
  138. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  139. runnableKey.push(filter);
  140. break;
  141. case 'mem_gather_tender_info':
  142. runnableRst.push(service.rptGatherMemory.getGatherTenderInfo(memFieldKeys[filter],
  143. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  144. runnableKey.push(filter);
  145. break;
  146. case 'mem_gather_stage_pay':
  147. runnableRst.push(service.rptGatherMemory.getGatherStagePay(memFieldKeys[filter],
  148. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  149. runnableKey.push(filter);
  150. break;
  151. case 'mem_gather_deal_bills':
  152. runnableRst.push(service.rptGatherMemory.getGatherDealBills(memFieldKeys[filter],
  153. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  154. runnableKey.push(filter);
  155. break;
  156. case 'mem_select_material':
  157. runnableRst.push(service.material.getSelectMaterial(params.tender_id, params.material_order));
  158. runnableKey.push(filter);
  159. break;
  160. case 'mem_select_material_audit':
  161. runnableRst.push(service.reportMemory.getSelectMaterialAuditors(params.tender_id, params.material_order));
  162. runnableKey.push(filter);
  163. break;
  164. case 'mem_material':
  165. runnableRst.push(service.reportMemory.getMaterial(params.tender_id, params.material_order, memFieldKeys[filter]));
  166. runnableKey.push(filter);
  167. break;
  168. case 'mem_material_gl':
  169. runnableRst.push(service.reportMemory.getMaterialGl(params.tender_id, params.material_order, memFieldKeys[filter]));
  170. runnableKey.push(filter);
  171. break;
  172. case 'mem_material_gl_detail':
  173. runnableRst.push(service.reportMemory.getMaterialGlDetail(params.tender_id, params.material_order, memFieldKeys[filter]));
  174. runnableKey.push(filter);
  175. break;
  176. case 'mem_material_bills':
  177. runnableRst.push(service.reportMemory.getMaterialBills(params.tender_id, params.material_order, memFieldKeys[filter]));
  178. runnableKey.push(filter);
  179. break;
  180. case 'mem_material_pos':
  181. runnableRst.push(service.reportMemory.getMaterialPos(params.tender_id, params.material_order, memFieldKeys[filter]));
  182. runnableKey.push(filter);
  183. break;
  184. case 'mem_stage_sum_bills':
  185. runnableRst.push(service.rptStageSumMemory.getStageSumBills(params.tender_id, memFieldKeys[filter],
  186. customDefine.stage_select, customSelect ? customSelect.stage_select : null));
  187. runnableKey.push(filter);
  188. break;
  189. case 'mem_stage_sum_pay':
  190. runnableRst.push(service.rptStageSumMemory.getStageSumPay(params.tender_id, memFieldKeys[filter],
  191. customDefine.stage_select, customSelect ? customSelect.stage_select : null));
  192. runnableKey.push(filter);
  193. break;
  194. case 'mem_material_sum_gl':
  195. runnableRst.push(service.rptStageSumMemory.getMaterialSumGl(params.tender_id, memFieldKeys[filter],
  196. customDefine.material_sum_select, customSelect ? customSelect.material_sum_select : null));
  197. runnableKey.push(filter);
  198. break;
  199. case 'ledger_cooperation':
  200. runnableRst.push(service.ledgerCooperation.getValidData(params.tender_id));
  201. runnableKey.push(filter);
  202. break;
  203. case 'mem_sign_select':
  204. runnableRst.push(service.reportMemory.getSignSelect(params.tender_id, params.stage_id, customSelect));
  205. runnableKey.push(filter);
  206. break;
  207. case 'mem_stage_change':
  208. runnableRst.push(service.stageChange.getAllDataByCondition({ where: { tid: params.tender_id, sid: params.stage_id } }));
  209. runnableKey.push(filter);
  210. break;
  211. case 'mem_stage_change_bills':
  212. runnableRst.push(service.stageChangeFinal.getFinalData(params.tender_id));
  213. runnableKey.push(filter);
  214. break;
  215. case 'mem_ledger_tag':
  216. runnableRst.push(service.ledgerTag.getDatas(params.tender_id));
  217. runnableKey.push(filter);
  218. break;
  219. case 'mem_stage_tag':
  220. runnableRst.push(service.ledgerTag.getDatas(params.tender_id, params.stage_id));
  221. runnableKey.push(filter);
  222. break;
  223. case 'mem_all_tag':
  224. runnableRst.push(service.ledgerTag.getAllDataByCondition({ where: { tid: params.tender_id } }));
  225. runnableKey.push(filter);
  226. break;
  227. case 'mem_change_info':
  228. runnableRst.push(service.reportMemory.getChangeInfo(params.tender_id, params.stage_id));
  229. runnableKey.push(filter);
  230. break;
  231. case 'mem_change_info_bills':
  232. runnableRst.push(service.reportMemory.getChangeInfoBills(params.tender_id, params.stage_id));
  233. runnableKey.push(filter);
  234. break;
  235. case 'mem_stage_rela_im':
  236. runnableRst.push(service.stageRelaIm.getAllDataByCondition({ where: { tid: params.tender_id, sid: params.stage_id } }));
  237. runnableKey.push(filter);
  238. break;
  239. case 'mem_stage_rela_im_bills':
  240. runnableRst.push(service.stageRelaImBills.getAllDataByCondition({ where: { tid: params.tender_id, sid: params.stage_id } }));
  241. runnableKey.push(filter);
  242. break;
  243. case 'mem_change_apply':
  244. runnableRst.push(service.changeApply.getAllDataByCondition({ where: { tid: params.tender_id } }));
  245. runnableKey.push(filter);
  246. break;
  247. case 'mem_change_project':
  248. runnableRst.push(service.changeProject.getAllDataByCondition({ where: { tid: params.tender_id } }));
  249. runnableKey.push(filter);
  250. break;
  251. default:
  252. break;
  253. }
  254. }
  255. }
  256. const queryRst = await Promise.all(runnableRst);
  257. for (let idx = 0; idx < runnableKey.length; idx++) {
  258. rst[runnableKey[idx]] = queryRst[idx];
  259. }
  260. for (const filter of filters) {
  261. switch (filter) {
  262. case 'mem_custom_select':
  263. rst[filter] = customSelect;
  264. break;
  265. case 'mem_stage_im_tz':
  266. rst[filter] = await service.reportMemory.getStageImTzData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  267. break;
  268. case 'mem_stage_im_tz_bills':
  269. rst[filter] = await service.reportMemory.getStageImTzBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  270. break;
  271. case 'mem_union_data':
  272. rst[filter] = [];
  273. break;
  274. case 'mem_change':
  275. rst[filter] = await service.reportMemory.getChangeData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  276. break;
  277. case 'mem_change_bills':
  278. rst[filter] = await service.reportMemory.getChangeBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  279. break;
  280. case 'mem_change_audit':
  281. rst[filter] = await service.reportMemory.getChangeAuditData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  282. break;
  283. case 'mem_jh_im_change':
  284. const jhHelper1 = new rptCustomData.jhHelper(this.ctx);
  285. rst[filter] = await jhHelper1.convert(params.tender_id, params.stage_id, memFieldKeys[filter], customDefine.option);
  286. break;
  287. case 'mem_jh_gather_im_change':
  288. const jhHelper2 = new rptCustomData.jhHelper(this.ctx);
  289. rst[filter] = await jhHelper2.gather(memFieldKeys[filter], customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  290. break;
  291. case 'mem_jh_gather_stage_bills_compare':
  292. const jhHelper3 = new rptCustomData.jhHelper(this.ctx);
  293. rst[filter] = await jhHelper3.gatherBills(memFieldKeys[filter], customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  294. break;
  295. // case 'mem_material_bills':
  296. // rst[filter] = await service.rptGatherMemory.getMaterialBills(params.tender_id, params.material_order, memFieldKeys[filter]);
  297. // break;
  298. // case 'mem_material_bills_gl':
  299. // rst[filter] = await service.rptGatherMemory.getMaterialBillsGl(params.tender_id, params.material_order, memFieldKeys[filter]);
  300. // break;
  301. default:
  302. break;
  303. }
  304. }
  305. return rst;
  306. }
  307. }
  308. return Report;
  309. };