fee_rate_view.js 42 KB

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