tender_controller.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350
  1. 'use strict';
  2. /**
  3. * 标段管理控制器
  4. *
  5. * @author CaiAoLin
  6. * @date 2018/2/5
  7. * @version
  8. */
  9. const tenderConst = require('../const/tender');
  10. const codeRuleConst = require('../const/code_rule');
  11. const settingConst = require('../const/setting.js');
  12. const tenderMenu = require('../../config/menu').tenderMenu;
  13. module.exports = app => {
  14. class TenderController extends app.BaseController {
  15. /**
  16. * 构造函数
  17. *
  18. * @param {Object} ctx - egg全局变量
  19. * @return {void}
  20. */
  21. constructor(ctx) {
  22. super(ctx);
  23. ctx.showProject = true;
  24. ctx.showTitle = true;
  25. }
  26. async _list(view, setting, modal = '') {
  27. try {
  28. const tenderList = await this.ctx.service.tender.getList();
  29. const categoryData = await this.ctx.service.category.getAllCategory(this.ctx.session.sessionProject.id);
  30. const renderData = {
  31. tenderList,
  32. tenderConst,
  33. settingConst,
  34. categoryData,
  35. tableColSetting: setting,
  36. measureType: tenderConst.measureType,
  37. jsFiles: this.app.jsFiles.common.concat(this.app.jsFiles.tender.list),
  38. };
  39. await this.layout(view, renderData, modal);
  40. } catch (err) {
  41. this.log(err);
  42. this.ctx.redirect('/dashboard');
  43. }
  44. }
  45. /**
  46. * 标段概况(Get)
  47. *
  48. * @param {object} ctx - egg全局变量
  49. * @return {void}
  50. */
  51. async listInfo(ctx) {
  52. await this._list('tender/index.ejs', tenderConst.infoTableCol, 'tender/modal.ejs');
  53. }
  54. /**
  55. * 计量进度(Get)
  56. *
  57. * @param ctx
  58. * @return {Promise<void>}
  59. */
  60. async listProgress(ctx) {
  61. await this._list('tender/progress.ejs', tenderConst.progressTableCol);
  62. }
  63. /**
  64. * 标段管理(Get)
  65. *
  66. * @param ctx
  67. * @return {Promise<void>}
  68. */
  69. async listManage(ctx) {
  70. await this._list('tender/manage.ejs', tenderConst.manageTableCol, 'tender/manage_modal.ejs');
  71. }
  72. /**
  73. * 新增标段(Ajax)
  74. *
  75. * @param ctx
  76. * @return {Promise<void>}
  77. */
  78. async addTender(ctx) {
  79. try {
  80. const responseData = {
  81. err: 0, msg: '', data: null,
  82. };
  83. const data = JSON.parse(ctx.request.body.data);
  84. if (!data.name || data.name === '') {
  85. throw '标段信息不完整';
  86. }
  87. responseData.data = await ctx.service.tender.add(data);
  88. ctx.body = responseData;
  89. } catch (error) {
  90. this.log(error);
  91. ctx.body = { err: 1, msg: error.toString(), data: null };
  92. }
  93. }
  94. /**
  95. * 编辑标段(Ajax)
  96. *
  97. * @param ctx
  98. * @return {Promise<void>}
  99. */
  100. async updateTender(ctx) {
  101. }
  102. /**
  103. * 删除标段(Ajax)
  104. *
  105. * @param ctx
  106. * @return {Promise<void>}
  107. */
  108. async deleteTender(ctx) {
  109. try {
  110. const data = JSON.parse(ctx.request.body.data), result = [];
  111. if (!(data instanceof Array) && (data.length === 0)) {
  112. throw '提交数据有误';
  113. }
  114. for (const id of data) {
  115. if (await ctx.service.tender.deleteTenderNoBackup(id)) {
  116. result.push(id);
  117. }
  118. }
  119. ctx.body = {err: 0, msg: '', data: result};
  120. } catch (err) {
  121. ctx.body = {err: 1, msg: err.toString(), data: []}
  122. }
  123. }
  124. /**
  125. * 标段概况(Get)
  126. *
  127. * @param ctx
  128. * @return {Promise<void>}
  129. */
  130. async tenderInfo(ctx) {
  131. try {
  132. const renderData = {
  133. tender: ctx.tender.data,
  134. tenderInfo: ctx.tender.info,
  135. tenderMenu: this.menu.tenderMenu,
  136. preUrl: '/tender/' + ctx.tender.id,
  137. };
  138. await this.layout('tender/detail.ejs', renderData);
  139. } catch (error) {
  140. this.log(error);
  141. this.ctx.redirect('/list');
  142. }
  143. }
  144. /**
  145. * 保存标段属性等(Ajax)
  146. *
  147. * @param ctx
  148. * @return {Promise<void>}
  149. */
  150. async saveTenderInfo(ctx) {
  151. try {
  152. const data = JSON.parse(ctx.request.body.data);
  153. if (!data) {
  154. throw '提交数据错误';
  155. }
  156. await ctx.service.tenderInfo.saveTenderInfo(ctx.tender.id, data);
  157. ctx.body = { err: 0, msg: '', data };
  158. } catch (err) {
  159. this.log(err);
  160. ctx.body = { err: 1, msg: err.toString(), data: null };
  161. }
  162. }
  163. /**
  164. * 设置标段计量类型并调整到标段概况(Get)
  165. *
  166. * @param ctx
  167. * @return {Promise<void>}
  168. */
  169. async tenderType(ctx) {
  170. try {
  171. const tenderId = ctx.params.id,
  172. type = ctx.query.type;
  173. if (!tenderId) {
  174. throw '当前未打开标段';
  175. }
  176. const tender = await ctx.service.tender.getTender(tenderId);
  177. if (!tender) {
  178. throw '标段数据错误';
  179. }
  180. if (!tender.measure_type) {
  181. await ctx.service.tender.update({ measure_type: type }, { id: tender.id });
  182. }
  183. ctx.redirect('/tender/' + tenderId);
  184. } catch (error) {
  185. this.log(error);
  186. ctx.redirect('/list');
  187. }
  188. }
  189. /**
  190. * 添加标段操作
  191. *
  192. * @param {Object} ctx - egg全局变量
  193. * @return {void}
  194. */
  195. async add(ctx) {
  196. try {
  197. const rule = ctx.service.tender.rule('add');
  198. ctx.helper.validate(rule);
  199. const result = ctx.service.tender.add(ctx.request.body);
  200. if (!result) {
  201. throw '新增标段失败';
  202. }
  203. } catch (error) {
  204. this.log(error);
  205. this.setMessage(error.toString(), this.messageType.ERROR);
  206. }
  207. ctx.redirect(ctx.request.header.referer);
  208. }
  209. /**
  210. * 切换标段 --》 暂时废弃,不存在此功能
  211. *
  212. * @param {Object} ctx - egg全局变量
  213. * @return {void}
  214. */
  215. async switchTender(ctx) {
  216. let tenderId = ctx.params.tenderId;
  217. tenderId = parseInt(tenderId);
  218. try {
  219. if (isNaN(tenderId) || tenderId <= 0) {
  220. throw '参数错误';
  221. }
  222. const result = await ctx.service.tender.switchTender(tenderId);
  223. if (!result) {
  224. throw '切换标段失败!';
  225. }
  226. } catch (error) {
  227. this.setMessage(error.toString(), this.messageType.ERROR);
  228. }
  229. ctx.redirect(ctx.request.header.referer);
  230. }
  231. /**
  232. * 保存标段操作
  233. *
  234. * @param {Object} ctx - egg全局变量
  235. * @return {void}
  236. */
  237. async save(ctx) {
  238. let id = ctx.request.body.tenderId;
  239. id = parseInt(id);
  240. try {
  241. if (isNaN(id) || id < 0) {
  242. throw '参数错误';
  243. }
  244. // 获取数据规则
  245. const rule = ctx.service.tender.rule('save');
  246. ctx.validate(rule);
  247. const result = await ctx.service.tender.save(ctx.request.body, id);
  248. if (!result) {
  249. throw '保存标段数据失败';
  250. }
  251. this.setMessage('保存标段数据成功', this.messageType.SUCCESS);
  252. } catch (error) {
  253. this.setMessage(error.toString(), this.messageType.ERROR);
  254. }
  255. ctx.redirect(ctx.request.header.referer);
  256. }
  257. /**
  258. * 删除标段
  259. *
  260. * @param {Object} ctx -egg全局变量
  261. * @return {void}
  262. */
  263. async delete(ctx) {
  264. let id = ctx.request.body.tenderId;
  265. id = parseInt(id);
  266. try {
  267. if (isNaN(id) || id <= 0) {
  268. throw '参数错误';
  269. }
  270. const result = ctx.service.tender.deleteTenderById(id);
  271. if (!result) {
  272. throw '删除标段失败';
  273. }
  274. this.setMessage('删除标段成功', this.messageType.SUCCESS);
  275. } catch (error) {
  276. this.setMessage(error.toString(), this.messageType.ERROR);
  277. }
  278. ctx.redirect(ctx.request.header.referer);
  279. }
  280. async rule(ctx) {
  281. const responseData = {
  282. err: 0,
  283. msg: '',
  284. data: {},
  285. };
  286. try {
  287. const tenderId = ctx.session.sessionUser.tenderId;
  288. if (!tenderId) {
  289. throw '当前未打开标段';
  290. }
  291. const data = JSON.parse(ctx.request.body.data);
  292. if (!data.rule || !data.connector || !codeRuleConst.ruleField[data.rule]) {
  293. throw '参数错误';
  294. }
  295. const updateData = {
  296. id: tenderId,
  297. };
  298. updateData[codeRuleConst.ruleField[data.rule]] = data.data;
  299. updateData.c_connector = data.connector;
  300. const result = await ctx.service.tender.db.update(ctx.service.tender.tableName, updateData);
  301. if (result.affectedRows !== 1) {
  302. throw '更新规则失败';
  303. }
  304. } catch (err) {
  305. this.log(err);
  306. responseData.err = 1;
  307. responseData.msg = err.toString();
  308. }
  309. ctx.body = responseData;
  310. }
  311. }
  312. return TenderController;
  313. };