|
|
@@ -6,30 +6,24 @@ import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
import com.github.yulichang.base.MPJBaseServiceImpl;
|
|
|
+import com.github.yulichang.wrapper.MPJLambdaWrapper;
|
|
|
import com.xjrsoft.common.exception.MyException;
|
|
|
import com.xjrsoft.module.evaluate.dto.EvaluateManagePageDto;
|
|
|
+import com.xjrsoft.module.evaluate.dto.EvaluateManageScoreDto;
|
|
|
import com.xjrsoft.module.evaluate.dto.EvaluateWritePageDto;
|
|
|
-import com.xjrsoft.module.evaluate.entity.EvaluateExecuter;
|
|
|
-import com.xjrsoft.module.evaluate.entity.EvaluateItem;
|
|
|
-import com.xjrsoft.module.evaluate.entity.EvaluateManage;
|
|
|
-import com.xjrsoft.module.evaluate.entity.EvaluateManageItem;
|
|
|
-import com.xjrsoft.module.evaluate.entity.EvaluateObject;
|
|
|
-import com.xjrsoft.module.evaluate.mapper.EvaluateExecuterMapper;
|
|
|
-import com.xjrsoft.module.evaluate.mapper.EvaluateItemMapper;
|
|
|
-import com.xjrsoft.module.evaluate.mapper.EvaluateManageItemMapper;
|
|
|
-import com.xjrsoft.module.evaluate.mapper.EvaluateManageMapper;
|
|
|
-import com.xjrsoft.module.evaluate.mapper.EvaluateObjectMapper;
|
|
|
+import com.xjrsoft.module.evaluate.entity.*;
|
|
|
+import com.xjrsoft.module.evaluate.mapper.*;
|
|
|
import com.xjrsoft.module.evaluate.service.IEvaluateManageService;
|
|
|
-import com.xjrsoft.module.evaluate.vo.EvaluateManageItemVo;
|
|
|
-import com.xjrsoft.module.evaluate.vo.EvaluateManagePageVo;
|
|
|
-import com.xjrsoft.module.evaluate.vo.EvaluateManageScoreVo;
|
|
|
-import com.xjrsoft.module.evaluate.vo.EvaluateWritePageVo;
|
|
|
-import com.xjrsoft.module.evaluate.vo.EvaluateWriteVo;
|
|
|
+import com.xjrsoft.module.evaluate.vo.*;
|
|
|
import lombok.AllArgsConstructor;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
import org.springframework.transaction.annotation.Transactional;
|
|
|
|
|
|
+import java.util.ArrayList;
|
|
|
+import java.util.HashMap;
|
|
|
import java.util.List;
|
|
|
+import java.util.Map;
|
|
|
+import java.util.stream.Collectors;
|
|
|
|
|
|
/**
|
|
|
* @title: 评价管理
|
|
|
@@ -108,18 +102,61 @@ public class EvaluateManageServiceImpl extends MPJBaseServiceImpl<EvaluateManage
|
|
|
@Override
|
|
|
public Page<EvaluateWritePageVo> getMobilePage(Page<EvaluateWritePageDto> page, EvaluateWritePageDto dto) {
|
|
|
Page<EvaluateWritePageVo> mobilePage = evaluateManageMapper.getMobilePage(page, dto);
|
|
|
- if(dto.getStatus() == 1){
|
|
|
- List<EvaluateManageScoreVo> scoreList = evaluateManageMapper.getScoreList(StpUtil.getLoginIdAsLong());
|
|
|
+ //获取所有评价管理下的所有的已评对象的得分
|
|
|
+ Map<String, Map<String, Integer>> scoreByManageIdAndObject = new HashMap<>();
|
|
|
+ Map<String, Integer> itemScore = new HashMap<>();
|
|
|
+ if(dto != null && dto.getStatus() != null && dto.getStatus() == 1){
|
|
|
+ List<Long> evaluateManageIdList = new ArrayList<>();
|
|
|
+ List<Long> evaluateObjectIdList = new ArrayList<>();
|
|
|
for (EvaluateWritePageVo record : mobilePage.getRecords()) {
|
|
|
- for (EvaluateManageScoreVo evaluateManageScoreVo : scoreList) {
|
|
|
- if(!record.getId().equals(evaluateManageScoreVo.getEvaluateManageId())){
|
|
|
- continue;
|
|
|
+ evaluateManageIdList.add(Long.parseLong(record.getEvaluateManageId()));
|
|
|
+ evaluateObjectIdList.add(Long.parseLong(record.getEvaluateObjectId()));
|
|
|
+ }
|
|
|
+
|
|
|
+ //获取评价管理下的模板下的题目数量
|
|
|
+ if(evaluateManageIdList.size() > 0){
|
|
|
+ MPJLambdaWrapper<EvaluateManageItem> evaluateManageItemMPJLambdaWrapper = new MPJLambdaWrapper<>();
|
|
|
+ evaluateManageItemMPJLambdaWrapper
|
|
|
+ .selectCount(EvaluateManageItem::getId, EvaluateWritePageVo::getItemCount)
|
|
|
+ .selectAs(EvaluateManageItem::getEvaluateManageId, EvaluateWritePageVo::getEvaluateManageId)
|
|
|
+ .in(EvaluateManageItem::getEvaluateManageId, evaluateManageIdList)
|
|
|
+ .disableSubLogicDel();
|
|
|
+ List<EvaluateWritePageVo> evaluateWritePageVoList = evaluateManageItemMapper.selectJoinList(EvaluateWritePageVo.class, evaluateManageItemMPJLambdaWrapper);
|
|
|
+ for (EvaluateWritePageVo e : evaluateWritePageVoList) {
|
|
|
+ itemScore.put(e.getEvaluateManageId(), e.getItemCount());
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ if(evaluateManageIdList.size() > 0 && evaluateObjectIdList.size() > 0){
|
|
|
+ List<EvaluateManageScoreVo> scoreList = evaluateManageMapper.getScoreList(new EvaluateManageScoreDto(){{
|
|
|
+ setEvaluateManageIdList(evaluateManageIdList);
|
|
|
+ setEvaluateObjectIdList(evaluateObjectIdList);
|
|
|
+ setUserId(StpUtil.getLoginIdAsLong());
|
|
|
+ }});
|
|
|
+
|
|
|
+ //将scoreList解析成map
|
|
|
+ Map<String, List<EvaluateManageScoreVo>> scoreByManageId = scoreList.stream()
|
|
|
+ .collect(Collectors.groupingBy(EvaluateManageScoreVo::getEvaluateManageId));
|
|
|
+
|
|
|
+ for (Map.Entry<String, List<EvaluateManageScoreVo>> entry : scoreByManageId.entrySet()) {
|
|
|
+ Map<String, Integer> scoreByObject = new HashMap<>();
|
|
|
+ for (EvaluateManageScoreVo evaluateManageScoreVo : entry.getValue()) {
|
|
|
+ scoreByObject.put(evaluateManageScoreVo.getEvaluateObjectId(), evaluateManageScoreVo.getScore());
|
|
|
}
|
|
|
- record.setTotalScore(evaluateManageScoreVo.getScore());
|
|
|
+ scoreByManageIdAndObject.put(entry.getKey(), scoreByObject);
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+ for (EvaluateWritePageVo record : mobilePage.getRecords()) {
|
|
|
+ if(scoreByManageIdAndObject.size() > 0){
|
|
|
+ record.setTotalScore(scoreByManageIdAndObject.get(record.getEvaluateManageId()).get(record.getObjectId()));
|
|
|
+ }
|
|
|
+ if(itemScore.size() > 0){
|
|
|
+ record.setItemCount(itemScore.get(record.getEvaluateManageId()));
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
return mobilePage;
|
|
|
}
|
|
|
|