report.js 21 KB

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