report.js 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Mai
  6. * @date
  7. * @version
  8. */
  9. const BudgetSource = require('../lib/rm/budget');
  10. const MaterialSource = require('../lib/rm/material');
  11. const rptCustomData = require('../lib/rptCustomData');
  12. const bindData = {
  13. materialGather: ['mem_material_gather_bills', 'mem_material_gather_xmj', 'mem_material_gather_gl'],
  14. gatherChange: ['mem_gather_change', 'mem_gather_change_bills'],
  15. };
  16. module.exports = app => {
  17. class Report extends app.BaseService {
  18. /**
  19. * 构造函数
  20. *
  21. * @param {Object} ctx - egg全局context
  22. * @return {void}
  23. */
  24. constructor(ctx) {
  25. super(ctx);
  26. }
  27. async checkStg(ctx, params) {
  28. if (ctx.stage === null || ctx.stage === undefined || parseInt(ctx.stage.id) !== parseInt(params.stage_id)) {
  29. await ctx.service.stage.checkStage(params.stage_id);
  30. if (ctx.stage) {
  31. params.stage_order = ctx.stage.curOrder;
  32. }
  33. }
  34. }
  35. getFilter(sourceFilters) {
  36. const common = [], spec = [];
  37. for (const sf of sourceFilters) {
  38. let bSpec = false;
  39. for (const key in bindData) {
  40. const b = bindData[key];
  41. if (b.indexOf(sf) >= 0) {
  42. bSpec = true;
  43. if (spec.indexOf(key) === -1) {
  44. spec.push(key);
  45. break;
  46. }
  47. }
  48. }
  49. if (!bSpec) common.push(sf);
  50. }
  51. return [common, spec];
  52. }
  53. async getReportData(params, sourceFilters, memFieldKeys, customDefine, customSelect) {
  54. const [filters, specFilters] = this.getFilter(sourceFilters);
  55. const service = this.ctx.service;
  56. await service.tender.checkTender(params.tender_id);
  57. const materialSource = new MaterialSource(this.ctx);
  58. const rst = {};
  59. const runnableRst = [];
  60. const runnableKey = []; // 这个配合runnableRst用,未来考虑并行查询优化
  61. const budgetSource = new BudgetSource(this.ctx);
  62. for (const filter of filters) {
  63. if (runnableKey.indexOf(filter) < 0) {
  64. switch (filter) {
  65. case 'project' :
  66. runnableRst.push(service.project.getProjectById(params.project_id));
  67. runnableKey.push(filter);
  68. break;
  69. case 'tender_info' :
  70. runnableRst.push(service.tenderInfo.getTenderInfoEx(params.tender_id));
  71. runnableKey.push(filter);
  72. break;
  73. case 'advance_pay':
  74. runnableRst.push(service.advance.getAllDataByCondition({ where: { tid: params.tender_id } }));
  75. runnableKey.push(filter);
  76. break;
  77. case 'deal_bills' :
  78. runnableRst.push(service.dealBills.getDataByTenderId(params.tender_id));
  79. runnableKey.push('deal_bills');
  80. break;
  81. case 'ledger' :
  82. runnableRst.push(service.ledger.getData(params.tender_id, 0));
  83. runnableKey.push(filter);
  84. break;
  85. case 'stage_bills':
  86. runnableRst.push(service.stageBills.getLastestStageData2(params.tender_id, params.stage_id));
  87. runnableKey.push(filter);
  88. break;
  89. case 'stage_bills_final':
  90. await this.checkStg(this.ctx, params);
  91. runnableRst.push(service.stageBillsFinal.getFinalDataEx(params.tender_id, params.stage_order));
  92. runnableKey.push(filter);
  93. break;
  94. case 'stage':
  95. runnableRst.push(service.stage.getStageById(params.stage_id));
  96. runnableKey.push(filter);
  97. break;
  98. case 'stage_pay':
  99. await this.checkStg(this.ctx, params);
  100. runnableRst.push(service.stagePay.getAuditorStageData(params.stage_id, params.stage_times, params.stage_order));
  101. runnableKey.push(filter);
  102. break;
  103. case 'mem_stage_im_zl':
  104. runnableRst.push(service.reportMemory.getStageImZlData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  105. runnableKey.push(filter);
  106. break;
  107. case 'mem_month_progress':
  108. runnableRst.push(service.reportMemory.getMonthProgress(params.tender_id, memFieldKeys[filter]));
  109. runnableKey.push(filter);
  110. break;
  111. case 'stage_audit':
  112. runnableRst.push(service.reportMemory.getStageAuditors(params.tender_id, params.stage_id));
  113. runnableKey.push(filter);
  114. break;
  115. case 'mem_stage_audit_ass':
  116. runnableRst.push(service.reportMemory.getStageAuditAss(params.tender_id, params.stage_id));
  117. runnableKey.push(filter);
  118. break;
  119. case 'mem_stage_bills':
  120. runnableRst.push(service.reportMemory.getStageBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  121. runnableKey.push(filter);
  122. break;
  123. case 'mem_stage_bills_filter':
  124. runnableRst.push(service.reportMemory.getStageBillsData(params.tender_id, params.stage_id, memFieldKeys[filter], true));
  125. runnableKey.push(filter);
  126. break;
  127. case 'mem_stage_pos':
  128. runnableRst.push(service.reportMemory.getStagePosData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  129. runnableKey.push(filter);
  130. break;
  131. case 'mem_stage_pos_compare':
  132. runnableRst.push(service.reportMemory.getStagePosCompareData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  133. runnableKey.push(filter);
  134. break;
  135. case 'mem_stage_bills_compare':
  136. runnableRst.push(service.reportMemory.getStageBillsCompareData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  137. runnableKey.push(filter);
  138. break;
  139. case 'mem_stage_bills_compare_filter':
  140. runnableRst.push(service.reportMemory.getStageBillsCompareData(params.tender_id, params.stage_id, memFieldKeys[filter], true));
  141. runnableKey.push(filter);
  142. break;
  143. case 'mem_stage_pay':
  144. runnableRst.push(service.reportMemory.getStagePayData(params.tender_id, params.stage_id, memFieldKeys[filter]));
  145. runnableKey.push(filter);
  146. break;
  147. case 'change':
  148. runnableRst.push(service.change.getListByStatus(params.tender_id, 3)); // 获取所有审核通过的变更主信息
  149. runnableKey.push(filter);
  150. break;
  151. case 'change_audit_list':
  152. runnableRst.push(service.changeAuditList.getChangeAuditBills(params.tender_id)); // 获取所有审核通过的变更清单
  153. runnableKey.push(filter);
  154. break;
  155. case 'mem_stage_jgcl':
  156. runnableRst.push(service.reportMemory.getStageJgcl(params.tender_id, params.stage_id, memFieldKeys[filter]));
  157. runnableKey.push(filter);
  158. break;
  159. case 'mem_stage_bonus':
  160. runnableRst.push(service.reportMemory.getStageBonus(params.tender_id, params.stage_id, memFieldKeys[filter]));
  161. runnableKey.push(filter);
  162. break;
  163. case 'mem_stage_other':
  164. runnableRst.push(service.reportMemory.getStageOther(params.tender_id, params.stage_id, memFieldKeys[filter]));
  165. runnableKey.push(filter);
  166. break;
  167. case 'mem_stage_safe_prod':
  168. runnableRst.push(service.reportMemory.getStageSafeProd(params.tender_id, params.stage_id, memFieldKeys[filter]));
  169. runnableKey.push(filter);
  170. break;
  171. case 'mem_stage_temp_land':
  172. runnableRst.push(service.reportMemory.getStageTempLand(params.tender_id, params.stage_id, memFieldKeys[filter]));
  173. runnableKey.push(filter);
  174. break;
  175. case 'mem_gather_tender_info':
  176. runnableRst.push(service.rptGatherMemory.getGatherTenderInfo(memFieldKeys[filter],
  177. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  178. runnableKey.push(filter);
  179. break;
  180. case 'mem_gather_stage_pay':
  181. runnableRst.push(service.rptGatherMemory.getGatherStagePay(memFieldKeys[filter],
  182. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  183. runnableKey.push(filter);
  184. break;
  185. case 'mem_gather_deal_bills':
  186. runnableRst.push(service.rptGatherMemory.getGatherDealBills(memFieldKeys[filter],
  187. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  188. runnableKey.push(filter);
  189. break;
  190. case 'mem_gather_stage_jgcl':
  191. runnableRst.push(service.rptGatherMemory.getGatherStageJgcl(memFieldKeys[filter],
  192. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  193. runnableKey.push(filter);
  194. break;
  195. case 'mem_gather_stage_bonus':
  196. runnableRst.push(service.rptGatherMemory.getGatherStageBonus(memFieldKeys[filter],
  197. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  198. runnableKey.push(filter);
  199. break;
  200. case 'mem_gather_stage_other':
  201. runnableRst.push(service.rptGatherMemory.getGatherStageOther(memFieldKeys[filter],
  202. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  203. runnableKey.push(filter);
  204. break;
  205. case 'mem_gather_stage_safe_prod':
  206. runnableRst.push(service.rptGatherMemory.getGatherStageSafeProd(memFieldKeys[filter],
  207. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  208. runnableKey.push(filter);
  209. break;
  210. case 'mem_gather_stage_temp_land':
  211. runnableRst.push(service.rptGatherMemory.getGatherStageTempLand(memFieldKeys[filter],
  212. customDefine.gather_select, customSelect ? customSelect.gather_select : null));
  213. runnableKey.push(filter);
  214. break;
  215. case 'mem_select_material':
  216. runnableRst.push(service.material.getSelectMaterial(params.tender_id, params.material_order));
  217. runnableKey.push(filter);
  218. break;
  219. case 'mem_select_material_audit':
  220. runnableRst.push(materialSource.getSelectMaterialAuditors(params.tender_id, params.material_order));
  221. runnableKey.push(filter);
  222. break;
  223. case 'mem_material':
  224. runnableRst.push(materialSource.getMaterial(params.tender_id, params.material_order, memFieldKeys[filter]));
  225. runnableKey.push(filter);
  226. break;
  227. case 'mem_material_gl':
  228. runnableRst.push(materialSource.getMaterialGl(params.tender_id, params.material_order, memFieldKeys[filter]));
  229. runnableKey.push(filter);
  230. break;
  231. case 'mem_material_gl_detail':
  232. runnableRst.push(materialSource.getMaterialGlDetail(params.tender_id, params.material_order, memFieldKeys[filter]));
  233. runnableKey.push(filter);
  234. break;
  235. case 'mem_material_bills':
  236. runnableRst.push(materialSource.getMaterialBills(params.tender_id, params.material_order, memFieldKeys[filter]));
  237. runnableKey.push(filter);
  238. break;
  239. case 'mem_material_bills_filter':
  240. runnableRst.push(materialSource.getMaterialBills(params.tender_id, params.material_order, memFieldKeys[filter], true));
  241. runnableKey.push(filter);
  242. break;
  243. case 'mem_material_pos':
  244. runnableRst.push(materialSource.getMaterialPos(params.tender_id, params.material_order, memFieldKeys[filter]));
  245. runnableKey.push(filter);
  246. break;
  247. case 'mem_material_stage':
  248. runnableRst.push(materialSource.getMaterialStage(params.tender_id, params.material_order, memFieldKeys[filter]));
  249. runnableKey.push(filter);
  250. break;
  251. case 'mem_stage_sum_bills':
  252. runnableRst.push(service.rptStageSumMemory.getStageSumBills(params.tender_id, memFieldKeys[filter],
  253. customDefine.stage_select, customSelect ? customSelect.stage_select : null));
  254. runnableKey.push(filter);
  255. break;
  256. case 'mem_stage_sum_bills_filter':
  257. runnableRst.push(service.rptStageSumMemory.getStageSumBills(params.tender_id, memFieldKeys[filter],
  258. customDefine.stage_select, customSelect ? customSelect.stage_select : null, true));
  259. runnableKey.push(filter);
  260. break;
  261. case 'mem_stage_sum_pay':
  262. runnableRst.push(service.rptStageSumMemory.getStageSumPay(params.tender_id, memFieldKeys[filter],
  263. customDefine.stage_select, customSelect ? customSelect.stage_select : null));
  264. runnableKey.push(filter);
  265. break;
  266. case 'mem_material_sum_gl':
  267. runnableRst.push(service.rptStageSumMemory.getMaterialSumGl(params.tender_id, memFieldKeys[filter],
  268. customDefine.material_sum_select, customSelect ? customSelect.material_sum_select : null));
  269. runnableKey.push(filter);
  270. break;
  271. case 'ledger_cooperation':
  272. runnableRst.push(service.ledgerCooperation.getValidData(params.tender_id));
  273. runnableKey.push(filter);
  274. break;
  275. case 'mem_sign_select':
  276. runnableRst.push(service.reportMemory.getSignSelect(params.tender_id, params.stage_id, customSelect));
  277. runnableKey.push(filter);
  278. break;
  279. case 'mem_stage_change':
  280. runnableRst.push(service.stageChange.getAllDataByCondition({ where: { tid: params.tender_id, sid: params.stage_id } }));
  281. runnableKey.push(filter);
  282. break;
  283. case 'mem_stage_change_bills':
  284. runnableRst.push(service.stageChangeFinal.getFinalData(params.tender_id));
  285. runnableKey.push(filter);
  286. break;
  287. case 'mem_ledger_tag':
  288. runnableRst.push(service.ledgerTag.getDatas(params.tender_id));
  289. runnableKey.push(filter);
  290. break;
  291. case 'mem_stage_tag':
  292. runnableRst.push(service.ledgerTag.getDatas(params.tender_id, params.stage_id));
  293. runnableKey.push(filter);
  294. break;
  295. case 'mem_all_tag':
  296. runnableRst.push(service.ledgerTag.getAllDataByCondition({ where: { tid: params.tender_id } }));
  297. runnableKey.push(filter);
  298. break;
  299. case 'mem_change_info':
  300. runnableRst.push(service.reportMemory.getChangeInfo(params.tender_id, params.stage_id));
  301. runnableKey.push(filter);
  302. break;
  303. case 'mem_change_info_bills':
  304. runnableRst.push(service.reportMemory.getChangeInfoBills(params.tender_id, params.stage_id));
  305. runnableKey.push(filter);
  306. break;
  307. case 'mem_stage_rela_im':
  308. runnableRst.push(service.stageRelaIm.getAllDataByCondition({ where: { tid: params.tender_id, sid: params.stage_id } }));
  309. runnableKey.push(filter);
  310. break;
  311. case 'mem_stage_rela_im_bills':
  312. runnableRst.push(service.stageRelaImBills.getAllDataByCondition({ where: { tid: params.tender_id, sid: params.stage_id } }));
  313. runnableKey.push(filter);
  314. break;
  315. case 'mem_budget_gu':
  316. runnableRst.push(params.budget_id ? budgetSource.budgetGu(params.budget_id) : budgetSource.tenderGu(params.tender_id));
  317. runnableKey.push(filter);
  318. break;
  319. case 'mem_budget_gai':
  320. runnableRst.push(params.budget_id ? budgetSource.budgetGai(params.budget_id) : budgetSource.tenderGai(params.tender_id));
  321. runnableKey.push(filter);
  322. break;
  323. case 'mem_budget_yu':
  324. runnableRst.push(params.budget_id ? budgetSource.budgetYu(params.budget_id) : budgetSource.tenderYu(params.tender_id));
  325. runnableKey.push(filter);
  326. break;
  327. case 'mem_budget_final':
  328. runnableRst.push(params.budget_id ? budgetSource.budgetFinal(params.budget_id) : budgetSource.tenderFinal(params.tender_id));
  329. runnableKey.push(filter);
  330. break;
  331. case 'mem_budget_gu_filter':
  332. runnableRst.push(params.budget_id ? budgetSource.budgetGu(params.budget_id, true) : budgetSource.tenderGu(params.tender_id, true));
  333. runnableKey.push(filter);
  334. break;
  335. case 'mem_budget_gai_filter':
  336. runnableRst.push(params.budget_id ? budgetSource.budgetGai(params.budget_id, true) : budgetSource.tenderGai(params.tender_id, true));
  337. runnableKey.push(filter);
  338. break;
  339. case 'mem_budget_yu_filter':
  340. runnableRst.push(params.budget_id ? budgetSource.budgetYu(params.budget_id, true) : budgetSource.tenderYu(params.tender_id, true));
  341. runnableKey.push(filter);
  342. break;
  343. case 'mem_budget_final_filter':
  344. runnableRst.push(params.budget_id ? budgetSource.budgetFinal(params.budget_id, true) : budgetSource.tenderFinal(params.tender_id, true));
  345. runnableKey.push(filter);
  346. break;
  347. case 'mem_pm_deal_pay':
  348. runnableRst.push(service.reportMemory.getPmDeal());
  349. runnableKey.push(filter);
  350. break;
  351. default:
  352. break;
  353. }
  354. }
  355. }
  356. const queryRst = await Promise.all(runnableRst);
  357. for (let idx = 0; idx < runnableKey.length; idx++) {
  358. rst[runnableKey[idx]] = queryRst[idx];
  359. }
  360. for (const filter of filters) {
  361. switch (filter) {
  362. case 'mem_custom_select':
  363. rst[filter] = customSelect;
  364. break;
  365. case 'mem_stage_im_tz':
  366. rst[filter] = await service.reportMemory.getStageImTzData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  367. break;
  368. case 'mem_stage_im_tz_bills':
  369. rst[filter] = await service.reportMemory.getStageImTzBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  370. break;
  371. case 'mem_union_data':
  372. rst[filter] = [];
  373. break;
  374. case 'mem_import_change':
  375. rst[filter] = await service.reportMemory.getImportChangeData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  376. break;
  377. case 'mem_import_change_bills':
  378. rst[filter] = await service.reportMemory.getImportChangeBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  379. break;
  380. case 'mem_change':
  381. rst[filter] = await service.reportMemory.getChangeData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  382. break;
  383. case 'mem_change_bills':
  384. rst[filter] = await service.reportMemory.getChangeBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  385. break;
  386. case 'mem_change_audit':
  387. rst[filter] = await service.reportMemory.getChangeAuditData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  388. break;
  389. case 'mem_change_apply':
  390. rst[filter] = await service.reportMemory.getChangeApplyData(params.tender_id);
  391. break;
  392. case 'mem_change_apply_bills':
  393. rst[filter] = await service.reportMemory.getChangeApplyBillsData(params.tender_id);
  394. break;
  395. case 'mem_change_apply_audit':
  396. rst[filter] = await service.reportMemory.getChangeApplyAuditData(params.tender_id);
  397. break;
  398. case 'mem_change_plan':
  399. rst[filter] = await service.reportMemory.getChangePlanData(params.tender_id);
  400. break;
  401. case 'mem_change_plan_bills':
  402. rst[filter] = await service.reportMemory.getChangePlanBillsData(params.tender_id);
  403. break;
  404. case 'mem_change_plan_audit':
  405. rst[filter] = await service.reportMemory.getChangePlanAuditData(params.tender_id);
  406. break;
  407. case 'mem_change_project':
  408. rst[filter] = await service.reportMemory.getChangeProjectData(params.tender_id);
  409. break;
  410. case 'mem_change_project_audit':
  411. rst[filter] = await service.reportMemory.getChangeProjectAuditData(params.tender_id);
  412. break;
  413. case 'mem_jh_im_change':
  414. const jhHelper1 = new rptCustomData.jhHelper(this.ctx);
  415. rst[filter] = await jhHelper1.convert(params.tender_id, params.stage_id, memFieldKeys[filter], customDefine.option);
  416. break;
  417. case 'mem_jh_gather_im_change':
  418. const jhHelper2 = new rptCustomData.jhHelper(this.ctx);
  419. rst[filter] = await jhHelper2.gather(memFieldKeys[filter], customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  420. break;
  421. case 'mem_jh_gather_stage_bills_compare':
  422. const jhHelper3 = new rptCustomData.jhHelper(this.ctx);
  423. rst[filter] = await jhHelper3.gatherBills(memFieldKeys[filter], customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  424. break;
  425. case 'mem_gather_stage_bills':
  426. rst[filter] = await service.rptGatherMemory.getGatherStageBills(memFieldKeys[filter],
  427. customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  428. break;
  429. case 'mem_gather_stage_bills_filter':
  430. rst[filter] = await service.rptGatherMemory.getGatherStageBills(memFieldKeys[filter],
  431. customDefine.gather_select, customSelect ? customSelect.gather_select : null, true);
  432. break;
  433. case 'mem_gather_stage_pos':
  434. rst[filter] = await service.rptGatherMemory.getGatherStagePos(memFieldKeys[filter],
  435. customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  436. break;
  437. // case 'mem_material_bills':
  438. // rst[filter] = await service.rptGatherMemory.getMaterialBills(params.tender_id, params.material_order, memFieldKeys[filter]);
  439. // break;
  440. // case 'mem_material_bills_gl':
  441. // rst[filter] = await service.rptGatherMemory.getMaterialBillsGl(params.tender_id, params.material_order, memFieldKeys[filter]);
  442. // break;
  443. default:
  444. break;
  445. }
  446. }
  447. for (const s of specFilters) {
  448. switch (s) {
  449. case 'materialGather':
  450. const mgResult = await materialSource.getMaterialGatherBills(params.tender_id, params.material_order);
  451. for (const d in mgResult) {
  452. rst[d] = mgResult[d];
  453. }
  454. break;
  455. case 'gatherChange':
  456. const gcResult = await service.rptGatherMemory.getGatherChange(memFieldKeys['mem_gather_change'],
  457. customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  458. for (const d in gcResult) {
  459. rst[d] = gcResult[d];
  460. }
  461. default:
  462. break;
  463. }
  464. }
  465. return rst;
  466. }
  467. }
  468. return Report;
  469. };