calc_base.js 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452
  1. /**
  2. * Created by Zhong on 2017/11/28.
  3. */
  4. //清单固定行
  5. const fixedFlag = {
  6. // 分部分项工程
  7. SUB_ENGINERRING: 1,
  8. // 措施项目
  9. MEASURE: 2,
  10. // 施工技术措施项目
  11. CONSTRUCTION_TECH: 3,
  12. // 安全文明施工按实计算费用
  13. SAFETY_CONSTRUCTION_ACTUAL: 4,
  14. // 施工组织措施专项费用
  15. CONSTRUCTION_ORGANIZATION: 5,
  16. // 安全文明施工专项费用
  17. SAFETY_CONSTRUCTION: 6,
  18. // 其他项目
  19. OTHER: 7,
  20. // 暂列金额
  21. PROVISIONAL: 8,
  22. // 暂估价
  23. ESTIMATE: 9,
  24. // 材料(工程设备)暂估价
  25. MATERIAL_PROVISIONAL: 10,
  26. // 专业工程暂估价
  27. ENGINEERING_ESITIMATE: 11,
  28. // 计日工
  29. DAYWORK: 12,
  30. // 总承包服务费
  31. TURN_KEY_CONTRACT: 13,
  32. // 索赔与现场签证
  33. CLAIM_VISA: 14,
  34. // 规费
  35. CHARGE: 15,
  36. // 社会保险费及住房公积金 Social insurance fee and housing accumulation fund
  37. SOCIAL_INSURANCE_HOUSING_FUND: 16,
  38. // 工程排污费 charges for disposing pollutants
  39. POLLUTANTS: 17,
  40. // 税金
  41. TAX: 18
  42. };
  43. let cbTools = {
  44. isDef: function (v) {
  45. return v !== undefined && v !== null;
  46. },
  47. isUnDef: function (v) {
  48. return v === undefined || v === null;
  49. },
  50. isNum: function (v) {
  51. return this.isDef(v) && !isNaN(v) && v !== Infinity;
  52. },
  53. returnV: function (v, r) {
  54. if(this.isDef(v)){
  55. return v;
  56. }
  57. return r;
  58. },
  59. findBill: function (fixedFlag) {
  60. let bills = projectObj.project.Bills.datas;
  61. for(let i = 0, len = bills.length; i < len; i++){
  62. if(bills[i].flagsIndex.flag === fixedFlag){
  63. return bills[i];
  64. }
  65. }
  66. },
  67. //需要用到计算基数的时候,先找出所有的固定清单,避免每个基数都要去遍历寻找清单
  68. setFixedBills: function (project, billsObj, fixedFlag) {
  69. let bills = project.Bills.datas;
  70. for(let i = 0, len = bills.length; i < len; i++){
  71. if(this.isDef(bills[i].flagsIndex.fixed)){
  72. for(let flag in fixedFlag){
  73. if(fixedFlag[flag] === bills[i].flagsIndex.fixed.flag){
  74. billsObj[fixedFlag[flag]] = bills[i];
  75. }
  76. }
  77. }
  78. }
  79. },
  80. //生成清单基数计算分类模板
  81. setBaseFigureClass: function (baseFigures, mapObj) {
  82. mapObj['CONSTRUCTION_ORGANIZATION'] = Object.create(null);
  83. mapObj['OTHER'] = Object.create(null);
  84. mapObj['CHARGE'] = Object.create(null);
  85. mapObj['TAX'] = Object.create(null);
  86. mapObj['OTHERS'] = Object.create(null);
  87. let filter = ['CSXMF', 'ZZCSXMF', 'ZZCSXMDEJJZJGCF', 'ZZCSXMDEJJRGF', 'ZZCSXMDEJJCLF', 'ZZCSXMDEJJJXF', 'QTXMF', 'GF', 'SJ'];
  88. for(let figure in baseFigures){
  89. if(filter.indexOf(baseFigures[figure]) === -1){
  90. mapObj['CONSTRUCTION_ORGANIZATION'][figure] = baseFigures[figure];
  91. }
  92. if(baseFigures[figure] !== 'QTXMF'){
  93. mapObj['OTHER'][figure] = baseFigures[figure];
  94. }
  95. if(baseFigures[figure] !== 'GF'){
  96. mapObj['CHARGE'][figure] = baseFigures[figure];
  97. }
  98. if(baseFigures[figure] !== 'SJ'){
  99. mapObj['TAX'][figure] = baseFigures[figure];
  100. }
  101. mapObj['OTHERS'][figure] = baseFigures[figure];
  102. }
  103. }
  104. };
  105. let baseFigureTemplate = {
  106. 'FBFXGCF': function () {
  107. let bill = calcBase.fixedBills[calcBase.fixedFlag.SUB_ENGINERRING];
  108. if(cbTools.isUnDef(bill)) return 0;
  109. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  110. return bill.feesIndex.common.totalFee || 0;
  111. },
  112. 'FBFXDEJJRGF': function () {
  113. let bill = calcBase.fixedBills[calcBase.fixedFlag.SUB_ENGINERRING];
  114. if(cbTools.isUnDef(bill)) return 0;
  115. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  116. return bill.feesIndex.labour.totalFee || 0;
  117. },
  118. 'FBFXDEJJCLF': function () {
  119. let bill = calcBase.fixedBills[calcBase.fixedFlag.SUB_ENGINERRING];
  120. if(cbTools.isUnDef(bill)) return 0;
  121. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  122. return bill.feesIndex.material.totalFee || 0;
  123. },
  124. 'FBFXDEJJJXF': function () {
  125. let bill = calcBase.fixedBills[calcBase.fixedFlag.SUB_ENGINERRING];
  126. if(cbTools.isUnDef(bill)) return 0;
  127. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  128. return bill.feesIndex.machine.totalFee || 0;
  129. },
  130. 'FBFXTZRGF': function () {
  131. let bill = calcBase.fixedBills[calcBase.fixedFlag.SUB_ENGINERRING];
  132. if(cbTools.isUnDef(bill)) return 0;
  133. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  134. return bill.feesIndex.adjustLabour.totalFee || 0;
  135. },
  136. 'FBFXTZJSRGF': function () {
  137. let bill = calcBase.fixedBills[calcBase.fixedFlag.SUB_ENGINERRING];
  138. if(cbTools.isUnDef(bill)) return 0;
  139. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  140. return bill.feesIndex.adjustMachineLabour.totalFee || 0;
  141. },
  142. 'FBFXZCF': function () {
  143. let bill = calcBase.fixedBills[calcBase.fixedFlag.SUB_ENGINERRING];
  144. if(cbTools.isUnDef(bill)) return 0;
  145. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  146. return bill.feesIndex.mainMaterial.totalFee || 0;
  147. },
  148. 'FBFXSBF': function () {
  149. let bill = calcBase.fixedBills[calcBase.fixedFlag.SUB_ENGINERRING];
  150. if(cbTools.isUnDef(bill)) return 0;
  151. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  152. return bill.feesIndex.mainMaterial.totalFee || 0;
  153. },
  154. 'FBFXWJJCLF': function () {
  155. return 0;
  156. },
  157. 'FBFXRGGR': function () {
  158. return 0;
  159. },
  160. 'FBFXGCLQDJJZJGCF': function () {
  161. return this['FBFXDEJJRGF']() + this['FBFXDEJJCLF']() + this['FBFXDEJJJXF']();
  162. },
  163. 'CSXMF': function () {
  164. let bill = calcBase.fixedBills[calcBase.fixedFlag.MEASURE];
  165. if(cbTools.isUnDef(bill)) return 0;
  166. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  167. return bill.feesIndex.common.totalFee || 0;
  168. },
  169. 'ZZCSXMF': function () {
  170. let bill = calcBase.fixedBills[calcBase.fixedFlag.CONSTRUCTION_ORGANIZATION];
  171. if(cbTools.isUnDef(bill)) return 0;
  172. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  173. return bill.feesIndex.common.totalFee || 0;
  174. },
  175. 'ZZCSXMDEJJZJGCF': function () {
  176. return this['ZZCSXMDEJJRGF']() + this['ZZCSXMDEJJCLF']() + this['ZZCSXMDEJJJXF']()
  177. },
  178. 'ZZCSXMDEJJRGF': function () {
  179. let bill = calcBase.fixedBills[calcBase.fixedFlag.CONSTRUCTION_ORGANIZATION];
  180. if(cbTools.isUnDef(bill)) return 0;
  181. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  182. return bill.feesIndex.labour.totalFee || 0;
  183. },
  184. 'ZZCSXMDEJJCLF': function () {
  185. let bill = calcBase.fixedBills[calcBase.fixedFlag.CONSTRUCTION_ORGANIZATION];
  186. if(cbTools.isUnDef(bill)) return 0;
  187. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  188. return bill.feesIndex.material.totalFee || 0;
  189. },
  190. 'ZZCSXMDEJJJXF': function () {
  191. let bill = calcBase.fixedBills[calcBase.fixedFlag.CONSTRUCTION_ORGANIZATION];
  192. if(cbTools.isUnDef(bill)) return 0;
  193. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  194. return bill.feesIndex.machine.totalFee || 0;
  195. },
  196. 'JSCSXMF': function () {
  197. let bill = calcBase.fixedBills[calcBase.fixedFlag.CONSTRUCTION_TECH];
  198. if(cbTools.isUnDef(bill)) return 0;
  199. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  200. return bill.feesIndex.common.totalFee || 0;
  201. },
  202. 'JSCSXMDEJJRGF': function () {
  203. let bill = calcBase.fixedBills[calcBase.fixedFlag.CONSTRUCTION_TECH];
  204. if(cbTools.isUnDef(bill)) return 0;
  205. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  206. return bill.feesIndex.labour.totalFee || 0;
  207. },
  208. 'JSCSXMDEJJCLF': function () {
  209. let bill = calcBase.fixedBills[calcBase.fixedFlag.CONSTRUCTION_TECH];
  210. if(cbTools.isUnDef(bill)) return 0;
  211. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  212. return bill.feesIndex.material.totalFee || 0;
  213. },
  214. 'JSCSXMDEJJJXF': function () {
  215. let bill = calcBase.fixedBills[calcBase.fixedFlag.CONSTRUCTION_TECH];
  216. if(cbTools.isUnDef(bill)) return 0;
  217. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  218. return bill.feesIndex.machine.totalFee || 0;
  219. },
  220. 'JSCSXMTZRGF': function () {
  221. let bill = calcBase.fixedBills[calcBase.fixedFlag.CONSTRUCTION_TECH];
  222. if(cbTools.isUnDef(bill)) return 0;
  223. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  224. return bill.feesIndex.adjustLabour.totalFee || 0;
  225. },
  226. 'JSCSXMTZJSRGF': function () {
  227. let bill = calcBase.fixedBills[calcBase.fixedFlag.CONSTRUCTION_TECH];
  228. if(cbTools.isUnDef(bill)) return 0;
  229. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  230. return bill.feesIndex.adjustMachineLabour.totalFee || 0;
  231. },
  232. 'JSCSXMZCF': function () {
  233. let bill = calcBase.fixedBills[calcBase.fixedFlag.CONSTRUCTION_TECH];
  234. if(cbTools.isUnDef(bill)) return 0;
  235. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  236. return bill.feesIndex.mainMaterial.totalFee || 0;
  237. },
  238. 'JSCSXMSBF': function () {
  239. return 0;
  240. },
  241. 'JSCSXMWJJCLF': function () {
  242. return 0;
  243. },
  244. 'JSCSXMRGGR': function () {
  245. return 0;
  246. },
  247. 'JSCSXMQDDEJJZJGCF': function () {
  248. return this['JSCSXMDEJJRGF']() + this['JSCSXMDEJJCLF']() + this['JSCSXMDEJJJXF']();
  249. },
  250. 'QTXMF': function () {
  251. let bill = calcBase.fixedBills[calcBase.fixedFlag.OTHER];
  252. if(cbTools.isUnDef(bill)) return 0;
  253. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  254. return bill.feesIndex.common.totalFee || 0;
  255. },
  256. 'GF': function () {
  257. let bill = calcBase.fixedBills[calcBase.fixedFlag.CHARGE];
  258. if(cbTools.isUnDef(bill)) return 0;
  259. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  260. return bill.feesIndex.common.totalFee || 0;
  261. },
  262. 'SJ': function () {
  263. let bill = calcBase.fixedBills[calcBase.fixedFlag.TAX];
  264. if(cbTools.isUnDef(bill)) return 0;
  265. if(cbTools.isUnDef(bill.feesIndex) || Object.keys(bill.feesIndex).length === 0) return 0;
  266. return bill.feesIndex.common.totalFee || 0;
  267. }
  268. };
  269. let baseFigureMap = {
  270. '分部分项工程费': 'FBFXGCF',
  271. '分部分项定额基价人工费': 'FBFXDEJJRGF',
  272. '分部分项定额基价材料费': 'FBFXDEJJCLF',
  273. '分部分项定额基价机械费': 'FBFXDEJJJXF',
  274. '分部分项调整人工费': 'FBFXTZRGF',
  275. '分部分项调整机上人工费': 'FBFXTZJSRGF',
  276. '分部分项主材费': 'FBFXZCF',
  277. '分部分项设备费': 'FBFXSBF',
  278. '分部分项未计价材料费': 'FBFXWJJCLF',
  279. '分部分项人工工日': 'FBFXRGGR',
  280. '分部分项工程量清单中的基价直接工程费': 'FBFXGCLQDJJZJGCF',
  281. '措施项目费': 'CSXMF',
  282. '组织措施项目费': 'ZZCSXMF',
  283. '组织措施项目定额基价直接工程费': 'ZZCSXMDEJJZJGCF',
  284. '组织措施项目定额基价人工费': 'ZZCSXMDEJJRGF',
  285. '组织措施项目定额基价材料费': 'ZZCSXMDEJJCLF',
  286. '组织措施项目定额基价机械费': 'ZZCSXMDEJJJXF',
  287. '技术措施项目费': 'JSCSXMF',
  288. '技术措施项目定额基价人工费': 'JSCSXMDEJJRGF',
  289. '技术措施项目定额基价材料费': 'JSCSXMDEJJCLF',
  290. '技术措施项目定额基价机械费': 'JSCSXMDEJJJXF',
  291. '技术措施项目调整人工费': 'JSCSXMTZRGF',
  292. '技术措施项目调整机上人工费': 'JSCSXMTZJSRGF',
  293. '技术措施项目主材费': 'JSCSXMZCF',
  294. '技术措施项目设备费': 'JSCSXMSBF',
  295. '技术措施项目未计价材料费': 'JSCSXMWJJCLF',
  296. '技术措施项目人工工日': 'JSCSXMRGGR',
  297. '技术措施项目清单中的定额基价直接工程费': 'JSCSXMQDDEJJZJGCF',
  298. '其他项目费': 'QTXMF',
  299. '规费': 'GF',
  300. '税金': 'SJ'
  301. };
  302. //输入式分析器
  303. let cbAnalyzer = {
  304. standar: function (exp) {
  305. //去空格
  306. exp = exp.replace(/\s/g, '');
  307. //( to (
  308. exp = exp.replace(/(/g, '(');
  309. //)to )
  310. exp = exp.replace(/)/g, ')');
  311. return exp;
  312. },
  313. //输入合法性
  314. inputLegal: function (exp) {
  315. let ilegalRex = /[^0-9,\u4e00-\u9fa5,\+,\-,\/,\*,\(,\),.]/g;
  316. return !ilegalRex.test(exp);
  317. },
  318. //基数合法性、存在性
  319. baseLegal: function (baseFigures, exp) {
  320. let expFigures = cbParser.getFigure(exp);
  321. for(let i = 0, len = expFigures.length; i < len; i++){
  322. if(cbTools.isUnDef(baseFigures[expFigures[i]])){
  323. return false;
  324. }
  325. }
  326. return true;
  327. },
  328. //四则运算合法性,前端控制不允许重复出现运算符,这里主要判断()的使用问题,这里再判断一次
  329. arithmeticLeagl: function (exp) {
  330. let ilegalRex = /[\+,\-,\*,\/]{2}/g;
  331. return !ilegalRex.test(exp);
  332. },
  333. //
  334. legalExp: function (exp) {
  335. exp = this.standar(exp);
  336. if(this.inputLegal(exp)){
  337. if(this.baseLegal(calcBase.baseFigures, exp)){
  338. if(this.arithmeticLeagl(exp)){
  339. return exp;
  340. }
  341. }
  342. return null;
  343. }
  344. return null;
  345. },
  346. isCN: function(v){
  347. let regex = /[\u4e00-\u9fa5]/g;
  348. return (regex.test(v));
  349. }
  350. };
  351. //输入式转换器
  352. let cbParser = {
  353. //获取表达式中的基数
  354. getFigure: function(expr){
  355. let rst = [];
  356. let cnRex = /[^\u4e00-\u9fa5]/;
  357. let temp = expr.split(cnRex);
  358. for(let i = 0, len = temp.length; i < len; i++){
  359. if(temp[i] !== '' && rst.indexOf(temp[i]) === -1){
  360. rst.push(temp[i]);
  361. }
  362. }
  363. return rst;
  364. },
  365. //将表达式转换为可编译的表达式
  366. toCompileExpr: function(v){
  367. let strs = this.getFigure(v);
  368. let exps = [];
  369. for(let i = 0, len = strs.length; i < len; i++){
  370. let exp = Object.create(null);
  371. exp.orgExp = strs[i];
  372. exps.push(exp);
  373. }
  374. for(let i = 0, len = exps.length;i < len; i++){
  375. exps[i].compileExp = '$CBC.base(\'' + exps[i].orgExp;
  376. exps[i].compileExp = exps[i].compileExp + '\')';
  377. v = v.replace(new RegExp(exps[i].orgExp,"g"), exps[i].compileExp);
  378. }
  379. return v;
  380. }
  381. };
  382. let cbCalctor = {
  383. //计算基数
  384. base: function (figure) {
  385. return baseFigureTemplate[calcBase.baseFigures[figure]]();
  386. },
  387. //计算
  388. exec: function () {
  389. }
  390. };
  391. let calcBase = {
  392. //清单固定行
  393. fixedFlag: null,
  394. fixedBills: Object.create(null),
  395. //清单基数
  396. baseFigures: Object.create(null),
  397. //清单可选基数映射,分两类:组织措施项目:排除父项和计算的父项; 其他项目、规费、税金、工程造价,及新增部分:显示所有计算基数
  398. baseFigureClass: Object.create(null),
  399. //初始化
  400. init: function (project) {
  401. let me = this;
  402. me.project = project;
  403. me.fixedFlag = fixedFlag;
  404. cbTools.setFixedBills(project, me.fixedBills, me.fixedFlag);
  405. me.baseFigures = baseFigureMap;
  406. //me.baseFigures.fixedBills = me.fixedBills;
  407. cbTools.setBaseFigureClass(me.baseFigures, me.baseFigureClass);
  408. },
  409. getBase: function (figure) {
  410. return cbCalctor.base(figure);
  411. },
  412. calculate: function (node) {
  413. let me = calcBase,
  414. $CBA = cbAnalyzer,
  415. $CBP = cbParser,
  416. $CBC = cbCalctor;
  417. try {
  418. //分析输入式合法性
  419. let exp = $CBA.legalExp(node.data.userCalcBase);
  420. if(!exp){
  421. throw '表达式不正确';
  422. }
  423. //输入式转换表达式
  424. let compileExp = $CBP.toCompileExpr(exp);
  425. //计算
  426. let calcBaseValue = eval(compileExp);
  427. if(!cbTools.isNum(calcBaseValue)){
  428. throw '表达式不正确';
  429. }
  430. //存储
  431. node.data.calcBase = exp;
  432. node.data.calcBaseValue = parseFloat(calcBaseValue).toDecimal(decimalObj.decimal('totalPrice', node));
  433. me.project.calcProgram.calculate(node);
  434. me.project.calcProgram.saveNode(node);
  435. }
  436. catch (err){
  437. alert('表达式不正确');
  438. }
  439. },
  440. };