From 9e3d47a16aa7b4ed4edbcc1a09ac5949aa8f8ff6 Mon Sep 17 00:00:00 2001 From: xiangpei <xiangpei@timesnew.cn> Date: 星期五, 14 六月 2024 10:50:52 +0800 Subject: [PATCH] 定时保存临时试卷 --- src/main/java/com/ycl/jxkg/service/impl/ExamTemplateServiceImpl.java | 154 +++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 143 insertions(+), 11 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..695db7e 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,23 @@ 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.transaction.annotation.Transactional; import org.springframework.util.Assert; +import org.springframework.util.StringUtils; +import java.math.BigDecimal; +import java.security.Security; +import java.util.ArrayList; +import java.util.Date; import java.util.List; import java.util.stream.Collectors; @@ -28,6 +44,9 @@ @RequiredArgsConstructor public class ExamTemplateServiceImpl extends ServiceImpl<ExamTemplateMapper, ExamTemplate> implements ExamTemplateService { + @Autowired + protected WebContext webContext; + private final ExamTemplateMapper examTemplateMapper; /** @@ -37,8 +56,54 @@ */ @Override public Result add(ExamTemplateForm form) { - ExamTemplate entity = ExamTemplateForm.getEntityByForm(form, null); - baseMapper.insert(entity); +// 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(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("娣诲姞鎴愬姛"); } @@ -48,14 +113,55 @@ * @return */ @Override + @Transactional(rollbackFor = Exception.class) public Result update(ExamTemplateForm form) { - ExamTemplate entity = baseMapper.selectById(form.getId()); - - // 涓虹┖鎶汭llegalArgumentException锛屽仛鍏ㄥ眬寮傚父澶勭悊 - Assert.notNull(entity, "璁板綍涓嶅瓨鍦�"); - BeanUtils.copyProperties(form, entity); - baseMapper.updateById(entity); - return Result.ok("淇敼鎴愬姛"); +// ExamTemplate entity = ExamTemplateForm.getEntityByForm(form, null); +// if(!StringUtils.isEmpty(entity.getVisibility())) { +// entity.setVisibility(VisibilityEnum.fromCode(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); +// examTemplateMapper.removeById(entity.getId()); +// baseMapper.insert(entity); + return Result.ok("淇敼鎴愬姛"); } /** @@ -87,9 +193,35 @@ */ @Override public Result page(ExamTemplateQuery query) { - IPage<ExamTemplateVO> page = PageUtil.getPage(query, ExamTemplateVO.class); + IPage<ExamTemplate> page = PageUtil.getPage(query, ExamTemplate.class); baseMapper.getPage(page, query); - return Result.ok().data(page.getRecords()).total(page.getTotal()); + List<ExamTemplate> records = page.getRecords(); + List<ExamTemplateVO> vos = new ArrayList<>(); + for (ExamTemplate examTemplate : records) { +// ExamTemplateVO vo = new ExamTemplateVO(); +// BeanUtils.copyProperties(examTemplate,vo); +// String visibility = vo.getVisibility(); +// vo.setVisibility(VisibilityEnum.valueOf(visibility).getCode()+""); +// //鏁寸悊棰樼洰淇℃伅涓洪泦鍚� +// List<TemplateQuestionDTO> questionList = new ArrayList<>(); +// addQuestionList(questionList,QuestionTypeEnum.SingleChoice.getCode(),examTemplate.getSingleScore(),examTemplate.getSingleChoice()); +// addQuestionList(questionList,QuestionTypeEnum.MultipleChoice.getCode(),examTemplate.getMultipleScore(),examTemplate.getMultipleChoice()); +// addQuestionList(questionList,QuestionTypeEnum.TrueFalse.getCode(),examTemplate.getTrueFalseScore(),examTemplate.getTrueFalse()); +// addQuestionList(questionList,QuestionTypeEnum.GapFilling.getCode(),examTemplate.getGapScore(),examTemplate.getGapFilling()); +// addQuestionList(questionList,QuestionTypeEnum.ShortAnswer.getCode(),examTemplate.getShortAnswerScore(),examTemplate.getShortAnswer()); +// addQuestionList(questionList,QuestionTypeEnum.Calculation.getCode(),examTemplate.getCalculationScore(),examTemplate.getCalculation()); +// vo.setQuestionList(questionList); +// vos.add(vo); + } + return Result.ok().data(vos).total(page.getTotal()); + } + + private void addQuestionList(List<TemplateQuestionDTO> questionList, Integer code,BigDecimal score,Integer num) { + TemplateQuestionDTO questionDTO = new TemplateQuestionDTO(); + questionDTO.setQuestionType(code); + questionDTO.setScore(score); + questionDTO.setNum(num); + questionList.add(questionDTO); } /** -- Gitblit v1.8.0