fee_rate_view.js 37 KB

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