|
@@ -31,6 +31,7 @@ const XMLStandard = (function () {
|
|
|
[fixedFlag.SUB_ENGINERRING]: '1100',
|
|
[fixedFlag.SUB_ENGINERRING]: '1100',
|
|
|
[fixedFlag.MEASURE]: '1200',
|
|
[fixedFlag.MEASURE]: '1200',
|
|
|
[fixedFlag.CONSTRUCTION_ORGANIZATION]: '120201',
|
|
[fixedFlag.CONSTRUCTION_ORGANIZATION]: '120201',
|
|
|
|
|
+ [fixedFlag.ORGANIZATION]: '120201',
|
|
|
[fixedFlag.SAFETY_CONSTRUCTION]: '1204',
|
|
[fixedFlag.SAFETY_CONSTRUCTION]: '1204',
|
|
|
[fixedFlag.PROJECT_COMPLETE_ARCH_FEE]: '10041',
|
|
[fixedFlag.PROJECT_COMPLETE_ARCH_FEE]: '10041',
|
|
|
[fixedFlag.HOUSE_QUALITY_ACCEPT_FEE]: '1206',
|
|
[fixedFlag.HOUSE_QUALITY_ACCEPT_FEE]: '1206',
|
|
@@ -54,6 +55,67 @@ const XMLStandard = (function () {
|
|
|
'1': '一般计税法',
|
|
'1': '一般计税法',
|
|
|
'2': '简易计税法',
|
|
'2': '简易计税法',
|
|
|
};
|
|
};
|
|
|
|
|
+ //固定类别-基数映射
|
|
|
|
|
+ const FlagCalcBaseMap = {
|
|
|
|
|
+ [fixedFlag.SUB_ENGINERRING]: 'FBFXHJ',
|
|
|
|
|
+ [fixedFlag.MEASURE]: 'CSXMHJ',
|
|
|
|
|
+ [fixedFlag.CONSTRUCTION_TECH]: 'JSCSF',
|
|
|
|
|
+ [fixedFlag.CONSTRUCTION_ORGANIZATION]: 'ZZCSF',
|
|
|
|
|
+ [fixedFlag.Other]: 'QTXMHJ',
|
|
|
|
|
+ [fixedFlag.CHARGE]: 'GF',
|
|
|
|
|
+ [fixedFlag.TAX]: 'SJ',
|
|
|
|
|
+ [fixedFlag.PROVISIONAL]: 'ZLJE',
|
|
|
|
|
+ [fixedFlag.ENGINEERING_ESITIMATE]: 'ZYZGJ',
|
|
|
|
|
+ [fixedFlag.DAYWORK]: 'JRG',
|
|
|
|
|
+ [fixedFlag.TURN_KEY_CONTRACT]: 'ZCBFWF',
|
|
|
|
|
+ [fixedFlag.CLAIM_VISA]: 'SPQZ',
|
|
|
|
|
+ '{分部分项工程费}': fixedFlag.SUB_ENGINERRING,
|
|
|
|
|
+ '{措施项目费}': fixedFlag.MEASURE,
|
|
|
|
|
+ '{组织措施项目费}': fixedFlag.CONSTRUCTION_ORGANIZATION,
|
|
|
|
|
+ '{技术措施项目费}': fixedFlag.CONSTRUCTION_TECH,
|
|
|
|
|
+ '{安全文明施工专项费}': fixedFlag.SAFETY_CONSTRUCTION,
|
|
|
|
|
+ '{其他项目费}': fixedFlag.OTHER,
|
|
|
|
|
+ '{规费}': fixedFlag.CHARGE,
|
|
|
|
|
+ '{税金}': fixedFlag.TAX,
|
|
|
|
|
+ '{增值税}': fixedFlag.ADDED_VALUE_TAX,
|
|
|
|
|
+ };
|
|
|
|
|
+ //计算基础表达式映射
|
|
|
|
|
+ const CalcBaseMap = {
|
|
|
|
|
+ '{分部分项工程费}': 'FBFXHJ',
|
|
|
|
|
+ '{措施项目费}': 'CSXMHJ',
|
|
|
|
|
+ '{组织措施项目费}': 'ZZCSF',
|
|
|
|
|
+ '{其他项目费}': 'QTXMHJ',
|
|
|
|
|
+ '{规费}': 'GF',
|
|
|
|
|
+ '{税金}': 'SJ',
|
|
|
|
|
+ '{分部分项定额人工费}': 'RGF',
|
|
|
|
|
+ '{分部分项定额材料费}': 'CLF',
|
|
|
|
|
+ '{分部分项定额施工机具使用费}': 'JXF',
|
|
|
|
|
+ '{分部分项主材费}': 'ZCF',
|
|
|
|
|
+ '{分部分项人工工日}': 'GR',
|
|
|
|
|
+ '{技术措施项目费}': 'JSCSF',
|
|
|
|
|
+ '{技术措施项目定额人工费}': 'JSCS_RGF',
|
|
|
|
|
+ '{技术措施项目定额材料费}': 'JSCS_CLF',
|
|
|
|
|
+ '{技术措施项目定额施工机具使用费}': 'JSCS_JXF',
|
|
|
|
|
+ '{技术措施项目主材费}': 'JSCS_ZCF',
|
|
|
|
|
+ '{技术措施项目人工工日}': 'JSCS_GR',
|
|
|
|
|
+ '{建筑面积}': 'JZMJ',
|
|
|
|
|
+ '{人材机价差}': 'RCJJC',
|
|
|
|
|
+ '{人工价差}': 'RGJC',
|
|
|
|
|
+ '{材料价差}': 'CLJC',
|
|
|
|
|
+ '{施工机具使用费价差}': 'JXJC',
|
|
|
|
|
+ '{甲供人工费}': 'JGRGF',
|
|
|
|
|
+ '{甲供材料费}': 'JGCLF',
|
|
|
|
|
+ '{甲供施工机具使用费}': 'JGJXF',
|
|
|
|
|
+ '{甲供主材费}': 'JGZCF',
|
|
|
|
|
+ '{甲供设备费}': 'JGSBF',
|
|
|
|
|
+ '{分包费}': 'FBF',
|
|
|
|
|
+ '{分包定额人工费}': 'FBRGF',
|
|
|
|
|
+ '{分包定额材料费}': 'FBCLF',
|
|
|
|
|
+ '{分包定额机械费}': 'FBJXF',
|
|
|
|
|
+ '{分包主材费}': 'FBZCF',
|
|
|
|
|
+ '{分包设备费}': 'FBSBF',
|
|
|
|
|
+ '{分包人工工日}': 'FBGR'
|
|
|
|
|
+ };
|
|
|
//加载数据间隔,减少服务器压力
|
|
//加载数据间隔,减少服务器压力
|
|
|
const TIMEOUT_TIME = 500;
|
|
const TIMEOUT_TIME = 500;
|
|
|
function isDef(v) {
|
|
function isDef(v) {
|
|
@@ -77,9 +139,9 @@ const XMLStandard = (function () {
|
|
|
granularity = GRANULARITY.PROJECT;
|
|
granularity = GRANULARITY.PROJECT;
|
|
|
}
|
|
}
|
|
|
this.granularity = granularity;
|
|
this.granularity = granularity;
|
|
|
- //默认导出招标文件
|
|
|
|
|
|
|
+ //默认导出投标文件
|
|
|
if (!exportKind || ![1, 2, 3].includes(exportKind)) {
|
|
if (!exportKind || ![1, 2, 3].includes(exportKind)) {
|
|
|
- exportKind = ExportKind.Bid;
|
|
|
|
|
|
|
+ exportKind = ExportKind.Tender;
|
|
|
}
|
|
}
|
|
|
this.exportKind = exportKind;
|
|
this.exportKind = exportKind;
|
|
|
/*
|
|
/*
|
|
@@ -109,27 +171,21 @@ const XMLStandard = (function () {
|
|
|
if (data.minLen && data.value.length < data.minLen){
|
|
if (data.minLen && data.value.length < data.minLen){
|
|
|
isFail = true;
|
|
isFail = true;
|
|
|
tempFail = `“${data.name}”字符数不可小于${data.minLen}个`;
|
|
tempFail = `“${data.name}”字符数不可小于${data.minLen}个`;
|
|
|
- //rst.failHints.push(`“${data.name}”字符数不可小于${data.minLen}个`);
|
|
|
|
|
} else if (data.maxLen && data.value.length > data.maxLen) {
|
|
} else if (data.maxLen && data.value.length > data.maxLen) {
|
|
|
isFail = true;
|
|
isFail = true;
|
|
|
tempFail = `“${data.name}”字符数不可大于${data.maxLen}个`;
|
|
tempFail = `“${data.name}”字符数不可大于${data.maxLen}个`;
|
|
|
- //rst.failHints.push(`“${data.name}”字符数不可大于${data.maxLen}个`);
|
|
|
|
|
} else if (data.enumeration && !data.enumeration.includes(data.value)) {
|
|
} else if (data.enumeration && !data.enumeration.includes(data.value)) {
|
|
|
isFail = true;
|
|
isFail = true;
|
|
|
tempFail = `“${data.name}”只能从“${data.enumeration.join(';')}”中选择`;
|
|
tempFail = `“${data.name}”只能从“${data.enumeration.join(';')}”中选择`;
|
|
|
- //rst.failHints.push(`“${data.name}”只能从“${data.enumeration.join(';')}”中选择`);
|
|
|
|
|
} else if (data.type && data.type === TYPE.DATE && !dateReg.test(data.value)) {
|
|
} else if (data.type && data.type === TYPE.DATE && !dateReg.test(data.value)) {
|
|
|
isFail = true;
|
|
isFail = true;
|
|
|
tempFail = `“${data.name}”日期格式必须是YYYY-MM-DD`;
|
|
tempFail = `“${data.name}”日期格式必须是YYYY-MM-DD`;
|
|
|
- //rst.push(`“${data.name}”日期格式必须是YYYY-MM-DD`);
|
|
|
|
|
} else if (data.type && data.type === TYPE.INT && !Number.isInteger(parseFloat(data.value))) {
|
|
} else if (data.type && data.type === TYPE.INT && !Number.isInteger(parseFloat(data.value))) {
|
|
|
isFail = true;
|
|
isFail = true;
|
|
|
tempFail = `“${data.name}”必须为整数`;
|
|
tempFail = `“${data.name}”必须为整数`;
|
|
|
- //rst.failHints.push(`“${data.name}”必须为整数`);
|
|
|
|
|
} else if (data.type && data.type === TYPE.DECIMAL && isNaN(parseFloat(data.value))) {
|
|
} else if (data.type && data.type === TYPE.DECIMAL && isNaN(parseFloat(data.value))) {
|
|
|
isFail = true;
|
|
isFail = true;
|
|
|
tempFail = `“${data.name}”必须为数值`;
|
|
tempFail = `“${data.name}”必须为数值`;
|
|
|
- //rst.failHints.push(`“${data.name}”必须为数值`)
|
|
|
|
|
} else if (data.type && data.type === TYPE.NUM2) {
|
|
} else if (data.type && data.type === TYPE.NUM2) {
|
|
|
let v = parseFloat(data.value);
|
|
let v = parseFloat(data.value);
|
|
|
if (isNaN(v)) {
|
|
if (isNaN(v)) {
|
|
@@ -138,13 +194,10 @@ const XMLStandard = (function () {
|
|
|
rst.failHints.push(`“${data.name}”必须为数值`);
|
|
rst.failHints.push(`“${data.name}”必须为数值`);
|
|
|
} else if (!data.value.length || (data.value.split('.').length > 1 && data.value.split('.')[1].length > 2)){
|
|
} else if (!data.value.length || (data.value.split('.').length > 1 && data.value.split('.')[1].length > 2)){
|
|
|
isFail = true;
|
|
isFail = true;
|
|
|
- //tempFail = `“${data.name}”小数位数不得多于两位`;
|
|
|
|
|
- //rst.failHints.push(`“${data.name}”小数位数不得多于两位`);
|
|
|
|
|
}
|
|
}
|
|
|
} else if (data.type && data.type === TYPE.BOOL && !['true', 'false'].includes(data.value.toString())) {
|
|
} else if (data.type && data.type === TYPE.BOOL && !['true', 'false'].includes(data.value.toString())) {
|
|
|
isFail = true;
|
|
isFail = true;
|
|
|
tempFail = `“${data.name}”必须为true或false`;
|
|
tempFail = `“${data.name}”必须为true或false`;
|
|
|
- //rst.failHints.push(`“${data.name}”必须为true或false`);
|
|
|
|
|
}
|
|
}
|
|
|
if (!isFail || data.required) {
|
|
if (!isFail || data.required) {
|
|
|
rst.filterAttrs.push(data);
|
|
rst.filterAttrs.push(data);
|
|
@@ -157,7 +210,7 @@ const XMLStandard = (function () {
|
|
|
}
|
|
}
|
|
|
//从fees数组中获取相关费用
|
|
//从fees数组中获取相关费用
|
|
|
function getFee(fees, feeFields) {
|
|
function getFee(fees, feeFields) {
|
|
|
- if (!fees) {
|
|
|
|
|
|
|
+ if (!Array.isArray(fees)) {
|
|
|
return 0;
|
|
return 0;
|
|
|
}
|
|
}
|
|
|
let fields = feeFields.split('.');
|
|
let fields = feeFields.split('.');
|
|
@@ -182,6 +235,7 @@ const XMLStandard = (function () {
|
|
|
}
|
|
}
|
|
|
return '';
|
|
return '';
|
|
|
}
|
|
}
|
|
|
|
|
+
|
|
|
//造成导出失败
|
|
//造成导出失败
|
|
|
let failList = [];
|
|
let failList = [];
|
|
|
/*
|
|
/*
|
|
@@ -204,7 +258,7 @@ const XMLStandard = (function () {
|
|
|
//source:来源数据
|
|
//source:来源数据
|
|
|
function Project(source) {
|
|
function Project(source) {
|
|
|
let attrs = [
|
|
let attrs = [
|
|
|
- {name: '项目编号', value: getValueByKey(source.basicInformation, 'projNumber'), required: true, minLen: 1, maxLen: 255, whiteSpace: WHITE_SPACE.COLLAPSE},
|
|
|
|
|
|
|
+ {name: '项目编号', value: getValueByKey(source.basicInformation, 'projNum'), required: true, minLen: 1, maxLen: 255, whiteSpace: WHITE_SPACE.COLLAPSE},
|
|
|
{name: '项目名称', value: source.name, required: true, minLen: 1, maxLen: 255, whiteSpace: WHITE_SPACE.COLLAPSE},
|
|
{name: '项目名称', value: source.name, required: true, minLen: 1, maxLen: 255, whiteSpace: WHITE_SPACE.COLLAPSE},
|
|
|
{name: '建设单位', value: getValueByKey(source.basicInformation, 'constructionUnit'), required: true},
|
|
{name: '建设单位', value: getValueByKey(source.basicInformation, 'constructionUnit'), required: true},
|
|
|
{name: '标准版本号', value: '3.2.2', required: true},
|
|
{name: '标准版本号', value: '3.2.2', required: true},
|
|
@@ -243,6 +297,7 @@ const XMLStandard = (function () {
|
|
|
//招标信息定义
|
|
//招标信息定义
|
|
|
function BiddingInfo(source) {
|
|
function BiddingInfo(source) {
|
|
|
//控制总价: 如果文件类型是“控制价”,则导出建设项目的工程造价;如果是“招标”、“投标”,则取0
|
|
//控制总价: 如果文件类型是“控制价”,则导出建设项目的工程造价;如果是“招标”、“投标”,则取0
|
|
|
|
|
+ console.log(exportKind);
|
|
|
let attrs = [
|
|
let attrs = [
|
|
|
{name: '招标代理机构', value: getValueByKey(source.basicInformation, 'agency')},
|
|
{name: '招标代理机构', value: getValueByKey(source.basicInformation, 'agency')},
|
|
|
{name: '造价工程师', value: getValueByKey(source.basicInformation, 'tenderCostEngineer'), required: true},
|
|
{name: '造价工程师', value: getValueByKey(source.basicInformation, 'tenderCostEngineer'), required: true},
|
|
@@ -307,7 +362,7 @@ const XMLStandard = (function () {
|
|
|
let attrs = [
|
|
let attrs = [
|
|
|
{name: '编号', value: source.code, required: true, minLen: 1, maxLen: 255, whiteSpace: WHITE_SPACE.COLLAPSE},
|
|
{name: '编号', value: source.code, required: true, minLen: 1, maxLen: 255, whiteSpace: WHITE_SPACE.COLLAPSE},
|
|
|
{name: '名称', value: source.name, required: true, minLen: 1, maxLen: 255, whiteSpace: WHITE_SPACE.COLLAPSE},
|
|
{name: '名称', value: source.name, required: true, minLen: 1, maxLen: 255, whiteSpace: WHITE_SPACE.COLLAPSE},
|
|
|
- {name: '金额', value: source.summaryInfo.engineeringCost, type: TYPE.NUM2},
|
|
|
|
|
|
|
+ {name: '金额', value: exportKind === FILE_KIND.tender ? source.summaryInfo.engineeringCost : '0', type: TYPE.NUM2},
|
|
|
];
|
|
];
|
|
|
element.call(this, '单项工程', attrs);
|
|
element.call(this, '单项工程', attrs);
|
|
|
}
|
|
}
|
|
@@ -326,7 +381,9 @@ const XMLStandard = (function () {
|
|
|
'围墙工程', '幕墙工程', '市政安装工程', '城市轨道交通安装', '人工土石方',
|
|
'围墙工程', '幕墙工程', '市政安装工程', '城市轨道交通安装', '人工土石方',
|
|
|
'房屋安装修缮工程', '房屋修缮单拆除'
|
|
'房屋安装修缮工程', '房屋修缮单拆除'
|
|
|
]},
|
|
]},
|
|
|
- {name: '金额', value: source.summaryInfo.engineeringCost, type: TYPE.NUM2},
|
|
|
|
|
|
|
+ {name: '金额', value: exportKind === FILE_KIND.tender
|
|
|
|
|
+ ? source.summaryInfo.engineeringCost
|
|
|
|
|
+ : '0', type: TYPE.NUM2},
|
|
|
{name: '定额库编码', value: source.defaultRationLibCode, enumeration: [
|
|
{name: '定额库编码', value: source.defaultRationLibCode, enumeration: [
|
|
|
'CQ18TJ', 'CQ18ZS', 'CQ18AZ', 'CQ18SZ', 'CQ18YL', 'CQ18FG', 'CQ18GD', 'CQ18FS',
|
|
'CQ18TJ', 'CQ18ZS', 'CQ18AZ', 'CQ18SZ', 'CQ18YL', 'CQ18FG', 'CQ18GD', 'CQ18FS',
|
|
|
'CQ18LS', 'CQ18GZW', 'CQ18BP', 'CQ18ZP'
|
|
'CQ18LS', 'CQ18GZW', 'CQ18BP', 'CQ18ZP'
|
|
@@ -363,7 +420,7 @@ const XMLStandard = (function () {
|
|
|
//特征项定义
|
|
//特征项定义
|
|
|
function FeatureItem(feature) {
|
|
function FeatureItem(feature) {
|
|
|
let attrs = [
|
|
let attrs = [
|
|
|
- {name: '编码', value: ''},
|
|
|
|
|
|
|
+ {name: '编码', value: feature.code || ''},
|
|
|
{name: '名称', value: feature.dispName, required: true},
|
|
{name: '名称', value: feature.dispName, required: true},
|
|
|
{name: '内容', value: feature.value, required: true},
|
|
{name: '内容', value: feature.value, required: true},
|
|
|
];
|
|
];
|
|
@@ -374,7 +431,7 @@ const XMLStandard = (function () {
|
|
|
element.call(this, '单位工程费汇总', []);
|
|
element.call(this, '单位工程费汇总', []);
|
|
|
}
|
|
}
|
|
|
//计价程序费用行定义
|
|
//计价程序费用行定义
|
|
|
- function DXFYRow(source) {
|
|
|
|
|
|
|
+ function FeeRow(source) {
|
|
|
let attrs = [
|
|
let attrs = [
|
|
|
{name: '序号', value: source.code},
|
|
{name: '序号', value: source.code},
|
|
|
{name: '行代号', value: source.rowCode, required: true},
|
|
{name: '行代号', value: source.rowCode, required: true},
|
|
@@ -618,7 +675,7 @@ const XMLStandard = (function () {
|
|
|
let attrs = [
|
|
let attrs = [
|
|
|
{name: '金额', value: getFee(source.fees, 'common.totalFee')}
|
|
{name: '金额', value: getFee(source.fees, 'common.totalFee')}
|
|
|
];
|
|
];
|
|
|
- element.call(this, '', attrs);
|
|
|
|
|
|
|
+ element.call(this, '计日工', attrs);
|
|
|
}
|
|
}
|
|
|
//人工定义
|
|
//人工定义
|
|
|
function Labour() {
|
|
function Labour() {
|
|
@@ -867,11 +924,14 @@ const XMLStandard = (function () {
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
this.failList = failList;
|
|
this.failList = failList;
|
|
|
- this.granularity = granularity;
|
|
|
|
|
//目前的数据
|
|
//目前的数据
|
|
|
let curPMData = {project: null, engineering: null, tender: null}, //项目管理项目数据
|
|
let curPMData = {project: null, engineering: null, tender: null}, //项目管理项目数据
|
|
|
curProjectEle = null, //建设项目节点
|
|
curProjectEle = null, //建设项目节点
|
|
|
curTenderEle = null; //单位工程节点
|
|
curTenderEle = null; //单位工程节点
|
|
|
|
|
+
|
|
|
|
|
+ //记录拉取的单位工程项目详细数据,导出的时候,可能会导出多个文件,只有导出第一个文件的时候需要请求数据
|
|
|
|
|
+ let tenderDetailMap = {}; //ID映射 ID: data
|
|
|
|
|
+
|
|
|
//自增编码
|
|
//自增编码
|
|
|
let incrementData = {
|
|
let incrementData = {
|
|
|
projectCode: 1, //项目编号,单项工程、单位工程编号自动生成
|
|
projectCode: 1, //项目编号,单项工程、单位工程编号自动生成
|
|
@@ -977,12 +1037,79 @@ const XMLStandard = (function () {
|
|
|
return target;
|
|
return target;
|
|
|
|
|
|
|
|
}
|
|
}
|
|
|
|
|
+ //转换基数表达式
|
|
|
|
|
+ //1.有子项,则取固定清单对应基数
|
|
|
|
|
+ //2.无子项,有基数,a.优先转换为行代号(不可自身) b.不能转换为行代号则找对应字典
|
|
|
|
|
+ //3.基数中有无法转换的,设为金额
|
|
|
|
|
+ function transformCalcBase(tenderDetail, node) {
|
|
|
|
|
+ let expr = node.data.calcBase || '';
|
|
|
|
|
+ if (node.children.length) {
|
|
|
|
|
+ let flag = getNodeFlag(node);
|
|
|
|
|
+ return FlagCalcBaseMap[flag] || '';
|
|
|
|
|
+ }
|
|
|
|
|
+ if (expr) {
|
|
|
|
|
+ let illegal = false;
|
|
|
|
|
+ let normalBase = getNormalBase(expr),
|
|
|
|
|
+ idBase = getIDBase(expr);
|
|
|
|
|
+ //普通基数转基数字典
|
|
|
|
|
+ normalBase.forEach(base => {
|
|
|
|
|
+ let replaceStr = CalcBaseMap[base];
|
|
|
|
|
+ //转换成行代号的优先级比较高,进行清单匹配
|
|
|
|
|
+ let flag = FlagCalcBaseMap[base];
|
|
|
|
|
+ if (flag) {
|
|
|
|
|
+ let flagNode = tenderDetail.mainTree.items.find(mNode => getNodeFlag(mNode) === flag);
|
|
|
|
|
+ //匹配到了 普通基数转换成行引用
|
|
|
|
|
+ if (flagNode) {
|
|
|
|
|
+ replaceStr = flagNode.serialNo() + 1;
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ //存在无法处理的基数
|
|
|
|
|
+ if (!replaceStr) {
|
|
|
|
|
+ illegal = true;
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
+ expr = expr.replace(new RegExp(base, 'g'), replaceStr);
|
|
|
|
|
+ });
|
|
|
|
|
+ //id引用转行代号引用
|
|
|
|
|
+ idBase.forEach(base => {
|
|
|
|
|
+ let id = base.match(/[^@]+/)[0];
|
|
|
|
|
+ let theNode = tenderDetail.mainTree.getNodeByID(id),
|
|
|
|
|
+ rowCode = theNode ? `F${theNode.serialNo() + 1}` : '';
|
|
|
|
|
+ if (!rowCode) {
|
|
|
|
|
+ illegal = true;
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
+ expr = expr.replace(new RegExp(base, 'g'), rowCode);
|
|
|
|
|
+ });
|
|
|
|
|
+ //不合法 返回金额
|
|
|
|
|
+ if (illegal) {
|
|
|
|
|
+ return getFee(node.data.fees, 'common.totalFee');
|
|
|
|
|
+ }
|
|
|
|
|
+ return expr;
|
|
|
|
|
+ }
|
|
|
|
|
+ //获取普通基数: {xxx}
|
|
|
|
|
+ function getNormalBase(str) {
|
|
|
|
|
+ let reg = /{.+?}/g,
|
|
|
|
|
+ matchs = str.match(reg);
|
|
|
|
|
+ return matchs || [];
|
|
|
|
|
+ }
|
|
|
|
|
+ //获取id引用基数: @xxx-xxx-xx
|
|
|
|
|
+ function getIDBase(str) {
|
|
|
|
|
+ let reg = /@.{36}/g,
|
|
|
|
|
+ matchs = str.match(reg);
|
|
|
|
|
+ return matchs || [];
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
//获取需要导出的项目数据
|
|
//获取需要导出的项目数据
|
|
|
//@param {Number}tenderID(当前界面的单位工程ID,后台根据这个单位工程,去找其建设项目下所有数据)
|
|
//@param {Number}tenderID(当前界面的单位工程ID,后台根据这个单位工程,去找其建设项目下所有数据)
|
|
|
//@return {Object}(eleObj)
|
|
//@return {Object}(eleObj)
|
|
|
async function loadProject(tenderID) {
|
|
async function loadProject(tenderID) {
|
|
|
//拉取标段数据:建设项目、单项工程、单位工程数据
|
|
//拉取标段数据:建设项目、单项工程、单位工程数据
|
|
|
- let projectData = curPMData.project = await ajaxPost('/pm/api/getProjectByGranularity', {user_id: userID, tenderID: tenderID, granularity: granularity});
|
|
|
|
|
|
|
+ let projectData = curPMData.project;
|
|
|
|
|
+ if (!projectData) { //没有数据,需要拉取
|
|
|
|
|
+ projectData = curPMData.project = await ajaxPost('/pm/api/getProjectByGranularity', {user_id: userID, tenderID: tenderID, granularity: granularity});
|
|
|
|
|
+ }
|
|
|
if (!projectData) {
|
|
if (!projectData) {
|
|
|
throw '获取项目数据错误';
|
|
throw '获取项目数据错误';
|
|
|
}
|
|
}
|
|
@@ -1063,7 +1190,10 @@ const XMLStandard = (function () {
|
|
|
//分批次获取单位工程
|
|
//分批次获取单位工程
|
|
|
for (let tenderData of engData.children) {
|
|
for (let tenderData of engData.children) {
|
|
|
curPMData.tender = tenderData;
|
|
curPMData.tender = tenderData;
|
|
|
- await setTimeoutSync(() => {},TIMEOUT_TIME); //间隔一段时间再初始单位工程数据,减少服务器压力
|
|
|
|
|
|
|
+ //需要请求项目详细数据的时候,间隔一段时间再初始单位工程数据,减少服务器压力
|
|
|
|
|
+ if (!tenderDetailMap[tenderData.ID]) {
|
|
|
|
|
+ await setTimeoutSync(() => {},TIMEOUT_TIME);
|
|
|
|
|
+ }
|
|
|
let tender = await loadTender(summaryInfo, tenderData);
|
|
let tender = await loadTender(summaryInfo, tenderData);
|
|
|
tenderGljs = []; //清空单位工程内所有的人材机(ID)
|
|
tenderGljs = []; //清空单位工程内所有的人材机(ID)
|
|
|
engineering.children.push(tender);
|
|
engineering.children.push(tender);
|
|
@@ -1077,8 +1207,12 @@ const XMLStandard = (function () {
|
|
|
* */
|
|
* */
|
|
|
async function loadTender(summaryInfo, tenderData) {
|
|
async function loadTender(summaryInfo, tenderData) {
|
|
|
//获取单位工程详细数据
|
|
//获取单位工程详细数据
|
|
|
- let tenderDetail = PROJECT.createNew(tenderData.ID, userID);
|
|
|
|
|
- await tenderDetail.loadDataSync();
|
|
|
|
|
|
|
+ let tenderDetail = tenderDetailMap[tenderData.ID];
|
|
|
|
|
+ if (!tenderDetail) {
|
|
|
|
|
+ tenderDetail = PROJECT.createNew(tenderData.ID, userID);
|
|
|
|
|
+ await tenderDetail.loadDataSync();
|
|
|
|
|
+ tenderDetailMap[tenderData.ID] = tenderDetail;
|
|
|
|
|
+ }
|
|
|
//设置定额库编码
|
|
//设置定额库编码
|
|
|
tenderDetail.rationLibMap = {};
|
|
tenderDetail.rationLibMap = {};
|
|
|
let defaultLib = null;
|
|
let defaultLib = null;
|
|
@@ -1091,7 +1225,6 @@ const XMLStandard = (function () {
|
|
|
//初始化项目人材机代号(人材机生成的代号要由排序后的项目人材机从C0开始生成),定额下的人材机含量提前使用到了这个代码,所以需要先初始化
|
|
//初始化项目人材机代号(人材机生成的代号要由排序后的项目人材机从C0开始生成),定额下的人材机含量提前使用到了这个代码,所以需要先初始化
|
|
|
let allGljs = gljUtil.sortRationGLJ(tenderDetail.projectGLJ.datas.gljList); //人材机汇总排序
|
|
let allGljs = gljUtil.sortRationGLJ(tenderDetail.projectGLJ.datas.gljList); //人材机汇总排序
|
|
|
tenderGljs = allGljs.map(glj => glj.glj_id);
|
|
tenderGljs = allGljs.map(glj => glj.glj_id);
|
|
|
-
|
|
|
|
|
//单位工程
|
|
//单位工程
|
|
|
let tenderSource = {
|
|
let tenderSource = {
|
|
|
code: getIncreamentData('projectCode'),
|
|
code: getIncreamentData('projectCode'),
|
|
@@ -1163,9 +1296,9 @@ const XMLStandard = (function () {
|
|
|
function loadDXFY(detail) {
|
|
function loadDXFY(detail) {
|
|
|
//单位工程费汇总
|
|
//单位工程费汇总
|
|
|
let tenderFeeSummary = new TenderFeeSummary();
|
|
let tenderFeeSummary = new TenderFeeSummary();
|
|
|
- //计价程序费用行,筛选大项费用行数据
|
|
|
|
|
- let dxfyNodes = detail.Bills.tree.roots;
|
|
|
|
|
- for (let node of dxfyNodes) {
|
|
|
|
|
|
|
+ //计价程序费用行,筛选大项费用
|
|
|
|
|
+ let feeNodes = detail.Bills.tree.roots;
|
|
|
|
|
+ for (let node of feeNodes) {
|
|
|
let mainTreeNode = detail.mainTree.getNodeByID(node.data.ID),
|
|
let mainTreeNode = detail.mainTree.getNodeByID(node.data.ID),
|
|
|
serialNo = mainTreeNode ? mainTreeNode.serialNo() + 1 : 1;
|
|
serialNo = mainTreeNode ? mainTreeNode.serialNo() + 1 : 1;
|
|
|
let flag = getNodeFlag(node) || 0;
|
|
let flag = getNodeFlag(node) || 0;
|
|
@@ -1173,14 +1306,14 @@ const XMLStandard = (function () {
|
|
|
code: node.data.code,
|
|
code: node.data.code,
|
|
|
rowCode: `F${serialNo}`,
|
|
rowCode: `F${serialNo}`,
|
|
|
name: node.data.name,
|
|
name: node.data.name,
|
|
|
- calcBase: node.data.calcBase,
|
|
|
|
|
|
|
+ calcBase: transformCalcBase(detail, node),
|
|
|
feeRate: node.data.feeRate ? node.data.feeRate : 100,
|
|
feeRate: node.data.feeRate ? node.data.feeRate : 100,
|
|
|
fees: node.data.fees,
|
|
fees: node.data.fees,
|
|
|
feeType: FEE_TYPE[flag] || FEE_TYPE['0'],
|
|
feeType: FEE_TYPE[flag] || FEE_TYPE['0'],
|
|
|
remark: node.data.remark
|
|
remark: node.data.remark
|
|
|
};
|
|
};
|
|
|
- let dxfy = new DXFYRow(source);
|
|
|
|
|
- tenderFeeSummary.children.push(dxfy);
|
|
|
|
|
|
|
+ let feeRow = new FeeRow(source);
|
|
|
|
|
+ tenderFeeSummary.children.push(feeRow);
|
|
|
}
|
|
}
|
|
|
return tenderFeeSummary;
|
|
return tenderFeeSummary;
|
|
|
}
|
|
}
|
|
@@ -1462,6 +1595,9 @@ const XMLStandard = (function () {
|
|
|
remark: node.data.remark,
|
|
remark: node.data.remark,
|
|
|
feeType: FEE_TYPE[getNodeFlag(node)] || FEE_TYPE['0']
|
|
feeType: FEE_TYPE[getNodeFlag(node)] || FEE_TYPE['0']
|
|
|
};
|
|
};
|
|
|
|
|
+ /*if (source.feeType === '1800') {
|
|
|
|
|
+ debugger;
|
|
|
|
|
+ }*/
|
|
|
let formula = new FormulaCalcMeasure(source);
|
|
let formula = new FormulaCalcMeasure(source);
|
|
|
parent.children.push(formula);
|
|
parent.children.push(formula);
|
|
|
}
|
|
}
|
|
@@ -1993,9 +2129,13 @@ const XMLStandard = (function () {
|
|
|
/*
|
|
/*
|
|
|
* 导出数据
|
|
* 导出数据
|
|
|
* @param {Number}tenderID(当前界面的单位工程ID,后台根据这个单位工程,根据导出粒度去找其建设项目下相关数据)
|
|
* @param {Number}tenderID(当前界面的单位工程ID,后台根据这个单位工程,根据导出粒度去找其建设项目下相关数据)
|
|
|
|
|
+ * @param {Number}curExportKind(导出的文件类型:1-投标 2-招标 3-控制价)
|
|
|
* @return {void}
|
|
* @return {void}
|
|
|
* */
|
|
* */
|
|
|
- this.toXml = async function (tenderID) {
|
|
|
|
|
|
|
+ this.toXml = async function (tenderID, curExportKind) {
|
|
|
|
|
+ if (curExportKind) {
|
|
|
|
|
+ this.exportKind = exportKind = parseInt(curExportKind);
|
|
|
|
|
+ }
|
|
|
let eleData = await loadProject(tenderID);
|
|
let eleData = await loadProject(tenderID);
|
|
|
this.datas = eleData;
|
|
this.datas = eleData;
|
|
|
if (!eleData) {
|
|
if (!eleData) {
|
|
@@ -2008,6 +2148,7 @@ const XMLStandard = (function () {
|
|
|
//格式化
|
|
//格式化
|
|
|
xmlStr = formatXml(xmlStr);
|
|
xmlStr = formatXml(xmlStr);
|
|
|
let blob = new Blob([xmlStr], {type: 'text/plain;charset=utf-8'});
|
|
let blob = new Blob([xmlStr], {type: 'text/plain;charset=utf-8'});
|
|
|
|
|
+ return blob;
|
|
|
saveAs(blob, '重庆标准交换数据.QTF');
|
|
saveAs(blob, '重庆标准交换数据.QTF');
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|