|
@@ -0,0 +1,272 @@
|
|
|
+/**
|
|
|
+ * Created by zhang on 2018/6/1.
|
|
|
+ */
|
|
|
+
|
|
|
+let tender_obj={
|
|
|
+ tenderSpread:null,
|
|
|
+ tenderSheet:null,
|
|
|
+ tenderTree:null,
|
|
|
+ tenderController:null,
|
|
|
+ tenderSetting:{
|
|
|
+ header:[
|
|
|
+ {headerName: "项目编码", headerWidth: 170, dataCode: "code", dataType: "String",spanRows: [2],getText:'getText.code'},
|
|
|
+ {headerName: "类别", headerWidth: 50, dataCode: "subType", hAlign: "center", dataType: "String",spanRows: [2],getText:'getText.subType'},
|
|
|
+ {headerName: "项目名称", headerWidth: 200, dataCode: "name",showHint:true, hAlign: "left", dataType: "String",spanRows: [2]},
|
|
|
+ {headerName: "计量\n单位", headerWidth: 60, dataCode: "unit", hAlign: "center", dataType: "String",spanRows: [2]},
|
|
|
+ {headerName: "工程量", headerWidth: 120, dataCode: "basePrice", hAlign: "right", dataType: "Number",validator:"number",spanRows: [2]},
|
|
|
+ {headerName: "不调价", headerWidth: 55, dataCode: "is_adjust_price", hAlign: "center", cellType : "checkBox",dataType: "Number",spanRows: [2]},
|
|
|
+ {headerName: ["初始报价","综合单价"], headerWidth: 80, dataCode: "feesIndex.common.unitFee", hAlign: "right", dataType: "Number",validator:"number",spanCols : [2,1]},
|
|
|
+ {headerName: ["","综合合价"], headerWidth: 80, dataCode: "feesIndex.common.totalFee", hAlign: "right", dataType: "Number",validator:"number",spanCols : [0,1]},
|
|
|
+ {headerName: ["目标造价","综合单价"], headerWidth: 80, dataCode: "targetUnitFee", hAlign: "right", dataType: "Number",validator:"number",spanCols : [2,1]},
|
|
|
+ {headerName: ["","综合合价"], headerWidth: 80, dataCode: "targetTotalFee", hAlign: "right", dataType: "Number",validator:"number",spanCols : [0,1]},
|
|
|
+ {headerName: ["调整后报价","综合单价"], headerWidth: 80, dataCode: "feesIndex.common.tenderUnitFee", hAlign: "right", dataType: "Number",validator:"number",spanCols : [2,1]},
|
|
|
+ {headerName: ["","综合合价"], headerWidth: 80, dataCode: "feesIndex.common.tenderTotalFee", hAlign: "right", dataType: "Number",validator:"number",spanCols : [0,1]},
|
|
|
+ {headerName: ["消耗量调整系数","人工"], headerWidth: 80, dataCode: "quantityCoe.labour", hAlign: "right", dataType: "Number",validator:"number",spanCols : [5,1]},
|
|
|
+ {headerName: ["","材料"], headerWidth: 80, dataCode: "quantityCoe.material", hAlign: "right", dataType: "Number",validator:"number",spanCols : [0,1]},
|
|
|
+ {headerName: ["","机械"], headerWidth: 80, dataCode: "quantityCoe.machine", hAlign: "right", dataType: "Number",validator:"number",spanCols : [0,1]},
|
|
|
+ {headerName: ["","主材"], headerWidth: 80, dataCode: "quantityCoe.main", hAlign: "right", dataType: "Number",validator:"number",spanCols : [0,1]},
|
|
|
+ {headerName: ["","设备"], headerWidth: 80, dataCode: "quantityCoe.equipment", hAlign: "right", dataType: "Number",validator:"number",spanCols : [0,1]},
|
|
|
+ {headerName: "子目工程量\n调整系数", headerWidth: 100, dataCode: "rationQuantityCoe", hAlign: "center", dataType: "Number",spanRows: [2],validator:"number"}
|
|
|
+ ],
|
|
|
+ view: {
|
|
|
+ lockColumns: [0,1,2,3,4,6,7,10,11]
|
|
|
+ }
|
|
|
+ },
|
|
|
+ tenderTreeSetting:{
|
|
|
+ "emptyRows" : 3,
|
|
|
+ "headRows" :2,
|
|
|
+ "treeCol" : 0,
|
|
|
+ "headRowHeight" : [21],
|
|
|
+ "cols" : []
|
|
|
+ },
|
|
|
+ initTenderSpread:function () {
|
|
|
+ if(!this.tenderSpread){
|
|
|
+ this.tenderSpread = SheetDataHelper.createNewSpread($("#tenderSpread")[0]);
|
|
|
+ }
|
|
|
+ this.tenderSheet = this.tenderSpread.getSheet(0);
|
|
|
+ this.tenderTree = cacheTree.createNew(this);
|
|
|
+ this.tenderTreeSetting = this.createTenderTreeSetting();
|
|
|
+ TREE_SHEET_HELPER.initSetting($('#tenderSpread')[0], this.tenderTreeSetting );
|
|
|
+ this.tenderTreeSetting.setAutoFitRow = MainTreeCol.getEvent("setAutoFitRow");
|
|
|
+ this.tenderController = TREE_SHEET_CONTROLLER.createNew(this.tenderTree, this.tenderSheet, this.tenderTreeSetting);
|
|
|
+ this.tenderSheet.bind(GC.Spread.Sheets.Events.ValueChanged, this.onSheetValueChange);
|
|
|
+ this.tenderSheet.bind(GC.Spread.Sheets.Events.EditStarting,this.onEditStarting);
|
|
|
+
|
|
|
+ // this.tenderController.bind(TREE_SHEET_CONTROLLER.eventName.treeSelectedChanged, this.onSelectionChange);
|
|
|
+ },
|
|
|
+ createTenderTreeSetting:function () {
|
|
|
+ return sheetCommonObj.transferToTreeSetting(this.tenderSetting,this.tenderTreeSetting,MainTreeCol);
|
|
|
+ },
|
|
|
+ showTenderData:function () {
|
|
|
+ let me = this;
|
|
|
+ let mainTree = projectObj.project.mainTree;
|
|
|
+ this.tenderTree.nodes={},this.tenderTree.selected = null,this.tenderTree.roots = [],this.tenderTree.items=[];
|
|
|
+ for(r of mainTree.roots){
|
|
|
+ createTenderNode(r,null,null);
|
|
|
+ }
|
|
|
+ me.tenderTree.sortTreeItems();
|
|
|
+ this.tenderSheet.setRowCount(0);
|
|
|
+ me.tenderController.showTreeData();
|
|
|
+
|
|
|
+ function createTenderNode(mainNode,parent,next) {
|
|
|
+ if(mainNode.sourceType != ModuleNames.ration_glj){//主材、设备的工料机不用显示
|
|
|
+ let newNode = me.tenderTree.addNode(parent, next, mainNode.data.ID);
|
|
|
+ newNode.data = mainNode.data;
|
|
|
+ newNode.source = mainNode.source;
|
|
|
+ newNode.sourceType = mainNode.sourceType;
|
|
|
+ newNode.mainNode = mainNode;
|
|
|
+ if(mainNode.children.length > 0){
|
|
|
+ for(let c of mainNode.children){
|
|
|
+ createTenderNode(c,newNode,null);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return newNode;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ },
|
|
|
+ onSheetValueChange : function (sender,args) {
|
|
|
+ let me = tender_obj, row = args.row, col = args.col;
|
|
|
+ let node = me.tenderTree.items[row];
|
|
|
+ let dataCode = me.tenderSetting.header[col].dataCode;
|
|
|
+ let value = args.newValue;
|
|
|
+ let updateData = {type:node.sourceType,data:{'ID' : node.data.ID}};
|
|
|
+ let datas = [],nodes = [];
|
|
|
+
|
|
|
+ if (value&&!projectGljObject.checkData(col,me.tenderSetting,value)) {
|
|
|
+ setTimeout(function () {//为了不与click事件冲突
|
|
|
+ alert('输入的数据类型不对,请重新输入!');
|
|
|
+ },200);
|
|
|
+ updateData = null;
|
|
|
+ }
|
|
|
+ if(dataCode == 'is_adjust_price'){//不调价,修改父项后,子项也跟着更新
|
|
|
+ if(value == true){
|
|
|
+ value = 1;
|
|
|
+ }else if(value == false){
|
|
|
+ value = 0;
|
|
|
+ }
|
|
|
+ me.updateChildrenValue(node,dataCode,value,datas,nodes);
|
|
|
+ }
|
|
|
+ if(updateData&&dataCode.indexOf("Coe") != -1 ){//如果是调整系统项,级联更新子项
|
|
|
+ value = scMathUtil.roundForObj(value,getDecimal('process'));
|
|
|
+ me.updateChildrenValue(node,dataCode,value,datas,nodes);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ //在目标造价综合单价中输入数值,按项目属性中的清单单价精度取舍,并清空当前行的目标造价综合合价
|
|
|
+ if(dataCode == 'targetUnitFee'){
|
|
|
+ value = scMathUtil.roundForObj(value,getDecimal('unitPrice',node));
|
|
|
+ updateData?updateData.data["targetTotalFee"] = null:'';
|
|
|
+ }
|
|
|
+ if(dataCode == 'targetTotalFee'){
|
|
|
+ value = scMathUtil.roundForObj(value,getDecimal('totalPrice',node));
|
|
|
+ updateData?updateData.data["targetUnitFee"] = null:'';
|
|
|
+ }
|
|
|
+ if(updateData){
|
|
|
+ updateData.data[dataCode] = value;
|
|
|
+ datas.push(updateData);
|
|
|
+ }
|
|
|
+ nodes.push(node);
|
|
|
+ me.updateTenderData(datas,function () {
|
|
|
+ me.tenderController.refreshTreeNode(nodes, false);
|
|
|
+ });
|
|
|
+
|
|
|
+ },
|
|
|
+ updateChildrenValue:function (node,dataCode,value,datas,nodes) {
|
|
|
+ if(node.children.length > 0){
|
|
|
+ for(let c of node.children){
|
|
|
+ let updateData = {type:c.sourceType,data:{'ID' : c.data.ID}};
|
|
|
+ updateData.data[dataCode] = value;
|
|
|
+ datas.push(updateData);
|
|
|
+ nodes.push(c);
|
|
|
+ this.updateChildrenValue(c,dataCode,value,datas,nodes);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ },
|
|
|
+
|
|
|
+ updateTenderData:function (datas,callback) {
|
|
|
+ let me = tender_obj;
|
|
|
+ if(datas.length <= 0){
|
|
|
+ callback?callback():'';
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ $.bootstrapLoading.start();
|
|
|
+ projectObj.project.updateNodes(datas,function () {
|
|
|
+ for(let d of datas){
|
|
|
+ let temObj = null;
|
|
|
+ if(d.type == ModuleNames.bills || d.type == ModuleNames.ration){
|
|
|
+ let temNode = me.tenderTree.findNode(d.data.ID);
|
|
|
+ temObj = temNode?temNode.data:null;
|
|
|
+ }else if(d.type == ModuleNames.project){
|
|
|
+ temObj = projectInfoObj.projectInfo;
|
|
|
+ }
|
|
|
+ if(temObj){
|
|
|
+ for(let key in d.data){
|
|
|
+ if(key == 'ID' || key == 'id'){
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ _.set(temObj,key,d.data[key]);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ callback?callback():'';
|
|
|
+ $.bootstrapLoading.end();
|
|
|
+ })
|
|
|
+ },
|
|
|
+
|
|
|
+
|
|
|
+ onEditStarting:function (sender,args) {
|
|
|
+ let me = tender_obj, row = args.row, col = args.col;
|
|
|
+ if(me.editChecking(row,col) == false){
|
|
|
+ args.cancel = true;
|
|
|
+ }
|
|
|
+
|
|
|
+ },
|
|
|
+ editChecking:function (row,col) {//return false表示不能编辑
|
|
|
+ let me = tender_obj;
|
|
|
+ let dataCode = me.tenderSetting.header[col].dataCode;
|
|
|
+ let lockColumns = me.tenderSetting.view.lockColumns;
|
|
|
+
|
|
|
+ if(lockColumns.indexOf(col)!= -1){
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ if(dataCode == 'is_adjust_price'){
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ if(row >= me.tenderTree.items.length){
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ if(dataCode == 'targetUnitFee' || dataCode == 'targetTotalFee'){
|
|
|
+ if($('#calcPriceOption').val() == 'coeBase'){//下拉按钮显示为“根据调整系数计算报价”时,目标造价(综合单价、综合合价) ,灰显,只读。
|
|
|
+ return false;
|
|
|
+ }else if(me.tenderTree.items[row].data.is_adjust_price === 1){//下拉按钮显示为“根据报价计算调整系数”时,打勾了不调价,目标造价(综合单价、综合合价)只读。
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if(dataCode.indexOf('Coe') != -1){//如果是调整系数列
|
|
|
+ if($('#calcPriceOption').val() =='priceBase'){//下拉按钮显示为“根据报价计算调整系数”时,只读。
|
|
|
+ return false;
|
|
|
+ }else if(me.tenderTree.items[row].data.is_adjust_price === 1){//打勾了不调价,只读。
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return true;
|
|
|
+ },
|
|
|
+ initPageContent : function () {
|
|
|
+ let tenderSetting = projectObj.project.property.tenderSetting;
|
|
|
+ let calcPriceOption = tenderSetting && tenderSetting.calcPriceOption? tenderSetting.calcPriceOption :"coeBase";
|
|
|
+ let gljPriceTenderCoe = tenderSetting && tenderSetting.gljPriceTenderCoe?tenderSetting.gljPriceTenderCoe:1;
|
|
|
+ $('#calcPriceOption').val(calcPriceOption);
|
|
|
+ $('#gljPriceTenderCoe').val(gljPriceTenderCoe);
|
|
|
+ if(calcPriceOption == 'coeBase'){
|
|
|
+ $('#tenderPrice').removeAttr("disabled");
|
|
|
+ $('#tenderGLJQuantity').attr("disabled",true);
|
|
|
+ $('#tenderRationQuantity').attr("disabled",true);
|
|
|
+ }else {
|
|
|
+ $('#tenderPrice').attr("disabled",true);
|
|
|
+ $('#tenderGLJQuantity').removeAttr("disabled");
|
|
|
+ $('#tenderRationQuantity').removeAttr("disabled");
|
|
|
+ }
|
|
|
+ //gljPriceTenderCoe
|
|
|
+ }
|
|
|
+};
|
|
|
+
|
|
|
+$(function () {
|
|
|
+ $('#tab_tender_price').on('shown.bs.tab', function (e) {
|
|
|
+ sessionStorage.setItem('mainTab', '#tab_tender_price');
|
|
|
+ $(e.relatedTarget.hash).removeClass('active');
|
|
|
+ if(!tender_obj.tenderSpread){
|
|
|
+ tender_obj.initTenderSpread();
|
|
|
+ }
|
|
|
+ autoFlashHeight();
|
|
|
+ tender_obj.tenderSpread.refresh();
|
|
|
+ tender_obj.showTenderData();
|
|
|
+ tender_obj.initPageContent();
|
|
|
+ });
|
|
|
+
|
|
|
+ $('#tenderGLJQuantity').bind('click',function () {
|
|
|
+ console.log($('#gljPriceTenderCoe').val()) ;
|
|
|
+ });
|
|
|
+
|
|
|
+ $('#calcPriceOption').change(function(){
|
|
|
+ let me = tender_obj;
|
|
|
+ let newVal = $(this).val();
|
|
|
+ let updateData = {type:ModuleNames.project,data:{'ID' : projectObj.project.ID(),'property.tenderSetting.calcPriceOption':newVal}};
|
|
|
+ me.updateTenderData([updateData],function () {
|
|
|
+ me.initPageContent();
|
|
|
+ });
|
|
|
+ });
|
|
|
+
|
|
|
+ $('#gljPriceTenderCoe').change(function(){
|
|
|
+ let me = tender_obj;
|
|
|
+ let process = getDecimal('process');
|
|
|
+ var newVal = $(this).val();
|
|
|
+ process = scMathUtil.roundForObj(newVal,process);
|
|
|
+ let updateData = {type:ModuleNames.project,data:{'ID' : projectObj.project.ID(),'property.tenderSetting.gljPriceTenderCoe':process}};
|
|
|
+ me.updateTenderData([updateData],function () {
|
|
|
+ me.initPageContent();
|
|
|
+ });
|
|
|
+ })
|
|
|
+
|
|
|
+
|
|
|
+});
|