fee_rate_view.js 50 KB

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