fee_rate_view.js 50 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195
  1. /**
  2. * Created by chen on 2017/8/1.
  3. */
  4. var feeRateObject={
  5. mainFeeRateSpread:null,
  6. mainFeeRateSheet:null,
  7. mainFeeRateData:null,
  8. mainFeeRateSetting:{
  9. header: [
  10. {headerName: "专业名称", headerWidth: 250, dataCode: "name", dataType: "String"},
  11. {headerName: "值%", headerWidth: 80, dataCode: "rate", dataType: "Number",hAlign: "right",decimalField:"feeRate"},
  12. {headerName: "备注", headerWidth: 150, dataCode: "memo", dataType: "String", showHint: true}
  13. ],
  14. view: {
  15. lockColumns: [0]
  16. }
  17. },
  18. mainViews:null,
  19. datas:null,
  20. datasBackup:null,
  21. canEdit:false,
  22. activateFeeRate:null,
  23. needCascadeSet:false,
  24. selectionLoad:false,
  25. changeInfo:null,
  26. feeRateSpreads:null,
  27. editingCell:null,
  28. feeRateSelection:null,
  29. sheetSetting: {
  30. header: [
  31. {headerName: "专业名称", headerWidth: 200, dataCode: "name", dataType: "String"},
  32. {headerName: "值%", headerWidth: 120, dataCode: "rate", dataType: "Number",hAlign: "right",decimalField:"feeRate"},
  33. {headerName: "备注", dataCode: "memo", dataType: "String", showHint: true}
  34. ],
  35. view: {
  36. comboBox: [],
  37. lockColumns: [0, 1, 2]
  38. }
  39. },
  40. columns: [
  41. {
  42. id: 'name',
  43. caption: '专业名称',
  44. dataField: 'name',
  45. width: 450,
  46. allowEditing: false
  47. },
  48. {
  49. id: 'rate',
  50. caption: '值%',
  51. dataField: 'rate',
  52. width: 120,
  53. minWidth: 50,
  54. allowEditing: true
  55. },
  56. {
  57. id: 'memo',
  58. caption: '备注',
  59. dataField: 'memo',
  60. minWidth: 120,
  61. allowEditing: true
  62. },
  63. {
  64. id: 'ID',
  65. caption: 'ID',
  66. dataField: 'ID',
  67. width: 80,
  68. visible: false,
  69. allowEditing: false
  70. },
  71. {
  72. id: 'subFeeRate',
  73. caption: '子费率',
  74. dataField: 'subFeeRate',
  75. width: 80,
  76. visible: false,
  77. allowEditing: false
  78. },
  79. {
  80. id: '_id',
  81. caption: '自动ID',
  82. dataField: '_id',
  83. width: 80,
  84. visible: false,
  85. allowEditing: false
  86. },
  87. {
  88. id: 'ParentID',
  89. caption: '父结点ID',
  90. dataField: 'ParentID',
  91. width: 80,
  92. visible: false,
  93. allowEditing: false
  94. }
  95. ],
  96. options :{
  97. allowSorting: false,
  98. showRowHeader: true,
  99. colMinWidth: 80,
  100. rowHeight: 30,
  101. allowEditing: true,
  102. editMode: 'inline',
  103. editUnit: 'cell',
  104. selectionUnit: "row",
  105. hierarchy: {
  106. keyField: 'ID',
  107. parentField: 'ParentID',
  108. collapsed: false,
  109. column: 'name'
  110. }
  111. },
  112. dataSource : {
  113. loadRange: function(params) {
  114. params.success(feeRateObject.datas);
  115. },
  116. update: function(params) {
  117. if(!params.hasOwnProperty('sourceIndex')){
  118. var selected = feeRateObject.mainViews.getSelections()[0];
  119. params.sourceIndex = selected.sourceRow;
  120. }
  121. params.success();
  122. if(!$('#cascadeSet').prop('checked')||params.hasOwnProperty('viewIndex')){
  123. projectObj.project.FeeRate.updateFeeRateByEdit(params,feeRateObject.activateFeeRate);
  124. }
  125. }
  126. },
  127. createSheet:function(){
  128. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  129. feeRateObject.feeRateSpreads=sheetCommonObj.buildSheet($('#fee_rate_sheet')[0], feeRateObject.sheetSetting,feeRateFile.rates.length);
  130. sheetCommonObj.spreadDefaultStyle(feeRateObject.feeRateSpreads);
  131. feeRateObject.feeRateSheet = feeRateObject.feeRateSpreads.getSheet(0);
  132. feeRateObject.feeRateSheet.selectionUnit(1)//0 cell,1 row,2 col;
  133. feeRateObject.feeRateSheet.options.isProtected = true;
  134. feeRateObject.feeRateSheet.name('fee_rate');
  135. feeRateObject.feeRateSheet.bind(GC.Spread.Sheets.Events.CellClick,feeRateObject.onCellClick);
  136. feeRateObject.feeRateSheet.bind(GC.Spread.Sheets.Events.CellDoubleClick,feeRateObject.onCellDoubleClick);
  137. },
  138. showFeeRateTree:function (sheet,setting,data) {
  139. let ch = GC.Spread.Sheets.SheetArea.viewport;
  140. let parentMap=_.groupBy(data, 'ParentID');
  141. let visibleMap = {};
  142. sheet.suspendPaint();
  143. sheet.suspendEvent();
  144. sheet.setRowCount(data.length);
  145. for (let col = 0; col < setting.header.length; col++) {
  146. let hAlign = "left", vAlign = "center";
  147. if (setting.header[col].hAlign) {
  148. hAlign = setting.header[col].hAlign;
  149. } else if (setting.header[col].dataType !== "String"){
  150. hAlign = "right";
  151. }
  152. vAlign = setting.header[col].vAlign?setting.header[col].vAlign:vAlign;
  153. sheetCommonObj.setAreaAlign(sheet.getRange(-1, col, -1, 1), hAlign, vAlign);
  154. if (setting.header[col].formatter) {
  155. sheet.setFormatter(-1, col, setting.header[col].formatter, GC.Spread.Sheets.SheetArea.viewport);
  156. }
  157. if (setting.header[col].showHint) {
  158. sheet.getRange(-1, col, -1, 1).cellType(TREE_SHEET_HELPER.getTipCellType(setting));
  159. }
  160. for (let row = 0; row < data.length; row++) {
  161. let val = data[row][setting.header[col].dataCode];
  162. if(val&&setting.header[col].dataType === "Number"){
  163. if(setting.header[col].hasOwnProperty('decimalField')){
  164. let decimal = getDecimal(setting.header[col].decimalField);
  165. val =scMathUtil.roundToString(val,decimal);
  166. sheet.setFormatter(-1, col,getFormatter(decimal), GC.Spread.Sheets.SheetArea.viewport);
  167. }else {
  168. val =scMathUtil.roundToString(val,2);
  169. }
  170. }
  171. sheet.setValue(row, col, val, ch);
  172. if(col==0){
  173. let treeType = sheetCommonObj.getTreeNodeCellType(data,row,parentMap);
  174. sheet.getCell(row, 0).cellType(treeType);
  175. visibleMap[data[row].ID] = treeType.collapsed;
  176. feeRateObject.setRowVisible(data,row,visibleMap,sheet);
  177. }
  178. }
  179. }
  180. sheet.resumeEvent();
  181. sheet.resumePaint();
  182. },
  183. setRowVisible:function (data,row,visibleMap,sheet) {
  184. sheet.getRange(row , -1, 1, -1).visible(getVisible(data[row].ParentID));//显示或隐藏
  185. function getVisible(ParentID) {
  186. if(visibleMap[ParentID]) return false //如果父节点是缩起的,那就隐藏本身。
  187. if(visibleMap[ParentID] == false){//如果父节点不是缩起的,要再往父节点找看
  188. let pnode = _.find(data,{'ID':ParentID});
  189. if(pnode) return getVisible(pnode.ParentID);//如果有父节点,递归调用
  190. return true;//没有,返回显示
  191. }
  192. }
  193. },
  194. getFeeRateLevel:function (rate,data) {
  195. if(rate.ParentID){
  196. let prate = _.find(data,{'ID':rate.ParentID});
  197. return this.getFeeRateLevel(prate,data) + 1;
  198. }else {
  199. return 0
  200. }
  201. },
  202. initFeeRateEditDiv:function(optionValue){//“0” 手工输入; “1” 选择费率
  203. let radioValue = optionValue,feeRateValue;
  204. if(!gljUtil.isDef(optionValue)){
  205. let fID = 0;
  206. if ($("#calc_program_manage").is(":visible")){
  207. fID = calcProgramManage.getSelectionInfo().calcItem.feeRateID;
  208. feeRateValue = calcProgramManage.getSelectionInfo().calcItem.feeRate;
  209. } else if ($("#zaojiashu").is(":visible")){
  210. fID = projectObj.project.mainTree.selected.data.feeRateID;
  211. feeRateValue = projectObj.project.mainTree.selected.data.feeRate;
  212. }
  213. radioValue = fID?"1":"0";
  214. $("#customFeeRate").val(feeRateValue);
  215. }
  216. $("input[name='editFeeRateOptions'][value='"+radioValue+"']").attr("checked",true);
  217. if(radioValue == "0"){
  218. $("#selfDiv").show();
  219. $("#fee_rate_sheet").hide();
  220. }else {
  221. $("#selfDiv").hide();
  222. $("#fee_rate_sheet").show();
  223. }
  224. },
  225. locate: function(){ // CSL,2018.07.18
  226. let sheet = feeRateObject.feeRateSpreads.getSheet(0);
  227. let fID = 0;
  228. if ($("#calc_program_manage").is(":visible"))
  229. fID = calcProgramManage.getSelectionInfo().calcItem.feeRateID;
  230. else if ($("#zaojiashu").is(":visible"))
  231. fID = projectObj.project.mainTree.selected.data.feeRateID;
  232. let rates = projectObj.project.FeeRate.getActivateFeeRate().rates;
  233. let rowIdx = 0, pID = 0;
  234. if (fID){
  235. fID = parseInt(fID);
  236. rowIdx = _.findIndex(rates,{ID:fID});
  237. if(rowIdx != -1) pID = rates[rowIdx].ParentID;
  238. }
  239. // 费率现有可能有多层节点,所以要递归展开父节点
  240. if(pID) expandParent(pID,rates,sheet);
  241. sheet.setSelection(rowIdx, -1, 1, -1);
  242. sheet.showRow(rowIdx, GC.Spread.Sheets.VerticalPosition.center);
  243. feeRateObject.onCellClick({type: 'CellClick'}, {row:rowIdx});
  244. function expandParent(ID,datas,sheet) {//递归展开父节点
  245. let cellType = setCollapsed(ID);
  246. cellType.refreshChildrenVisible(sheet);
  247. function setCollapsed(parentID){
  248. let index = _.findIndex(datas,{'ID':parentID});
  249. let type = sheet.getCellType(index,0);
  250. type.collapsed = false;
  251. if(datas[index].ParentID){
  252. setCollapsed(datas[index].ParentID)
  253. }
  254. return type
  255. }
  256. }
  257. },
  258. getFeeRateEditCellType:function () {
  259. var ns = GC.Spread.Sheets;
  260. function FeeRateEditCellType() {
  261. var init=false;
  262. }
  263. FeeRateEditCellType.prototype = new ns.CellTypes.Text();
  264. //2018-12-12 按新需求隐藏费率选择按钮
  265. /* FeeRateEditCellType.prototype.paint = function (ctx, value, x, y, w, h, style, options) {
  266. GC.Spread.Sheets.CellTypes.Text.prototype.paint.apply(this, arguments);
  267. if(feeRateObject.editingCell && !projectReadOnly){
  268. if(feeRateObject.editingCell.row==options.row&&feeRateObject.editingCell.col==options.col){
  269. var image = document.getElementById('f_btn'),imageMagin = 3;
  270. var imageHeight = h-2*imageMagin;
  271. var imageWidth = w*2/7;
  272. var imageX = x + w - imageWidth- imageMagin, imageY = y + h / 2 - imageHeight / 2;
  273. ctx.save();
  274. ctx.drawImage(image, imageX, imageY,imageWidth,imageHeight);
  275. ctx.beginPath();
  276. ctx.arc(imageX+imageWidth/2,imageY+imageHeight/2,1,0,360,false);
  277. ctx.arc(imageX+imageWidth/2-4,imageY+imageHeight/2,1,0,360,false);
  278. ctx.arc(imageX+imageWidth/2+4,imageY+imageHeight/2,1,0,360,false);
  279. ctx.fillStyle="black";//填充颜色,默认是黑色
  280. ctx.fill();//画实心圆
  281. ctx.closePath();
  282. ctx.restore();
  283. }
  284. }
  285. };
  286. FeeRateEditCellType.prototype.getHitInfo = function (x, y, cellStyle, cellRect, context) {
  287. return {
  288. x: x,
  289. y: y,
  290. row: context.row,
  291. col: context.col,
  292. cellStyle: cellStyle,
  293. cellRect: cellRect,
  294. sheetArea: context.sheetArea
  295. };
  296. };
  297. FeeRateEditCellType.prototype.processMouseDown = function (hitinfo) {
  298. let me=feeRateObject;
  299. if(me.editingCell && 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. if(!projectReadOnly && me.ifFeeRateEdit(hitinfo.row,hitinfo.sheet.name())){
  306. $('#calcBaseFeeRateConf').attr('toggle', 'feeRate');
  307. changeCalcBaseFeeRate('feeRate');
  308. $('#tabFeeRate').tab('show');
  309. me.showSelectModal(hitinfo);
  310. }
  311. }else {//鼠标点击其它地方,消失
  312. hideButton(hitinfo);
  313. }
  314. }
  315. };
  316. FeeRateEditCellType.prototype.processMouseEnter = function (hitinfo){
  317. let me=feeRateObject;
  318. me.pmLeave = false;
  319. if(me.editingCell==null){
  320. var showSelectBtn = true;
  321. if(hitinfo.sheet.name()!='calc_detail'){
  322. showSelectBtn=me.ifFeeRateEdit(hitinfo.row,hitinfo.sheet.name());
  323. }
  324. if(showSelectBtn){
  325. me.editingCell={
  326. row:hitinfo.row,
  327. col:hitinfo.col
  328. };
  329. hitinfo.sheet.invalidateLayout();
  330. hitinfo.sheet.repaint();
  331. }
  332. }
  333. };
  334. FeeRateEditCellType.prototype.processMouseLeave = function (hitinfo) {
  335. hideButton(hitinfo);
  336. };
  337. function hideButton(hitinfo) {
  338. if(!feeRateObject.pmLeave){
  339. feeRateObject.editingCell=null;
  340. hitinfo.sheet.invalidateLayout();
  341. hitinfo.sheet.repaint();
  342. feeRateObject.pmLeave = true;
  343. }
  344. }*/
  345. return new FeeRateEditCellType();
  346. },
  347. showSelectModal:function (hitinfo) {
  348. //锁定的清单不显示
  349. let project = projectObj.project;
  350. if(project.isBillsLocked() && project.withinBillsLocked(project.mainTree.selected)){
  351. return;
  352. }
  353. //$("#fee_rate_tree").modal({show:true});
  354. $("#calcBaseFeeRate").modal({show:true});
  355. $('#edit_from').val(hitinfo.sheet.name());
  356. },
  357. getChildrenCount:function (id,data) {
  358. var me=this;
  359. var sum=0;
  360. var children=_.filter(data,{'ParentID':id});
  361. if(children&&children.length==0){
  362. return 0;
  363. }
  364. for(var i=0;i<children.length;i++){
  365. sum+=me.getChildrenCount(children[i].ID,data);
  366. }
  367. return children.length+sum;
  368. },
  369. ifFeeRateEdit:function (row,name) {
  370. if( name == 'mainSheet'){
  371. var selected = projectObj.project.mainTree.items[row];
  372. return selected&&MainTreeCol.readOnly.forFeeRate(selected)?false:true;
  373. }
  374. return true;
  375. },
  376. createSpreadView:function () {
  377. if (this.mainViews) {
  378. this.mainViews.destroy();
  379. this.mainViews = null;
  380. }
  381. if(subRateObject.views){
  382. subRateObject.views.destroy();
  383. subRateObject.views = null;
  384. }
  385. this.activateFeeRate = projectObj.project.FeeRate.getActivateFeeRate();
  386. this.datas = this.activateFeeRate.rates;
  387. var rateColSetting = _.find(this.columns,{"id":"rate"});
  388. rateColSetting?rateColSetting.format=getFormatter(getDecimal("feeRate")):"";
  389. this.mainViews = new GC.Spread.Views.DataView($('#divFee')[0],
  390. this.dataSource, this.columns, new GC.Spread.Views.Plugins.GridLayout(this.options));
  391. this.mainViews["rowClick"].addHandler(subRateObject.reFreshRateViews);
  392. this.mainViews.invalidate();
  393. document.querySelector('#divFee').focus();
  394. },
  395. initFeeRateSpread:function (rowCount) {
  396. //初始化费用项表格
  397. this.mainFeeRateSpread = sheetCommonObj.buildSheet($('#divFee')[0], this.mainFeeRateSetting,rowCount);
  398. sheetCommonObj.spreadDefaultStyle(this.mainFeeRateSpread);
  399. this.mainFeeRateSpread.options.scrollbarMaxAlign = true;
  400. this.mainFeeRateSheet = this.mainFeeRateSpread.getSheet(0);
  401. if(!projectReadOnly){
  402. sheetCommonObj.lockCells(this.mainFeeRateSheet , this.mainFeeRateSetting);
  403. }
  404. this.mainFeeRateSheet.bind(GC.Spread.Sheets.Events.ValueChanged, this.onMainFeeRateSheetValueChange);
  405. //this.mainFeeRateSheet.bind(GC.Spread.Sheets.Events.SelectionChanged, this.onMainFeeRateSelectChanged);
  406. this.mainFeeRateSheet.bind(GC.Spread.Sheets.Events.RangeChanged, this.onMainFeeRateRangeChanged);
  407. this.mainFeeRateSheet.bind(GC.Spread.Sheets.Events.EditStarting, function (e,args) {
  408. let me =feeRateObject;
  409. if($.bootstrapLoading.isLoading()) args.cancel = true;
  410. if(!me.mainFeeRateEditChecking(args.row,args.col)){
  411. args.cancel = true;
  412. }
  413. });
  414. this.mainFeeRateSheet.name('mainFeeRateSheet');
  415. disableRightMenu("divFee",this.mainFeeRateSpread,this.rightClickCallback);
  416. //打开他人分享的项目、只读
  417. if(projectReadOnly){
  418. disableSpread(this.mainFeeRateSpread);
  419. }
  420. },
  421. rightClickCallback:function (row) {
  422. let me = feeRateObject;
  423. me.onMainFeeRateSelect(row);
  424. },
  425. showMainFeeRateData:function () {
  426. let me = this;
  427. let selected = me.mainFeeRateSheet.getSelections()[0];
  428. me.activateFeeRate = projectObj.project.FeeRate.getActivateFeeRate();
  429. me.mainFeeRateData = projectObj.project.FeeRate.getActivateFeeRate().rates;
  430. me.mainFeeRateSheet.setRowCount(0);
  431. me.mainFeeRateSheet.setRowCount(me.mainFeeRateData.length);
  432. me.showFeeRateTree(me.mainFeeRateSheet,me.mainFeeRateSetting,me.mainFeeRateData);
  433. me.mainFeeRateSheet.setSelection(selected.row,selected.col,selected.rowCount,selected.colCount);
  434. },
  435. reFreshRateViews:function() {
  436. feeRateObject.loadPageContent();
  437. this.showMainFeeRateData();
  438. if(subRateObject.subRateSpread){//如果子费率没有初始化过的话,不需要显示。
  439. subRateObject.initSubRateSpread(this.mainFeeRateData[0]);
  440. }
  441. },
  442. mainFeeRateEditChecking:function (row,col) {//false 不能编辑,true 可以编辑
  443. let me =feeRateObject;
  444. let recode = me.mainFeeRateData[row];
  445. let dataCode = me.mainFeeRateSetting.header[col].dataCode;
  446. if(dataCode=="rate"&&(recode.sum != true && me.getChildrenCount(recode.ID,me.mainFeeRateData)>0)){//除了标记要汇总的节点,其它的有子节点时不能编辑费率列
  447. return false;
  448. }
  449. return true;
  450. },
  451. onMainFeeRateSheetValueChange:function (e,info) {
  452. feeRateObject.updateFeerateWhenCellsChange([info]);
  453. },
  454. onMainFeeRateRangeChanged:function (e,info) {
  455. let me = feeRateObject;
  456. let changeCells = [];
  457. for(let c of info.changedCells){
  458. let tem = {
  459. row:c.row,
  460. col:c.col,
  461. newValue:info.sheet.getCell(c.row,c.col).value()
  462. };
  463. changeCells.push(tem);
  464. }
  465. me.updateFeerateWhenCellsChange(changeCells);
  466. },
  467. sumParentRate:function (rateID,value,updateDatas) {
  468. let feeRate = projectObj.project.FeeRate;
  469. let rate = feeRate.getFeeRateByID(rateID);
  470. let parent = feeRate.getFeeRateByID(rate.ParentID);
  471. if(parent && parent.sum == true){
  472. let suRates = feeRate.getChildrenByID(parent.ID);
  473. let total = 0;
  474. for(let r of suRates) {
  475. let tem = r.rate ? r.rate:0;
  476. tem = scMathUtil.roundForObj(tem,getDecimal("feeRate"));
  477. if (rateID == r.ID){
  478. tem = value;
  479. }else {
  480. let u = _.find(updateDatas,{"rateID":r.ID})//看是不是更新的过程中包含了汇总的数据
  481. if(u && gljUtil.isDef(u.doc.rate)) tem = u.doc.rate;
  482. }
  483. total = scMathUtil.roundForObj(tem + total,getDecimal('process'))
  484. }
  485. total = scMathUtil.roundForObj(total,getDecimal("feeRate"));
  486. let tp = _.find(updateDatas,{"rateID":parent.ID});//如果父节点也在更新列表中
  487. if(tp){
  488. tp.doc.rate = total
  489. }else {
  490. updateDatas.push({rateID:parent.ID,doc:{rate:total}});
  491. }
  492. }
  493. },
  494. updateFeerateWhenCellsChange:function (cells) {// col,row,newValue
  495. let me = feeRateObject,updateDatas = [],feeRate = projectObj.project.FeeRate;//[{rateID:rateID,doc:doc}]
  496. let refreshA = [];//记录刷新条数的数组
  497. for(let c of cells){
  498. let temData = {};
  499. let recode = me.mainFeeRateData[c.row];
  500. let fieldID = me.mainFeeRateSetting.header[c.col].dataCode;
  501. let value = c.newValue;
  502. let oldValue = recode[fieldID];
  503. if(!me.mainFeeRateEditChecking(c.row, c.col)){
  504. me.mainFeeRateSheet.setValue(c.row, c.col, oldValue);
  505. continue;
  506. }else if(fieldID == 'rate'&&value !== null && value!==0){
  507. let checkResult = scMathUtil.isNumOrFormula(value);
  508. if(checkResult!=null && !isNaN(checkResult)){
  509. value = scMathUtil.roundForObj(checkResult,getDecimal("feeRate"));
  510. }else {
  511. alert('当前输入的数据类型不正确,请重新输入。');
  512. me.mainFeeRateSheet.setValue(c.row, c.col, oldValue);
  513. continue;
  514. }
  515. }
  516. if(recode[fieldID] == value){//没有改变
  517. continue;
  518. }
  519. temData[fieldID] = value ;
  520. updateDatas.push({rateID:recode.ID,doc:temData});
  521. if(fieldID == 'rate') feeRateObject.sumParentRate(recode.ID,value,updateDatas);
  522. }
  523. if(updateDatas.length > 0){
  524. $.bootstrapLoading.start();
  525. feeRate.updateFeeRatesByIDs(updateDatas,async function () {
  526. let feerateInfo = [];
  527. for(let u of updateDatas){
  528. let row = _.findIndex(me.mainFeeRateData,{'ID':u.rateID})
  529. for(let key in u.doc){
  530. let col = _.findIndex(me.mainFeeRateSetting.header,{'dataCode':key});
  531. me.mainFeeRateSheet.setValue(row, col, u.doc[key]);
  532. if(key == 'rate'){
  533. feerateInfo.push({rateID:u.rateID,value:u.doc[key]});
  534. }
  535. }
  536. }
  537. feerateInfo.length > 0 ?await feeRate.onFeeRatesChange(feerateInfo):'';
  538. $.bootstrapLoading.end();
  539. })
  540. }
  541. },
  542. onMainFeeRateSelectChanged:function (e, info) {
  543. let me = feeRateObject;
  544. let row = info.newSelections[0].row;
  545. me.onMainFeeRateSelect(row);
  546. },
  547. onMainFeeRateSelect:function (row) {
  548. let me = this;
  549. if(row!=-1){
  550. subRateObject.initSubRateSpread(me.mainFeeRateData[row]);
  551. }
  552. },
  553. setRateFromSub:function (subRate,value,subList,editText,feeRateCoe) {//editText 下拉框选择的值,对于如“19.00”这样下拉选择项,value会变成19,所以在valueMap里找的时候要用editText去查找
  554. let me = feeRateObject,feeRate = projectObj.project.FeeRate;
  555. let rates = feeRate.getActivateFeeRate().rates;
  556. let updateDatas = [];
  557. //对于有子节点的记录和可输入的记录,只支持一个参数(因为还要内插法取费率值),如果要支持两个以上的参数,valueMap要再改下~~~~
  558. for(let r of rates){
  559. if(gljUtil.isDef(r.subFeeRate)){
  560. let valueArray=[];//用来存参数的值
  561. let temP =null;//这个用来存储需要内插法记算的时候,同时,树节点的子节点改变也计在这里, 这样,改变temP的值,会体现在保存subRecode
  562. let match = false;
  563. let temR = _.cloneDeep(r);//临时存储
  564. for(let p of temR.subFeeRate.recodes){
  565. if(p.name == subRate.name){
  566. temP = p;
  567. match = true;
  568. }
  569. let setValue = false;
  570. for(let o of p.optionList){
  571. if(match == true) {//匹配上了,改对应的selected 为 true
  572. if(o.name == value){
  573. o.selected = true;
  574. valueArray.push(editText);//这里要用字符串去匹配而不是转换成数值的value
  575. setValue = true;
  576. }else {
  577. o.selected = false;
  578. }
  579. }else {//没有匹配上的,直接取值就可以(这个是为多参数时用的,但是目前来看,不支持多参数,比较麻烦)
  580. if(o.selected == true) valueArray.push(o.name);
  581. }
  582. }
  583. if(match==true && setValue ==false) valueArray.push(value);//如果匹配上了,但是setValue为false,说明没有满足和选项,要用内插法或超出倍数算值
  584. }
  585. if(match == true){//说明要改rate的值,先从valueMap中去查
  586. if(subList && temP.subList && temP.subList.length > 0){
  587. temP.subList = subList;// 设置树节点的子节点的值
  588. }
  589. let doc = {"subFeeRate":temR.subFeeRate};
  590. let valueKey = valueArray.join('-');
  591. let valueMaps = r.subFeeRate.valueMaps;
  592. if(me.feeRateSpecialHandle){//不同编办特殊处理
  593. let sf = me.feeRateSpecialHandle(subRate,value);
  594. if(!_.isEmpty(sf)){
  595. valueKey = sf.valueKey;
  596. temP.value = sf.value;
  597. }
  598. }
  599. let rate = _.find(valueMaps,{"ID":valueKey});
  600. if(isDef(rate)) {//找到了,直接改费率值
  601. doc.rate = rate.value;
  602. } else {//没找到,用内插法或步长算值
  603. let ltRate = null;//
  604. let gtRate = null;
  605. temP.value = scMathUtil.roundForObj(value,getDecimal("feeRate")) ;
  606. for(let v of valueMaps){
  607. if(parseFloat(v.ID)<parseFloat(value)){
  608. ltRate = v;
  609. }else if( gtRate==null && parseFloat(v.ID)>parseFloat(value)){
  610. gtRate = v;
  611. }
  612. }
  613. if(gljUtil.isDef(ltRate)&&gljUtil.isDef(gtRate)){//已经找到前后的值了
  614. let step = scMathUtil.roundForObj(gtRate.value - ltRate.value,getDecimal("process"));
  615. let total = parseFloat(gtRate.ID) - parseFloat(ltRate.ID)
  616. doc.rate =getRateByStep(ltRate.value,total,parseFloat(value) - parseFloat(ltRate.ID),step);
  617. }else if(gljUtil.isDef(ltRate)&&gtRate == null){//说明是超出了选项的最大值
  618. let share = parseFloat(value) - parseFloat(ltRate.ID);//超出了多少
  619. doc.rate = getRateByStep(ltRate.value,temP.step,share,temP.amount)
  620. }else if(gljUtil.isDef(gtRate)&&ltRate==null){//说明是只有一个选项,且这个选项比输入的值大
  621. let step = parseFloat(gtRate.value)- 0;
  622. doc.rate = getRateByStep(0,gtRate.value,value,step)
  623. }
  624. }
  625. if(isDef(doc.rate)){
  626. if(feeRateCoe) doc.rate = scMathUtil.roundForObj(doc.rate * feeRateCoe,getDecimal("feeRate")); //如果是从乘系数过来的,乘以系数。
  627. updateDatas.push({rateID:r.ID,doc:doc});
  628. me.sumParentRate(r.ID,doc.rate,updateDatas);
  629. }
  630. }
  631. }
  632. }
  633. if(updateDatas.length > 0){
  634. $.bootstrapLoading.start();
  635. feeRate.updateFeeRatesByIDs(updateDatas,async function () {
  636. let feerateInfo = [];
  637. for(let u of updateDatas){
  638. feerateInfo.push({rateID:u.rateID,value:u.doc["rate"]});
  639. }
  640. subRateObject.showSubRateData();
  641. me.showMainFeeRateData();
  642. if(feerateInfo.length > 0){
  643. await feeRate.onFeeRatesChange(feerateInfo);
  644. }else {
  645. $.bootstrapLoading.end();
  646. }
  647. })
  648. }
  649. function getRateByStep(ltValue,total,share,step) { //min值 ,计算值的总区间, 区间中占比,步长--后端重选标准也要用到
  650. let p = scMathUtil.roundForObj(share/total,getDecimal("process"));
  651. let a = scMathUtil.roundForObj(step * p,getDecimal("process")) ;
  652. return scMathUtil.roundForObj(ltValue + a,getDecimal("feeRate"))
  653. }
  654. },
  655. cascadeSetRates:function(selectedItem,sourceRow,mapID,selectMap){
  656. let items=[];
  657. items.push({rateIndex:sourceRow,rate:selectedItem});
  658. _.forEach(this.mainFeeRateData,function (recode,Index) {
  659. if(Index!=sourceRow&&recode.subFeeRate){
  660. let valueMaps = recode.subFeeRate.valueMaps;
  661. let valueMap = _.find(valueMaps,{ID:mapID});
  662. if(valueMap){//选项完全一样的情况
  663. if(valueMap.value==recode.rate){
  664. return;
  665. }else {
  666. recode.rate = valueMap.value;
  667. _.forEach(selectMap,function (value,key) {
  668. let tempRecode = recode.subFeeRate.recodes[key];
  669. let optionList = tempRecode.optionList;
  670. for(let o of optionList){
  671. o.value===value? o.selected = true:o.selected = false;
  672. }
  673. });
  674. items.push({rateIndex:Index,rate:recode});
  675. }
  676. }else {//某条选项一样的情况
  677. let needUpdate = false;
  678. let selectList = mapID.split('-');
  679. let newList=[];
  680. _.forEach(recode.subFeeRate.recodes,function (r) {
  681. let oList = r.optionList, oldSelectIndex=0, hasChange=false;
  682. _.forEach(oList,function (o,key) {
  683. if(o.selected) oldSelectIndex = key;
  684. if(_.includes(selectList,o.value)){
  685. needUpdate=true;
  686. o.selected=true;
  687. hasChange=true;
  688. newList.push(o.value);
  689. }else {
  690. o.selected=false;
  691. }
  692. });
  693. if(!hasChange){
  694. oList[oldSelectIndex].selected=true;
  695. newList.push(oList[oldSelectIndex].value)
  696. }
  697. });
  698. if(needUpdate){
  699. let newValue = _.find(valueMaps,{ID:newList.join("-")})//取出费率值并更新
  700. if(newValue){
  701. if(recode.rate != newValue.value){
  702. recode.rate = newValue.value;
  703. items.push({rateIndex:Index,rate:recode});
  704. }
  705. }
  706. }
  707. }
  708. }
  709. });
  710. projectObj.project.FeeRate.batchUpdateFeeRate(items,feeRateObject.activateFeeRate);
  711. },
  712. loadPageContent:function(){
  713. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  714. var usageProjects = feeRateFile.usageProjects;
  715. $('#feeRateFileName').text(feeRateFile.name);
  716. $('#feeRateLibName').text(feeRateFile.libName);
  717. $('#projectCount').text(usageProjects.length);
  718. },
  719. loadFeeRateSelection:function() {
  720. if(!this.selectionLoad){
  721. var selectedID=0;
  722. _.forEach(projectObj.project.FeeRate.datas,function (data) {
  723. var option = $("<option>").val(data.ID).text(data.libName);
  724. $('#inlineFormCustomSelect').append(option);
  725. if(data.status=='activate'){
  726. selectedID=data.ID;
  727. }
  728. })
  729. $('#inlineFormCustomSelect').val(selectedID);
  730. }
  731. },
  732. getFeeRateStandards:function (callback) {
  733. CommonAjax.post('/feeRates/getFeeRateStandards', {"projectID": projectObj.project.ID()}, function (data) {
  734. if (data) {
  735. callback(data);
  736. }
  737. });
  738. },
  739. changeFeeRateStandard:function(newVal){
  740. $.bootstrapLoading.start();
  741. var callback=function () {
  742. feeRateObject.reFreshRateViews();
  743. $.bootstrapLoading.end();
  744. };
  745. projectObj.project.FeeRate.changeFeeRateStandard(newVal,callback);
  746. },
  747. checkFeeRateName:function (newVal) {
  748. if(!newVal||newVal==""){
  749. //$('#saveAsConfirm').attr("disabled","disabled");
  750. $('#nameError').text("请输入文件名称。").show();
  751. return;
  752. }
  753. var callback=function (data) {
  754. if(data){
  755. // $('#saveAsConfirm').attr("disabled","disabled");
  756. $('#nameError').text("已存在同名费率文件。").show();
  757. $('#valid_name').val('');
  758. }else {
  759. $('#valid_name').val(newVal);
  760. $('#saveAsConfirm').removeAttr("disabled");
  761. $('#nameError').hide();
  762. }
  763. };
  764. projectObj.project.FeeRate.checkFeeRateName(newVal,callback);
  765. },
  766. feeRateFileSaveAs:function (newName) {
  767. if(!newName||newName==""){
  768. // $('#saveAsConfirm').attr("disabled","disabled");
  769. $('#nameError').text("请输入文件名称。").show();
  770. return;
  771. }
  772. let callback=function (data) {
  773. if(data){
  774. // $('#saveAsConfirm').attr("disabled","disabled");
  775. $('#nameError').text("已存在同名费率文件。").show();
  776. $('#valid_name').val('');
  777. }else {
  778. feeRateObject.submitSaveAs(newName);
  779. }
  780. }
  781. projectObj.project.FeeRate.checkFeeRateName(newName,callback);
  782. /* let valideName = $('#valid_name').val();
  783. if(valideName==''||valideName!==newName){
  784. }else {
  785. feeRateObject.submitSaveAs(newName);
  786. }*/
  787. },
  788. submitSaveAs:function (newName) {
  789. let me = this;
  790. let FeeRate = projectObj.project.FeeRate;
  791. FeeRate.feeRateFileSaveAs(newName,function (result) {
  792. me.activateFeeRate = result;
  793. me.loadPageContent();
  794. $('#copy-lv').modal('hide');
  795. let data ={
  796. projectID:projectObj.project.ID(),
  797. oldRoom:socketObject.roomInfo.feeRate,
  798. newRoom: FeeRate.getActivateFeeRateFileID(),
  799. userID:userID,
  800. name:'feeRate'
  801. };
  802. socket.emit('changeNewRoom',data);
  803. socketObject.roomInfo.feeRate = FeeRate.getActivateFeeRateFileID();
  804. $.bootstrapLoading.end();
  805. });
  806. },
  807. getChangeInfo:function () {
  808. var me = this;
  809. var callback=function (data) {
  810. me.changeInfo=data;
  811. me.loadChangePageContent(data);
  812. };
  813. projectObj.project.FeeRate.getChangeInfo(callback);
  814. },
  815. loadChangePageContent:function (data) {
  816. $('#currentProject').text(data.currentProject.name);
  817. $('#currentOptions').empty();
  818. _.forEach(data.currentProject.currentOptions,function (s) {
  819. var option = $("<option>").val(s.ID).text(s.name);
  820. $('#currentOptions').append(option);
  821. })
  822. $('#otherProject').empty();
  823. _.forEach(data.others,function (p) {
  824. var option = $("<option>").val(p.ID).text(p.name);
  825. $('#otherProject').append(option);
  826. });
  827. $('#otherFeeRateOption').empty();
  828. if(data.others.length>0){
  829. _.forEach(data.others[0].optionList,function (f) {
  830. var option = $("<option>").val(f.ID).text(f.name);
  831. $('#otherFeeRateOption').append(option);
  832. });
  833. }
  834. },
  835. changeFeeRateFileFromCurrent:function(){
  836. $.bootstrapLoading.start();
  837. var newVal = $("#currentOptions").val();
  838. if(!$("#currentOptions").val()){
  839. if($.bootstrapLoading.isLoading()){
  840. $.bootstrapLoading.end();
  841. }
  842. alert('费率文件不可为空');
  843. return;
  844. }
  845. if($("#currentOptions").val()==this.activateFeeRate.ID){
  846. return;
  847. }
  848. var name =$("#currentOptions").find("option:selected").text();
  849. var newFeeRateFile = {
  850. id:newVal,
  851. name:name
  852. }
  853. var callback=function () {
  854. feeRateObject.reFreshRateViews();
  855. projectObj.project.FeeRate.onFeeRateFileChange();
  856. $.bootstrapLoading.end();
  857. }
  858. projectObj.project.FeeRate.changeFeeRateFileFromCurrent(newFeeRateFile,callback);
  859. },
  860. changeFeeRateFileFromOthers:function () {
  861. var feeRateFileID = $("#otherFeeRateOption").val();
  862. var name =$("#otherFeeRateOption").find("option:selected").text();
  863. if(null===feeRateFileID){
  864. alert("请选择一个费率文件!");
  865. return;
  866. }
  867. var callback=function (data) {
  868. if(data){
  869. //$('#renameConfirm').attr("disabled","disabled");
  870. $('#renameError').text("本建设项目中已存在同名费率文件。").show();
  871. $('#rename-lv').modal('show');
  872. $("#newFeeRateID").val(feeRateFileID);
  873. $("#newFeeRateName").val(name);
  874. }else {
  875. //$('#renameConfirm').removeAttr("disabled");
  876. $('#renameError').hide();
  877. feeRateObject.changeFeeRateFileConfirm(feeRateFileID,name);
  878. }
  879. };
  880. projectObj.project.FeeRate.checkFeeRateName(name,callback);
  881. /* var currentOption = _.find(this.changeInfo.currentProject.currentOptions,{name:name})
  882. if(currentOption){
  883. $("#rename-lv").modal({show:true});
  884. $("#newFeeRateID").val(feeRateFileID);
  885. $("#newFeeRateName").val(name);
  886. }else {
  887. this.changeFeeRateFileConfirm(feeRateFileID,name);
  888. }*/
  889. },
  890. changeFeeRateFileConfirm:function(feeRateFileID,name){
  891. $.bootstrapLoading.start();
  892. var callback=function () {
  893. feeRateObject.reFreshRateViews();
  894. projectObj.project.FeeRate.onFeeRateFileChange();
  895. $.bootstrapLoading.end();
  896. }
  897. projectObj.project.FeeRate.changeFeeRateFileFromOthers(feeRateFileID,name,callback);
  898. },
  899. setFeeRateCellCol:function (sheet,col) {
  900. sheet.getRange(-1, col, -1, 1).cellType(this.getFeeRateEditCellType());
  901. },
  902. onCellClick:function (sender,args) {
  903. var data =projectObj.project.FeeRate.getActivateFeeRate().rates;
  904. feeRateObject.feeRateSelection=data[args.row];
  905. },
  906. onCellDoubleClick:function (sender,args) {
  907. var data =projectObj.project.FeeRate.getActivateFeeRate().rates;
  908. feeRateObject.feeRateSelection=data[args.row];
  909. feeRateObject.submitFeeRateBySelect();
  910. },
  911. checkSelectedFeeRate:function () {
  912. var validate = false;
  913. var data =projectObj.project.FeeRate.getActivateFeeRate().rates;
  914. if(feeRateObject.feeRateSelection!=null){
  915. var children=_.filter(data,{'ParentID':feeRateObject.feeRateSelection.ID});
  916. validate=children&&children.length==0;
  917. }
  918. return validate;
  919. },
  920. submitFeeRateFromBill:function () {
  921. var rate = feeRateObject.feeRateSelection;
  922. var selected = projectObj.project.mainTree.selected;
  923. if(selected.data.feeRateID === parseInt(rate.ID)) return $("#calcBaseFeeRate").modal('hide');
  924. $.bootstrapLoading.start();
  925. projectObj.project.FeeRate.submitFeeRateFromBill(rate,selected.data,function (data) {
  926. selected.updateData.feeRateID= parseInt(rate.ID);
  927. selected.updateData.feeRate=scMathUtil.roundToString(rate.rate,getDecimal("feeRate"));
  928. selected.changed = true;
  929. projectObj.project.calcProgram.calcAndSave(selected);
  930. $("#calcBaseFeeRate").modal('hide');
  931. $.bootstrapLoading.end();
  932. });
  933. },
  934. submitFeeRateFromCalc:function () {
  935. var rate = feeRateObject.feeRateSelection;
  936. var calInfo = calcProgramManage.getSelectionInfo();
  937. calInfo.calcItem.feeRateID=rate.ID;
  938. calInfo.calcItem.feeRate=null;
  939. var data={'projectID': projectObj.project.ID(),'templatesID': calInfo.template.ID,'calcItem': calInfo.calcItem};
  940. $.bootstrapLoading.start();
  941. calcProgramManage.saveCalcItem(data,function (result) {
  942. calInfo.calcItem.feeRate=rate.rate;
  943. projectObj.project.calcProgram.compileAllTemps();
  944. projectObj.project.calcProgram.calcAllNodesAndSave();
  945. calcProgramManage.refreshDetailSheet();
  946. $("#calcBaseFeeRate").modal('hide');
  947. $.bootstrapLoading.end();
  948. });
  949. console.log(calInfo);
  950. },
  951. submitFeeRateBySelect:function () {
  952. var validate = this.checkSelectedFeeRate();
  953. if(validate){
  954. if($('#edit_from').val()=='calc_detail'){
  955. this.submitFeeRateFromCalc();
  956. }else {
  957. this.submitFeeRateFromBill();
  958. }
  959. }else {
  960. //$("#fee_rate_tree").modal('hide');
  961. }
  962. }
  963. }
  964. function getPopoverContent() {
  965. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  966. var usageProjects = feeRateFile.usageProjects;
  967. let names = _.map(usageProjects,'name');
  968. let popover_content = names.join('<br>');
  969. return "费率的变化,将自动影响以下单位工程造价:<br>"+ popover_content;
  970. }
  971. $(function(){
  972. $('#pop-lv').tooltip({
  973. placement:"bottom",
  974. html:true,
  975. trigger:"hover | focus",
  976. title:getPopoverContent
  977. }
  978. );
  979. $('#tab_fee_rate').on('shown.bs.tab', function (e) {
  980. sessionStorage.setItem('mainTab', '#tab_fee_rate');
  981. let me = feeRateObject;
  982. $(e.relatedTarget.hash).removeClass('active');
  983. if(me.mainFeeRateSpread == null) me.initFeeRateSpread(0);
  984. subRateObject.initSubRateSpread();
  985. me.showMainFeeRateData();
  986. me.loadPageContent();
  987. });
  988. $('#setNewFeeRate').bind('click', function () {
  989. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  990. var usageProjects = feeRateFile.usageProjects;
  991. var listString ='';
  992. _.forEach(usageProjects,function (u) {
  993. listString+="<li>"+u.name+"</li>"
  994. })
  995. $("#usageProjectList").html(listString);
  996. $("#set-lv-feeRateName").text(feeRateFile.name);
  997. $("#set-use-feeRateName").text(feeRateFile.name);
  998. feeRateObject.getFeeRateStandards(function (data) {
  999. $('#standardSelect').empty();
  1000. _.forEach(data,function (s) {
  1001. var option = $("<option>").val(s.ID).text(s.libName);
  1002. $('#standardSelect').append(option);
  1003. })
  1004. $('#standardSelect').val(feeRateFile.libID);
  1005. });
  1006. });
  1007. $('#changeConfirm').bind('click', function (){
  1008. var newVal=$('#standardSelect').val();
  1009. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  1010. feeRateObject.changeFeeRateStandard(newVal);
  1011. //这里改成不判断了,只是点击确定了就重选
  1012. //if(newVal&&newVal!=feeRateFile.libID) feeRateObject.changeFeeRateStandard(newVal);
  1013. });
  1014. $('#saveAs').bind('click', function (){
  1015. var feeRateFile = projectObj.project.FeeRate.getActivateFeeRate();
  1016. $('#copyFeeRateName').val(feeRateFile.name+'副本');
  1017. $('#valid_name').val(feeRateFile.name+'副本');
  1018. $('#nameError').hide();
  1019. });
  1020. $('#saveAsConfirm').bind('click',function () {
  1021. feeRateObject.feeRateFileSaveAs($('#copyFeeRateName').val());
  1022. })
  1023. $('#copyFeeRateName').change(function () {
  1024. feeRateObject.checkFeeRateName(this.value);
  1025. });
  1026. $('#newFeeRateName').change(function () {
  1027. var newName = $(this).val();
  1028. if(!newName||newName==""){
  1029. //$('#renameConfirm').attr("disabled","disabled");
  1030. $('#renameError').text("请输入文件名称。").show();
  1031. return;
  1032. }
  1033. var callback=function (data) {
  1034. if(data){
  1035. //$('#renameConfirm').attr("disabled","disabled");
  1036. $('#renameError').text("本建设项目中已存在同名费率文件。").show();
  1037. }else {
  1038. //$('#renameConfirm').removeAttr("disabled");
  1039. $('#renameError').hide();
  1040. }
  1041. };
  1042. projectObj.project.FeeRate.checkFeeRateName(newName,callback);
  1043. });
  1044. $('#changeFeeRateConfirm').bind('click',function (){
  1045. var radioV= $("input[name='chaneg-lv-Radio']:checked").val();
  1046. if(radioV==='0'){
  1047. feeRateObject.changeFeeRateFileFromCurrent();
  1048. }else {
  1049. feeRateObject.changeFeeRateFileFromOthers();
  1050. }
  1051. })
  1052. $('#changFeeRateFile').bind('click',function (){
  1053. $("input[name='chaneg-lv-Radio']")[0].checked=true;
  1054. $("#fromProject").show();
  1055. $("#fromOther").hide();
  1056. feeRateObject.getChangeInfo();
  1057. })
  1058. $('#otherProject').change(function(){
  1059. var newVal = $(this).val();
  1060. var projects = feeRateObject.changeInfo.others;
  1061. var selected = _.find(projects,{ID:parseInt(newVal)});
  1062. $('#otherFeeRateOption').empty();
  1063. _.forEach(selected.optionList,function (f) {
  1064. var option = $("<option>").val(f.ID).text(f.name);
  1065. $('#otherFeeRateOption').append(option);
  1066. });
  1067. })
  1068. $('#renameConfirm').bind('click',function (){
  1069. var feeRateFileID= $("#newFeeRateID").val();
  1070. var name = $("#newFeeRateName").val();
  1071. var callback=function (data) {
  1072. if(data){
  1073. $('#renameError').text("已存在同名费率文件。").show();
  1074. $("#newFeeRateID").val(feeRateFileID);
  1075. $("#newFeeRateName").val(name);
  1076. }else {
  1077. $('#renameError').hide();
  1078. $('#rename-lv').modal('hide');
  1079. feeRateObject.changeFeeRateFileConfirm(feeRateFileID,name);
  1080. }
  1081. };
  1082. projectObj.project.FeeRate.checkFeeRateName(name,callback);
  1083. })
  1084. $('#inlineFormCustomSelect').change(function(){
  1085. var updateTask = [];
  1086. var selectID = $(this).val();
  1087. var oldValue=0;
  1088. _.forEach(projectObj.project.FeeRate.datas,function (feeRate) {
  1089. if(feeRate.status=='activate'){
  1090. oldValue=feeRate.ID;
  1091. }
  1092. if(feeRate.ID ==selectID){
  1093. feeRate.status='activate';
  1094. }else {
  1095. feeRate.status='disable';
  1096. }
  1097. updateTask.push({query:{ID:feeRate.feeRateID},doc:{status:feeRate.status}});
  1098. })
  1099. projectObj.project.FeeRate.updateStatusBySelected(updateTask);
  1100. feeRateObject.createSpreadView();
  1101. subRateObject.destorySpreadView();
  1102. socket.emit('changeActivateFeeRate',{oldRoom:oldValue,newRoom:selectID});
  1103. })
  1104. $('#calcBaseFeeRate').on('shown.bs.modal', function (e) {
  1105. let toggle = $('#calcBaseFeeRateConf').attr('toggle');
  1106. if(feeRateObject.feeRateSpreads==null){
  1107. feeRateObject.createSheet();
  1108. }
  1109. feeRateObject.initFeeRateEditDiv();
  1110. feeRateObject.feeRateSelection=null;
  1111. feeRateObject.showFeeRateTree(feeRateObject.feeRateSheet,feeRateObject.sheetSetting,projectObj.project.FeeRate.getActivateFeeRate().rates);
  1112. feeRateObject.locate();
  1113. feeRateObject.feeRateSpreads.refresh();
  1114. });
  1115. $('#tabFeeRate').on('shown.bs.tab', function () {
  1116. if(feeRateObject.feeRateSpreads){
  1117. feeRateObject.feeRateSpreads.refresh();
  1118. }
  1119. });
  1120. $('#calcBaseFeeRate').on('hidden.bs.modal', function (e) {
  1121. if(feeRateObject.feeRateSpreads){
  1122. feeRateObject.feeRateSpreads.destroy();
  1123. feeRateObject.feeRateSpreads=null;
  1124. $('#edit_from').val('');
  1125. $('#edit_row').val('');
  1126. }
  1127. });
  1128. //fee_selected_conf
  1129. $('#calcBaseFeeRateConf').bind('click',function (){
  1130. let toggle = $(this).attr('toggle');
  1131. if(!toggle || toggle !== 'feeRate'){
  1132. return;
  1133. }
  1134. feeRateObject.submitFeeRateBySelect();
  1135. });
  1136. $("input[name='editFeeRateOptions']").each(function(){
  1137. $(this).click(function(){
  1138. let optins = $(this).val();
  1139. if(optins == "0"){
  1140. $("#selfDiv").show();
  1141. $("#fee_rate_sheet").hide();
  1142. }else {
  1143. $("#selfDiv").hide();
  1144. $("#fee_rate_sheet").show(function () {
  1145. feeRateObject.feeRateSpreads.refresh();
  1146. });
  1147. }
  1148. });
  1149. });
  1150. })
  1151. function changeFRadioClick() {
  1152. var radioV= $("input[name='chaneg-lv-Radio']:checked").val();
  1153. if(radioV==='0'){
  1154. $("#fromProject").show();
  1155. $("#fromOther").hide();
  1156. }else {
  1157. $("#fromProject").hide();
  1158. $("#fromOther").show();
  1159. }
  1160. }