fee_rate_view.js 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874
  1. /**
  2. * Created by chen on 2017/8/1.
  3. */
  4. var feeRateObject={
  5. mainViews:null,
  6. datas:null,
  7. datasBackup:null,
  8. canEdit:false,
  9. activateFeeRate:null,
  10. needCascadeSet:false,
  11. selectionLoad:false,
  12. changeInfo:null,
  13. feeRateSpreads:null,
  14. editingCell:null,
  15. feeRateSelection:null,
  16. sheetSetting: {
  17. header: [
  18. {headerName: "专业名称", headerWidth: 200, dataCode: "name", dataType: "String"},
  19. {headerName: "值%", headerWidth: 150, dataCode: "rate", dataType: "Number",hAlign: "right",decimalField:"feeRate"},
  20. {headerName: "备注", dataCode: "memo", dataType: "String"}
  21. ],
  22. view: {
  23. comboBox: [],
  24. lockColumns: [0, 1, 2]
  25. }
  26. },
  27. columns: [
  28. {
  29. id: 'name',
  30. caption: '专业名称',
  31. dataField: 'name',
  32. width: 450,
  33. allowEditing: false
  34. },
  35. {
  36. id: 'rate',
  37. caption: '值%',
  38. dataField: 'rate',
  39. width: 120,
  40. minWidth: 50,
  41. allowEditing: true
  42. },
  43. {
  44. id: 'memo',
  45. caption: '备注',
  46. dataField: 'memo',
  47. minWidth: 120,
  48. allowEditing: true
  49. },
  50. {
  51. id: 'ID',
  52. caption: 'ID',
  53. dataField: 'ID',
  54. width: 80,
  55. visible: false,
  56. allowEditing: false
  57. },
  58. {
  59. id: 'subFeeRate',
  60. caption: '子费率',
  61. dataField: 'subFeeRate',
  62. width: 80,
  63. visible: false,
  64. allowEditing: false
  65. },
  66. {
  67. id: '_id',
  68. caption: '自动ID',
  69. dataField: '_id',
  70. width: 80,
  71. visible: false,
  72. allowEditing: false
  73. },
  74. {
  75. id: 'ParentID',
  76. caption: '父结点ID',
  77. dataField: 'ParentID',
  78. width: 80,
  79. visible: false,
  80. allowEditing: false
  81. }
  82. ],
  83. options :{
  84. allowSorting: false,
  85. showRowHeader: true,
  86. colMinWidth: 80,
  87. rowHeight: 30,
  88. allowEditing: true,
  89. editMode: 'inline',
  90. editUnit: 'cell',
  91. selectionUnit: "row",
  92. hierarchy: {
  93. keyField: 'ID',
  94. parentField: 'ParentID',
  95. collapsed: false,
  96. column: 'name'
  97. }
  98. },
  99. dataSource : {
  100. loadRange: function(params) {
  101. params.success(feeRateObject.datas);
  102. },
  103. update: function(params) {
  104. if(!params.hasOwnProperty('sourceIndex')){
  105. var selected = feeRateObject.mainViews.getSelections()[0];
  106. params.sourceIndex = selected.sourceRow;
  107. }
  108. params.success();
  109. if(!$('#cascadeSet').prop('checked')||params.hasOwnProperty('viewIndex')){
  110. projectObj.project.FeeRate.updateFeeRateByEdit(params,feeRateObject.activateFeeRate);
  111. }
  112. }
  113. },
  114. createSheet:function(){
  115. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  116. feeRateObject.feeRateSpreads=sheetCommonObj.buildSheet($('#fee_rate_sheet')[0], feeRateObject.sheetSetting,feeRateFile.rates.length);
  117. feeRateObject.feeRateSheet = feeRateObject.feeRateSpreads.getSheet(0);
  118. feeRateObject.feeRateSheet.selectionUnit(1)//0 cell,1 row,2 col;
  119. feeRateObject.feeRateSheet.options.isProtected = true;
  120. feeRateObject.feeRateSheet.name('fee_rate');
  121. feeRateObject.feeRateSheet.bind(GC.Spread.Sheets.Events.CellClick,feeRateObject.onCellClick);
  122. feeRateObject.feeRateSheet.bind(GC.Spread.Sheets.Events.CellDoubleClick,feeRateObject.onCellDoubleClick);
  123. },
  124. showSelectTree:function () {
  125. var sheet= feeRateObject.feeRateSheet;
  126. var setting=feeRateObject.sheetSetting;
  127. var data = projectObj.project.FeeRate.getActivateFeeRate().rates;
  128. var ch = GC.Spread.Sheets.SheetArea.viewport;
  129. var groups=[];
  130. sheet.suspendPaint();
  131. sheet.suspendEvent();
  132. sheet.rowOutlines.direction(GC.Spread.Sheets.Outlines.OutlineDirection.backward);
  133. sheet.getRange(-1, 0, -1, 1).cellType(feeRateObject.getTreeNodeCellType());
  134. for (var col = 0; col < setting.header.length; col++) {
  135. var hAlign = "left", vAlign = "center";
  136. if (setting.header[col].hAlign) {
  137. hAlign = setting.header[col].hAlign;
  138. } else if (setting.header[col].dataType !== "String"){
  139. hAlign = "right";
  140. }
  141. vAlign = setting.header[col].vAlign?setting.header[col].vAlign:vAlign;
  142. sheetCommonObj.setAreaAlign(sheet.getRange(-1, col, -1, 1), hAlign, vAlign);
  143. if (setting.header[col].formatter) {
  144. sheet.setFormatter(-1, col, setting.header[col].formatter, GC.Spread.Sheets.SheetArea.viewport);
  145. }
  146. for (var row = 0; row < data.length; row++) {
  147. var val = data[row][setting.header[col].dataCode];
  148. if(val&&setting.header[col].dataType === "Number"){
  149. if(setting.header[col].hasOwnProperty('decimalField')){
  150. var decimal = getDecimal(setting.header[col].decimalField);
  151. val =scMathUtil.roundToString(val,decimal);
  152. sheet.setFormatter(-1, col,getFormatter(decimal), GC.Spread.Sheets.SheetArea.viewport);
  153. }else {
  154. val =scMathUtil.roundToString(val,2);
  155. }
  156. }
  157. sheet.setValue(row, col, val, ch);
  158. if(col==0){
  159. feeRateObject.setSheetGroup(data[row],data,groups,row+1);
  160. }
  161. }
  162. }
  163. //this.lockCells(sheet,setting);
  164. _.forEach(groups,function (g) {
  165. for(var k in g){
  166. sheet.rowOutlines.group(parseInt(k), g[k]);
  167. }
  168. })
  169. /* sheet.rowOutlines.group(1, 6);
  170. sheet.rowOutlines.group(8, 6);
  171. sheet.rowOutlines.group(15, 6);
  172. sheet.rowOutlines.group(22, 6);*/
  173. // sheet.getRange(-1, 0, -1, 1).width(300);
  174. sheet.showRowOutline(false);
  175. sheet.resumeEvent();
  176. sheet.resumePaint(false);
  177. },
  178. getTreeNodeCellType:function () {
  179. var ns = GC.Spread.Sheets;
  180. function TreeNodeCellType() {
  181. }
  182. TreeNodeCellType.prototype = new ns.CellTypes.Text();
  183. TreeNodeCellType.prototype.paint = function (ctx, value, x, y, w, h, style, options) {
  184. var level = options.sheet.rowOutlines.getLevel(options.row);
  185. var nlevel = -1;
  186. if (options.row < options.sheet.getRowCount() - 1) {
  187. nlevel = options.sheet.rowOutlines.getLevel(options.row + 1);
  188. }
  189. var hoffset = (level + 2) * 12;
  190. x += hoffset;
  191. w -= hoffset;
  192. GC.Spread.Sheets.CellTypes.Base.prototype.paint.apply(this, arguments);
  193. if (options.row == options.sheet.getRowCount() - 1) return; //last row
  194. if (nlevel > level) {
  195. var collapsed = options.sheet.rowOutlines.isCollapsed(options.row + 1);
  196. x--;
  197. y += h / 2 - 3;
  198. ctx.save();
  199. ctx.fillStyle = "black";
  200. ctx.beginPath();
  201. if (collapsed) {
  202. ctx.moveTo(x - 5, y);
  203. ctx.lineTo(x, y + 3);
  204. ctx.lineTo(x - 5, y + 6);
  205. } else {
  206. ctx.moveTo(x, y);
  207. ctx.lineTo(x, y + 5);
  208. ctx.lineTo(x - 5, y + 5);
  209. }
  210. ctx.fill();
  211. ctx.restore();
  212. }
  213. else {
  214. // x--;
  215. //y += h / 2 - 3;
  216. ctx.save();
  217. ctx.restore();
  218. }
  219. };
  220. // override getHitInfo to allow cell type get mouse messages
  221. TreeNodeCellType.prototype.getHitInfo = function (x, y, cellStyle, cellRect, context) {
  222. return {
  223. x: x,
  224. y: y,
  225. row: context.row,
  226. col: context.col,
  227. cellStyle: cellStyle,
  228. cellRect: cellRect,
  229. sheetArea: context.sheetArea
  230. };
  231. }
  232. TreeNodeCellType.prototype.processMouseDown = function (hitinfo) {
  233. var level = hitinfo.sheet.rowOutlines.getLevel(hitinfo.row);
  234. var hoffset = (level + 2) * 12 + hitinfo.cellRect.x;
  235. if (level==-1&&hitinfo.x < hoffset && hitinfo.x > hoffset - 10) {
  236. var collapsed = hitinfo.sheet.rowOutlines.isCollapsed(hitinfo.row + 1);
  237. hitinfo.sheet.rowOutlines.setCollapsed(hitinfo.row, !collapsed);
  238. hitinfo.sheet.invalidateLayout();
  239. hitinfo.sheet.repaint();
  240. }
  241. };
  242. return new TreeNodeCellType()
  243. },
  244. getFeeRateEditCellType:function () {
  245. var ns = GC.Spread.Sheets;
  246. function FeeRateEditCellType() {
  247. var init=false;
  248. }
  249. FeeRateEditCellType.prototype = new ns.CellTypes.Text();
  250. FeeRateEditCellType.prototype.paint = function (ctx, value, x, y, w, h, style, options) {
  251. // if(value!=null){
  252. // ctx.fillText(value,x+3+ctx.measureText(value).width,y+h-3);
  253. GC.Spread.Sheets.CellTypes.Text.prototype.paint.apply(this, arguments);
  254. // }
  255. if(feeRateObject.editingCell){
  256. if(feeRateObject.editingCell.row==options.row&&feeRateObject.editingCell.col==options.col){
  257. var image = document.getElementById('f_btn'),imageMagin = 3;
  258. var imageHeight = h-2*imageMagin;
  259. var imageWidth = w*2/7;
  260. var imageX = x + w - imageWidth- imageMagin, imageY = y + h / 2 - imageHeight / 2;
  261. ctx.save();
  262. ctx.drawImage(image, imageX, imageY,imageWidth,imageHeight);
  263. ctx.beginPath();
  264. ctx.arc(imageX+imageWidth/2,imageY+imageHeight/2,1,0,360,false);
  265. ctx.arc(imageX+imageWidth/2-4,imageY+imageHeight/2,1,0,360,false);
  266. ctx.arc(imageX+imageWidth/2+4,imageY+imageHeight/2,1,0,360,false);
  267. ctx.fillStyle="black";//填充颜色,默认是黑色
  268. ctx.fill();//画实心圆
  269. ctx.closePath();
  270. ctx.restore();
  271. }
  272. }
  273. };
  274. FeeRateEditCellType.prototype.getHitInfo = function (x, y, cellStyle, cellRect, context) {
  275. return {
  276. x: x,
  277. y: y,
  278. row: context.row,
  279. col: context.col,
  280. cellStyle: cellStyle,
  281. cellRect: cellRect,
  282. sheetArea: context.sheetArea
  283. };
  284. };
  285. FeeRateEditCellType.prototype.processMouseDown = function (hitinfo) {
  286. var me=feeRateObject;
  287. me.pmLeave = false;
  288. if(me.editingCell==null){
  289. var showSelectBtn = true;
  290. if(hitinfo.sheet.name()!='calc_detail'){
  291. showSelectBtn=me.ifFeeRateEdit();
  292. }
  293. if(showSelectBtn){
  294. me.editingCell={
  295. row:hitinfo.row,
  296. col:hitinfo.col
  297. }
  298. hitinfo.sheet.invalidateLayout();
  299. hitinfo.sheet.repaint();
  300. }
  301. }else if(hitinfo.row==me.editingCell.row){
  302. var offset=hitinfo.cellRect.x+hitinfo.cellRect.width-6;
  303. var imageMagin=3;
  304. var imageHeight = hitinfo.cellRect.height-2*imageMagin;
  305. var imageWidth = hitinfo.cellRect.width*2/7;
  306. if(hitinfo.x<offset&&hitinfo.x>offset-imageWidth){
  307. me.showSelectModal(hitinfo);
  308. }
  309. }
  310. };
  311. FeeRateEditCellType.prototype.processMouseLeave = function (hitinfo) {
  312. if(!feeRateObject.pmLeave){
  313. feeRateObject.editingCell=null;
  314. hitinfo.sheet.invalidateLayout();
  315. hitinfo.sheet.repaint();
  316. feeRateObject.pmLeave = true;
  317. }
  318. }
  319. return new FeeRateEditCellType();
  320. },
  321. showSelectModal:function (hitinfo) {
  322. $("#fee_rate_tree").modal({show:true});
  323. $('#edit_from').val(hitinfo.sheet.name());
  324. },
  325. setSheetGroup:function (rate,data,groups,row) {
  326. var me=this;
  327. var group={};
  328. var count=me.getChildrenCount(rate.ID,data);
  329. if(count>0){
  330. group[row]=count;
  331. groups.push(group);
  332. }
  333. return groups;
  334. },
  335. getChildrenCount:function (id,data) {
  336. var me=this;
  337. var sum=0;
  338. var children=_.filter(data,{'ParentID':id});
  339. if(children&&children.length==0){
  340. return 0;
  341. }
  342. for(var i=0;i<children.length;i++){
  343. sum+=me.getChildrenCount(children[i].ID,data);
  344. }
  345. return children.length+sum;
  346. },
  347. ifFeeRateEdit:function () {
  348. var selected = projectObj.project.mainTree.selected;
  349. return MainTreeCol.readOnly.forFeeRate(selected)?false:true;
  350. },
  351. createSpreadView:function () {
  352. if (this.mainViews) {
  353. this.mainViews.destroy();
  354. this.mainViews = null;
  355. }
  356. if(subRateObject.views){
  357. subRateObject.views.destroy();
  358. subRateObject.views = null;
  359. }
  360. this.activateFeeRate = projectObj.project.FeeRate.getActivateFeeRate();
  361. this.datas = this.activateFeeRate.rates;
  362. var rateColSetting = _.find(this.columns,{"id":"rate"});
  363. rateColSetting?rateColSetting.format=getFormatter(getDecimal("feeRate")):"";
  364. this.mainViews = new GC.Spread.Views.DataView($('#divFee')[0],
  365. this.dataSource, this.columns, new GC.Spread.Views.Plugins.GridLayout(this.options));
  366. this.mainViews["rowClick"].addHandler(subRateObject.reFreshRateViews);
  367. this.mainViews.invalidate();
  368. document.querySelector('#divFee').focus();
  369. },
  370. reFreshRateViews:function() {
  371. feeRateObject.createSpreadView();
  372. },
  373. updateBySelect:function (rate,selectMap,mapID) {
  374. var selected = this.mainViews.getSelections()[0];
  375. projectObj.project.FeeRate.backupDatas();
  376. var item = this.datas[selected.sourceRow];
  377. item.rate = rate;
  378. _.forEach(selectMap,function (value,key) {
  379. var recode = item.subFeeRate.recodes[key];
  380. var optionList = recode.optionList;
  381. _.forEach(optionList,function (o) {
  382. if(o.value==value){
  383. o.selected=true;
  384. }else {
  385. o.selected = false;
  386. }
  387. })
  388. })
  389. if($('#cascadeSet').prop('checked')){
  390. this.cascadeSetRates(item,selected.sourceRow,mapID,selectMap)
  391. }else {
  392. this.mainViews.data.updateItem(selected.sourceRow,item);
  393. }
  394. //projectObj.project.FeeRate.synchronizeFeeRate();
  395. //this.views.data.updateItem()
  396. },
  397. cascadeSetRates:function(selectedItem,sourceRow,mapID,selectMap){
  398. var items=[];
  399. items.push({rateIndex:sourceRow,rate:selectedItem});
  400. _.forEach(this.datas,function (recode,Index) {
  401. if(Index!=sourceRow&&recode.subFeeRate){
  402. var valueMaps = recode.subFeeRate.valueMaps;
  403. var valueMap = _.find(valueMaps,{ID:mapID});
  404. if(valueMap){//选项完全一样的情况
  405. if(valueMap.value==recode.rate){
  406. return;
  407. }else {
  408. recode.rate = valueMap.value;
  409. _.forEach(selectMap,function (value,key) {
  410. var tempRecode = recode.subFeeRate.recodes[key];
  411. var optionList = tempRecode.optionList;
  412. _.forEach(optionList,function (o) {
  413. if(o.value==value){
  414. o.selected=true;
  415. }else {
  416. o.selected = false;
  417. }
  418. })
  419. })
  420. items.push({rateIndex:Index,rate:recode});
  421. }
  422. }else {//某条选项一样的情况
  423. var needUpdate = false;
  424. var selectList = mapID.split('-');
  425. var newList=[];
  426. _.forEach(recode.subFeeRate.recodes,function (r) {
  427. var oList = r.optionList;
  428. var oldSelectIndex=0;
  429. var hasChange=false;
  430. _.forEach(oList,function (o,key) {
  431. if(o.selected){
  432. oldSelectIndex = key;
  433. }
  434. if(_.includes(selectList,o.value)){
  435. needUpdate=true;
  436. o.selected=true;
  437. hasChange=true;
  438. newList.push(o.value);
  439. }else {
  440. o.selected=false;
  441. }
  442. })
  443. if(!hasChange){
  444. oList[oldSelectIndex].selected=true;
  445. newList.push(oList[oldSelectIndex].value)
  446. }
  447. })
  448. if(needUpdate){
  449. var newValue = _.find(valueMaps,{ID:newList.join("-")})//取出费率值并更新
  450. if(newValue){
  451. if(recode.rate != newValue.value){
  452. recode.rate = newValue.value
  453. items.push({rateIndex:Index,rate:recode});
  454. }
  455. }
  456. }
  457. }
  458. }
  459. })
  460. projectObj.project.FeeRate.batchUpdateFeeRate(items,feeRateObject.activateFeeRate);
  461. },
  462. loadPageContent:function(){
  463. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  464. var usageProjects = feeRateFile.usageProjects;
  465. $('#feeRateFileName').text(feeRateFile.name);
  466. $('#feeRateLibName').text(feeRateFile.libName);
  467. $('#projectCount').text(usageProjects.length);
  468. },
  469. loadFeeRateSelection:function() {
  470. if(!this.selectionLoad){
  471. var selectedID=0;
  472. _.forEach(projectObj.project.FeeRate.datas,function (data) {
  473. var option = $("<option>").val(data.ID).text(data.libName);
  474. $('#inlineFormCustomSelect').append(option);
  475. if(data.status=='activate'){
  476. selectedID=data.ID;
  477. }
  478. })
  479. $('#inlineFormCustomSelect').val(selectedID);
  480. }
  481. },
  482. getFeeRateStandards:function (callback) {
  483. CommonAjax.post('/feeRates/getFeeRateStandards', {"projectID": projectObj.project.ID()}, function (data) {
  484. if (data) {
  485. callback(data);
  486. }
  487. });
  488. },
  489. changeFeeRateStandard:function(newVal){
  490. $.bootstrapLoading.start();
  491. var callback=function () {
  492. feeRateObject.createSpreadView();
  493. feeRateObject.loadPageContent();
  494. projectObj.project.FeeRate.synchronizeFeeRate();
  495. subRateObject.destorySpreadView();
  496. $.bootstrapLoading.end();
  497. };
  498. projectObj.project.FeeRate.changeFeeRateStandard(newVal,callback);
  499. },
  500. checkFeeRateName:function (newVal) {
  501. if(!newVal||newVal==""){
  502. $('#saveAsConfirm').attr("disabled","disabled");
  503. $('#nameError').text("请输入文件名称。").show();
  504. return;
  505. }
  506. var callback=function (data) {
  507. if(data){
  508. $('#saveAsConfirm').attr("disabled","disabled");
  509. $('#nameError').text("已存在同名费率文件。").show();
  510. $('#valid_name').val('');
  511. }else {
  512. $('#valid_name').val(newVal);
  513. $('#saveAsConfirm').removeAttr("disabled");
  514. $('#nameError').hide();
  515. }
  516. };
  517. projectObj.project.FeeRate.checkFeeRateName(newVal,callback);
  518. },
  519. feeRateFileSaveAs:function (newName) {
  520. if(!newName||newName==""){
  521. $('#saveAsConfirm').attr("disabled","disabled");
  522. $('#nameError').text("请输入文件名称。").show();
  523. return;
  524. }
  525. var valideName = $('#valid_name').val();
  526. if(valideName==''||valideName!==newName){
  527. var callback=function (data) {
  528. if(data){
  529. $('#saveAsConfirm').attr("disabled","disabled");
  530. $('#nameError').text("已存在同名费率文件。").show();
  531. $('#valid_name').val('');
  532. }else {
  533. feeRateObject.submitSaveAs(newName);
  534. }
  535. }
  536. projectObj.project.FeeRate.checkFeeRateName(newName,callback)
  537. }else {
  538. feeRateObject.submitSaveAs(newName);
  539. }
  540. },
  541. submitSaveAs:function (newName) {
  542. var me = this;
  543. projectObj.project.FeeRate.feeRateFileSaveAs(newName,function (result) {
  544. me.activateFeeRate = result;
  545. me.loadPageContent();
  546. $('#copy-lv').modal('hide');
  547. socket.emit('feeRateChangeNotify', projectObj.project.FeeRate.getActivateFeeRateFileID());
  548. $.bootstrapLoading.end();
  549. });
  550. },
  551. getChangeInfo:function () {
  552. var me = this;
  553. var callback=function (data) {
  554. me.changeInfo=data;
  555. me.loadChangePageContent(data);
  556. console.log(data);
  557. };
  558. projectObj.project.FeeRate.getChangeInfo(callback);
  559. },
  560. loadChangePageContent:function (data) {
  561. $('#currentProject').text(data.currentProject.name);
  562. $('#currentOptions').empty();
  563. _.forEach(data.currentProject.currentOptions,function (s) {
  564. var option = $("<option>").val(s.ID).text(s.name);
  565. $('#currentOptions').append(option);
  566. })
  567. $('#currentOptions').val(projectObj.project.FeeRate.getActivateFeeRateFileID());
  568. $('#otherProject').empty();
  569. _.forEach(data.others,function (p) {
  570. var option = $("<option>").val(p.ID).text(p.name);
  571. $('#otherProject').append(option);
  572. });
  573. $('#otherFeeRateOption').empty();
  574. if(data.others.length>0){
  575. _.forEach(data.others[0].optionList,function (f) {
  576. var option = $("<option>").val(f.ID).text(f.name);
  577. $('#otherFeeRateOption').append(option);
  578. });
  579. }
  580. },
  581. changeFeeRateFileFromCurrent:function(){
  582. $.bootstrapLoading.start();
  583. var newVal = $("#currentOptions").val();
  584. if($("#currentOptions").val()==this.activateFeeRate.ID){
  585. return;
  586. }
  587. var name =$("#currentOptions").find("option:selected").text();
  588. var newFeeRateFile = {
  589. id:newVal,
  590. name:name
  591. }
  592. var callback=function () {
  593. feeRateObject.createSpreadView();
  594. feeRateObject.loadPageContent();
  595. projectObj.project.FeeRate.onFeeRateFileChange();
  596. $.bootstrapLoading.end();
  597. }
  598. projectObj.project.FeeRate.changeFeeRateFileFromCurrent(newFeeRateFile,callback);
  599. },
  600. changeFeeRateFileFromOthers:function () {
  601. var feeRateFileID = $("#otherFeeRateOption").val();
  602. var name =$("#otherFeeRateOption").find("option:selected").text();
  603. if(null===feeRateFileID){
  604. alert("请选择一个费率文件!");
  605. return;
  606. }
  607. var currentOption = _.find(this.changeInfo.currentProject.currentOptions,{name:name})
  608. if(currentOption){
  609. $("#rename-lv").modal({show:true});
  610. $("#newFeeRateID").val(feeRateFileID);
  611. $("#newFeeRateName").val(name);
  612. }else {
  613. this.changeFeeRateFileConfirm(feeRateFileID,name);
  614. }
  615. },
  616. changeFeeRateFileConfirm:function(feeRateFileID,name){
  617. $.bootstrapLoading.start();
  618. var callback=function () {
  619. feeRateObject.createSpreadView();
  620. feeRateObject.loadPageContent();
  621. projectObj.project.FeeRate.onFeeRateFileChange();
  622. $.bootstrapLoading.end();
  623. }
  624. projectObj.project.FeeRate.changeFeeRateFileFromOthers(feeRateFileID,name,callback);
  625. },
  626. setFeeRateCellCol:function (sheet,col) {
  627. sheet.getRange(-1, col, -1, 1).cellType(this.getFeeRateEditCellType());
  628. },
  629. onCellClick:function (sender,args) {
  630. var data =projectObj.project.FeeRate.getActivateFeeRate().rates;
  631. feeRateObject.feeRateSelection=data[args.row];
  632. },
  633. onCellDoubleClick:function (sender,args) {
  634. var data =projectObj.project.FeeRate.getActivateFeeRate().rates;
  635. feeRateObject.feeRateSelection=data[args.row];
  636. feeRateObject.submitFeeRateBySelect();
  637. },
  638. checkSelectedFeeRate:function () {
  639. var validate = false;
  640. var data =projectObj.project.FeeRate.getActivateFeeRate().rates;
  641. if(feeRateObject.feeRateSelection!=null){
  642. var children=_.filter(data,{'ParentID':feeRateObject.feeRateSelection.ID});
  643. validate=children&&children.length==0;
  644. }
  645. return validate;
  646. },
  647. submitFeeRateFromBill:function () {
  648. var rate = feeRateObject.feeRateSelection;
  649. var selected = projectObj.project.mainTree.selected;
  650. $.bootstrapLoading.start();
  651. projectObj.project.FeeRate.submitFeeRateFromBill(rate,selected.data,function (data) {
  652. selected.data.feeRateID=rate.ID.toString();
  653. selected.data.feeRate=scMathUtil.roundToString(rate.rate,getDecimal("feeRate"));
  654. selected.changed = true;
  655. projectObj.project.calcProgram.calcAndSave(selected);
  656. //projectObj.mainController.refreshTreeNode([selected]);
  657. $("#fee_rate_tree").modal('hide');
  658. });
  659. },
  660. submitFeeRateFromCalc:function () {
  661. var rate = feeRateObject.feeRateSelection;
  662. var calInfo = calcProgramManage.getSelectionInfo();
  663. calInfo.calcItem.feeRateID=rate.ID;
  664. calInfo.calcItem.feeRate=null;
  665. var data={'projectID': projectObj.project.ID(),'templatesID': calInfo.template.ID,'calcItem': calInfo.calcItem};
  666. $.bootstrapLoading.start();
  667. calcProgramManage.saveCalcItem(data,function (result) {
  668. calInfo.calcItem.feeRate=rate.rate;
  669. projectObj.project.calcProgram.compileAllTemps();
  670. projectObj.project.calcProgram.calcAllNodesAndSave();
  671. calcProgramManage.refreshDetailSheet();
  672. $("#fee_rate_tree").modal('hide');
  673. });
  674. console.log(calInfo);
  675. },
  676. submitFeeRateBySelect:function () {
  677. var validate = this.checkSelectedFeeRate();
  678. if(validate){
  679. if($('#edit_from').val()=='calc_detail'){
  680. this.submitFeeRateFromCalc();
  681. }else {
  682. this.submitFeeRateFromBill();
  683. }
  684. }else {
  685. //$("#fee_rate_tree").modal('hide');
  686. }
  687. }
  688. }
  689. function getPopoverContent() {
  690. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  691. var usageProjects = feeRateFile.usageProjects;
  692. var popover_content = "";
  693. _.forEach(usageProjects,function (p,index) {
  694. if(index>0){
  695. popover_content+='<br>';
  696. }
  697. popover_content+=p.name;
  698. })
  699. return popover_content;
  700. }
  701. $(function(){
  702. $('#pop-lv').popover({
  703. placement:"bottom",
  704. html:true,
  705. trigger:"hover | focus",
  706. content:getPopoverContent
  707. }
  708. );
  709. $('#tab_fee_rate').on('shown.bs.tab', function (e) {
  710. $(e.relatedTarget.hash).removeClass('active');
  711. feeRateObject.reFreshRateViews();
  712. feeRateObject.loadPageContent();
  713. });
  714. $('#setNewFeeRate').bind('click', function () {
  715. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  716. var usageProjects = feeRateFile.usageProjects;
  717. var listString ='';
  718. _.forEach(usageProjects,function (u) {
  719. listString+="<li>"+u.name+"</li>"
  720. })
  721. $("#usageProjectList").html(listString);
  722. $("#set-lv-feeRateName").text(feeRateFile.name);
  723. $("#set-use-feeRateName").text(feeRateFile.name);
  724. feeRateObject.getFeeRateStandards(function (data) {
  725. $('#standardSelect').empty();
  726. _.forEach(data,function (s) {
  727. var option = $("<option>").val(s.ID).text(s.libName);
  728. $('#standardSelect').append(option);
  729. })
  730. $('#standardSelect').val(feeRateFile.libID);
  731. });
  732. });
  733. $('#changeConfirm').bind('click', function (){
  734. var newVal=$('#standardSelect').val();
  735. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  736. if(newVal&&newVal!=feeRateFile.libID){
  737. feeRateObject.changeFeeRateStandard(newVal);
  738. }
  739. });
  740. $('#saveAs').bind('click', function (){
  741. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  742. $('#copyFeeRateName').val(feeRateFile.name+'副本');
  743. $('#valid_name').val(feeRateFile.name+'副本');
  744. $('#nameError').hide();
  745. });
  746. $('#saveAsConfirm').bind('click',function () {
  747. feeRateObject.feeRateFileSaveAs($('#copyFeeRateName').val());
  748. })
  749. $('#copyFeeRateName').change(function () {
  750. feeRateObject.checkFeeRateName(this.value);
  751. });
  752. $('#newFeeRateName').change(function () {
  753. var newName = $(this).val();
  754. if(!newName||newName==""){
  755. $('#renameConfirm').attr("disabled","disabled");
  756. $('#renameError').text("请输入文件名称。").show();
  757. return;
  758. }
  759. var callback=function (data) {
  760. if(data){
  761. $('#renameConfirm').attr("disabled","disabled");
  762. $('#renameError').text("本建设项目中已存在同名费率文件。").show();
  763. }else {
  764. $('#renameConfirm').removeAttr("disabled");
  765. $('#renameError').hide();
  766. }
  767. };
  768. projectObj.project.FeeRate.checkFeeRateName(newName,callback);
  769. });
  770. $('#changeFeeRateConfirm').bind('click',function (){
  771. var radioV= $("input[name='chaneg-lv-Radio']:checked").val();
  772. if(radioV==='0'){
  773. feeRateObject.changeFeeRateFileFromCurrent();
  774. }else {
  775. feeRateObject.changeFeeRateFileFromOthers();
  776. }
  777. })
  778. $('#changFeeRateFile').bind('click',function (){
  779. $("input[name='chaneg-lv-Radio']")[0].checked=true;
  780. $("#fromProject").show();
  781. $("#fromOther").hide();
  782. feeRateObject.getChangeInfo();
  783. })
  784. $('#otherProject').change(function(){
  785. var newVal = $(this).val();
  786. var projects = feeRateObject.changeInfo.others;
  787. var selected = _.find(projects,{ID:parseInt(newVal)});
  788. $('#otherFeeRateOption').empty();
  789. _.forEach(selected.optionList,function (f) {
  790. var option = $("<option>").val(f.ID).text(f.name);
  791. $('#otherFeeRateOption').append(option);
  792. });
  793. })
  794. $('#renameConfirm').bind('click',function (){
  795. var feeRateFileID= $("#newFeeRateID").val();
  796. var name = $("#newFeeRateName").val();
  797. feeRateObject.changeFeeRateFileConfirm(feeRateFileID,name);
  798. })
  799. $('#inlineFormCustomSelect').change(function(){
  800. var updateTask = [];
  801. var selectID = $(this).val();
  802. var oldValue=0;
  803. _.forEach(projectObj.project.FeeRate.datas,function (feeRate) {
  804. if(feeRate.status=='activate'){
  805. oldValue=feeRate.ID;
  806. }
  807. if(feeRate.ID ==selectID){
  808. feeRate.status='activate';
  809. }else {
  810. feeRate.status='disable';
  811. }
  812. updateTask.push({query:{ID:feeRate.feeRateID},doc:{status:feeRate.status}});
  813. })
  814. projectObj.project.FeeRate.updateStatusBySelected(updateTask);
  815. feeRateObject.createSpreadView();
  816. subRateObject.destorySpreadView();
  817. socket.emit('changeActivateFeeRate',{oldRoom:oldValue,newRoom:selectID});
  818. })
  819. $('#fee_rate_tree').on('shown.bs.modal', function (e) {
  820. if(feeRateObject.feeRateSpreads==null){
  821. feeRateObject.createSheet();
  822. }
  823. feeRateObject.feeRateSelection=null;
  824. feeRateObject.showSelectTree();
  825. });
  826. $('#fee_rate_tree').on('hidden.bs.modal', function (e) {
  827. if(feeRateObject.feeRateSpreads){
  828. feeRateObject.feeRateSpreads.destroy();
  829. feeRateObject.feeRateSpreads=null;
  830. $('#edit_from').val('');
  831. $('#edit_row').val('');
  832. }
  833. });
  834. $('#fee_selected_conf').bind('click',function (){
  835. feeRateObject.submitFeeRateBySelect();
  836. })
  837. })
  838. function changeFRadioClick() {
  839. var radioV= $("input[name='chaneg-lv-Radio']:checked").val();
  840. if(radioV==='0'){
  841. $("#fromProject").show();
  842. $("#fromOther").hide();
  843. }else {
  844. $("#fromProject").hide();
  845. $("#fromOther").show();
  846. }
  847. }