|
|
@@ -3,10 +3,20 @@ package com.xjrsoft.module.textbook.service.impl;
|
|
|
import cn.hutool.core.bean.BeanUtil;
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
import com.github.yulichang.base.MPJBaseServiceImpl;
|
|
|
+import com.github.yulichang.wrapper.MPJLambdaWrapper;
|
|
|
import com.xjrsoft.common.model.result.RT;
|
|
|
+import com.xjrsoft.common.utils.VoToColumnUtil;
|
|
|
+import com.xjrsoft.module.base.entity.BaseClass;
|
|
|
+import com.xjrsoft.module.base.mapper.BaseClassMapper;
|
|
|
+import com.xjrsoft.module.base.service.IBaseClassService;
|
|
|
import com.xjrsoft.module.oa.entity.NewsRelation;
|
|
|
+import com.xjrsoft.module.oa.vo.NewsAppendixVo;
|
|
|
+import com.xjrsoft.module.system.entity.Databaselink;
|
|
|
+import com.xjrsoft.module.system.entity.DictionaryDetail;
|
|
|
+import com.xjrsoft.module.system.entity.File;
|
|
|
import com.xjrsoft.module.textbook.dto.AddTextbookWarehouseRecordDto;
|
|
|
import com.xjrsoft.module.textbook.dto.UpdateWfTextbookSubscriptionDto;
|
|
|
+import com.xjrsoft.module.textbook.entity.Textbook;
|
|
|
import com.xjrsoft.module.textbook.entity.TextbookSubscriptionRecord;
|
|
|
import com.xjrsoft.module.textbook.entity.WfTextbookSubscriptionItem;
|
|
|
import com.xjrsoft.module.textbook.mapper.TextbookSubscriptionRecordMapper;
|
|
|
@@ -15,13 +25,14 @@ import com.xjrsoft.module.textbook.entity.WfTextbookSubscription;
|
|
|
import com.xjrsoft.module.textbook.mapper.WfTextbookSubscriptionMapper;
|
|
|
import com.xjrsoft.module.textbook.service.ITextbookService;
|
|
|
import com.xjrsoft.module.textbook.service.IWfTextbookSubscriptionService;
|
|
|
+import com.xjrsoft.module.textbook.vo.WfTextbookSubscriptionItemVo;
|
|
|
+import com.xjrsoft.module.textbook.vo.WfTextbookSubscriptionPageVo;
|
|
|
+import com.xjrsoft.module.textbook.vo.WfTextbookSubscriptionVo;
|
|
|
import lombok.AllArgsConstructor;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
import org.springframework.transaction.annotation.Transactional;
|
|
|
|
|
|
-import java.util.Date;
|
|
|
-import java.util.List;
|
|
|
-import java.util.Objects;
|
|
|
+import java.util.*;
|
|
|
import java.util.stream.Collectors;
|
|
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
|
|
|
|
@@ -42,6 +53,8 @@ public class WfTextbookSubscriptionServiceImpl extends MPJBaseServiceImpl<WfText
|
|
|
|
|
|
private final ITextbookService textbookService;
|
|
|
|
|
|
+ private final BaseClassMapper baseClassMapper;
|
|
|
+
|
|
|
@Override
|
|
|
@Transactional(rollbackFor = Exception.class)
|
|
|
public Boolean add(WfTextbookSubscription wfTextbookSubscription) {
|
|
|
@@ -146,4 +159,70 @@ public class WfTextbookSubscriptionServiceImpl extends MPJBaseServiceImpl<WfText
|
|
|
}
|
|
|
return false;
|
|
|
}
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public WfTextbookSubscriptionVo getInfo(Long id) {
|
|
|
+ WfTextbookSubscription wfTextbookSubscription = this.getById(id);
|
|
|
+ if(wfTextbookSubscription == null){
|
|
|
+ return null;
|
|
|
+ }
|
|
|
+ WfTextbookSubscriptionVo wfTextbookSubscriptionVo = BeanUtil.toBean(wfTextbookSubscription, WfTextbookSubscriptionVo.class);
|
|
|
+
|
|
|
+ MPJLambdaWrapper<WfTextbookSubscriptionItem> mpjLambdaWrapper = new MPJLambdaWrapper<>();
|
|
|
+ mpjLambdaWrapper
|
|
|
+ .select(WfTextbookSubscriptionItem.class,x -> VoToColumnUtil.fieldsToColumns(WfTextbookSubscriptionItemVo.class).contains(x.getProperty()))
|
|
|
+ .select(Textbook.class,x -> VoToColumnUtil.fieldsToColumns(WfTextbookSubscriptionItemVo.class).contains(x.getProperty()))
|
|
|
+ .leftJoin(Textbook.class, Textbook::getId, WfTextbookSubscriptionItem::getTextbookId)
|
|
|
+ .leftJoin(DictionaryDetail.class, DictionaryDetail::getCode, Textbook::getTextbookType,
|
|
|
+ ext -> ext.selectAs(DictionaryDetail::getName, WfTextbookSubscriptionItemVo::getTextbookTypeCn))
|
|
|
+ .eq(WfTextbookSubscriptionItem::getWfTextbookSubscriptionId, wfTextbookSubscription.getId())
|
|
|
+ ;
|
|
|
+ List<WfTextbookSubscriptionItemVo> itemList = wfTextbookSubscriptionWfTextbookSubscriptionItemMapper.selectJoinList(WfTextbookSubscriptionItemVo.class, mpjLambdaWrapper);
|
|
|
+
|
|
|
+ //处理班级
|
|
|
+ List<String> classIdList = new ArrayList<>();
|
|
|
+ StringBuilder sb = new StringBuilder();
|
|
|
+ if(!itemList.isEmpty() && itemList.get(0).getClassIds() != null && !itemList.get(0).getClassIds().equals("")){
|
|
|
+ String classIds = itemList.get(0).getClassIds();
|
|
|
+ String[] classIdArr = classIds.split(",");
|
|
|
+ classIdList = Arrays.asList(classIdArr);
|
|
|
+ if(!classIdList.isEmpty()){
|
|
|
+ List<BaseClass> baseClassList = baseClassMapper.selectList(Wrappers.<BaseClass>query().lambda().in(BaseClass::getId, classIdList));
|
|
|
+ Map<Long, BaseClass> baseClassMap = baseClassList.stream()
|
|
|
+ .collect(Collectors.toMap(BaseClass::getId, baseClass -> baseClass));
|
|
|
+
|
|
|
+ for (String classId : classIdList){
|
|
|
+ BaseClass baseClass = baseClassMap.get(Long.parseLong(classId));
|
|
|
+ if(baseClass != null){
|
|
|
+ sb.append(baseClass.getName());
|
|
|
+ sb.append(",");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ sb.deleteCharAt(sb.length() - 1);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ //遍历处理所有项
|
|
|
+ int stuSum = 0;
|
|
|
+ int teaSum = 0;
|
|
|
+ for (WfTextbookSubscriptionItemVo w : itemList){
|
|
|
+ if(!classIdList.isEmpty()){
|
|
|
+ w.setClassNum(classIdList.size());
|
|
|
+ }
|
|
|
+ if(w.getStudentSubscriptionNumber() != null){
|
|
|
+ stuSum += w.getStudentSubscriptionNumber();
|
|
|
+ }
|
|
|
+ if(w.getTeacherSubscriptionNumber() != null){
|
|
|
+ teaSum += w.getTeacherSubscriptionNumber();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ wfTextbookSubscriptionVo.setClassIdsCn(sb.toString());
|
|
|
+ wfTextbookSubscriptionVo.setStudentSubscriptionNumberSum(stuSum);
|
|
|
+ wfTextbookSubscriptionVo.setTeacherSubscriptionNumberSum(teaSum);
|
|
|
+ wfTextbookSubscriptionVo.setSum(stuSum + teaSum);
|
|
|
+ wfTextbookSubscriptionVo.setWfTextbookSubscriptionItemList(itemList);
|
|
|
+
|
|
|
+ return wfTextbookSubscriptionVo;
|
|
|
+ }
|
|
|
}
|