sub_proj_setting_controller.js 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Mai
  6. * @date
  7. * @version
  8. */
  9. const tenderConst = require('../const/tender');
  10. const auditConst = require('../const/audit');
  11. const officeList = require('../const/cld_office').list;
  12. const settingConst = require('../const/setting.js');
  13. const scheduleConst = require('../const/schedule');
  14. const settingMenu = require('../../config/menu').projectSettingMenu;
  15. const projectLog = require('../const/project_log');
  16. const imType = require('../const/tender').imType;
  17. const path = require('path');
  18. const funSet = require('../const/fun_set');
  19. const projectSettingConst = require('../const/project_setting');
  20. const shenpiConst = require('../const/shenpi');
  21. module.exports = app => {
  22. class SettingController extends app.BaseController {
  23. /**
  24. * 构造函数
  25. *
  26. * @param {Object} ctx - egg全局context
  27. * @return {void}
  28. */
  29. constructor(ctx) {
  30. super(ctx);
  31. ctx.subMenu = JSON.parse(JSON.stringify(settingMenu));
  32. for (const index in ctx.subMenu) {
  33. const menu = ctx.subMenu[index];
  34. menu.url = `/sp/${ctx.subProject.id}` + menu.url;
  35. }
  36. }
  37. async defaultCheck(ctx) {
  38. if (!ctx.subProject) throw '没有对应的项目数据';
  39. if (ctx.session.sessionUser.is_admin === 0) throw '没有访问权限';
  40. }
  41. /**
  42. * 项目设置 -- 自定义标段分类(Get)
  43. *
  44. * @param ctx
  45. * @return {Promise<void>}
  46. */
  47. async category(ctx) {
  48. try {
  49. this.defaultCheck(ctx);
  50. // 获取项目数据
  51. const categoryData = await ctx.service.category.getAllCategory(ctx.subProject);
  52. const tenderData = await ctx.service.tender.getList('', null, 1);
  53. const renderData = {
  54. categoryType: settingConst.cType,
  55. categoryData,
  56. tenderData,
  57. };
  58. await this.layout('sp_setting/category.ejs', renderData, 'sp_setting/category_modal.ejs');
  59. } catch (error) {
  60. ctx.log(error);
  61. ctx.redirect(`/sp/${ctx.subProject.id}/dashboard`);
  62. }
  63. }
  64. /**
  65. * 新增分类(Ajax)
  66. *
  67. * @param ctx
  68. * @return {Promise<void>}
  69. */
  70. async addCategory(ctx) {
  71. try {
  72. const responseData = {
  73. err: 0, msg: '', data: null,
  74. };
  75. const data = JSON.parse(ctx.request.body.data);
  76. if (!data.name) {
  77. throw '提交数据错误';
  78. }
  79. responseData.data = await ctx.service.category.addCategory(ctx.subProject, data.name, settingConst.cType.key.dropDown);
  80. ctx.body = responseData;
  81. } catch (err) {
  82. ctx.log(err);
  83. ctx.body = {err: 1, msg: err.toString(), data: null};
  84. }
  85. }
  86. /**
  87. * 编辑分类(Ajax)
  88. *
  89. * @param ctx
  90. * @return {Promise<void>}
  91. */
  92. async updateCategory(ctx) {
  93. try {
  94. const responseData = {err: 0, msg: '', data: null};
  95. const data = JSON.parse(ctx.request.body.data);
  96. if (!data.id) {
  97. throw '提交数据错误';
  98. }
  99. if (data.name) {
  100. const count = await ctx.service.category.count({spid: ctx.subProject.id, name: data.name});
  101. if (count >= 1) {
  102. throw '存在同名类别';
  103. }
  104. }
  105. const result = await ctx.service.category.update(data, {id: data.id});
  106. if (!result) {
  107. throw '提交数据失败';
  108. }
  109. responseData.data = await ctx.service.category.getCategory(data.id);
  110. ctx.body = responseData;
  111. } catch (err) {
  112. ctx.log(err);
  113. ctx.body = {err: 1, msg: err.toString(), data: null};
  114. }
  115. }
  116. async setCategoryValue(ctx) {
  117. try {
  118. const responseData = {err: 0, msg: '', data: {}};
  119. const data = JSON.parse(ctx.request.body.data);
  120. if (!data.id) {
  121. throw '提交数据错误';
  122. }
  123. await ctx.service.categoryValue.setCategoryValue(ctx.subProject, data.id, data.updateValue);
  124. responseData.data.category = await ctx.service.category.getCategory(data.id);
  125. // todo 查询标段
  126. responseData.data.tenders = await ctx.service.tender.getList('', null, 1);
  127. ctx.body = responseData;
  128. } catch (err) {
  129. ctx.log(err);
  130. ctx.body = {err: 1, msg: err instanceof String ? err : '提交数据失败', data: null};
  131. }
  132. }
  133. /**
  134. * 删除分类(Ajax)
  135. *
  136. * @param ctx
  137. * @return {Promise<void>}
  138. */
  139. async deleteCategory(ctx) {
  140. try {
  141. const responseData = {
  142. err: 0, msg: '', data: null,
  143. };
  144. const data = JSON.parse(ctx.request.body.data);
  145. if (!data.id) {
  146. throw '提交数据错误';
  147. }
  148. await ctx.service.category.deleteCategory(ctx.subProject, data.id);
  149. ctx.body = responseData;
  150. } catch (err) {
  151. ctx.log(err);
  152. ctx.body = {err: 1, msg: err.toString(), data: null};
  153. }
  154. }
  155. /**
  156. * 调整分类层次排序(Ajax)
  157. *
  158. * @param ctx
  159. * @return {Promise<void>}
  160. */
  161. async resetCategoryLevel(ctx) {
  162. try {
  163. const responseData = {
  164. err: 0, msg: '', data: null,
  165. };
  166. const data = JSON.parse(ctx.request.body.data);
  167. await ctx.service.category.resetCategoryLevel(data);
  168. responseData.data = await ctx.service.category.getAllCategory(ctx.subProject);
  169. ctx.body = responseData;
  170. } catch (err) {
  171. ctx.log(err);
  172. ctx.body = {err: 1, msg: err.toString(), data: null};
  173. }
  174. }
  175. async selfCategoryLevel(ctx) {
  176. try {
  177. const data = JSON.parse(ctx.request.body.data);
  178. await ctx.service.subProjPermission.defaultUpdate({
  179. self_category_level: data.self_category_level || ''
  180. }, { where: { spid: ctx.subProject.id, uid: ctx.session.sessionUser.accountId}});
  181. ctx.body = {
  182. err: 0, msg: '', data: null,
  183. };
  184. } catch (err) {
  185. ctx.log(err);
  186. ctx.ajaxErrorBody(err, '保存自定义分类失败');
  187. }
  188. }
  189. async user(ctx) {
  190. try {
  191. this.defaultCheck(ctx);
  192. const unitList = await ctx.service.constructionUnit.getAllDataByCondition({ where: { pid: ctx.session.sessionProject.id } });
  193. const filter = {
  194. company: ctx.query.company || '',
  195. keyword: ctx.query.keyword || '',
  196. };
  197. const total = await ctx.service.projectAccount.getSubProjectAccountCount(ctx.subProject, filter);
  198. const subProjectAccountList = await ctx.service.projectAccount.getSubProjectAccountListWithPermission(ctx.subProject, filter);
  199. const subProjectAllAccountList = await ctx.service.projectAccount.getSubProjecAllAccountListWithPermission(ctx.subProject);
  200. const subProjectUnitList = unitList.map(item => {
  201. const users = subProjectAllAccountList.filter(item1 => item1.company === item.name);
  202. return { name: item.name, users };
  203. }).filter(x => { return x.users.length > 0; });
  204. const pageInfo = {
  205. page: ctx.page,
  206. pageSizeSelect: 1,
  207. pageSize: ctx.pageSize,
  208. total_num: total,
  209. total: Math.ceil(total / ctx.pageSize),
  210. queryData: JSON.stringify(ctx.urlInfo.query),
  211. };
  212. const accountList = await ctx.service.projectAccount.getAllDataByCondition({
  213. columns: ['id', 'name', 'company', 'role', 'enable', 'is_admin', 'account_group', 'mobile', 'company_id'],
  214. where: { project_id: ctx.subProject.project_id },
  215. });
  216. accountList.forEach(x => {
  217. x.sp_exist = subProjectAllAccountList.findIndex(y => { return y.id === x.id; }) >= 0;
  218. });
  219. const accountGroup = unitList.map(item => {
  220. const groupList = accountList.filter(item1 => item1.company === item.name);
  221. return { id: item.id, name: item.name, groupList };
  222. }).filter(x => { return x.groupList.length > 0; });
  223. // const subProjects = await this.ctx.service.subProject.getAllDataByCondition({ where: { project_id: this.ctx.session.sessionProject.id, is_delete: 0 }});
  224. const subProjects = await this.ctx.service.subProject.getSubProjectTreeNodes(this.ctx.session.sessionProject.id,
  225. this.ctx.session.sessionUser.accountId, this.ctx.session.sessionUser.is_admin);
  226. const renderData = {
  227. pageInfo,
  228. accountGroup,
  229. subProjectAccountList,
  230. subProjectUnitList,
  231. subProjectAllAccountList,
  232. keyword: filter.keyword,
  233. company: filter.company,
  234. jsFiles: this.app.jsFiles.common.concat(this.app.jsFiles.setting.sp_permission),
  235. permissionBlock: ctx.service.subProjPermission.PermissionBlock,
  236. accountList,
  237. subProjects,
  238. };
  239. await this.layout('sp_setting/user.ejs', renderData, 'sp_setting/user_modal.ejs');
  240. } catch (error) {
  241. ctx.log(error);
  242. ctx.redirect(`/sp/${ctx.subProject.id}/dashboard`);
  243. }
  244. }
  245. async permission(ctx) {
  246. try {
  247. this.defaultCheck(ctx);
  248. const unitList = await ctx.service.constructionUnit.getAllDataByCondition({ where: { pid: ctx.session.sessionProject.id } });
  249. const filter = {
  250. keyword: ctx.query.keyword || '',
  251. };
  252. const permissionConst = this.service.subProjPermission.PermissionConst;
  253. const subProjectAccountList = await ctx.service.projectAccount.getSubProjecAllAccountListWithPermission(ctx.subProject, filter);
  254. const subProjectAllAccountList = await ctx.service.projectAccount.getSubProjecAllAccountListWithPermission(ctx.subProject);
  255. const subProjectUnitList = unitList.map(item => {
  256. const users = subProjectAccountList.filter(item1 => item1.company === item.name);
  257. return { name: item.name, users };
  258. }).filter(x => { return x.users.length > 0; });
  259. const accountList = await ctx.service.projectAccount.getAllDataByCondition({
  260. columns: ['id', 'name', 'company', 'role', 'enable', 'is_admin', 'account_group', 'mobile', 'company_id'],
  261. where: { project_id: ctx.subProject.project_id },
  262. });
  263. accountList.forEach(x => {
  264. x.sp_exist = subProjectAllAccountList.findIndex(y => { return y.id === x.id; }) >= 0;
  265. });
  266. const accountGroup = unitList.map(item => {
  267. const groupList = accountList.filter(item1 => item1.company === item.name);
  268. return { id: item.id, name: item.name, groupList };
  269. }).filter(x => { return x.groupList.length > 0; });
  270. const relaBlock = ctx.service.subProjPermission.getRelaPermissionBlock(ctx.query.ptype);
  271. const subProjects = await this.ctx.service.subProject.getAllDataByCondition({ where: { project_id: this.ctx.session.sessionProject.id, is_folder: 0, is_delete: 0 }});
  272. const renderData = {
  273. ptype: ctx.query.ptype,
  274. ptypeStr: relaBlock ? relaBlock.name : '',
  275. ptypeHint: relaBlock && relaBlock.hint ? relaBlock.hint : '',
  276. accountGroup,
  277. subProjectAccountList,
  278. subProjectAllAccountList,
  279. subProjectUnitList,
  280. keyword: filter.keyword,
  281. jsFiles: this.app.jsFiles.common.concat(this.app.jsFiles.setting.sp_permission),
  282. permissionBlock: ctx.service.subProjPermission.PermissionBlock,
  283. permissionConst: permissionConst[ctx.query.ptype],
  284. accountList,
  285. subProjects,
  286. };
  287. await this.layout('sp_setting/permission.ejs', renderData, 'sp_setting/user_modal.ejs');
  288. } catch (error) {
  289. ctx.log(error);
  290. ctx.redirect(`/sp/${ctx.subProject.id}/dashboard`);
  291. }
  292. }
  293. async permissionUpdate(ctx) {
  294. try {
  295. this.defaultCheck(ctx);
  296. const data = JSON.parse(ctx.request.body.data);
  297. const result = await ctx.service.subProjPermission.updatePermission(ctx.subProject, data);
  298. ctx.body = { err: 0, msg: '', data: result };
  299. } catch (err) {
  300. ctx.log(err);
  301. ctx.ajaxErrorBody(err, '更新账号权限失败');
  302. }
  303. }
  304. async logs(ctx) {
  305. try {
  306. this.defaultCheck(ctx);
  307. // 获取项目数据
  308. const settingType = ctx.params.type ? parseInt(ctx.params.type) : 0;
  309. const logs = await ctx.service.projectLog.getLogs(ctx.subProject.id, settingType);
  310. const renderData = {
  311. officeList,
  312. projectLog,
  313. settingType,
  314. logs,
  315. };
  316. await this.layout('sp_setting/logs.ejs', renderData);
  317. } catch (error) {
  318. ctx.log(error);
  319. ctx.redirect(`/sp/${ctx.subProject.id}/dashboard`);
  320. }
  321. }
  322. async fun(ctx) {
  323. try {
  324. this.defaultCheck(ctx);
  325. const funRela = this.ctx.subProject.fun_rela;
  326. const fun_set = this.ctx.subProject.fun_set;
  327. await this.layout('sp_setting/fun.ejs', {
  328. funRela,
  329. imType,
  330. endMonth: funSet.endMonth,
  331. funSet: fun_set,
  332. }, 'sp_setting/fun_modal.ejs');
  333. } catch (error) {
  334. ctx.log(error);
  335. ctx.redirect(`/sp/${ctx.subProject.id}/dashboard`);
  336. }
  337. }
  338. /**
  339. * 保存功能设置相关
  340. * @param ctx
  341. * @returns {Promise<void>}
  342. */
  343. async updateFun(ctx) {
  344. try {
  345. this.defaultCheck(ctx);
  346. const data = JSON.parse(ctx.request.body.data);
  347. if (data) ctx.request.body = data;
  348. const rule = ctx.service.subProject.rule('fun');
  349. ctx.validate(rule);
  350. const result = await ctx.service.subProject.updateFunRela(ctx.subProject.id, ctx.request.body);
  351. if (!result) throw '保存数据失败';
  352. this.ctx.subProject.page_show.openChangeProject = data.openChangeProject ? 1 : 0;
  353. this.ctx.subProject.page_show.openChangeApply = data.openChangeApply ? 1 : 0;
  354. this.ctx.subProject.page_show.openChangePlan = data.openChangePlan ? 1 : 0;
  355. this.ctx.subProject.page_show.openChangeWhiteList = data.openChangeWhiteList ? 1 : 0;
  356. this.ctx.subProject.page_show.openChangeState = data.openChangeState ? 1 : 0;
  357. this.ctx.subProject.page_show.openMaterialTax = data.openMaterialTax ? 1 : 0;
  358. this.ctx.subProject.page_show.openMaterialChecklist = data.openMaterialChecklist ? 1 : 0;
  359. this.ctx.subProject.page_show.openMaterialSelf = data.openMaterialSelf ? 1 : 0;
  360. this.ctx.subProject.page_show.openMaterialEditForAudit = data.openMaterialEditForAudit ? 1 : 0;
  361. this.ctx.subProject.page_show.openStageStart = data.openStageStart ? 1 : 0;
  362. this.ctx.subProject.page_show.openMaterialStageRepeat = data.openMaterialStageRepeat ? 1 : 0;
  363. this.ctx.subProject.page_show.openContractExpr = data.openContractExpr ? 1 : 0;
  364. this.ctx.subProject.page_show.correctCalcContractTp = data.correctCalcContractTp ? 1 : 0;
  365. this.ctx.subProject.page_show.close1stStageCheckDealParam = data.close1stStageCheckDealParam ? 1 : 0;
  366. this.ctx.subProject.page_show.openMultiStageCalc = data.openMultiStageCalc ? 1 : 0;
  367. this.ctx.subProject.page_show.closeWapYfSf = data.closeWapYfSf ? 1 : 0;
  368. this.ctx.subProject.page_show.openStageAudit = data.openStageAudit ? 1 : 0;
  369. this.ctx.subProject.page_show.stageAuditEarly = data.stageAuditEarly || 0;
  370. this.ctx.subProject.page_show.stageAuditWorry = data.stageAuditWorry || 0;
  371. const result2 = await ctx.service.subProject.updatePageshow(ctx.subProject.id);
  372. if (!result2) throw '保存数据失败';
  373. if (data.addFunSet) {
  374. const funSet = ctx.subProject.fun_set;
  375. ctx.helper._.defaultsDeep(data.addFunSet, funSet);
  376. const result3 = await ctx.service.subProject.updateFunSet(ctx.subProject.id, data.addFunSet);
  377. if (!result3) throw '保存数据失败';
  378. }
  379. ctx.body = {err: 0, msg: '', data: null};
  380. } catch (error) {
  381. ctx.log(error);
  382. this.ajaxErrorBody(error, '保存数据失败');
  383. }
  384. }
  385. async dataCollect(ctx) {
  386. try {
  387. this.defaultCheck(ctx);
  388. if (!ctx.subProject.page_show.openDataCollect) {
  389. throw '该功能已关闭或无法查看';
  390. }
  391. ctx.subProject.data_collect_pages = ctx.subProject.data_collect_pages ? ctx.subProject.data_collect_pages.split(',') : [];
  392. if (ctx.session.sessionUser.is_admin === 0) throw '没有访问权限';
  393. const dataCollectAudits = await ctx.service.subProjPermission.getDatacollectAuditList(ctx.subProject.id);
  394. // 获取所有项目参与者
  395. const accountList = await ctx.service.projectAccount.getAllSubProjectAccount(ctx.subProject);
  396. const unitList = await ctx.service.constructionUnit.getAllDataByCondition({where: {pid: ctx.session.sessionProject.id}});
  397. const accountGroupList = unitList.map(item => {
  398. const groupList = accountList.filter(item1 => item1.company === item.name);
  399. return {groupName: item.name, companyId: item.id, groupList};
  400. }).filter(x => { return x.groupList.length > 0; });
  401. const categoryData = await ctx.service.category.getAllCategory(ctx.subProject);
  402. const tenders = await ctx.service.tender.getList('', null, 1);
  403. const dcTenders = await ctx.service.datacollectTender.getList(ctx.subProject.project_id, ctx.subProject.id);
  404. const is_dz2 = ['P0505', 'P0506', 'P1201', 'P1202', 'GY18Y', 'GYJJ1', 'P1103', 'KLG25', 'I2U5B', 'SEN48'].indexOf(ctx.session.sessionProject.code) !== -1 ? 6 : false;
  405. const renderData = {
  406. dataCollectAudits,
  407. accountList,
  408. accountGroup: accountGroupList,
  409. categoryData,
  410. tenders,
  411. dcTenders,
  412. is_dz1: ['P0505', 'MI22U'].indexOf(ctx.session.sessionProject.code) !== -1 ? 5 : false,
  413. is_dz2,
  414. selfCategoryLevel: await ctx.service.projectAccount.getSelfCategoryLevel(this.ctx.session.sessionUser.accountId),
  415. };
  416. if (is_dz2) {
  417. const projectData = await this.ctx.service.project.getDataById(ctx.subProject.project_id);
  418. // 获取分类及对应值
  419. if (!ctx.subProject.common_json) {
  420. ctx.subProject.common_json = await ctx.service.subProject.updateCommonJsonDaping06(ctx.subProject, projectData);
  421. }
  422. const commonJson = ctx.subProject.common_json ? JSON.parse(ctx.subProject.common_json) : null;
  423. renderData.daPing06Set = commonJson && commonJson.daPing06_set ? commonJson.daPing06_set : ctx.helper._.cloneDeep(projectSettingConst.daPing06Set);
  424. }
  425. await this.layout('sp_setting/datacollect.ejs', renderData, 'sp_setting/datacollect_modal.ejs');
  426. } catch (error) {
  427. ctx.log(error);
  428. ctx.session.postError = error.toString();
  429. ctx.redirect(`/sp/${ctx.subProject.id}/dashboard`);
  430. }
  431. }
  432. async dataCollectSave(ctx) {
  433. try {
  434. this.defaultCheck(ctx);
  435. const responseData = {
  436. err: 0, msg: '', data: null,
  437. };
  438. const data = JSON.parse(ctx.request.body.data);
  439. if (!data.type) {
  440. throw '提交数据错误';
  441. }
  442. let uids;
  443. let auditList = [];
  444. switch (data.type) {
  445. case 'show':
  446. responseData.data = await ctx.service.subProject.update({
  447. data_collect: data.data_collect,
  448. data_collect_pages: data.data_collect_pages.join(','),
  449. }, {id: ctx.subProject.id});
  450. ctx.subProject.data_collect = data.data_collect;
  451. ctx.subProject.showDataCollect = data.data_collect ? 1 : 0;
  452. break;
  453. case 'add-audit':
  454. uids = data.id instanceof Array ? data.id : [data.id];
  455. // 判断该用户是否已加入到表中,已加入则提示无需添加
  456. auditList = await ctx.service.subProjPermission.getDatacollectAuditList(ctx.subProject.id, uids);
  457. const addAidList = ctx.helper._.difference(uids, ctx.helper._.map(auditList, 'uid'));
  458. if (addAidList.length === 0) {
  459. throw '用户已存在权限中,无需重复添加';
  460. }
  461. // await ctx.service.datacollectAudit.saveAudit(ctx.subProject.project_id, data.id);
  462. await ctx.service.subProjPermission.saveDatacollectPermissionAudits(ctx.subProject.id, addAidList, 'add');
  463. responseData.data = await ctx.service.subProjPermission.getDatacollectAuditList(ctx.subProject.id);
  464. break;
  465. case 'del-audit':
  466. uids = data.id instanceof Array ? data.id : [data.id];
  467. auditList = await ctx.service.subProjPermission.getDatacollectAuditList(ctx.subProject.id, uids);
  468. if (auditList.length !== uids.length) {
  469. throw '该用户已不存在权限中,移除失败';
  470. }
  471. await ctx.service.subProjPermission.saveDatacollectPermissionAudits(ctx.subProject.id, uids, 'del');
  472. responseData.data = await ctx.service.subProjPermission.getDatacollectAuditList(ctx.subProject.id);
  473. break;
  474. case 'tender':
  475. if (ctx.subProject.page_show.addDataCollect !== parseInt(data.add_datacollect)) {
  476. ctx.subProject.page_show.addDataCollect = parseInt(data.add_datacollect);
  477. await ctx.service.subProject.updatePageshow(ctx.subProject.id);
  478. }
  479. await ctx.service.datacollectTender.updateList(ctx.subProject.project_id, data.tids);
  480. responseData.data = {
  481. dcTenders: await ctx.service.datacollectTender.getList(ctx.subProject.project_id, ctx.subProject.id),
  482. addDatacollect: ctx.subProject.page_show.addDataCollect,
  483. };
  484. break;
  485. case 'save-dp06':
  486. responseData.data = await ctx.service.subProject.saveCommonJson(ctx.subProject.id, 'daPing06_set', data.daPing06Set);
  487. break;
  488. default:
  489. throw '参数有误';
  490. }
  491. ctx.body = responseData;
  492. } catch (err) {
  493. ctx.log(err);
  494. ctx.body = {err: 1, msg: err.toString(), data: null};
  495. }
  496. }
  497. async manage(ctx) {
  498. try {
  499. this.defaultCheck(ctx);
  500. const projectId = ctx.session.sessionProject.id;
  501. const projectData = await ctx.service.project.getDataById(projectId);
  502. if (projectData === null) throw '没有对应的项目数据';
  503. if (ctx.session.sessionUser.is_admin === 0) throw '没有访问权限';
  504. // 默认查询已完工的标段
  505. const { done = '1' } = ctx.query || {};
  506. const buildStatusFilter = ctx.service.tender.db.format(' AND build_status = ?', [tenderConst.buildStatus.status.finish]);
  507. const tenderList = await ctx.service.tender.getList('', null, 1, done === '1' ? buildStatusFilter : '');
  508. const removeTenders = await ctx.service.shenpiAudit.getRemoveTenders(tenderList);
  509. if (removeTenders.length > 0) {
  510. ctx.helper._.remove(tenderList, function(n) {
  511. return removeTenders.indexOf(n.id) !== -1;
  512. });
  513. }
  514. // for (const t of tenderList) {
  515. // t.visitor = (await this.ctx.service.tenderTourist.getTourists(t.id)).map(x => { return x.user_name; });
  516. // await this.ctx.service.tenderCache.loadTenderCache(t, this.ctx.session.sessionUser.accountId);
  517. // }
  518. // todo 自定义分类移动到子项目内部后,在整个项目上没有分类了
  519. const categoryData = await ctx.service.category.getAllCategory(ctx.subProject);
  520. // const categoryData = []; // await this.ctx.service.category.getAllCategory(this.ctx.session.sessionProject.id);
  521. // 获取所有项目参与者
  522. const accountList = await ctx.service.projectAccount.getAllSubProjectAccount(ctx.subProject);
  523. const unitList = await ctx.service.constructionUnit.getAllDataByCondition({where: {pid: ctx.session.sessionProject.id}});
  524. const accountGroupList = unitList.map(item => {
  525. const groupList = accountList.filter(item1 => item1.company === item.name);
  526. return {groupName: item.name, groupList};
  527. }).filter(x => { return x.groupList.length > 0; });
  528. // 获取项目列表
  529. // const subProjects = await ctx.service.subProject.getAllDataByCondition({ where: { project_id: projectId, is_folder: 0, is_delete: 0 } });
  530. const subProjects = await ctx.service.subProject.getSubProject(projectId, ctx.session.sessionUser.accountId, ctx.session.sessionUser.is_admin);
  531. const renderData = {
  532. projectData,
  533. tenderList,
  534. auditConst,
  535. auditType: auditConst.auditType,
  536. accountList,
  537. accountGroup: accountGroupList,
  538. categoryData,
  539. settingConst,
  540. measureType: tenderConst.measureType,
  541. jsFiles: this.app.jsFiles.common.concat(this.app.jsFiles.setting.sp_manage),
  542. uid: this.ctx.session.sessionUser.accountId,
  543. pid: this.ctx.session.sessionProject.id,
  544. spid: ctx.subProject.id,
  545. scPermission: scheduleConst.permission,
  546. change_type_list: shenpiConst.change_type_list,
  547. subProjects,
  548. };
  549. renderData.selfCategoryLevel = await this.ctx.service.projectAccount.getSelfCategoryLevel(this.ctx.session.sessionUser.accountId);
  550. renderData.permissionConst = ctx.service.tenderPermission.partPermissionConst('quality');
  551. renderData.permissionBlock = ctx.service.tenderPermission.partPermissionBlock('quality');
  552. await this.layout('sp_setting/manage.ejs', renderData, 'sp_setting/manage_modal.ejs');
  553. } catch (error) {
  554. ctx.log(error);
  555. ctx.redirect(`/sp/${ctx.subProject.id}/dashboard`);
  556. }
  557. }
  558. async manageTenderSave(ctx) {
  559. try {
  560. this.defaultCheck(ctx);
  561. if (ctx.session.sessionUser.is_admin === 0) throw '没有设置权限';
  562. const projectId = ctx.session.sessionProject.id;
  563. const responseData = {
  564. err: 0, msg: '', data: {},
  565. };
  566. const data = JSON.parse(ctx.request.body.data);
  567. if (!data.type) {
  568. throw '提交数据错误';
  569. }
  570. // if (!data.tid) {
  571. // throw '参数有误';
  572. // }
  573. // const tender = await ctx.service.tender.getDataById(data.tid);
  574. // if (!tender) {
  575. // throw '标段不存在';
  576. // }
  577. // const tenderInfo = await ctx.service.tenderInfo.getTenderInfo(tender.id);
  578. switch (data.type) {
  579. case 'msg':
  580. if (!data.tid) {
  581. throw '参数有误';
  582. }
  583. const tender = await ctx.service.tender.getDataById(data.tid);
  584. if (!tender) {
  585. throw '标段不存在';
  586. }
  587. const tenderInfo = await ctx.service.tenderInfo.getTenderInfo(tender.id);
  588. const lastRevise = await ctx.service.ledgerRevise.getLastestRevise(tender.id);
  589. const revising = (lastRevise && lastRevise.status !== auditConst.revise.status.checked) || false;
  590. // 获取审批流,游客账号,及投资进度账号信息
  591. responseData.data.tender = tender;
  592. responseData.data.revising = revising;
  593. responseData.data.shenpi = await ctx.service.shenpiAudit.getShenpi(tender.id, tenderInfo);
  594. const tourists = await ctx.service.tenderTourist.getTourists(tender.id);
  595. for (const t of tourists) {
  596. t.permission = await ctx.service.tenderTourist.getTouristPermission(t);
  597. }
  598. responseData.data.tourists = tourists;
  599. responseData.data.scheduleAuditList = await ctx.service.scheduleAudit.getAllDataByCondition({ where: { tid: tender.id } });
  600. responseData.data.contractAuditList = await ctx.service.contractAudit.getList({ tid: tender.id });
  601. responseData.data.constructionAuditList = await ctx.service.constructionAudit.getList(tender.id);
  602. responseData.data.qualityAuditList = await ctx.service.tenderPermission.getPartsPermission(tender.id, ['quality']);
  603. break;
  604. case 'copy2otu':
  605. if (data.userType === 'tourist') {
  606. await ctx.service.tenderTourist.setOtherTender(data.tidList, data.auditList);
  607. } else if (data.userType === 'schedule') {
  608. await ctx.service.scheduleAudit.setOtherTender(data.tidList, data.auditList);
  609. } else if (data.userType === 'contract') {
  610. await ctx.service.contractAudit.setOtherTender(data.tidList, data.auditList);
  611. } else if (data.userType === 'construction') {
  612. await ctx.service.constructionAudit.setOtherTender(data.tidList, data.auditList);
  613. } else if (data.userType === 'quality') {
  614. await ctx.service.tenderPermission.setOtherTender(data.tidList, data.auditList, ['quality']);
  615. } else {
  616. throw '参数有误';
  617. }
  618. break;
  619. case 'noSp-tenders':
  620. responseData.data = await ctx.service.tender.getNoSpTenders(projectId);
  621. break;
  622. case 'bind-sp':
  623. if (!data.spid || !data.tidList) {
  624. throw '参数有误';
  625. }
  626. if (data.tidList.split(',').length === 0) {
  627. throw '参数有误';
  628. }
  629. responseData.data = await ctx.service.tender.bindSp(projectId, data.spid, data.tidList.split(','));
  630. break;
  631. case 'get-category':
  632. responseData.data = await ctx.service.category.getAllCategory({ id: data.spid });
  633. break;
  634. default:
  635. throw '参数有误';
  636. }
  637. ctx.body = responseData;
  638. } catch (err) {
  639. ctx.log(err);
  640. ctx.body = { err: 1, msg: err.toString(), data: null };
  641. }
  642. }
  643. }
  644. return SettingController;
  645. };