Browse Source

新增通知通告表

guhongwei 2 years ago
parent
commit
125e5d0dc7
6 changed files with 157 additions and 13 deletions
  1. 59 0
      app/controller/.notice.js
  2. 13 0
      app/controller/notice.js
  3. 28 0
      app/model/notice.js
  4. 14 13
      app/router.js
  5. 15 0
      app/service/notice.js
  6. 28 0
      app/z_router/notice.js

+ 59 - 0
app/controller/.notice.js

@@ -0,0 +1,59 @@
+module.exports = {
+  create: {
+    requestBody: [
+      "send_id",
+      "send_name",
+      "send_time",
+      "type",
+      "content",
+      "file",
+      "receive_user",
+      "remark",
+    ],
+  },
+  destroy: {
+    params: ["!id"],
+    service: "delete",
+  },
+  update: {
+    params: ["!id"],
+    requestBody: [
+      "send_id",
+      "send_name",
+      "send_time",
+      "type",
+      "content",
+      "file",
+      "receive_user",
+      "remark",
+    ],
+  },
+  show: {
+    parameters: {
+      params: ["!id"],
+    },
+    service: "fetch",
+  },
+  index: {
+    parameters: {
+      query: {
+        send_id: "send_id",
+        send_name: "send_name",
+        send_time: "send_time",
+        type: "type",
+        "meta.createdAt@start": "meta.createdAt@start",
+        "meta.createdAt@end": "meta.createdAt@end",
+      },
+      // options: {
+      //   "meta.state": 0 // 默认条件
+      // },
+    },
+    service: "query",
+    options: {
+      query: ["skip", "limit"],
+      sort: ["meta.createdAt"],
+      desc: true,
+      count: true,
+    },
+  },
+};

+ 13 - 0
app/controller/notice.js

@@ -0,0 +1,13 @@
+'use strict';
+const meta = require("./.notice.js");
+const Controller = require('egg').Controller;
+const { CrudController } = require('naf-framework-mongoose-free/lib/controller');
+
+// 通知通告
+class NoticeController extends Controller {
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.notice;
+  }
+}
+module.exports = CrudController(NoticeController, meta);

+ 28 - 0
app/model/notice.js

@@ -0,0 +1,28 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const moment = require('moment');
+const metaPlugin = require('naf-framework-mongoose-free/lib/model/meta-plugin');
+const { ObjectId } = require('mongoose').Types;
+// 通知通告
+const notice = {
+  send_id: { type: String }, // 发送人
+  send_name: { type: String }, // 发送人姓名
+  send_time: { type: String }, // 发送时间
+  type: { type: String }, //接收人类型 0:所有人,1:团队创建人,2:个人用户,3:指定,某一个人
+  content: { type: String }, // 通知内容
+  file: { type: Array }, // 文件
+  receive_user: { type: Array }, // 接收人 [{user_id,user_name,status:0:未读,1:已读}]
+  remark: { type: String },
+};
+const schema = new Schema(notice, { toJSON: { virtuals: true } });
+schema.index({ id: 1 });
+schema.index({ match_id: 1 });
+schema.index({ send_name: 1 });
+schema.index({ send_time: 1 });
+schema.index({ type: 1 });
+schema.index({ 'meta.createdAt': 1 });
+schema.plugin(metaPlugin);
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model("Notice", schema, "notice");
+};

+ 14 - 13
app/router.js

@@ -17,20 +17,21 @@ function getIPAdress() {
     }
   }
 }
-module.exports = app => {
+module.exports = (app) => {
   const { router, controller } = app;
   const { routePrefix, cluster } = app.config;
   const ipAddress = getIPAdress();
   console.log(`前缀:http://${ipAddress}:${cluster.listen.port}${routePrefix}`);
-  router.get('/', controller.home.index);
-  router.post('/courtAdmin/api/admin/login', controller.home.login);
-  router.get('/courtAdmin/api/useradmin', controller.admin.index);
-  require('./z_router/menu')(app); // 菜单
-  require('./z_router/user')(app); // 用户
-  require('./z_router/team')(app); // 团队
-  require('./z_router/joinapply')(app); // 加入团队
-  require('./z_router/dismissapply')(app); // 解散团队
-  require('./z_router/match')(app); // 比赛管理
-  require('./z_router/matchteam')(app); // 参赛团队
-  require('./z_router/schedule')(app); // 赛程信息
-};
+  router.get("/", controller.home.index);
+  router.post("/courtAdmin/api/admin/login", controller.home.login);
+  router.get("/courtAdmin/api/useradmin", controller.admin.index);
+  require("./z_router/menu")(app); // 菜单
+  require("./z_router/user")(app); // 用户
+  require("./z_router/team")(app); // 团队
+  require("./z_router/joinapply")(app); // 加入团队
+  require("./z_router/dismissapply")(app); // 解散团队
+  require("./z_router/match")(app); // 比赛管理
+  require("./z_router/matchteam")(app); // 参赛团队
+  require("./z_router/schedule")(app); // 赛程信息
+  require("./z_router/notice")(app); // 通知通告
+};;

+ 15 - 0
app/service/notice.js

@@ -0,0 +1,15 @@
+'use strict';
+const { CrudService } = require('naf-framework-mongoose-free/lib/service');
+const { BusinessError, ErrorCode } = require('naf-core').Error;
+const _ = require('lodash');
+const assert = require('assert');
+
+// 通知通告
+class NoticeService extends CrudService {
+  constructor(ctx) {
+    super(ctx, "notice");
+    this.model = this.ctx.model.Notice;
+  }
+}
+
+module.exports = NoticeService;

+ 28 - 0
app/z_router/notice.js

@@ -0,0 +1,28 @@
+'use strict';
+// 路由配置
+const rkey = "notice";
+const ckey = "notice";
+const keyZh = '通知通告';
+const routes = [
+  { method: 'get', path: `${rkey}`, controller: `${ckey}.index`, name: `${ckey}Query`, zh: `${keyZh}列表查询` },
+  { method: 'get', path: `${rkey}/:id`, controller: `${ckey}.show`, name: `${ckey}Show`, zh: `${keyZh}查询` },
+  { method: 'post', path: `${rkey}`, controller: `${ckey}.create`, middleware: [ 'password' ], name: `${ckey}Create`, zh: `创建${keyZh}` },
+  { method: 'post', path: `${rkey}/:id`, controller: `${ckey}.update`, name: `${ckey}Update`, zh: `修改${keyZh}` },
+  { method: 'delete', path: `${rkey}/:id`, controller: `${ckey}.destroy`, name: `${ckey}Delete`, zh: `删除${keyZh}` },
+];
+
+module.exports = app => {
+  const { router, config } = app;
+  const mwares = app.middleware;
+  for (const route of routes) {
+    const { method, path, controller: ctl, zh } = route;
+    let { middleware = [] } = route;
+    if (!method || !path || !ctl) continue;
+    // 拼全路径
+    const allPath = `${config.routePrefix}/${path}`;
+    // 处理中间件
+    if (middleware.length > 0) middleware = middleware.map(i => mwares[i]({ enable: true }));
+    // 注册路由
+    router[method](zh, allPath, ...middleware, ctl);
+  }
+};