report.js 23 KB

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