From 095c52c6ec7882ce11177178b49d33e6c886af61 Mon Sep 17 00:00:00 2001
From: peng <peng.com>
Date: 星期一, 17 十一月 2025 15:02:38 +0800
Subject: [PATCH] 添加已完成标识
---
framework/src/main/java/cn/lili/modules/lmk/service/impl/PrizeGrantRecordServiceImpl.java | 81 ++++++++++++++++++++++++++++++++++++++++
1 files changed, 81 insertions(+), 0 deletions(-)
diff --git a/framework/src/main/java/cn/lili/modules/lmk/service/impl/PrizeGrantRecordServiceImpl.java b/framework/src/main/java/cn/lili/modules/lmk/service/impl/PrizeGrantRecordServiceImpl.java
index 78f34d3..848f588 100644
--- a/framework/src/main/java/cn/lili/modules/lmk/service/impl/PrizeGrantRecordServiceImpl.java
+++ b/framework/src/main/java/cn/lili/modules/lmk/service/impl/PrizeGrantRecordServiceImpl.java
@@ -1,5 +1,7 @@
package cn.lili.modules.lmk.service.impl;
+import cn.lili.modules.lmk.enums.general.PrizeGrantStatusEnums;
+import cn.lili.modules.order.order.entity.dto.PrizeGrantRecordExportDetailDtO;
import com.baomidou.mybatisplus.core.metadata.IPage;
import cn.lili.modules.lmk.domain.entity.PrizeGrantRecord;
import cn.lili.modules.lmk.mapper.PrizeGrantRecordMapper;
@@ -9,12 +11,21 @@
import cn.lili.modules.lmk.domain.form.PrizeGrantRecordForm;
import cn.lili.modules.lmk.domain.vo.PrizeGrantRecordVO;
import cn.lili.modules.lmk.domain.query.PrizeGrantRecordQuery;
+import org.apache.poi.ss.usermodel.Cell;
+import org.apache.poi.ss.usermodel.Row;
+import org.apache.poi.ss.usermodel.Sheet;
+import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.stereotype.Service;
import lombok.RequiredArgsConstructor;
import cn.lili.utils.PageUtil;
import org.springframework.beans.BeanUtils;
import org.springframework.util.Assert;
+import javax.servlet.ServletOutputStream;
+import javax.servlet.http.HttpServletResponse;
+import java.net.URLEncoder;
+import java.text.SimpleDateFormat;
+import java.util.ArrayList;
import java.util.List;
import java.util.stream.Collectors;
@@ -30,6 +41,76 @@
private final PrizeGrantRecordMapper prizeGrantRecordMapper;
+ @Override
+ public void queryExportStock(HttpServletResponse response, PrizeGrantRecordQuery query){
+ List<PrizeGrantRecordVO> list = baseMapper.getExportData(query);
+ XSSFWorkbook workbook = initExportData(list);
+ try {
+ // 璁剧疆鍝嶅簲澶�
+ String fileName = URLEncoder.encode("濂栧搧鍙戞斁璁板綍", "UTF-8");
+ response.setContentType("application/vnd.ms-excel;charset=UTF-8");
+ response.setHeader("Content-Disposition", "attachment;filename=" + fileName + ".xlsx");
+
+ ServletOutputStream out = response.getOutputStream();
+ workbook.write(out);
+ } catch (Exception e) {
+ e.printStackTrace();
+ } finally {
+ try {
+ workbook.close();
+ } catch (Exception e) {
+ e.printStackTrace();
+ }
+ }
+ }
+ private XSSFWorkbook initExportData(List<PrizeGrantRecordVO> list){
+ List<PrizeGrantRecordExportDetailDtO> exportDetailDtOS = new ArrayList<>();
+ for (PrizeGrantRecordVO vo : list){
+ PrizeGrantRecordExportDetailDtO detailDtO = new PrizeGrantRecordExportDetailDtO();
+ BeanUtils.copyProperties(vo,detailDtO);
+ SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+ // 灏咲ate绫诲瀷杞崲涓烘寚瀹氭牸寮忕殑瀛楃涓�
+ String createTimeStr = sdf.format(vo.getCreateTime());
+ // 璁剧疆鍒癉TO涓�
+ detailDtO.setCreateTime(createTimeStr);
+ exportDetailDtOS.add(detailDtO);
+ }
+
+ XSSFWorkbook workbook = new XSSFWorkbook();
+
+ Sheet sheet = workbook.createSheet("濂栧搧鍙戞斁璁板綍");
+ // 鍒涘缓琛ㄥご
+ Row header = sheet.createRow(0);
+ String[] headers = {
+ "鐢ㄦ埛鏄电О", "娲诲姩鍚�","鍟嗗搧鍚�",
+ "鍟嗗搧鍐呭","鍙戞斁鐘舵��"
+ ,"鎻忚堪","鍙戝竷鏃堕棿"
+ };
+ for(int i= 0 ;i< headers.length;i++){
+ Cell cell = header.createCell(i);
+ cell.setCellValue(headers[i]);
+ }
+ for (int i=0;i< exportDetailDtOS.size();i++){
+ PrizeGrantRecordExportDetailDtO dto = exportDetailDtOS.get(i);
+ Row row = sheet.createRow(i+1);
+ row.createCell(0).setCellValue(dto.getNickName());
+ row.createCell(1).setCellValue(dto.getActivityName());
+ row.createCell(2).setCellValue(dto.getPrizeName());
+ row.createCell(3).setCellValue(dto.getPrizeContent());
+ if (PrizeGrantStatusEnums.SUCCESS.name().equals(dto.getGrantStatus())){
+ row.createCell(4).setCellValue(PrizeGrantStatusEnums.SUCCESS.getDescription());
+ }else {
+ row.createCell(4).setCellValue(PrizeGrantStatusEnums.FAILED.getDescription());
+
+ }
+
+ row.createCell(5).setCellValue(dto.getDes());
+ row.createCell(6).setCellValue(dto.getCreateTime());
+ }
+
+ return workbook;
+ }
+
/**
* 娣诲姞
* @param form
--
Gitblit v1.8.0