Browse Source

评审记录表

guhongwei 3 years ago
parent
commit
253f96a4e9

+ 13 - 0
app/controller/achieve_verify_record.js

@@ -0,0 +1,13 @@
+'use strict';
+const meta = require('./config/.achieve_verify_record.js');
+const Controller = require('egg').Controller;
+const { CrudController } = require('naf-framework-mongoose/lib/controller');
+
+// 审核记录
+class Achieve_verify_recordController extends Controller {
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.achieveVerifyRecord;
+  }
+}
+module.exports = CrudController(Achieve_verify_recordController, meta);

+ 55 - 0
app/controller/config/.achieve_verify_record.js

@@ -0,0 +1,55 @@
+module.exports = {
+  create: {
+    requestBody: [
+      "!apply_id",
+      "desc",
+      "status",
+      "!verify_id",
+      "verify_phone",
+      "verify",
+      "step",
+    ],
+  },
+  destroy: {
+    params: ["!id"],
+    service: "delete",
+  },
+  update: {
+    params: ["!id"],
+    requestBody: [
+      "apply_id",
+      "desc",
+      "status",
+      "verify_id",
+      "verify_phone",
+      "verify",
+      "step",
+    ],
+  },
+  show: {
+    parameters: {
+      params: ["!id"],
+    },
+    service: "fetch",
+  },
+  index: {
+    parameters: {
+      query: {
+        apply_id: "apply_id",
+        step: "step",
+        "create_time@start": "create_time@start",
+        "create_time@end": "create_time@end",
+      },
+      // options: {
+      //   "meta.state": 0 // 默认条件
+      // },
+    },
+    service: "query",
+    options: {
+      query: ["skip", "limit"],
+      sort: ["meta.createdAt"],
+      desc: true,
+      count: true,
+    },
+  },
+};

+ 26 - 0
app/model/achieve_verify_record.js

@@ -0,0 +1,26 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const moment = require('moment');
+const metaPlugin = require('naf-framework-mongoose/lib/model/meta-plugin');
+const { ObjectId } = require('mongoose').Types;
+// 审核记录表
+const achieve_verify_record = {
+  apply_id: { type: ObjectId }, // 成果申请数据id
+  desc: { type: String }, // 本次审核的意见
+  status: { type: String }, // 本次审核的结果
+  verify_id: { type: ObjectId }, // 本次审核人
+  verify_phone: { type: String }, // 本次审核人的联系电话
+  verify: { type: String }, // 本次审核人
+  step: { type: String }, // 初审=>评分=>会审=>资料/发证书
+  remark: { type: String, maxLength: 200 },
+  create_time: { type: String, default: moment().format('YYYY-MM-DD HH:mm:ss') },
+};
+const schema = new Schema(achieve_verify_record, { toJSON: { virtuals: true } });
+schema.index({ id: 1 });
+schema.index({ apply_id: 1 });
+schema.index({ 'meta.createdAt': 1 });
+schema.plugin(metaPlugin);
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('Achieve_verify_record', schema, 'achieve_verify_record');
+};

+ 1 - 0
app/router.js

@@ -14,4 +14,5 @@ module.exports = app => {
   require('./z_router/apply')(app); // 申报
   require('./z_router/expert')(app); // 专家
   require('./z_router/review_expert')(app); // 专家评审
+  require('./z_router/achieve_verify_record')(app); // 评审记录表
 };

+ 15 - 0
app/service/achieve_verify_record.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 Achieve_verify_recordService extends CrudService {
+  constructor(ctx) {
+    super(ctx, 'achieve_verify_record');
+    this.model = this.ctx.model.AchieveVerifyRecord;
+  }
+}
+
+module.exports = Achieve_verify_recordService;

+ 28 - 0
app/z_router/achieve_verify_record.js

@@ -0,0 +1,28 @@
+'use strict';
+// 路由配置
+const rkey = 'AchieveVerifyRecord';
+const ckey = 'AchieveVerifyRecord';
+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 => {
+  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);
+  }
+};