compilation_controller.js 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688
  1. /**
  2. * 编办控制控制器
  3. *
  4. * @author CaiAoLin
  5. * @date 2017/7/28
  6. * @compilation
  7. */
  8. import BaseController from "../../common/base/base_controller";
  9. import CompilationModel from "../models/compilation_model";
  10. import STDRationLibMapModel from "../../common/std/std_ration_lib_map_model";
  11. import STDBillLibListsModel from "../../common/std/std_bills_lib_lists_model";
  12. import STDGLJLibMapModel from "../../common/std/std_glj_lib_map_model";
  13. import STDFeeRateLibsModel from "../../common/std/std_fee_rate_libs_model";
  14. import {default as EngineeringConst, List as EngineeringList} from "../../common/const/engineering";
  15. import BillsTemplateModel from "../models/bills_template_model";
  16. import {default as BillsFixedFlagConst, List as BillsFixedFlagList} from "../../common/const/bills_fixed.js";
  17. import {default as BillsTypeFlagConst, List as BillsTypeFlagList} from "../../common/const/bills_type.js";
  18. import EngineeringLibModel from "../models/engineering_lib_model";
  19. import STDLabourCoesModel from "../../common/std/std_labour_coes_model";
  20. import STDCalcProgramModel from "../../common/std/std_calc_program_model";
  21. const billsGuidanceFc = require('../../std_billsGuidance_lib/facade/facades');
  22. import mainColFacade from "../../main_col_lib/facade/main_col_facade";
  23. import billTemplateFacade from "../../bills_template_lib/facade/bills_template_facade";
  24. import projectFeatureFacade from "../../project_feature_lib/facade/project_feature_facade";
  25. import progressiveFacade from "../../progressive_interval_lib/facade/progressive_facade";
  26. import {default as category, List as categoryList} from "../../common/const/category_const.js";
  27. let config = require("../../../config/config.js");
  28. const fs = require('fs');
  29. class CompilationController extends BaseController {
  30. /**
  31. * 编办管理控制页面
  32. *
  33. * @param {object} request
  34. * @param {object} response
  35. * @return {void}
  36. */
  37. async index(request, response) {
  38. let id = request.query.id;
  39. let compilationList = [];
  40. let selectedCompilation = {};
  41. try {
  42. let compilationModel = new CompilationModel();
  43. compilationList = await compilationModel.getCompilationList();
  44. if (compilationList.length <= 0) {
  45. throw '没有数据';
  46. }
  47. // 循环查找数据
  48. for (let tmp of compilationList) {
  49. if (tmp._id.toString() === id) {
  50. selectedCompilation = tmp;
  51. break;
  52. }
  53. }
  54. selectedCompilation = Object.keys(selectedCompilation).length <= 0 ? compilationList[0] : selectedCompilation;
  55. request.session.selectedCompilation = selectedCompilation;
  56. } catch (error) {
  57. console.log(error);
  58. }
  59. if (selectedCompilation.example && Array.isArray(selectedCompilation.example)) {
  60. selectedCompilation.example = selectedCompilation.example.join(';');
  61. }
  62. let renderData = {
  63. id: id,
  64. compilationList: compilationList,
  65. categoryList: categoryList,
  66. selectedCompilation: selectedCompilation,
  67. layout: 'users/views/layout/layout',
  68. LicenseKey:config.getLicenseKey(process.env.NODE_ENV)
  69. };
  70. response.render('users/views/compilation/index', renderData);
  71. }
  72. /**
  73. * 新增计价页面
  74. *
  75. * @param {object} request
  76. * @param {object} response
  77. * @return {void}
  78. */
  79. async addValuation(request, response) {
  80. let name = request.body.name;
  81. let id = request.body.id;
  82. let section = request.body.section;
  83. let responseData = {
  84. err: 0,
  85. msg: ''
  86. };
  87. try {
  88. if (id === undefined || id === '') {
  89. throw '参数错误';
  90. }
  91. let insertData = {
  92. name: name,
  93. };
  94. let compilationModel = new CompilationModel();
  95. let valuationId = await compilationModel.addValuation(id, section, insertData);
  96. if (!valuationId) {
  97. throw '新增计价规则失败';
  98. }
  99. //添加标准工程专业 2018-08-24 不自动添加标准工程了
  100. /*let engineeringLibModel = new EngineeringLibModel();
  101. let stdEngs = await engineeringLibModel.addStdLib(valuationId);
  102. console.log(stdEngs);*/
  103. } catch (error) {
  104. console.log(error);
  105. responseData.err = 1;
  106. responseData.msg = error;
  107. }
  108. response.json(responseData);
  109. }
  110. /**
  111. * 修改计价规则页面
  112. *
  113. * @param {object} request
  114. * @param {object} response
  115. * @return {void}
  116. */
  117. async editValuation(request, response) {
  118. let selectedCompilation = request.session.selectedCompilation;
  119. let valuationId = request.params.id;
  120. let section = request.params.section;
  121. let compilationList = [];
  122. let engineeringList = [];
  123. let valuationData = {};
  124. let valuationList = {};
  125. try {
  126. let compilationModel = new CompilationModel();
  127. compilationList = await compilationModel.getCompilationList();
  128. // 获取对应的计价规则数据
  129. [valuationData, valuationList] = await compilationModel.getValuation(selectedCompilation._id, valuationId, section);
  130. if (Object.keys(valuationData).length <= 0) {
  131. throw '不存在数据';
  132. }
  133. // 获取计价规则中对应的标准库数据
  134. let engineeringLibModel = new EngineeringLibModel();
  135. engineeringList = await engineeringLibModel.getLibsByValuationID(valuationId);
  136. } catch (error) {
  137. console.log(error);
  138. }
  139. let renderData = {
  140. compilationList: compilationList,
  141. engineeringList: engineeringList,
  142. selectedCompilation: selectedCompilation,
  143. valuationData: valuationData,
  144. valuationList: valuationList,
  145. valuationId: valuationId,
  146. section: section,
  147. layout: 'users/views/layout/layout',
  148. LicenseKey:config.getLicenseKey(process.env.NODE_ENV)
  149. };
  150. response.render('users/views/compilation/add', renderData);
  151. }
  152. /**
  153. * 编辑工程专业页面
  154. *
  155. * @param {object} request
  156. * @param {object} response
  157. * @return {void}
  158. */
  159. async editEngineering(request, response) {
  160. let engineerID = request.params.engineerID;
  161. let valuationId = request.params.id;
  162. let section = request.params.section;
  163. let selectedCompilation = request.session.selectedCompilation;
  164. let compilationList = [],billList = [], rationList = [], gljList = [],feeRateList = [], libData = {}, billsTemplateData = [],featureList = [],progressiveList = [];
  165. let valuationData = {}, valuationList = {}, artificialCoefficientList = [], calculationList = [], billsGuidanceList = [], mainTreeColList = [];
  166. let billTemplateList = [];
  167. try {
  168. let compilationModel = new CompilationModel();
  169. compilationList = await compilationModel.getCompilationList();
  170. // 获取标准清单,不绑定编办
  171. let stdBillLibListsModel = new STDBillLibListsModel();
  172. billList = await stdBillLibListsModel.getBillList();
  173. // 获取定额库
  174. let stdRationLibMapModel = new STDRationLibMapModel();
  175. rationList = await stdRationLibMapModel.getRationLib(selectedCompilation._id);
  176. // 获取工料机库
  177. let stdGLJLibMapModel = new STDGLJLibMapModel();
  178. gljList = await stdGLJLibMapModel.getGLJLibList(selectedCompilation._id);
  179. // 获取费率标准库
  180. let stdFeeRateLibsModel = new STDFeeRateLibsModel();
  181. feeRateList = await stdFeeRateLibsModel.getFeeRateList(selectedCompilation._id);
  182. // 获取人工系数标准库
  183. let stdLabourCoesModel = new STDLabourCoesModel();
  184. artificialCoefficientList = await stdLabourCoesModel.getLabourCoesList();
  185. // 获取计算程序库
  186. let stdCalcProgramModel = new STDCalcProgramModel();
  187. calculationList = await stdCalcProgramModel.getProgramList(selectedCompilation._id);
  188. //获取列设置库
  189. mainTreeColList = await mainColFacade.getColLibsByCompilationID(selectedCompilation._id);
  190. //获取清单模板库
  191. billTemplateList = await billTemplateFacade.getTemplateLibByCompilationID(selectedCompilation._id);
  192. // 获取对应的计价规则数据
  193. [valuationData, valuationList] = await compilationModel.getValuation(selectedCompilation._id, valuationId, section);
  194. if (Object.keys(valuationData).length <= 0) {
  195. throw '不存在数据';
  196. }
  197. // 获取对应专业工程下的标准库数据
  198. let engineeringLibModel = new EngineeringLibModel();
  199. libData = await engineeringLibModel.findDataByCondition({_id:engineerID});
  200. // 获取清单模板数据
  201. let billsTemplateModel = new BillsTemplateModel();
  202. billsTemplateData = await billsTemplateModel.getTemplateData(valuationId, libData.engineering);
  203. //获取清单指引数据
  204. billsGuidanceList = await billsGuidanceFc.getBillsGuideLibs({compilationId: selectedCompilation._id, $or: [{deleted: null}, {deleted: false}]});
  205. //获取工程特征库
  206. featureList = await projectFeatureFacade.findByCondition({},null,false);
  207. //获取累进区间库
  208. progressiveList = await progressiveFacade.findByCondition({},null,false);
  209. } catch (error) {
  210. console.log(error);
  211. }
  212. //example Array to example String
  213. if (selectedCompilation.example && Array.isArray(selectedCompilation.example)) {
  214. selectedCompilation.example = selectedCompilation.example.join(';');
  215. }
  216. let renderData = {
  217. section: section,
  218. valuationId: valuationId,
  219. compilationList: compilationList,
  220. selectedCompilation: selectedCompilation,
  221. libData: libData,
  222. billList: JSON.stringify(billList),
  223. rationList: JSON.stringify(rationList),
  224. gljList: JSON.stringify(gljList),
  225. artificialCoefficientList: JSON.stringify(artificialCoefficientList),
  226. feeRateList: JSON.stringify(feeRateList),
  227. billsTemplateData: JSON.stringify(billsTemplateData),
  228. billTemplateList:JSON.stringify(billTemplateList),
  229. mainTreeColList: JSON.stringify(mainTreeColList),
  230. gljCol:JSON.stringify(libData.glj_col),
  231. calculationList: JSON.stringify(calculationList),
  232. billsGuidanceList: JSON.stringify(billsGuidanceList),
  233. featureList:JSON.stringify(featureList),
  234. progressiveList:JSON.stringify(progressiveList),
  235. layout: 'users/views/layout/layout',
  236. LicenseKey:config.getLicenseKey(process.env.NODE_ENV)
  237. };
  238. response.render('users/views/compilation/engineering', renderData);
  239. }
  240. /**
  241. * 保存工程专业标准库
  242. *
  243. * @param {object} request
  244. * @param {object} response
  245. * @return {void}
  246. */
  247. async saveEngineering(request, response) {
  248. let engineerId = request.body.id;
  249. try {
  250. if (engineerId === '') {
  251. throw 'id参数错误';
  252. }
  253. // 先存入工程专业标准库表
  254. let engineeringLibModel = new EngineeringLibModel();
  255. let result = await engineeringLibModel.addLib(engineerId, request.body);
  256. if (!result) {
  257. throw '保存失败';
  258. }
  259. } catch (error) {
  260. console.log(error);
  261. }
  262. response.redirect(request.headers.referer);
  263. }
  264. /**
  265. * 通过工程专业ID删除工程专业
  266. * @param request
  267. * @param response
  268. * @returns {Promise.<void>}
  269. */
  270. async deleteEngineer(request,response){
  271. let result={
  272. error:0
  273. };
  274. try {
  275. let data = request.body.data;
  276. data = JSON.parse(data);
  277. if(data.id ){
  278. let engineeringLibModel = new EngineeringLibModel();
  279. result.data = await engineeringLibModel.deleteById(data.id,true);
  280. }else {
  281. throw new Error("提交数据有误");
  282. }
  283. }catch (err){
  284. console.log(err);
  285. result.error=1;
  286. result.message = err.message;
  287. }
  288. response.json(result);
  289. }
  290. /**
  291. * 修改保存工程专业信息-用于异步操作
  292. * @param request
  293. * @param response
  294. * @returns {Promise.<void>}
  295. */
  296. async updateEngineer(request,response){
  297. let result={
  298. error:0
  299. };
  300. try {
  301. let data = request.body.data;
  302. data = JSON.parse(data);
  303. if(data.id && data.updateData){
  304. let engineeringLibModel = new EngineeringLibModel();
  305. result.data = await engineeringLibModel.updateById(data.id,data.updateData);
  306. }else {
  307. throw new Error("提交数据有误");
  308. }
  309. }catch (err){
  310. console.log(err);
  311. result.error=1;
  312. result.message = err.message;
  313. }
  314. response.json(result);
  315. }
  316. /**
  317. * 保存计价规则
  318. *
  319. * @param {object} request
  320. * @param {object} response
  321. * @return {void}
  322. */
  323. async saveValuation(request, response) {
  324. let valuationId = request.body.id;
  325. try {
  326. if (valuationId === '') {
  327. throw 'id参数错误';
  328. }
  329. let compilationModel = new CompilationModel();
  330. let result = await compilationModel.saveValuation(valuationId, request.body);
  331. if (!result) {
  332. throw '保存失败';
  333. }
  334. } catch (error) {
  335. console.log(error);
  336. }
  337. response.redirect(request.headers.referer);
  338. }
  339. /**
  340. * 删除计价规则
  341. *
  342. * @param {object} request
  343. * @param {object} response
  344. * @return {void}
  345. */
  346. async deleteValuation(request, response) {
  347. let id = request.params.id;
  348. let section = request.params.section;
  349. let selectedCompilation = request.session.selectedCompilation;
  350. try {
  351. if (id === undefined || id === '' || section === undefined || section === '') {
  352. throw '参数错误';
  353. }
  354. //先删除对应的工程专业
  355. let engineeringLibModel = new EngineeringLibModel();
  356. await engineeringLibModel.deleteByValuationID(id);
  357. //删除计价规则
  358. let compilationModel = new CompilationModel();
  359. let result = compilationModel.deleteValuation(selectedCompilation._id, id, section);
  360. if (!result) {
  361. throw '删除失败';
  362. }
  363. } catch (error) {
  364. console.log(error);
  365. }
  366. response.redirect(request.headers.referer);
  367. }
  368. /**
  369. * 快速切换启用/禁用
  370. *
  371. * @param {object} request
  372. * @param {object} response
  373. * @return {void}
  374. */
  375. async enableSwitch(request, response) {
  376. let id = request.body.id;
  377. let section = request.params.section;
  378. let enable = request.body.enable;
  379. let responseData = {
  380. err: 0,
  381. msg: ''
  382. };
  383. try {
  384. let compilationModel = new CompilationModel();
  385. let result = await compilationModel.switchEnable(id, section, enable);
  386. if (!result) {
  387. throw '新增编办失败';
  388. }
  389. } catch (error) {
  390. console.log(error);
  391. responseData.err = 1;
  392. responseData.msg = error;
  393. }
  394. response.json(responseData);
  395. }
  396. /**
  397. * 发布/取消编办
  398. *
  399. * @param {object} request
  400. * @param {object} response
  401. * @return {void}
  402. */
  403. async release(request, response) {
  404. let id = request.body.id;
  405. let release = request.body.status;
  406. release = parseInt(release);
  407. let responseData = {
  408. err: 0,
  409. msg: ''
  410. };
  411. try {
  412. let compilationModel = new CompilationModel();
  413. let result = await compilationModel.release(id, release);
  414. if (!result) {
  415. throw '发布编办失败';
  416. }
  417. } catch (error) {
  418. console.log(error);
  419. responseData.err = 1;
  420. responseData.msg = error;
  421. }
  422. response.json(responseData);
  423. }
  424. /**
  425. * 新增编办操作
  426. *
  427. * @param {object} request
  428. * @param {object} response
  429. * @return {void}
  430. */
  431. async addCompilation(request, response) {
  432. let name = request.body.name;
  433. let responseData = {
  434. err: 0,
  435. msg: ''
  436. };
  437. try {
  438. let sessionManager = request.session.managerData;
  439. let insertData = {
  440. name: name,
  441. creator: sessionManager.userID
  442. };
  443. let compilationModel = new CompilationModel();
  444. let result = await compilationModel.add(insertData);
  445. if (!result) {
  446. throw '新增编办失败';
  447. }
  448. } catch (error) {
  449. console.log(error);
  450. responseData.err = 1;
  451. responseData.msg = error;
  452. }
  453. response.json(responseData);
  454. }
  455. async setDescription(request, response){
  456. let compilationId = request.body.id;
  457. let description = request.body.description;
  458. try{
  459. let compilationModel = new CompilationModel();
  460. await compilationModel.setDescription(compilationId, description);
  461. response.json({err: 0, msg: '', data: null});
  462. }
  463. catch (err){
  464. response.json({err: 1, msg: err, data: null});
  465. }
  466. }
  467. async setOverWriteUrl(request, response){
  468. let compilationId = request.body.id;
  469. let overWriteUrl = request.body.overWriteUrl;
  470. try{
  471. let compilationModel = new CompilationModel();
  472. //绝对路径
  473. let absoluteUrl = request.app.locals.rootDir + overWriteUrl;
  474. //文件是否存在
  475. let fileExists = fs.existsSync(absoluteUrl);
  476. let pricePropertiesTemplate = [],
  477. consumeAmtPropertiesTemplate = [];
  478. if(fileExists && fs.statSync(absoluteUrl).isFile()){
  479. //读取配置文件并赋值
  480. let overWriteExports = require(absoluteUrl);
  481. if(overWriteExports){
  482. pricePropertiesTemplate = overWriteExports.pricePropertiesTemplate ? overWriteExports.pricePropertiesTemplate : [];
  483. consumeAmtPropertiesTemplate = overWriteExports.consumeAmtPropertiesTemplate ? overWriteExports.consumeAmtPropertiesTemplate : [];
  484. }
  485. }
  486. await compilationModel.setOverWriteUrl(compilationId, overWriteUrl, pricePropertiesTemplate, consumeAmtPropertiesTemplate);
  487. response.json({err: 0, msg: '', data: null});
  488. }
  489. catch (err){
  490. console.log(err);
  491. response.json({err: 1, msg: err, data: null});
  492. }
  493. }
  494. async setExample(request, response){
  495. let compilationId = request.body.id,
  496. example = request.body.example;
  497. try {
  498. let compilationModel = new CompilationModel();
  499. await compilationModel.setExample(compilationId, example);
  500. response.json({err: 0, msg: 'success', data: null});
  501. }
  502. catch (err){
  503. console.log(err);
  504. response.json({err: 1, msg: err, data: null});
  505. }
  506. }
  507. /**
  508. * 模板设置页面
  509. *
  510. * @param {object} request
  511. * @param {object} response
  512. * @return {void}
  513. */
  514. async billsTemplate(request, response) {
  515. let billList = {};
  516. let valuationList = {};
  517. let valuationData = {};
  518. let compilationList = [];
  519. let billsTemplateData = [];
  520. let selectedCompilation = request.session.selectedCompilation;
  521. let engineering = request.params.engineering;
  522. let valuationId = request.params.id;
  523. let section = request.params.section;
  524. try {
  525. let compilationModel = new CompilationModel;
  526. // 获取对应的计价规则数据
  527. [valuationData, valuationList] = await compilationModel.getValuation(selectedCompilation._id, valuationId, section);
  528. compilationList = await compilationModel.getCompilationList();
  529. // 获取标准清单
  530. let stdBillLibListsModel = new STDBillLibListsModel();
  531. billList = await stdBillLibListsModel.getBillList(selectedCompilation._id);
  532. // 获取清单模板数据
  533. let billsTemplateModel = new BillsTemplateModel();
  534. billsTemplateData = await billsTemplateModel.getTemplateData(valuationId, engineering);
  535. } catch (error) {
  536. console.log(error);
  537. }
  538. let renderData = {
  539. engineering: engineering,
  540. billList: JSON.stringify(billList),
  541. billsTemplateData: JSON.stringify(billsTemplateData),
  542. billsFixedFlagList: JSON.stringify(BillsFixedFlagList),
  543. billsTypeFlagList: JSON.stringify(BillsTypeFlagList),
  544. valuationData: valuationData,
  545. valuationList: valuationList,
  546. selectedCompilation: selectedCompilation,
  547. compilationList: compilationList,
  548. valuationId: valuationId,
  549. section: section,
  550. layout: 'users/views/layout/layout',
  551. LicenseKey:config.getLicenseKey(process.env.NODE_ENV)
  552. };
  553. response.render('users/views/compilation/template', renderData);
  554. }
  555. /**
  556. * 清单模板,更新数据操作
  557. *
  558. * @param request
  559. * @param response
  560. */
  561. async updateBillsTemplate(request, response) {
  562. let engineering = request.params.engineering;
  563. let valuationId = request.params.id;
  564. let section = request.params.section;
  565. let data = JSON.parse(request.body.data);
  566. let billsTemplateModel = new BillsTemplateModel();
  567. let result = await billsTemplateModel.updateTemplate(valuationId, engineering, data);
  568. if (result) {
  569. response.json({error: 0, message: '', data: data});
  570. } else {
  571. response.json({error: 1, message: '更新数据错误', data: null});
  572. }
  573. }
  574. async addEngineer(request,response){
  575. let engineeringLibModel = new EngineeringLibModel();
  576. try {
  577. await engineeringLibModel.addEngineer(request.body);
  578. }catch (error) {
  579. console.log(error);
  580. }
  581. response.redirect(request.headers.referer);
  582. }
  583. /**
  584. * 更改编办所属办事处信息
  585. *
  586. * @param request
  587. * @param response
  588. * @return {Promise.<void>}
  589. */
  590. async changeCategory(request, response) {
  591. let valuationId = request.body.id;
  592. let category = request.body.category;
  593. category = parseInt(category);
  594. try {
  595. let compilationModel = new CompilationModel();
  596. let result = await compilationModel.updateCategory(valuationId, category);
  597. if (result) {
  598. response.json({error: 0, message: '', data: null});
  599. } else {
  600. response.json({error: 1, message: '更新数据错误', data: null});
  601. }
  602. } catch(error) {
  603. response.json({error: 1, message: '更新数据错误', data: null});
  604. }
  605. }
  606. }
  607. export default CompilationController;