tender.js 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Mai
  6. * @date
  7. * @version
  8. */
  9. const RptMemBase = require('./base');
  10. const bindData = {
  11. materialGather: ['mem_material_gather_bills', 'mem_material_gather_xmj', 'mem_material_gather_gl'],
  12. gatherChange: ['mem_gather_change', 'mem_gather_change_bills'],
  13. fjChange: ['mem_fj_change_progress', 'mem_fj_change_sum'],
  14. };
  15. const BudgetSource = require('./tender_budget');
  16. const MaterialSource = require('./tender_material');
  17. const FinancialSource = require('./tender_financial');
  18. const rptCustomData = require('../rptCustomData');
  19. const SpssSource = require('./spss');
  20. class rptMemPaymentSafe extends RptMemBase {
  21. constructor(ctx) {
  22. super(ctx, bindData);
  23. }
  24. async checkStg(ctx, params) {
  25. if (ctx.stage === null || ctx.stage === undefined || parseInt(ctx.stage.id) !== parseInt(params.stage_id)) {
  26. await ctx.service.stage.checkStage(params.stage_id);
  27. if (ctx.stage) {
  28. params.stage_order = ctx.stage.curOrder;
  29. }
  30. }
  31. }
  32. async doBeforeLoadReport(params) {
  33. await this.ctx.service.tender.checkTender(params.tender_id);
  34. await this.checkStg(this.ctx, params);
  35. }
  36. getCommonData(params, tableName, fields, customDefine, customSelect) {
  37. const service = this.ctx.service;
  38. const budgetSource = new BudgetSource(this.ctx);
  39. const financialSource = new FinancialSource(this.ctx);
  40. switch (tableName) {
  41. case 'project' :
  42. return service.project.getProjectById(params.project_id);
  43. case 'tender_info' :
  44. return service.tenderInfo.getTenderInfoEx(params.tender_id);
  45. case 'advance_pay':
  46. return service.advance.getAllDataByCondition({ where: { tid: params.tender_id } });
  47. case 'deal_bills' :
  48. return service.dealBills.getDataByTenderId(params.tender_id);
  49. case 'ledger' :
  50. return service.ledger.getData(params.tender_id, 0);
  51. case 'stage_bills':
  52. return service.stageBills.getLastestStageData2(params.tender_id, params.stage_id);
  53. case 'stage_bills_final':
  54. return service.stageBillsFinal.getFinalDataEx(params.tender_id, params.stage_order);
  55. case 'stage':
  56. return service.stage.getStageById(params.stage_id);
  57. case 'stage_pay':
  58. return service.stagePay.getStagePays(ctx.stage);
  59. case 'mem_stage_im_zl':
  60. return service.reportMemory.getStageImZlData(params.tender_id, params.stage_id, fields);
  61. case 'mem_month_progress':
  62. return service.reportMemory.getMonthProgress(params.tender_id, fields);
  63. case 'stage_audit':
  64. return service.reportMemory.getStageAuditors(params.tender_id, params.stage_id);
  65. case 'mem_stage_audit_ass':
  66. return service.reportMemory.getStageAuditAss(params.tender_id, params.stage_id);
  67. case 'mem_stage_bills':
  68. return service.reportMemory.getStageBillsData(params.tender_id, params.stage_id, fields);
  69. case 'mem_stage_bills_filter':
  70. return service.reportMemory.getStageBillsData(params.tender_id, params.stage_id, fields, true);
  71. case 'mem_stage_pos':
  72. return service.reportMemory.getStagePosData(params.tender_id, params.stage_id, fields);
  73. case 'mem_stage_pos_compare':
  74. return service.reportMemory.getStagePosCompareData(params.tender_id, params.stage_id, fields);
  75. case 'mem_stage_bills_compare':
  76. return service.reportMemory.getStageBillsCompareData(params.tender_id, params.stage_id, fields);
  77. case 'mem_stage_bills_compare_filter':
  78. return service.reportMemory.getStageBillsCompareData(params.tender_id, params.stage_id, fields, true);
  79. case 'mem_stage_pay':
  80. return service.reportMemory.getStagePayData(params.tender_id, params.stage_id, fields);
  81. case 'change':
  82. return service.change.getListByStatus(params.tender_id, 3); // 获取所有审核通过的变更主信息
  83. case 'change_audit_list':
  84. return service.changeAuditList.getChangeAuditBills(params.tender_id); // 获取所有审核通过的变更清单
  85. case 'mem_stage_jgcl':
  86. return service.reportMemory.getStageJgcl(params.tender_id, params.stage_id, fields);
  87. case 'mem_stage_bonus':
  88. return service.reportMemory.getStageBonus(params.tender_id, params.stage_id, fields);
  89. case 'mem_stage_other':
  90. return service.reportMemory.getStageOther(params.tender_id, params.stage_id, fields);
  91. case 'mem_stage_safe_prod':
  92. return service.reportMemory.getStageSafeProd(params.tender_id, params.stage_id, fields);
  93. case 'mem_stage_temp_land':
  94. return service.reportMemory.getStageTempLand(params.tender_id, params.stage_id, fields);
  95. case 'mem_gather_tender_info':
  96. return service.rptGatherMemory.getGatherTenderInfo(fields,
  97. customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  98. case 'mem_gather_stage_pay':
  99. return service.rptGatherMemory.getGatherStagePay(fields,
  100. customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  101. case 'mem_gather_deal_bills':
  102. return service.rptGatherMemory.getGatherDealBills(fields,
  103. customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  104. case 'mem_gather_stage_jgcl':
  105. return service.rptGatherMemory.getGatherStageJgcl(fields,
  106. customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  107. case 'mem_gather_stage_bonus':
  108. return service.rptGatherMemory.getGatherStageBonus(fields,
  109. customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  110. case 'mem_gather_stage_other':
  111. return service.rptGatherMemory.getGatherStageOther(fields,
  112. customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  113. case 'mem_gather_stage_safe_prod':
  114. return service.rptGatherMemory.getGatherStageSafeProd(fields,
  115. customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  116. case 'mem_gather_stage_temp_land':
  117. return service.rptGatherMemory.getGatherStageTempLand(fields,
  118. customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  119. case 'mem_select_material':
  120. return service.material.getSelectMaterial(params.tender_id, params.material_order);
  121. case 'mem_select_material_audit':
  122. return materialSource.getSelectMaterialAuditors(params.tender_id, params.material_order);
  123. case 'mem_material':
  124. return materialSource.getMaterial(params.tender_id, params.material_order, fields);
  125. case 'mem_material_gl':
  126. return materialSource.getMaterialGl(params.tender_id, params.material_order, fields);
  127. case 'mem_material_gl_detail':
  128. return materialSource.getMaterialGlDetail(params.tender_id, params.material_order, fields);
  129. case 'mem_material_bills':
  130. return materialSource.getMaterialBills(params.tender_id, params.material_order, fields);
  131. case 'mem_material_bills_filter':
  132. return materialSource.getMaterialBills(params.tender_id, params.material_order, fields, true);
  133. case 'mem_material_pos':
  134. return materialSource.getMaterialPos(params.tender_id, params.material_order, fields);
  135. case 'mem_material_stage':
  136. return materialSource.getMaterialStage(params.tender_id, params.material_order, fields);
  137. case 'mem_stage_sum_bills':
  138. return service.rptStageSumMemory.getStageSumBills(params.tender_id, fields,
  139. customDefine.stage_select, customSelect ? customSelect.stage_select : null);
  140. case 'mem_stage_sum_bills_filter':
  141. return service.rptStageSumMemory.getStageSumBills(params.tender_id, fields,
  142. customDefine.stage_select, customSelect ? customSelect.stage_select : null, true);
  143. case 'mem_stage_sum_pos':
  144. return service.rptStageSumMemory.getStageSumPos(params.tender_id, fields,
  145. customDefine.stage_select, customSelect ? customSelect.stage_select : null);
  146. case 'mem_stage_sum_pay':
  147. return service.rptStageSumMemory.getStageSumPay(params.tender_id, fields,
  148. customDefine.stage_select, customSelect ? customSelect.stage_select : null);
  149. case 'mem_material_sum_gl':
  150. return service.rptStageSumMemory.getMaterialSumGl(params.tender_id, fields,
  151. customDefine.material_sum_select, customSelect ? customSelect.material_sum_select : null);
  152. case 'ledger_cooperation':
  153. return service.ledgerCooperation.getValidData(params.tender_id);
  154. case 'mem_sign_select':
  155. return service.reportMemory.getSignSelect(params.tender_id, params.stage_id, customSelect);
  156. case 'mem_stage_change':
  157. return service.stageChange.getAllDataByCondition({ where: { tid: params.tender_id, sid: params.stage_id } });
  158. case 'mem_stage_change_bills':
  159. return service.stageChangeFinal.getFinalData(params.tender_id);
  160. case 'mem_stage_import_change':
  161. return service.stageImportChange.getFinalData(params.tender_id);
  162. case 'mem_ledger_tag':
  163. return service.ledgerTag.getDatas(params.tender_id);
  164. case 'mem_stage_tag':
  165. return service.ledgerTag.getDatas(params.tender_id, params.stage_id);
  166. case 'mem_all_tag':
  167. return service.ledgerTag.getAllDataByCondition({ where: { tid: params.tender_id } });
  168. case 'mem_change_info':
  169. return service.reportMemory.getChangeInfo(params.tender_id, params.stage_id);
  170. case 'mem_change_info_bills':
  171. return service.reportMemory.getChangeInfoBills(params.tender_id, params.stage_id);
  172. case 'mem_stage_rela_im':
  173. return service.stageRelaIm.getAllDataByCondition({ where: { tid: params.tender_id, sid: params.stage_id } });
  174. case 'mem_stage_rela_im_bills':
  175. return service.stageRelaImBills.getAllDataByCondition({ where: { tid: params.tender_id, sid: params.stage_id } });
  176. case 'mem_budget_gu':
  177. return params.budget_id ? budgetSource.budgetGu(params.budget_id) : budgetSource.tenderGu(params.tender_id);
  178. case 'mem_budget_gai':
  179. return params.budget_id ? budgetSource.budgetGai(params.budget_id) : budgetSource.tenderGai(params.tender_id);
  180. case 'mem_budget_yu':
  181. return params.budget_id ? budgetSource.budgetYu(params.budget_id) : budgetSource.tenderYu(params.tender_id);
  182. case 'mem_budget_zb':
  183. return params.budget_id ? budgetSource.budgetZb(params.budget_id) : budgetSource.tenderZb(params.tender_id);
  184. case 'mem_budget_final':
  185. return params.budget_id ? budgetSource.budgetFinal(params.budget_id) : budgetSource.tenderFinal(params.tender_id);
  186. case 'mem_budget_gu_filter':
  187. return params.budget_id ? budgetSource.budgetGu(params.budget_id, true) : budgetSource.tenderGu(params.tender_id, true);
  188. case 'mem_budget_gai_filter':
  189. return params.budget_id ? budgetSource.budgetGai(params.budget_id, true) : budgetSource.tenderGai(params.tender_id, true);
  190. case 'mem_budget_yu_filter':
  191. return params.budget_id ? budgetSource.budgetYu(params.budget_id, true) : budgetSource.tenderYu(params.tender_id, true);
  192. case 'mem_budget_zb_filter':
  193. return params.budget_id ? budgetSource.budgetZb(params.budget_id, true) : budgetSource.tenderZb(params.tender_id, true);
  194. case 'mem_budget_final_filter':
  195. return params.budget_id ? budgetSource.budgetFinal(params.budget_id, true) : budgetSource.tenderFinal(params.tender_id, true);
  196. case 'mem_pm_deal_pay':
  197. return service.reportMemory.getPmDeal();
  198. case 'mem_financial_pay':
  199. return financialSource.pay(params.tender_id);
  200. case 'mem_financial_pay_contract':
  201. return financialSource.payContract(params.tender_id);
  202. case 'mem_financial_pay_tender':
  203. return financialSource.payTender(params.tender_id);
  204. case 'mem_financial_transfer':
  205. return financialSource.transfer(params.tender_id);
  206. case 'mem_financial_transfer_tender':
  207. return financialSource.transferTender(params.tender_id);
  208. default:
  209. break;
  210. }
  211. }
  212. async getFlowData(params, key, fields, customDefine, customSelect) {
  213. const service = this.ctx.service;
  214. const spssSource = new SpssSource(this.ctx);
  215. switch (filter) {
  216. case 'mem_custom_select':
  217. return customSelect;
  218. case 'mem_stage_im_tz':
  219. return await service.reportMemory.getStageImTzData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  220. case 'mem_stage_im_tz_bills':
  221. return await service.reportMemory.getStageImTzBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  222. case 'mem_union_data':
  223. return [];
  224. case 'mem_import_change':
  225. return await service.reportMemory.getImportChangeData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  226. case 'mem_import_change_bills':
  227. return await service.reportMemory.getImportChangeBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  228. case 'mem_change':
  229. return await service.reportMemory.getChangeData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  230. case 'mem_change_bills':
  231. return await service.reportMemory.getChangeBillsData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  232. case 'mem_change_audit':
  233. return await service.reportMemory.getChangeAuditData(params.tender_id, params.stage_id, memFieldKeys[filter]);
  234. case 'mem_change_apply':
  235. return await service.reportMemory.getChangeApplyData(params.tender_id);
  236. case 'mem_change_apply_bills':
  237. return await service.reportMemory.getChangeApplyBillsData(params.tender_id);
  238. case 'mem_change_apply_audit':
  239. return await service.reportMemory.getChangeApplyAuditData(params.tender_id);
  240. case 'mem_change_plan':
  241. return await service.reportMemory.getChangePlanData(params.tender_id);
  242. case 'mem_change_plan_bills':
  243. return await service.reportMemory.getChangePlanBillsData(params.tender_id);
  244. case 'mem_change_plan_audit':
  245. return await service.reportMemory.getChangePlanAuditData(params.tender_id);
  246. case 'mem_change_project':
  247. return await service.reportMemory.getChangeProjectData(params.tender_id);
  248. case 'mem_change_project_audit':
  249. return await service.reportMemory.getChangeProjectAuditData(params.tender_id);
  250. case 'mem_jh_im_change':
  251. const jhHelper1 = new rptCustomData.jhHelper(this.ctx);
  252. return await jhHelper1.convert(params.tender_id, params.stage_id, memFieldKeys[filter], customDefine.option);
  253. case 'mem_jh_gather_im_change':
  254. const jhHelper2 = new rptCustomData.jhHelper(this.ctx);
  255. return await jhHelper2.gather(memFieldKeys[filter], customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  256. case 'mem_jh_gather_stage_bills_compare':
  257. const jhHelper3 = new rptCustomData.jhHelper(this.ctx);
  258. return await jhHelper3.gatherBills(memFieldKeys[filter], customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  259. case 'mem_gather_stage_bills':
  260. return await service.rptGatherMemory.getGatherStageBills(memFieldKeys[filter],
  261. customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  262. case 'mem_gather_stage_bills_filter':
  263. return await service.rptGatherMemory.getGatherStageBills(memFieldKeys[filter],
  264. customDefine.gather_select, customSelect ? customSelect.gather_select : null, true);
  265. case 'mem_gather_stage_pos':
  266. return await service.rptGatherMemory.getGatherStagePos(memFieldKeys[filter],
  267. customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  268. // case 'mem_material_bills':
  269. // return await service.rptGatherMemory.getMaterialBills(params.tender_id, params.material_order, memFieldKeys[filter]);
  270. // case 'mem_material_bills_gl':
  271. // return await service.rptGatherMemory.getMaterialBillsGl(params.tender_id, params.material_order, memFieldKeys[filter]);
  272. case 'mem_spss_gather_info_tender':
  273. return await spssSource.getGatherStageInfoTender();
  274. break;
  275. case 'mem_spss_gather_info':
  276. return await spssSource.getGatherStageInfo();
  277. break;
  278. case 'mem_spss_gather_ledger_tender':
  279. return await spssSource.getGatherLedgerTender();
  280. break;
  281. case 'mem_spss_gather_ledger_bills':
  282. return await spssSource.getGatherLedgerBills();
  283. break;
  284. case 'mem_spss_gather_ledger_pos':
  285. return await spssSource.getGatherLedgerPos();
  286. break;
  287. case 'mem_spss_gather_stage_tender':
  288. return await spssSource.getGatherStageTender();
  289. break;
  290. case 'mem_spss_gather_stage_bills':
  291. return await spssSource.getGatherStageBills();
  292. break;
  293. case 'mem_spss_gather_stage_pos':
  294. return await spssSource.getGatherStagePos();
  295. break;
  296. case 'mem_spss_gather_stage_extra_tender':
  297. return await spssSource.getGatherStageExtraTender();
  298. break;
  299. case 'mem_spss_gather_stage_jgcl':
  300. return await spssSource.getGatherStageJgcl();
  301. break;
  302. case 'mem_spss_gather_stage_yjcl':
  303. return await spssSource.getGatherStageYjcl();
  304. break;
  305. case 'mem_spss_gather_stage_bonus':
  306. return await spssSource.getGatherStageBonus();
  307. break;
  308. case 'mem_spss_gather_stage_other':
  309. return await spssSource.getGatherStageOther();
  310. break;
  311. case 'mem_spss_gather_stage_safe_prod':
  312. return await spssSource.getGatherStageSafeProd();
  313. break;
  314. case 'mem_spss_gather_stage_temp_land':
  315. return await spssSource.getGatherStageTempLand();
  316. break;
  317. case 'mem_spss_gather_stage_pay_tender':
  318. return await spssSource.getGatherStagePayTender();
  319. break;
  320. case 'mem_spss_gather_stage_pay':
  321. return await spssSource.getGatherStagePay();
  322. break;
  323. case 'mem_spss_compare_ledger_tender':
  324. return await spssSource.getCompareLedgerTender();
  325. break;
  326. case 'mem_spss_compare_ledger_bills':
  327. return await spssSource.getCompareLedgerBills();
  328. break;
  329. case 'mem_spss_compare_ledger_pos':
  330. return await spssSource.getCompareLedgerPos();
  331. break;
  332. case 'mem_spss_compare_stage_tender':
  333. return await spssSource.getCompareStageTender();
  334. break;
  335. case 'mem_spss_compare_stage_bills':
  336. return await spssSource.getCompareStageBills();
  337. break;
  338. case 'mem_spss_compare_stage_pos':
  339. return await spssSource.getCompareStagePos();
  340. break;
  341. default:
  342. return [];
  343. }
  344. }
  345. async getBindData(params, key, fields, customDefine, customSelect) {
  346. const service = this.ctx.service;
  347. switch (key) {
  348. case 'materialGather':
  349. const materialSource = new MaterialSource(this.ctx);
  350. return await materialSource.getMaterialGatherBills(params.tender_id, params.material_order);
  351. case 'gatherChange':
  352. return await service.rptGatherMemory.getGatherChange(fields, customDefine.gather_select, customSelect ? customSelect.gather_select : null);
  353. case 'fjChange':
  354. const fjHelper = new rptCustomData.fjHelper(this.ctx);
  355. return await fjHelper.getChangeProgressData(params.tender_id, params.stage_id);
  356. default:
  357. return {};
  358. }
  359. }
  360. }
  361. module.exports = rptMemPaymentSafe;