fee_rate_view.js 42 KB

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