compilation_controller.js 23 KB

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