| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606 | 
							- /**
 
-  * Created by zhang on 2018/11/26.
 
-  */
 
- let mbzm_obj={
 
-     spread:null,
 
-     nodeChanged:false,
 
-     datas:[],
 
-     locateMap:{
 
-       INMEASURE:1,
 
-       INFBFX:2,
 
-       AFTERRATION:3
 
-     },
 
-     setting:{
 
-         header: [
 
-             {headerName: "编码", headerWidth: 130, dataCode: "code", dataType: "String", formatter: "@"},
 
-             {headerName: "模板类别", headerWidth: 260, dataCode: "name", dataType: "String", hAlign: "left"},
 
-             {headerName: "单位", headerWidth: 45, dataCode: "unit", dataType: "String", hAlign: "center",getText:'forUnit'},
 
-             {headerName: "系数", headerWidth: 65, dataCode: "coe", dataType: "Number",validator:"number"},
 
-             {headerName: "工程量", headerWidth: 65, dataCode: "quantity", dataType: "Number",validator:"number",getText:'forQuantity'},//这里做成当系数不为0时,动态生成工程量,同步更新太麻烦
 
-             {headerName: "关联类别", headerWidth: 100, dataCode: "type", dataType: "String"},
 
-             {headerName: "清单位置", headerWidth: 200, dataCode: "position", hAlign: "left", dataType: "String",cellType:'selectButton',getText:'forPosition'},
 
-         ],
 
-         view: {
 
-             lockColumns:["code","name","unit","type"],
 
-             rowHeaderWidth:25
 
-         },
 
-         getText:{
 
-             forPosition:function (item) {
 
-                 let createL =  $('#createLocation').val();
 
-                 if(createL == mbzm_obj.locateMap.INMEASURE) return  mbzm_obj.getDisplayText(item.billID,item.billsLocation);
 
-                 if(createL == mbzm_obj.locateMap.INFBFX) return  mbzm_obj.getDisplayText(item.fxID,"");
 
-                 return ""
 
-             },
 
-             forUnit:function (item) {//这里显示的单位是去掉定额单位前面的数字的结果
 
-                return item.unit &&_.isString(item.unit)?item.unit.replace(/^\d+/,""):""
 
-             },
 
-             forQuantity:function (item) {
 
-                 return mbzm_obj.getQuantity(item);
 
-             }
 
-         }
 
-     },
 
-     getDisplayText:function (billID,position) {
 
-         if(billID && billID!=''){
 
-             let node = projectObj.project.mainTree.getNodeByID(billID);
 
-             if(node){
 
-                 let code = node.data.code?node.data.code:"";
 
-                 let name = node.data.name?node.data.name:"";
 
-                 return code +" "+name;
 
-             }
 
-         }
 
-         return  position;
 
-     },
 
-     //当点击应用的时候才保存数据
 
-     initSpread:function () {
 
-         this.spread = SheetDataHelper.createNewSpread($("#mbzmSpread")[0]);
 
-         sheetCommonObj.spreadDefaultStyle(this.spread);
 
-         this.sheet = this.spread.getSheet(0);
 
-         sheetCommonObj.initSheet(this.sheet, this.setting);
 
-         this.sheet.bind(GC.Spread.Sheets.Events.ValueChanged, this.onSheetValueChange);
 
-         this.spread.bind(GC.Spread.Sheets.Events.ButtonClicked, installationFeeObj.onPositionButtonClick);//共用一个位置选择器
 
-         this.sheet.name('ration_template');
 
-         if(projectReadOnly){
 
-             sheetCommonObj.disableSpread(this.spread);
 
-         }
 
-     },
 
-     refresh:function () {
 
-         let total = $('#mbzmSpread').parent().height();
 
-         let b_height = $('#mbzmSpread').prev('.col-12').height();
 
-         $('#mbzmSpread').css('height',total- b_height);
 
-         this.spread?this.spread.refresh():this.initSpread();
 
-     },
 
-     refreshSheetData:function () {
 
-         if($('#mbzmSpread').is(':visible')) sheetCommonObj.showData(this.sheet, this.setting,this.datas);
 
-     },
 
-     showMBZMData:function(node){
 
-         let selected = node?node:projectObj.project.mainTree.selected;
 
-         if(this.nodeChanged == true){//选中的行改变了才做初始化,刷新当前缓存, 在project_view 中treeSelectedChanged方法里设置
 
-             let datas = [];
 
-             $("#createLocation").val(this.locateMap.INMEASURE);//初始化
 
-             if(selected&&selected.sourceType == ModuleNames.ration){
 
-                 let ration = selected.data;
 
-                 let  template = projectObj.project.ration_template.getTemplateByRationID(ration.ID);
 
-                 if(template) {
 
-                     $("#createLocation").val(template.createLocation);
 
-                     let pcol = _.findIndex(this.setting.header,{dataCode:"position"});
 
-                     this.setting.header[pcol].visible = template.createLocation == this.locateMap.AFTERRATION?false:true;
 
-                     datas = _.cloneDeep(template.templateList);
 
-                 }
 
-             }
 
-             this.datas = datas;
 
-             this.nodeChanged = false;//这里要恢复成false 应为调用gljObj.refresh() 方法也会进到这里来,这时节点应是没有改变的
 
-         }
 
-         sheetCommonObj.showData(this.sheet, this.setting,this.datas);
 
-         this.sheet.setRowCount(this.datas.length);
 
-     },
 
-     onSheetValueChange:function (e,info) {
 
-         let me = mbzm_obj;
 
-         let selected = projectObj.project.mainTree.selected;
 
-         let row = info.row, col = info.col;
 
-         let dataCode = me.setting.header[col].dataCode;
 
-         let recode = me.datas[row], value = info.newValue;
 
-         if (info.newValue === undefined) {
 
-             return;
 
-         }
 
-         if (value && !sheetCommonObj.checkData(col, me.setting, value)) {
 
-             alert('输入的数据类型不对,请重新输入!');
 
-             me.refreshSheetData();
 
-             return;
 
-         }
 
-         if (dataCode === 'coe') {//  //为了避免各种同步更新,后面的工程量改成实时动态计算,所以这里更新为0
 
-             recode["quantity"] = "0";
 
-         }
 
-         if (dataCode === 'quantity') {//定额默认显示为0,可输入数值,输入数值后,则清空前面的系数列
 
-             value = scMathUtil.roundForObj(value, getDecimal('ration.quantity'))+"";
 
-             recode["coe"] = "0";
 
-         }
 
-         recode[dataCode] = value;
 
-         me.refreshSheetData();
 
-     },
 
-     getQuantity:function(item){//当系数不为0的时候实时获取消耗量
 
-         if(item.coe && item.coe!="0"){
 
-             let selected = projectObj.project.mainTree.selected;
 
-             let rationQuantity = selected.data.quantity;
 
-             rationQuantity = rationQuantity?scMathUtil.roundForObj(rationQuantity, getDecimal('ration.quantity')):0;
 
-             let times = parseInt(selected.data.unit);
 
-             times = isNaN(times)?1:times;//工程量要乘以定额单位的倍数
 
-             let value = scMathUtil.roundForObj(item.coe, getDecimal('process'));
 
-             //为了避免各种同步更新这里改成实时动态计算带系数的工程量
 
-             return scMathUtil.roundForObj(rationQuantity * value*times, getDecimal('ration.quantity'))+"";
 
-         }else {
 
-             return item.quantity;
 
-         }
 
-     },
 
-     updatePosition:function (recode) {
 
-         let selection = this.sheet.getSelections()[0];
 
-         let selectedItem =this.datas[selection.row];
 
-         let updateField = $("#createLocation").val()==this.locateMap.INMEASURE?"billID":"fxID";
 
-         if(selectedItem[updateField] == recode.ID) return;
 
-         selectedItem[updateField] = recode.ID;
 
-         if($("#createLocation").val()==this.locateMap.INMEASURE)selectedItem.billsLocation = recode.code;
 
-         this.refreshSheetData();
 
-     },
 
-     applyTemplate:function () {//应用清单模板
 
-         let selected = projectObj.project.mainTree.selected;
 
-         let template = projectObj.project.ration_template.getTemplateByRationID(selected.data.ID);
 
-         let createLocation = $("#createLocation").val();
 
-         let rations = {update:[],create:[],delete:[]},bills={update:[],create:[]};
 
-         if(this.datas.length <= 0) return;
 
-         let quantityValide = false;
 
-         for(let data of this.datas){
 
-           let quantity = this.getQuantity(data);//取实时或手输工程量 
 
-           if(quantity&&quantity!='0') quantityValide = true;
 
-         }
 
-         if(quantityValide == false)return alert('请输入工程量');         
 
-         for(let d of this.datas){
 
-             let ration = _.find(projectObj.project.Ration.datas,{'referenceRationID':selected.data.ID,'code':d.code});
 
-             if(ration||(gljUtil.isDef(d.quantity)&& parseFloat(d.quantity)>0)||(d.coe && d.coe!="0")){
 
-                 if(this.positionChecking(createLocation,d) == false){//清单位置检查
 
-                     alert(`请选择${d.code}生成的清单位置`);
 
-                     return;
 
-                 }
 
-                 this.getNodeUpdateData(d,selected.data.ID,createLocation,rations,bills);
 
-             }
 
-         }
 
-         let ration_template={type:ModuleNames.ration_template,data:{ID:template.ID, createLocation:createLocation, templateList:this.datas}};
 
-         let data = {
 
-             ration_template:ration_template,
 
-             rations:rations,
 
-             bills:bills
 
-         };
 
-         console.log(data);
 
-         $.bootstrapLoading.start();
 
-         CommonAjax.post('/ration/applyTemplate',data,function (result) {
 
-             let parentsNodes = [];
 
-             //先删除旧的定额
 
-             if(data.rations.delete.length > 0){
 
-                 for(let d of data.rations.delete){
 
-                     let dRaNode =  projectObj.project.mainTree.getNodeByID(d.ID);
 
-                     if(dRaNode){
 
-                         parentsNodes.push(dRaNode.parent);
 
-                         projectObj.project.Ration.deleteSubListOfRation({ID:d.ID});
 
-                         _.remove(projectObj.project.Ration.datas,{'ID':d.ID});
 
-                         projectObj.mainController.m_delete([dRaNode],dRaNode.serialNo(),false)//这里删除关联子目生成的定额因为是离散的树节点,所以要这样分开处理
 
-                     }
 
-                 }
 
-             }
 
-             let refreshNodes = projectObj.project.updateNodesCache(result.updateDatas);//更新要update的前端缓存,并返回要刷新的树节点
 
-             let nodeDatas = {ration:{add:[]}, bills:{add:[]}};
 
-             if(result.rationResult){
 
-                 for(let rr of result.rationResult){
 
-                     nodeDatas.ration.add.push(rr.ration);//定额datas数据的push在addNodes里面做
 
-                     projectObj.project.Ration.addSubListOfRation(rr,false);//添加定额子项缓存
 
-                 }
 
-             }
 
-             //对于新插入的清单:
 
-             if(result.billsResult.length > 0){
 
-                 nodeDatas.bills.add = result.billsResult;
 
-             }
 
-             let calRations = ProjectController.addNewNodes(nodeDatas);
 
-             if(refreshNodes.length > 0){
 
-                 for(let r of refreshNodes){
 
-                     if(r.sourceType == ModuleNames.ration){
 
-                         calRations.push(r);
 
-                         if(r.data.quantityEXP =="MBGCL" ) projectObj.project.quantity_detail.cleanQuantityDetail(r,true);
 
-                     }
 
-                 }
 
-                 projectObj.mainController.refreshTreeNode(refreshNodes, false);
 
-             }
 
-             projectObj.project.projectGLJ.calcQuantity();
 
-             $.bootstrapLoading.end();
 
-             cbTools.refreshFormulaNodes();
 
-             //更新计算程序模板,并进行重新计算
 
-             if(parentsNodes.length > 0) calRations = calRations.concat(parentsNodes);//计算被删除的子目关联定额的父节点
 
-             projectObj.project.calcProgram.calcNodesAndSave(calRations,async function () {
 
-                 installationFeeObj.calcInstallationFee();
 
-                 await OVER_HEIGHT.reCalcOverHeightFee();
 
-                 await itemIncreaseFeeObj.calcItemIncreaseFeeByNodes(calRations);
 
-             });
 
-             mbzm_obj.showApplySuccess();
 
-         })
 
-     },
 
-     showApplySuccess:function () {
 
-         $(".applySuccess").show();
 
-         setTimeout(function () {
 
-             $(".applySuccess").hide();
 
-         },1500)
 
-     },
 
-     positionChecking(type,data){//这个要之后再测试一下
 
-         let validate = true;
 
-         if(type == mbzm_obj.locateMap.INMEASURE){
 
-             if(!_.isEmpty(data.billID)){
 
-                 let node = projectObj.project.mainTree.getNodeByID(data.billID);
 
-                 if(!node) validate = false;//ID有值,但是找不到,说明清单已经被删除
 
-             }else if(_.isEmpty(data.billsLocation)){
 
-                 validate = false
 
-             }
 
-         }else if(type == mbzm_obj.locateMap.INFBFX){
 
-             if(_.isEmpty(data.fxID)) {
 
-                 validate = false;
 
-             }else {
 
-                 let node = projectObj.project.mainTree.getNodeByID(data.fxID);
 
-                 if(!node) validate = false;//ID有值,但是找不到,说明分项已经被删除
 
-             }
 
-         }
 
-         return validate
 
-     },
 
-     getNodeUpdateData:function(data,referenceRationID,type,rations,bills){
 
-         let quantity = this.getQuantity(data);//取实时或手输工程量
 
-         quantity = this.transferToRationQuantity(data.unit,quantity);//工程量要经过转换
 
-         let mainRation = projectObj.project.mainTree.getNodeByID(referenceRationID);
 
-         let billsID="";
 
-         //先检查要更新的定额是否已经存在
 
-         let ration = this.getExistRation(data,referenceRationID,type,rations);
 
-         if(ration) {//如果存在,则比较清耗量、工程量表达式是否一致
 
-             let tem =  this.getRationData(ration,data,quantity);//取更新信息
 
-             if(tem){//如果不一致,则需要更新
 
-                 rations.update.push(tem);
 
-             }
 
-             //在定额存在的情况下,不用往下执行了
 
-             return;
 
-         }
 
-         //定额不存在的情况下
 
-         if(type == mbzm_obj.locateMap.AFTERRATION) {//如果是生成在主定额后面的位置
 
-             this.createNewRationAfterMain(data,mainRation,quantity,rations);
 
-         }else if(type == mbzm_obj.locateMap.INMEASURE){//生成在措施项目下
 
-             this.createNewRationInMeasure(data,mainRation,quantity,rations,bills);
 
-         }else {
 
-             this.createNewRationInFBFX(data,mainRation,quantity,rations,bills);
 
-         }
 
-     },
 
-     getRationData:function (ration,data,quantity) {
 
-         let tem = {};
 
-         if (ration.quantity + "" != quantity) tem.quantity = quantity;
 
-         if (gljUtil.isDef(data.coe) && data.coe != "0"&&ration.quantityEXP != "MBGCL") {
 
-             tem.isFromDetail = 0;
 
-             tem.quantityEXP = "MBGCL";
 
-         }
 
-         if(!_.isEmpty(tem)) {
 
-             tem.projectID = ration.projectID;
 
-             tem.ID = ration.ID;
 
-             tem.contain = projectObj.project.Ration.getContain(projectObj.project.mainTree.findNode(ration.billsItemID),tem.quantity);
 
-             return tem;
 
-         }
 
-         return null;
 
-     },
 
-     createNewRationAfterMain:function (data,mainRation,quantity,rations) {
 
-         //生成新的定额
 
-         let newID =  uuid.v1();
 
-         let serialNo = mainRation.data.serialNo+1;
 
-         //如果已经有正要生成的定额,则取这个序号再加1
 
-         if(rations.create.length > 0){
 
-             serialNo = rations.create[rations.create.length -1].newData.serialNo + 1
 
-         }
 
-         let n_ration = this.createNewRationData(data,newID,mainRation.data.ID,mainRation.data.billsItemID,serialNo,quantity,mainRation.data.libID,false,mainRation.data.manageFeeRate);
 
-         rations.create.push(n_ration);
 
-         //处理其它兄弟节点的序号
 
-         let br = projectObj.project.Ration.getBillsSortRation();
 
-         for(let i = mainRation.data.serialNo;i<br.length;i++){
 
-             if(rations.update.length > 0){//如果update列表中有数据,要更新那里的序列号
 
-                let u =  _.find(rations.update,{'ID':br[i].ID});
 
-                if(u){
 
-                    u.serialNo += 1;
 
-                    continue;
 
-                }
 
-             }
 
-             rations.update.push({ID:br[i].ID,projectID:br[i].projectID,serialNo:br[i].serialNo+1})
 
-         }
 
-     },
 
-     createNewRationInMeasure:function (data,mainRation,quantity,rations,bills) {
 
-         let controller = projectObj.mainController;
 
-         let billsID="";
 
-         if(!_.isEmpty(data.billID)&&projectObj.project.mainTree.getNodeByID(data.billID)){
 
-             billsID = data.billID;
 
-         }else {//剩下的就是没找到的
 
-             let rootNode = projectObj.project.Bills.getMeasureNode(controller);
 
-             let leaveNodes = projectObj.mainController.tree.getLeavesNodes(rootNode.source);
 
-             for(let n of leaveNodes){
 
-                 if (!(n.data.calcBase&&n.data.calcBase!="")&& n.data.code&&(n.data.code ==data.billsLocation||n.data.code.indexOf(data.billsLocation) != -1)){//没有使用基数计算的清单
 
-                     billsID = n.data.ID;
 
-                     break;
 
-                 }
 
-             }
 
-             if(billsID == ""){//还是没有找到的情况下,先查找是不是已经生成过了
 
-                 if(bills.create.length > 0){
 
-                     let t_b = _.find(bills.create,{"billsLocation":data.billsLocation});
 
-                     if(t_b) billsID = t_b.ID;
 
-                 }
 
-             }
 
-             if(billsID == ""){//也没有生成过的情况下,要自动生成清单
 
-                 //2018-12-19  对于新生成的清单,根据新清单编码的前6位去查询有没有完全匹配的清单,有的话将这一节点做为新清单的父项清单
 
-                 let subNodes=[];
 
-                 //默认没有找到编码匹配的就挂在技术措施项目下
 
-                 let parentNode = projectObj.project.Bills.getAutoParentNode("措施费用");
 
-                 if(data.billsLocation.length >= 6){
 
-                     projectObj.mainController.tree.getAllSubNode(rootNode,subNodes);
 
-                     let tem_code = data.billsLocation.substr(0,6);
 
-                     let n_parentNode = _.find(subNodes,function (n) {
 
-                         return n.data.code == tem_code;
 
-                     });
 
-                     if(n_parentNode) parentNode = n_parentNode;
 
-                 }
 
-                 billsID = uuid.v1();
 
-                 let newBill = {
 
-                     ID:billsID,
 
-                     projectID: parseInt(projectObj.project.ID()),
 
-                     ParentID:parentNode.data.ID,
 
-                     NextSiblingID:-1,
 
-                     code:projectObj.project.Bills.newFormatCode(data.billsLocation),
 
-                     type:billType.BILL,
 
-                     billsLibId:projectObj.project.projectInfo.engineeringInfo.bill_lib[0].id,//projectObj.project.projectInfo.engineeringInfo.billsGuidance_lib
 
-                     billsLocation : data.billsLocation//这个是用来在后端查找清单信息
 
-                 };
 
-                 let existB = projectObj.project.Bills.sameStdCodeBillsData(data.billsLocation);//对于多单位的清单
 
-                 if (existB) {
 
-                     newBill.unit = existB.unit;
 
-                 }
 
-                 //将这个节点的上一节点的NextSiblingID设置为这个新清单
 
-                 //先看有没有刚生成的清单,有的话直接修改最后一个清单的NextSiblingID即可
 
-                 let lastIndex = this.getLastIndex(bills.create,"ParentID",parentNode.data.ID);
 
-                 if(bills.create.length > 0 && lastIndex!=-1){
 
-                     bills.create[lastIndex].NextSiblingID = newBill.ID;
 
-                 }else if(parentNode.children.length > 0){//如果新生的没有找到的话,查看父节点下是否有子节点
 
-                     let pre = parentNode.children[parentNode.children.length-1];
 
-                     bills.update.push({ projectID:newBill.projectID,ID:pre.data.ID, NextSiblingID:newBill.ID});
 
-                 }
 
-                 bills.create.push(newBill);
 
-             }
 
-         }
 
-         //生成定额
 
-         let newID =  uuid.v1();
 
-         let serialNo = 1;
 
-         serialNo =  this.checkAndGetSerialNo(serialNo,billsID,rations);
 
-         //先查看刚生成的定额中有没有相同父清单,有的话取最后的一个序列号加1
 
-         let n_ration = this.createNewRationData(data,newID,mainRation.data.ID,billsID,serialNo,quantity,mainRation.data.libID,false,mainRation.data.manageFeeRate);
 
-         rations.create.push(n_ration);
 
-     },
 
-     createNewRationInFBFX:function (data,mainRation,quantity,rations,bills) {
 
-         let billsID = "";
 
-         let parentNode = projectObj.project.mainTree.getNodeByID(data.fxID);
 
-         //分部分项这里,如果没选择位置,或者选择后又删除了,是无法到这一步的,所以不用像生成在清单那里做很多检查
 
-         if(!_.isEmpty(data.fxID)&&parentNode){
 
-             billsID = data.fxID;
 
-         }
 
-         if(billsID !=""){
 
-             //生成定额
 
-             let newID =  uuid.v1();
 
-             let serialNo = 1;
 
-              serialNo =  this.checkAndGetSerialNo(serialNo,billsID,rations);
 
-             let n_ration = this.createNewRationData(data,newID,mainRation.data.ID,billsID,serialNo,quantity,mainRation.data.libID,true,mainRation.data.manageFeeRate);
 
-             rations.create.push(n_ration);
 
-         }
 
-     },
 
-     getLastIndex:function (arrays,key,value) {
 
-         let index = -1;
 
-         for (let i = 0;i<arrays.length;i++) {
 
-             if(arrays[i][key] == value){
 
-                 index = i;
 
-             }
 
-         }
 
-         return index;
 
-     },
 
-     checkAndGetSerialNo:function (sNo,billsID,rations) {
 
-         let serialNo = sNo;
 
-         //先查看刚生成的定额中有没有相同父清单,有的话取最后的一个序列号加1
 
-         let last_ration = this.getLastBrotherNewRation(billsID,rations.create);
 
-         if(last_ration){
 
-             serialNo = last_ration.serialNo +1;
 
-         }else {
 
-             let parentBillsNode = projectObj.project.mainTree.getNodeByID(billsID);
 
-             if(parentBillsNode && parentBillsNode.children.length > 0){//如果能找到则说明已经存在的清单
 
-                 serialNo = parentBillsNode.children[parentBillsNode.children.length - 1].data.serialNo + 1
 
-             }
 
-         }
 
-         return serialNo
 
-     },
 
-     getLastBrotherNewRation:function(billsItemID,rations){
 
-         let newData = null;
 
-         for(let tem of rations){
 
-             if(tem.newData.billsItemID == billsItemID)  newData = tem.newData;
 
-         }
 
-         return newData;
 
-     },
 
-     createNewRationData:function (data,newID,referenceRationID,billsID,serialNo,quantity,libID,isFBFX,manageFeeRate) {
 
-         let newData = projectObj.project.Ration.getTempRationData(newID,billsID,serialNo,rationType.ration);
 
-         newData.referenceRationID = referenceRationID;
 
-         newData.quantity = quantity;
 
-         newData.quantityEXP = gljUtil.isDef(data.coe) && data.coe != "0"?"MBGCL":quantity+"";
 
-         //这里还要生成根据清单生成含量,父清单如果是刚自动生成的,其工程量为0,含量也为0
 
-         newData.contain = projectObj.project.Ration.getContain(projectObj.project.mainTree.findNode(billsID),quantity);
 
-         newData.manageFeeRate = manageFeeRate;
 
-         let temRation = this.getDefaultRationCreateData(newData,data.code,libID,isFBFX);
 
-         return temRation;
 
-     },
 
-     getDefaultRationCreateData:function(newData,code,libID,isFBFX){
 
-         let itemQuery = {userID: userID, rationRepId: libID, code: code};
 
-         let needInstall = false;
 
-         if(projectObj.project.isInstall()) {//如果是安装工程,要看需不需要生成安装增加费
 
-             needInstall = isFBFX;//在分部分项插入的定额才需要定额安装增加费
 
-         }
 
-         return{itemQuery:itemQuery,newData:newData,defaultLibID: rationLibObj.getDefaultStdRationLibID(),calQuantity:false,brUpdate:[],needInstall:needInstall}
 
-     },
 
- /*    getQuantity:function (data) {//取最新的消耗量,需经过转换
 
-         if(data.unit){
 
-             let times = parseInt(data.unit);
 
-             if(!isNaN(times)){
 
-                 return scMathUtil.roundForObj(parseFloat(data.quantity)/times,getDecimal("ration.quantity"))+""
 
-             }
 
-         }
 
-         return data.quantity
 
-     },*/
 
-     transferToRationQuantity:function (unit,quantity) {
 
-         if(unit){
 
-             let times = parseInt(unit);
 
-             if(!isNaN(times)){
 
-                 return scMathUtil.roundForObj(parseFloat(quantity)/times,getDecimal("ration.quantity"))+""
 
-             }
 
-         }
 
-         return quantity;
 
-     },
 
-     getExistRation:function (data,referenceRationID,type,updateRations) {
 
-         let temRation = null;
 
-         //先检查要更新的定额是否已经存在
 
-         let rations =_.filter(projectObj.project.Ration.datas,{'referenceRationID':referenceRationID,'code':data.code});
 
-         for(let r of rations){
 
-             if(type == mbzm_obj.locateMap.AFTERRATION){//如果是生成在主定额后面的位置
 
-                 let mainRationNode = projectObj.project.mainTree.getNodeByID(referenceRationID);
 
-                 if(r.billsItemID == mainRationNode.data.billsItemID){//如果清单ID相同, 说明是兄弟节点,位置相同
 
-                     temRation = r;
 
-                     break;
 
-                 }
 
-             }
 
-             let billsNode = projectObj.project.mainTree.getNodeByID(r.billsItemID);
 
-             if(billsNode){//将父清单与要生成的清单比较,看是否一致
 
-                 if(type == mbzm_obj.locateMap.INMEASURE && billsNode.data.type ==billType.BILL){
 
-                     if(!_.isEmpty(data.billID)){
 
-                         //说明生成位置已经有定额了,只需更新消耗量就好
 
-                         if(data.billID == r.billsItemID){
 
-                             temRation = r;
 
-                             break;
 
-                         }
 
-                     }else if(!_.isEmpty(data.billsLocation)){//按清单编号到找对应的位置
 
-                         if(billsNode.data.code && billsNode.data.code.indexOf(data.billsLocation)!=-1) {
 
-                             temRation = r;
 
-                             break;
 
-                         }
 
-                     }
 
-                 }else if(type == mbzm_obj.locateMap.INFBFX && (billsNode.data.type ==billType.FX||billsNode.data.type ==billType.BX)){
 
-                     if(!_.isEmpty(data.fxID) && data.fxID == r.billsItemID){//分项、补项下有对应的定额
 
-                         temRation = r;
 
-                         break;
 
-                     }
 
-                 }
 
-             }
 
-             //如果没有执行到break,则说明这条定额是要被删除的
 
-             updateRations.delete.push({projectID:r.projectID,ID:r.ID});
 
-         }
 
-         return temRation;
 
-     },
 
-     hasReferenceRation:function (node) {
 
-         if(node.sourceType == ModuleNames.ration){
 
-             let  template = projectObj.project.ration_template.getTemplateByRationID(node.data.ID);
 
-             if(template){
 
-                 let ration = _.find(projectObj.project.Ration.datas,{'referenceRationID':node.data.ID});
 
-                 if(ration) return true;
 
-             }
 
-         }
 
-         return false;
 
-     },
 
-     deleteReferenceRation:function (mainNodes,updateNodes) {
 
-         let refNode = [];
 
-         for(let m of mainNodes){
 
-             if(this.hasReferenceRation(m)){
 
-                 let  rations = _.filter(projectObj.project.Ration.datas,{'referenceRationID':m.data.ID});
 
-                 for(let r of rations){
 
-                     let temNode =  projectObj.project.mainTree.getNodeByID(r.ID);
 
-                     if(temNode && updateNodes.indexOf(temNode) == -1){//能找到该节点,并且节点不在已经删除的列表中
 
-                         refNode.push(temNode);
 
-                         updateNodes.push(temNode);
 
-                         projectObj.mainController.tree.getAllSubNode(temNode,updateNodes)//添加显示到造价书页面的主材、设备节点
 
-                     }
 
-                 }
 
-             }
 
-         }
 
-         return refNode;
 
-     },
 
-     updateReferenceRationNodeQuantity:function (node) {
 
-         let rationNodes = [],codeMap={};
 
-         let  template = projectObj.project.ration_template.getTemplateByRationID(node.data.ID);
 
-         if(template) {
 
-             for(let t of template.templateList){
 
-                 if(t.coe && t.coe!="0"){
 
-                     codeMap[t.code] = t;
 
-                 }
 
-             }
 
-             let times = parseInt(node.data.unit);
 
-             times = isNaN(times)?1:times;//工程量要乘以定额单位的倍数
 
-             let referenceRations = this.findReferenceRation(node.data.ID);
 
-             for(let r of  referenceRations ){
 
-                 let t_tem = codeMap[r.code];
 
-                 if(t_tem){
 
-                     let rationQuantity = node.data.quantity?scMathUtil.roundForObj(node.data.quantity, getDecimal('ration.quantity')):0;
 
-                     let t_quantity = scMathUtil.roundForObj(rationQuantity * parseFloat(t_tem.coe)*times, getDecimal('ration.quantity')); //这个也要同步更新
 
-                     let rnode =  projectObj.project.mainTree.findNode(r.ID);
 
-                     if(rnode && r.quantityEXP == "MBGCL"){//表达式是模板工程量的才要同步更新
 
-                         let t_times = parseInt(rnode.data.unit);
 
-                         t_times = isNaN(t_times)?1:t_times;//工程量要乘以定额单位的倍数
 
-                         rnode.data.quantity = scMathUtil.roundForObj(t_quantity/t_times,getDecimal('ration.quantity'));
 
-                         rnode.data.contain = projectObj.project.Ration.getContain(rnode.parent,rnode.data.quantity);
 
-                         rnode.change = true;
 
-                         rationNodes.push(rnode)
 
-                     }
 
-                 }
 
-             }
 
-         }
 
-         return rationNodes;
 
-     },
 
-     findReferenceRation:function(rationID){
 
-         return _.filter(projectObj.project.Ration.datas,{'referenceRationID':rationID})
 
-     }
 
- };
 
- $('#createLocation').change(function(){
 
-     let me = mbzm_obj;
 
-     let pcol = _.findIndex(me.setting.header,{dataCode:"position"});
 
-     me.setting.header[pcol].visible =  $(this).val() == mbzm_obj.locateMap.AFTERRATION?false:true;
 
-     me.refreshSheetData();
 
- });
 
- $('#next_mbzm').click(function () {
 
-     if (projectReadOnly) {
 
-         return;
 
-     }
 
-     let mainSheet = projectObj.mainSpread.getActiveSheet();
 
-     let selection = mainSheet.getSelections()[0];
 
-     let node =  projectObj.project.mainTree.selected;
 
-     let index = node.serialNo();
 
-     let next = null;
 
-     for(let i = index+1;i< projectObj.project.mainTree.items.length;i++){
 
-         let temNode =  projectObj.project.mainTree.items[i];
 
-         if(temNode && temNode.sourceType == ModuleNames.ration){
 
-             let  template = projectObj.project.ration_template.getTemplateByRationID(temNode.data.ID);
 
-             if(template) {
 
-                 next = temNode;
 
-                 break;
 
-             }
 
-         }
 
-     }
 
-     if(next){
 
-         let row = next.serialNo();
 
-         let col = selection.col?selection.col:0;
 
-         mainSheet.setSelection(row, col, selection.rowCount, selection.colCount);
 
-         projectObj.mainController.setTreeSelected(next);
 
-         mainSheet.showRow(row, GC.Spread.Sheets.VerticalPosition.center);
 
-     }
 
- });
 
- $('#apply_mbzm').click(function () {
 
-     if(projectReadOnly) return;
 
-     mbzm_obj.applyTemplate();
 
- });
 
 
  |