payment_controller.js 12 KB

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