glj_col.js 15 KB

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