compilation_controller.js 23 KB

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