fee_rate_view.js 45 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135
  1. /**
  2. * Created by chen on 2017/8/1.
  3. */
  4. var feeRateObject={
  5. mainFeeRateSpread:null,
  6. mainFeeRateSheet:null,
  7. mainFeeRateData:null,
  8. mainFeeRateSetting:{
  9. header: [
  10. {headerName: "专业名称", headerWidth: 250, dataCode: "name", dataType: "String"},
  11. {headerName: "值%", headerWidth: 80, dataCode: "rate", dataType: "Number",hAlign: "right",decimalField:"feeRate"},
  12. {headerName: "备注", headerWidth: 150, dataCode: "memo", dataType: "String"}
  13. ],
  14. view: {
  15. lockColumns: [0]
  16. }
  17. },
  18. mainViews:null,
  19. datas:null,
  20. datasBackup:null,
  21. canEdit:false,
  22. activateFeeRate:null,
  23. needCascadeSet:false,
  24. selectionLoad:false,
  25. changeInfo:null,
  26. feeRateSpreads:null,
  27. editingCell:null,
  28. feeRateSelection:null,
  29. sheetSetting: {
  30. header: [
  31. {headerName: "专业名称", headerWidth: 200, dataCode: "name", dataType: "String"},
  32. {headerName: "值%", headerWidth: 120, dataCode: "rate", dataType: "Number",hAlign: "right",decimalField:"feeRate"},
  33. {headerName: "备注", dataCode: "memo", dataType: "String"}
  34. ],
  35. view: {
  36. comboBox: [],
  37. lockColumns: [0, 1, 2]
  38. }
  39. },
  40. columns: [
  41. {
  42. id: 'name',
  43. caption: '专业名称',
  44. dataField: 'name',
  45. width: 450,
  46. allowEditing: false
  47. },
  48. {
  49. id: 'rate',
  50. caption: '值%',
  51. dataField: 'rate',
  52. width: 120,
  53. minWidth: 50,
  54. allowEditing: true
  55. },
  56. {
  57. id: 'memo',
  58. caption: '备注',
  59. dataField: 'memo',
  60. minWidth: 120,
  61. allowEditing: true
  62. },
  63. {
  64. id: 'ID',
  65. caption: 'ID',
  66. dataField: 'ID',
  67. width: 80,
  68. visible: false,
  69. allowEditing: false
  70. },
  71. {
  72. id: 'subFeeRate',
  73. caption: '子费率',
  74. dataField: 'subFeeRate',
  75. width: 80,
  76. visible: false,
  77. allowEditing: false
  78. },
  79. {
  80. id: '_id',
  81. caption: '自动ID',
  82. dataField: '_id',
  83. width: 80,
  84. visible: false,
  85. allowEditing: false
  86. },
  87. {
  88. id: 'ParentID',
  89. caption: '父结点ID',
  90. dataField: 'ParentID',
  91. width: 80,
  92. visible: false,
  93. allowEditing: false
  94. }
  95. ],
  96. options :{
  97. allowSorting: false,
  98. showRowHeader: true,
  99. colMinWidth: 80,
  100. rowHeight: 30,
  101. allowEditing: true,
  102. editMode: 'inline',
  103. editUnit: 'cell',
  104. selectionUnit: "row",
  105. hierarchy: {
  106. keyField: 'ID',
  107. parentField: 'ParentID',
  108. collapsed: false,
  109. column: 'name'
  110. }
  111. },
  112. dataSource : {
  113. loadRange: function(params) {
  114. params.success(feeRateObject.datas);
  115. },
  116. update: function(params) {
  117. if(!params.hasOwnProperty('sourceIndex')){
  118. var selected = feeRateObject.mainViews.getSelections()[0];
  119. params.sourceIndex = selected.sourceRow;
  120. }
  121. params.success();
  122. if(!$('#cascadeSet').prop('checked')||params.hasOwnProperty('viewIndex')){
  123. projectObj.project.FeeRate.updateFeeRateByEdit(params,feeRateObject.activateFeeRate);
  124. }
  125. }
  126. },
  127. createSheet:function(){
  128. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  129. feeRateObject.feeRateSpreads=sheetCommonObj.buildSheet($('#fee_rate_sheet')[0], feeRateObject.sheetSetting,feeRateFile.rates.length);
  130. sheetCommonObj.spreadDefaultStyle(feeRateObject.feeRateSpreads);
  131. feeRateObject.feeRateSheet = feeRateObject.feeRateSpreads.getSheet(0);
  132. feeRateObject.feeRateSheet.selectionUnit(1)//0 cell,1 row,2 col;
  133. feeRateObject.feeRateSheet.options.isProtected = true;
  134. feeRateObject.feeRateSheet.name('fee_rate');
  135. feeRateObject.feeRateSheet.bind(GC.Spread.Sheets.Events.CellClick,feeRateObject.onCellClick);
  136. feeRateObject.feeRateSheet.bind(GC.Spread.Sheets.Events.CellDoubleClick,feeRateObject.onCellDoubleClick);
  137. },
  138. showFeeRateTree:function (sheet,setting,data) {
  139. let ch = GC.Spread.Sheets.SheetArea.viewport;
  140. let parentMap=_.groupBy(data, 'ParentID');
  141. let visibleMap = {};
  142. sheet.suspendPaint();
  143. sheet.suspendEvent();
  144. for (let col = 0; col < setting.header.length; col++) {
  145. let hAlign = "left", vAlign = "center";
  146. if (setting.header[col].hAlign) {
  147. hAlign = setting.header[col].hAlign;
  148. } else if (setting.header[col].dataType !== "String"){
  149. hAlign = "right";
  150. }
  151. vAlign = setting.header[col].vAlign?setting.header[col].vAlign:vAlign;
  152. sheetCommonObj.setAreaAlign(sheet.getRange(-1, col, -1, 1), hAlign, vAlign);
  153. if (setting.header[col].formatter) {
  154. sheet.setFormatter(-1, col, setting.header[col].formatter, GC.Spread.Sheets.SheetArea.viewport);
  155. }
  156. for (let row = 0; row < data.length; row++) {
  157. let val = data[row][setting.header[col].dataCode];
  158. if(val&&setting.header[col].dataType === "Number"){
  159. if(setting.header[col].hasOwnProperty('decimalField')){
  160. let decimal = getDecimal(setting.header[col].decimalField);
  161. val =scMathUtil.roundToString(val,decimal);
  162. sheet.setFormatter(-1, col,getFormatter(decimal), GC.Spread.Sheets.SheetArea.viewport);
  163. }else {
  164. val =scMathUtil.roundToString(val,2);
  165. }
  166. }
  167. sheet.setValue(row, col, val, ch);
  168. if(col==0){
  169. let treeType = feeRateObject.getTreeNodeCellType(data,row,parentMap);
  170. sheet.getCell(row, 0).cellType(treeType);
  171. visibleMap[data[row].ID] = treeType.collapsed;
  172. if(visibleMap[data[row].ParentID] ) sheet.getRange(row , -1, 1, -1).visible(false);//显示或隐藏
  173. }
  174. }
  175. }
  176. sheet.resumeEvent();
  177. sheet.resumePaint();
  178. },
  179. getFeeRateLevel:function (rate,data) {
  180. if(rate.ParentID){
  181. let prate = _.find(data,{'ID':rate.ParentID});
  182. return this.getFeeRateLevel(prate,data) + 1;
  183. }else {
  184. return 0
  185. }
  186. },
  187. locate: function(){ // CSL,2018.07.18
  188. let sheet = feeRateObject.feeRateSpreads.getSheet(0);
  189. let fID = 0;
  190. if ($("#calc_program_manage").is(":visible"))
  191. fID = calcProgramManage.getSelectionInfo().calcItem.feeRateID;
  192. else if ($("#zaojiashu").is(":visible"))
  193. fID = projectObj.project.mainTree.selected.data.feeRateID;
  194. let rates = projectObj.project.FeeRate.getActivateFeeRate().rates;
  195. let rowIdx = 0, pID = 0;
  196. if (fID){
  197. fID = parseInt(fID);
  198. rowIdx = _.findIndex(rates,{ID:fID});
  199. if(rowIdx != -1) pID = rates[rowIdx].ParentID;
  200. }
  201. // 费率现有可能有多层节点,所以要递归展开父节点
  202. if(pID) expandParent(pID,rates,sheet);
  203. sheet.setSelection(rowIdx, -1, 1, -1);
  204. sheet.showRow(rowIdx, GC.Spread.Sheets.VerticalPosition.center);
  205. feeRateObject.onCellClick({type: 'CellClick'}, {row:rowIdx});
  206. function expandParent(ID,datas,sheet) {//递归展开父节点
  207. let cellType = setCollapsed(ID);
  208. cellType.refreshChildrenVisible(sheet);
  209. function setCollapsed(parentID){
  210. let index = _.findIndex(datas,{'ID':parentID});
  211. let type = sheet.getCellType(index,0);
  212. type.collapsed = false;
  213. if(datas[index].ParentID){
  214. setCollapsed(datas[index].ParentID)
  215. }
  216. return type
  217. }
  218. }
  219. },
  220. getTreeNodeCellType:function (datas,row,parentMap) {// 2018-09-26 不用spreadjs默认的树结构,自定义控件
  221. var ns = GC.Spread.Sheets;
  222. let rectW = 10;
  223. let rectH = 10;
  224. let margin = 3;
  225. function TreeNodeCellType() {
  226. this.collapsed = true; //默认是折叠的
  227. this.rectInfo = {};
  228. }
  229. TreeNodeCellType.prototype = new ns.CellTypes.Text();
  230. TreeNodeCellType.prototype.paint = function (ctx, value, x, y, w, h, style, options) {
  231. let offset = 0;
  232. let step = 7;
  233. let level = getTreeLevel(datas[row],datas);//从0开始,取当前节点是第几级的
  234. let tem = offset+margin+ rectW/2+step;//两条线之间的间隔
  235. let t_offset = offset;
  236. let temParentID = datas[row].ParentID;
  237. for(let i = level;i>0;i--){//这里是画子节点前面的竖线,从第二级开始
  238. let temParent = getParent(temParentID,datas);
  239. if(temParent){//父节点有下一个兄弟节点才需要画
  240. if(hasNextBrother(parentMap,temParent)) sheetCommonObj.drawLine(ctx,x+t_offset+tem*i,y,x+t_offset+tem*i,y+h);
  241. temParentID = temParent.ParentID;
  242. }
  243. offset +=tem;
  244. }
  245. offset+=step;
  246. if(hasChildern(datas[row].ID,datas)){//如果是有子节点
  247. //第一条不用画方框头上那条竖线其它都要
  248. if(row !=0) sheetCommonObj.drawLine(ctx,x+offset+ rectW/2+margin,y,x+offset+ rectW/2+margin,y + Math.round(h / 2) - rectH / 2);
  249. //画方框下面的那条竖线,如果没有下一个兄弟节点,则不用画
  250. if(hasNextBrother(parentMap,datas[row])) sheetCommonObj.drawLine(ctx,x+offset+ rectW/2+margin,y + Math.round(h / 2) + rectH / 2,x+offset+ rectW/2+margin,y + h);
  251. sheetCommonObj.drowRect(ctx, x+offset, y, w, h,rectW,rectH,margin);
  252. sheetCommonObj.drowSymbol(ctx, x+offset, y, w, h,rectW,rectH,margin, this.collapsed);
  253. this.rectInfo = {x:x+offset+margin,rectW:rectW}//计录一下可点击位置
  254. }else {
  255. let hasNext = datas[row+1]?datas[row+1].ParentID == datas[row].ParentID:false;
  256. sheetCommonObj.drowSubItem(ctx, x, y, w, h, offset,hasNext,margin+ rectW/2);
  257. }
  258. offset += step;
  259. offset += rectW;
  260. x = x + offset;//设置偏移
  261. w = w - offset;
  262. GC.Spread.Sheets.CellTypes.Text.prototype.paint.apply(this, arguments);
  263. };
  264. // override getHitInfo to allow cell type get mouse messages
  265. TreeNodeCellType.prototype.getHitInfo = function (x, y, cellStyle, cellRect, context) {
  266. return {
  267. x: x,
  268. y: y,
  269. row: context.row,
  270. col: context.col,
  271. cellStyle: cellStyle,
  272. cellRect: cellRect,
  273. sheetArea: context.sheetArea
  274. };
  275. }
  276. TreeNodeCellType.prototype.processMouseDown = function (hitinfo) {
  277. if (!_.isEmpty(this.rectInfo)&&hitinfo.x < this.rectInfo.x+this.rectInfo.rectW && hitinfo.x > this.rectInfo.x) {
  278. this.collapsed = !this.collapsed;
  279. this.refreshChildrenVisible(hitinfo.sheet);
  280. hitinfo.sheet.invalidateLayout();
  281. hitinfo.sheet.repaint();
  282. }
  283. };
  284. TreeNodeCellType.prototype.refreshChildrenVisible = function (sheet) {
  285. sheet.suspendPaint();
  286. sheet.suspendEvent();
  287. refreshVisible(datas[row]);
  288. sheet.resumeEvent();
  289. sheet.resumePaint();
  290. function refreshVisible(item){
  291. if(parentMap[item.ID]){
  292. for(let sub of parentMap[item.ID]){
  293. refreshVisible(sub)
  294. }
  295. }
  296. let parent = getParent(item.ParentID,datas);
  297. if(parent){
  298. let prow= datas.indexOf(parent);
  299. let visible = !sheet.getCellType(prow,0).collapsed;
  300. let trow = datas.indexOf(item);
  301. sheet.getRange(trow , -1, 1, -1).visible(visible);
  302. }
  303. }
  304. };
  305. return new TreeNodeCellType()
  306. function getTreeLevel(item,data) {
  307. if(item.ParentID){
  308. let pitem = _.find(data,{'ID':item.ParentID});
  309. return getTreeLevel(pitem,data) + 1;
  310. }else {
  311. return 0
  312. }
  313. }
  314. function hasChildern(ID,data) {//返回是否有子项
  315. let p = _.find(data,{'ParentID':ID});
  316. if(p) return true;
  317. return false
  318. }
  319. function getParent(ParentID,data) {
  320. let p = _.find(data,{'ID':ParentID});
  321. return p;
  322. }
  323. function hasNextBrother(parentMap,item){
  324. let children =parentMap[item.ParentID];
  325. if(children && children.indexOf(item) == children.length -1) return false;
  326. return true
  327. }
  328. },
  329. getFeeRateEditCellType:function () {
  330. var ns = GC.Spread.Sheets;
  331. function FeeRateEditCellType() {
  332. var init=false;
  333. }
  334. FeeRateEditCellType.prototype = new ns.CellTypes.Text();
  335. FeeRateEditCellType.prototype.paint = function (ctx, value, x, y, w, h, style, options) {
  336. // if(value!=null){
  337. // ctx.fillText(value,x+3+ctx.measureText(value).width,y+h-3);
  338. GC.Spread.Sheets.CellTypes.Text.prototype.paint.apply(this, arguments);
  339. // }
  340. if(feeRateObject.editingCell && !projectReadOnly){
  341. if(feeRateObject.editingCell.row==options.row&&feeRateObject.editingCell.col==options.col){
  342. var image = document.getElementById('f_btn'),imageMagin = 3;
  343. var imageHeight = h-2*imageMagin;
  344. var imageWidth = w*2/7;
  345. var imageX = x + w - imageWidth- imageMagin, imageY = y + h / 2 - imageHeight / 2;
  346. ctx.save();
  347. ctx.drawImage(image, imageX, imageY,imageWidth,imageHeight);
  348. ctx.beginPath();
  349. ctx.arc(imageX+imageWidth/2,imageY+imageHeight/2,1,0,360,false);
  350. ctx.arc(imageX+imageWidth/2-4,imageY+imageHeight/2,1,0,360,false);
  351. ctx.arc(imageX+imageWidth/2+4,imageY+imageHeight/2,1,0,360,false);
  352. ctx.fillStyle="black";//填充颜色,默认是黑色
  353. ctx.fill();//画实心圆
  354. ctx.closePath();
  355. ctx.restore();
  356. }
  357. }
  358. };
  359. FeeRateEditCellType.prototype.getHitInfo = function (x, y, cellStyle, cellRect, context) {
  360. return {
  361. x: x,
  362. y: y,
  363. row: context.row,
  364. col: context.col,
  365. cellStyle: cellStyle,
  366. cellRect: cellRect,
  367. sheetArea: context.sheetArea
  368. };
  369. };
  370. FeeRateEditCellType.prototype.processMouseDown = function (hitinfo) {
  371. let me=feeRateObject;
  372. if(me.editingCell && hitinfo.row==me.editingCell.row){
  373. var offset=hitinfo.cellRect.x+hitinfo.cellRect.width-6;
  374. var imageMagin=3;
  375. var imageHeight = hitinfo.cellRect.height-2*imageMagin;
  376. var imageWidth = hitinfo.cellRect.width*2/7;
  377. if(hitinfo.x<offset&&hitinfo.x>offset-imageWidth){
  378. if(!projectReadOnly && me.ifFeeRateEdit(hitinfo.row,hitinfo.sheet.name())){
  379. $('#calcBaseFeeRateConf').attr('toggle', 'feeRate');
  380. changeCalcBaseFeeRate('feeRate');
  381. $('#tabFeeRate').tab('show');
  382. me.showSelectModal(hitinfo);
  383. }
  384. }else {//鼠标点击其它地方,消失
  385. hideButton(hitinfo);
  386. }
  387. }
  388. };
  389. FeeRateEditCellType.prototype.processMouseEnter = function (hitinfo){
  390. let me=feeRateObject;
  391. me.pmLeave = false;
  392. if(me.editingCell==null){
  393. var showSelectBtn = true;
  394. if(hitinfo.sheet.name()!='calc_detail'){
  395. showSelectBtn=me.ifFeeRateEdit(hitinfo.row,hitinfo.sheet.name());
  396. }
  397. if(showSelectBtn){
  398. me.editingCell={
  399. row:hitinfo.row,
  400. col:hitinfo.col
  401. };
  402. hitinfo.sheet.invalidateLayout();
  403. hitinfo.sheet.repaint();
  404. }
  405. }
  406. };
  407. FeeRateEditCellType.prototype.processMouseLeave = function (hitinfo) {
  408. hideButton(hitinfo);
  409. };
  410. function hideButton(hitinfo) {
  411. if(!feeRateObject.pmLeave){
  412. feeRateObject.editingCell=null;
  413. hitinfo.sheet.invalidateLayout();
  414. hitinfo.sheet.repaint();
  415. feeRateObject.pmLeave = true;
  416. }
  417. }
  418. return new FeeRateEditCellType();
  419. },
  420. showSelectModal:function (hitinfo) {
  421. //锁定的清单不显示
  422. let project = projectObj.project;
  423. if(project.isBillsLocked() && project.withinBillsLocked(project.mainTree.selected)){
  424. return;
  425. }
  426. //$("#fee_rate_tree").modal({show:true});
  427. $("#calcBaseFeeRate").modal({show:true});
  428. $('#edit_from').val(hitinfo.sheet.name());
  429. },
  430. getChildrenCount:function (id,data) {
  431. var me=this;
  432. var sum=0;
  433. var children=_.filter(data,{'ParentID':id});
  434. if(children&&children.length==0){
  435. return 0;
  436. }
  437. for(var i=0;i<children.length;i++){
  438. sum+=me.getChildrenCount(children[i].ID,data);
  439. }
  440. return children.length+sum;
  441. },
  442. ifFeeRateEdit:function (row,name) {
  443. if( name == 'mainSheet'){
  444. var selected = projectObj.project.mainTree.items[row];
  445. return selected&&MainTreeCol.readOnly.forFeeRate(selected)?false:true;
  446. }
  447. return true;
  448. },
  449. createSpreadView:function () {
  450. if (this.mainViews) {
  451. this.mainViews.destroy();
  452. this.mainViews = null;
  453. }
  454. if(subRateObject.views){
  455. subRateObject.views.destroy();
  456. subRateObject.views = null;
  457. }
  458. this.activateFeeRate = projectObj.project.FeeRate.getActivateFeeRate();
  459. this.datas = this.activateFeeRate.rates;
  460. var rateColSetting = _.find(this.columns,{"id":"rate"});
  461. rateColSetting?rateColSetting.format=getFormatter(getDecimal("feeRate")):"";
  462. this.mainViews = new GC.Spread.Views.DataView($('#divFee')[0],
  463. this.dataSource, this.columns, new GC.Spread.Views.Plugins.GridLayout(this.options));
  464. this.mainViews["rowClick"].addHandler(subRateObject.reFreshRateViews);
  465. this.mainViews.invalidate();
  466. document.querySelector('#divFee').focus();
  467. },
  468. initFeeRateSpread:function (rowCount) {
  469. //初始化费用项表格
  470. this.mainFeeRateSpread = sheetCommonObj.buildSheet($('#divFee')[0], this.mainFeeRateSetting,rowCount);
  471. sheetCommonObj.spreadDefaultStyle(this.mainFeeRateSpread);
  472. this.mainFeeRateSpread.options.scrollbarMaxAlign = true;
  473. this.mainFeeRateSheet = this.mainFeeRateSpread.getSheet(0);
  474. if(!projectReadOnly){
  475. sheetCommonObj.lockCells(this.mainFeeRateSheet , this.mainFeeRateSetting);
  476. }
  477. this.mainFeeRateSheet.bind(GC.Spread.Sheets.Events.ValueChanged, this.onMainFeeRateSheetValueChange);
  478. this.mainFeeRateSheet.bind(GC.Spread.Sheets.Events.SelectionChanged, this.onMainFeeRateSelectChanged);
  479. this.mainFeeRateSheet.bind(GC.Spread.Sheets.Events.RangeChanged, this.onMainFeeRateRangeChanged);
  480. this.mainFeeRateSheet.bind(GC.Spread.Sheets.Events.EditStarting, function (e,args) {
  481. let me =feeRateObject;
  482. if(!me.mainFeeRateEditChecking(args.row,args.col)){
  483. args.cancel = true;
  484. }
  485. });
  486. this.mainFeeRateSheet.name('mainFeeRateSheet');
  487. disableRightMenu("divFee",this.mainFeeRateSpread,this.rightClickCallback);
  488. //打开他人分享的项目、只读
  489. if(projectReadOnly){
  490. disableSpread(this.mainFeeRateSpread);
  491. }
  492. },
  493. rightClickCallback:function (row) {
  494. let me = feeRateObject;
  495. me.onMainFeeRateSelect(row);
  496. },
  497. showMainFeeRateData:function () {
  498. let me = this;
  499. let selected = me.mainFeeRateSheet.getSelections()[0];
  500. me.activateFeeRate = projectObj.project.FeeRate.getActivateFeeRate();
  501. me.mainFeeRateData = projectObj.project.FeeRate.getActivateFeeRate().rates;
  502. me.mainFeeRateSheet.setRowCount(0);
  503. me.mainFeeRateSheet.setRowCount(me.mainFeeRateData.length);
  504. me.showFeeRateTree(me.mainFeeRateSheet,me.mainFeeRateSetting,me.mainFeeRateData);
  505. me.mainFeeRateSheet.setSelection(selected.row,selected.col,selected.rowCount,selected.colCount);
  506. },
  507. reFreshRateViews:function() {
  508. feeRateObject.loadPageContent();
  509. this.showMainFeeRateData();
  510. if(subRateObject.subRateSpread){//如果子费率没有初始化过的话,不需要显示。
  511. subRateObject.initSubRateSpread(this.mainFeeRateData[0]);
  512. }
  513. },
  514. mainFeeRateEditChecking:function (row,col) {//false 不能编辑,true 可以编辑
  515. let me =feeRateObject;
  516. let recode = me.mainFeeRateData[row];
  517. let dataCode = me.mainFeeRateSetting.header[col].dataCode;
  518. if(dataCode=="rate"&&me.getChildrenCount(recode.ID,me.mainFeeRateData)>0){//有子节点时不能编辑费率列
  519. return false;
  520. }
  521. return true;
  522. },
  523. onMainFeeRateSheetValueChange:function (e,info) {
  524. feeRateObject.updateFeerateWhenCellsChange([info]);
  525. },
  526. onMainFeeRateRangeChanged:function (e,info) {
  527. let me = feeRateObject;
  528. let changeCells = [];
  529. for(let c of info.changedCells){
  530. let tem = {
  531. row:c.row,
  532. col:c.col,
  533. newValue:info.sheet.getCell(c.row,c.col).value()
  534. };
  535. changeCells.push(tem);
  536. }
  537. me.updateFeerateWhenCellsChange(changeCells);
  538. },
  539. updateFeerateWhenCellsChange:function (cells) {// col,row,newValue
  540. let me = feeRateObject,updateDatas = [],feeRate = projectObj.project.FeeRate;//[{rateID:rateID,doc:doc}]
  541. let refreshA = [];//记录刷新条数的数组
  542. for(let c of cells){
  543. let temData = {};
  544. let recode = me.mainFeeRateData[c.row];
  545. let fieldID = me.mainFeeRateSetting.header[c.col].dataCode;
  546. let value = c.newValue;
  547. let oldValue = recode[fieldID];
  548. if(!me.mainFeeRateEditChecking(c.row, c.col)){
  549. me.mainFeeRateSheet.setValue(c.row, c.col, oldValue);
  550. continue;
  551. }else if(fieldID == 'rate'&&value !== null && value!==0){
  552. let checkResult = scMathUtil.isNumOrFormula(value);
  553. if(checkResult!=null && !isNaN(checkResult)){
  554. value = scMathUtil.roundForObj(checkResult,getDecimal("feeRate"));
  555. }else {
  556. alert('当前输入的数据类型不正确,请重新输入。');
  557. me.mainFeeRateSheet.setValue(c.row, c.col, oldValue);
  558. continue;
  559. }
  560. }
  561. if(recode[fieldID] == value){//没有改变
  562. continue;
  563. }
  564. temData[fieldID] = value ;
  565. updateDatas.push({rateID:recode.ID,doc:temData});
  566. refreshA.push({col:c.col,row:c.row,fieldID:fieldID,value:value,rateID:recode.ID});
  567. }
  568. if(updateDatas.length > 0){
  569. $.bootstrapLoading.start();
  570. feeRate.updateFeeRatesByIDs(updateDatas,function () {
  571. let feerateInfo = [];
  572. for(let r of refreshA){
  573. me.mainFeeRateSheet.setValue(r.row, r.col, r.value);
  574. if(r.fieldID == 'rate'){
  575. feerateInfo.push({rateID:r.rateID,value:r.value});
  576. }
  577. }
  578. feerateInfo.length > 0 ?feeRate.onFeeRatesChange(feerateInfo):'';
  579. $.bootstrapLoading.end();
  580. })
  581. }
  582. },
  583. onMainFeeRateSelectChanged:function (e, info) {
  584. let me = feeRateObject;
  585. let row = info.newSelections[0].row;
  586. me.onMainFeeRateSelect(row);
  587. },
  588. onMainFeeRateSelect:function (row) {
  589. let me = this;
  590. if(row!=-1){
  591. subRateObject.initSubRateSpread(me.mainFeeRateData[row]);
  592. }
  593. },
  594. updateBySelect:function (rate,selectMap,mapID) {
  595. let selected = this.mainFeeRateSheet.getSelections()[0];
  596. projectObj.project.FeeRate.backupDatas();
  597. let item = this.mainFeeRateData[selected.row];
  598. item.rate = rate;
  599. for(let key in selectMap){
  600. let recode = item.subFeeRate.recodes[key];
  601. let optionList = recode.optionList;
  602. for(let o of optionList){
  603. if(o.value==selectMap[key]){
  604. o.selected=true;
  605. }else {
  606. o.selected = false;
  607. }
  608. }
  609. }
  610. if($('#cascadeSet').prop('checked')){
  611. this.cascadeSetRates(item,selected.row,mapID,selectMap);
  612. }else {
  613. projectObj.project.FeeRate.batchUpdateFeeRate([{rateIndex:selected.row,rate:item}],feeRateObject.activateFeeRate);
  614. }
  615. },
  616. cascadeSetRates:function(selectedItem,sourceRow,mapID,selectMap){
  617. let items=[];
  618. items.push({rateIndex:sourceRow,rate:selectedItem});
  619. _.forEach(this.mainFeeRateData,function (recode,Index) {
  620. if(Index!=sourceRow&&recode.subFeeRate){
  621. let valueMaps = recode.subFeeRate.valueMaps;
  622. let valueMap = _.find(valueMaps,{ID:mapID});
  623. if(valueMap){//选项完全一样的情况
  624. if(valueMap.value==recode.rate){
  625. return;
  626. }else {
  627. recode.rate = valueMap.value;
  628. _.forEach(selectMap,function (value,key) {
  629. let tempRecode = recode.subFeeRate.recodes[key];
  630. let optionList = tempRecode.optionList;
  631. for(let o of optionList){
  632. o.value===value? o.selected = true:o.selected = false;
  633. }
  634. });
  635. items.push({rateIndex:Index,rate:recode});
  636. }
  637. }else {//某条选项一样的情况
  638. let needUpdate = false;
  639. let selectList = mapID.split('-');
  640. let newList=[];
  641. _.forEach(recode.subFeeRate.recodes,function (r) {
  642. let oList = r.optionList, oldSelectIndex=0, hasChange=false;
  643. _.forEach(oList,function (o,key) {
  644. if(o.selected) oldSelectIndex = key;
  645. if(_.includes(selectList,o.value)){
  646. needUpdate=true;
  647. o.selected=true;
  648. hasChange=true;
  649. newList.push(o.value);
  650. }else {
  651. o.selected=false;
  652. }
  653. });
  654. if(!hasChange){
  655. oList[oldSelectIndex].selected=true;
  656. newList.push(oList[oldSelectIndex].value)
  657. }
  658. });
  659. if(needUpdate){
  660. let newValue = _.find(valueMaps,{ID:newList.join("-")})//取出费率值并更新
  661. if(newValue){
  662. if(recode.rate != newValue.value){
  663. recode.rate = newValue.value;
  664. items.push({rateIndex:Index,rate:recode});
  665. }
  666. }
  667. }
  668. }
  669. }
  670. });
  671. projectObj.project.FeeRate.batchUpdateFeeRate(items,feeRateObject.activateFeeRate);
  672. },
  673. loadPageContent:function(){
  674. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  675. var usageProjects = feeRateFile.usageProjects;
  676. $('#feeRateFileName').text(feeRateFile.name);
  677. $('#feeRateLibName').text(feeRateFile.libName);
  678. $('#projectCount').text(usageProjects.length);
  679. },
  680. loadFeeRateSelection:function() {
  681. if(!this.selectionLoad){
  682. var selectedID=0;
  683. _.forEach(projectObj.project.FeeRate.datas,function (data) {
  684. var option = $("<option>").val(data.ID).text(data.libName);
  685. $('#inlineFormCustomSelect').append(option);
  686. if(data.status=='activate'){
  687. selectedID=data.ID;
  688. }
  689. })
  690. $('#inlineFormCustomSelect').val(selectedID);
  691. }
  692. },
  693. getFeeRateStandards:function (callback) {
  694. CommonAjax.post('/feeRates/getFeeRateStandards', {"projectID": projectObj.project.ID()}, function (data) {
  695. if (data) {
  696. callback(data);
  697. }
  698. });
  699. },
  700. changeFeeRateStandard:function(newVal){
  701. $.bootstrapLoading.start();
  702. var callback=function () {
  703. feeRateObject.reFreshRateViews();
  704. projectObj.project.FeeRate.onFeeRateFileChange();
  705. $.bootstrapLoading.end();
  706. };
  707. projectObj.project.FeeRate.changeFeeRateStandard(newVal,callback);
  708. },
  709. checkFeeRateName:function (newVal) {
  710. if(!newVal||newVal==""){
  711. $('#saveAsConfirm').attr("disabled","disabled");
  712. $('#nameError').text("请输入文件名称。").show();
  713. return;
  714. }
  715. var callback=function (data) {
  716. if(data){
  717. $('#saveAsConfirm').attr("disabled","disabled");
  718. $('#nameError').text("已存在同名费率文件。").show();
  719. $('#valid_name').val('');
  720. }else {
  721. $('#valid_name').val(newVal);
  722. $('#saveAsConfirm').removeAttr("disabled");
  723. $('#nameError').hide();
  724. }
  725. };
  726. projectObj.project.FeeRate.checkFeeRateName(newVal,callback);
  727. },
  728. feeRateFileSaveAs:function (newName) {
  729. if(!newName||newName==""){
  730. $('#saveAsConfirm').attr("disabled","disabled");
  731. $('#nameError').text("请输入文件名称。").show();
  732. return;
  733. }
  734. let valideName = $('#valid_name').val();
  735. if(valideName==''||valideName!==newName){
  736. let callback=function (data) {
  737. if(data){
  738. $('#saveAsConfirm').attr("disabled","disabled");
  739. $('#nameError').text("已存在同名费率文件。").show();
  740. $('#valid_name').val('');
  741. }else {
  742. feeRateObject.submitSaveAs(newName);
  743. }
  744. }
  745. projectObj.project.FeeRate.checkFeeRateName(newName,callback);
  746. }else {
  747. feeRateObject.submitSaveAs(newName);
  748. }
  749. },
  750. submitSaveAs:function (newName) {
  751. let me = this;
  752. let FeeRate = projectObj.project.FeeRate;
  753. FeeRate.feeRateFileSaveAs(newName,function (result) {
  754. me.activateFeeRate = result;
  755. me.loadPageContent();
  756. $('#copy-lv').modal('hide');
  757. let data ={
  758. projectID:projectObj.project.ID(),
  759. oldRoom:socketObject.roomInfo.feeRate,
  760. newRoom: FeeRate.getActivateFeeRateFileID(),
  761. name:'feeRate'
  762. };
  763. socket.emit('changeNewRoom',data);
  764. socketObject.roomInfo.feeRate = FeeRate.getActivateFeeRateFileID();
  765. $.bootstrapLoading.end();
  766. });
  767. },
  768. getChangeInfo:function () {
  769. var me = this;
  770. var callback=function (data) {
  771. me.changeInfo=data;
  772. me.loadChangePageContent(data);
  773. };
  774. projectObj.project.FeeRate.getChangeInfo(callback);
  775. },
  776. loadChangePageContent:function (data) {
  777. $('#currentProject').text(data.currentProject.name);
  778. $('#currentOptions').empty();
  779. _.forEach(data.currentProject.currentOptions,function (s) {
  780. var option = $("<option>").val(s.ID).text(s.name);
  781. $('#currentOptions').append(option);
  782. })
  783. $('#otherProject').empty();
  784. _.forEach(data.others,function (p) {
  785. var option = $("<option>").val(p.ID).text(p.name);
  786. $('#otherProject').append(option);
  787. });
  788. $('#otherFeeRateOption').empty();
  789. if(data.others.length>0){
  790. _.forEach(data.others[0].optionList,function (f) {
  791. var option = $("<option>").val(f.ID).text(f.name);
  792. $('#otherFeeRateOption').append(option);
  793. });
  794. }
  795. },
  796. changeFeeRateFileFromCurrent:function(){
  797. $.bootstrapLoading.start();
  798. var newVal = $("#currentOptions").val();
  799. if(!$("#currentOptions").val()){
  800. if($.bootstrapLoading.isLoading()){
  801. $.bootstrapLoading.end();
  802. }
  803. alert('费率文件不可为空');
  804. return;
  805. }
  806. if($("#currentOptions").val()==this.activateFeeRate.ID){
  807. return;
  808. }
  809. var name =$("#currentOptions").find("option:selected").text();
  810. var newFeeRateFile = {
  811. id:newVal,
  812. name:name
  813. }
  814. var callback=function () {
  815. feeRateObject.reFreshRateViews();
  816. projectObj.project.FeeRate.onFeeRateFileChange();
  817. $.bootstrapLoading.end();
  818. }
  819. projectObj.project.FeeRate.changeFeeRateFileFromCurrent(newFeeRateFile,callback);
  820. },
  821. changeFeeRateFileFromOthers:function () {
  822. var feeRateFileID = $("#otherFeeRateOption").val();
  823. var name =$("#otherFeeRateOption").find("option:selected").text();
  824. if(null===feeRateFileID){
  825. alert("请选择一个费率文件!");
  826. return;
  827. }
  828. var callback=function (data) {
  829. if(data){
  830. //$('#renameConfirm').attr("disabled","disabled");
  831. $('#renameError').text("本建设项目中已存在同名费率文件。").show();
  832. $('#rename-lv').modal('show');
  833. $("#newFeeRateID").val(feeRateFileID);
  834. $("#newFeeRateName").val(name);
  835. }else {
  836. //$('#renameConfirm').removeAttr("disabled");
  837. $('#renameError').hide();
  838. feeRateObject.changeFeeRateFileConfirm(feeRateFileID,name);
  839. }
  840. };
  841. projectObj.project.FeeRate.checkFeeRateName(name,callback);
  842. /* var currentOption = _.find(this.changeInfo.currentProject.currentOptions,{name:name})
  843. if(currentOption){
  844. $("#rename-lv").modal({show:true});
  845. $("#newFeeRateID").val(feeRateFileID);
  846. $("#newFeeRateName").val(name);
  847. }else {
  848. this.changeFeeRateFileConfirm(feeRateFileID,name);
  849. }*/
  850. },
  851. changeFeeRateFileConfirm:function(feeRateFileID,name){
  852. $.bootstrapLoading.start();
  853. var callback=function () {
  854. feeRateObject.reFreshRateViews();
  855. projectObj.project.FeeRate.onFeeRateFileChange();
  856. $.bootstrapLoading.end();
  857. }
  858. projectObj.project.FeeRate.changeFeeRateFileFromOthers(feeRateFileID,name,callback);
  859. },
  860. setFeeRateCellCol:function (sheet,col) {
  861. sheet.getRange(-1, col, -1, 1).cellType(this.getFeeRateEditCellType());
  862. },
  863. onCellClick:function (sender,args) {
  864. var data =projectObj.project.FeeRate.getActivateFeeRate().rates;
  865. feeRateObject.feeRateSelection=data[args.row];
  866. },
  867. onCellDoubleClick:function (sender,args) {
  868. var data =projectObj.project.FeeRate.getActivateFeeRate().rates;
  869. feeRateObject.feeRateSelection=data[args.row];
  870. feeRateObject.submitFeeRateBySelect();
  871. },
  872. checkSelectedFeeRate:function () {
  873. var validate = false;
  874. var data =projectObj.project.FeeRate.getActivateFeeRate().rates;
  875. if(feeRateObject.feeRateSelection!=null){
  876. var children=_.filter(data,{'ParentID':feeRateObject.feeRateSelection.ID});
  877. validate=children&&children.length==0;
  878. }
  879. return validate;
  880. },
  881. submitFeeRateFromBill:function () {
  882. var rate = feeRateObject.feeRateSelection;
  883. var selected = projectObj.project.mainTree.selected;
  884. if(selected.data.feeRateID === parseInt(rate.ID)) return $("#calcBaseFeeRate").modal('hide');
  885. $.bootstrapLoading.start();
  886. projectObj.project.FeeRate.submitFeeRateFromBill(rate,selected.data,function (data) {
  887. selected.data.feeRateID= parseInt(rate.ID);
  888. selected.data.feeRate=scMathUtil.roundToString(rate.rate,getDecimal("feeRate"));
  889. selected.changed = true;
  890. projectObj.project.calcProgram.calcAndSave(selected);
  891. $("#calcBaseFeeRate").modal('hide');
  892. $.bootstrapLoading.end();
  893. });
  894. },
  895. submitFeeRateFromCalc:function () {
  896. var rate = feeRateObject.feeRateSelection;
  897. var calInfo = calcProgramManage.getSelectionInfo();
  898. calInfo.calcItem.feeRateID=rate.ID;
  899. calInfo.calcItem.feeRate=null;
  900. var data={'projectID': projectObj.project.ID(),'templatesID': calInfo.template.ID,'calcItem': calInfo.calcItem};
  901. $.bootstrapLoading.start();
  902. calcProgramManage.saveCalcItem(data,function (result) {
  903. calInfo.calcItem.feeRate=rate.rate;
  904. projectObj.project.calcProgram.compileAllTemps();
  905. projectObj.project.calcProgram.calcAllNodesAndSave();
  906. calcProgramManage.refreshDetailSheet();
  907. $("#calcBaseFeeRate").modal('hide');
  908. $.bootstrapLoading.end();
  909. });
  910. console.log(calInfo);
  911. },
  912. submitFeeRateBySelect:function () {
  913. var validate = this.checkSelectedFeeRate();
  914. if(validate){
  915. if($('#edit_from').val()=='calc_detail'){
  916. this.submitFeeRateFromCalc();
  917. }else {
  918. this.submitFeeRateFromBill();
  919. }
  920. }else {
  921. //$("#fee_rate_tree").modal('hide');
  922. }
  923. }
  924. }
  925. function getPopoverContent() {
  926. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  927. var usageProjects = feeRateFile.usageProjects;
  928. let names = _.map(usageProjects,'name');
  929. let popover_content = names.join('<br>');
  930. return popover_content;
  931. }
  932. $(function(){
  933. $('#pop-lv').tooltip({
  934. placement:"bottom",
  935. html:true,
  936. trigger:"hover | focus",
  937. title:getPopoverContent
  938. }
  939. );
  940. $('#tab_fee_rate').on('shown.bs.tab', function (e) {
  941. sessionStorage.setItem('mainTab', '#tab_fee_rate');
  942. let me = feeRateObject;
  943. $(e.relatedTarget.hash).removeClass('active');
  944. if(me.mainFeeRateSpread == null) me.initFeeRateSpread(0);
  945. me.showMainFeeRateData();
  946. me.loadPageContent();
  947. });
  948. $('#setNewFeeRate').bind('click', function () {
  949. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  950. var usageProjects = feeRateFile.usageProjects;
  951. var listString ='';
  952. _.forEach(usageProjects,function (u) {
  953. listString+="<li>"+u.name+"</li>"
  954. })
  955. $("#usageProjectList").html(listString);
  956. $("#set-lv-feeRateName").text(feeRateFile.name);
  957. $("#set-use-feeRateName").text(feeRateFile.name);
  958. feeRateObject.getFeeRateStandards(function (data) {
  959. $('#standardSelect').empty();
  960. _.forEach(data,function (s) {
  961. var option = $("<option>").val(s.ID).text(s.libName);
  962. $('#standardSelect').append(option);
  963. })
  964. $('#standardSelect').val(feeRateFile.libID);
  965. });
  966. });
  967. $('#changeConfirm').bind('click', function (){
  968. var newVal=$('#standardSelect').val();
  969. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  970. if(newVal&&newVal!=feeRateFile.libID) feeRateObject.changeFeeRateStandard(newVal);
  971. });
  972. $('#saveAs').bind('click', function (){
  973. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  974. $('#copyFeeRateName').val(feeRateFile.name+'副本');
  975. $('#valid_name').val(feeRateFile.name+'副本');
  976. $('#nameError').hide();
  977. });
  978. $('#saveAsConfirm').bind('click',function () {
  979. feeRateObject.feeRateFileSaveAs($('#copyFeeRateName').val());
  980. })
  981. $('#copyFeeRateName').change(function () {
  982. feeRateObject.checkFeeRateName(this.value);
  983. });
  984. $('#newFeeRateName').change(function () {
  985. var newName = $(this).val();
  986. if(!newName||newName==""){
  987. //$('#renameConfirm').attr("disabled","disabled");
  988. $('#renameError').text("请输入文件名称。").show();
  989. return;
  990. }
  991. var callback=function (data) {
  992. if(data){
  993. //$('#renameConfirm').attr("disabled","disabled");
  994. $('#renameError').text("本建设项目中已存在同名费率文件。").show();
  995. }else {
  996. //$('#renameConfirm').removeAttr("disabled");
  997. $('#renameError').hide();
  998. }
  999. };
  1000. projectObj.project.FeeRate.checkFeeRateName(newName,callback);
  1001. });
  1002. $('#changeFeeRateConfirm').bind('click',function (){
  1003. var radioV= $("input[name='chaneg-lv-Radio']:checked").val();
  1004. if(radioV==='0'){
  1005. feeRateObject.changeFeeRateFileFromCurrent();
  1006. }else {
  1007. feeRateObject.changeFeeRateFileFromOthers();
  1008. }
  1009. })
  1010. $('#changFeeRateFile').bind('click',function (){
  1011. $("input[name='chaneg-lv-Radio']")[0].checked=true;
  1012. $("#fromProject").show();
  1013. $("#fromOther").hide();
  1014. feeRateObject.getChangeInfo();
  1015. })
  1016. $('#otherProject').change(function(){
  1017. var newVal = $(this).val();
  1018. var projects = feeRateObject.changeInfo.others;
  1019. var selected = _.find(projects,{ID:parseInt(newVal)});
  1020. $('#otherFeeRateOption').empty();
  1021. _.forEach(selected.optionList,function (f) {
  1022. var option = $("<option>").val(f.ID).text(f.name);
  1023. $('#otherFeeRateOption').append(option);
  1024. });
  1025. })
  1026. $('#renameConfirm').bind('click',function (){
  1027. var feeRateFileID= $("#newFeeRateID").val();
  1028. var name = $("#newFeeRateName").val();
  1029. var callback=function (data) {
  1030. if(data){
  1031. $('#renameError').text("已存在同名费率文件。").show();
  1032. $("#newFeeRateID").val(feeRateFileID);
  1033. $("#newFeeRateName").val(name);
  1034. }else {
  1035. $('#renameError').hide();
  1036. $('#rename-lv').modal('hide');
  1037. feeRateObject.changeFeeRateFileConfirm(feeRateFileID,name);
  1038. }
  1039. };
  1040. projectObj.project.FeeRate.checkFeeRateName(name,callback);
  1041. })
  1042. $('#inlineFormCustomSelect').change(function(){
  1043. var updateTask = [];
  1044. var selectID = $(this).val();
  1045. var oldValue=0;
  1046. _.forEach(projectObj.project.FeeRate.datas,function (feeRate) {
  1047. if(feeRate.status=='activate'){
  1048. oldValue=feeRate.ID;
  1049. }
  1050. if(feeRate.ID ==selectID){
  1051. feeRate.status='activate';
  1052. }else {
  1053. feeRate.status='disable';
  1054. }
  1055. updateTask.push({query:{ID:feeRate.feeRateID},doc:{status:feeRate.status}});
  1056. })
  1057. projectObj.project.FeeRate.updateStatusBySelected(updateTask);
  1058. feeRateObject.createSpreadView();
  1059. subRateObject.destorySpreadView();
  1060. socket.emit('changeActivateFeeRate',{oldRoom:oldValue,newRoom:selectID});
  1061. })
  1062. $('#calcBaseFeeRate').on('shown.bs.modal', function (e) {
  1063. let toggle = $('#calcBaseFeeRateConf').attr('toggle');
  1064. if(feeRateObject.feeRateSpreads==null){
  1065. feeRateObject.createSheet();
  1066. }
  1067. feeRateObject.feeRateSelection=null;
  1068. feeRateObject.showFeeRateTree(feeRateObject.feeRateSheet,feeRateObject.sheetSetting,projectObj.project.FeeRate.getActivateFeeRate().rates);
  1069. feeRateObject.locate();
  1070. feeRateObject.feeRateSpreads.refresh();
  1071. });
  1072. $('#tabFeeRate').on('shown.bs.tab', function () {
  1073. if(feeRateObject.feeRateSpreads){
  1074. feeRateObject.feeRateSpreads.refresh();
  1075. }
  1076. });
  1077. $('#calcBaseFeeRate').on('hidden.bs.modal', function (e) {
  1078. if(feeRateObject.feeRateSpreads){
  1079. feeRateObject.feeRateSpreads.destroy();
  1080. feeRateObject.feeRateSpreads=null;
  1081. $('#edit_from').val('');
  1082. $('#edit_row').val('');
  1083. }
  1084. });
  1085. //fee_selected_conf
  1086. $('#calcBaseFeeRateConf').bind('click',function (){
  1087. let toggle = $(this).attr('toggle');
  1088. if(!toggle || toggle !== 'feeRate'){
  1089. return;
  1090. }
  1091. feeRateObject.submitFeeRateBySelect();
  1092. })
  1093. })
  1094. function changeFRadioClick() {
  1095. var radioV= $("input[name='chaneg-lv-Radio']:checked").val();
  1096. if(radioV==='0'){
  1097. $("#fromProject").show();
  1098. $("#fromOther").hide();
  1099. }else {
  1100. $("#fromProject").hide();
  1101. $("#fromOther").show();
  1102. }
  1103. }