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