All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.kangaroohy.plugin.excel.handler.SingleSheetWriteHandler Maven / Gradle / Ivy

package com.kangaroohy.plugin.excel.handler;

import com.alibaba.excel.ExcelWriter;
import com.alibaba.excel.converters.Converter;
import com.alibaba.excel.write.metadata.WriteSheet;
import com.kangaroohy.plugin.excel.annotation.ResponseExcel;
import com.kangaroohy.plugin.excel.annotation.Sheet;
import com.kangaroohy.plugin.excel.config.ExcelConfigProperties;
import com.kangaroohy.plugin.excel.domain.SheetBuildProperties;
import com.kangaroohy.plugin.excel.enhance.WriterBuilderEnhancer;
import com.kangaroohy.plugin.excel.kit.ExcelException;
import org.springframework.beans.factory.ObjectProvider;

import javax.servlet.http.HttpServletResponse;
import java.util.List;

/**
 * @author kangaroohy
 * @author kangaroohy
 * @author kangaroohy
 * @date 2020/3/29
 * 

* 处理单sheet 页面 */ public class SingleSheetWriteHandler extends AbstractSheetWriteHandler { public SingleSheetWriteHandler(ExcelConfigProperties configProperties, ObjectProvider>> converterProvider, WriterBuilderEnhancer excelWriterBuilderEnhance) { super(configProperties, converterProvider, excelWriterBuilderEnhance); } /** * obj 是List 且list不为空同时list中的元素不是是List 才返回true * @param obj 返回对象 * @return boolean */ @Override public boolean support(Object obj) { if (obj instanceof List) { List objList = (List) obj; return !objList.isEmpty() && !(objList.get(0) instanceof List); } else { throw new ExcelException("@ResponseExcel 返回值必须为List类型"); } } @Override public void write(Object obj, HttpServletResponse response, ResponseExcel responseExcel) { List eleList = (List) obj; ExcelWriter excelWriter = getExcelWriter(response, responseExcel); // 获取 Sheet 配置 SheetBuildProperties sheetBuildProperties; Sheet[] sheets = responseExcel.sheets(); if (sheets != null && sheets.length > 0) { sheetBuildProperties = new SheetBuildProperties(sheets[0]); } else { sheetBuildProperties = new SheetBuildProperties(0); } // 模板信息 String template = responseExcel.template(); // 创建sheet WriteSheet sheet; if (eleList.isEmpty()) { sheet = this.emptySheet(sheetBuildProperties, template); } else { Class dataClass = eleList.get(0).getClass(); sheet = this.emptySheet(sheetBuildProperties, dataClass, template, responseExcel.headGenerator()); } if (responseExcel.fill()) { // 填充 sheet excelWriter.fill(eleList, sheet); } else { // 写入 sheet excelWriter.write(eleList, sheet); } excelWriter.finish(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy