fee_rate_view.js 32 KB

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