material_calc_view.js 53 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075
  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: 70, dataCode: "code", dataType: "String"},
  12. {headerName: "名称", headerWidth: 105, dataCode: "name", dataType: "String"},
  13. {headerName: "预算价", headerWidth: 60, dataCode: "marketPrice", hAlign: "right", dataType: "Number",validator:"number"},
  14. {headerName: "供应地点", headerWidth: 75, 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: 65, dataCode: "grossWeightCoe_n", hAlign: "right", dataType: "Number",validator:"number"},//,decimalField:"glj.unitPrice"
  18. {headerName: "装卸总次数", headerWidth: 53, 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. rowHeaderWidth:25,
  29. colHeaderHeight:36
  30. }
  31. },
  32. freightSpread:null,
  33. freightSheet:null,
  34. freightDatas:[],
  35. conveyanceOptions:["自办运输","汽车","火车","船舶","马车","手推车","拖拉机"],
  36. userFreightList:[],
  37. freightSetting:{
  38. header:[
  39. {headerName: "起讫地点", headerWidth: 85, dataCode: "start", dataType: "String"},
  40. {headerName: "运输工具", headerWidth: 65, dataCode: "conveyance", dataType: "String"},
  41. {headerName: "材料类型", headerWidth: 65, dataCode: "materialType", visible: false,dataType: "String",cellType:"comboBox",options:["","地方材料","外购材料","沥青、燃料等"]},
  42. {headerName: "单位运价", headerWidth: 65, dataCode: "unitFreight", hAlign: "right", dataType: "Number",validator:"number"},
  43. {headerName: "km运距", headerWidth: 55, dataCode: "kmDistance", hAlign: "right", dataType: "String",validator:"number"},
  44. {headerName: "装卸费\n单价", headerWidth: 53, dataCode: "unitLoadingFee", hAlign: "right", dataType: "String",validator:"number"},
  45. {headerName: "装卸\n次数", headerWidth: 41, dataCode: "loadingTimes", hAlign: "right", dataType: "Number",validator:"number"},//,decimalField:'glj.unitPrice'
  46. {headerName: "其它\n费用", headerWidth: 41, dataCode: "otherFee", hAlign: "right", dataType: "Number",validator:"number"},//,decimalField:"glj.unitPrice"
  47. {headerName: "运价增\n加率(%)", headerWidth: 55, dataCode: "freightIncreaseRate", hAlign: "right", dataType: "Number",validator:"number"},//,decimalField:"glj.unitPrice"
  48. {headerName: "加权\n系数", headerWidth: 41, dataCode: "weightCoe", hAlign: "right", dataType: "Number",validator:"number"},
  49. {headerName: "计算式", headerWidth: 170, dataCode: "exp", hAlign: "left", dataType: "Number",getText:'forExp'},//,decimalField:"glj.unitPrice"
  50. {headerName: "计算方式", headerWidth: 80, dataCode: "calcType",visible: false, dataType: "String",cellType:"comboBox",options:["全国","内蒙古"]}
  51. ],
  52. view: {
  53. lockColumns: ["exp"],
  54. rowHeaderWidth:25,
  55. colHeaderHeight:36
  56. },
  57. getText:{
  58. forExp:function (item) {
  59. let material = materialCalcObj.getMaterialSelected();
  60. if(gljUtil.isDef(item.materialType)&&item.materialType != ""){
  61. let uString = materialCalcObj.getNeiMengUnitFreightString(item.kmDistance,item.materialType);
  62. return `((${uString}x(1+${item.freightIncreaseRate}%)+${item.unitLoadingFee}x${item.loadingTimes})/1.09+${item.otherFee})x${material.grossWeightCoe_n}x${item.weightCoe}`;
  63. }
  64. //(单位运价×(1+运距增加率%)+装卸费单价×装卸次数+其它费用)×单位毛重×加权系数
  65. if(item.conveyance == "自办运输") return `(${item.unitFreight}x(1+${item.freightIncreaseRate}%)+${item.unitLoadingFee}x${item.loadingTimes}+${item.otherFee})x${material.grossWeightCoe_n}x${item.weightCoe}`;
  66. //(单位运价×km运距×(1+运距增加率%)+装卸费单价×装卸次数+其它费用)×单位毛重×加权系数
  67. return `(${item.unitFreight}x${item.kmDistance}x(1+${item.freightIncreaseRate}%)+${item.unitLoadingFee}x${item.loadingTimes}+${item.otherFee})x${material.grossWeightCoe_n}x${item.weightCoe}`;
  68. }
  69. }
  70. },
  71. priceSpread:null,
  72. priceSheet:null,
  73. priceDatas:[],
  74. priceSetting:{
  75. header:[
  76. {headerName: "供应地点", headerWidth: 80, dataCode: "supplyLocation", dataType: "String"},
  77. {headerName: "供应价", headerWidth: 70, dataCode: "supplyPrice", hAlign: "right", dataType: "Number",validator:"number"},
  78. {headerName: "加权系数", headerWidth: 80, dataCode: "coe", hAlign: "right", dataType: "Number",validator:"number"},//,decimalField:'glj.unitPrice'
  79. ],
  80. view: {
  81. lockColumns: [],
  82. rowHeaderWidth:25,
  83. colHeaderHeight:36
  84. }
  85. },
  86. freightRationSpread:null,
  87. freightRationSheet:null,
  88. freightRations:[],
  89. priceRations:[],
  90. priceRationSpread:null,
  91. priceRationSheet:null,
  92. rationSetting:{
  93. header:[
  94. {headerName: "编号", headerWidth: 80, dataCode: "code", dataType: "String",formatter: "@"},
  95. {headerName: "名称", headerWidth: 160, dataCode: "name", dataType: "String"},
  96. {headerName: "单位", headerWidth: 100, dataCode: "unit", dataType: "String"},
  97. {headerName: "数量", headerWidth: 100, dataCode: "quantity", dataType: "String",hAlign: "right",validator:"number"},
  98. {headerName: "高原取费类别", headerWidth: 100, dataCode: "feeType", dataType: "String",visible: false,cellType:"comboBox",options:[],maxDropDownItems:5}
  99. ],
  100. view: {
  101. lockColumns: ["unit"],
  102. rowHeaderWidth:25,
  103. colHeaderHeight:36
  104. }
  105. },
  106. initMaterialSpread:function () {
  107. this.materialSpread = SheetDataHelper.createNewSpread($("#materialCalcSheet")[0]);
  108. sheetCommonObj.spreadDefaultStyle(this.materialSpread);
  109. this.materialSheet = this.materialSpread.getSheet(0);
  110. sheetCommonObj.initSheet(this.materialSheet, this.materialSetting, 30);
  111. this.materialSheet.bind(GC.Spread.Sheets.Events.ValueChanged, this.onMaterialValueChange);
  112. this.materialSheet.bind(GC.Spread.Sheets.Events.SelectionChanged,this.onMaterialSelectionChange);
  113. this.materialSheet.bind(GC.Spread.Sheets.Events.EditStarting,this.onMaterialEditStarting);
  114. this.materialSheet.bind(GC.Spread.Sheets.Events.RangeChanged, this.onMaterialRangeChange);
  115. this.materialSheet.name('material_calc');
  116. if(projectReadOnly){
  117. disableSpread(this.materialSpread);
  118. }else {
  119. this.initRightClick("materialCalcSheet",this.materialSpread)
  120. }
  121. },
  122. initFreightSpread:async function(){
  123. this.freightSpread = SheetDataHelper.createNewSpread($("#freightSheet")[0]);
  124. sheetCommonObj.spreadDefaultStyle(this.freightSpread);
  125. this.freightSheet = this.freightSpread.getSheet(0);
  126. sheetCommonObj.initSheet(this.freightSheet, this.freightSetting, 30);
  127. this.freightSheet.bind(GC.Spread.Sheets.Events.ValueChanged, this.onFreightValueChange);
  128. this.freightSheet.bind(GC.Spread.Sheets.Events.SelectionChanged,this.onFreightSelectionChange);
  129. this.freightSheet.bind(GC.Spread.Sheets.Events.EditStarting,this.onFreightEditStarting);
  130. this.freightSheet.bind(GC.Spread.Sheets.Events.RangeChanged, this.onFreightPriceRangeChange);
  131. this.freightSheet.name('freight_calc');
  132. if(projectReadOnly){
  133. disableSpread(this.freightSpread);
  134. }else {
  135. this.initRightClick("freightSheet",this.freightSpread)
  136. }
  137. this.userFreightList = await projectObj.project.projectGLJ.getUserFreights();
  138. },
  139. initFreightRationSpread:function () {
  140. this.freightRationSpread = SheetDataHelper.createNewSpread($("#freight_ration_sheet")[0]);
  141. sheetCommonObj.spreadDefaultStyle(this.freightRationSpread);
  142. this.freightRationSheet = this.freightRationSpread.getSheet(0);
  143. sheetCommonObj.initSheet(this.freightRationSheet, this.rationSetting, 30);
  144. this.freightRationSheet.bind(GC.Spread.Sheets.Events.ValueChanged, this.onFreightRationValueChange);
  145. this.freightRationSheet.bind(GC.Spread.Sheets.Events.SelectionChanged,this.onRationSelectionChange);
  146. this.freightRationSheet.bind(GC.Spread.Sheets.Events.EditStarting,this.onFreightRationEditStarting);
  147. this.freightRationSheet.name('freight_ration');
  148. if(projectReadOnly){
  149. disableSpread(this.freightRationSpread);
  150. }else {
  151. this.initRightClick("freight_ration_sheet",this.freightRationSpread);
  152. }
  153. },
  154. initPriceRationSpread:function () {
  155. this.priceRationSpread = SheetDataHelper.createNewSpread($("#price_ration_sheet")[0]);
  156. sheetCommonObj.spreadDefaultStyle(this.priceRationSpread);
  157. this.priceRationSheet = this.priceRationSpread.getSheet(0);
  158. sheetCommonObj.initSheet(this.priceRationSheet, this.rationSetting, 30);
  159. this.priceRationSheet.bind(GC.Spread.Sheets.Events.ValueChanged, this.onPriceRationValueChange);
  160. this.priceRationSheet.bind(GC.Spread.Sheets.Events.SelectionChanged,this.onRationSelectionChange);
  161. this.priceRationSheet.bind(GC.Spread.Sheets.Events.EditStarting,this.onPriceRationEditStarting);
  162. this.priceRationSheet.name('price_ration');
  163. if(projectReadOnly){
  164. disableSpread(this.priceRationSpread);
  165. }else {
  166. this.initRightClick("price_ration_sheet",this.priceRationSpread);
  167. }
  168. },
  169. initPriceSpread:async function(){
  170. this.priceSpread = SheetDataHelper.createNewSpread($("#priceSheet")[0]);
  171. sheetCommonObj.spreadDefaultStyle(this.priceSpread);
  172. this.priceSheet = this.priceSpread.getSheet(0);
  173. sheetCommonObj.initSheet(this.priceSheet, this.priceSetting, 30);
  174. this.priceSheet.bind(GC.Spread.Sheets.Events.RangeChanged, this.onFreightPriceRangeChange);
  175. this.priceSheet.bind(GC.Spread.Sheets.Events.ValueChanged, this.onPriceValueChange);
  176. this.priceSheet.bind(GC.Spread.Sheets.Events.SelectionChanged,this.onPriceSelectionChange);
  177. this.priceSheet.bind(GC.Spread.Sheets.Events.EditStarting,this.onPriceEditStarting);
  178. this.priceSheet.name('price_calc');
  179. if(projectReadOnly){
  180. disableSpread(this.priceSpread);
  181. }else {
  182. this.initRightClick("priceSheet",this.priceSpread)
  183. }
  184. },
  185. showFreightDatas:function () {
  186. if(!$('#freightSheet').is(':visible')) return;
  187. let sel = this.freightSheet.getSelections()[0];
  188. let oldData = sel.row<this.freightDatas.length?this.freightDatas[sel.row]:"";
  189. this.freightSheet.setRowCount(0);
  190. this.freightDatas = this.getFreightDatas();
  191. sheetCommonObj.showData(this.freightSheet, this.freightSetting,this.freightDatas);
  192. this.freightSheet.setRowCount(this.freightDatas.length+20);
  193. let convCol = _.findIndex(this.freightSetting.header,{'dataCode':'conveyance'});
  194. sheetCommonObj.setComboBox(-1,convCol,this.freightSheet,this.conveyanceOptions,false);
  195. let startCol = _.findIndex(this.freightSetting.header,{'dataCode':'start'});
  196. let startOptions = this.getUserFreightOptions();
  197. sheetCommonObj.setComboBox(-1,startCol,this.freightSheet,startOptions,false,true,5);
  198. sel.row = oldData?_.findIndex(this.freightDatas,{'ID':oldData.ID}):sel.row ;
  199. this.freightSheet.setSelection(sel.row==-1?0:sel.row,sel.col,sel.rowCount,sel.colCount);
  200. this.refreshRationView();
  201. },
  202. getUserFreightOptions :function () {
  203. let options = [];
  204. for(let uf of this.userFreightList){
  205. options.push(uf.freight.start);
  206. }
  207. return options;
  208. },
  209. showFreightRationDatas:function (freight) {
  210. let sel = this.freightRationSheet.getSelections()[0];
  211. let oldData = sel.row<this.freightRations.length?this.freightRations[sel.row]:"";
  212. this.freightRationSheet.setRowCount(0);
  213. this.freightRations = freight.rations?freight.rations:[];
  214. sheetCommonObj.showData(this.freightRationSheet, this.rationSetting,this.freightRations);
  215. this.freightRationSheet.setRowCount(this.freightRations+20);
  216. sel.row = oldData?_.findIndex(this.freightRations,{'ID':oldData.ID}):sel.row ;
  217. this.freightRationSheet.setSelection(sel.row==-1?0:sel.row,sel.col,sel.rowCount,sel.colCount);
  218. this.refreshAssView();
  219. },
  220. showPriceRationDatas:function () {
  221. let price = this.getSelectedPrice();
  222. let sel = this.priceRationSheet.getSelections()[0];
  223. let oldData = sel.row<this.priceRations.length?this.priceRations[sel.row]:"";
  224. this.priceRationSheet.setRowCount(0);
  225. this.priceRations = price&&price.rations?price.rations:[];
  226. sheetCommonObj.showData(this.priceRationSheet, this.rationSetting,this.priceRations);
  227. this.priceRationSheet.setRowCount(this.priceRations+20);
  228. sel.row = oldData?_.findIndex(this.priceRations,{'ID':oldData.ID}):sel.row ;
  229. this.priceRationSheet.setSelection(sel.row==-1?0:sel.row,sel.col,sel.rowCount,sel.colCount);
  230. this.refreshAssView();
  231. },
  232. showMaterialCalcDatas:function(){
  233. let sel = this.materialSheet.getSelections()[0];
  234. let oldData = sel.row<this.materialDatas.length?this.materialDatas[sel.row]:"";
  235. this.materialSheet.setRowCount(0);
  236. this.materialDatas = this.getMaterialCalcDatas();
  237. sheetCommonObj.showData(this.materialSheet, this.materialSetting,this.materialDatas);
  238. this.materialSheet.setRowCount(this.materialDatas.length);
  239. sel.row = oldData?_.findIndex(this.materialDatas,{'id':oldData.id}):-1;
  240. this.materialSheet.setSelection(sel.row==-1?0:sel.row,sel.col,sel.rowCount,sel.colCount);
  241. },
  242. showPriceDatas:function () {
  243. if(!$('#priceSheet').is(':visible')) return;
  244. let sel = this.priceSheet.getSelections()[0];
  245. let oldData = sel.row<this.priceDatas.length?this.priceDatas[sel.row]:"";
  246. this.priceSheet.setRowCount(0);
  247. this.priceDatas = this.getPriceDatas();
  248. sheetCommonObj.showData(this.priceSheet, this.priceSetting,this.priceDatas);
  249. this.priceSheet.setRowCount(this.priceDatas.length+20);
  250. sel.row = oldData?_.findIndex(this.priceDatas,{'ID':oldData.ID}):sel.row ;
  251. this.priceSheet.setSelection(sel.row==-1?0:sel.row,sel.col,sel.rowCount,sel.colCount);
  252. this.showPriceRationDatas();
  253. },
  254. showDatas:async function(){
  255. if(!$('#materialCalcSheet').is(':visible')) return;
  256. if(!this.materialSpread) this.initMaterialSpread();
  257. if(!this.freightSpread)await this.initFreightSpread();
  258. if(!this.priceSpread) this.initPriceSpread();
  259. if(!this.freightRationSpread) this.initFreightRationSpread();
  260. if(!this.priceRationSpread) this.initPriceRationSpread();
  261. let h =_.find(this.rationSetting.header,{"dataCode":"feeType"});
  262. if(h) h.options = projectObj.project.calcProgram.compiledTemplateNames;
  263. this.showMaterialCalcDatas();
  264. this.showFreightDatas();
  265. this.showPriceDatas();
  266. // 先试试看注释有没有bug projectGljObject.refreshSubViews();
  267. },
  268. getMaterialSelected:function () {
  269. let sel = this.materialSheet.getSelections()[0];
  270. if(sel.row != -1 && this.materialDatas.length>sel.row){
  271. return this.materialDatas[sel.row]
  272. }
  273. return null;
  274. },
  275. getPriceDatas:function () {
  276. let list = projectObj.project.projectGLJ.datas.originalList;
  277. let material = this.getMaterialSelected();
  278. return material?_.filter(list,{"connect_key":gljUtil.getIndex(material)}):[];
  279. },
  280. getFreightDatas:function () {
  281. let list = projectObj.project.projectGLJ.datas.freightList;
  282. let material = this.getMaterialSelected();
  283. return material?_.filter(list,{"connect_key":gljUtil.getIndex(material)}):[];
  284. },
  285. getMaterialCalcDatas:function () {
  286. let gljList = projectObj.project.projectGLJ.datas.gljList;
  287. let datas = [];
  288. for(let g of gljList){
  289. if(g.quantity !== 0 && g.quantity !== '0' && g.unit_price.calcMaterial == 1){
  290. let data = {
  291. id:g.id,
  292. code:g.code,
  293. name:g.name,
  294. type:g.type,
  295. unit:g.unit,
  296. specs:g.specs,
  297. unit_price:{id:g.unit_price.id,type:g.type,unit_price_file_id:g.unit_price.unit_price_file_id},//type用来排序
  298. supplyLocation:g.unit_price.supplyLocation,
  299. originalPrice:g.unit_price.originalPrice?g.unit_price.originalPrice:0,
  300. unitFreight:g.unit_price.unitFreight?g.unit_price.unitFreight:0,
  301. // unitWeight:g.unit_price.unitWeight?g.unit_price.unitWeight:0,
  302. totalLoadingTimes:g.unit_price.totalLoadingTimes?g.unit_price.totalLoadingTimes:0,
  303. handlingLossRate_n:g.unit_price.handlingLossRate_n?g.unit_price.handlingLossRate_n:0,
  304. offSiteTransportLossRate_n:g.unit_price.offSiteTransportLossRate_n?g.unit_price.offSiteTransportLossRate_n:0,
  305. offSiteTransportLoss:g.unit_price.offSiteTransportLoss?g.unit_price.offSiteTransportLoss:0,
  306. purchaseStorageRate_n:g.unit_price.purchaseStorageRate_n?g.unit_price.purchaseStorageRate_n:0,
  307. purchaseStorage:g.unit_price.purchaseStorage?g.unit_price.purchaseStorage:0,
  308. grossWeightCoe_n:g.unit_price.grossWeightCoe_n?g.unit_price.grossWeightCoe_n:0,
  309. packageRecoverValue:g.unit_price.packageRecoverValue?g.unit_price.packageRecoverValue:0
  310. };
  311. gljOprObj.setGLJPrice(data,g);
  312. datas.push(data);
  313. }
  314. }
  315. return gljUtil.sortProjectGLJ(datas);
  316. },
  317. onMaterialSelectionChange:function(sender,args){
  318. let me = materialCalcObj;
  319. let newSel = args.newSelections[0];
  320. let oldSel = args.oldSelections?args.oldSelections[0]:{};
  321. if(newSel.row != oldSel.row){
  322. me.showPriceDatas();
  323. me.showFreightDatas();
  324. }
  325. },
  326. onFreightSelectionChange:function (sender,args) {
  327. materialCalcObj.refreshRationView();
  328. args.sheet.repaint();
  329. },
  330. onRationSelectionChange:function(sender,args){
  331. materialCalcObj.refreshAssView(args);
  332. args.sheet.repaint();
  333. },
  334. onPriceSelectionChange:function (sender,args) {
  335. materialCalcObj.showPriceRationDatas();
  336. },
  337. onPriceEditStarting:function (sender,args) {
  338. let me = materialCalcObj;
  339. if(!me.getMaterialSelected()){
  340. args.cancel = true;
  341. }else {
  342. let price = me.priceDatas[args.row];
  343. let dataCode = me.priceSetting.header[args.col].dataCode;
  344. if(dataCode == "supplyPrice"){
  345. if(price.rations && price.rations.length > 0) args.cancel = true;
  346. }
  347. }
  348. },
  349. onFreightEditStarting:function(sender,args){
  350. let me = materialCalcObj;
  351. if(!me.getMaterialSelected()){
  352. args.cancel = true;
  353. }else {
  354. let freigth = me.freightDatas[args.row];
  355. let dataCode = me.freightSetting.header[args.col].dataCode;
  356. if(dataCode=="materialType"){
  357. if(!freigth){
  358. args.cancel = true;
  359. }else if(freigth.conveyance !="汽车"){//只有在汽车的情况下,材料类型列才能编辑
  360. args.cancel = true;
  361. }
  362. }
  363. if(freigth){
  364. if(dataCode == "kmDistance" || dataCode=="unitLoadingFee" || dataCode =="loadingTimes" || dataCode == "freightIncreaseRate"){
  365. if(freigth.conveyance == "自办运输") args.cancel = true;
  366. }
  367. if(dataCode == "unitFreight"){
  368. if(freigth.rations && freigth.rations.length > 0) args.cancel = true;
  369. if(gljUtil.isDef(freigth.materialType) && freigth.materialType != "") args.cancel = true;//当材料类型有值时,说明是内蒙古计算,运费是通过运距算出来的,不能编辑
  370. }
  371. }
  372. }
  373. },
  374. onFreightRationEditStarting:function (sender,args) {
  375. materialCalcObj.onRationEditStarting(sender,args,"freight");
  376. },
  377. onPriceRationEditStarting:function (sender,args) {
  378. materialCalcObj.onRationEditStarting(sender,args,"price");
  379. },
  380. onRationEditStarting:function(sender,args,type){
  381. let me = materialCalcObj;
  382. let dataCode = me.rationSetting.header[args.col].dataCode;
  383. let datas = type == "freight"?me.freightRations:me.priceRations;
  384. if(type == 'price' && !gljUtil.isDef(me.getSelectedPrice())) args.cancel = true;//没有选中原价,不可编辑
  385. if(args.row > datas.length){
  386. args.cancel = true;
  387. }else if(args.row == datas.length && dataCode != "code"){
  388. args.cancel = true;
  389. }
  390. },
  391. onMaterialEditStarting:function (sender,args) {
  392. let me = materialCalcObj;
  393. let dataCode = me.materialSetting.header[args.col].dataCode;
  394. if(dataCode == "supplyLocation" ||dataCode == "originalPrice"){//原价计算表有数据时只读,
  395. args.cancel = me.getPriceDatas().length > 0;
  396. }
  397. if(dataCode == "unitFreight"){//当运费计算表有数据时,则只读
  398. args.cancel = me.getFreightDatas().length > 0;
  399. }
  400. },
  401. onMaterialValueChange:function (sender,args) {
  402. let me = materialCalcObj;
  403. let dataMap = {};
  404. dataMap[args.row]={};
  405. dataMap[args.row][args.col] = args.newValue;
  406. me.updateMaterialCalcs(dataMap);
  407. },
  408. updateMaterialCalcs:function(dataMap){
  409. let me = materialCalcObj;
  410. let updateDatas = [];
  411. for(let row in dataMap) {
  412. let t = dataMap[row];
  413. let doc = {};
  414. let recode = me.materialDatas[row];
  415. for (let col in t) {
  416. let value = t[col];
  417. let dataCode = me.materialSetting.header[col].dataCode;
  418. if (value&&!sheetCommonObj.checkData(col,me.materialSetting,value)) {
  419. alert('输入的数据类型不对,请重新输入!');
  420. return me.showDatas();
  421. }
  422. if(dataCode != 'supplyLocation'){
  423. value = value?scMathUtil.roundForObj(value,getDecimal("glj.unitPrice"))+'':'0'//4舍五入加默认为0
  424. }
  425. if(recode[dataCode] == value) continue;
  426. doc[dataCode] = value;
  427. }
  428. if (!_.isEmpty(doc)) updateDatas.push({id:recode.id,doc:doc});
  429. }
  430. if(updateDatas.length > 0) projectObj.project.projectGLJ.updateMaterialCalc(updateDatas);
  431. },
  432. getDefualtCalcType:function () {
  433. return "全国";
  434. },
  435. getNewFreightData:function (material) {
  436. let newData = {
  437. ID: uuid.v1(),
  438. start:"",//起讫地点
  439. conveyance:"汽车",//运输工具
  440. unitFreight:'0',//单位运价
  441. kmDistance:'0',//km运距
  442. unitLoadingFee:'0',//装卸费单价
  443. loadingTimes:'0',//装卸次数
  444. otherFee:'0',//其它费用
  445. freightIncreaseRate:'0',//运价增加率
  446. weightCoe:'1',//加权系数
  447. connect_key:gljUtil.getIndex(material),
  448. materialType:"",
  449. unit_price_file_id:material.unit_price.unit_price_file_id
  450. };
  451. return newData;
  452. },
  453. getSavedFreight:function (start,material) {
  454. let t = null;
  455. for(let f of this.userFreightList){
  456. if(f.freight.start == start){
  457. t = newDatas(f.freight,material);
  458. break;
  459. }
  460. }
  461. return t;
  462. function newDatas(freight,material) {
  463. let doc = {};
  464. for(let key in freight){
  465. doc[key] = freight[key];
  466. if(key == "ID") doc[key] = uuid.v1();
  467. if(key == "connect_key") doc[key] = gljUtil.getIndex(material);
  468. if(key == "unit_price_file_id") doc[key] = material.unit_price.unit_price_file_id;
  469. }
  470. delete doc._id;
  471. return doc;
  472. }
  473. },
  474. checkSavedFreight:function (start) {
  475. let t = null;
  476. for(let f of this.userFreightList){
  477. if(f.freight.start == start){
  478. t = f;
  479. break;
  480. }
  481. }
  482. return t;
  483. },
  484. onMaterialRangeChange:function(sender,args){
  485. let me = materialCalcObj;
  486. let dataMap={};
  487. for(let c of args.changedCells){
  488. let info = {row:c.row,col:c.col,cancel:false};
  489. me.onMaterialEditStarting(sender,info);
  490. if(info.cancel) return me.showDatas();
  491. let value= args.sheet.getCell(c.row, c.col).text();
  492. if(dataMap[c.row]){
  493. dataMap[c.row][c.col]=value;
  494. }else{
  495. dataMap[c.row] ={};
  496. dataMap[c.row][c.col] = value;
  497. }
  498. }
  499. me.updateMaterialCalcs(dataMap);
  500. },
  501. onFreightPriceRangeChange:function (sender,args) {
  502. let me = materialCalcObj;
  503. let dataMap={};
  504. let sheetName = args.sheet.name();
  505. for(let c of args.changedCells){
  506. let info = {row:c.row,col:c.col,cancel:false};
  507. sheetName == 'price_calc'?me.onPriceEditStarting(sender,info): me.onFreightEditStarting(sender,info);
  508. if(info.cancel) return me.showDatas();
  509. let value= args.sheet.getCell(c.row, c.col).text();
  510. if(dataMap[c.row]){
  511. dataMap[c.row][c.col]=value;
  512. }else{
  513. dataMap[c.row] ={};
  514. dataMap[c.row][c.col] = value;
  515. }
  516. }
  517. sheetName == 'price_calc'?me.addOrUpdatePriceCalc(dataMap):me.addOrUpdateFreightCalc(dataMap);
  518. },
  519. onFreightValueChange:function (sender,args) {
  520. let me = materialCalcObj;
  521. let dataMap = {};
  522. dataMap[args.row]={};
  523. dataMap[args.row][args.col] = args.newValue;
  524. me.addOrUpdateFreightCalc(dataMap);
  525. },
  526. addOrUpdateFreightCalc:function (dataMap) {//{2:{col:value}}
  527. let me = materialCalcObj;
  528. let material = me.getMaterialSelected();
  529. let addDatas=[],updateDatas=[];
  530. for(let row in dataMap) {
  531. let t = dataMap[row];
  532. let newData = {};
  533. let doc = {};
  534. let recode = me.freightDatas[row];
  535. for (let col in t) {
  536. let value = t[col];
  537. let dataCode = me.freightSetting.header[col].dataCode;
  538. if (value && !sheetCommonObj.checkData(col, me.freightSetting, value)) {
  539. alert('输入的数据类型不对,请重新输入!');
  540. return me.showDatas();
  541. }
  542. if (dataCode != 'start' && dataCode != 'conveyance' && dataCode != 'calcType' && dataCode != 'materialType') {
  543. value = value ? scMathUtil.roundForObj(value, getDecimal("glj.unitPrice")) + '' : '0'//4舍五入加默认为0
  544. }
  545. if (parseInt(row) >= me.freightDatas.length) {//新增
  546. let tempFreight = null;
  547. if (dataCode == "start") {
  548. tempFreight = me.getSavedFreight(value, material);
  549. }
  550. if (tempFreight) {
  551. newData = tempFreight;
  552. } else {
  553. if(_.isEmpty(newData)) newData = me.getNewFreightData(material);
  554. newData[dataCode] = value;
  555. }
  556. } else {//修改
  557. if (recode[dataCode] == value) continue;
  558. doc[dataCode] = value;
  559. if (dataCode == "conveyance") {//如果运输方式从自办运输切换成其它的东西时,要把底下挂的定额和定额工料机都清空
  560. if (recode[dataCode] == "自办运输") {//没改之前的值
  561. doc["rations"] = [];
  562. doc["ration_gljs"] = [];
  563. }
  564. if (value == "自办运输") {//当运输工具下拉选择“自办运输”时,“Km运距”、“装卸费单价”、“装卸次数”、“运价增加率(%)”列数据归0,且灰选不可编辑
  565. doc["kmDistance"] = '0';
  566. doc["unitLoadingFee"] = '0';
  567. doc["loadingTimes"] = '0';
  568. doc["freightIncreaseRate"] = '0';
  569. }
  570. if (recode[dataCode] == "汽车") doc["materialType"] = "";//当运输方式从汽车切换成其它方式时,清空材料类型
  571. }
  572. if (dataCode == "materialType" && value != "") doc["unitFreight"] = me.calcNeiMengUnitFreight(recode.kmDistance, value);
  573. if (dataCode == "kmDistance" && gljUtil.isDef(recode.materialType) && recode.materialType != "") doc["unitFreight"] = me.calcNeiMengUnitFreight(value, recode.materialType);
  574. if (dataCode == "start") {
  575. let t_f = me.getSavedFreight(value, material);
  576. if (t_f) doc = t_f;
  577. }
  578. }
  579. }
  580. if (!_.isEmpty(newData)) addDatas.push(newData);
  581. if (!_.isEmpty(doc)) updateDatas.push({ID:recode.ID,doc:doc});
  582. }
  583. if(addDatas.length > 0 && updateDatas.length > 0) {
  584. alert("不能同时增加和更新操作");
  585. return me.showDatas();
  586. }
  587. if(addDatas.length > 0) projectObj.project.projectGLJ.addFreightCalc(addDatas,material.id);
  588. if(updateDatas.length > 0) projectObj.project.projectGLJ.updateFreightCalc(updateDatas,material.id);
  589. },
  590. calcNeiMengUnitFreight:function (tkmDistance,tmaterialType) {
  591. if(!tkmDistance||tkmDistance == '0') return "0";
  592. let decimal = getDecimal("glj.unitPrice");
  593. tkmDistance = scMathUtil.roundForObj(tkmDistance,decimal);
  594. return scMathUtil.roundForObj(this.calNeiMengTotalFreight(tkmDistance,tmaterialType)/tkmDistance,decimal);
  595. },
  596. calNeiMengTotalFreight:function (kmDistance,materialType) {
  597. if(!kmDistance||kmDistance == '0') return 0;
  598. let decimal = getDecimal("glj.unitPrice");
  599. let baseMap = {"地方材料":6,"外购材料":13,"沥青、燃料等":19};//"地方材料","外购材料","沥青、燃料等"
  600. let baseFreight = baseMap[materialType];
  601. kmDistance = scMathUtil.roundForObj(kmDistance,decimal);
  602. //用截取的方式,一段段取值
  603. let less = kmDistance - 5;//kmDistance <= 5 这段
  604. if(less <= 0) return baseFreight ; //kmDistance <= 5 的时候直接取baseFreight
  605. //5< kmDistance <= 15 每增运1km 则增加0.6
  606. less = less - 10;
  607. if(less <=0) return scMathUtil.roundForObj(baseFreight + scMathUtil.roundForObj((less + 10) * 0.6,6),decimal);//baseFreight + (less + 10) * 0.6;
  608. baseFreight = baseFreight + 10 * 0.6; //累加5到15这一段的运费;
  609. //15< kmDistance <= 100 每增运1km 则增加0.45
  610. less = less - 85;
  611. if(less <=0) return scMathUtil.roundForObj(baseFreight + scMathUtil.roundForObj((less + 85)*0.45,6),decimal);//baseFreight + (less + 85)*0.45;
  612. baseFreight = scMathUtil.roundForObj(baseFreight + scMathUtil.roundForObj(85*0.45,6),6) ; //累加15到100这一段的运费;
  613. return scMathUtil.roundForObj(baseFreight + scMathUtil.roundForObj(less * 0.35,6),decimal); // >100 的所有部分每增运1km 则增加0.35 baseFreight + less * 0.35
  614. },
  615. getNeiMengUnitFreightString:function (kmDistance,materialType) {
  616. if(!kmDistance||kmDistance == '0') return "0";
  617. let decimal = getDecimal("glj.unitPrice");
  618. let baseMap = {"地方材料":6,"外购材料":13,"沥青、燃料等":19};//"地方材料","外购材料","沥青、燃料等"
  619. let baseFreight = baseMap[materialType];
  620. kmDistance = scMathUtil.roundForObj(kmDistance,decimal);
  621. let resultString = baseFreight+"";
  622. //用截取的方式,一段段取值
  623. let less = kmDistance - 5;//kmDistance <= 5 这段
  624. if(less <= 0) return resultString ; //kmDistance <= 5 的时候直接取baseFreight
  625. //5< kmDistance <= 15 每增运1km 则增加0.6
  626. less = less - 10;
  627. if(less <=0) return `(${resultString}+0.6x${less + 10})`;//baseFreight + (less + 10) * 0.6;
  628. resultString = `${resultString}+0.6x10`;
  629. //15< kmDistance <= 100 每增运1km 则增加0.45
  630. less = less - 85;
  631. if(less <=0) return `(${resultString}+0.45x${less + 85})`; //baseFreight + (less + 85)*0.45;
  632. resultString = `${resultString}+0.45x85`;
  633. return `(${resultString}+0.35x${less})`;// >100 的所有部分每增运1km 则增加0.35 baseFreight + less * 0.35
  634. },
  635. onFreightRationValueChange:function (sender,args) {
  636. materialCalcObj.onRationValueChange(sender,args,"freight");
  637. },
  638. onPriceRationValueChange:function (sender,args) {
  639. materialCalcObj.onRationValueChange(sender,args,"price");
  640. },
  641. onRationValueChange:function (sender,args,type) {
  642. let me = materialCalcObj;
  643. let dataCode = me.rationSetting.header[args.col].dataCode;
  644. let value = args.newValue;
  645. let parent = type == "freight"? me.getSelectedFreight():me.getSelectedPrice();
  646. let dataList = type == "freight"?me.freightRations:me.priceRations;
  647. if(dataCode == "code" && args.row >= dataList.length) {//新增
  648. if(parent) projectObj.project.projectGLJ.addMaterialRation(value,type,parent.ID,parent.connect_key);
  649. }else { //修改
  650. let ration = dataList[args.row];
  651. if (value&&!sheetCommonObj.checkData(args.col,me.rationSetting,value)) {
  652. alert('输入的数据类型不对,请重新输入!');
  653. return type == "freight"?me.showFreightRationDatas(parent):me.showPriceRationDatas();
  654. }
  655. if(dataCode == 'quantity'){
  656. if(value){
  657. value = scMathUtil.roundForObj(parseFloat(value) / FilterNumberFromUnit(ration.unit),getDecimal("ration.quantity"))+"";
  658. }else {
  659. value = "0";
  660. }
  661. }
  662. let datas = {parentID:parent.ID,rationID:ration.ID,type:type,actionType:"update",field:dataCode,value:value};
  663. if(dataCode == "code"){ //这时是替换,替换比较麻烦
  664. datas.code = value;
  665. datas.row = args.row;
  666. let libIDs = rationLibObj.getStdRationLibIDs();
  667. let defaultLibID = rationLibObj.getDefaultStdRationLibID();
  668. let selectedLib = sessionStorage.getItem("stdRationLib");
  669. selectedLib&&selectedLib!='undefined'?libIDs.unshift(selectedLib):libIDs.unshift(defaultLibID);
  670. datas.userID = userID;
  671. datas.defaultLibID = defaultLibID;
  672. datas.rationRepIds = libIDs;
  673. datas.quantityDecimal = getDecimal("ration.quantity");
  674. datas.connect_key = parent.connect_key;
  675. datas.projectID = projectObj.project.ID();
  676. datas.rations = parent.rations;
  677. datas.ration_gljs = parent.ration_gljs;
  678. }
  679. projectObj.project.projectGLJ.updateMaterialRation(datas);
  680. }
  681. },
  682. addOrUpdatePriceCalc:function (dataMap) {
  683. let me = materialCalcObj;
  684. let material = me.getMaterialSelected();
  685. let addDatas=[],updateDatas=[];
  686. for(let row in dataMap) {
  687. let t = dataMap[row];
  688. let doc = {};
  689. let recode = me.priceDatas[row];
  690. let newData = {};
  691. for (let col in t) {
  692. let value = t[col];
  693. let dataCode = me.priceSetting.header[col].dataCode;;
  694. if (value && !sheetCommonObj.checkData(col, me.priceSetting, value)) {
  695. alert('输入的数据类型不对,请重新输入!');
  696. return me.showDatas();
  697. }
  698. if(dataCode == 'coe'||dataCode == 'supplyPrice'){
  699. let decimal = dataCode == 'supplyPrice'?getDecimal("glj.unitPriceHasMix"):getDecimal("glj.unitPrice");
  700. value = value?scMathUtil.roundForObj(value,decimal)+'':'0'//4舍五入加默认为0
  701. }
  702. if(parseInt(row) >= me.priceDatas.length){//新增
  703. if(_.isEmpty(newData)) newData = me.getNewPriceData(material);
  704. newData[dataCode] = value;
  705. }else {//修改
  706. if(recode[dataCode] == value) continue;
  707. doc[dataCode] = value;
  708. }
  709. }
  710. if (!_.isEmpty(newData)) addDatas.push(newData);
  711. if (!_.isEmpty(doc)) updateDatas.push({ID:recode.ID,doc:doc});
  712. }
  713. if(addDatas.length > 0 && updateDatas.length > 0) {
  714. alert("不能同时增加和更新操作");
  715. return me.showDatas();
  716. }
  717. if(addDatas.length > 0) projectObj.project.projectGLJ.addPriceCalc(addDatas,material.id);
  718. if(updateDatas.length > 0) projectObj.project.projectGLJ.updatePriceCalc(updateDatas,material.id);
  719. },
  720. getNewPriceData:function (material) {
  721. let newData = {
  722. ID:uuid.v1(),
  723. supplyLocation:"",
  724. supplyPrice:'0',
  725. coe:'1',
  726. connect_key:gljUtil.getIndex(material),
  727. unit_price_file_id:material.unit_price.unit_price_file_id
  728. };
  729. return newData;
  730. },
  731. onPriceValueChange:function(sender,args){
  732. let me = materialCalcObj;
  733. let dataMap = {};
  734. dataMap[args.row]={};
  735. dataMap[args.row][args.col] = args.newValue;
  736. me.addOrUpdatePriceCalc(dataMap);
  737. },
  738. deleteMaterialCal:function (row) {
  739. let record = this.materialDatas[row];//修改材料计算标记的同时还要删除原价计算,运费计算等
  740. if(record){
  741. projectObj.project.projectGLJ.updateCalcMaterial(record,'calcMaterial',0);
  742. }
  743. },
  744. deletePriceCalc:function (row) {
  745. let record = this.priceDatas[row];
  746. if(record){
  747. let material = this.getMaterialSelected();
  748. projectObj.project.projectGLJ.deletePriceCalc(record.ID,material.id);
  749. }
  750. },
  751. deleteFreightCalc:function (row) {
  752. let record = this.freightDatas[row];
  753. if(record){
  754. let material = this.getMaterialSelected();
  755. projectObj.project.projectGLJ.deleteFreightCalc(record.ID,material.id);
  756. }
  757. },
  758. deleteRation:function (row,type) {
  759. let me = this;
  760. let parent = type == "freight"?me.getSelectedFreight():me.getSelectedPrice();
  761. let ration = type == "freight"?me.freightRations[row]:me.priceRations[row];
  762. let datas = {parentID:parent.ID,rationID:ration.ID,type:type,actionType:"delete"};
  763. projectObj.project.projectGLJ.updateMaterialRation(datas);
  764. },
  765. saveFreight:function (row) {
  766. let me = this;
  767. let record = this.freightDatas[row];
  768. if(record){
  769. let exist = this.checkSavedFreight(record.start);
  770. if(exist){//已存在的情况,更新
  771. let info =`起讫地点“${record.start}”已存在,是否覆盖?`;
  772. //to do 检查是否已经存在,存在给出是否覆盖提示
  773. hintBox.infoBox('操作确认', info, 2, function () {
  774. me.updateUserFreight(record,exist)
  775. }, function () {
  776. //
  777. },['确定','取消'],false);
  778. return true;
  779. }
  780. let user_freight = {rootProjectID:projectObj.project.projectInfo.property.rootProjectID};
  781. let f = {};
  782. for(let key in record){
  783. if(key == "_id") continue;
  784. f[key] = record[key];
  785. if(key =="ration" || key == "ration_gljs")f[key] = [];//下面的定额和工料机不用保存
  786. }
  787. user_freight.freight = f;
  788. projectObj.project.projectGLJ.updateUserFreight({freights:[user_freight],action:"add"});
  789. }
  790. },
  791. updateUserFreight:function (record,userFreight) {
  792. let t = {};
  793. for(let t_key in userFreight){
  794. if(t_key == "ID") continue;
  795. t[t_key] = userFreight[t_key];
  796. }
  797. t.rootProjectID = projectObj.project.projectInfo.property.rootProjectID;
  798. let f = {};
  799. for(let key in record){
  800. if(key == "_id") continue;
  801. f[key] = record[key];
  802. if(key =="ration" || key == "ration_gljs")f[key] = [];//下面的定额和工料机不用保存
  803. }
  804. t.freight = f;
  805. projectObj.project.projectGLJ.updateUserFreight({ID:userFreight.ID,doc:t,action:"update"});
  806. },
  807. getSideResize: function () {
  808. let rg_sideResizeEles = {};
  809. rg_sideResizeEles.eleObj = {
  810. module: this.moduleName,
  811. resize: $('#mrResize'),
  812. parent: $('#projectGljBottom'),
  813. left: $('#materialCalcSheet'),
  814. right: $('#calcDiv')
  815. };
  816. rg_sideResizeEles.limit = {
  817. min: 100,
  818. max: `$('#projectGljBottom').width()-100`
  819. };
  820. return rg_sideResizeEles;
  821. },
  822. initRightClick:function (id,spread) {
  823. let me = this;
  824. $.contextMenu({
  825. selector: '#'+id,
  826. build: function ($trigger, e) {
  827. me.rightClickTarget = SheetDataHelper.safeRightClickSelection($trigger, e, spread);
  828. return me.rightClickTarget.hitTestType === GC.Spread.Sheets.SheetArea.viewport ||
  829. me.rightClickTarget.hitTestType === GC.Spread.Sheets.SheetArea.rowHeader;
  830. },
  831. items: {
  832. "insertFreight":{
  833. name: "内蒙古计算",
  834. icon: 'fa-sign-in',
  835. visible:function () {
  836. return false;//2019-11-17 改成不需要右键插入功能 id == "freightSheet";
  837. },
  838. disabled: function (){
  839. let material = me.getMaterialSelected();
  840. return !material;
  841. },
  842. callback:function () {
  843. $("#insertNeimengDiv").modal("show");
  844. }
  845. },
  846. "saveFreight":{
  847. name: "保存运输起讫地点",
  848. icon: 'fa-sign-in',
  849. visible:function () {
  850. return id == "freightSheet";
  851. },
  852. disabled: function (){
  853. if(id == "freightSheet") return me.rightClickTarget.row >= me.freightDatas.length;
  854. return me.rightClickTarget.row === undefined;
  855. },
  856. callback:function () {
  857. let row = me.rightClickTarget.row;
  858. me.saveFreight(row);
  859. }
  860. },
  861. "delete": {
  862. name: "删除",
  863. icon: 'fa-trash-o',
  864. disabled: function () {
  865. if(id == "priceSheet") return me.rightClickTarget.row >= me.priceDatas.length;
  866. if(id == "freightSheet") return me.rightClickTarget.row >= me.freightDatas.length;
  867. if(id == "freight_ration_sheet") return me.rightClickTarget.row >= me.freightRations.length;
  868. if(id == "price_ration_sheet") return me.rightClickTarget.row >= me.priceRations.length;
  869. return me.rightClickTarget.row === undefined;
  870. },
  871. callback: function (key, opt) {
  872. let row = me.rightClickTarget.row;
  873. if (id == "materialCalcSheet") me.deleteMaterialCal(row);
  874. if (id == "priceSheet") me.deletePriceCalc(row);
  875. if (id == "freightSheet") me.deleteFreightCalc(row);
  876. if (id == "freight_ration_sheet") me.deleteRation(row,"freight");
  877. if (id == "price_ration_sheet") me.deleteRation(row,"price");
  878. }
  879. }
  880. }
  881. });
  882. },
  883. initTabWidth:function () {
  884. if($("#mix_ratio_sheet").is(':visible')) return ;//如果是组成物计算界面,返回
  885. let mr_sideResizeEles = this.getSideResize();
  886. SlideResize.loadHorizonWidth(mr_sideResizeEles.eleObj.module,
  887. [mr_sideResizeEles.eleObj.resize], [mr_sideResizeEles.eleObj.left, mr_sideResizeEles.eleObj.right],null,2);
  888. $("#spreadTabDiv").width( $('#calcDiv').width() - mr_sideResizeEles.eleObj.resize.width() - 32)
  889. },
  890. refreshRationView:function () {
  891. let freight = this.getSelectedFreight();
  892. let hide = true;
  893. let stats = $("#freight_ration").is(':visible');
  894. if(freight && freight.conveyance == "自办运输"){
  895. this.showFreightRationDatas(freight);
  896. $("#freightSheet").css("height","50%");
  897. $("#freight_ration").show();
  898. hide = false;
  899. }
  900. if(hide){
  901. $("#freightSheet").css("height","100%");
  902. $("#freight_ration").hide();
  903. }
  904. if(stats != $("#freight_ration").is(':visible')){//状态改变了才刷新
  905. this.freightSpread.refresh();
  906. this.freightRationSpread.refresh();
  907. }
  908. },
  909. refreshAssView:function () {
  910. let me = materialCalcObj;
  911. let sheet = $('#freightSheet').is(':visible')?me.freightRationSheet:me.priceRationSheet;
  912. let preString = $('#freightSheet').is(':visible')?"freight":"price";
  913. let show = false;
  914. let ass = null;
  915. let ration = me.getSelectedRation();
  916. let stats = $(`#${preString}_ration_ass`).is(':visible');
  917. if(ration && ration.rationAssList){
  918. for(let r of ration.rationAssList){
  919. if(r.name.indexOf("运距")!= -1){//辅助定额只处理运距的情况,其它的都忽略 模糊匹配
  920. show = true;
  921. ass = r;
  922. }
  923. }
  924. }
  925. if(show){
  926. $(`#${preString}_ration_sheet`).addClass("material-ration-left");
  927. $(`#${preString}_ration_ass`).addClass("material-ass");
  928. $(`#${preString}_ass_value`).val(ass.actualValue);
  929. $(`#${preString}_ass_label`).text(ass.name);
  930. $(`#${preString}_ration_ass`).show();
  931. }else {
  932. $(`#${preString}_ration_sheet`).removeClass("material-ration-left");
  933. $(`#${preString}_ration_ass`).removeClass("material-ass");
  934. $(`#${preString}_ration_ass`).hide();
  935. }
  936. if(stats != $(`#${preString}_ration_ass`).is(':visible')) sheet.parent.refresh();//状态改变了才刷新
  937. },
  938. updateMaterialRationAss:function (value,ele) {//to do 同步修改定额工料机的消耗量
  939. let parent = this.getSelectedRationParent(),ration = this.getSelectedRation();
  940. let replaceList = [];
  941. if(value && !number_util.isNum(value)){
  942. alert("输入的数据类型不对,请重新输入!");
  943. let a = _.find(ration.rationAssList,function (item) {
  944. return item.name.indexOf("运距") != -1;
  945. });
  946. if(a)ele.val(a.actualValue);
  947. return;
  948. }
  949. for(let ass of ration.rationAssList){
  950. if(ass.name.indexOf("运距")!= -1){
  951. ass.actualValue = value?scMathUtil.roundForObj(value,2):ass.stdValue;
  952. }
  953. replaceList.push(value);
  954. }
  955. let name = ration.caption;
  956. for(let re of replaceList){
  957. name = name.replace('%s',re);
  958. }
  959. let type = $('#freightSheet').is(':visible')?"freight":"price";
  960. //let ration_glj =
  961. let datas = {parentID:parent.ID,rationID:ration.ID,type:type,actionType:"update",field:"name",value:name,ext:{rationAssList:ration.rationAssList}};
  962. let ration_gljs = projectObj.project.projectGLJ.calcMaterialAssQuantity(parent,ration,ration.rationAssList);
  963. if(ration_gljs.length > 0) datas.ration_gljs = ration_gljs;
  964. projectObj.project.projectGLJ.updateMaterialRation(datas);
  965. },
  966. getSelectedRation:function () {
  967. if($('#freightSheet').is(':visible')){
  968. return this.getSelectedRecode(this.freightRationSheet,this.freightRations);
  969. }else {
  970. return this.getSelectedRecode(this.priceRationSheet,this.priceRations);
  971. }
  972. },
  973. getSelectedRationParent:function () {
  974. if($('#freightSheet').is(':visible')){
  975. return this.getSelectedFreight();
  976. }else {
  977. return this.getSelectedRecode(this.priceSheet,this.priceDatas);
  978. }
  979. },
  980. getSelectedFreight:function(){
  981. return this.getSelectedRecode(this.freightSheet,this.freightDatas);
  982. },
  983. getSelectedPrice:function () {
  984. return this.getSelectedRecode(this.priceSheet,this.priceDatas)
  985. },
  986. getSelectedRecode:function (sheet,datas) {
  987. return sheetCommonObj.getSelectedRecode(sheet,datas);
  988. }
  989. };
  990. $(function () {
  991. $("#calc-nav").on('shown.bs.tab', function () {
  992. materialCalcObj.initTabWidth();
  993. projectGljObject.refreshSubViews();
  994. });
  995. $("#calTab ul li a").on('shown.bs.tab', function () {
  996. materialCalcObj.showFreightDatas();
  997. materialCalcObj.showPriceDatas();
  998. projectGljObject.refreshSubViews();
  999. });
  1000. $(".ration_ass_value").change(function () {
  1001. let me = materialCalcObj;
  1002. me.updateMaterialRationAss($(this).val(),$(this));
  1003. });
  1004. $('#calcCoeDiv').on('show.bs.modal', function () {
  1005. if(materialCalcObj.getAssistProductionLabel) $("#assistProductionLabel").text(materialCalcObj.getAssistProductionLabel);
  1006. $("#assistProductionFeeRate").val(scMathUtil.roundForObj(projectObj.project.projectGLJ.datas.constData.assistProductionFeeRate,getDecimal("feeRate")));
  1007. })
  1008. $("#calcCoeConfirm").click(function () {
  1009. let feeRate = $("#assistProductionFeeRate").val();
  1010. if(!number_util.isNum(feeRate)){
  1011. alert("输入的数据类型不对,请重新输入!");
  1012. return $("#assistProductionFeeRate").val(scMathUtil.roundForObj(projectObj.project.projectGLJ.datas.constData.assistProductionFeeRate,getDecimal("feeRate")));
  1013. }
  1014. feeRate = scMathUtil.roundForObj(feeRate,getDecimal("feeRate"));
  1015. $("#calcCoeDiv").modal("hide");
  1016. projectObj.project.projectGLJ.changeAssistProductionFeeRate(feeRate);
  1017. });
  1018. $("#insertFreightconfirm").click(function () {
  1019. let me = materialCalcObj;
  1020. let material = me.getMaterialSelected();
  1021. let newData = me.getNewFreightData(material);
  1022. let start = $("#freight_start").val();
  1023. let kmDistance = $("#freight_kmDistance").val();
  1024. let materialType = $("#freight_materialType").val();
  1025. if(!number_util.isNum(kmDistance)){
  1026. alert("运输距离数据类型不对,请重新输入!");
  1027. return ;
  1028. }
  1029. kmDistance = scMathUtil.roundForObj(kmDistance,getDecimal("glj.unitPrice"))+'';
  1030. newData.start = start;
  1031. newData.kmDistance = kmDistance;
  1032. newData.materialType = materialType;
  1033. newData.calcType = "内蒙古";
  1034. newData.unitFreight = me.calcNeiMengUnitFreight(kmDistance,materialType);
  1035. $("#insertNeimengDiv").modal("hide");
  1036. projectObj.project.projectGLJ.addFreightCalc([newData],material.id);
  1037. })
  1038. });
  1039. let mr_sideResizeEles = materialCalcObj.getSideResize();
  1040. SlideResize.horizontalSlide(mr_sideResizeEles.eleObj, mr_sideResizeEles.limit, function(){
  1041. $("#spreadTabDiv").width( $('#calcDiv').width() - mr_sideResizeEles.eleObj.resize.width() - 32);
  1042. projectGljObject.refreshSubViews();
  1043. },2);