payment_controller.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. 'use strict';
  2. const accountGroup = require('../const/account_group').group;
  3. module.exports = app => {
  4. class PaymentController extends app.BaseController {
  5. /**
  6. * 构造函数
  7. *
  8. * @param {Object} ctx - egg全局变量
  9. * @return {void}
  10. */
  11. constructor(ctx) {
  12. super(ctx);
  13. ctx.showProject = true;
  14. // ctx.showTitle = true;
  15. }
  16. /**
  17. * 支付审批列表页
  18. *
  19. * @param {Object} ctx - egg全局页面
  20. * @return {void}
  21. */
  22. async index(ctx) {
  23. try {
  24. const auditPermission = await this.ctx.service.paymentPermissionAudit.getOnePermission(ctx.session.sessionUser.is_admin, ctx.session.sessionUser.accountId);
  25. if (!auditPermission) {
  26. throw '权限不足';
  27. }
  28. // 列表读取及目录读取
  29. const renderData = {
  30. auditPermission,
  31. jsFiles: this.app.jsFiles.common.concat(this.app.jsFiles.payment.index),
  32. };
  33. if (ctx.session.sessionUser.is_admin) {
  34. const projectId = ctx.session.sessionProject.id;
  35. const permissionAudits = await ctx.service.paymentPermissionAudit.getList(projectId);
  36. // 获取所有项目参与者
  37. const accountList = await ctx.service.projectAccount.getAllDataByCondition({
  38. where: { project_id: ctx.session.sessionProject.id, enable: 1 },
  39. columns: ['id', 'name', 'company', 'role', 'enable', 'is_admin', 'account_group', 'mobile'],
  40. });
  41. const accountGroupList = accountGroup.map((item, idx) => {
  42. const groupList = accountList.filter(item => item.account_group === idx);
  43. return { groupName: item, groupList };
  44. });
  45. renderData.permissionAudits = permissionAudits;
  46. renderData.accountList = accountList;
  47. renderData.accountGroup = accountGroupList;
  48. }
  49. await this.layout('payment/index.ejs', renderData, 'payment/modal.ejs');
  50. } catch (err) {
  51. console.log(err);
  52. this.log(err);
  53. ctx.redirect(this.menu.menu.dashboard.url);
  54. }
  55. }
  56. async listLoad(ctx) {
  57. const responseData = {
  58. err: 0, msg: '', data: {},
  59. };
  60. // 先获取你创建的标段及参与的标段
  61. const tenderList = await ctx.service.paymentTender.getList(ctx.session.sessionUser.accountId);
  62. // 获取你创建的目录及对应目录下的所有目录
  63. const folderList = await ctx.service.paymentFolder.getList(ctx.session.sessionUser.accountId, tenderList);
  64. responseData.data.folderList = folderList;
  65. responseData.data.tenderList = tenderList;
  66. ctx.body = responseData;
  67. }
  68. async permissionSave(ctx) {
  69. try {
  70. if (ctx.session.sessionUser.is_admin === 0) throw '没有设置权限';
  71. const projectId = ctx.session.sessionProject.id;
  72. const responseData = {
  73. err: 0, msg: '', data: null,
  74. };
  75. const data = JSON.parse(ctx.request.body.data);
  76. if (!data.type) {
  77. throw '提交数据错误';
  78. }
  79. let uids;
  80. let result = false;
  81. let auditList = [];
  82. switch (data.type) {
  83. case 'add-audit':
  84. // 判断用户是单个还是数组
  85. uids = data.id instanceof Array ? data.id : [data.id];
  86. // 判断该用户的组是否已加入到表中,已加入则提示无需添加
  87. auditList = await ctx.service.paymentPermissionAudit.getAllDataByCondition({ where: { pid: projectId, uid: uids } });
  88. const addAidList = ctx.helper._.difference(uids, ctx.helper._.map(auditList, 'uid'));
  89. if (addAidList.length === 0) {
  90. throw '用户已存在权限中,无需重复添加';
  91. }
  92. const accountList = await ctx.service.projectAccount.getAllDataByCondition({ where: { id: addAidList } });
  93. await ctx.service.paymentPermissionAudit.saveAudits(projectId, accountList);
  94. responseData.data = await ctx.service.paymentPermissionAudit.getList(projectId);
  95. break;
  96. case 'del-audit':
  97. uids = data.id instanceof Array ? data.id : [data.id];
  98. auditList = await ctx.service.paymentPermissionAudit.getAllDataByCondition({ where: { id: uids } });
  99. if (auditList.length !== uids.length) {
  100. throw '该用户已不存在权限中,移除失败';
  101. }
  102. await ctx.service.paymentPermissionAudit.delAudit(uids);
  103. responseData.data = await ctx.service.paymentPermissionAudit.getList(projectId);
  104. break;
  105. case 'save-permission-one':
  106. result = await ctx.service.paymentPermissionAudit.updateOnePermission(data.updateData);
  107. if (!result) {
  108. throw '修改权限失败';
  109. }
  110. break;
  111. case 'save-permission-all':
  112. result = await ctx.service.paymentPermissionAudit.updateAllPermission(projectId, data.permission_type, data.value);
  113. if (!result) {
  114. throw '修改权限失败';
  115. }
  116. responseData.data = await ctx.service.paymentPermissionAudit.getList(projectId);
  117. break;
  118. default: throw '参数有误';
  119. }
  120. ctx.body = responseData;
  121. } catch (err) {
  122. this.log(err);
  123. ctx.body = { err: 1, msg: err.toString(), data: null };
  124. }
  125. }
  126. async save(ctx) {
  127. try {
  128. const projectId = ctx.session.sessionProject.id;
  129. const auditPermission = await this.ctx.service.paymentPermissionAudit.getOnePermission(ctx.session.sessionUser.is_admin, ctx.session.sessionUser.accountId);
  130. if (!auditPermission) {
  131. throw '权限不足';
  132. }
  133. const responseData = {
  134. err: 0, msg: '', data: {},
  135. };
  136. const data = JSON.parse(ctx.request.body.data);
  137. if (!data.type) {
  138. throw '提交数据错误';
  139. }
  140. let type = '';
  141. switch (data.type) {
  142. case 'add-folder':
  143. if (!auditPermission.folder) {
  144. throw '没有权限新建目录';
  145. }
  146. await ctx.service.paymentFolder.addFolder(projectId, ctx.session.sessionUser.accountId, data.parentId, data.name);
  147. break;
  148. case 'add-tender':
  149. if (!auditPermission.tender) {
  150. throw '没有权限新建标段';
  151. }
  152. await ctx.service.paymentTender.addTender(projectId, ctx.session.sessionUser.accountId, data.folderId, data.name);
  153. break;
  154. case 'edit-name':
  155. type = data.postData.type;
  156. const updateData = {
  157. name: data.postData.name,
  158. };
  159. const conditionData = {
  160. id: data.postData.id,
  161. };
  162. if (type === 'tender') {
  163. await ctx.service.paymentTender.update(updateData, conditionData);
  164. } else {
  165. await ctx.service.paymentFolder.update(updateData, conditionData);
  166. }
  167. break;
  168. case 'del':
  169. type = data.postData.type;
  170. if (type === 'tender') {
  171. await ctx.service.paymentTender.deleteTender(data.postData.id);
  172. } else {
  173. await ctx.service.paymentFolder.deleteFolder(data.postData.id);
  174. }
  175. break;
  176. default: throw '参数有误';
  177. }
  178. // 先获取你创建的标段及参与的标段
  179. const tenderList = await ctx.service.paymentTender.getList(ctx.session.sessionUser.accountId);
  180. // 获取你创建的目录及对应目录下的所有目录
  181. const folderList = await ctx.service.paymentFolder.getList(ctx.session.sessionUser.accountId, tenderList);
  182. responseData.data.folderList = folderList;
  183. responseData.data.tenderList = tenderList;
  184. ctx.body = responseData;
  185. } catch (err) {
  186. this.log(err);
  187. ctx.body = { err: 1, msg: err.toString(), data: null };
  188. }
  189. }
  190. /**
  191. * 支付表单页面
  192. *
  193. * @param {Object} ctx - egg全局页面
  194. * @return {void}
  195. */
  196. async detail(ctx) {
  197. try {
  198. const id = parseInt(ctx.params.id);
  199. if (!id) throw '参数错误';
  200. const info = await ctx.service.paymentDetail.getDataById(id);
  201. const rptTpl = await ctx.service.rptTpl.getDataById(3030);
  202. const pageRst = ctx.service.jpcReport.getAllPreviewPagesCommon(rptTpl, 'A4');
  203. const renderData = {
  204. info,
  205. pageRst,
  206. };
  207. await this.layout('payment/detail.ejs', renderData);
  208. } catch (err) {
  209. console.log(err);
  210. this.log(err);
  211. ctx.redirect(this.menu.menu.dashboard.url);
  212. }
  213. }
  214. async process(ctx) {
  215. try {
  216. const id = parseInt(ctx.params.pid);
  217. if (!id) throw '参数错误';
  218. const info = await ctx.service.paymentTender.getDataById(id);
  219. if (!info) throw '标段不存在';
  220. // 获取报表表单列表
  221. const rptProject = await ctx.service.rptTreeNode.getDataByCondition({ name: '01.支付审批报表' });
  222. const rptProjectList = rptProject.items ? JSON.parse(rptProject.items) : [];
  223. const rptTplList = [];
  224. if (rptProjectList.length > 0) {
  225. for (const rpt of rptProjectList) {
  226. const rptTpl = await ctx.service.rptTpl.getDataById(rpt.ID);
  227. // 根据模板ID获取报表JSON
  228. const pageRst = ctx.service.jpcReport.getAllPreviewPagesCommon(rptTpl, 'A4');
  229. rptTplList.push(pageRst.items[0]);
  230. }
  231. }
  232. const renderData = {
  233. info,
  234. jsFiles: this.app.jsFiles.common.concat(this.app.jsFiles.payment.process),
  235. rptProjectList,
  236. rptTplList,
  237. };
  238. await this.layout('payment/process.ejs', renderData, 'payment/process_modal.ejs');
  239. } catch (err) {
  240. console.log(err);
  241. this.log(err);
  242. ctx.redirect(this.menu.menu.dashboard.url);
  243. }
  244. }
  245. }
  246. return PaymentController;
  247. };