فهرست منبع

新增团长申请表

guhongwei 2 سال پیش
والد
کامیت
4f2e588b3b

+ 43 - 0
app/controller/system/config/.userleader.js

@@ -0,0 +1,43 @@
+module.exports = {
+  create: {
+    requestBody: ["user_id", "openid", "name", "card", "phone", "status"],
+  },
+  destroy: {
+    params: ["!id"],
+    service: "delete",
+  },
+  update: {
+    params: ["!id"],
+    requestBody: ["user_id", "openid", "name", "card", "phone", "status"],
+  },
+  show: {
+    parameters: {
+      params: ["!id"],
+    },
+    service: "fetch",
+  },
+  index: {
+    parameters: {
+      query: {
+        "meta.createdAt@start": "meta.createdAt@start",
+        "meta.createdAt@end": "meta.createdAt@end",
+        user_id: "user_id",
+        openid: "openid",
+        name: "name",
+        card: "card",
+        phone: "phone",
+        status: "status",
+      },
+      // options: {
+      //   "meta.state": 0 // 默认条件
+      // },
+    },
+    service: "query",
+    options: {
+      query: ["skip", "limit"],
+      sort: ["meta.createdAt"],
+      desc: true,
+      count: true,
+    },
+  },
+};

+ 13 - 0
app/controller/system/userleader.js

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

+ 31 - 0
app/model/system/userleader.js

@@ -0,0 +1,31 @@
+"use strict";
+const Schema = require("mongoose").Schema;
+const metaPlugin = require("naf-framework-mongoose-free/lib/model/meta-plugin");
+
+// 团长申请表
+const userleader = {
+  user_id: { type: String, required: false, zh: "用户id" }, //
+  openid: { type: String, required: false, zh: "openid" }, //
+  name: { type: String, required: false, zh: "姓名" }, //
+  card: { type: String, required: false, zh: "身份证号" }, //
+  phone: { type: String, required: false, zh: "手机号" }, //
+  status: { type: String, required: false, default: "0", zh: "状态" }, // 字典表:exam_status
+};
+const schema = new Schema(userleader, {
+  toJSON: { getters: true, virtuals: true },
+});
+schema.index({ id: 1 });
+schema.index({ "meta.createdAt": 1 });
+schema.index({ user_id: 1 });
+schema.index({ openid: 1 });
+schema.index({ name: 1 });
+schema.index({ card: 1 });
+schema.index({ phone: 1 });
+schema.index({ status: 1 });
+
+schema.plugin(metaPlugin);
+
+module.exports = (app) => {
+  const { mongoose } = app;
+  return mongoose.model("Userleader", schema, "userleader");
+};

+ 15 - 0
app/service/system/userleader.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 UserleaderService extends CrudService {
+  constructor(ctx) {
+    super(ctx, "userleader");
+    this.model = this.ctx.model.System.Userleader;
+  }
+}
+
+module.exports = UserleaderService;

+ 8 - 7
app/z_router/system/index.js

@@ -2,11 +2,12 @@
  * @param {Egg.Application} app - egg application
  */
 module.exports = app => {
-  require('./banner')(app); // 广告图
-  require('./indexModule')(app); // 图标菜单
-  require('./serviceContact')(app); // 客服信息
-  require('./goodsTags')(app); // 商品标签
-  require('./actTags')(app); // 活动标签
-  require('./config')(app); // 系统设置
-  require('./platformAct')(app); // 平台活动
+  require("./banner")(app); // 广告图
+  require("./indexModule")(app); // 图标菜单
+  require("./serviceContact")(app); // 客服信息
+  require("./goodsTags")(app); // 商品标签
+  require("./actTags")(app); // 活动标签
+  require("./config")(app); // 系统设置
+  require("./platformAct")(app); // 平台活动
+  require("./userleader")(app); // 团长管理
 };

+ 19 - 0
app/z_router/system/userleader.js

@@ -0,0 +1,19 @@
+'use strict';
+// 路由配置
+const path = require('path');
+const regPath = path.resolve('app', 'public', 'routerRegister');
+const routerRegister = require(regPath);
+const rkey = 'config';
+const ckey = "system.userleader";
+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`, 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 => {
+  routerRegister(app, routes, keyZh, rkey, ckey);
+};