material_calc_view.js 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424
  1. /**
  2. * Created by zhang on 2019/3/11.
  3. */
  4. materialCalcObj = {
  5. moduleName:'materalCal',
  6. materialSpread:null,
  7. materialSheet:null,
  8. materialDatas:[],
  9. materialSetting:{
  10. header:[
  11. {headerName: "编号", headerWidth: 80, dataCode: "code", dataType: "String"},
  12. {headerName: "名称", headerWidth: 100, dataCode: "name", dataType: "String"},
  13. {headerName: "预算价", headerWidth: 70, dataCode: "marketPrice", hAlign: "right", dataType: "Number",validator:"number"},
  14. {headerName: "供应地点", headerWidth: 100, dataCode: "supplyLocation", hAlign: "left", dataType: "String"},
  15. {headerName: "原价", headerWidth: 60, dataCode: "originalPrice", hAlign: "right", dataType: "String"},
  16. {headerName: "单位运费", headerWidth: 60, dataCode: "unitFreight", hAlign: "right", dataType: "Number",validator:"number"},//,decimalField:'glj.unitPrice'
  17. {headerName: "单位毛重(吨)", headerWidth: 60, dataCode: "grossWeightCoe_n", hAlign: "right", dataType: "Number"},//,decimalField:"glj.unitPrice"
  18. {headerName: "装卸总次数", headerWidth: 60, dataCode: "totalLoadingTimes", hAlign: "right", dataType: "Number",validator:"number"},//,decimalField:"glj.unitPrice"
  19. {headerName: "每增加一次装卸损耗率", headerWidth: 80, dataCode: "handlingLossRate_n", hAlign: "right", dataType: "Number",validator:"number"},
  20. {headerName: "场外运输损耗率", headerWidth: 60, dataCode: "offSiteTransportLossRate_n", hAlign: "right", dataType: "Number"},//,decimalField:"glj.unitPrice"
  21. {headerName: "场外运输损耗", headerWidth: 60, dataCode: "offSiteTransportLoss", hAlign: "right", dataType: "Number"},//,decimalField:"glj.unitPrice"
  22. {headerName: "采购及保管费率", headerWidth: 60, dataCode: "purchaseStorageRate_n", hAlign: "right", dataType: "Number"},//,decimalField:"glj.unitPrice"
  23. {headerName: "采购及保管费", headerWidth: 60, dataCode: "purchaseStorage", hAlign: "right", dataType: "Number"},//,decimalField:"glj.unitPrice"
  24. {headerName: "包装品回收价值", headerWidth: 60, dataCode: "packageRecoverValue", hAlign: "right", dataType: "Number"}//,decimalField:"glj.unitPrice"
  25. ],
  26. view: {
  27. lockColumns: ["code","name","marketPrice",'offSiteTransportLoss','purchaseStorage'],
  28. colHeaderHeight:36
  29. }
  30. },
  31. freightSpread:null,
  32. freightSheet:null,
  33. freightDatas:[],
  34. conveyanceOptions:["汽车","火车","船舶","马车","手推车","拖拉机"],
  35. freightSetting:{
  36. header:[
  37. {headerName: "起讫地点", headerWidth: 80, dataCode: "start", dataType: "String"},
  38. {headerName: "运输工具", headerWidth: 80, dataCode: "conveyance", dataType: "String"},
  39. {headerName: "单位运价", headerWidth: 60, dataCode: "unitFreight", hAlign: "right", dataType: "Number",validator:"number"},
  40. {headerName: "km运距", headerWidth: 60, dataCode: "kmDistance", hAlign: "right", dataType: "String",validator:"number"},
  41. {headerName: "装卸费\n单价", headerWidth: 60, dataCode: "unitLoadingFee", hAlign: "right", dataType: "String",validator:"number"},
  42. {headerName: "装卸\n次数", headerWidth: 60, dataCode: "loadingTimes", hAlign: "right", dataType: "Number",validator:"number"},//,decimalField:'glj.unitPrice'
  43. {headerName: "其它\n费用", headerWidth: 60, dataCode: "otherFee", hAlign: "right", dataType: "Number",validator:"number"},//,decimalField:"glj.unitPrice"
  44. {headerName: "运价增\n加率(%)", headerWidth: 60, dataCode: "freightIncreaseRate", hAlign: "right", dataType: "Number",validator:"number"},//,decimalField:"glj.unitPrice"
  45. {headerName: "加权\n系数", headerWidth: 60, dataCode: "weightCoe", hAlign: "right", dataType: "Number",validator:"number"},
  46. {headerName: "计算式", headerWidth: 170, dataCode: "exp", hAlign: "right", dataType: "Number",getText:'forExp'},//,decimalField:"glj.unitPrice"
  47. ],
  48. view: {
  49. lockColumns: ["exp"],
  50. colHeaderHeight:36
  51. },
  52. getText:{
  53. forExp:function (item) {
  54. let material = materialCalcObj.getMaterialSelected();
  55. //(单位运价×km运距×(1+运距增加率%)+装卸费单价×装卸次数+其它费用)×单位毛重×加权系数
  56. return `(${item.unitFreight}x${item.kmDistance}x(1+${item.freightIncreaseRate}%)+${item.unitLoadingFee}x${item.loadingTimes}+${item.otherFee})x${material.grossWeightCoe_n}x${item.weightCoe}`
  57. }
  58. }
  59. },
  60. priceSpread:null,
  61. priceSheet:null,
  62. priceDatas:[],
  63. priceSetting:{
  64. header:[
  65. {headerName: "供应地点", headerWidth: 80, dataCode: "supplyLocation", dataType: "String"},
  66. {headerName: "供应价", headerWidth: 70, dataCode: "supplyPrice", hAlign: "right", dataType: "Number",validator:"number"},
  67. {headerName: "加权系数", headerWidth: 80, dataCode: "coe", hAlign: "right", dataType: "Number",validator:"number"},//,decimalField:'glj.unitPrice'
  68. ],
  69. view: {
  70. lockColumns: [],
  71. colHeaderHeight:36
  72. }
  73. },
  74. initMaterialSpread:function () {
  75. this.materialSpread = SheetDataHelper.createNewSpread($("#materialCalcSheet")[0]);
  76. sheetCommonObj.spreadDefaultStyle(this.materialSpread);
  77. this.materialSheet = this.materialSpread.getSheet(0);
  78. sheetCommonObj.initSheet(this.materialSheet, this.materialSetting, 30);
  79. this.materialSheet.bind(GC.Spread.Sheets.Events.ValueChanged, this.onMaterialValueChange);
  80. this.materialSheet.bind(GC.Spread.Sheets.Events.SelectionChanged,this.onMaterialSelectionChange);
  81. this.materialSheet.bind(GC.Spread.Sheets.Events.EditStarting,this.onMaterialEditStarting);
  82. this.materialSheet.name('material_calc');
  83. if(projectReadOnly){
  84. disableSpread(this.materialSpread);
  85. }else {
  86. this.initRightClick("materialCalcSheet",this.materialSpread)
  87. }
  88. },
  89. initFreightSpread:function(){
  90. this.freightSpread = SheetDataHelper.createNewSpread($("#freightSheet")[0]);
  91. sheetCommonObj.spreadDefaultStyle(this.freightSpread);
  92. this.freightSheet = this.freightSpread.getSheet(0);
  93. sheetCommonObj.initSheet(this.freightSheet, this.freightSetting, 30);
  94. this.freightSheet.bind(GC.Spread.Sheets.Events.ValueChanged, this.onFreightValueChange);
  95. this.freightSheet.bind(GC.Spread.Sheets.Events.SelectionChanged,this.onFreightSelectionChange);
  96. this.freightSheet.bind(GC.Spread.Sheets.Events.EditStarting,this.onFreightEditStarting);
  97. this.freightSheet.name('freight_calc');
  98. if(projectReadOnly){
  99. disableSpread(this.freightSpread);
  100. }else {
  101. this.initRightClick("freightSheet",this.freightSpread)
  102. }
  103. },
  104. initPriceSpread:function(){
  105. this.priceSpread = SheetDataHelper.createNewSpread($("#priceSheet")[0]);
  106. sheetCommonObj.spreadDefaultStyle(this.priceSpread);
  107. this.priceSheet = this.priceSpread.getSheet(0);
  108. sheetCommonObj.initSheet(this.priceSheet, this.priceSetting, 30);
  109. this.priceSheet.bind(GC.Spread.Sheets.Events.ValueChanged, this.onPriceValueChange);
  110. this.priceSheet.bind(GC.Spread.Sheets.Events.EditStarting,this.onPriceEditStarting);
  111. this.priceSheet.name('price_calc');
  112. if(projectReadOnly){
  113. disableSpread(this.priceSpread);
  114. }else {
  115. this.initRightClick("priceSheet",this.priceSpread)
  116. }
  117. },
  118. showFreightDatas:function () {
  119. if(!$('#freightSheet').is(':visible')) return;
  120. let sel = this.freightSheet.getSelections()[0];
  121. let oldData = sel.row<this.freightDatas.length?this.freightDatas[sel.row]:"";
  122. this.freightSheet.setRowCount(0);
  123. this.freightDatas = this.getFreightDatas();
  124. sheetCommonObj.showData(this.freightSheet, this.freightSetting,this.freightDatas);
  125. this.freightSheet.setRowCount(this.freightDatas+20);
  126. let convCol = _.findIndex(this.freightSetting.header,{'dataCode':'conveyance'});
  127. sheetCommonObj.setComboBox(-1,convCol,this.freightSheet,this.conveyanceOptions,false);
  128. sel.row = oldData?_.findIndex(this.freightDatas,{'ID':oldData.ID}):sel.row ;
  129. this.freightSheet.setSelection(sel.row==-1?0:sel.row,sel.col,sel.rowCount,sel.colCount);
  130. },
  131. showMaterialCalcDatas:function(){
  132. let sel = this.materialSheet.getSelections()[0];
  133. let oldData = sel.row<this.materialDatas.length?this.materialDatas[sel.row]:"";
  134. this.materialSheet.setRowCount(0);
  135. this.materialDatas = this.getMaterialCalcDatas();
  136. sheetCommonObj.showData(this.materialSheet, this.materialSetting,this.materialDatas);
  137. this.materialSheet.setRowCount(this.materialDatas.length);
  138. sel.row = oldData?_.findIndex(this.materialDatas,{'id':oldData.id}):-1;
  139. this.materialSheet.setSelection(sel.row==-1?0:sel.row,sel.col,sel.rowCount,sel.colCount);
  140. },
  141. showPriceDatas:function () {
  142. if(!$('#priceSheet').is(':visible')) return;
  143. let sel = this.priceSheet.getSelections()[0];
  144. let oldData = sel.row<this.priceDatas.length?this.priceDatas[sel.row]:"";
  145. this.priceSheet.setRowCount(0);
  146. this.priceDatas = this.getPriceDatas();
  147. sheetCommonObj.showData(this.priceSheet, this.priceSetting,this.priceDatas);
  148. this.priceSheet.setRowCount(this.priceDatas.length+20);
  149. sel.row = oldData?_.findIndex(this.priceDatas,{'ID':oldData.ID}):sel.row ;
  150. this.priceSheet.setSelection(sel.row==-1?0:sel.row,sel.col,sel.rowCount,sel.colCount);
  151. },
  152. showDatas:function(){
  153. if(!$('#materialCalcSheet').is(':visible')) return;
  154. if(!this.materialSpread) this.initMaterialSpread();
  155. if(!this.freightSpread) this.initFreightSpread();
  156. if(!this.priceSpread) this.initPriceSpread();
  157. this.showMaterialCalcDatas();
  158. this.showFreightDatas();
  159. this.showPriceDatas();
  160. projectGljObject.refreshSubViews();
  161. },
  162. getMaterialSelected:function () {
  163. let sel = this.materialSheet.getSelections()[0];
  164. if(sel.row != -1 && this.materialDatas.length>sel.row){
  165. return this.materialDatas[sel.row]
  166. }
  167. return null;
  168. },
  169. getPriceDatas:function () {
  170. let list = projectObj.project.projectGLJ.datas.originalList;
  171. let material = this.getMaterialSelected();
  172. return material?_.filter(list,{"connect_key":gljUtil.getIndex(material)}):[];
  173. },
  174. getFreightDatas:function () {
  175. let list = projectObj.project.projectGLJ.datas.freightList;
  176. let material = this.getMaterialSelected();
  177. return material?_.filter(list,{"connect_key":gljUtil.getIndex(material)}):[];
  178. },
  179. getMaterialCalcDatas:function () {
  180. let gljList = projectObj.project.projectGLJ.datas.gljList;
  181. let datas = [];
  182. for(let g of gljList){
  183. if(g.quantity !== 0 && g.quantity !== '0' && g.unit_price.calcMaterial == 1){
  184. let data = {
  185. id:g.id,
  186. code:g.code,
  187. name:g.name,
  188. type:g.type,
  189. unit:g.unit,
  190. specs:g.specs,
  191. unit_price:{id:g.unit_price.id,type:g.type,unit_price_file_id:g.unit_price.unit_price_file_id},//type用来排序
  192. supplyLocation:g.unit_price.supplyLocation,
  193. originalPrice:g.unit_price.originalPrice?g.unit_price.originalPrice:0,
  194. unitFreight:g.unit_price.unitFreight?g.unit_price.unitFreight:0,
  195. // unitWeight:g.unit_price.unitWeight?g.unit_price.unitWeight:0,
  196. totalLoadingTimes:g.unit_price.totalLoadingTimes?g.unit_price.totalLoadingTimes:0,
  197. handlingLossRate_n:g.unit_price.handlingLossRate_n?g.unit_price.handlingLossRate_n:0,
  198. offSiteTransportLossRate_n:g.unit_price.offSiteTransportLossRate_n?g.unit_price.offSiteTransportLossRate_n:0,
  199. offSiteTransportLoss:g.unit_price.offSiteTransportLoss?g.unit_price.offSiteTransportLoss:0,
  200. purchaseStorageRate_n:g.unit_price.purchaseStorageRate_n?g.unit_price.purchaseStorageRate_n:0,
  201. purchaseStorage:g.unit_price.purchaseStorage?g.unit_price.purchaseStorage:0,
  202. grossWeightCoe_n:g.unit_price.grossWeightCoe_n?g.unit_price.grossWeightCoe_n:0,
  203. packageRecoverValue:g.unit_price.packageRecoverValue?g.unit_price.packageRecoverValue:0
  204. };
  205. gljOprObj.setGLJPrice(data,g);
  206. datas.push(data);
  207. }
  208. }
  209. return gljUtil.sortProjectGLJ(datas);
  210. },
  211. onMaterialSelectionChange:function(sender,args){
  212. let me = materialCalcObj;
  213. let newSel = args.newSelections[0];
  214. let oldSel = args.oldSelections?args.oldSelections[0]:{};
  215. if(newSel.row != oldSel.row){
  216. me.showPriceDatas();
  217. me.showFreightDatas();
  218. }
  219. },
  220. onFreightSelectionChange:function (sender,args) {
  221. args.sheet.repaint();
  222. },
  223. onPriceEditStarting:function (sender,args) {
  224. let me = materialCalcObj;
  225. if(!me.getMaterialSelected()){
  226. args.cancel = true;
  227. }
  228. },
  229. onFreightEditStarting:function(sender,args){
  230. let me = materialCalcObj;
  231. if(!me.getMaterialSelected()){
  232. args.cancel = true;
  233. }
  234. },
  235. onMaterialEditStarting:function (sender,args) {
  236. let me = materialCalcObj;
  237. let dataCode = me.materialSetting.header[args.col].dataCode;
  238. if(dataCode == "supplyLocation" ||dataCode == "originalPrice"){//原价计算表有数据时只读,
  239. args.cancel = me.getPriceDatas().length > 0;
  240. }
  241. if(dataCode == "unitFreight"){//当运费计算表有数据时,则只读
  242. args.cancel = me.getFreightDatas().length > 0;
  243. }
  244. },
  245. onMaterialValueChange:function (sender,args) {
  246. let me = materialCalcObj;
  247. let dataCode = me.materialSetting.header[args.col].dataCode;
  248. let value = args.newValue;
  249. if (value&&!sheetCommonObj.checkData(args.col,me.materialSetting,value)) {
  250. alert('输入的数据类型不对,请重新输入!');
  251. me.showDatas();
  252. return;
  253. }
  254. if(dataCode != 'supplyLocation'){
  255. value = value?scMathUtil.roundForObj(value,getDecimal("glj.unitPrice"))+'':'0'//4舍五入加默认为0
  256. }
  257. let recode = me.materialDatas[args.row];
  258. if(recode[dataCode] == value) return;
  259. let doc = {};
  260. doc[dataCode] = value;
  261. projectObj.project.projectGLJ.updateMaterialCalc([{id:recode.id,doc:doc}]);
  262. },
  263. onFreightValueChange:function (sender,args) {
  264. let me = materialCalcObj;
  265. let dataCode = me.freightSetting.header[args.col].dataCode;
  266. let value = args.newValue;
  267. let material = me.getMaterialSelected();
  268. if (value&&!sheetCommonObj.checkData(args.col,me.freightSetting,value)) {
  269. alert('输入的数据类型不对,请重新输入!');
  270. me.showDatas();
  271. return;
  272. }
  273. if(dataCode != 'start'&&dataCode != 'conveyance'){
  274. value = value?scMathUtil.roundForObj(value,getDecimal("glj.unitPrice"))+'':'0'//4舍五入加默认为0
  275. }
  276. if(args.row >= me.freightDatas.length){//新增
  277. let newData = {
  278. start:"",//起讫地点
  279. conveyance:"汽车",//运输工具
  280. unitFreight:'0',//单位运价
  281. kmDistance:'0',//km运距
  282. unitLoadingFee:'0',//装卸费单价
  283. loadingTimes:'0',//装卸次数
  284. otherFee:'0',//其它费用
  285. freightIncreaseRate:'0',//运价增加率
  286. weightCoe:'1',//加权系数
  287. connect_key:gljUtil.getIndex(material),
  288. unit_price_file_id:material.unit_price.unit_price_file_id
  289. };
  290. newData[dataCode] = value;
  291. projectObj.project.projectGLJ.addFreightCalc([newData],material.id);
  292. }else {//修改
  293. let recode = me.freightDatas[args.row];
  294. if(recode[dataCode] == value) return;
  295. let doc = {};
  296. doc[dataCode] = value;
  297. projectObj.project.projectGLJ.updateFreightCalc([{ID:recode.ID,doc:doc}],material.id);
  298. }
  299. },
  300. onPriceValueChange:function(sender,args){
  301. let me = materialCalcObj;
  302. let dataCode = me.priceSetting.header[args.col].dataCode;
  303. let value = args.newValue;
  304. let material = me.getMaterialSelected();
  305. //输入有效性判断, to do
  306. if (value&&!sheetCommonObj.checkData(args.col,me.priceSetting,value)) {
  307. alert('输入的数据类型不对,请重新输入!');
  308. me.showDatas();
  309. return;
  310. }
  311. if(dataCode == 'coe'||dataCode == 'supplyPrice'){
  312. value = value?scMathUtil.roundForObj(value,getDecimal("glj.unitPrice"))+'':'0'//4舍五入加默认为0
  313. }
  314. if(args.row >= me.priceDatas.length){//新增
  315. let newData = {
  316. supplyLocation:"",
  317. supplyPrice:'0',
  318. coe:'1',
  319. connect_key:gljUtil.getIndex(material),
  320. unit_price_file_id:material.unit_price.unit_price_file_id
  321. };
  322. newData[dataCode] = value;
  323. projectObj.project.projectGLJ.addPriceCalc([newData],material.id);
  324. }else {//修改
  325. let recode = me.priceDatas[args.row];
  326. if(recode[dataCode] == value) return;
  327. let doc = {};
  328. doc[dataCode] = value;
  329. projectObj.project.projectGLJ.updatePriceCalc([{ID:recode.ID,doc:doc}],material.id);
  330. }
  331. },
  332. deleteMaterialCal:function (row) {
  333. let record = this.materialDatas[row];//修改材料计算标记的同时还要删除原价计算,运费计算等
  334. if(record){
  335. projectObj.project.projectGLJ.updateCalcMaterial(record,'calcMaterial',0);
  336. }
  337. },
  338. deletePriceCalc:function (row) {
  339. let record = this.priceDatas[row];
  340. if(record){
  341. let material = this.getMaterialSelected();
  342. projectObj.project.projectGLJ.deletePriceCalc(record.ID,material.id);
  343. }
  344. },
  345. deleteFreightCalc:function (row) {
  346. let record = this.freightDatas[row];
  347. if(record){
  348. let material = this.getMaterialSelected();
  349. projectObj.project.projectGLJ.deleteFreightCalc(record.ID,material.id);
  350. }
  351. },
  352. getSideResize: function () {
  353. let rg_sideResizeEles = {};
  354. rg_sideResizeEles.eleObj = {
  355. module: this.moduleName,
  356. resize: $('#mrResize'),
  357. parent: $('#projectGljBottom'),
  358. left: $('#materialCalcSheet'),
  359. right: $('#calcDiv')
  360. };
  361. rg_sideResizeEles.limit = {
  362. min: 100,
  363. max: `$('#projectGljBottom').width()-100`
  364. };
  365. return rg_sideResizeEles;
  366. },
  367. initRightClick:function (id,spread) {
  368. let me = this;
  369. $.contextMenu({
  370. selector: '#'+id,
  371. build: function ($trigger, e) {
  372. me.rightClickTarget = SheetDataHelper.safeRightClickSelection($trigger, e, spread);
  373. return me.rightClickTarget.hitTestType === GC.Spread.Sheets.SheetArea.viewport ||
  374. me.rightClickTarget.hitTestType === GC.Spread.Sheets.SheetArea.rowHeader;
  375. },
  376. items: {
  377. "delete": {
  378. name: "删除",
  379. icon: 'fa-trash-o',
  380. disabled: function () {
  381. if(id == "priceSheet") return me.rightClickTarget.row >= me.priceDatas.length;
  382. if(id == "freightSheet") return me.rightClickTarget.row >= me.freightDatas.length;
  383. return me.rightClickTarget.row === undefined;
  384. },
  385. callback: function (key, opt) {
  386. let row = me.rightClickTarget.row;
  387. if (id == "materialCalcSheet") me.deleteMaterialCal(row);
  388. if (id == "priceSheet") me.deletePriceCalc(row);
  389. if(id == "freightSheet") me.deleteFreightCalc(row);
  390. }
  391. }
  392. }
  393. });
  394. },
  395. initTabWidth:function () {
  396. if($("#mix_ratio_sheet").is(':visible')) return ;//如果是组成物计算界面,返回
  397. let mr_sideResizeEles = this.getSideResize();
  398. SlideResize.loadHorizonWidth(mr_sideResizeEles.eleObj.module,
  399. [mr_sideResizeEles.eleObj.resize], [mr_sideResizeEles.eleObj.left, mr_sideResizeEles.eleObj.right],null,2);
  400. $("#spreadTabDiv").width( $('#calcDiv').width() - mr_sideResizeEles.eleObj.resize.width() - 32)
  401. }
  402. };
  403. $(function () {
  404. $("#calc-nav").on('shown.bs.tab', function () {
  405. materialCalcObj.initTabWidth();
  406. projectGljObject.refreshSubViews();
  407. });
  408. $("#calTab ul li a").on('shown.bs.tab', function () {
  409. materialCalcObj.showFreightDatas();
  410. materialCalcObj.showPriceDatas();
  411. projectGljObject.refreshSubViews();
  412. });
  413. });
  414. let mr_sideResizeEles = materialCalcObj.getSideResize();
  415. SlideResize.horizontalSlide(mr_sideResizeEles.eleObj, mr_sideResizeEles.limit, function(){
  416. $("#spreadTabDiv").width( $('#calcDiv').width() - mr_sideResizeEles.eleObj.resize.width() - 32);
  417. projectGljObject.refreshSubViews();
  418. },2);