base_controller.js 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. 'use strict';
  2. /**
  3. * 控制器基类
  4. *
  5. * @author CaiAoLin
  6. * @date 2017/10/11
  7. * @version
  8. */
  9. const moment = require('moment');
  10. const messageType = require('../const/message_type');
  11. const Controller = require('egg').Controller;
  12. const menuList = require('../../config/menu');
  13. class BaseController extends Controller {
  14. /**
  15. * 构造函数
  16. *
  17. * @param {Object} ctx - egg全局context
  18. * @return {void}
  19. */
  20. constructor(ctx) {
  21. super(ctx);
  22. this.messageType = messageType;
  23. this.jsValidator = this.app.jsValidator;
  24. // 当前菜单
  25. ctx.menu = menuList[ctx.controllerName] === undefined ? {} : menuList[ctx.controllerName];
  26. ctx.title = ctx.menu === {} ? '' : ctx.menu.name;
  27. if (ctx.menu !== {} && ctx.menu.children !== null) {
  28. for (const index in ctx.menu.children) {
  29. if (index === ctx.actionName) {
  30. ctx.title = ctx.menu.children[index].name;
  31. }
  32. }
  33. }
  34. // 菜单列表
  35. ctx.menuList = menuList;
  36. ctx.showProject = false;
  37. ctx.showTender = false;
  38. ctx.showTitle = false;
  39. }
  40. /**
  41. * 渲染layout
  42. *
  43. * @param {String} view - 渲染的view
  44. * @param {Object} data - 渲染的数据
  45. * @param {String} modal - 渲染的modal
  46. * @return {void}
  47. */
  48. async layout(view, data = {}, modal = '') {
  49. data.moment = moment;
  50. // 获取消息提示
  51. const message = this.ctx.session.message;
  52. // 取出后删除
  53. this.ctx.session.message = null;
  54. const viewString = await this.ctx.renderView(view, data);
  55. const modalString = modal === '' ? '' : await this.ctx.renderView(modal, data);
  56. const renderData = {
  57. content: viewString,
  58. message: JSON.stringify(message),
  59. modal: modalString,
  60. dropDownMenu: data.dropDownMenu === undefined ? [] : data.dropDownMenu,
  61. breadCrumb: data.breadCrumb === undefined ? '' : data.breadCrumb,
  62. tenderList: data.tenderList === undefined ? [] : data.tenderList,
  63. };
  64. await this.ctx.render('layout/layout.ejs', renderData);
  65. }
  66. /**
  67. * 设置提示
  68. *
  69. * @param {String} message - 提示信息
  70. * @param {String} type - 提示类型
  71. * @return {void}
  72. */
  73. setMessage(message, type) {
  74. let icon = '';
  75. switch (type) {
  76. case messageType.SUCCESS:
  77. icon = 'check';
  78. break;
  79. case messageType.ERROR:
  80. icon = 'exclamation-circle';
  81. break;
  82. case messageType.INFO:
  83. icon = 'info-circle';
  84. break;
  85. case messageType.WARNING:
  86. icon = 'warning';
  87. break;
  88. default:
  89. break;
  90. }
  91. this.ctx.session.message = {
  92. type,
  93. icon,
  94. message,
  95. };
  96. }
  97. }
  98. module.exports = BaseController;