fee_rate_view.js 51 KB

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