ledger_audit_controller.js 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Mai
  6. * @date 2018/5/28
  7. * @version
  8. */
  9. const auditConst = require('../const/audit').ledger;
  10. const shenpiConst = require('../const/shenpi');
  11. const measureType = require('../const/tender').measureType;
  12. const spreadSetting = require('../lib/spread_setting');
  13. const stdConst = require('../const/standard');
  14. module.exports = app => {
  15. class LedgerAuditController extends app.BaseController {
  16. /**
  17. * 构造函数
  18. *
  19. * @param {Object} ctx - egg全局context
  20. * @return {void}
  21. */
  22. constructor(ctx) {
  23. super(ctx);
  24. ctx.showProject = true;
  25. }
  26. /**
  27. * 新增审批人(Ajax)
  28. *
  29. * @param ctx
  30. * @return {Promise<void>}
  31. */
  32. async add(ctx) {
  33. const responseData = {
  34. err: 0,
  35. msg: '',
  36. data: [],
  37. };
  38. try {
  39. const data = JSON.parse(ctx.request.body.data);
  40. const id = data.auditorId;
  41. if (isNaN(id) || id <= 0) {
  42. throw '参数错误';
  43. }
  44. // 检查权限等
  45. if (ctx.tender.data.user_id !== ctx.session.sessionUser.accountId) {
  46. throw '您无权添加审核人';
  47. }
  48. if (ctx.tender.data.status === auditConst.status.checking || ctx.tender.data.status === auditConst.status.checked) {
  49. throw '当前不允许添加审核人';
  50. }
  51. // 检查审核人是否已存在
  52. const exist = await ctx.service.ledgerAudit.getAuditor(ctx.tender.id, id, ctx.tender.data.ledger_times);
  53. if (exist) {
  54. throw '该审核人已存在,请勿重复添加';
  55. }
  56. const shenpiInfo = await ctx.service.shenpiAudit.getDataByCondition({ tid: ctx.tender.id, sp_type: shenpiConst.sp_type.ledger, sp_status: shenpiConst.sp_status.gdzs });
  57. const is_gdzs = shenpiInfo && ctx.tender.info.shenpi.ledger === shenpiConst.sp_status.gdzs ? 1 : 0;
  58. const result = await ctx.service.ledgerAudit.addAuditor(ctx.tender.id, id, ctx.tender.data.ledger_times, is_gdzs);
  59. if (!result) {
  60. throw '添加审核人失败';
  61. }
  62. responseData.data = await ctx.service.ledgerAudit.getUserGroup(ctx.tender.id, ctx.tender.data.ledger_times);
  63. } catch (err) {
  64. responseData.err = 1;
  65. responseData.msg = err.toString();
  66. }
  67. ctx.body = responseData;
  68. }
  69. /**
  70. * 移除审批人(Ajax)
  71. *
  72. * @param ctx
  73. * @return {Promise<void>}
  74. */
  75. async remove(ctx) {
  76. const responseData = {
  77. err: 0,
  78. msg: '',
  79. data: [],
  80. };
  81. try {
  82. const data = JSON.parse(ctx.request.body.data);
  83. const id = data.auditorId instanceof Number ? data.auditorId : this.app._.toNumber(data.auditorId);
  84. if (isNaN(id) || id <= 0) {
  85. throw '参数错误';
  86. }
  87. const result = await ctx.service.ledgerAudit.deleteAuditor(ctx.tender.id, id, ctx.tender.data.ledger_times);
  88. if (!result) {
  89. throw '移除审核人失败';
  90. }
  91. responseData.data = await ctx.service.ledgerAudit.getAuditors(ctx.tender.id, ctx.tender.data.ledger_times);
  92. } catch (err) {
  93. responseData.err = 1;
  94. responseData.msg = err.toString();
  95. }
  96. ctx.body = responseData;
  97. }
  98. /**
  99. * 上报(post)
  100. *
  101. * @param ctx
  102. * @return {Promise<void>}
  103. */
  104. async start(ctx) {
  105. try {
  106. if (!ctx.tender.data || ctx.tender.data.ledger_status === auditConst.status.checking || ctx.tender.data.ledger_status === auditConst.status.checked) {
  107. throw '标段数据有误';
  108. }
  109. if (ctx.tender.data.user_id !== ctx.session.sessionUser.accountId) {
  110. throw '上报失败';
  111. }
  112. await ctx.service.ledgerAudit.start(ctx.tender.id, ctx.tender.data.ledger_times);
  113. ctx.body = { err: 0, msg: '', data: { url: '/tender/' + ctx.tender.id + '/ledger' } };
  114. } catch (err) {
  115. this.log(err);
  116. ctx.session.postError = err.toString();
  117. ctx.body = this.ajaxErrorBody(err, '上报失败,请刷新页面重试');
  118. }
  119. }
  120. /**
  121. * 审批(post)
  122. *
  123. * @param ctx
  124. * @return {Promise<void>}
  125. */
  126. async check(ctx) {
  127. try {
  128. const tender = ctx.tender;
  129. if (!tender.data || tender.data.ledger_status !== auditConst.status.checking) {
  130. throw '当前标段数据有误';
  131. }
  132. const curAudits = await ctx.service.ledgerAudit.getCurAuditors(tender.id, tender.data.ledger_times);
  133. const curAuditIds = curAudits.map(x => { return x.audit_id; });
  134. if (curAuditIds.indexOf(ctx.session.sessionUser.accountId) < 0) {
  135. throw '审批失败';
  136. }
  137. const checkType = parseInt(ctx.request.body.checkType);
  138. if (!checkType || isNaN(checkType)) {
  139. throw '提交数据错误';
  140. }
  141. await ctx.service.ledgerAudit.check(tender.id, checkType, ctx.request.body.opinion, tender.data.ledger_times);
  142. ctx.redirect('/tender/' + ctx.tender.id + '/ledger');
  143. } catch (err) {
  144. this.log(err);
  145. ctx.session.postError = err.toString();
  146. ctx.redirect(ctx.request.header.referer);
  147. }
  148. }
  149. /**
  150. * 重新审批(post)
  151. *
  152. * @param ctx
  153. * @return {Promise<void>}
  154. */
  155. async checkAgain(ctx) {
  156. try {
  157. const tender = ctx.tender;
  158. if (!tender.data || tender.data.ledger_status !== auditConst.status.checked) {
  159. throw '当前标段数据有误';
  160. }
  161. const revise = await this.ctx.service.ledgerRevise.getLastestRevise(tender.id);
  162. if (revise) throw '当前标段存在台账修订,不可重新审批';
  163. const stage = await this.ctx.service.stage.getDataByCondition({ tid: tender.id });
  164. if (stage) throw '当前标段已开始计量,不可重新审批';
  165. await ctx.service.ledgerAudit.checkAgain(tender.id, tender.data.ledger_times);
  166. ctx.redirect('/tender/' + ctx.tender.id + '/ledger');
  167. } catch (err) {
  168. this.log(err);
  169. ctx.session.postError = err.toString();
  170. ctx.redirect(ctx.request.header.referer);
  171. }
  172. }
  173. async saveAudit(ctx) {
  174. try {
  175. const data = JSON.parse(ctx.request.body.data);
  176. if (ctx.session.sessionUser.is_admin && ctx.tender.ledger_status !== auditConst.status.checked) {
  177. await ctx.service.ledgerAudit.saveAudit(ctx.tender.id, ctx.tender.data.ledger_times, 0, data);
  178. const auditorUniqs = await ctx.service.ledgerAudit.getUniqUserGroup(ctx.tender.id, ctx.tender.data.ledger_times);
  179. const auditors = await ctx.service.ledgerAudit.getAuditors(ctx.tender.id, ctx.tender.data.ledger_times);
  180. ctx.body = { err: 0, msg: '', data: { auditorUniqs, auditors } };
  181. } else {
  182. throw '您无权进行该操作';
  183. }
  184. } catch (err) {
  185. this.log(err);
  186. // ctx.session.postError = err.toString();
  187. // ctx.redirect(ctx.request.header.referer);
  188. ctx.body = {
  189. err: 1,
  190. // url: ctx.request.header.referer,
  191. msg: err,
  192. };
  193. }
  194. }
  195. }
  196. return LedgerAuditController;
  197. };