fee_rate_view.js 49 KB

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