From 3e456f3e812ead6a19e80cfbdbf86ae0263d50b9 Mon Sep 17 00:00:00 2001 From: mitao <2763622819@qq.com> Date: 星期五, 12 七月 2024 22:39:45 +0800 Subject: [PATCH] 完成7.4迭代内容,通过冒烟测试 --- finance-system/src/main/java/com/finance/system/service/impl/TbQuestionServiceImpl.java | 41 ++++++++++++++++++++++++++++++++++++++++- 1 files changed, 40 insertions(+), 1 deletions(-) diff --git a/finance-system/src/main/java/com/finance/system/service/impl/TbQuestionServiceImpl.java b/finance-system/src/main/java/com/finance/system/service/impl/TbQuestionServiceImpl.java index 335f6db..a99170e 100644 --- a/finance-system/src/main/java/com/finance/system/service/impl/TbQuestionServiceImpl.java +++ b/finance-system/src/main/java/com/finance/system/service/impl/TbQuestionServiceImpl.java @@ -1,9 +1,12 @@ package com.finance.system.service.impl; +import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.finance.common.basic.PageDTO; +import com.finance.common.core.domain.entity.SysUser; import com.finance.common.utils.BeanUtils; +import com.finance.common.utils.CollUtils; import com.finance.common.utils.DateUtils; import com.finance.common.utils.StringUtils; import com.finance.system.domain.TbQuestion; @@ -11,9 +14,17 @@ import com.finance.system.dto.update.QuestionUpdDTO; import com.finance.system.mapper.TbQuestionMapper; import com.finance.system.query.QuestionQuery; +import com.finance.system.service.AsyncService; +import com.finance.system.service.ISysUserService; import com.finance.system.service.TbQuestionService; import com.finance.system.vo.QuestionVO; +import java.util.List; +import java.util.Map; +import java.util.Set; +import java.util.stream.Collectors; +import lombok.RequiredArgsConstructor; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; /** * <p> @@ -24,19 +35,27 @@ * @since 2024-03-13 */ @Service +@RequiredArgsConstructor public class TbQuestionServiceImpl extends ServiceImpl<TbQuestionMapper, TbQuestion> implements TbQuestionService { + private final ISysUserService sysUserService; + private final AsyncService asyncService; + @Override + @Transactional(rollbackFor = Exception.class) public void addQuestion(QuestionDTO dto) throws Exception { TbQuestion tbQuestion = BeanUtils.copyBean(dto, TbQuestion.class); + tbQuestion.setType(dto.getType()); tbQuestion.setQuarter(DateUtils.getNowQuarter()); this.save(tbQuestion); + asyncService.subtractScoreWithFixedRules(dto.getDeptAreaCode()); } @Override public void editQuestion(QuestionUpdDTO dto) { TbQuestion tbQuestion = BeanUtils.copyBean(dto, TbQuestion.class); + tbQuestion.setType(dto.getType()); this.updateById(tbQuestion); } @@ -48,6 +67,26 @@ .like(StringUtils.isNotBlank(dto.getTitle()), TbQuestion::getTitle, dto.getTitle()) .orderByDesc(TbQuestion::getCreateTime) .page(new Page<>(dto.getPageNum(), dto.getPageSize())); - return PageDTO.of(page, QuestionVO.class); + if (StringUtils.isEmpty(page.getRecords())) { + return PageDTO.empty(page.getTotal(), page.getPages()); + } + PageDTO<QuestionVO> questionVOPageDTO = PageDTO.of(page, QuestionVO.class); + Set<String> areaCodeSet = questionVOPageDTO.getList().stream() + .map(QuestionVO::getDeptAreaCode) + .collect(Collectors.toSet()); + if (CollUtils.isNotEmpty(areaCodeSet)) { + List<SysUser> sysUsers = sysUserService.list( + Wrappers.lambdaQuery(SysUser.class).in(SysUser::getAreaCode, areaCodeSet)); + Map<String, String> deptNameMap = sysUsers.stream() + .collect(Collectors.toMap(SysUser::getAreaCode, SysUser::getAreaName)); + if (CollUtils.isNotEmpty(deptNameMap)) { + for (QuestionVO questionVO : questionVOPageDTO.getList()) { + String deptName = deptNameMap.get(questionVO.getDeptAreaCode()); + questionVO.setDeptName(StringUtils.isNotBlank(deptName) ? deptName : ""); + } + } + } + + return questionVOPageDTO; } } -- Gitblit v1.7.1