From fdaba78e25c457c48c4581cc84635b63d6363176 Mon Sep 17 00:00:00 2001
From: fuliqi <fuliqi@qq.com>
Date: 星期五, 07 六月 2024 11:30:06 +0800
Subject: [PATCH] 新增模板及校验

---
 src/main/java/com/ycl/jxkg/service/impl/ExamTemplateServiceImpl.java |   63 +++++++++++++++++++++++++++++++
 1 files changed, 63 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/ycl/jxkg/service/impl/ExamTemplateServiceImpl.java b/src/main/java/com/ycl/jxkg/service/impl/ExamTemplateServiceImpl.java
index 20bea45..d682060 100644
--- a/src/main/java/com/ycl/jxkg/service/impl/ExamTemplateServiceImpl.java
+++ b/src/main/java/com/ycl/jxkg/service/impl/ExamTemplateServiceImpl.java
@@ -1,7 +1,12 @@
 package com.ycl.jxkg.service.impl;
 
 import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.ycl.jxkg.context.WebContext;
 import com.ycl.jxkg.domain.entity.ExamTemplate;
+import com.ycl.jxkg.domain.entity.User;
+import com.ycl.jxkg.domain.question.TemplateQuestionDTO;
+import com.ycl.jxkg.enums.QuestionTypeEnum;
+import com.ycl.jxkg.enums.VisibilityEnum;
 import com.ycl.jxkg.mapper.ExamTemplateMapper;
 import com.ycl.jxkg.service.ExamTemplateService;
 import com.ycl.jxkg.base.Result;
@@ -9,12 +14,21 @@
 import com.ycl.jxkg.domain.form.ExamTemplateForm;
 import com.ycl.jxkg.domain.vo.ExamTemplateVO;
 import com.ycl.jxkg.domain.query.ExamTemplateQuery;
+import io.swagger.models.auth.In;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.security.core.context.SecurityContext;
+import org.springframework.security.core.context.SecurityContextHolder;
+import org.springframework.security.core.userdetails.UserDetails;
 import org.springframework.stereotype.Service;
 import lombok.RequiredArgsConstructor;
 import com.ycl.jxkg.utils.PageUtil;
 import org.springframework.beans.BeanUtils;
 import org.springframework.util.Assert;
+import org.springframework.util.StringUtils;
 
+import java.math.BigDecimal;
+import java.security.Security;
+import java.util.Date;
 import java.util.List;
 import java.util.stream.Collectors;
 
@@ -28,6 +42,9 @@
 @RequiredArgsConstructor
 public class ExamTemplateServiceImpl extends ServiceImpl<ExamTemplateMapper, ExamTemplate> implements ExamTemplateService {
 
+    @Autowired
+    protected WebContext webContext;
+
     private final ExamTemplateMapper examTemplateMapper;
 
     /**
@@ -38,6 +55,52 @@
     @Override
     public Result add(ExamTemplateForm form) {
         ExamTemplate entity = ExamTemplateForm.getEntityByForm(form, null);
+        User currentUser = webContext.getCurrentUser();
+        entity.setCreateUser(currentUser.getId());
+        entity.setCreateTime(new Date());
+        if(!StringUtils.isEmpty(entity.getVisibility())) {
+            entity.setVisibility(VisibilityEnum.fromCode(Integer.parseInt(entity.getVisibility())).getName());
+        }
+        List<TemplateQuestionDTO> questionList = form.getQuestionList();
+        BigDecimal score = BigDecimal.ZERO;
+        //璁剧疆棰樼洰淇℃伅
+        for (TemplateQuestionDTO dto : questionList) {
+            score = score.add(dto.getScore().multiply(BigDecimal.valueOf(dto.getNum())));
+            Integer questionType = dto.getQuestionType();
+            switch (QuestionTypeEnum.fromCode(questionType)){
+                //鍗曢��
+                case SingleChoice:
+                    entity.setSingleChoice(dto.getNum());
+                    entity.setSingleScore(dto.getScore());
+                    break;
+                //澶氶��
+                case MultipleChoice:
+                    entity.setMultipleChoice(dto.getNum());
+                    entity.setMultipleScore(dto.getScore());
+                    break;
+                //鍒ゆ柇
+                case TrueFalse:
+                    entity.setTrueFalse(dto.getNum());
+                    entity.setTrueFalseScore(dto.getScore());
+                    break;
+                //濉┖
+                case GapFilling:
+                    entity.setGapFilling(dto.getNum());
+                    entity.setGapScore(dto.getScore());
+                    break;
+                //绠�绛�
+                case ShortAnswer:
+                    entity.setShortAnswer(dto.getNum());
+                    entity.setShortAnswerScore(dto.getScore());
+                    break;
+                //璁$畻
+                case Calculation:
+                    entity.setCalculation(dto.getNum());
+                    entity.setCalculationScore(dto.getScore());
+                    break;
+            }
+        }
+        entity.setScore(score);
         baseMapper.insert(entity);
         return Result.ok("娣诲姞鎴愬姛");
     }

--
Gitblit v1.8.0