sub_proj_controller.js 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Mai
  6. * @date
  7. * @version
  8. */
  9. const auditConst = require('../const/audit');
  10. const accountGroup = require('../const/account_group').group;
  11. const sendToWormhole = require('stream-wormhole');
  12. const path = require('path');
  13. const projectSetting = require('../const/project_setting');
  14. module.exports = app => {
  15. class SubProjController extends app.BaseController {
  16. async _loadCount(projectList){
  17. for (const p of projectList) {
  18. p.tender_count = await this.ctx.service.tender.count({ spid: p.id });
  19. p.contract_count = await this.ctx.service.contract.count({ spid: p.id });
  20. p.file_count = await this.ctx.service.file.count({ spid: p.id, is_deleted: 0 });
  21. }
  22. }
  23. /**
  24. * 概算投资
  25. *
  26. * @param ctx
  27. * @returns {Promise<void>}
  28. */
  29. async index(ctx) {
  30. try {
  31. const renderData = {
  32. jsFiles: this.app.jsFiles.common.concat(this.app.jsFiles.subProject.list),
  33. auditConst,
  34. };
  35. renderData.budgetStd = await ctx.service.budgetStd.getDataByProjectId(ctx.session.sessionProject.id);
  36. renderData.projectList = await ctx.service.subProject.getSubProject(ctx.session.sessionProject.id, ctx.session.sessionUser.accountId, ctx.session.sessionUser.is_admin);
  37. await this._loadCount(renderData.projectList);
  38. renderData.tenderList = await ctx.service.tender.getManageTenderList(ctx.session.sessionProject.id);
  39. const accountList = await ctx.service.projectAccount.getAllDataByCondition({
  40. columns: ['id', 'name', 'company', 'role', 'enable', 'is_admin', 'account_group', 'mobile'],
  41. where: { project_id: ctx.session.sessionProject.id }
  42. });
  43. renderData.accountList = accountList;
  44. const unitList = await ctx.service.constructionUnit.getAllDataByCondition({ where: { pid: ctx.session.sessionProject.id } });
  45. renderData.accountGroup = unitList.map(item => {
  46. const groupList = accountList.filter(item1 => item1.company === item.name);
  47. return { groupName: item.name, groupList };
  48. }).filter(x => { return x.groupList.length > 0; });
  49. renderData.permissionConst = ctx.service.subProjPermission.PermissionConst;
  50. renderData.companys = await this.ctx.service.constructionUnit.getAllDataByCondition({ where: { pid: ctx.session.sessionProject.id } });
  51. renderData.templates = await this.ctx.service.filingTemplateList.getAllTemplate(ctx.session.sessionProject.id);
  52. await this.layout('sub_proj/index.ejs', renderData, 'sub_proj/modal.ejs');
  53. } catch (err) {
  54. ctx.log(err);
  55. ctx.session.postError = err.toString();
  56. ctx.redirect(this.menu.menu.dashboard.url);
  57. }
  58. }
  59. async addFolder(ctx) {
  60. try {
  61. const data = JSON.parse(ctx.request.body.data);
  62. if (!data.name || data.name.length > 100) throw '文件夹名称有误';
  63. const result = await ctx.service.subProject.addFolder(data);
  64. await this._loadCount(result);
  65. ctx.body = { err: 0, msg: '', data: result };
  66. } catch (err) {
  67. ctx.log(err);
  68. ctx.ajaxErrorBody(err, '新建文件夹失败');
  69. }
  70. }
  71. async addProj(ctx) {
  72. try {
  73. const data = JSON.parse(ctx.request.body.data);
  74. if (!data.name || data.name.length > 100) throw '项目名称有误';
  75. const result = await ctx.service.subProject.addSubProject(data);
  76. await this._loadCount(result);
  77. ctx.body = { err: 0, msg: '', data: result };
  78. } catch (err) {
  79. ctx.log(err);
  80. ctx.ajaxErrorBody(err, '新建项目失败');
  81. }
  82. }
  83. async dragTo(ctx) {
  84. try {
  85. const data = JSON.parse(ctx.request.body.data);
  86. if (!data.drag_id || !data.drop_id) throw '提交数据错误';
  87. const result = await ctx.service.subProject.dragTo(data);
  88. await this._loadCount(result);
  89. ctx.body = { err: 0, msg: '', data: result };
  90. } catch (err) {
  91. ctx.log(err);
  92. ctx.ajaxErrorBody(err, '调整所属文件夹失败');
  93. }
  94. }
  95. async move(ctx) {
  96. try {
  97. const data = JSON.parse(ctx.request.body.data);
  98. if (!data.id || !data.type) throw '提交数据错误';
  99. const result = await ctx.service.subProject.move(data);
  100. await this._loadCount(result);
  101. ctx.body = { err: 0, msg: '', data: result };
  102. } catch (err) {
  103. ctx.log(err);
  104. ctx.ajaxErrorBody(err, '调整所属文件夹失败');
  105. }
  106. }
  107. async del(ctx) {
  108. try {
  109. const data = JSON.parse(ctx.request.body.data);
  110. if (!data.id) throw '参数有误';
  111. const result = await ctx.service.subProject.del(data.id);
  112. await this._loadCount(result);
  113. ctx.body = { err: 0, msg: '', data: result };
  114. } catch(err) {
  115. ctx.log(err);
  116. ctx.ajaxErrorBody(err, '删除项目失败');
  117. }
  118. }
  119. async save(ctx) {
  120. try {
  121. const data = JSON.parse(ctx.request.body.data);
  122. if (!data.id) throw '参数有误';
  123. let result = null;
  124. if (data.name !== undefined) {
  125. if (!data.name || data.name.length > 100) throw '项目名称有误';
  126. result = await ctx.service.subProject.save({ id: data.id, name: data.name });
  127. } else if (data.rela_tender !== undefined) {
  128. result = await ctx.service.subProject.setRelaTender({ id: data.id, rela_tender: data.rela_tender });
  129. } else if (data.std_id !== undefined) {
  130. result = await ctx.service.subProject.setBudgetStd({ id: data.id, std_id: data.std_id });
  131. } else if (data.management !== undefined) {
  132. result = await ctx.service.subProject.setManagement({ id: data.id, management: data.management, filingTemplate: data.filingTemplate });
  133. }
  134. ctx.body = { err: 0, msg: '', data: { update: [result] } };
  135. } catch(err) {
  136. ctx.log(err);
  137. ctx.ajaxErrorBody(err, '保存数据失败');
  138. }
  139. }
  140. async refresh(ctx) {
  141. try {
  142. const data = JSON.parse(ctx.request.body.data);
  143. if (!data.id) throw '参数有误';
  144. const result = await ctx.service.subProject.refreshManagementPermission({ id: data.id });
  145. ctx.body = { err: 0, msg: '', data: result };
  146. } catch(err) {
  147. ctx.log(err);
  148. ctx.ajaxErrorBody(err, '保存数据失败');
  149. }
  150. }
  151. async rela(ctx) {
  152. try {
  153. const id = ctx.query.id;
  154. const projectList = await ctx.service.subProject.getSubProject(this.ctx.session.sessionProject.id, this.ctx.session.sessionUser.accountId, true);
  155. const otherProj = projectList.filter(x => { return x.id !== id || !x.rela_tender || x.is_folder });
  156. const _ = ctx.helper._;
  157. const otherRela = _.map(_.map(otherProj, 'rela_tender').join(',').split(','), _.toInteger);
  158. const tenderList = await ctx.service.tender.getList4Select('stage');
  159. ctx.body = {
  160. err: 0,
  161. msg: '',
  162. data: tenderList.filter(x => { return otherRela.indexOf(x.id) === -1})
  163. .map(y => { return {id: y.id, name: y.name, lastStageOrder: y.lastStage.order, lastStageStatus: auditConst.stage.statusString[y.lastStage.status], category: y.category}}),
  164. };
  165. } catch (err) {
  166. ctx.log(err);
  167. ctx.postError(err, '获取数据失败');
  168. }
  169. }
  170. async saveRela(ctx) {
  171. try {
  172. const data = JSON.parse(ctx.request.body.data);
  173. if (!data.id || data.rela_tender === undefined) throw '参数有误';
  174. const permission = ctx.session.sessionUser.is_admin
  175. ? ctx.service.subProjPermission.adminPermission
  176. : await ctx.service.subProjPermission.getSubProjectUserPermission(data.id, ctx.session.sessionUser.accountId);
  177. if (!permission || permission.manage_permission.indexOf(ctx.service.subProjPermission.PermissionConst.manage.rela.value) < 0) throw '您无权进行该操作';
  178. const result = await ctx.service.subProject.setRelaTender({ id: data.id, rela_tender: data.rela_tender || '' });
  179. ctx.body = { err: 0, msg: '', data: { update: [result] } };
  180. } catch(err) {
  181. ctx.log(err);
  182. ctx.ajaxErrorBody(err, '保存数据失败');
  183. }
  184. }
  185. async member(ctx) {
  186. try {
  187. const data = JSON.parse(ctx.request.body.data);
  188. const member = await ctx.service.subProjPermission.getPermission(data.id);
  189. ctx.body = { err: 0, msg: '', data: member };
  190. } catch (err) {
  191. ctx.log(err);
  192. ctx.ajaxErrorBody(err, '查询项目成员失败');
  193. }
  194. }
  195. async memberSave(ctx) {
  196. try {
  197. const data = JSON.parse(ctx.request.body.data);
  198. if (!data.id) throw '参数有误';
  199. await ctx.service.subProjPermission.savePermission(data.id, data.member);
  200. ctx.body = { err: 0, msg: '', data: '' };
  201. } catch (err) {
  202. ctx.log(err);
  203. ctx.ajaxErrorBody(err, '保存数据失败');
  204. }
  205. }
  206. _checkInfoEditPermission() {
  207. if (this.ctx.subProject.permission.info_permission.indexOf(this.ctx.service.subProjPermission.PermissionConst.info.edit.value) < 0) {
  208. throw '暂无权编辑项目概况信息';
  209. }
  210. }
  211. async info(ctx) {
  212. try {
  213. const info = await this.ctx.service.subProjInfo.getInfo(ctx.subProject.id);
  214. info.lx_tp = await this.ctx.service.budgetGu.getSumTp(ctx.subProject.budget_id);
  215. if (info.lx_tp_unit === '万元') info.lx_tp = this.ctx.helper.div(info.lx_tp, 10000, 6);
  216. info.cb_tp = await this.ctx.service.budgetGai.getSumTp(ctx.subProject.budget_id);
  217. if (info.cb_tp_unit === '万元') info.cb_tp = this.ctx.helper.div(info.cb_tp, 10000, 6);
  218. info.sgt_tp = await this.ctx.service.budgetYu.getSumTp(ctx.subProject.budget_id);
  219. if (info.sgt_tp_unit === '万元') info.sgt_tp = this.ctx.helper.div(info.sgt_tp, 10000, 6);
  220. info.zbys_tp = await this.ctx.service.budgetZb.getSumTp(ctx.subProject.budget_id);
  221. if (info.zbys_tp_unit === '万元') info.zbys_tp = this.ctx.helper.div(info.zbys_tp, 10000, 6);
  222. info.kzmb_tp = await this.ctx.service.budgetCtrl.getSumTp(ctx.subProject.budget_id);
  223. if (info.kzmb_tp_unit === '万元') info.kzmb_tp = this.ctx.helper.div(info.kzmb_tp, 10000, 6);
  224. const renderData = {
  225. info,
  226. jsFiles: this.app.jsFiles.common.concat(this.app.jsFiles.subProject.info),
  227. readOnly: ctx.subProject.permission.info_permission.indexOf(ctx.service.subProjPermission.PermissionConst.info.edit.value) < 0,
  228. };
  229. await this.layout('sub_proj/info.ejs', renderData);
  230. } catch (err) {
  231. ctx.log(err);
  232. }
  233. }
  234. async dataIndex(ctx) {
  235. try {
  236. const info = await this.ctx.service.subProjInfo.getInfo(ctx.subProject.id);
  237. const renderData = {
  238. info,
  239. jsFiles: this.app.jsFiles.common.concat(this.app.jsFiles.subProject.data),
  240. readOnly: ctx.subProject.permission.info_permission.indexOf(ctx.service.subProjPermission.PermissionConst.info.edit.value) < 0,
  241. };
  242. await this.layout('sub_proj/data_index.ejs', renderData);
  243. } catch (err) {
  244. ctx.log(err);
  245. }
  246. }
  247. async saveInfo(ctx) {
  248. try {
  249. this._checkInfoEditPermission();
  250. const data = JSON.parse(ctx.request.body.data);
  251. const result = await ctx.service.subProjInfo.saveInfo(ctx.subProject.id, data);
  252. ctx.body = { err: 0, msg: '', data: result };
  253. } catch(err) {
  254. ctx.log(err);
  255. }
  256. }
  257. async progress(ctx) {
  258. try {
  259. const fileReferenceList = await ctx.service.subProject.getFileReference(ctx.subProject, ctx.service.subProject.FileReferenceType.info_progress);
  260. const renderData = {
  261. jsFiles: this.app.jsFiles.common.concat(this.app.jsFiles.subProject.progress),
  262. fileReferenceList,
  263. readOnly: ctx.subProject.permission.info_permission.indexOf(ctx.service.subProjPermission.PermissionConst.info.edit.value) < 0,
  264. };
  265. await this.layout('sub_proj/progress.ejs', renderData, 'sub_proj/progress_modal.ejs');
  266. } catch (err) {
  267. ctx.log(err);
  268. ctx.postError(err, '查看阶段进度')
  269. }
  270. }
  271. async load(ctx) {
  272. try {
  273. const data = JSON.parse(ctx.request.body.data);
  274. const filter = data.filter.split(';');
  275. const result = {};
  276. for (const f of filter) {
  277. switch(f) {
  278. case 'progress':
  279. result[f] = await ctx.service.subProjProgress.getData(ctx.subProject);
  280. break;
  281. case 'progress_file':
  282. result[f] = await ctx.service.subProjFile.getData(ctx.subProject.id, 'progress');
  283. break;
  284. case 'push':
  285. result[f] = await ctx.service.subProjPush.getData(ctx.subProject.id);
  286. break;
  287. case 'push_file':
  288. result[f] = await ctx.service.subProjFile.getData(ctx.subProject.id, 'push');
  289. break;
  290. default:
  291. continue;
  292. }
  293. }
  294. ctx.body = { err: 0, msg: '', data: result };
  295. } catch(err) {
  296. ctx.log(err);
  297. ctx.ajaxErrorBody(err, '获取阶段进度数据有误');
  298. }
  299. }
  300. async _progressBase(subProj, type, data) {
  301. if (isNaN(data.id) || data.id <= 0) throw '数据错误';
  302. if (type !== 'add') {
  303. if (isNaN(data.count) || data.count <= 0) data.count = 1;
  304. }
  305. switch (type) {
  306. case 'add':
  307. return await this.ctx.service.subProjProgress.addProgressNode(subProj.id, data.id, data.count);
  308. case 'delete':
  309. return await this.ctx.service.subProjProgress.delete(subProj.id, data.id, data.count);
  310. case 'up-move':
  311. return await this.ctx.service.subProjProgress.upMoveNode(subProj.id, data.id, data.count);
  312. case 'down-move':
  313. return await this.ctx.service.subProjProgress.downMoveNode(subProj.id, data.id, data.count);
  314. case 'up-level':
  315. return await this.ctx.service.subProjProgress.upLevelNode(subProj.id, data.id, data.count);
  316. case 'down-level':
  317. return await this.ctx.service.subProjProgress.downLevelNode(subProj.id, data.id, data.count);
  318. }
  319. }
  320. async progressUpdate(ctx) {
  321. try {
  322. this._checkInfoEditPermission();
  323. const data = JSON.parse(ctx.request.body.data);
  324. if (!data.postType || !data.postData) throw '数据错误';
  325. const responseData = { err: 0, msg: '', data: {} };
  326. switch (data.postType) {
  327. case 'add':
  328. case 'delete':
  329. case 'up-move':
  330. case 'down-move':
  331. case 'up-level':
  332. case 'down-level':
  333. responseData.data = await this._progressBase(ctx.subProject, data.postType, data.postData);
  334. break;
  335. case 'update':
  336. responseData.data = await this.ctx.service.subProjProgress.updateInfos(ctx.subProject.id, data.postData);
  337. break;
  338. case 'add-std':
  339. responseData.data = await this.ctx.service.subProjProgress.addStdNode(ctx.subProject, data.postData.id, data.postData.stdData);
  340. break;
  341. default:
  342. throw '未知操作';
  343. }
  344. ctx.body = responseData;
  345. } catch (err) {
  346. ctx.log(err);
  347. ctx.body = this.ajaxErrorBody(err, '数据错误');
  348. }
  349. }
  350. async push(ctx) {
  351. try {
  352. const renderData = {
  353. jsFiles: this.app.jsFiles.common.concat(this.app.jsFiles.subProject.push),
  354. readOnly: ctx.subProject.permission.info_permission.indexOf(ctx.service.subProjPermission.PermissionConst.info.edit.value) < 0,
  355. };
  356. await this.layout('sub_proj/push.ejs', renderData, 'sub_proj/push_modal.ejs');
  357. } catch (err) {
  358. ctx.log(err);
  359. }
  360. }
  361. async pushUpdate(ctx) {
  362. try {
  363. this._checkInfoEditPermission();
  364. const data = JSON.parse(ctx.request.body.data);
  365. const result = await ctx.service.subProjPush.updateDatas(data);
  366. ctx.body = { err: 0, msg: '', data: result };
  367. } catch (error) {
  368. ctx.log(error);
  369. ctx.body = this.ajaxErrorBody(error, '提交数据失败,请重试');
  370. }
  371. }
  372. /**
  373. * 上传附件
  374. * @param {Object} ctx - egg全局变量
  375. * @return {void}
  376. */
  377. async uploadFile(ctx) {
  378. let stream;
  379. try {
  380. const parts = ctx.multipart({autoFields: true});
  381. let index = 0;
  382. const create_time = Date.parse(new Date()) / 1000;
  383. let stream = await parts();
  384. const user = await ctx.service.projectAccount.getDataById(ctx.session.sessionUser.accountId);
  385. const rela_id = parts.field.rela_id;
  386. const uploadfiles = [];
  387. while (stream !== undefined) {
  388. if (!stream.filename) throw '未发现上传文件!';
  389. const fileInfo = path.parse(stream.filename);
  390. const filepath = `sp/progress/${ctx.subProject.id}/${ctx.moment().format('YYYYMMDD')}/${create_time + '_' + index + fileInfo.ext}`;
  391. // 保存文件
  392. await ctx.app.fujianOss.put(ctx.app.config.fujianOssFolder + filepath, stream);
  393. await sendToWormhole(stream);
  394. // 插入到stage_pay对应的附件列表中
  395. uploadfiles.push({
  396. rela_id,
  397. filename: fileInfo.name,
  398. fileext: fileInfo.ext,
  399. filesize: Array.isArray(parts.field.size) ? parts.field.size[index] : parts.field.size,
  400. filepath,
  401. });
  402. ++index;
  403. if (Array.isArray(parts.field.size) && index < parts.field.size.length) {
  404. stream = await parts();
  405. } else {
  406. stream = undefined;
  407. }
  408. }
  409. const result = await ctx.service.subProjFile.addFiles(ctx.subProject.id, ctx.request.url.split('/')[3], uploadfiles, user);
  410. ctx.body = {err: 0, msg: '', data: result};
  411. } catch (error) {
  412. ctx.log(error);
  413. // 失败需要消耗掉stream 以防卡死
  414. if (stream) await sendToWormhole(stream);
  415. ctx.body = this.ajaxErrorBody(error, '上传附件失败,请重试');
  416. }
  417. }
  418. async uploadBigFile(ctx) {
  419. try {
  420. const data = JSON.parse(ctx.request.body.data);
  421. if (!data.type || !data.rela_id || !data.fileInfo) throw '缺少参数';
  422. let result;
  423. const fileInfo = path.parse(data.fileInfo.filename);
  424. switch(data.type) {
  425. case 'begin':
  426. const create_time = Date.parse(new Date()) / 1000;
  427. result = {
  428. filename: `sp/progress/${ctx.subProject.id}/${ctx.moment().format('YYYYMMDD')}/${create_time + '_' + fileInfo.ext}`,
  429. };
  430. result.filepath = ctx.app.config.fujianOssFolder + result.filename;
  431. result.oss = await ctx.helper.getOssToken(ctx.app.fujianOss);
  432. break;
  433. case 'end':
  434. const user = await ctx.service.projectAccount.getDataById(ctx.session.sessionUser.accountId);
  435. const uploadFiles = [{
  436. filepath: data.filepath, rela_id: data.rela_id,
  437. filename: fileInfo.name, fileext: fileInfo.ext, filesize: data.fileInfo.filesize,
  438. }];
  439. result = await ctx.service.subProjFile.addFiles(ctx.subProject.id, ctx.request.url.split('/')[3], uploadFiles, user);
  440. break;
  441. }
  442. ctx.body = {err: 0, msg: '', data: result };
  443. } catch (error) {
  444. ctx.log(error);
  445. ctx.body = this.ajaxErrorBody(error, '上传附件失败,请重试');
  446. }
  447. }
  448. async deleteFile(ctx) {
  449. try{
  450. const data = JSON.parse(ctx.request.body.data);
  451. if (!data) throw '缺少参数';
  452. const result = await ctx.service.subProjFile.delFiles(data.id);
  453. ctx.body = { err: 0, msg: '', data: result };
  454. } catch(error) {
  455. ctx.log(error);
  456. ctx.ajaxErrorBody(error, '删除附件失败');
  457. }
  458. }
  459. async moveFile(ctx) {
  460. try {
  461. const data = JSON.parse(ctx.request.body.data);
  462. if (!data.id || !data.rela_id) throw '缺少参数';
  463. const result = await ctx.service.subProjFile.moveFile(data.id, data.rela_id);
  464. ctx.body = { err: 0, msg: '', data: result };
  465. } catch (error) {
  466. this.log(error);
  467. ctx.ajaxErrorBody(error, '编辑附件失败');
  468. }
  469. }
  470. async saveFile(ctx) {
  471. try {
  472. const data = JSON.parse(ctx.request.body.data);
  473. if (!data.id || !data.filename) throw '缺少参数';
  474. const result = await ctx.service.subProjFile.saveFile(data.id, data.filename);
  475. ctx.body = { err: 0, msg: '', data: result };
  476. } catch (error) {
  477. this.log(error);
  478. ctx.ajaxErrorBody(error, '编辑附件失败');
  479. }
  480. }
  481. async noPermission(ctx) {
  482. ctx.controllerName = ctx.params.block;
  483. await this.layout('sub_proj/no_permission.ejs');
  484. }
  485. /**
  486. * 保存列设置
  487. * @param ctx
  488. * @returns {Promise<void>}
  489. */
  490. async colSet(ctx) {
  491. try {
  492. const colType = ctx.request.body.col_type;
  493. const colSet = JSON.parse(ctx.request.body.col_set);
  494. await ctx.service.projectColSet.setProjectColSet(ctx.session.sessionProject.id, ctx.subProject ? ctx.subProject.id : '', colType, colSet);
  495. ctx.redirect(ctx.request.header.referer);
  496. } catch (err) {
  497. ctx.log(err);
  498. ctx.redirect(ctx.request.header.referer);
  499. }
  500. }
  501. async templateSet(ctx) {
  502. try {
  503. const data = JSON.parse(ctx.request.body.data);
  504. const updateData = { id: ctx.subProject.id };
  505. if (data.cost_ledger_template !== undefined) updateData.cost_ledger_template = data.cost_ledger_template;
  506. if (data.cost_analysis_template !== undefined) updateData.cost_analysis_template = data.cost_analysis_template;
  507. if (data.cost_calc_template !== undefined) updateData.cost_calc_template = data.cost_calc_template;
  508. await ctx.service.subProject.defaultUpdate(updateData);
  509. ctx.body = { err: 0, msg: '', data: null };
  510. } catch(err) {
  511. ctx.log(err);
  512. ctx.ajaxErrorBody(err, '保存模板设置失败');
  513. }
  514. }
  515. async listInfo(ctx) {
  516. try {
  517. const renderData = {
  518. jsFiles: this.app.jsFiles.common.concat(this.app.jsFiles.subProject.listInfo),
  519. };
  520. const projectColSet = await ctx.service.projectColSet.getProjectColSet(ctx.session.sessionProject.id);
  521. renderData.colSet = ctx.service.projectColSet.analysisColSetWithDefine(projectSetting.colSet.projectInfo, projectColSet.info, projectSetting.defaultProjectColSet.info);
  522. renderData.projectList = await ctx.service.subProject.getSubProject(ctx.session.sessionProject.id, ctx.session.sessionUser.accountId, ctx.session.sessionUser.is_admin);
  523. await this._loadCount(renderData.projectList);
  524. await this.layout('sub_proj/list_info.ejs', renderData, 'sub_proj/list_info_modal.ejs');
  525. } catch (err) {
  526. ctx.log(err);
  527. ctx.postError(err, '加载金额概况数据错误');
  528. ctx.redirect(this.menu.menu.dashboard.url);
  529. }
  530. }
  531. async refreshInfoCache(ctx) {
  532. try {
  533. const data = JSON.parse(ctx.request.body.data);
  534. if (!data.spid) throw '参数错误';
  535. const subProjectId = data.spid.split(';');
  536. const result = [];
  537. for (const spid of subProjectId ) {
  538. const tp_cache = await ctx.service.subProject.refreshTpCache(spid, ctx.session.sessionUser.accountId, ctx.session.sessionUser.is_admin);
  539. result.push({ id: spid, tp_cache });
  540. }
  541. ctx.body = { err: 0, msg: '', data: result };
  542. } catch(err) {
  543. ctx.log(err);
  544. ctx.ajaxErrorBody(err, '刷新金额概况数据失败');
  545. }
  546. }
  547. }
  548. return SubProjController;
  549. };