divide_view.js 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706
  1. let divideObj = {
  2. divideSetting:{//“类别”、“清单编号”、“名称”、“单位”、“工程量”、“单价”、“金额”、“预算价”、“取费类别”。
  3. header: [
  4. {headerName: "类别", headerWidth: 60, dataCode: "itemType", hAlign:'center', dataType: "String"},
  5. {headerName: "清单编号", headerWidth: 130, dataCode: "code", hAlign:'left', dataType: "String", formatter: "@"},
  6. {headerName: "名称", headerWidth: 160, dataCode: "name", dataType: "String",formatter: "@"},
  7. {headerName: "单位", headerWidth: 100, dataCode: "unit", dataType: "String",cellType:'comboBox',editable:true,options:['m', 'm2', 'm3', 'km', 't', 'kg', '台班', '工日', '昼夜', '元', '项', '处', '个', '件',
  8. '根', '组', '系统', '台', '套', '株', '丛', '缸', '支', '只', '块', '座', '对', '份', '樘', '攒', '榀']},
  9. {headerName: "工程量", headerWidth: 80, dataCode: "quantity", dataType: "Number",validator:"number",getText:"notZero"},
  10. {headerName: "单价", headerWidth: 100, dataCode: "unitPrice", dataType: "Number",validator:"number",getText:"notZero"},
  11. {headerName: "金额", headerWidth: 100, dataCode: "totalPrice", dataType: "Number",validator:"number",getText:"notZero"},
  12. {headerName: "预算价", headerWidth: 100, dataCode: "marketPrice", dataType: "Number",validator:"number",getText:"notZero"},
  13. {headerName: "取费类别", headerWidth: 60, dataCode: "programID", hAlign:'center', dataType: "String",cellType:'comboBox',editorValueType:true}
  14. ],
  15. view:{
  16. lockColumns: [0],
  17. colHeaderHeight:30
  18. },
  19. getText:{
  20. notZero:function (item,value) {
  21. return value == 0?"":value;
  22. }
  23. },
  24. treeCol:1
  25. },
  26. billsSetting:{
  27. header: [//“编号”、“名称”、“分摊比例”、“分摊金额”、“原始金额”、“合计”、“金额”。
  28. {headerName: "编号", headerWidth: 130, dataCode: "code", hAlign:'left', dataType: "String"},
  29. {headerName: "名称", headerWidth: 160, dataCode: "name", dataType: "String"},
  30. {headerName: "分摊比例", headerWidth: 80, dataCode: "divideRate", dataType: "Number",validator:"number"},
  31. {headerName: "分摊金额", headerWidth: 100, dataCode: "dividePrice", dataType: "Number",validator:"number"},
  32. {headerName: "原始金额", headerWidth: 100, dataCode: "originalPrice", dataType: "Number",validator:"number"},
  33. {headerName: "合计", headerWidth: 100, dataCode: "totalPrice", dataType: "Number",validator:"number"},
  34. {headerName: "金额", headerWidth: 60, dataCode: "price", dataType: "Number",validator:"number"}
  35. ],
  36. view:{
  37. lockColumns: [0,1,2,3,4,5,6],
  38. colHeaderHeight:30
  39. }
  40. },
  41. divideSpread:null,
  42. billsSpread:null,
  43. divideSubSpread:null,
  44. showDivideGljSubTab:false,
  45. initSpread:function(){
  46. this.initDivideSpread();
  47. this.initBillsSpread();
  48. this.initDivideSubSpread();
  49. if(!projectReadOnly){
  50. this.initDivideRightClick();
  51. }else {
  52. disableSpread(this.divideSpread);
  53. disableSpread(this.billsSpread);
  54. }
  55. },
  56. showDatas:function(){
  57. this.showDivideDatas();
  58. this.showBillsDatas();
  59. this.showRationGLJDatas();
  60. },
  61. refreshViews:function(){
  62. if(!$('#divide_main').is(':visible')) return;
  63. if(this.divideSpread) this.divideSpread.refresh();
  64. if(this.billsSpread) this.billsSpread.refresh();
  65. if(this.divideSubSpread) this.divideSubSpread.refresh();
  66. },
  67. showDivideDatas:function(){
  68. if(!$('#divide_main_sheet').is(':visible')) return;
  69. this.divideDatas = getDivideDatas();
  70. this.divideSheet.setRowCount(this.divideDatas.length);
  71. let fheader= _.find(this.divideSetting.header,{'dataCode': "programID"})
  72. fheader.options = this.getProgramOptions();
  73. sheetCommonObj.showTreeData(this.divideSheet, this.divideSetting,this.divideDatas);
  74. function getDivideDatas(){
  75. let datas = [];
  76. let divideSetting = projectObj.project.divide_setting.datas
  77. let parentMap={};
  78. //divideSetting.divideList = [{ID:"1",code:"1",ParentID:-1,collapsed:false},{ID:"2",code:"2",ParentID:"1",collapsed:false}]
  79. divideSetting.divideList = _.sortByAll(divideSetting.divideList,['seq'])
  80. for(let d of divideSetting.divideList){
  81. parentMap[d.ParentID]?parentMap[d.ParentID].push(d):parentMap[d.ParentID]=[d]
  82. }
  83. if(parentMap[-1]&&parentMap[-1].length>0){
  84. for(let r of parentMap[-1]){
  85. r.collapsed = false;
  86. datas.push(r)
  87. if(parentMap[r.ID] && parentMap[r.ID].length > 0){
  88. for(let c of parentMap[r.ID]){
  89. datas.push(c);
  90. }
  91. }
  92. }
  93. }
  94. return datas;
  95. }
  96. },
  97. showRationGLJDatas:function(){
  98. if(!$('#divide_glj_nav').hasClass('active')) return;
  99. this.divideSubSpread.setActiveSheetIndex(0);
  100. this.rationGLJDatas = this.getRationGLJDatas();
  101. let rationGLJSheet = this.divideSubSpread.getSheet(0)
  102. rationGLJSheet.setRowCount(this.rationGLJDatas.length);
  103. sheetCommonObj.showTreeData(rationGLJSheet, gljCol.ration_glj_setting,this.rationGLJDatas);
  104. },
  105. getRationGLJDatas : function (){
  106. let datas = [];
  107. let selected = divideObj.getSelectedItem();
  108. let divideSetting = projectObj.project.divide_setting.datas;
  109. if(selected && selected.itemType=="定额"){
  110. for(r of divideSetting.ration_gljs){
  111. if(r.rationID == selected.ID){
  112. let newr = Object.assign(r);
  113. newr.ParentID = -1;
  114. datas.push(newr);
  115. }
  116. }
  117. gljOprObj.combineWithProjectGlj(datas);
  118. }
  119. return datas;
  120. },
  121. getProgramOptions:function(){
  122. let names = projectObj.project.calcProgram.compiledTemplateNames;
  123. let map = projectObj.project.calcProgram.compiledTemplateMaps;
  124. let options = [];
  125. for(let n of names){
  126. options.push({text:n,value:map[n]});
  127. }
  128. return options;
  129. },
  130. divideEditChecking:function(row,col){//return false表示不能编辑
  131. let me = this;
  132. let data = me.divideDatas[row],setting = me.divideSetting;
  133. let dataCode = setting.header[col].dataCode;
  134. if(data){
  135. if(data.itemType == "分摊项"){
  136. //金额,预算价,取费类别不可编辑
  137. if(dataCode =="totalPrice" || dataCode =="marketPrice" || dataCode =="programID" ) return false;
  138. //有子项时,单价不可编辑
  139. if(dataCode =="unitPrice"&& _.find(me.divideDatas,{ParentID:data.ID})) return false;
  140. }
  141. if( data.itemType == "量价" && dataCode =="totalPrice") return false//量价:“金额”不可编辑。
  142. if(data.itemType == "定额"){ //定额:“单位”、“单价”、“金额”、“预算价”
  143. return !(dataCode == "unit"||dataCode == "unitPrice"||dataCode == "totalPrice"||dataCode == "marketPrice")
  144. }
  145. return true
  146. }
  147. return false;
  148. },
  149. showBillsDatas:function(){
  150. if(!$('#divide_bills_sheet').is(':visible')) return;
  151. this.billsDatas = getBillsDatas();
  152. sheetCommonObj.showData(this.billsSheet, this.billsSetting,this.billsDatas);
  153. this.billsSheet.setRowCount(this.billsDatas.length);
  154. function getBillsDatas(){
  155. return [];
  156. }
  157. },
  158. getSelectedItem:function(){
  159. let me = this,data=null;
  160. let sel = me.divideSheet.getSelections()[0];
  161. let srow = sel.row == -1||sel.row == ""?0:sel.row;
  162. if(me.divideDatas.length>srow){
  163. data = me.divideDatas[srow];
  164. }
  165. return data;
  166. },
  167. addNewItems:async function(itemType,type){
  168. let newItem = {
  169. ID:uuid.v1(),
  170. itemType:itemType,
  171. ParentID:-1
  172. };
  173. if(type) newItem.subType = type;
  174. let selected = this.getSelectedItem();
  175. if(itemType!="分摊项"){//当插入定额或者量价时:
  176. newItem.ParentID = selected.itemType == "分摊项"?selected.ID:selected.ParentID;
  177. }
  178. if(itemType == "定额") newItem.type = rationType.ration;
  179. if(itemType == "量价"){
  180. newItem['programID'] = projectObj.project.calcProgram.compiledTemplateMaps["费率为0"];
  181. newItem.type = rationType.volumePrice;
  182. }
  183. let [seq,datas] = this.getNewSeqs(selected,newItem);
  184. newItem.seq = seq;
  185. datas.push({type:"add",doc:newItem});
  186. await this.updateItem(datas);
  187. },
  188. deleteItem:async function(){
  189. let selected = this.getSelectedItem();
  190. let subItems = [];
  191. if(selected.itemType == "分摊项"){
  192. //检查是否执行了分摊,如果已经执行了,要取消分摊才能删除
  193. // todo
  194. for(let s of this.divideDatas){
  195. if(s.ParentID == selected.ID) subItems.push({type:"delete",ID:s.ID});
  196. }
  197. }
  198. subItems.push({type:"delete",ID:selected.ID,itemType:selected.itemType});
  199. await this.updateItem(subItems);
  200. },
  201. getNewSeqs:function(selected,newItem){
  202. let seq = 1,datas=[],refreshSeq = false;
  203. for(let d of this.divideDatas){
  204. if(d.ParentID == newItem.ParentID){
  205. if(refreshSeq == true){
  206. if(d.seq == seq || d.seq > seq) datas.push({ID:d.ID,type:'update',doc:{seq:d.seq+1}})
  207. }
  208. if(selected && d.ID == selected.ID){
  209. seq = d.seq + 1;
  210. refreshSeq = true;
  211. }
  212. }
  213. }
  214. return [seq,datas]
  215. },
  216. updateItem: async function(datas){
  217. let divideSetting = projectObj.project.divide_setting.datas
  218. try {
  219. $.bootstrapLoading.start();
  220. let result = ajaxPost("/divide/updateItem",{ID:divideSetting.ID,updateDatas:datas})
  221. this.refreshDivideCaches(datas);
  222. } catch (error) {
  223. console.log(error)
  224. }
  225. $.bootstrapLoading.end();
  226. this.showDatas();
  227. },
  228. refreshDivideCaches:function(datas){
  229. let divideSetting = projectObj.project.divide_setting.datas
  230. for(let d of datas){
  231. if(d.type == "add"){
  232. divideSetting.divideList.push(d.doc);
  233. }
  234. if(d.type == "delete"){
  235. _.remove(divideSetting.divideList,{'ID':d.ID});
  236. if(d.itemType =="定额"){
  237. _.remove(divideSetting.ration_gljs,{'rationID':d.ID});
  238. _.remove(divideSetting.ration_coes,{'rationID':d.ID});
  239. }
  240. }
  241. if(d.type == "update"){
  242. let item = _.find(divideSetting.divideList,{'ID':d.ID});
  243. if(item) gljUtil.updateProperty(item,d.doc);
  244. }
  245. }
  246. },
  247. addDivideRation:async function(rationRepId,code){
  248. let selected = this.getSelectedItem();
  249. if(!selected) return;
  250. let divideSetting = projectObj.project.divide_setting.datas
  251. let pEngineer = projectObj.project.projectInfo.property.projectEngineering;
  252. let libIDs = [rationRepId];
  253. let defaultLibID = rationLibObj.getDefaultStdRationLibID();
  254. let data = {userID:userID,defaultLibID:defaultLibID, rationRepIds: libIDs, code: code,quantityDecimal:getDecimal("ration.quantity"),projectID:projectObj.project.ID()};
  255. data.ParentID = selected.itemType == "分摊项"?selected.ID:selected.ParentID;
  256. let [seq,datas] = this.getNewSeqs(selected,data);
  257. data.type="add";
  258. data.seq = seq;
  259. data.divideID = divideSetting.ID;
  260. if(pEngineer) data.programID = pEngineer;
  261. data.divideDatas = datas;
  262. let sel = this.divideSheet.getSelections()[0];
  263. this.divideSheet.setSelection(sel.row+1,sel.col,sel.rowCount,sel.colCount);
  264. await this.updateDivideRation(data);
  265. },
  266. updateDivideRation:async function(data){
  267. let divideSetting = projectObj.project.divide_setting.datas
  268. try {
  269. $.bootstrapLoading.start();
  270. let result = await ajaxPost("/ration/updateDivideRation",data)
  271. if(data.type=="add"){
  272. data.divideDatas.push({type:"add",doc:result.ration});
  273. this.refreshDivideCaches(data.divideDatas);
  274. if(result.projectGLJList) projectObj.project.projectGLJ.loadNewProjectGLJToCaches(result.projectGLJList,true);
  275. if(result.ration_gljs) divideSetting.ration_gljs = divideSetting.ration_gljs.concat(result.ration_gljs);
  276. if(result.ration_coes) divideSetting.ration_coes = divideSetting.ration_coes.concat(result.ration_coes);
  277. }
  278. } catch (error) {
  279. console.log(error)
  280. }
  281. $.bootstrapLoading.end();
  282. this.showDatas();
  283. },
  284. initDivideSpread:function(){
  285. if(this.divideSpread) return;
  286. this.divideSpread = SheetDataHelper.createNewSpread($("#divide_main_sheet")[0]);
  287. sheetCommonObj.spreadDefaultStyle(this.divideSpread);
  288. this.divideSheet = this.divideSpread.getSheet(0);
  289. sheetCommonObj.initSheet(this.divideSheet, this.divideSetting, 2);
  290. this.divideSheet.bind(GC.Spread.Sheets.Events.EditStarting,this.onDivideEditStarting);
  291. this.divideSheet.bind(GC.Spread.Sheets.Events.ValueChanged,this.onDivideValueChange)
  292. this.divideSheet.bind(GC.Spread.Sheets.Events.SelectionChanged,this.onDivideSelectionChange);
  293. /* ;
  294. this.divideSheet.bind(GC.Spread.Sheets.Events.RangeChanged, this.onCoeRangeChanged); */
  295. SheetDataHelper.protectdSheet(this.divideSheet);
  296. },
  297. onDivideEditStarting:function (sender, args) {
  298. let me = divideObj;
  299. let row = args.row;
  300. let col = args.col;
  301. if(me.divideEditChecking(row,col)==false){
  302. args.cancel = true;
  303. }
  304. },
  305. onDivideValueChange:async function(sender,info){
  306. let me = divideObj,row = info.row, col = info.col;
  307. let setting = me.divideSetting;
  308. let dataCode = setting.header[col].dataCode;
  309. let recode = me.divideDatas[row];
  310. let value = info.newValue;
  311. if(info.newValue === undefined ){
  312. return;
  313. }
  314. if(value && !sheetCommonObj.checkData(col,setting,value)) {
  315. alert('输入的数据类型不对,请重新输入!');
  316. return me.showDatas();
  317. }
  318. await me.updateItem([me.getDivideUpdateData(recode,dataCode,value)]);
  319. },
  320. onDivideSelectionChange:function(sender,args){
  321. let me = divideObj;
  322. let newSel = args.newSelections[0];
  323. let oldSel = args.oldSelections?args.oldSelections[0]:{};
  324. if(newSel.row != oldSel.row){
  325. me.initNavItem();
  326. me.showRationGLJDatas();
  327. }
  328. args.sheet.repaint();
  329. },
  330. getDivideUpdateData:function(recode,dataCode,value){
  331. let doc = {};
  332. if(recode.itemType == "分摊项"){
  333. if(dataCode == "quantity"){
  334. value = scMathUtil.roundForObj(value,3);
  335. let tu = scMathUtil.roundForObj(recode.unitPrice&&recode.unitPrice!=""?recode.unitPrice:0,getDecimal("bills.unitPrice"))
  336. doc["totalPrice"] = scMathUtil.roundForObj(value * tu,getDecimal("bills.totalPrice"))
  337. }
  338. if(dataCode == "unitPrice"){
  339. value = scMathUtil.roundForObj(value,getDecimal("bills.unitPrice"));
  340. let tq = scMathUtil.roundForObj(recode.quantity && recode.quantity!=""?recode.quantity:0,3)
  341. doc["totalPrice"] = scMathUtil.roundForObj(value * tq,getDecimal("bills.totalPrice"))
  342. }
  343. }
  344. doc[dataCode]=value;
  345. return {ID:recode.ID,type:'update',doc:doc}
  346. },
  347. initBillsSpread:function(){
  348. if(this.billsSpread) return;
  349. this.billsSpread = SheetDataHelper.createNewSpread($("#divide_bills_sheet")[0]);
  350. sheetCommonObj.spreadDefaultStyle(this.billsSpread);
  351. this.billsSheet = this.billsSpread.getSheet(0);
  352. sheetCommonObj.initSheet(this.billsSheet, this.billsSetting, 0);
  353. SheetDataHelper.protectdSheet(this.divideSheet);
  354. },
  355. initDivideSubSpread:function(){
  356. if(this.divideSubSpread) return;
  357. this.divideSubSpread = SheetDataHelper.createNewSpread($("#divide_subSpread")[0],2);
  358. sheetCommonObj.spreadDefaultStyle(this.divideSubSpread);
  359. this.divideSubSheet = this.divideSubSpread.getSheet(0);
  360. sheetCommonObj.initSheet(this.divideSubSheet, gljCol.ration_glj_setting, 0);
  361. SheetDataHelper.protectdSheet(this.divideSubSheet);
  362. },
  363. initNavItem(){
  364. let selected = this.getSelectedItem();
  365. if(selected.itemType == "分摊项"){
  366. $("#divide_itemTextDiv").hide();
  367. $(`#divide_subSpread`).css('width', "100%");
  368. }else{
  369. $("#divide_itemTextDiv").show();
  370. if(this.showDivideGljSubTab == true){
  371. $("#divide_gljSubDiv").show();
  372. $("#divide_rgResize").show();
  373. } else {
  374. $("#divide_gljSubDiv").hide();
  375. $("#divide_rgResize").hide();
  376. }
  377. this.initItemWidth();
  378. }
  379. this.divideSubSpread.refresh();
  380. },
  381. initItemWidth:function (){
  382. //总宽度
  383. let totalWidth = $('#divide_subItems').width();
  384. //人材机和项目特征文本比例
  385. const openWidth = 30;//打开项目特征工具条
  386. const tab_tem = (305+openWidth+10)/totalWidth;//tab显示框默认宽度:305(表格宽度) + 30(工具条宽度)+10(resize div 宽度)
  387. let //默认比例
  388. textPercent = tab_tem * 100 + '%',//'15%',
  389. rcjPercent = (1 - tab_tem)* 100 + '%';//85
  390. //文本没显示,则打开工具条固定30px转换百分比
  391. if (!this.showDivideGljSubTab) {
  392. textPercent = openWidth / totalWidth;
  393. rcjPercent = 1 - textPercent;
  394. textPercent = textPercent * 100 + '%';
  395. rcjPercent = rcjPercent * 100 + '%';
  396. }
  397. //设置特征及内容与排版规则的比例
  398. $('#divide_subSpread').css('width', rcjPercent);
  399. $('#divide_itemTextDiv').css('width', textPercent);
  400. //打开了项目特征,则继续加载人材机表和项目特征文本具体比例
  401. if (divideObj.showDivideGljSubTab === true) {
  402. let rg_sideResizeEles = this.getSubSideResize();
  403. SlideResize.loadHorizonWidth(rg_sideResizeEles.eleObj.module,
  404. [rg_sideResizeEles.eleObj.resize], [rg_sideResizeEles.eleObj.left, rg_sideResizeEles.eleObj.right]);
  405. $("#divide_gljSubDiv").width( $('#divide_itemTextDiv').width() - rg_sideResizeEles.eleObj.resize.width() - 30)
  406. }
  407. },
  408. initDivideGljSubTab:function(){
  409. if(this.showDivideGljSubTab == true){
  410. $("#divide_gljSubDiv").show();
  411. $("#divide_rgResize").show();
  412. } else {
  413. $("#divide_gljSubDiv").hide();
  414. $("#divide_rgResize").hide();
  415. }
  416. this.initItemWidth();
  417. },
  418. getSubSideResize: function () {
  419. let rg_sideResizeEles = {};
  420. rg_sideResizeEles.eleObj = {
  421. module: this.moduleName,
  422. resize: $('#divide_rgResize'),
  423. parent: $('#divide_subItems'),
  424. left: $('#divide_subSpread'),
  425. right: $('#divide_itemTextDiv')
  426. };
  427. rg_sideResizeEles.limit = {
  428. min: 100,
  429. max: `$('#divide_subItems').width()-100`
  430. };
  431. return rg_sideResizeEles;
  432. },
  433. initDivideRightClick:function(){
  434. //如果当前行是无组成物的“普通材料”、“绿化苗木”、“外购砼构件”、“商品混凝土”、“商品砂浆”,则右键“添加计算材料”按钮有效。
  435. let me = this;
  436. $.contextMenu({
  437. selector: '#divide_main_sheet',
  438. build: function ($trigger, e) {
  439. me.rightClickTarget = SheetDataHelper.safeRightClickSelection($trigger, e, me.divideSpread);
  440. return me.rightClickTarget.hitTestType === GC.Spread.Sheets.SheetArea.viewport ||
  441. me.rightClickTarget.hitTestType === GC.Spread.Sheets.SheetArea.rowHeader;
  442. },
  443. items: {
  444. "insertItem": {
  445. name: "插入分摊项",
  446. icon: 'fa-sign-in',
  447. disabled: function () {
  448. let selected = me.getSelectedItem();
  449. if(selected && selected.itemType !="分摊项") return true;
  450. return false;
  451. },
  452. callback: function (key, opt) {
  453. me.addNewItems("分摊项");
  454. }
  455. },
  456. "insertRation": {
  457. name: "插入定额",
  458. icon: 'fa-sign-in',
  459. disabled: function () {
  460. return me.rightClickTarget.row === undefined
  461. },
  462. callback: function (key, opt) {
  463. me.addNewItems("定额");
  464. }
  465. },
  466. "insertVolumePrice": {
  467. name: "插入量价",
  468. icon: 'fa-sign-in',
  469. disabled: function () {
  470. return me.rightClickTarget.row === undefined;
  471. },
  472. items:{
  473. insertLabour:{
  474. name: "人工",
  475. icon: 'fa-sign-in',
  476. callback:function(key){
  477. me.addNewItems("量价",1);
  478. }
  479. },
  480. insertMaterial:{
  481. name:"材料" ,
  482. icon: 'fa-sign-in',
  483. callback:function(key){
  484. me.addNewItems("量价",201);
  485. }
  486. },
  487. insertMachine:{
  488. name:"机械" ,
  489. icon: 'fa-sign-in',
  490. callback:function(key){
  491. me.addNewItems("量价",301);
  492. }
  493. }
  494. }
  495. },
  496. "calcRation": {
  497. name: "计算定额/量价",
  498. icon: 'fa-sign-in',
  499. disabled: function () {
  500. return me.rightClickTarget.row === undefined
  501. },
  502. callback: function (key, opt) {
  503. let selected = me.getSelectedItem();
  504. projectObj.project.calcProgram.innerCalcForFTRation({data:selected,sourceType:"ration",updateData:[]});
  505. console.log(selected)
  506. }
  507. },
  508. "removeItem": {
  509. name: "删除",
  510. icon: 'fa-trash-o',
  511. disabled: function () {
  512. return me.rightClickTarget.row === undefined;;
  513. },
  514. callback: function (key, opt) {
  515. me.deleteItem();
  516. }
  517. }
  518. }
  519. });
  520. },
  521. getDivideResizeEles:function () {
  522. let divideResizeEles = {};
  523. divideResizeEles.eleObj = {
  524. module: 'divide',
  525. resize: $('#divide_rgResize'),
  526. top: $('#divide_top'),
  527. topSpread: $('#divide_main_sheet'),
  528. bottom: $('#divideBottom').children().find('.main-data-bottom'),
  529. bottomSpread: [$('#divide_subSpread')]
  530. };
  531. divideResizeEles.limit = {
  532. min: 150,
  533. max: `$(window).height()-$('.header').height()-$('#divideToolsBar').height()-150-5`,//5: resize.height()
  534. notTopSpread: 0,
  535. notBottomSpread: 0,
  536. bottomNav:`$('#divideBottom ul').height()`,
  537. totalHeight: `$(window).height()-$('.header').height()-$('#divideToolsBar').height()-5`
  538. };
  539. return divideResizeEles;
  540. }
  541. }
  542. function loadDivideHeight(){
  543. if(!$('#divide_main').is(':visible')) return;
  544. let me = divideObj;
  545. let divideResizeEles = me.getDivideResizeEles();
  546. SlideResize.loadVerticalHeight(divideResizeEles.eleObj.module, divideResizeEles.eleObj, divideResizeEles.limit, function () {
  547. me.refreshViews();
  548. zmhs_obj.refresh();
  549. });
  550. if($('#divide_de').is(':visible')) showDivideSide($($("#divide_stdRationTab").attr('relaPanel')), true, $("#divide_stdRationTab").attr('id'));
  551. }
  552. $('#tab_divide').on('shown.bs.tab', function (e) {
  553. sessionStorage.setItem('mainTab', '#tab_divide');
  554. loadDivideHeight();
  555. divideObj.initSpread();
  556. divideObj.showDatas();
  557. divideObj.initNavItem();
  558. })
  559. $('.divide-nav-link').bind('click', function () {//$('.side-tabs ul li a').bind 2018-11-23 使用更多标签,所以不能这样绑定事件了
  560. var tab = $(this), tabPanel = $(tab.attr('relaPanel'));
  561. if(tab.hasClass('disabled')){
  562. return;
  563. }
  564. let setActiveTab = tab;
  565. if (!(setActiveTab.hasClass('active')&&tabPanel.is(":visible"))) {
  566. $('.divide_side-tabs ul li a').removeClass('active');
  567. setActiveTab.addClass('active');
  568. showDivideSide(tabPanel, true, tab.attr('id'));
  569. } else {
  570. setActiveTab.removeClass('active');
  571. showDivideSide(tabPanel, false, tab.attr('id'));
  572. }
  573. divideObj.refreshViews();
  574. });
  575. //定额库上下拖动
  576. let dividRationLibResizeEles = {};
  577. dividRationLibResizeEles.eleObj = {
  578. module: 'divide_de',
  579. resize: $('#divide_deResize'),
  580. top: $('#divide_deTopDiv'),
  581. topSpread: $('#divide_stdRationChapter'),
  582. bottom: $('#divide_deBottomDiv'),
  583. bottomSpread: $('#divide_stdSectionRations')
  584. };
  585. dividRationLibResizeEles.limit = {
  586. min: 150,
  587. max: `$(window).height()-$('.header').height()-$('.toolsbar').height()-$('#deToolsBar').height()-150-5`,//5: resize.height()
  588. notTopSpread: 0,
  589. notBottomSpread: 0,
  590. totalHeight: `$(window).height()-$('.header').height()-$('.toolsbar').height()-$('#divide_deToolsBar').height()-5`
  591. };
  592. function showDivideSide(tabPanel, show, id){
  593. let divideSideResizeEles = {};
  594. divideSideResizeEles.eleObj = {
  595. module: 'divideRationLibTab',
  596. resize: $('#divideSideResize'),
  597. parent: $('#divideRow'),
  598. left: $('#divide_main'),
  599. right: $('#divide_side')
  600. };
  601. divideSideResizeEles.limit = {
  602. min: 150,
  603. max: `$('#divideRow').width()-150`
  604. };
  605. divideSideResizeEles.eleObj.module = id;
  606. if (show) {
  607. //刚打开各库时的默认比例
  608. divideSideResizeEles.eleObj.left.css('width', '66.666667%');
  609. divideSideResizeEles.eleObj.right.css('width', '33.333333%');
  610. SlideResize.setResizeWidth(divideSideResizeEles.eleObj.resize);
  611. $('.divide_side .tab-pane').hide();
  612. tabPanel.show();//locateTab要等div显示后才执行刷新操作
  613. //加载打开的库与主界面的宽度比
  614. SlideResize.loadHorizonWidth(id, [divideSideResizeEles.eleObj.resize], [divideSideResizeEles.eleObj.left, divideSideResizeEles.eleObj.right], function(){
  615. if (id === 'divide_stdRationTab') {//加载定额库内部上下高度
  616. SlideResize.loadVerticalHeight(dividRationLibResizeEles.eleObj.module, dividRationLibResizeEles.eleObj, dividRationLibResizeEles.limit, function () {
  617. if(rationLibObj.divide_rationChapterSpread) rationLibObj.divide_rationChapterSpread.refresh();
  618. if(rationLibObj.divide_sectionRationsSpread) rationLibObj.divide_sectionRationsSpread.refresh();
  619. });
  620. }
  621. });
  622. } else {
  623. divideSideResizeEles.eleObj.left.css('width', '100%');
  624. divideSideResizeEles.eleObj.right.css('width', '0%');
  625. tabPanel.hide();
  626. }
  627. }
  628. $('#divide_stdRationTab').bind('click', function () {
  629. var select = $('#divide_stdRationLibSelect');
  630. rationLibObj.checkSpread('divide');
  631. if (select[0].options.length === 0) {
  632. rationLibObj.loadStdRationLibs('divide');
  633. //rationLibObj.loadStdRationContextMenu();
  634. };
  635. divideObj.initNavItem();
  636. });
  637. $('#divide_stdRationLibSelect').change(function () {
  638. var select = $(this);
  639. if (this.children.length !== 0) {
  640. let rationLibId = select.val();
  641. sessionStorage.setItem('divide_stdRationLib', rationLibId);
  642. sessionStorage.removeItem('divide_stdRationLibExpState');
  643. rationLibObj.loadStdRation(rationLibId,'divide');
  644. }
  645. });
  646. $('.divide_gljSubTab ul li a').bind('click',function () {
  647. if(this.hash =="#divide_rnc-close"){
  648. $("#divide_zmhs_nav").hide();
  649. $("#divide_zmhs_toogle").show();
  650. closeTab(this);
  651. divideObj.showDivideGljSubTab = false;
  652. }else{
  653. divideObj.showDivideGljSubTab = true;
  654. }
  655. divideObj.initDivideGljSubTab();
  656. if(divideObj.divideSubSpread) divideObj.divideSubSpread.refresh();
  657. });
  658. $('.divide_gljSubTab ul li a').on('shown.bs.tab', function () {
  659. if(this.hash == "#divide_rnc-zm"){
  660. zmhs_obj.initCoeSpread();
  661. }else if(this.hash == "#divide_rnc-fz"){
  662. zmhs_obj.initAssSpread();
  663. }else if(this.hash == "#divide_rnc-cus"){
  664. zmhs_obj.initCusSpread();
  665. }else if(this.hash == "#divide_rnc-stable"){
  666. zmhs_obj.initStableSpread();
  667. }
  668. zmhs_obj.refresh();
  669. zmhs_obj.showDatas();
  670. });
  671. $('#divide_zmhs_toogle').bind('click',function (){
  672. $("#divide_zmhs_nav").show();
  673. if(divideObj.showDivideGljSubTab == false){
  674. $("#divide_hs-nav").click();
  675. }
  676. $("#divide_zmhs_toogle").hide();
  677. });