Ver Fonte

新建学校表

reloaded há 5 anos atrás
pai
commit
4dec36823a

+ 46 - 0
app/controller/.school.js

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

+ 5 - 4
app/controller/schoolctrl.js

@@ -1,15 +1,16 @@
 'use strict';
 
 const _ = require('lodash');
+const meta = require('./.school.js');
 const Controller = require('egg').Controller;
 const { CrudController } = require('naf-framework-mongoose/lib/controller');
 
-// 学校管理
-class SchoolctrlController extends Controller {
+// 学校管理
+class SchoolController extends Controller {
 
   constructor(ctx) {
     super(ctx);
-    this.service = this.ctx.service.schoolctrl;
+    this.service = this.ctx.service.school;
   }
 
   // 学生名单上报
@@ -21,4 +22,4 @@ class SchoolctrlController extends Controller {
 
 }
 
-module.exports = CrudController(SchoolctrlController);
+module.exports = CrudController(SchoolController, meta);

+ 21 - 0
app/model/school.js

@@ -0,0 +1,21 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const metaPlugin = require('naf-framework-mongoose/lib/model/meta-plugin');
+
+// 学校表
+const SchoolSchema = {
+  code: { type: String, required: false, maxLength: 200 }, // 学校代码
+  name: { type: String, required: false, maxLength: 500 }, // 学校名称
+  logourl: { type: String, required: false, maxLength: 500 }, // logo路径
+  level: { type: String, required: false, maxLength: 500 }, // 高校层次
+};
+
+
+const schema = new Schema(SchoolSchema, { toJSON: { virtuals: true } });
+schema.index({ id: 1 });
+schema.plugin(metaPlugin);
+
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('School', schema, 'school');
+};

+ 3 - 1
app/router.js

@@ -110,5 +110,7 @@ module.exports = app => {
   router.post('attendance', '/api/train/attendance/update/:id', controller.attendance.update);
 
   // 学校上传学生名单
-  router.post('/api/train/school/import', controller.schoolctrl.stuimport); // 名单上传
+  router.resources('school', '/api/train/school', controller.school); // index、create、show、destroy
+  router.post('school', '/api/train/school/update/:id', controller.school.update);
+  router.post('/api/train/school/import', controller.school.stuimport); // 名单上传
 };

+ 2 - 2
app/service/schoolctrl.js

@@ -8,7 +8,7 @@ const { CrudService } = require('naf-framework-mongoose/lib/service');
 const { BusinessError, ErrorCode } = require('naf-core').Error;
 const XLSX = require('xlsx');
 
-class SchtimeService extends CrudService {
+class SchoolService extends CrudService {
   constructor(ctx) {
     super(ctx, 'schoolctrl');
     this.model = this.ctx.model.Student;
@@ -99,4 +99,4 @@ class SchtimeService extends CrudService {
   }
 }
 
-module.exports = SchtimeService;
+module.exports = SchoolService;