fee_rate_view.js 42 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081
  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. feeRateObject.feeRateSheet = feeRateObject.feeRateSpreads.getSheet(0);
  131. feeRateObject.feeRateSheet.selectionUnit(1)//0 cell,1 row,2 col;
  132. feeRateObject.feeRateSheet.options.isProtected = true;
  133. feeRateObject.feeRateSheet.name('fee_rate');
  134. feeRateObject.feeRateSheet.bind(GC.Spread.Sheets.Events.CellClick,feeRateObject.onCellClick);
  135. feeRateObject.feeRateSheet.bind(GC.Spread.Sheets.Events.CellDoubleClick,feeRateObject.onCellDoubleClick);
  136. },
  137. showSelectTree:function (sheet,setting,data) {
  138. var ch = GC.Spread.Sheets.SheetArea.viewport;
  139. var groups=[];
  140. sheet.suspendPaint();
  141. sheet.suspendEvent();
  142. sheet.rowOutlines.direction(GC.Spread.Sheets.Outlines.OutlineDirection.backward);
  143. sheet.getRange(-1, 0, -1, 1).cellType(feeRateObject.getTreeNodeCellType());
  144. for (var col = 0; col < setting.header.length; col++) {
  145. var 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 (var row = 0; row < data.length; row++) {
  157. var val = data[row][setting.header[col].dataCode];
  158. if(val&&setting.header[col].dataType === "Number"){
  159. if(setting.header[col].hasOwnProperty('decimalField')){
  160. var 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. feeRateObject.setSheetGroup(data[row],data,groups,row+1);
  170. }
  171. }
  172. }
  173. //this.lockCells(sheet,setting);
  174. _.forEach(groups,function (g) {
  175. for(var k in g){
  176. sheet.rowOutlines.group(parseInt(k), g[k]);
  177. }
  178. })
  179. /* sheet.rowOutlines.group(1, 6);
  180. sheet.rowOutlines.group(8, 6);
  181. sheet.rowOutlines.group(15, 6);
  182. sheet.rowOutlines.group(22, 6);*/
  183. // sheet.getRange(-1, 0, -1, 1).width(300);
  184. sheet.showRowOutline(false);
  185. // 默认折叠
  186. for (let i in data){
  187. if (!data[i].ParentID){
  188. sheet.rowOutlines.setCollapsed(parseFloat(i), true);
  189. };
  190. };
  191. sheet.resumeEvent();
  192. sheet.resumePaint(false);
  193. },
  194. locate: function(){ // CSL,2018.07.18
  195. let sheet = feeRateObject.feeRateSpreads.getSheet(0);
  196. let fID = calcProgramManage.getSelectionInfo().calcItem.feeRateID;
  197. let rates = projectObj.project.FeeRate.getActivateFeeRate().rates;
  198. let rowIdx = 0, pID = 0;
  199. if (fID){
  200. for (let i in rates) {
  201. if (rates[i].ID == fID){
  202. rowIdx = parseFloat(i);
  203. pID = rates[i].ParentID;
  204. break;
  205. };
  206. }
  207. };
  208. // 展开
  209. for (let i in rates){
  210. if (!rates[i].ParentID && (rates[i].ID == pID)){
  211. sheet.rowOutlines.setCollapsed(parseFloat(i), false);
  212. break;
  213. };
  214. };
  215. sheet.setSelection(rowIdx, -1, 1, -1);
  216. sheet.showRow(rowIdx, GC.Spread.Sheets.VerticalPosition.center);
  217. },
  218. getTreeNodeCellType:function () {
  219. var ns = GC.Spread.Sheets;
  220. function TreeNodeCellType() {
  221. }
  222. TreeNodeCellType.prototype = new ns.CellTypes.Text();
  223. TreeNodeCellType.prototype.paint = function (ctx, value, x, y, w, h, style, options) {
  224. var level = options.sheet.rowOutlines.getLevel(options.row);
  225. var nlevel = -1;
  226. if (options.row < options.sheet.getRowCount() - 1) {
  227. nlevel = options.sheet.rowOutlines.getLevel(options.row + 1);
  228. }
  229. var hoffset = (level + 2) * 12;
  230. x += hoffset;
  231. w -= hoffset;
  232. GC.Spread.Sheets.CellTypes.Base.prototype.paint.apply(this, arguments);
  233. if (options.row == options.sheet.getRowCount() - 1) return; //last row
  234. if (nlevel > level) {
  235. var collapsed = options.sheet.rowOutlines.isCollapsed(options.row + 1);
  236. x--;
  237. y += h / 2 - 3;
  238. ctx.save();
  239. ctx.fillStyle = "black";
  240. ctx.beginPath();
  241. if (collapsed) {
  242. ctx.moveTo(x - 5, y);
  243. ctx.lineTo(x, y + 3);
  244. ctx.lineTo(x - 5, y + 6);
  245. } else {
  246. ctx.moveTo(x, y);
  247. ctx.lineTo(x, y + 5);
  248. ctx.lineTo(x - 5, y + 5);
  249. }
  250. ctx.fill();
  251. ctx.restore();
  252. }
  253. else {
  254. // x--;
  255. //y += h / 2 - 3;
  256. ctx.save();
  257. ctx.restore();
  258. }
  259. };
  260. // override getHitInfo to allow cell type get mouse messages
  261. TreeNodeCellType.prototype.getHitInfo = function (x, y, cellStyle, cellRect, context) {
  262. return {
  263. x: x,
  264. y: y,
  265. row: context.row,
  266. col: context.col,
  267. cellStyle: cellStyle,
  268. cellRect: cellRect,
  269. sheetArea: context.sheetArea
  270. };
  271. }
  272. TreeNodeCellType.prototype.processMouseDown = function (hitinfo) {
  273. var level = hitinfo.sheet.rowOutlines.getLevel(hitinfo.row);
  274. var hoffset = (level + 2) * 12 + hitinfo.cellRect.x;
  275. if (level==-1&&hitinfo.x < hoffset && hitinfo.x > hoffset - 10) {
  276. var collapsed = hitinfo.sheet.rowOutlines.isCollapsed(hitinfo.row + 1);
  277. hitinfo.sheet.rowOutlines.setCollapsed(hitinfo.row, !collapsed);
  278. hitinfo.sheet.invalidateLayout();
  279. hitinfo.sheet.repaint();
  280. }
  281. };
  282. return new TreeNodeCellType()
  283. },
  284. getFeeRateEditCellType:function () {
  285. var ns = GC.Spread.Sheets;
  286. function FeeRateEditCellType() {
  287. var init=false;
  288. }
  289. FeeRateEditCellType.prototype = new ns.CellTypes.Text();
  290. FeeRateEditCellType.prototype.paint = function (ctx, value, x, y, w, h, style, options) {
  291. // if(value!=null){
  292. // ctx.fillText(value,x+3+ctx.measureText(value).width,y+h-3);
  293. GC.Spread.Sheets.CellTypes.Text.prototype.paint.apply(this, arguments);
  294. // }
  295. if(feeRateObject.editingCell && !projectReadOnly){
  296. if(feeRateObject.editingCell.row==options.row&&feeRateObject.editingCell.col==options.col){
  297. var image = document.getElementById('f_btn'),imageMagin = 3;
  298. var imageHeight = h-2*imageMagin;
  299. var imageWidth = w*2/7;
  300. var imageX = x + w - imageWidth- imageMagin, imageY = y + h / 2 - imageHeight / 2;
  301. ctx.save();
  302. ctx.drawImage(image, imageX, imageY,imageWidth,imageHeight);
  303. ctx.beginPath();
  304. ctx.arc(imageX+imageWidth/2,imageY+imageHeight/2,1,0,360,false);
  305. ctx.arc(imageX+imageWidth/2-4,imageY+imageHeight/2,1,0,360,false);
  306. ctx.arc(imageX+imageWidth/2+4,imageY+imageHeight/2,1,0,360,false);
  307. ctx.fillStyle="black";//填充颜色,默认是黑色
  308. ctx.fill();//画实心圆
  309. ctx.closePath();
  310. ctx.restore();
  311. }
  312. }
  313. };
  314. FeeRateEditCellType.prototype.getHitInfo = function (x, y, cellStyle, cellRect, context) {
  315. return {
  316. x: x,
  317. y: y,
  318. row: context.row,
  319. col: context.col,
  320. cellStyle: cellStyle,
  321. cellRect: cellRect,
  322. sheetArea: context.sheetArea
  323. };
  324. };
  325. FeeRateEditCellType.prototype.processMouseDown = function (hitinfo) {
  326. var me=feeRateObject;
  327. me.pmLeave = false;
  328. if(me.editingCell==null){
  329. var showSelectBtn = true;
  330. if(hitinfo.sheet.name()!='calc_detail'){
  331. showSelectBtn=me.ifFeeRateEdit();
  332. }
  333. if(showSelectBtn){
  334. me.editingCell={
  335. row:hitinfo.row,
  336. col:hitinfo.col
  337. }
  338. hitinfo.sheet.invalidateLayout();
  339. hitinfo.sheet.repaint();
  340. }
  341. }else if(hitinfo.row==me.editingCell.row){
  342. var offset=hitinfo.cellRect.x+hitinfo.cellRect.width-6;
  343. var imageMagin=3;
  344. var imageHeight = hitinfo.cellRect.height-2*imageMagin;
  345. var imageWidth = hitinfo.cellRect.width*2/7;
  346. if(hitinfo.x<offset&&hitinfo.x>offset-imageWidth){
  347. if(!projectReadOnly){
  348. me.showSelectModal(hitinfo);
  349. }
  350. }
  351. }
  352. };
  353. FeeRateEditCellType.prototype.processMouseLeave = function (hitinfo) {
  354. if(!feeRateObject.pmLeave){
  355. feeRateObject.editingCell=null;
  356. hitinfo.sheet.invalidateLayout();
  357. hitinfo.sheet.repaint();
  358. feeRateObject.pmLeave = true;
  359. }
  360. }
  361. return new FeeRateEditCellType();
  362. },
  363. showSelectModal:function (hitinfo) {
  364. //锁定的清单不显示
  365. let project = projectObj.project;
  366. if(project.isBillsLocked() && project.withinBillsLocked(project.mainTree.selected)){
  367. return;
  368. }
  369. $("#fee_rate_tree").modal({show:true});
  370. $('#edit_from').val(hitinfo.sheet.name());
  371. },
  372. setSheetGroup:function (rate,data,groups,row) {
  373. var me=this;
  374. var group={};
  375. var count=me.getChildrenCount(rate.ID,data);
  376. if(count>0){
  377. group[row]=count;
  378. groups.push(group);
  379. }
  380. return groups;
  381. },
  382. getChildrenCount:function (id,data) {
  383. var me=this;
  384. var sum=0;
  385. var children=_.filter(data,{'ParentID':id});
  386. if(children&&children.length==0){
  387. return 0;
  388. }
  389. for(var i=0;i<children.length;i++){
  390. sum+=me.getChildrenCount(children[i].ID,data);
  391. }
  392. return children.length+sum;
  393. },
  394. ifFeeRateEdit:function () {
  395. var selected = projectObj.project.mainTree.selected;
  396. return selected&&MainTreeCol.readOnly.forFeeRate(selected)?false:true;
  397. },
  398. createSpreadView:function () {
  399. if (this.mainViews) {
  400. this.mainViews.destroy();
  401. this.mainViews = null;
  402. }
  403. if(subRateObject.views){
  404. subRateObject.views.destroy();
  405. subRateObject.views = null;
  406. }
  407. this.activateFeeRate = projectObj.project.FeeRate.getActivateFeeRate();
  408. this.datas = this.activateFeeRate.rates;
  409. var rateColSetting = _.find(this.columns,{"id":"rate"});
  410. rateColSetting?rateColSetting.format=getFormatter(getDecimal("feeRate")):"";
  411. this.mainViews = new GC.Spread.Views.DataView($('#divFee')[0],
  412. this.dataSource, this.columns, new GC.Spread.Views.Plugins.GridLayout(this.options));
  413. this.mainViews["rowClick"].addHandler(subRateObject.reFreshRateViews);
  414. this.mainViews.invalidate();
  415. document.querySelector('#divFee').focus();
  416. },
  417. initFeeRateSpread:function (rowCount) {
  418. //初始化费用项表格
  419. this.mainFeeRateSpread = sheetCommonObj.buildSheet($('#divFee')[0], this.mainFeeRateSetting,rowCount);
  420. this.mainFeeRateSpread.options.scrollbarMaxAlign = true;
  421. this.mainFeeRateSheet = this.mainFeeRateSpread.getSheet(0);
  422. if(!projectReadOnly){
  423. sheetCommonObj.lockCells(this.mainFeeRateSheet , this.mainFeeRateSetting);
  424. }
  425. this.mainFeeRateSheet.bind(GC.Spread.Sheets.Events.ValueChanged, this.onMainFeeRateSheetValueChange);
  426. this.mainFeeRateSheet.bind(GC.Spread.Sheets.Events.SelectionChanged, this.onMainFeeRateSelectChanged);
  427. this.mainFeeRateSheet.bind(GC.Spread.Sheets.Events.RangeChanged, this.onMainFeeRateRangeChanged);
  428. this.mainFeeRateSheet.bind(GC.Spread.Sheets.Events.EditStarting, function (e,args) {
  429. let me =feeRateObject;
  430. if(!me.mainFeeRateEditChecking(args.row,args.col)){
  431. args.cancel = true;
  432. }
  433. });
  434. this.mainFeeRateSheet.name('mainFeeRateSheet');
  435. disableRightMenu("divFee",this.mainFeeRateSpread,this.rightClickCallback);
  436. //打开他人分享的项目、只读
  437. if(projectReadOnly){
  438. disableSpread(this.mainFeeRateSpread);
  439. }
  440. },
  441. rightClickCallback:function (row) {
  442. let me = feeRateObject;
  443. me.onMainFeeRateSelect(row);
  444. },
  445. showMainFeeRateData:function () {
  446. let me = this;
  447. let selected = me.mainFeeRateSheet.getSelections()[0];
  448. me.activateFeeRate = projectObj.project.FeeRate.getActivateFeeRate();
  449. me.mainFeeRateData = projectObj.project.FeeRate.getActivateFeeRate().rates;
  450. me.mainFeeRateSheet.setRowCount(0);
  451. me.mainFeeRateSheet.setRowCount(me.mainFeeRateData.length);
  452. me.showSelectTree(me.mainFeeRateSheet,me.mainFeeRateSetting,me.mainFeeRateData);
  453. me.mainFeeRateSheet.setSelection(selected.row,selected.col,selected.rowCount,selected.colCount);
  454. },
  455. reFreshRateViews:function() {
  456. //feeRateObject.createSpreadView();
  457. feeRateObject.loadPageContent();
  458. this.showMainFeeRateData();
  459. if(subRateObject.subRateSpread){//如果子费率没有初始化过的话,不需要显示。
  460. subRateObject.initSubRateSpread(this.mainFeeRateData[0]);
  461. }
  462. },
  463. mainFeeRateEditChecking:function (row,col) {//false 不能编辑,true 可以编辑
  464. let me =feeRateObject;
  465. let recode = me.mainFeeRateData[row];
  466. let dataCode = me.mainFeeRateSetting.header[col].dataCode;
  467. if(dataCode=="rate"&&me.getChildrenCount(recode.ID,me.mainFeeRateData)>0){//有子节点时不能编辑费率列
  468. return false;
  469. }
  470. return true;
  471. },
  472. onMainFeeRateSheetValueChange:function (e,info) {
  473. /* let me = feeRateObject,updateData = {},feeRate = projectObj.project.FeeRate;
  474. let recode = me.mainFeeRateData[info.row];
  475. let fieldID = me.mainFeeRateSetting.header[info.col].dataCode;
  476. let value = info.newValue;
  477. if(fieldID == 'rate'&&value != null){
  478. let checkResult = scMathUtil.isNumOrFormula(value);
  479. if(checkResult!=null){
  480. value = scMathUtil.roundForObj(checkResult,getDecimal("feeRate"));
  481. }else {
  482. alert('当前输入的数据类型不正确,请重新输入。');
  483. me.mainFeeRateSheet.setValue(info.row, info.col, info.oldValue);
  484. return;
  485. }
  486. }
  487. if(recode[fieldID] == value){//没有改变
  488. return;
  489. }
  490. updateData[fieldID] = value;
  491. $.bootstrapLoading.start();
  492. feeRate.updateFeeRateByID(recode.ID,updateData,function () {
  493. me.mainFeeRateSheet.setValue(info.row, info.col, value);
  494. if(fieldID == 'rate'){
  495. feeRate.onFeeRateChange(recode.ID,value);
  496. }
  497. $.bootstrapLoading.end();
  498. })*/
  499. feeRateObject.updateFeerateWhenCellsChange([info]);
  500. },
  501. onMainFeeRateRangeChanged:function (e,info) {
  502. let me = feeRateObject;
  503. let changeCells = [];
  504. for(let c of info.changedCells){
  505. let tem = {
  506. row:c.row,
  507. col:c.col,
  508. newValue:info.sheet.getCell(c.row,c.col).value()
  509. };
  510. changeCells.push(tem);
  511. }
  512. me.updateFeerateWhenCellsChange(changeCells);
  513. },
  514. updateFeerateWhenCellsChange:function (cells) {// col,row,newValue
  515. let me = feeRateObject,updateDatas = [],feeRate = projectObj.project.FeeRate;//[{rateID:rateID,doc:doc}]
  516. let refreshA = [];//记录刷新条数的数组
  517. for(let c of cells){
  518. let temData = {};
  519. let recode = me.mainFeeRateData[c.row];
  520. let fieldID = me.mainFeeRateSetting.header[c.col].dataCode;
  521. let value = c.newValue;
  522. let oldValue = recode[fieldID];
  523. if(!me.mainFeeRateEditChecking(c.row, c.col)){
  524. me.mainFeeRateSheet.setValue(c.row, c.col, oldValue);
  525. continue;
  526. }else if(fieldID == 'rate'&&value != null){
  527. let checkResult = scMathUtil.isNumOrFormula(value);
  528. if(checkResult!=null && !isNaN(checkResult)){
  529. value = scMathUtil.roundForObj(checkResult,getDecimal("feeRate"));
  530. }else {
  531. setTimeout(function () {
  532. alert('当前输入的数据类型不正确,请重新输入。');
  533. },100);
  534. me.mainFeeRateSheet.setValue(c.row, c.col, oldValue);
  535. continue;
  536. }
  537. }
  538. if(recode[fieldID] == value){//没有改变
  539. continue;
  540. }
  541. temData[fieldID] = value ;
  542. updateDatas.push({rateID:recode.ID,doc:temData});
  543. refreshA.push({col:c.col,row:c.row,fieldID:fieldID,value:value,rateID:recode.ID});
  544. }
  545. if(updateDatas.length > 0){
  546. $.bootstrapLoading.start();
  547. feeRate.updateFeeRatesByIDs(updateDatas,function () {
  548. let feerateInfo = [];
  549. for(let r of refreshA){
  550. me.mainFeeRateSheet.setValue(r.row, r.col, r.value);
  551. if(r.fieldID == 'rate'){
  552. feerateInfo.push({rateID:r.rateID,value:r.value});
  553. }
  554. }
  555. feerateInfo.length > 0 ?feeRate.onFeeRatesChange(feerateInfo):'';
  556. $.bootstrapLoading.end();
  557. })
  558. }
  559. },
  560. onMainFeeRateSelectChanged:function (e, info) {
  561. let me = feeRateObject;
  562. let row = info.newSelections[0].row;
  563. me.onMainFeeRateSelect(row);
  564. },
  565. onMainFeeRateSelect:function (row) {
  566. let me = this;
  567. if(row!=-1){
  568. subRateObject.initSubRateSpread(me.mainFeeRateData[row]);
  569. }
  570. },
  571. updateBySelect:function (rate,selectMap,mapID) {
  572. let selected = this.mainFeeRateSheet.getSelections()[0];
  573. projectObj.project.FeeRate.backupDatas();
  574. let item = this.mainFeeRateData[selected.row];
  575. item.rate = rate;
  576. for(let key in selectMap){
  577. let recode = item.subFeeRate.recodes[key];
  578. let optionList = recode.optionList;
  579. for(let o of optionList){
  580. if(o.value==selectMap[key]){
  581. o.selected=true;
  582. }else {
  583. o.selected = false;
  584. }
  585. }
  586. }
  587. if($('#cascadeSet').prop('checked')){
  588. this.cascadeSetRates(item,selected.row,mapID,selectMap);
  589. }else {
  590. projectObj.project.FeeRate.batchUpdateFeeRate([{rateIndex:selected.row,rate:item}],feeRateObject.activateFeeRate);
  591. }
  592. },
  593. cascadeSetRates:function(selectedItem,sourceRow,mapID,selectMap){
  594. let items=[];
  595. items.push({rateIndex:sourceRow,rate:selectedItem});
  596. _.forEach(this.mainFeeRateData,function (recode,Index) {
  597. if(Index!=sourceRow&&recode.subFeeRate){
  598. let valueMaps = recode.subFeeRate.valueMaps;
  599. let valueMap = _.find(valueMaps,{ID:mapID});
  600. if(valueMap){//选项完全一样的情况
  601. if(valueMap.value==recode.rate){
  602. return;
  603. }else {
  604. recode.rate = valueMap.value;
  605. _.forEach(selectMap,function (value,key) {
  606. let tempRecode = recode.subFeeRate.recodes[key];
  607. let optionList = tempRecode.optionList;
  608. _.forEach(optionList,function (o) {
  609. if(o.value==value){
  610. o.selected = true;
  611. }else {
  612. o.selected = false;
  613. }
  614. })
  615. });
  616. items.push({rateIndex:Index,rate:recode});
  617. }
  618. }else {//某条选项一样的情况
  619. let needUpdate = false;
  620. let selectList = mapID.split('-');
  621. let newList=[];
  622. _.forEach(recode.subFeeRate.recodes,function (r) {
  623. let oList = r.optionList;
  624. let oldSelectIndex=0;
  625. let hasChange=false;
  626. _.forEach(oList,function (o,key) {
  627. if(o.selected){
  628. oldSelectIndex = key;
  629. }
  630. if(_.includes(selectList,o.value)){
  631. needUpdate=true;
  632. o.selected=true;
  633. hasChange=true;
  634. newList.push(o.value);
  635. }else {
  636. o.selected=false;
  637. }
  638. });
  639. if(!hasChange){
  640. oList[oldSelectIndex].selected=true;
  641. newList.push(oList[oldSelectIndex].value)
  642. }
  643. });
  644. if(needUpdate){
  645. let newValue = _.find(valueMaps,{ID:newList.join("-")})//取出费率值并更新
  646. if(newValue){
  647. if(recode.rate != newValue.value){
  648. recode.rate = newValue.value
  649. items.push({rateIndex:Index,rate:recode});
  650. }
  651. }
  652. }
  653. }
  654. }
  655. });
  656. projectObj.project.FeeRate.batchUpdateFeeRate(items,feeRateObject.activateFeeRate);
  657. },
  658. loadPageContent:function(){
  659. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  660. var usageProjects = feeRateFile.usageProjects;
  661. $('#feeRateFileName').text(feeRateFile.name);
  662. $('#feeRateLibName').text(feeRateFile.libName);
  663. $('#projectCount').text(usageProjects.length);
  664. },
  665. loadFeeRateSelection:function() {
  666. if(!this.selectionLoad){
  667. var selectedID=0;
  668. _.forEach(projectObj.project.FeeRate.datas,function (data) {
  669. var option = $("<option>").val(data.ID).text(data.libName);
  670. $('#inlineFormCustomSelect').append(option);
  671. if(data.status=='activate'){
  672. selectedID=data.ID;
  673. }
  674. })
  675. $('#inlineFormCustomSelect').val(selectedID);
  676. }
  677. },
  678. getFeeRateStandards:function (callback) {
  679. CommonAjax.post('/feeRates/getFeeRateStandards', {"projectID": projectObj.project.ID()}, function (data) {
  680. if (data) {
  681. callback(data);
  682. }
  683. });
  684. },
  685. changeFeeRateStandard:function(newVal){
  686. $.bootstrapLoading.start();
  687. var callback=function () {
  688. feeRateObject.reFreshRateViews();
  689. projectObj.project.FeeRate.onFeeRateFileChange();
  690. $.bootstrapLoading.end();
  691. };
  692. projectObj.project.FeeRate.changeFeeRateStandard(newVal,callback);
  693. },
  694. checkFeeRateName:function (newVal) {
  695. if(!newVal||newVal==""){
  696. $('#saveAsConfirm').attr("disabled","disabled");
  697. $('#nameError').text("请输入文件名称。").show();
  698. return;
  699. }
  700. var callback=function (data) {
  701. if(data){
  702. $('#saveAsConfirm').attr("disabled","disabled");
  703. $('#nameError').text("已存在同名费率文件。").show();
  704. $('#valid_name').val('');
  705. }else {
  706. $('#valid_name').val(newVal);
  707. $('#saveAsConfirm').removeAttr("disabled");
  708. $('#nameError').hide();
  709. }
  710. };
  711. projectObj.project.FeeRate.checkFeeRateName(newVal,callback);
  712. },
  713. feeRateFileSaveAs:function (newName) {
  714. if(!newName||newName==""){
  715. $('#saveAsConfirm').attr("disabled","disabled");
  716. $('#nameError').text("请输入文件名称。").show();
  717. return;
  718. }
  719. var valideName = $('#valid_name').val();
  720. if(valideName==''||valideName!==newName){
  721. var callback=function (data) {
  722. if(data){
  723. $('#saveAsConfirm').attr("disabled","disabled");
  724. $('#nameError').text("已存在同名费率文件。").show();
  725. $('#valid_name').val('');
  726. }else {
  727. feeRateObject.submitSaveAs(newName);
  728. }
  729. }
  730. projectObj.project.FeeRate.checkFeeRateName(newName,callback);
  731. }else {
  732. feeRateObject.submitSaveAs(newName);
  733. }
  734. },
  735. submitSaveAs:function (newName) {
  736. var me = this;
  737. projectObj.project.FeeRate.feeRateFileSaveAs(newName,function (result) {
  738. me.activateFeeRate = result;
  739. me.loadPageContent();
  740. $('#copy-lv').modal('hide');
  741. socket.emit('feeRateChangeNotify', projectObj.project.FeeRate.getActivateFeeRateFileID());
  742. $.bootstrapLoading.end();
  743. });
  744. },
  745. getChangeInfo:function () {
  746. var me = this;
  747. var callback=function (data) {
  748. me.changeInfo=data;
  749. me.loadChangePageContent(data);
  750. console.log(data);
  751. };
  752. projectObj.project.FeeRate.getChangeInfo(callback);
  753. },
  754. loadChangePageContent:function (data) {
  755. $('#currentProject').text(data.currentProject.name);
  756. $('#currentOptions').empty();
  757. _.forEach(data.currentProject.currentOptions,function (s) {
  758. var option = $("<option>").val(s.ID).text(s.name);
  759. $('#currentOptions').append(option);
  760. })
  761. $('#currentOptions').val(projectObj.project.FeeRate.getActivateFeeRateFileID());
  762. $('#otherProject').empty();
  763. _.forEach(data.others,function (p) {
  764. var option = $("<option>").val(p.ID).text(p.name);
  765. $('#otherProject').append(option);
  766. });
  767. $('#otherFeeRateOption').empty();
  768. if(data.others.length>0){
  769. _.forEach(data.others[0].optionList,function (f) {
  770. var option = $("<option>").val(f.ID).text(f.name);
  771. $('#otherFeeRateOption').append(option);
  772. });
  773. }
  774. },
  775. changeFeeRateFileFromCurrent:function(){
  776. $.bootstrapLoading.start();
  777. var newVal = $("#currentOptions").val();
  778. if($("#currentOptions").val()==this.activateFeeRate.ID){
  779. return;
  780. }
  781. var name =$("#currentOptions").find("option:selected").text();
  782. var newFeeRateFile = {
  783. id:newVal,
  784. name:name
  785. }
  786. var callback=function () {
  787. //feeRateObject.createSpreadView();
  788. feeRateObject.reFreshRateViews();
  789. projectObj.project.FeeRate.onFeeRateFileChange();
  790. $.bootstrapLoading.end();
  791. }
  792. projectObj.project.FeeRate.changeFeeRateFileFromCurrent(newFeeRateFile,callback);
  793. },
  794. changeFeeRateFileFromOthers:function () {
  795. var feeRateFileID = $("#otherFeeRateOption").val();
  796. var name =$("#otherFeeRateOption").find("option:selected").text();
  797. if(null===feeRateFileID){
  798. alert("请选择一个费率文件!");
  799. return;
  800. }
  801. var currentOption = _.find(this.changeInfo.currentProject.currentOptions,{name:name})
  802. if(currentOption){
  803. $("#rename-lv").modal({show:true});
  804. $("#newFeeRateID").val(feeRateFileID);
  805. $("#newFeeRateName").val(name);
  806. }else {
  807. this.changeFeeRateFileConfirm(feeRateFileID,name);
  808. }
  809. },
  810. changeFeeRateFileConfirm:function(feeRateFileID,name){
  811. $.bootstrapLoading.start();
  812. var callback=function () {
  813. feeRateObject.reFreshRateViews();
  814. projectObj.project.FeeRate.onFeeRateFileChange();
  815. $.bootstrapLoading.end();
  816. }
  817. projectObj.project.FeeRate.changeFeeRateFileFromOthers(feeRateFileID,name,callback);
  818. },
  819. setFeeRateCellCol:function (sheet,col) {
  820. sheet.getRange(-1, col, -1, 1).cellType(this.getFeeRateEditCellType());
  821. },
  822. onCellClick:function (sender,args) {
  823. var data =projectObj.project.FeeRate.getActivateFeeRate().rates;
  824. feeRateObject.feeRateSelection=data[args.row];
  825. },
  826. onCellDoubleClick:function (sender,args) {
  827. var data =projectObj.project.FeeRate.getActivateFeeRate().rates;
  828. feeRateObject.feeRateSelection=data[args.row];
  829. feeRateObject.submitFeeRateBySelect();
  830. },
  831. checkSelectedFeeRate:function () {
  832. var validate = false;
  833. var data =projectObj.project.FeeRate.getActivateFeeRate().rates;
  834. if(feeRateObject.feeRateSelection!=null){
  835. var children=_.filter(data,{'ParentID':feeRateObject.feeRateSelection.ID});
  836. validate=children&&children.length==0;
  837. }
  838. return validate;
  839. },
  840. submitFeeRateFromBill:function () {
  841. var rate = feeRateObject.feeRateSelection;
  842. var selected = projectObj.project.mainTree.selected;
  843. $.bootstrapLoading.start();
  844. projectObj.project.FeeRate.submitFeeRateFromBill(rate,selected.data,function (data) {
  845. selected.data.feeRateID=rate.ID.toString();
  846. selected.data.feeRate=scMathUtil.roundToString(rate.rate,getDecimal("feeRate"));
  847. selected.changed = true;
  848. projectObj.project.calcProgram.calcAndSave(selected);
  849. //projectObj.mainController.refreshTreeNode([selected]);
  850. $("#fee_rate_tree").modal('hide');
  851. $.bootstrapLoading.end();
  852. });
  853. },
  854. submitFeeRateFromCalc:function () {
  855. var rate = feeRateObject.feeRateSelection;
  856. var calInfo = calcProgramManage.getSelectionInfo();
  857. calInfo.calcItem.feeRateID=rate.ID;
  858. calInfo.calcItem.feeRate=null;
  859. var data={'projectID': projectObj.project.ID(),'templatesID': calInfo.template.ID,'calcItem': calInfo.calcItem};
  860. $.bootstrapLoading.start();
  861. calcProgramManage.saveCalcItem(data,function (result) {
  862. calInfo.calcItem.feeRate=rate.rate;
  863. projectObj.project.calcProgram.compileAllTemps();
  864. projectObj.project.calcProgram.calcAllNodesAndSave();
  865. calcProgramManage.refreshDetailSheet();
  866. $("#fee_rate_tree").modal('hide');
  867. $.bootstrapLoading.end();
  868. });
  869. console.log(calInfo);
  870. },
  871. submitFeeRateBySelect:function () {
  872. var validate = this.checkSelectedFeeRate();
  873. if(validate){
  874. if($('#edit_from').val()=='calc_detail'){
  875. this.submitFeeRateFromCalc();
  876. }else {
  877. this.submitFeeRateFromBill();
  878. }
  879. }else {
  880. //$("#fee_rate_tree").modal('hide');
  881. }
  882. }
  883. }
  884. function getPopoverContent() {
  885. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  886. var usageProjects = feeRateFile.usageProjects;
  887. var popover_content = "";
  888. _.forEach(usageProjects,function (p,index) {
  889. if(index>0){
  890. popover_content+='<br>';
  891. }
  892. popover_content+=p.name;
  893. })
  894. return popover_content;
  895. }
  896. $(function(){
  897. $('#pop-lv').popover({
  898. placement:"bottom",
  899. html:true,
  900. trigger:"hover | focus",
  901. content:getPopoverContent
  902. }
  903. );
  904. $('#tab_fee_rate').on('shown.bs.tab', function (e) {
  905. sessionStorage.setItem('mainTab', '#tab_fee_rate');
  906. let me = feeRateObject;
  907. $(e.relatedTarget.hash).removeClass('active');
  908. if(me.mainFeeRateSpread == null){
  909. me.initFeeRateSpread(0);
  910. }
  911. me.showMainFeeRateData();
  912. me.loadPageContent();
  913. });
  914. $('#setNewFeeRate').bind('click', function () {
  915. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  916. var usageProjects = feeRateFile.usageProjects;
  917. var listString ='';
  918. _.forEach(usageProjects,function (u) {
  919. listString+="<li>"+u.name+"</li>"
  920. })
  921. $("#usageProjectList").html(listString);
  922. $("#set-lv-feeRateName").text(feeRateFile.name);
  923. $("#set-use-feeRateName").text(feeRateFile.name);
  924. feeRateObject.getFeeRateStandards(function (data) {
  925. $('#standardSelect').empty();
  926. _.forEach(data,function (s) {
  927. var option = $("<option>").val(s.ID).text(s.libName);
  928. $('#standardSelect').append(option);
  929. })
  930. $('#standardSelect').val(feeRateFile.libID);
  931. });
  932. });
  933. $('#changeConfirm').bind('click', function (){
  934. var newVal=$('#standardSelect').val();
  935. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  936. if(newVal&&newVal!=feeRateFile.libID){
  937. feeRateObject.changeFeeRateStandard(newVal);
  938. }
  939. });
  940. $('#saveAs').bind('click', function (){
  941. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  942. $('#copyFeeRateName').val(feeRateFile.name+'副本');
  943. $('#valid_name').val(feeRateFile.name+'副本');
  944. $('#nameError').hide();
  945. });
  946. $('#saveAsConfirm').bind('click',function () {
  947. feeRateObject.feeRateFileSaveAs($('#copyFeeRateName').val());
  948. })
  949. $('#copyFeeRateName').change(function () {
  950. feeRateObject.checkFeeRateName(this.value);
  951. });
  952. $('#newFeeRateName').change(function () {
  953. var newName = $(this).val();
  954. if(!newName||newName==""){
  955. $('#renameConfirm').attr("disabled","disabled");
  956. $('#renameError').text("请输入文件名称。").show();
  957. return;
  958. }
  959. var callback=function (data) {
  960. if(data){
  961. $('#renameConfirm').attr("disabled","disabled");
  962. $('#renameError').text("本建设项目中已存在同名费率文件。").show();
  963. }else {
  964. $('#renameConfirm').removeAttr("disabled");
  965. $('#renameError').hide();
  966. }
  967. };
  968. projectObj.project.FeeRate.checkFeeRateName(newName,callback);
  969. });
  970. $('#changeFeeRateConfirm').bind('click',function (){
  971. var radioV= $("input[name='chaneg-lv-Radio']:checked").val();
  972. if(radioV==='0'){
  973. feeRateObject.changeFeeRateFileFromCurrent();
  974. }else {
  975. feeRateObject.changeFeeRateFileFromOthers();
  976. }
  977. })
  978. $('#changFeeRateFile').bind('click',function (){
  979. $("input[name='chaneg-lv-Radio']")[0].checked=true;
  980. $("#fromProject").show();
  981. $("#fromOther").hide();
  982. feeRateObject.getChangeInfo();
  983. })
  984. $('#otherProject').change(function(){
  985. var newVal = $(this).val();
  986. var projects = feeRateObject.changeInfo.others;
  987. var selected = _.find(projects,{ID:parseInt(newVal)});
  988. $('#otherFeeRateOption').empty();
  989. _.forEach(selected.optionList,function (f) {
  990. var option = $("<option>").val(f.ID).text(f.name);
  991. $('#otherFeeRateOption').append(option);
  992. });
  993. })
  994. $('#renameConfirm').bind('click',function (){
  995. var feeRateFileID= $("#newFeeRateID").val();
  996. var name = $("#newFeeRateName").val();
  997. feeRateObject.changeFeeRateFileConfirm(feeRateFileID,name);
  998. })
  999. $('#inlineFormCustomSelect').change(function(){
  1000. var updateTask = [];
  1001. var selectID = $(this).val();
  1002. var oldValue=0;
  1003. _.forEach(projectObj.project.FeeRate.datas,function (feeRate) {
  1004. if(feeRate.status=='activate'){
  1005. oldValue=feeRate.ID;
  1006. }
  1007. if(feeRate.ID ==selectID){
  1008. feeRate.status='activate';
  1009. }else {
  1010. feeRate.status='disable';
  1011. }
  1012. updateTask.push({query:{ID:feeRate.feeRateID},doc:{status:feeRate.status}});
  1013. })
  1014. projectObj.project.FeeRate.updateStatusBySelected(updateTask);
  1015. feeRateObject.createSpreadView();
  1016. subRateObject.destorySpreadView();
  1017. socket.emit('changeActivateFeeRate',{oldRoom:oldValue,newRoom:selectID});
  1018. })
  1019. $('#fee_rate_tree').on('shown.bs.modal', function (e) {
  1020. if(feeRateObject.feeRateSpreads==null){
  1021. feeRateObject.createSheet();
  1022. }
  1023. feeRateObject.feeRateSelection=null;
  1024. feeRateObject.showSelectTree(feeRateObject.feeRateSheet,feeRateObject.sheetSetting,projectObj.project.FeeRate.getActivateFeeRate().rates);
  1025. feeRateObject.locate();
  1026. });
  1027. $('#fee_rate_tree').on('hidden.bs.modal', function (e) {
  1028. if(feeRateObject.feeRateSpreads){
  1029. feeRateObject.feeRateSpreads.destroy();
  1030. feeRateObject.feeRateSpreads=null;
  1031. $('#edit_from').val('');
  1032. $('#edit_row').val('');
  1033. }
  1034. });
  1035. $('#fee_selected_conf').bind('click',function (){
  1036. feeRateObject.submitFeeRateBySelect();
  1037. })
  1038. })
  1039. function changeFRadioClick() {
  1040. var radioV= $("input[name='chaneg-lv-Radio']:checked").val();
  1041. if(radioV==='0'){
  1042. $("#fromProject").show();
  1043. $("#fromOther").hide();
  1044. }else {
  1045. $("#fromProject").hide();
  1046. $("#fromOther").show();
  1047. }
  1048. }