pm_controller.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. /**
  2. * Created by Mai on 2017/1/18.
  3. */
  4. import UnitPriceFileModel from "../../glj/models/unit_price_file_model";
  5. let ProjectsData = require('../models/project_model').project;
  6. let projType = require('../models/project_model').projType;
  7. const engineering = require("../../common/const/engineering");
  8. let EngineeringLibModel = require("../../users/models/engineering_lib_model");
  9. let fee_rate_facade = require("../../fee_rates/facade/fee_rates_facade");
  10. //统一回调函数
  11. let callback = function(req, res, err, message, data){
  12. res.json({error: err, message: message, data: data});
  13. };
  14. module.exports = {
  15. checkRight: function (req, res) {
  16. let data = JSON.parse(req.body.data);
  17. if (data.user_id) {
  18. return data.user_id === req.session.sessionUser.ssoId;
  19. } else {
  20. return false;
  21. }
  22. },
  23. checkProjectRight: function (userId, projectId, callback) {
  24. ProjectsData.getProject(projectId).then(function (result) {
  25. /**
  26. * result._doc.userID(Number): MongoDB
  27. * userId(String): Session.userID
  28. */
  29. if (result._doc.userID == userId && result._doc.projType === projType.tender) {
  30. callback(true);
  31. } else {
  32. callback(false);
  33. }
  34. }).catch(function (err) {
  35. callback(false);
  36. });
  37. },
  38. getProjects: function(req, res){
  39. ProjectsData.getUserProjects(req.session.sessionUser.ssoId, function(err, message, projects){
  40. if (projects) {
  41. callback(req, res, err, message, projects);
  42. } else {
  43. callback(req, res, err, message, null);
  44. }
  45. });
  46. },
  47. updateProjects: async function (req, res) {
  48. let data = JSON.parse(req.body.data);
  49. await ProjectsData.updateUserProjects(req.session.sessionUser.ssoId, data.updateData, function (err, message, data) {
  50. if (err === 0) {
  51. callback(req, res, err, message, data);
  52. } else {
  53. callback(req, res, err, message, null);
  54. }
  55. });
  56. },
  57. copyProjects: function (req, res) {
  58. let data = JSON.parse(req.body.data);
  59. ProjectsData.copyUserProjects(req.session.sessionUser.ssoId, data.updateData, function (err, message, data) {
  60. if (err === 0) {
  61. callback(req, res, err, message, data);
  62. } else {
  63. callback(req, res, err, message, null);
  64. }
  65. });
  66. },
  67. rename: function (req, res) {
  68. let data = JSON.parse(req.body.data);
  69. ProjectsData.rename(req.session.sessionUser.ssoId, data, function (err, message) {
  70. callback(req, res, err, message, null);
  71. });
  72. },
  73. getProject: function(req, res){
  74. let data = JSON.parse(req.body.data);
  75. ProjectsData.getUserProject(req.session.sessionUser.ssoId, data.proj_id, async function(err, message, data){
  76. if (err === 0) {
  77. let engineeringLibModel = new EngineeringLibModel();
  78. let engineeringInfo = data !== null && data.property.engineering_id !== undefined ?
  79. await engineeringLibModel.getEngineering(data.property.engineering_id) : null;
  80. let strData = JSON.stringify(data);
  81. let projInfo = JSON.parse(strData);
  82. if (engineeringInfo !== null) {
  83. projInfo.engineeringInfo = engineeringInfo;
  84. }
  85. callback(req, res, err, message, projInfo);
  86. } else {
  87. callback(req, res, err, message, null);
  88. }
  89. });
  90. },
  91. beforeOpenProject: function (req, res) {
  92. let data = JSON.parse(req.body.data);
  93. ProjectsData.beforeOpenProject(req.session.sessionUser.ssoId, data.proj_id, data.updateData, function (err, message, data) {
  94. callback(req, res, err, message, data);
  95. });
  96. },
  97. getNewProjectID: function (req, res) {
  98. let data = JSON.parse(req.body.data);
  99. ProjectsData.getNewProjectID(data.count, function (err, message, data) {
  100. callback(req, res, err, message, data);
  101. });
  102. },
  103. // 项目管理首页
  104. index: async function(request, response) {
  105. // 获取编办信息
  106. let sessionCompilation = request.session.sessionCompilation;
  107. if (sessionCompilation === undefined) {
  108. return response.redirect('/logout');
  109. }
  110. // 清单计价
  111. let billValuation = sessionCompilation.bill_valuation !== undefined ?
  112. sessionCompilation.bill_valuation : [];
  113. // 获取标准库数据
  114. let engineeringLibModel = new EngineeringLibModel();
  115. billValuation = await engineeringLibModel.getLib(billValuation);
  116. // 定额计价
  117. let rationValuation = sessionCompilation.ration_valuation !== undefined ?
  118. sessionCompilation.ration_valuation : [];
  119. rationValuation = await engineeringLibModel.getLib(rationValuation);
  120. let renderData = {
  121. userAccount: request.session.userAccount,
  122. userID: request.session.sessionUser.ssoId,
  123. compilationData: sessionCompilation,
  124. billValuation: JSON.stringify(billValuation),
  125. rationValuation: JSON.stringify(rationValuation),
  126. engineeringList: JSON.stringify(engineering.List)
  127. };
  128. response.render('building_saas/pm/html/project-management.html', renderData);
  129. },
  130. // 获取单价文件列表
  131. getUnitFileList: async function(request, response) {
  132. let data = request.body.data;
  133. try {
  134. data = JSON.parse(data);
  135. let projectId = data.parentID !== undefined ? data.parentID : 0;
  136. if (isNaN(projectId) && projectId <= 0) {
  137. throw {msg: 'id数据有误!', err: 1};
  138. }
  139. // 获取对应建设项目下所有的单位工程id
  140. let idList = await ProjectsData.getTenderByProjectId(projectId);
  141. if (idList.length <= 0) {
  142. throw {msg: '不存在对应单位工程', err: 0};
  143. }
  144. // 获取对应的单价文件
  145. let unitPriceFileModel = new UnitPriceFileModel();
  146. let unitPriceFileData = await unitPriceFileModel.getDataByTenderId(idList);
  147. if (unitPriceFileData === null) {
  148. throw {msg: '不存在对应单价文件', err: 0};
  149. }
  150. // 整理数据
  151. let unitPriceFileList = [];
  152. for (let unitPriceFile of unitPriceFileData) {
  153. let tmp = {
  154. name: unitPriceFile.name,
  155. id: unitPriceFile.id
  156. };
  157. unitPriceFileList.push(tmp);
  158. }
  159. callback(request, response, 0, '', unitPriceFileList);
  160. } catch (error) {
  161. console.log(error);
  162. let responseData = error.err === 1 ? null : [];
  163. callback(request, response, error.err, error.msg, responseData);
  164. }
  165. },
  166. getFeeRateFileList:async function(request, response) {
  167. let data = request.body.data;
  168. try {
  169. data = JSON.parse(data);
  170. let projectId = data.parentID !== undefined ? data.parentID : 0;
  171. if (isNaN(projectId) && projectId <= 0) {
  172. throw {msg: 'id数据有误!', err: 1};
  173. }
  174. // 获取对应建设项目下所有的单位工程id
  175. let feeRateFileList = await fee_rate_facade.getFeeRatesByProject(projectId);
  176. callback(request, response, 0, '',feeRateFileList );
  177. } catch (error) {
  178. console.log(error);
  179. let responseData = error.err === 1 ? null : [];
  180. callback(request, response, error.err, error.msg, responseData);
  181. }
  182. },
  183. //拼接获取回收站数据
  184. getGCDatas: async function(request, response) {
  185. let userID = req.session.sessionUser.ssoId;
  186. let engIdsSet = new Set(), rootIdsSet = new Set(), rst = [];
  187. try{
  188. let gc_unitPriceFiles = await ProjectsData.getGCFiles('UnitPriceFile', userID);
  189. let gc_feeRateFiles = await ProjectsData.getGCFiles('FeeRateFile', userID);
  190. let gc_tenderFiles = await ProjectsData.getGCFiles(projType.tender, userID);
  191. if(gc_unitPriceFiles.length > 0){
  192. gc_unitPriceFiles.forEach(function (obj) {
  193. rootIdsSet.add(obj.rootProjectID);
  194. });
  195. }
  196. if(gc_feeRateFiles.length > 0){
  197. gc_feeRateFiles.forEach(function (obj) {
  198. rootIdsSet.add(obj.rootProjectID);
  199. });
  200. }
  201. if(gc_tenderFiles.length > 0){
  202. rst = rst.concat(gc_tenderFiles);
  203. gc_tenderFiles.forEach(function (obj) {
  204. engIdsSet.add(obj.ParentID);
  205. });
  206. }
  207. if(engIdsSet.size > 0){
  208. let engineerings = await ProjectsData.getProjectsByIds(Array.from(engIdsSet));
  209. engineerings.forEach(function (obj) {
  210. rst.push(obj);
  211. rootIdsSet.add(obj.ParentID);
  212. });
  213. }
  214. if(rootIdsSet.size > 0){
  215. let projects = await ProjectsData.getProjectsByIds(Array.from(rootIdsSet));
  216. for(let i = 0, len = projects.length; i < len; i++){
  217. projects[i].unitPriceFiles = [];
  218. projects[i].feeRateFiles = [];
  219. for(let j = 0, jLen = gc_unitPriceFiles.length; j < jLen; j++){
  220. if(gc_unitPriceFiles[j].rootProjectID === projects[i].ID){
  221. projects[i].unitPriceFiles.push(gc_unitPriceFiles);
  222. break;
  223. }
  224. }
  225. for(let j = 0, jLen = gc_feeRateFiles.length; j < jLen; j++){
  226. if(gc_feeRateFiles[j].rootProjectID === projects[i].ID){
  227. projects[i].feeRateFiles.push(gc_feeRateFiles[j]);
  228. break;
  229. }
  230. }
  231. }
  232. rst = rst.concat(projects);
  233. }
  234. callback(request, response, null, 'success', rst);
  235. }
  236. catch (error){
  237. callback(request, response, true, 'fail', null);
  238. }
  239. }
  240. };