fee_rate_view.js 42 KB

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