liuyu 5 rokov pred
rodič
commit
d93f96863e

+ 40 - 0
app/controller/.codecategory.js

@@ -0,0 +1,40 @@
+module.exports = {
+  create: {
+    requestBody: [
+      '!code',
+      '!name'
+    ]
+  },
+  destroy: {
+    params: ['!id'],
+    service: 'delete'
+  },
+  update: {
+    params: ['!id'],
+    requestBody: [
+      'code',
+      'name'
+    ]
+  },
+  show: {
+    parameters: {
+      params: ['!id']
+    },
+    service: 'fetch'
+  },
+  index: {
+    parameters: {
+      query: {
+        code  :'code',
+        name  :'name'
+      }
+    },
+    service: 'query',
+    options: {
+      query: ['skip', 'limit'],
+      sort: ['meta.createdAt'],
+      desc: true,
+      count: true
+    }
+  },
+};

+ 45 - 0
app/controller/.codeitem.js

@@ -0,0 +1,45 @@
+module.exports = {
+  create: {
+    requestBody: [
+      '!code',
+      '!name',
+      '!category',
+      'sort'
+    ]
+  },
+  destroy: {
+    params: ['!id'],
+    service: 'delete'
+  },
+  update: {
+    params: ['!id'],
+    requestBody: [
+      'code',
+      'name',
+      'category',
+      'sort'
+    ]
+  },
+  show: {
+    parameters: {
+      params: ['!id']
+    },
+    service: 'fetch'
+  },
+  index: {
+    parameters: {
+      query: {
+        code  :'code',
+        name  :'name',
+        category  :'category'
+      }
+    },
+    service: 'query',
+    options: {
+      query: ['skip', 'limit'],
+      sort: ['sort'],
+      desc: true,
+      count: true
+    }
+  },
+};

+ 19 - 0
app/controller/codecategory.js

@@ -0,0 +1,19 @@
+'use strict';
+
+const _ = require('lodash');
+const meta = require('./.codecategory.js');
+const Controller = require('egg').Controller;
+const { CrudController } = require('naf-framework-mongoose/lib/controller');
+
+// 字典类别信息管理
+class CodecategoryController extends Controller {
+
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.codecategory;
+  }
+
+
+}
+
+module.exports = CrudController(CodecategoryController, meta);

+ 19 - 0
app/controller/codeitem.js

@@ -0,0 +1,19 @@
+'use strict';
+
+const _ = require('lodash');
+const meta = require('./.codeitem.js');
+const Controller = require('egg').Controller;
+const { CrudController } = require('naf-framework-mongoose/lib/controller');
+
+// 字典信息管理
+class CodeitemController extends Controller {
+
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.codeitem;
+  }
+
+
+}
+
+module.exports = CrudController(CodeitemController, meta);

+ 19 - 0
app/model/codecategory.js

@@ -0,0 +1,19 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const metaPlugin = require('naf-framework-mongoose/lib/model/meta-plugin');
+
+// 字典类别表
+const CodecategorySchema = {
+  code: { type: String, required: true, maxLength: 500 }, // 类别code
+  name: { type: String, required: true, maxLength: 500 }, // 名称
+};
+
+
+const schema = new Schema(CodecategorySchema, { toJSON: { virtuals: true } });
+schema.index({ id: 1 });
+schema.plugin(metaPlugin);
+
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('Codecategory', schema, 'code_category');
+};

+ 22 - 0
app/model/codeitem.js

@@ -0,0 +1,22 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const metaPlugin = require('naf-framework-mongoose/lib/model/meta-plugin');
+
+// 字典表
+const CodeitemSchema = {
+  code: { type: String, required: true, maxLength: 500 }, // code
+  name: { type: String, required: true, maxLength: 500 }, // 名称
+  category: { type: String, required: true, maxLength: 500 }, // 类别code
+  sort: { type: String, required: false, maxLength: 500 }, // 排序
+};
+
+
+const schema = new Schema(CodeitemSchema, { toJSON: { virtuals: true } });
+schema.index({ id: 1 });
+schema.index({ category: 1 });
+schema.plugin(metaPlugin);
+
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('Codeitem', schema, 'code_item');
+};

+ 6 - 0
app/router.js

@@ -19,4 +19,10 @@ module.exports = app => {
   // 用户表设置路由
   router.resources('user', '/api/setting/user', controller.user); // index、create、show、destroy
   router.post('user', '/api/setting/user/update/:id', controller.user.update);
+
+  // 字典信息表设置路由
+  router.resources('codecategory', '/api/setting/codecategory', controller.codecategory); // index、create、show、destroy
+  router.post('codecategory', '/api/setting/codecategory/update/:id', controller.codecategory.update);
+  router.resources('codeitem', '/api/setting/codeitem', controller.codeitem); // index、create、show、destroy
+  router.post('codeitem', '/api/setting/codeitem/update/:id', controller.codeitem.update);
 };

+ 17 - 0
app/service/codecategory.js

@@ -0,0 +1,17 @@
+'use strict';
+
+
+const assert = require('assert');
+const _ = require('lodash');
+const { ObjectId } = require('mongoose').Types;
+const { CrudService } = require('naf-framework-mongoose/lib/service');
+const { BusinessError, ErrorCode } = require('naf-core').Error;
+
+class CodecategoryService extends CrudService {
+  constructor(ctx) {
+    super(ctx, 'code_category');
+    this.model = this.ctx.model.Codecategory;
+  }
+}
+
+module.exports = CodecategoryService;

+ 17 - 0
app/service/codeitem.js

@@ -0,0 +1,17 @@
+'use strict';
+
+
+const assert = require('assert');
+const _ = require('lodash');
+const { ObjectId } = require('mongoose').Types;
+const { CrudService } = require('naf-framework-mongoose/lib/service');
+const { BusinessError, ErrorCode } = require('naf-core').Error;
+
+class CodeitemService extends CrudService {
+  constructor(ctx) {
+    super(ctx, 'code_item');
+    this.model = this.ctx.model.Codeitem;
+  }
+}
+
+module.exports = CodeitemService;

+ 1 - 1
app/service/link.js

@@ -9,7 +9,7 @@ const { BusinessError, ErrorCode } = require('naf-core').Error;
 
 class LinkService extends CrudService {
   constructor(ctx) {
-    super(ctx, 'set');
+    super(ctx, 'link');
     this.model = this.ctx.model.Link;
   }
 }