fee_rate_view.js 32 KB

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