|
|
@@ -1,8 +1,6 @@
|
|
|
package com.xjrsoft.module.textbook.service.impl;
|
|
|
|
|
|
import cn.dev33.satoken.stp.StpUtil;
|
|
|
-import com.alibaba.excel.EasyExcel;
|
|
|
-import com.alibaba.excel.support.ExcelTypeEnum;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
|
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
|
@@ -13,12 +11,11 @@ import com.xjrsoft.common.enums.ClaimTypeEnum;
|
|
|
import com.xjrsoft.common.enums.DeleteMark;
|
|
|
import com.xjrsoft.common.enums.IssueModeEnum;
|
|
|
import com.xjrsoft.common.exception.MyException;
|
|
|
-import com.xjrsoft.common.model.result.RT;
|
|
|
import com.xjrsoft.common.page.ConventPage;
|
|
|
import com.xjrsoft.common.utils.VoToColumnUtil;
|
|
|
import com.xjrsoft.module.base.entity.BaseClass;
|
|
|
import com.xjrsoft.module.base.entity.BaseSemester;
|
|
|
-import com.xjrsoft.module.oa.entity.WfMeetingApply;
|
|
|
+import com.xjrsoft.module.generator.entity.ImportConfig;
|
|
|
import com.xjrsoft.module.system.entity.DictionaryDetail;
|
|
|
import com.xjrsoft.module.teacher.entity.XjrUser;
|
|
|
import com.xjrsoft.module.teacher.mapper.XjrUserMapper;
|
|
|
@@ -27,21 +24,29 @@ import com.xjrsoft.module.textbook.entity.*;
|
|
|
import com.xjrsoft.module.textbook.mapper.*;
|
|
|
import com.xjrsoft.module.textbook.service.IWfTextbookClaimService;
|
|
|
import com.xjrsoft.module.textbook.vo.*;
|
|
|
+import com.xjrsoft.module.veb.util.ImportExcelUtil;
|
|
|
import com.xjrsoft.module.workflow.entity.WorkflowFormRelation;
|
|
|
import com.xjrsoft.module.workflow.mapper.WorkflowFormRelationMapper;
|
|
|
import lombok.AllArgsConstructor;
|
|
|
import org.apache.commons.collections.CollectionUtils;
|
|
|
+import org.apache.commons.collections.MapUtils;
|
|
|
import org.apache.commons.lang3.ObjectUtils;
|
|
|
import org.apache.commons.lang3.StringUtils;
|
|
|
+import org.apache.poi.ss.usermodel.*;
|
|
|
+import org.apache.poi.ss.util.CellRangeAddress;
|
|
|
+import org.apache.poi.xssf.usermodel.XSSFWorkbook;
|
|
|
import org.camunda.bpm.engine.history.HistoricProcessInstance;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
import org.springframework.transaction.annotation.Transactional;
|
|
|
|
|
|
import java.io.ByteArrayOutputStream;
|
|
|
+import java.io.IOException;
|
|
|
import java.math.BigDecimal;
|
|
|
import java.time.LocalDateTime;
|
|
|
+import java.time.ZoneId;
|
|
|
import java.time.format.DateTimeFormatter;
|
|
|
import java.util.*;
|
|
|
+import java.util.function.Function;
|
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
/**
|
|
|
@@ -71,6 +76,7 @@ public class WfTextbookClaimServiceImpl extends MPJBaseServiceImpl<WfTextbookCla
|
|
|
|
|
|
@Override
|
|
|
public IPage<DistributePageVo> distributePage(DistributePageDto dto) {
|
|
|
+ // 申领主表记录
|
|
|
MPJLambdaWrapper<WfTextbookClaim> wfTextbookClaimMPJLambdaWrapper = new MPJLambdaWrapper<>();
|
|
|
wfTextbookClaimMPJLambdaWrapper
|
|
|
.disableSubLogicDel()
|
|
|
@@ -97,7 +103,6 @@ public class WfTextbookClaimServiceImpl extends MPJBaseServiceImpl<WfTextbookCla
|
|
|
.selectAs(XjrUser::getName, DistributePageVo::getStudentUserIdCn)
|
|
|
)
|
|
|
.eq(WfTextbookClaim::getBaseSemesterId, dto.getBaseSemesterId())
|
|
|
- .eq(WfTextbookClaim::getWorkflowStatus, 1)
|
|
|
.eq(StringUtils.isNotEmpty(dto.getClaimType()), WfTextbookClaim::getClaimType, dto.getClaimType())
|
|
|
.and(StringUtils.isNotEmpty(dto.getName()),
|
|
|
wrapper -> wrapper
|
|
|
@@ -106,7 +111,10 @@ public class WfTextbookClaimServiceImpl extends MPJBaseServiceImpl<WfTextbookCla
|
|
|
.like(BaseClass::getName, dto.getName())
|
|
|
)
|
|
|
;
|
|
|
+
|
|
|
+ // 发放状态(是否有过发放(1:未发放,2:部分发放,3:全部发放,4:有发放))
|
|
|
if (ObjectUtils.isNotEmpty(dto.getDistributeStatus())) {
|
|
|
+ // 有发放,除了未发放其他所有的状态
|
|
|
if (dto.getDistributeStatus() == 4) {
|
|
|
wfTextbookClaimMPJLambdaWrapper
|
|
|
.ne(WfTextbookClaim::getStatus, 1)
|
|
|
@@ -116,8 +124,9 @@ public class WfTextbookClaimServiceImpl extends MPJBaseServiceImpl<WfTextbookCla
|
|
|
.eq(WfTextbookClaim::getStatus, dto.getDistributeStatus())
|
|
|
;
|
|
|
}
|
|
|
-
|
|
|
}
|
|
|
+
|
|
|
+ // 流程状态(0:未结束,1:已结束,正常通过,2:已结束,未通过,3:作废)
|
|
|
if (ObjectUtils.isNotEmpty(dto.getWorkflowStatus())) {
|
|
|
wfTextbookClaimMPJLambdaWrapper
|
|
|
.eq(WfTextbookClaim::getWorkflowStatus, dto.getWorkflowStatus())
|
|
|
@@ -131,42 +140,95 @@ public class WfTextbookClaimServiceImpl extends MPJBaseServiceImpl<WfTextbookCla
|
|
|
)
|
|
|
;
|
|
|
}
|
|
|
+
|
|
|
IPage<DistributePageVo> page = this.selectJoinListPage(ConventPage.getPage(dto), DistributePageVo.class, wfTextbookClaimMPJLambdaWrapper);
|
|
|
|
|
|
- List<DistributePageVo> distributePageVos = page.getRecords();
|
|
|
-
|
|
|
- // 处理申领总数量和已经发放总数量
|
|
|
- if (ObjectUtils.isNotEmpty(distributePageVos)) {
|
|
|
- List<Long> textbookClaimIds = distributePageVos.stream()
|
|
|
- .map(DistributePageVo::getId)
|
|
|
- .collect(Collectors.toList());
|
|
|
- Map<Long, WfTextbookClaimItem> applicantTatolNumberMap = new HashMap<>();
|
|
|
- WfTextbookClaimItem wfTextbookClaimItem;
|
|
|
- if (ObjectUtils.isNotEmpty(textbookClaimIds)) {
|
|
|
- MPJLambdaWrapper<WfTextbookClaimItem> wfTextbookClaimItemLambdaQueryWrapper = new MPJLambdaWrapper<>();
|
|
|
- wfTextbookClaimItemLambdaQueryWrapper
|
|
|
- .selectAs(WfTextbookClaimItem::getWfTextbookClaimId, WfTextbookClaimItem::getWfTextbookClaimId)
|
|
|
- .selectSum(WfTextbookClaimItem::getApplicantNumber, WfTextbookClaimItem::getApplicantNumber)
|
|
|
- .selectSum(WfTextbookClaimItem::getIssueNumber, WfTextbookClaimItem::getIssueNumber)
|
|
|
- .in(WfTextbookClaimItem::getWfTextbookClaimId, textbookClaimIds)
|
|
|
- .groupBy(WfTextbookClaimItem::getWfTextbookClaimId)
|
|
|
- ;
|
|
|
- List<WfTextbookClaimItem> wfTextbookClaimItemList = wfTextbookClaimWfTextbookClaimItemMapper.selectJoinList(WfTextbookClaimItem.class, wfTextbookClaimItemLambdaQueryWrapper);
|
|
|
- if (ObjectUtils.isNotEmpty(wfTextbookClaimItemList)) {
|
|
|
- applicantTatolNumberMap = wfTextbookClaimItemList.stream()
|
|
|
- .collect(Collectors.toMap(WfTextbookClaimItem::getWfTextbookClaimId, w -> w, (w1, w2) -> w1));
|
|
|
- }
|
|
|
+ // 当申领记录为空
|
|
|
+ List<DistributePageVo> records = page.getRecords();
|
|
|
+
|
|
|
+
|
|
|
+ List<Long> claimIds = records.stream()
|
|
|
+ .map(DistributePageVo::getId)
|
|
|
+ .collect(Collectors.toList());
|
|
|
+
|
|
|
+ // 查询统计数据
|
|
|
+ MPJLambdaWrapper<WfTextbookClaimItem> statsWrapper = new MPJLambdaWrapper<>();
|
|
|
+ statsWrapper
|
|
|
+ .selectAs(WfTextbookClaimItem::getWfTextbookClaimId, WfTextbookClaimItem::getWfTextbookClaimId)
|
|
|
+ .selectSum(WfTextbookClaimItem::getApplicantNumber, WfTextbookClaimItem::getApplicantNumber)
|
|
|
+ .selectSum(WfTextbookClaimItem::getIssueNumber, WfTextbookClaimItem::getIssueNumber)
|
|
|
+ .in(WfTextbookClaimItem::getWfTextbookClaimId, claimIds)
|
|
|
+ .groupBy(WfTextbookClaimItem::getWfTextbookClaimId);
|
|
|
+
|
|
|
+ List<WfTextbookClaimItem> statsList = wfTextbookClaimWfTextbookClaimItemMapper.selectJoinList(WfTextbookClaimItem.class, statsWrapper);
|
|
|
+ Map<Long, WfTextbookClaimItem> statsMap = statsList.stream()
|
|
|
+ .collect(Collectors.toMap(
|
|
|
+ WfTextbookClaimItem::getWfTextbookClaimId,
|
|
|
+ Function.identity(),
|
|
|
+ (w1, w2) -> w1)); // 可视情况记录冲突日志
|
|
|
+
|
|
|
+ // 查询子项数据
|
|
|
+ MPJLambdaWrapper<WfTextbookClaimItem> itemWrapper = new MPJLambdaWrapper<>();
|
|
|
+ itemWrapper.disableSubLogicDel()
|
|
|
+ .select(WfTextbookClaimItem::getId)
|
|
|
+ .selectAs(WfTextbookClaimItem::getApplicantNumber, WfTextbookClaimItemVo::getApplicantNumber)
|
|
|
+ .selectAs(WfTextbookClaimItem::getIssueNumber, WfTextbookClaimItemVo::getIssueNumber)
|
|
|
+ .select(WfTextbookClaimItem.class, x -> VoToColumnUtil.fieldsToColumns(WfTextbookClaimItemVo.class).contains(x.getProperty()))
|
|
|
+ .leftJoin(Textbook.class, Textbook::getId, WfTextbookClaimItem::getTextbookId,
|
|
|
+ w -> w
|
|
|
+ .selectAs(Textbook::getBookName, DistributeRecordVo::getTextbookIdCn)
|
|
|
+ .selectAs(Textbook::getIssn, DistributeRecordVo::getIssn))
|
|
|
+ .in(WfTextbookClaimItem::getWfTextbookClaimId, claimIds);
|
|
|
+
|
|
|
+ List<WfTextbookClaimItemVo> itemList = wfTextbookClaimWfTextbookClaimItemMapper.selectJoinList(WfTextbookClaimItemVo.class, itemWrapper);
|
|
|
+ Map<Long, List<WfTextbookClaimItemVo>> itemMap = itemList.stream()
|
|
|
+ .collect(Collectors.groupingBy(WfTextbookClaimItemVo::getWfTextbookClaimId));
|
|
|
+
|
|
|
+ // 查询发放记录
|
|
|
+ MPJLambdaWrapper<TextbookIssueRecord> recordWrapper = new MPJLambdaWrapper<>();
|
|
|
+ recordWrapper.disableSubLogicDel()
|
|
|
+ .selectAs(TextbookIssueRecord::getDataId, DistributeRecordVo::getWfTextbookClaimId)
|
|
|
+ .selectAs(TextbookIssueRecord::getDataItemId, DistributeRecordVo::getWfTextbookClaimItemId)
|
|
|
+ .selectAs(TextbookIssueRecord::getCreateDate, DistributeRecordVo::getIssueDate)
|
|
|
+ .selectAs(TextbookIssueRecord::getIssueNumber, DistributeRecordVo::getIssueNumber)
|
|
|
+ .selectAs(TextbookIssueRecord::getOrderNumber, DistributeRecordVo::getOrderNumber)
|
|
|
+ .selectAs(TextbookIssueRecord::getRemark, DistributeRecordVo::getRemark)
|
|
|
+ .leftJoin(Textbook.class, Textbook::getId, TextbookIssueRecord::getTextbookId,
|
|
|
+ w -> w
|
|
|
+ .selectAs(Textbook::getBookName, DistributeRecordVo::getTextbookIdCn)
|
|
|
+ .selectAs(Textbook::getIssn, DistributeRecordVo::getIssn))
|
|
|
+ .leftJoin(XjrUser.class, XjrUser::getId, TextbookIssueRecord::getIssueUserId,
|
|
|
+ w -> w
|
|
|
+ .selectAs(XjrUser::getName, DistributeRecordVo::getIssueUser))
|
|
|
+ .in(TextbookIssueRecord::getDataId, claimIds);
|
|
|
+
|
|
|
+ List<DistributeRecordVo> recordList = textbookIssueRecordMapper.selectJoinList(DistributeRecordVo.class, recordWrapper);
|
|
|
+ Map<Long, List<DistributeRecordVo>> recordMap = recordList.stream()
|
|
|
+ .collect(Collectors.groupingBy(DistributeRecordVo::getWfTextbookClaimItemId));
|
|
|
+
|
|
|
+ // 组装数据
|
|
|
+ for (DistributePageVo vo : records) {
|
|
|
+ Long claimId = vo.getId();
|
|
|
+
|
|
|
+ // 填充统计信息
|
|
|
+ if (MapUtils.isNotEmpty(statsMap) && statsMap.containsKey(claimId)) {
|
|
|
+ WfTextbookClaimItem stat = statsMap.get(claimId);
|
|
|
+ vo.setApplicantTatolNumber(stat.getApplicantNumber());
|
|
|
+ vo.setIssueTatolNumber(stat.getIssueNumber());
|
|
|
}
|
|
|
- if (ObjectUtils.isNotEmpty(applicantTatolNumberMap)) {
|
|
|
- for (DistributePageVo distributePageVo : page.getRecords()) {
|
|
|
- wfTextbookClaimItem = applicantTatolNumberMap.get(distributePageVo.getId());
|
|
|
- if (ObjectUtils.isNotEmpty(wfTextbookClaimItem)) {
|
|
|
- distributePageVo.setApplicantTatolNumber(wfTextbookClaimItem.getApplicantNumber());
|
|
|
- distributePageVo.setIssueTatolNumber(wfTextbookClaimItem.getIssueNumber());
|
|
|
+
|
|
|
+ // 填充子项及发放记录
|
|
|
+ if (MapUtils.isNotEmpty(itemMap) && CollectionUtils.isNotEmpty(itemMap.get(claimId))) {
|
|
|
+ List<WfTextbookClaimItemVo> items = itemMap.get(claimId);
|
|
|
+ for (WfTextbookClaimItemVo item : items) {
|
|
|
+ if (recordMap.containsKey(item.getId())) {
|
|
|
+ item.setDistributeRecordVos(recordMap.get(item.getId()));
|
|
|
}
|
|
|
}
|
|
|
+ vo.setWfTextbookClaimItemVoList(items);
|
|
|
}
|
|
|
}
|
|
|
+
|
|
|
return page;
|
|
|
}
|
|
|
|
|
|
@@ -697,7 +759,7 @@ public class WfTextbookClaimServiceImpl extends MPJBaseServiceImpl<WfTextbookCla
|
|
|
}
|
|
|
|
|
|
@Override
|
|
|
- public ByteArrayOutputStream claimRecordsExportQuery(ClaimRecordsExportQueryDto dto) {
|
|
|
+ public ByteArrayOutputStream claimRecordsExportQuery(ClaimRecordsExportQueryDto dto) throws IOException {
|
|
|
MPJLambdaWrapper<WfTextbookClaim> wfTextbookClaimMPJLambdaWrapper = new MPJLambdaWrapper<>();
|
|
|
wfTextbookClaimMPJLambdaWrapper
|
|
|
.disableSubLogicDel()
|
|
|
@@ -724,39 +786,112 @@ public class WfTextbookClaimServiceImpl extends MPJBaseServiceImpl<WfTextbookCla
|
|
|
;
|
|
|
List<ClaimRecordsExportQueryVo> dataList = this.selectJoinList(ClaimRecordsExportQueryVo.class, wfTextbookClaimMPJLambdaWrapper);
|
|
|
|
|
|
- // 处理申领总数量和已经发放总数量
|
|
|
- if (ObjectUtils.isNotEmpty(dataList)) {
|
|
|
- List<Long> textbookClaimIds = dataList.stream()
|
|
|
- .map(ClaimRecordsExportQueryVo::getId)
|
|
|
- .collect(Collectors.toList());
|
|
|
- Map<Long, WfTextbookClaimItem> applicantTatolNumberMap = new HashMap<>();
|
|
|
- WfTextbookClaimItem wfTextbookClaimItem;
|
|
|
- if (ObjectUtils.isNotEmpty(textbookClaimIds)) {
|
|
|
- MPJLambdaWrapper<WfTextbookClaimItem> wfTextbookClaimItemLambdaQueryWrapper = new MPJLambdaWrapper<>();
|
|
|
- wfTextbookClaimItemLambdaQueryWrapper
|
|
|
- .selectAs(WfTextbookClaimItem::getWfTextbookClaimId, WfTextbookClaimItem::getWfTextbookClaimId)
|
|
|
- .selectSum(WfTextbookClaimItem::getApplicantNumber, WfTextbookClaimItem::getApplicantNumber)
|
|
|
- .selectSum(WfTextbookClaimItem::getIssueNumber, WfTextbookClaimItem::getIssueNumber)
|
|
|
- .in(WfTextbookClaimItem::getWfTextbookClaimId, textbookClaimIds)
|
|
|
- .groupBy(WfTextbookClaimItem::getWfTextbookClaimId)
|
|
|
- ;
|
|
|
- List<WfTextbookClaimItem> wfTextbookClaimItemList = wfTextbookClaimWfTextbookClaimItemMapper.selectJoinList(WfTextbookClaimItem.class, wfTextbookClaimItemLambdaQueryWrapper);
|
|
|
- if (ObjectUtils.isNotEmpty(wfTextbookClaimItemList)) {
|
|
|
- applicantTatolNumberMap = wfTextbookClaimItemList.stream()
|
|
|
- .collect(Collectors.toMap(WfTextbookClaimItem::getWfTextbookClaimId, w -> w, (w1, w2) -> w1));
|
|
|
- }
|
|
|
- }
|
|
|
- if (ObjectUtils.isNotEmpty(applicantTatolNumberMap)) {
|
|
|
- for (ClaimRecordsExportQueryVo vo : dataList) {
|
|
|
- wfTextbookClaimItem = applicantTatolNumberMap.get(vo.getId());
|
|
|
- if (ObjectUtils.isNotEmpty(wfTextbookClaimItem)) {
|
|
|
- vo.setApplicantTatolNumber(wfTextbookClaimItem.getApplicantNumber());
|
|
|
- vo.setIssueTatolNumber(wfTextbookClaimItem.getIssueNumber());
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
+ List<Long> claimIds = dataList.stream()
|
|
|
+ .map(ClaimRecordsExportQueryVo::getId)
|
|
|
+ .collect(Collectors.toList());
|
|
|
+
|
|
|
+ // 查询统计数据
|
|
|
+ MPJLambdaWrapper<WfTextbookClaimItem> statsWrapper = new MPJLambdaWrapper<>();
|
|
|
+ statsWrapper
|
|
|
+ .selectAs(WfTextbookClaimItem::getWfTextbookClaimId, WfTextbookClaimItem::getWfTextbookClaimId)
|
|
|
+ .selectSum(WfTextbookClaimItem::getApplicantNumber, WfTextbookClaimItem::getApplicantNumber)
|
|
|
+ .selectSum(WfTextbookClaimItem::getIssueNumber, WfTextbookClaimItem::getIssueNumber)
|
|
|
+ .in(WfTextbookClaimItem::getWfTextbookClaimId, claimIds)
|
|
|
+ .groupBy(WfTextbookClaimItem::getWfTextbookClaimId);
|
|
|
+
|
|
|
+ List<WfTextbookClaimItem> statsList = wfTextbookClaimWfTextbookClaimItemMapper.selectJoinList(WfTextbookClaimItem.class, statsWrapper);
|
|
|
+ Map<Long, WfTextbookClaimItem> statsMap = statsList.stream()
|
|
|
+ .collect(Collectors.toMap(
|
|
|
+ WfTextbookClaimItem::getWfTextbookClaimId,
|
|
|
+ Function.identity(),
|
|
|
+ (w1, w2) -> w1)); // 可视情况记录冲突日志
|
|
|
+
|
|
|
+ // 查询子项数据
|
|
|
+ MPJLambdaWrapper<WfTextbookClaimItem> itemWrapper = new MPJLambdaWrapper<>();
|
|
|
+ itemWrapper.disableSubLogicDel()
|
|
|
+ .select(WfTextbookClaimItem::getId)
|
|
|
+ .selectAs(WfTextbookClaimItem::getApplicantNumber, WfTextbookClaimItemVo::getApplicantNumber)
|
|
|
+ .selectAs(WfTextbookClaimItem::getIssueNumber, WfTextbookClaimItemVo::getIssueNumber)
|
|
|
+ .select(WfTextbookClaimItem.class, x -> VoToColumnUtil.fieldsToColumns(WfTextbookClaimItemVo.class).contains(x.getProperty()))
|
|
|
+ .leftJoin(Textbook.class, Textbook::getId, WfTextbookClaimItem::getTextbookId,
|
|
|
+ w -> w
|
|
|
+ .selectAs(Textbook::getBookName, DistributeRecordVo::getTextbookIdCn)
|
|
|
+ .selectAs(Textbook::getIssn, DistributeRecordVo::getIssn))
|
|
|
+ .in(WfTextbookClaimItem::getWfTextbookClaimId, claimIds);
|
|
|
+
|
|
|
+ List<WfTextbookClaimItemVo> itemList = wfTextbookClaimWfTextbookClaimItemMapper.selectJoinList(WfTextbookClaimItemVo.class, itemWrapper);
|
|
|
+ Map<Long, List<WfTextbookClaimItemVo>> itemMap = itemList.stream()
|
|
|
+ .collect(Collectors.groupingBy(WfTextbookClaimItemVo::getWfTextbookClaimId));
|
|
|
+
|
|
|
+ // 查询发放记录
|
|
|
+ MPJLambdaWrapper<TextbookIssueRecord> recordWrapper = new MPJLambdaWrapper<>();
|
|
|
+ recordWrapper.disableSubLogicDel()
|
|
|
+ .selectAs(TextbookIssueRecord::getDataId, DistributeRecordVo::getWfTextbookClaimId)
|
|
|
+ .selectAs(TextbookIssueRecord::getDataItemId, DistributeRecordVo::getWfTextbookClaimItemId)
|
|
|
+ .selectAs(TextbookIssueRecord::getCreateDate, DistributeRecordVo::getIssueDate)
|
|
|
+ .selectAs(TextbookIssueRecord::getIssueNumber, DistributeRecordVo::getIssueNumber)
|
|
|
+ .selectAs(TextbookIssueRecord::getOrderNumber, DistributeRecordVo::getOrderNumber)
|
|
|
+ .selectAs(TextbookIssueRecord::getRemark, DistributeRecordVo::getRemark)
|
|
|
+ .leftJoin(Textbook.class, Textbook::getId, TextbookIssueRecord::getTextbookId,
|
|
|
+ w -> w
|
|
|
+ .selectAs(Textbook::getBookName, DistributeRecordVo::getTextbookIdCn)
|
|
|
+ .selectAs(Textbook::getIssn, DistributeRecordVo::getIssn))
|
|
|
+ .leftJoin(XjrUser.class, XjrUser::getId, TextbookIssueRecord::getIssueUserId,
|
|
|
+ w -> w
|
|
|
+ .selectAs(XjrUser::getName, DistributeRecordVo::getIssueUser))
|
|
|
+ .in(TextbookIssueRecord::getDataId, claimIds);
|
|
|
+
|
|
|
+ List<DistributeRecordVo> recordList = textbookIssueRecordMapper.selectJoinList(DistributeRecordVo.class, recordWrapper);
|
|
|
+ Map<Long, List<DistributeRecordVo>> recordMap = recordList.stream()
|
|
|
+ .collect(Collectors.groupingBy(DistributeRecordVo::getWfTextbookClaimItemId));
|
|
|
+
|
|
|
+ // 开始写入
|
|
|
+ Workbook workbook = new XSSFWorkbook();
|
|
|
+ // 创建一个工作表(sheet)
|
|
|
+ String sheetName = "sheet1";
|
|
|
+ Sheet sheet = workbook.createSheet(sheetName);
|
|
|
+
|
|
|
+ // 出参vo字段数量
|
|
|
+ ClaimRecordsExportQueryVo obj = new ClaimRecordsExportQueryVo();
|
|
|
+ List<ImportConfig> importConfigs = ImportExcelUtil.allFields(obj);
|
|
|
+
|
|
|
+ // 写大标题
|
|
|
+ int rowNumber = 0;
|
|
|
+ ImportExcelUtil.createBigHead(workbook, sheet, "教材申领情况", rowNumber++, importConfigs.size() - 1);
|
|
|
+
|
|
|
+ // 表头
|
|
|
+ ImportExcelUtil.createHead(workbook, sheet, importConfigs, IndexedColors.YELLOW.getIndex(), IndexedColors.RED.getIndex(), rowNumber++);
|
|
|
+
|
|
|
+ // 字体内容格式
|
|
|
+ Font font = workbook.createFont();
|
|
|
+ font.setBold(false);// 设置为粗体
|
|
|
+ font.setFontName("宋体");
|
|
|
+ font.setFontHeightInPoints((short) 12);
|
|
|
+
|
|
|
+ // 单元格样式
|
|
|
+ CellStyle cellStyle = workbook.createCellStyle();
|
|
|
+ cellStyle.setFont(font); // 将字体应用到样式
|
|
|
+ cellStyle.setVerticalAlignment(VerticalAlignment.CENTER);
|
|
|
+ cellStyle.setAlignment(HorizontalAlignment.CENTER);
|
|
|
+
|
|
|
+ // 设置边框样式为细线
|
|
|
+ cellStyle.setBorderTop(BorderStyle.THIN);
|
|
|
+ cellStyle.setTopBorderColor(IndexedColors.BLACK.getIndex()); // 设置顶部边框颜色
|
|
|
+
|
|
|
+ cellStyle.setBorderBottom(BorderStyle.THIN);
|
|
|
+ cellStyle.setBottomBorderColor(IndexedColors.BLACK.getIndex()); // 设置底部边框颜色
|
|
|
+
|
|
|
+ cellStyle.setBorderLeft(BorderStyle.THIN);
|
|
|
+ cellStyle.setLeftBorderColor(IndexedColors.BLACK.getIndex()); // 设置左边框颜色
|
|
|
+
|
|
|
+ cellStyle.setBorderRight(BorderStyle.THIN);
|
|
|
+ cellStyle.setRightBorderColor(IndexedColors.BLACK.getIndex()); // 设置右边框颜色
|
|
|
+
|
|
|
+ // 记录写入
|
|
|
+ List<String> claimVo;
|
|
|
+ List<String> claimItemVo;
|
|
|
+ List<String> claimItemIssueVo;
|
|
|
+ DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
|
|
|
for (ClaimRecordsExportQueryVo vo : dataList) {
|
|
|
if (ObjectUtils.isNotEmpty(vo.getClaimType()) && ClaimTypeEnum.ClaimClass.getCode().equals(vo.getClaimType())) {
|
|
|
vo.setReceiver(vo.getClassIdCn());
|
|
|
@@ -772,11 +907,105 @@ public class WfTextbookClaimServiceImpl extends MPJBaseServiceImpl<WfTextbookCla
|
|
|
} else {
|
|
|
vo.setStatusStr("未发放");
|
|
|
}
|
|
|
+
|
|
|
+ Long claimId = vo.getId();
|
|
|
+
|
|
|
+ // 填充统计信息
|
|
|
+ if (MapUtils.isNotEmpty(statsMap) && statsMap.containsKey(claimId)) {
|
|
|
+ WfTextbookClaimItem stat = statsMap.get(claimId);
|
|
|
+ vo.setApplicantTatolNumber(stat.getApplicantNumber());
|
|
|
+ vo.setIssueTatolNumber(stat.getIssueNumber());
|
|
|
+ }
|
|
|
+
|
|
|
+ // 申领总记录
|
|
|
+ claimVo = new ArrayList<>();
|
|
|
+ claimVo.add(vo.getBaseSemesterIdCn());
|
|
|
+ claimVo.add(vo.getClaimTypeCn());
|
|
|
+ claimVo.add(vo.getReceiver());
|
|
|
+ if (StringUtils.isNotEmpty(vo.getClassIdCn())) {
|
|
|
+ claimVo.add(vo.getClassIdCn());
|
|
|
+ } else {
|
|
|
+ claimVo.add("无");
|
|
|
+ }
|
|
|
+ claimVo.add(vo.getApplicantTatolNumber() + "");
|
|
|
+ claimVo.add(vo.getStatusStr());
|
|
|
+ claimVo.add(vo.getIssueTatolNumber() + "");
|
|
|
+
|
|
|
+ // 填充子项及发放记录
|
|
|
+ int mergeClaim = 0;
|
|
|
+ if (MapUtils.isNotEmpty(itemMap) && CollectionUtils.isNotEmpty(itemMap.get(claimId))) {
|
|
|
+ List<WfTextbookClaimItemVo> items = itemMap.get(claimId);
|
|
|
+ for (WfTextbookClaimItemVo item : items) {
|
|
|
+ mergeClaim++;
|
|
|
+ claimItemVo = new ArrayList<>(claimVo);
|
|
|
+ claimItemVo.add(item.getTextbookIdCN());
|
|
|
+ claimItemVo.add(item.getIssn());
|
|
|
+ claimItemVo.add(item.getApplicantNumber() + "");
|
|
|
+ claimItemVo.add(item.getIssueNumber() + "");
|
|
|
+
|
|
|
+ int mergeClaimItem = 0;
|
|
|
+ if (recordMap.containsKey(item.getId())) {
|
|
|
+ List<DistributeRecordVo> issues = recordMap.get(item.getId());
|
|
|
+ for (DistributeRecordVo issue : issues) {
|
|
|
+ mergeClaimItem++;
|
|
|
+ claimItemIssueVo = new ArrayList<>(claimItemVo);
|
|
|
+ LocalDateTime localDateTime = issue.getIssueDate().toInstant()
|
|
|
+ .atZone(ZoneId.systemDefault())
|
|
|
+ .toLocalDateTime();
|
|
|
+ claimItemIssueVo.add(localDateTime.format(formatter));
|
|
|
+ claimItemIssueVo.add(issue.getIssueUser());
|
|
|
+ claimItemIssueVo.add(issue.getOrderNumber());
|
|
|
+ claimItemIssueVo.add(issue.getIssueNumber() + "");
|
|
|
+
|
|
|
+ Row dataRow = sheet.createRow(rowNumber++);
|
|
|
+ for (int j = 0; j < claimItemIssueVo.size(); j++) {
|
|
|
+ String content = claimItemIssueVo.get(j);
|
|
|
+ Cell cell = dataRow.createCell(j);
|
|
|
+ cell.setCellValue(content);
|
|
|
+ cell.setCellStyle(cellStyle);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ // 合并申领项
|
|
|
+ if (mergeClaimItem > 1) {
|
|
|
+ for (int k = 7; k < 11; k++) {
|
|
|
+ sheet.addMergedRegion(new CellRangeAddress(rowNumber - mergeClaimItem, rowNumber - 1, k, k));
|
|
|
+ }
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ Row dataRow = sheet.createRow(rowNumber++);
|
|
|
+ for (int j = 0; j < claimItemVo.size(); j++) {
|
|
|
+ String content = claimItemVo.get(j);
|
|
|
+ Cell cell = dataRow.createCell(j);
|
|
|
+ cell.setCellValue(content);
|
|
|
+ cell.setCellStyle(cellStyle);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ // 合并申领
|
|
|
+ if (mergeClaim > 1) {
|
|
|
+ for (int k = 0; k < 7; k++) {
|
|
|
+ sheet.addMergedRegion(new CellRangeAddress(rowNumber - mergeClaim, rowNumber - 1, k, k));
|
|
|
+ }
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ Row dataRow = sheet.createRow(rowNumber++);
|
|
|
+ for (int j = 0; j < claimVo.size(); j++) {
|
|
|
+ String content = claimVo.get(j);
|
|
|
+ Cell cell = dataRow.createCell(j);
|
|
|
+ cell.setCellValue(content);
|
|
|
+ cell.setCellStyle(cellStyle);
|
|
|
+ }
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
- ByteArrayOutputStream bot = new ByteArrayOutputStream();
|
|
|
- EasyExcel.write(bot, ClaimRecordsExportQueryVo.class).automaticMergeHead(false).excelType(ExcelTypeEnum.XLSX).sheet().doWrite(dataList);
|
|
|
+ // 自动列宽
|
|
|
+ for (int i = 0; i < importConfigs.size(); i++) {
|
|
|
+ sheet.autoSizeColumn(i);
|
|
|
+ }
|
|
|
|
|
|
+ ByteArrayOutputStream bot = new ByteArrayOutputStream();
|
|
|
+ workbook.write(bot);
|
|
|
return bot;
|
|
|
}
|
|
|
}
|