lrf402788946 4 years ago
parent
commit
87d56d2ba1

+ 37 - 0
app/controller/.groupscore.js

@@ -0,0 +1,37 @@
+module.exports = {
+  create: {
+    requestBody: ["!classid", "!subid", "date", "!groupid", "score"],
+  },
+  destroy: {
+    params: ["!id"],
+    service: "delete",
+  },
+  update: {
+    params: ["!id"],
+    requestBody: ["!classid", "!subid", "date", "!groupid", "score"],
+  },
+  show: {
+    parameters: {
+      params: ["!id"],
+    },
+    service: "fetch",
+  },
+  index: {
+    parameters: {
+      query: {
+        classid: "classid",
+        subid: "subid",
+        groupid: "groupid",
+        score: "score",
+        date: "date",
+      },
+    },
+    service: "query",
+    options: {
+      query: ["skip", "limit"],
+      sort: ["meta.createdAt"],
+      desc: true,
+      count: true,
+    },
+  },
+};

+ 37 - 0
app/controller/.personalscore.js

@@ -0,0 +1,37 @@
+module.exports = {
+  create: {
+    requestBody: ["!classid", "!subid", "date", "!studentid", "score"],
+  },
+  destroy: {
+    params: ["!id"],
+    service: "delete",
+  },
+  update: {
+    params: ["!id"],
+    requestBody: ["!classid", "!subid", "date", "!studentid", "score"],
+  },
+  show: {
+    parameters: {
+      params: ["!id"],
+    },
+    service: "fetch",
+  },
+  index: {
+    parameters: {
+      query: {
+        classid: "classid",
+        subid: "subid",
+        studentid: "studentid",
+        score: "score",
+        date: "date",
+      },
+    },
+    service: "query",
+    options: {
+      query: ["skip", "limit"],
+      sort: ["meta.createdAt"],
+      desc: true,
+      count: true,
+    },
+  },
+};

+ 16 - 0
app/controller/groupscore.js

@@ -0,0 +1,16 @@
+'use strict';
+
+const _ = require('lodash');
+const Controller = require('egg').Controller;
+const meta = require('./.groupscore.js');
+const { CrudController } = require('naf-framework-mongoose/lib/controller');
+
+// 科目管理
+class GroupscoreController extends Controller {
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.groupscore;
+  }
+}
+
+module.exports = CrudController(GroupscoreController, meta);

+ 16 - 0
app/controller/personalscore.js

@@ -0,0 +1,16 @@
+'use strict';
+
+const _ = require('lodash');
+const Controller = require('egg').Controller;
+const meta = require('./.personalscore.js');
+const { CrudController } = require('naf-framework-mongoose/lib/controller');
+
+// 科目管理
+class PersonalscoreController extends Controller {
+  constructor(ctx) {
+    super(ctx);
+    this.service = this.ctx.service.personalscore;
+  }
+}
+
+module.exports = CrudController(PersonalscoreController, meta);

+ 22 - 0
app/model/groupscore.js

@@ -0,0 +1,22 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const metaPlugin = require('naf-framework-mongoose/lib/model/meta-plugin');
+
+
+// 学生-团队分表
+const GroupscoreSchema = {
+  classid: { type: String, required: true, maxLength: 200 }, // 班级id
+  subid: { type: String, required: true, maxLength: 500 }, // 科目id
+  date: { type: String, required: false, maxLength: 200 }, // 该科上课日期
+  groupid: { type: String, required: true, maxLength: 200 }, // 小组id
+  score: { type: String, required: true, maxLength: 200 }, // 分数
+};
+
+const schema = new Schema(GroupscoreSchema, { toJSON: { virtuals: true } });
+schema.index({ id: 1 });
+schema.plugin(metaPlugin);
+
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('GroupscoreSchema', schema, 'groupscore');
+};

+ 22 - 0
app/model/personalscore.js

@@ -0,0 +1,22 @@
+'use strict';
+const Schema = require('mongoose').Schema;
+const metaPlugin = require('naf-framework-mongoose/lib/model/meta-plugin');
+
+
+// 学生-个人分表
+const PersonalscoreSchema = {
+  classid: { type: String, required: true, maxLength: 200 }, // 班级id
+  subid: { type: String, required: true, maxLength: 500 }, // 科目id
+  date: { type: String, required: false, maxLength: 200 }, // 该科上课日期
+  studentid: { type: String, required: true, maxLength: 200 }, // 学生id
+  score: { type: String, required: true, maxLength: 200 }, // 分数
+};
+
+const schema = new Schema(PersonalscoreSchema, { toJSON: { virtuals: true } });
+schema.index({ id: 1 });
+schema.plugin(metaPlugin);
+
+module.exports = app => {
+  const { mongoose } = app;
+  return mongoose.model('Personalscore', schema, 'personalscore');
+};

+ 22 - 0
app/router.js

@@ -570,4 +570,26 @@ module.exports = app => {
     '/api/train/answerchat/update/:id',
     controller.answerchat.update
   );
+
+  // 个人分groupscoreController
+  router.resources(
+    'personalscore',
+    '/api/train/personalscore',
+    controller.personalscore
+  ); // index、create、show、destroy
+  router.post(
+    'personalscore',
+    '/api/train/personalscore/update/:id',
+    controller.personalscore.update
+  );
+  router.resources(
+    'groupscore',
+    '/api/train/groupscore',
+    controller.groupscore
+  ); // index、create、show、destroy
+  router.post(
+    'groupscore',
+    '/api/train/groupscore/update/:id',
+    controller.groupscore.update
+  );
 };

+ 16 - 0
app/service/groupscore.js

@@ -0,0 +1,16 @@
+'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 GroupscoreService extends CrudService {
+  constructor(ctx) {
+    super(ctx, 'groupscore');
+    this.model = this.ctx.model.Groupscore;
+  }
+}
+
+module.exports = GroupscoreService;

+ 16 - 0
app/service/personalscore.js

@@ -0,0 +1,16 @@
+'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 PersonalscoreService extends CrudService {
+  constructor(ctx) {
+    super(ctx, 'personalscore');
+    this.model = this.ctx.model.Personalscore;
+  }
+}
+
+module.exports = PersonalscoreService;