glj_col.js 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360
  1. /**
  2. * Created by zhang on 2018/7/3.
  3. */
  4. let gljCol = {
  5. showTaxRate: false,
  6. showPurchaseFeeRate:false,
  7. hideInfoPrice:true,
  8. ration_glj_setting: {
  9. header: [
  10. {headerName: "编码", headerWidth: 110, dataCode: "code", dataType: "String", formatter: "@"},
  11. {headerName: "名称", headerWidth: 160, dataCode: "name", dataType: "String",cellType:'tipsCell'},
  12. {headerName: "规格型号", headerWidth: 120, dataCode: "specs", dataType: "String", hAlign: "left",cellType:'tipsCell'},
  13. {headerName: "单位", headerWidth: 45, dataCode: "unit", dataType: "String", hAlign: "center"},
  14. {headerName: "市场价", headerWidth: 65, dataCode: "marketPrice", dataType: "Number", hAlign: "right"},//, decimalField: "glj.unitPrice"
  15. {headerName: "调整价", headerWidth: 65, dataCode: "adjustPrice", dataType: "Number", hAlign: "right"},//, decimalField: "glj.unitPrice"1
  16. {headerName: "自定消耗", headerWidth: 65, dataCode: "customQuantity", dataType: "Number", hAlign: "right"},
  17. {headerName: "消耗量", headerWidth: 65, dataCode: "quantity", dataType: "Number", hAlign: "right"},
  18. {headerName: "定额价", headerWidth: 65, dataCode: "basePrice", dataType: "Number", hAlign: "right"},//, decimalField: "glj.unitPrice"
  19. {headerName: "定额消耗", headerWidth: 65, dataCode: "rationItemQuantity", dataType: "Number", hAlign: "right"}, // dataType: "Number", formatter: "0.00"
  20. {headerName: "总消耗量", headerWidth: 80, dataCode: "totalQuantity", dataType: "Number", hAlign: "right"},
  21. {headerName: "暂估", headerWidth: 45, dataCode: "isEstimate", dataType: "String", hAlign: "center", vAlign: "center", cellType: "checkBox"},
  22. {headerName: "调后市场价", headerWidth: 80, dataCode: "tenderPrice", dataType: "Number", hAlign: "right", visible: false},
  23. {headerName: "调后消耗量", headerWidth: 80, dataCode: "tenderQuantity", dataType: "Number", hAlign: "right", visible: false}
  24. ],
  25. view: {
  26. lockColumns: [ "adjustPrice", "quantity", "totalQuantity", "isEstimate",
  27. "tenderPrice", "tenderQuantity"],//这里以后改成dataCode好一点
  28. rowHeaderWidth:25
  29. },
  30. getStyle:function (data) {
  31. if(data&&data.type == gljType.MAIN_MATERIAL){//是主材的话字体蓝色显示
  32. return {foreColor:"#4D7BFF"};
  33. }
  34. return null;
  35. },
  36. navigationRightCol:['name','specs','unit'],//选中这几列时,按enter键跳到右边一列
  37. // 工料机类型是混凝土、砂浆、配合比、机械台班时,价格不可编辑。
  38. editedTyep:[GLJTypeConst.MAIN_MATERIAL,GLJTypeConst.EQUIPMENT]//主材设备
  39. },
  40. project_glj_setting:{
  41. header: [
  42. {headerName: "编码", headerWidth: 80, dataCode: "code", dataType: "String",spanRows: [2]},
  43. {headerName: "名称", headerWidth: 160, dataCode: "name", dataType: "String",cellType:'tipsCell',spanRows: [2]},
  44. {headerName: "规格型号", headerWidth: 120, dataCode: "specs", hAlign: "left", dataType: "String",cellType:'tipsCell',spanRows: [2]},
  45. {headerName: "单位", headerWidth: 45, dataCode: "unit", hAlign: "center", dataType: "String",spanRows: [2]},
  46. {headerName: "类型", headerWidth: 45, dataCode: "short_name", hAlign: "center", dataType: "String",spanRows: [2]},
  47. {headerName: "市场价", headerWidth: 70, dataCode: "marketPrice", hAlign: "right", dataType: "Number",validator:"number",spanRows: [2]},//,decimalField:"glj.unitPrice"
  48. {headerName: "价格来源", headerWidth: 90, dataCode: "priceFrom", dataType: "String",spanRows: [2],cellType:"tipsCell"},
  49. {headerName: "税率", headerWidth: 70, dataCode: "taxRate", hAlign: "right", dataType: "Number",validator:"number",spanRows: [2]},//,decimalField:"glj.unitPrice"
  50. {headerName: "调整价", headerWidth: 70, dataCode: "adjustPrice", hAlign: "right", dataType: "Number",spanRows: [2]},//,decimalField:"glj.unitPrice"
  51. {headerName: "定额价", headerWidth: 70, dataCode: "basePrice", hAlign: "right", dataType: "Number",validator:"number",spanRows: [2]},//decimalField:'glj.unitPrice',
  52. {headerName: "信息价", headerWidth: 70, dataCode: "infoPrice", hAlign: "right", dataType: "Number",validator:"number",spanRows: [2], visible: false},
  53. {headerName: "采保费率%", headerWidth: 70, dataCode: "purchaseFeeRate", hAlign: "right", dataType: "Number",validator:"number",spanRows: [2], visible: false},
  54. {headerName: "总消耗量", headerWidth: 90, dataCode: "quantity", hAlign: "right", dataType: "Number",decimalField:'glj.quantity',spanRows: [2]},
  55. {headerName: "暂估", headerWidth: 45, dataCode: "is_evaluate", hAlign: "center", dataType: "String",cellType:'checkBox',spanRows: [2]},
  56. {headerName: "主要\n材料", headerWidth: 45, dataCode: "is_main_material", hAlign: "center", dataType: "String",cellType:'checkBox',spanRows: [2]},
  57. {headerName: "不计税设备", headerWidth: 55, dataCode: "no_tax_eqp", dataType: "String",cellType: "checkBox",spanRows: [2]},
  58. {headerName: "评标材料", headerWidth: 35, dataCode: "is_eval_material", dataType: "String",cellType: "checkBox",spanRows: [2]},
  59. {headerName: "供货方式", headerWidth: 70, dataCode: "supply", hAlign: "center", dataType: "String",cellType:'comboBox',editorValueType:true,options:supplyComboMap,spanRows: [2]},
  60. {headerName: "甲供数量", headerWidth: 90, dataCode: "supply_quantity", hAlign: "right", dataType: "Number",validator:"number",decimalField:'glj.quantity',spanRows: [2]},
  61. {headerName: "三材类别", headerWidth: 70, dataCode: "materialType", hAlign: "center", dataType: "String",cellType:'comboBox',editorValueType:true,options:materialComboMap,spanRows: [2]},
  62. {headerName: "三材系数", headerWidth: 70, dataCode: "materialCoe", hAlign: "right", dataType: "Number",validator:"number",spanRows: [2]},//,decimalField:'material'
  63. {headerName: "交货方式", headerWidth: 70, dataCode: "delivery", hAlign: "left", dataType: "String",spanRows: [2]},
  64. {headerName: "送达地点", headerWidth: 70, dataCode: "delivery_address", hAlign: "left", dataType: "String",spanRows: [2]},
  65. {headerName: "产地", headerWidth: 80, dataCode: "originPlace", hAlign: "left", dataType: "String",spanRows: [2]},
  66. {headerName: "厂家", headerWidth: 80, dataCode: "vender", hAlign: "left", dataType: "String",spanRows: [2]},
  67. {headerName: "质量等级", headerWidth: 80, dataCode: "qualityGrace", hAlign: "left", dataType: "String",spanRows: [2]},
  68. {headerName: "品牌", headerWidth: 80, dataCode: "brand", hAlign: "left", dataType: "String",spanRows: [2]},
  69. {headerName: "备注", headerWidth: 100, dataCode: "remark", hAlign: "left", dataType: "String",spanRows: [2]},
  70. {headerName: "不调价", headerWidth: 55, dataCode: "is_adjust_price", dataType: "String",cellType: "checkBox",spanRows: [2], visible: true},
  71. {headerName: ["调价后","市场价"], headerWidth: 75, dataCode: "tenderPrice", hAlign: "right", dataType: "Number",validator:"number",spanCols: [2,1], visible: false},
  72. {headerName: ["","总消耗量"], headerWidth: 90, dataCode: "tenderQuantity", hAlign: "right", dataType: "Number",decimalField:'glj.quantity',spanCols: [0,1], visible: false}
  73. ],
  74. view: {
  75. lockColumns: ["code","name","specs","unit","short_name","tenderPrice","adjustPrice","quantity","tenderQuantity","priceFrom"]
  76. },
  77. /* autoFit:true,
  78. fitRow:['priceFrom'], */
  79. frozenCols:4,
  80. headRows:2,
  81. getStyle:function (data,row,activeRow,dataCode) {
  82. let style = {};
  83. if(row === activeRow){//选中黄色显示
  84. style = new GC.Spread.Sheets.Style();
  85. style.backColor = "#FFFACD";
  86. style.borderLeft = new GC.Spread.Sheets.LineBorder("#D4D4D4", GC.Spread.Sheets.LineStyle.thin);
  87. style.borderTop = new GC.Spread.Sheets.LineBorder("#D4D4D4", GC.Spread.Sheets.LineStyle.thin);
  88. style.borderRight = new GC.Spread.Sheets.LineBorder("#D4D4D4", GC.Spread.Sheets.LineStyle.thin);
  89. style.borderBottom = new GC.Spread.Sheets.LineBorder("#D4D4D4", GC.Spread.Sheets.LineStyle.thin);
  90. }
  91. if(dataCode === "marketPrice"){
  92. if(data.marketPrice == data.basePrice) style.foreColor = 'black';//改回相等的时候,要改回来
  93. if(data.marketPrice > data.basePrice) style.foreColor = 'red';
  94. if(data.marketPrice < data.basePrice) style.foreColor = 'green';
  95. }
  96. return _.isEmpty(style)?null:style;
  97. },
  98. },
  99. mixRatio_Setting:{
  100. header:[
  101. {headerName: "编码", headerWidth: 80, dataCode: "code", dataType: "String"},
  102. {headerName: "名称", headerWidth: 240, dataCode: "name", dataType: "String"},
  103. {headerName: "规格型号", headerWidth: 190, dataCode: "specs", dataType: "String"},
  104. {headerName: "单位", headerWidth: 45, dataCode: "unit", hAlign: "center", dataType: "String"},
  105. {headerName: "类型", headerWidth: 45, dataCode: "short_name", hAlign: "center", dataType: "String"},
  106. {headerName: "定额价", headerWidth: 80, dataCode: "basePrice", hAlign: "right", dataType: "Number",validator:"number"},//,decimalField:'glj.unitPrice'
  107. {headerName: "调整价", headerWidth: 80, dataCode: "adjustPrice", hAlign: "right", dataType: "Number"},//,decimalField:"glj.unitPrice"
  108. {headerName: "市场价", headerWidth: 80, dataCode: "marketPrice", hAlign: "right", dataType: "Number",validator:"number"},//,decimalField:"glj.unitPrice"
  109. {headerName: "消耗量", headerWidth: 80, dataCode: "consumption", hAlign: "right", dataType: "Number",decimalField:"glj.quantity",validator:"number"}
  110. ],
  111. view: {
  112. lockColumns: [0,1,2,3,4,5,6,7]
  113. }
  114. },
  115. scopeSetting:{
  116. "emptyRows":0,
  117. "headRows":1,
  118. "headRowHeight":[30],
  119. "defaultRowHeight": 21,
  120. "treeCol": 1,
  121. "cols":[
  122. {
  123. "width":40,
  124. "readOnly": true,
  125. "head":{
  126. "titleNames":["选择"],
  127. "spanCols":[1],
  128. "spanRows":[1],
  129. "vAlign":[1],
  130. "hAlign":[1],
  131. "font":["Arial"]
  132. },
  133. "data":{
  134. "field":"selected",
  135. "vAlign":1,
  136. "hAlign":1,
  137. "font":"Arial",
  138. "cellType":function (node) {
  139. return new GC.Spread.Sheets.CellTypes.CheckBox();
  140. }
  141. }
  142. },
  143. {
  144. "width":140,
  145. "readOnly": true,
  146. "head":{
  147. "titleNames":["编号"],
  148. "spanCols":[1],
  149. "spanRows":[1],
  150. "vAlign":[1],
  151. "hAlign":[1],
  152. "font":["Arial"]
  153. },
  154. "data":{
  155. "field":"code",
  156. "vAlign":1,
  157. "hAlign":0,
  158. "font":"Arial"
  159. }
  160. },
  161. {
  162. "width":240,
  163. "readOnly": true,
  164. "head":{
  165. "titleNames":["名称"],
  166. "spanCols":[1],
  167. "spanRows":[1],
  168. "vAlign":[1],
  169. "hAlign":[1],
  170. "font":["Arial"]
  171. },
  172. "data":{
  173. "field":"name",
  174. "vAlign":0,
  175. "hAlign":0,
  176. "font":"Arial"
  177. }
  178. },
  179. {
  180. "width":70,
  181. "readOnly": true,
  182. "head":{
  183. "titleNames":["单位"],
  184. "spanCols":[1],
  185. "spanRows":[1],
  186. "vAlign":[1],
  187. "hAlign":[1],
  188. "font":["Arial"]
  189. },
  190. "data":{
  191. "field":"unit",
  192. "vAlign":1,
  193. "hAlign":1,
  194. "font":"Arial"
  195. }
  196. },
  197. {
  198. "width":80,
  199. "readOnly": true,
  200. "head":{
  201. "titleNames":["工程量"],
  202. "spanCols":[1],
  203. "spanRows":[1],
  204. "vAlign":[1],
  205. "hAlign":[1],
  206. "font":["Arial"]
  207. },
  208. "data":{
  209. "field":"quantity",
  210. "vAlign":1,
  211. "hAlign":2,
  212. "font":"Arial"
  213. }
  214. },
  215. {
  216. "width":80,
  217. "readOnly": true,
  218. "head":{
  219. "titleNames":["单价"],
  220. "spanCols":[1],
  221. "spanRows":[1],
  222. "vAlign":[1],
  223. "hAlign":[1],
  224. "font":["Arial"]
  225. },
  226. "data":{
  227. "field":"unitPrice",
  228. "vAlign":1,
  229. "hAlign":2,
  230. "font":"Arial"
  231. }
  232. },
  233. {
  234. "width":80,
  235. "readOnly": true,
  236. "head":{
  237. "titleNames":["金额"],
  238. "spanCols":[1],
  239. "spanRows":[1],
  240. "vAlign":[1],
  241. "hAlign":[1],
  242. "font":["Arial"]
  243. },
  244. "data":{
  245. "field":"totalPrice",
  246. "vAlign":1,
  247. "hAlign":2,
  248. "font":"Arial"
  249. }
  250. }
  251. ]
  252. },
  253. removeCol:function (dataCode,setting) {
  254. let colIndex = _.findIndex(setting.header,{'dataCode':dataCode});
  255. if(colIndex != -1){
  256. setting.header.splice(colIndex,1);//去掉列;
  257. let newArray = [];
  258. for(let l of setting.view.lockColumns){
  259. if(_.isString(l)) return;//如果是用dataCode表示的,不用处理
  260. if(l == colIndex) continue;
  261. if(l > colIndex) l = l -1;
  262. newArray.push(l);
  263. }
  264. setting.view.lockColumns = newArray;
  265. }
  266. },
  267. setVisible:function (dataCode,setting,visible) {
  268. let head = setting.header.find((item)=>item.dataCode === dataCode);
  269. if(head) head.visible = visible;
  270. },
  271. initGljCol: function (showAdjustPrice, showTenderFields,init=false) {
  272. let me = gljCol;
  273. if (showAdjustPrice !== true) {
  274. me.removeCol('adjustPrice', me.ration_glj_setting);
  275. me.removeCol('adjustPrice', me.project_glj_setting);
  276. me.removeCol('adjustPrice', me.mixRatio_Setting);
  277. };
  278. if (me.showTaxRate == false) me.removeCol('taxRate', me.project_glj_setting);
  279. if(me.showPurchaseFeeRate){
  280. me.setVisible('infoPrice', me.project_glj_setting,true);
  281. me.setVisible('purchaseFeeRate', me.project_glj_setting,true);
  282. }
  283. if (me.hideInfoPrice == true) {
  284. $("#info-nav-li").hide();
  285. me.removeCol('priceFrom', me.project_glj_setting);
  286. }
  287. me.showTenderFields(showTenderFields, false,init);
  288. gljOprObj.setting = me.ration_glj_setting;
  289. projectGljObject.projectGljSetting = me.project_glj_setting;
  290. projectGljObject.mixRatioSetting = me.mixRatio_Setting;
  291. me.setScopeFormater();
  292. gljOprObj.scopeSetting = me.scopeSetting;
  293. },
  294. showTenderFields: function (showFields = false, needRefresh = false,init=false){
  295. let me = gljCol;
  296. let PGLJHeader = me.project_glj_setting.header;
  297. for (let e of PGLJHeader){
  298. if (e.dataCode == 'tenderPrice' || e.dataCode == 'tenderQuantity'){
  299. e.visible = showFields;
  300. }
  301. };
  302. let RGLJHeader = me.ration_glj_setting.header;
  303. for (let e of RGLJHeader){
  304. if (e.dataCode == 'tenderPrice' || e.dataCode == 'tenderQuantity'){
  305. e.visible = showFields;
  306. }
  307. };
  308. let CalcProgramHeader = calcProgramObj.setting.header;
  309. for (let e of CalcProgramHeader){
  310. if (e.dataCode == 'tenderUnitFee' || e.dataCode == 'tenderTotalFee'){
  311. e.visible = showFields;
  312. }
  313. };
  314. colSettingObj.setVisible('feesIndex.common.tenderUnitFee', showFields);
  315. colSettingObj.setVisible('feesIndex.common.tenderTotalFee', showFields);
  316. colSettingObj.updateColSetting(true,init);
  317. if (needRefresh){
  318. if(projectGljObject.projectGljSpread) {
  319. projectGljObject.projectGljSheet = projectGljObject.projectGljSpread .getSheet(0);
  320. projectGljObject.initSheet(projectGljObject.projectGljSheet, projectGljObject.projectGljSetting);
  321. }
  322. if (subSpread) {
  323. gljOprObj.refreshView();
  324. calcProgramObj.refreshCalcProgram(projectObj.project.mainTree.selected);
  325. //gljOprObj.initSheet(subSpread.getSheet(0), false);
  326. //gljOprObj.initSheet(subSpread.getSheet(2), false);
  327. }
  328. };
  329. },
  330. setScopeFormater:function () {
  331. // 综合单价、综合合价,小数部分应补0对齐。 CSL
  332. for(let col of this.scopeSetting.cols){
  333. if (col.data.field=="totalPrice") col.data.formatter = MainTreeCol.getNumberFormatter(decimalObj.ration.totalPrice, true);
  334. if (col.data.field== "unitPrice") col.data.formatter = MainTreeCol.getNumberFormatter(decimalObj.ration.unitPrice, true);
  335. }
  336. }
  337. };
  338. /*
  339. $(function () {
  340. $('#fullpath').click(function () {
  341. checkfeeRate();
  342. });
  343. })
  344. async function checkfeeRate() {
  345. let result = await ajaxPost('/feeRates/checkFeeRateName', data = {name: '编辑工程量表达式', rootProjectID: 3163});
  346. console.log(result);
  347. }*/