|  | @@ -12,134 +12,6 @@ const Ledger = require('../lib/ledger');
 | 
	
		
			
				|  |  |  const PayCalculator = require('../lib/pay_calc');
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  const auditConst = require('../const/audit');
 | 
	
		
			
				|  |  | -const payConst = require('../const/deal_pay');
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -const moment = require('moment');
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -const indexPre = 'id_';
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -const gatherUtils = {
 | 
	
		
			
				|  |  | -    completeStageSumData: function (datas, completeDatas) {
 | 
	
		
			
				|  |  | -        for (const data of datas) {
 | 
	
		
			
				|  |  | -            for (const cd of completeDatas) {
 | 
	
		
			
				|  |  | -                data[cd.prefix + 'order'] = cd.order;
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -    },
 | 
	
		
			
				|  |  | -    gatherStage: function (tender, gatherNode, sourceNode, prefix, helper) {
 | 
	
		
			
				|  |  | -        gatherNode[prefix + 'id'] = tender.id;
 | 
	
		
			
				|  |  | -        gatherNode[prefix + 'name'] = tender.name;
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "qty"] = helper.add(gatherNode[prefix + "qty"], sourceNode.quantity);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "tp"] = helper.add(gatherNode[prefix + "tp"], sourceNode.total_price);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "dgn_qty1"] = helper.add(gatherNode[prefix + "dgn_qty1"], sourceNode.dgn_qty1);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "dgn_qty2"] = helper.add(gatherNode[prefix + "dgn_qty2"], sourceNode.dgn_qty2);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "contract_qty"] = helper.add(gatherNode[prefix + "contract_qty"], sourceNode.contract_qty);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "contract_tp"] = helper.add(gatherNode[prefix + "contract_tp"], sourceNode.contract_tp);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "qc_qty"] = helper.add(gatherNode[prefix + "qc_qty"], sourceNode.qc_qty);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "qc_tp"] = helper.add(gatherNode[prefix + "qc_tp"], sourceNode.qc_tp);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "gather_qty"] = helper.add(gatherNode[prefix + "gather_qty"], sourceNode.gather_qty);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "gather_tp"] = helper.add(gatherNode[prefix + "gather_tp"], sourceNode.gather_tp);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "pre_contract_qty"] = helper.add(gatherNode[prefix + "pre_contract_qty"], sourceNode.pre_contract_qty);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "pre_contract_tp"] = helper.add(gatherNode[prefix + "pre_contract_tp"], sourceNode.pre_contract_tp);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "pre_qc_qty"] = helper.add(gatherNode[prefix + "pre_qc_qty"], sourceNode.pre_qc_qty);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "pre_qc_tp"] = helper.add(gatherNode[prefix + "pre_qc_tp"], sourceNode.pre_qc_tp);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "pre_gather_qty"] = helper.add(gatherNode[prefix + "pre_gather_qty"], sourceNode.pre_gather_qty);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "pre_gather_tp"] = helper.add(gatherNode[prefix + "pre_gather_tp"], sourceNode.pre_gather_tp);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "end_contract_qty"] = helper.add(gatherNode[prefix + "end_contract_qty"], sourceNode.end_contract_qty);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "end_contract_tp"] = helper.add(gatherNode[prefix + "end_contract_tp"], sourceNode.end_contract_tp);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "end_qc_qty"] = helper.add(gatherNode[prefix + "end_qc_qty"], sourceNode.end_qc_qty);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "end_qc_tp"] = helper.add(gatherNode[prefix + "end_qc_tp"], sourceNode.end_qc_tp);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "end_gather_qty"] = helper.add(gatherNode[prefix + "end_gather_qty"], sourceNode.end_gather_qty);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "end_gather_tp"] = helper.add(gatherNode[prefix + "end_gather_tp"], sourceNode.end_gather_tp);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "deal_dgn_qty1"] = helper.add(gatherNode[prefix + "deal_dgn_qty1"], sourceNode.deal_dgn_qty1);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "deal_dgn_qty2"] = helper.add(gatherNode[prefix + "deal_dgn_qty2"], sourceNode.deal_dgn_qty2);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "c_dgn_qty1"] = helper.add(gatherNode[prefix + "c_dgn_qty1"], sourceNode.c_dgn_qty1);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "c_dgn_qty2"] = helper.add(gatherNode[prefix + "c_dgn_qty2"], sourceNode.c_dgn_qty2);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "qty"] = helper.add(gatherNode['s_' + "qty"], sourceNode.quantity);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "tp"] = helper.add(gatherNode['s_' + "tp"], sourceNode.total_price);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "contract_qty"] = helper.add(gatherNode['s_' + "contract_qty"], sourceNode.contract_qty);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "contract_tp"] = helper.add(gatherNode['s_' + "contract_tp"], sourceNode.contract_tp);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "qc_qty"] = helper.add(gatherNode['s_' + "qc_qty"], sourceNode.qc_qty);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "qc_tp"] = helper.add(gatherNode['s_' + "qc_tp"], sourceNode.qc_tp);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "gather_qty"] = helper.add(gatherNode['s_' + "gather_qty"], sourceNode.gather_qty);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "gather_tp"] = helper.add(gatherNode['s_' + "gather_tp"], sourceNode.gather_tp);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "pre_contract_qty"] = helper.add(gatherNode['s_' + "pre_contract_qty"], sourceNode.pre_contract_qty);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "pre_contract_tp"] = helper.add(gatherNode['s_' + "pre_contract_tp"], sourceNode.pre_contract_tp);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "pre_qc_qty"] = helper.add(gatherNode['s_' + "pre_qc_qty"], sourceNode.pre_qc_qty);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "pre_qc_tp"] = helper.add(gatherNode['s_' + "pre_qc_tp"], sourceNode.pre_qc_tp);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "pre_gather_qty"] = helper.add(gatherNode['s_' + "pre_gather_qty"], sourceNode.pre_gather_qty);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "pre_gather_tp"] = helper.add(gatherNode['s_' + "pre_gather_tp"], sourceNode.pre_gather_tp);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "end_contract_qty"] = helper.add(gatherNode['s_' + "end_contract_qty"], sourceNode.end_contract_qty);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "end_contract_tp"] = helper.add(gatherNode['s_' + "end_contract_tp"], sourceNode.end_contract_tp);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "end_qc_qty"] = helper.add(gatherNode['s_' + "end_qc_qty"], sourceNode.end_qc_qty);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "end_qc_tp"] = helper.add(gatherNode['s_' + "end_qc_tp"], sourceNode.end_qc_tp);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "end_gather_qty"] = helper.add(gatherNode['s_' + "end_gather_qty"], sourceNode.end_gather_qty);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "end_gather_tp"] = helper.add(gatherNode['s_' + "end_gather_tp"], sourceNode.end_gather_tp);
 | 
	
		
			
				|  |  | -    },
 | 
	
		
			
				|  |  | -    gatherZone: function (tender, gatherNode, sourceNode, prefix, helper) {
 | 
	
		
			
				|  |  | -        gatherNode[prefix + 'id'] = tender.id;
 | 
	
		
			
				|  |  | -        gatherNode[prefix + 'name'] = tender.name;
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "qty"] = helper.add(gatherNode[prefix + "qty"], sourceNode.quantity);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "tp"] = helper.add(gatherNode[prefix + "tp"], sourceNode.total_price);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "dgn_qty1"] = helper.add(gatherNode[prefix + "dgn_qty1"], sourceNode.dgn_qty1);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "dgn_qty2"] = helper.add(gatherNode[prefix + "dgn_qty2"], sourceNode.dgn_qty2);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "contract_qty"] = helper.add(gatherNode[prefix + "contract_qty"], sourceNode.contract_qty);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "contract_tp"] = helper.add(gatherNode[prefix + "contract_tp"], sourceNode.contract_tp);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "qc_qty"] = helper.add(gatherNode[prefix + "qc_qty"], sourceNode.qc_qty);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "qc_tp"] = helper.add(gatherNode[prefix + "qc_tp"], sourceNode.qc_tp);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "gather_qty"] = helper.add(gatherNode[prefix + "gather_qty"], sourceNode.gather_qty);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "gather_tp"] = helper.add(gatherNode[prefix + "gather_tp"], sourceNode.gather_tp);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "deal_dgn_qty1"] = helper.add(gatherNode[prefix + "deal_dgn_qty1"], sourceNode.deal_dgn_qty1);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "deal_dgn_qty2"] = helper.add(gatherNode[prefix + "deal_dgn_qty2"], sourceNode.deal_dgn_qty2);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "c_dgn_qty1"] = helper.add(gatherNode[prefix + "c_dgn_qty1"], sourceNode.c_dgn_qty1);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "c_dgn_qty2"] = helper.add(gatherNode[prefix + "c_dgn_qty2"], sourceNode.c_dgn_qty2);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "qty"] = helper.add(gatherNode['s_' + "qty"], sourceNode.quantity);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "tp"] = helper.add(gatherNode['s_' + "tp"], sourceNode.total_price);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "contract_qty"] = helper.add(gatherNode['s_' + "contract_qty"], sourceNode.contract_qty);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "contract_tp"] = helper.add(gatherNode['s_' + "contract_tp"], sourceNode.contract_tp);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "qc_qty"] = helper.add(gatherNode['s_' + "qc_qty"], sourceNode.qc_qty);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "qc_tp"] = helper.add(gatherNode['s_' + "qc_tp"], sourceNode.qc_tp);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "gather_qty"] = helper.add(gatherNode['s_' + "gather_qty"], sourceNode.gather_qty);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "gather_tp"] = helper.add(gatherNode['s_' + "gather_tp"], sourceNode.gather_tp);
 | 
	
		
			
				|  |  | -    },
 | 
	
		
			
				|  |  | -    gatherLedger: function (tender, gatherNode, sourceNode, prefix, helper) {
 | 
	
		
			
				|  |  | -        gatherNode[prefix + 'id'] = tender.id;
 | 
	
		
			
				|  |  | -        gatherNode[prefix + 'name'] = tender.name;
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "qty"] = helper.add(gatherNode[prefix + "qty"], sourceNode.quantity);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "tp"] = helper.add(gatherNode[prefix + "tp"], sourceNode.total_price);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "dgn_qty1"] = helper.add(gatherNode[prefix + "dgn_qty1"], sourceNode.dgn_qty1);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "dgn_qty2"] = helper.add(gatherNode[prefix + "dgn_qty2"], sourceNode.dgn_qty2);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "qty"] = helper.add(gatherNode['s_' + "qty"], sourceNode.quantity);
 | 
	
		
			
				|  |  | -        gatherNode['s_' + "tp"] = helper.add(gatherNode['s_' + "tp"], sourceNode.total_price);
 | 
	
		
			
				|  |  | -    },
 | 
	
		
			
				|  |  | -    gatherSpecial: function (gatherNode, sourceNode, prefix, helper) {
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "qty"] = helper.add(gatherNode[prefix + "qty"], sourceNode.quantity);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "tp"] = helper.add(gatherNode[prefix + "tp"], sourceNode.total_price);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "dgn_qty1"] = helper.add(gatherNode[prefix + "dgn_qty1"], sourceNode.dgn_qty1);
 | 
	
		
			
				|  |  | -        gatherNode[prefix + "dgn_qty2"] = helper.add(gatherNode[prefix + "dgn_qty2"], sourceNode.dgn_qty2);
 | 
	
		
			
				|  |  | -    },
 | 
	
		
			
				|  |  | -};
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  module.exports = app => {
 | 
	
		
			
				|  |  |      class RptStageSumMemory extends app.BaseService {
 | 
	
	
		
			
				|  | @@ -163,7 +35,6 @@ module.exports = app => {
 | 
	
		
			
				|  |  |              const billsData = await this.ctx.service.ledger.getData(this.ctx.tender.id);
 | 
	
		
			
				|  |  |              const calcFields = ['deal_tp', 'total_price'], calcPrefix = [];
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -            const gsSetting = JSON.parse(gsDefine.setting);
 | 
	
		
			
				|  |  |              for (const s of gsCustom.stages) {
 | 
	
		
			
				|  |  |                  const stage = await this.db.get(this.ctx.service.stage.tableName, { tid: this.ctx.tender.id, order: s });
 | 
	
		
			
				|  |  |                  if (!stage) continue;
 | 
	
	
		
			
				|  | @@ -180,8 +51,10 @@ module.exports = app => {
 | 
	
		
			
				|  |  |                  const curStage = stage.readOnly
 | 
	
		
			
				|  |  |                      ? await this.ctx.service.stageBills.getAuditorStageData2(this.ctx.tender.id, stage.id, stage.curTimes, stage.curOrder)
 | 
	
		
			
				|  |  |                      : await this.ctx.service.stageBills.getLastestStageData2(this.ctx.tender.id, stage.id);
 | 
	
		
			
				|  |  | +                const bpcStage = await this.ctx.service.stageBillsPc.getAllDataByCondition({ where: { sid: stage.id } });
 | 
	
		
			
				|  |  |                  this.ctx.helper.assignRelaData(billsData, [
 | 
	
		
			
				|  |  | -                    {data: curStage, fields: ['contract_qty', 'contract_tp', 'contract_expr', 'qc_qty', 'qc_tp'], prefix: prefix, relaId: 'lid', defaultData}
 | 
	
		
			
				|  |  | +                    {data: curStage, fields: ['contract_qty', 'contract_tp', 'contract_expr', 'qc_qty', 'qc_tp'], prefix: prefix, relaId: 'lid', defaultData},
 | 
	
		
			
				|  |  | +                    {data: bpcStage, fields: ['contract_pc_tp', 'qc_pc_tp', 'pc_tp'], prefix: prefix, relaId: 'lid', defaultData},
 | 
	
		
			
				|  |  |                  ]);
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -199,7 +72,7 @@ module.exports = app => {
 | 
	
		
			
				|  |  |                          if (node.children && node.children.length === 0) {
 | 
	
		
			
				|  |  |                              node[prefix + 'gather_qty'] = self.ctx.helper.add(node[prefix + 'contract_qty'], node[prefix + 'qc_qty']);
 | 
	
		
			
				|  |  |                          }
 | 
	
		
			
				|  |  | -                        node[prefix + 'gather_tp'] = self.ctx.helper.add(node[prefix + 'contract_tp'], node[prefix + 'qc_tp']);
 | 
	
		
			
				|  |  | +                        node[prefix + 'gather_tp'] = self.ctx.helper.sum([node[prefix + 'contract_tp'], node[prefix + 'qc_tp'], node[prefix + 'pc_tp']]);
 | 
	
		
			
				|  |  |                      }
 | 
	
		
			
				|  |  |                  }
 | 
	
		
			
				|  |  |              });
 |