You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
191 lines
7.8 KiB
191 lines
7.8 KiB
/*******************************************************************************
|
|
* Copyright 2017 Bstek
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
|
|
* use this file except in compliance with the License. You may obtain a copy
|
|
* of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
* License for the specific language governing permissions and limitations under
|
|
* the License.
|
|
******************************************************************************/
|
|
package com.bstek.ureport.export;
|
|
|
|
import java.util.List;
|
|
import java.util.Map;
|
|
|
|
import com.bstek.ureport.build.paging.Page;
|
|
import com.bstek.ureport.cache.CacheUtils;
|
|
import com.bstek.ureport.definition.ReportDefinition;
|
|
import com.bstek.ureport.export.excel.high.ExcelProducer;
|
|
import com.bstek.ureport.export.excel.low.Excel97Producer;
|
|
import com.bstek.ureport.export.html.HtmlProducer;
|
|
import com.bstek.ureport.export.html.HtmlReport;
|
|
import com.bstek.ureport.export.pdf.PdfProducer;
|
|
import com.bstek.ureport.export.word.high.WordProducer;
|
|
import com.bstek.ureport.model.Report;
|
|
|
|
/**
|
|
* @author Jacky.gao
|
|
* @since 2016年12月4日
|
|
*/
|
|
public class ExportManagerImpl implements ExportManager {
|
|
private ReportRender reportRender;
|
|
private HtmlProducer htmlProducer=new HtmlProducer();
|
|
private WordProducer wordProducer=new WordProducer();
|
|
private ExcelProducer excelProducer=new ExcelProducer();
|
|
private Excel97Producer excel97Producer=new Excel97Producer();
|
|
private PdfProducer pdfProducer=new PdfProducer();
|
|
@Override
|
|
public HtmlReport exportHtml(String file,String contextPath,Map<String, Object> parameters) {
|
|
ReportDefinition reportDefinition=reportRender.getReportDefinition(file);
|
|
Report report=reportRender.render(reportDefinition, parameters);
|
|
String fullName=file+parameters.toString();
|
|
CacheUtils.storeReport(fullName, report);
|
|
HtmlReport htmlReport=new HtmlReport();
|
|
String content=htmlProducer.produce(report);
|
|
htmlReport.setContent(content);
|
|
htmlReport.setStyle(reportDefinition.getStyle());
|
|
htmlReport.setSearchFormData(reportDefinition.buildSearchFormData(report.getContext().getDatasetMap()));
|
|
htmlReport.setReportAlign(report.getPaper().getHtmlReportAlign().name());
|
|
htmlReport.setChartDatas(report.getContext().getChartDataMap().values());
|
|
htmlReport.setHtmlIntervalRefreshValue(report.getPaper().getHtmlIntervalRefreshValue());
|
|
return htmlReport;
|
|
}
|
|
|
|
@Override
|
|
public HtmlReport exportHtml(String file,String contextPath,Map<String, Object> parameters, int pageIndex) {
|
|
ReportDefinition reportDefinition=reportRender.getReportDefinition(file);
|
|
String fullName=file+parameters.toString();
|
|
Report report=CacheUtils.getReport(fullName);
|
|
if (report == null) {
|
|
report = reportRender.render(reportDefinition, parameters);
|
|
}
|
|
SinglePageData pageData=PageBuilder.buildSinglePageData(pageIndex, report);
|
|
List<Page> pages=pageData.getPages();
|
|
String content=null;
|
|
if(pages.size()==1){
|
|
content=htmlProducer.produce(report.getContext(),pages.get(0),false);
|
|
}else{
|
|
content=htmlProducer.produce(report.getContext(),pages,pageData.getColumnMargin(),false);
|
|
}
|
|
HtmlReport htmlReport=new HtmlReport();
|
|
htmlReport.setContent(content);
|
|
htmlReport.setStyle(reportDefinition.getStyle());
|
|
htmlReport.setSearchFormData(reportDefinition.buildSearchFormData(report.getContext().getDatasetMap()));
|
|
htmlReport.setPageIndex(pageIndex);
|
|
htmlReport.setTotalPage(pageData.getTotalPages());
|
|
htmlReport.setReportAlign(report.getPaper().getHtmlReportAlign().name());
|
|
htmlReport.setChartDatas(report.getContext().getChartDataMap().values());
|
|
htmlReport.setHtmlIntervalRefreshValue(report.getPaper().getHtmlIntervalRefreshValue());
|
|
return htmlReport;
|
|
}
|
|
@Override
|
|
public void exportPdf(ExportConfigure config) {
|
|
String file=config.getFile();
|
|
Map<String, Object> parameters=config.getParameters();
|
|
String fullName=file+parameters.toString();
|
|
Report report=CacheUtils.getReport(fullName);
|
|
if (report == null) {
|
|
ReportDefinition reportDefinition=reportRender.getReportDefinition(file);
|
|
report = reportRender.render(reportDefinition, parameters);
|
|
}
|
|
pdfProducer.produce(report, config.getOutputStream());
|
|
}
|
|
@Override
|
|
public void exportWord(ExportConfigure config) {
|
|
String file=config.getFile();
|
|
Map<String, Object> parameters=config.getParameters();
|
|
String fullName=file+parameters.toString();
|
|
Report report=CacheUtils.getReport(fullName);
|
|
if (report == null) {
|
|
ReportDefinition reportDefinition=reportRender.getReportDefinition(file);
|
|
report = reportRender.render(reportDefinition, parameters);
|
|
}
|
|
wordProducer.produce(report, config.getOutputStream());
|
|
}
|
|
@Override
|
|
public void exportExcel(ExportConfigure config) {
|
|
String file=config.getFile();
|
|
Map<String, Object> parameters=config.getParameters();
|
|
String fullName=file+parameters.toString();
|
|
Report report=CacheUtils.getReport(fullName);
|
|
if (report == null) {
|
|
ReportDefinition reportDefinition=reportRender.getReportDefinition(file);
|
|
report = reportRender.render(reportDefinition, parameters);
|
|
}
|
|
excelProducer.produce(report, config.getOutputStream());
|
|
}
|
|
|
|
@Override
|
|
public void exportExcel97(ExportConfigure config) {
|
|
String file=config.getFile();
|
|
Map<String, Object> parameters=config.getParameters();
|
|
String fullName=file+parameters.toString();
|
|
Report report=CacheUtils.getReport(fullName);
|
|
if (report == null) {
|
|
ReportDefinition reportDefinition=reportRender.getReportDefinition(file);
|
|
report = reportRender.render(reportDefinition, parameters);
|
|
}
|
|
excel97Producer.produce(report, config.getOutputStream());
|
|
}
|
|
|
|
@Override
|
|
public void exportExcelWithPaging(ExportConfigure config) {
|
|
String file=config.getFile();
|
|
Map<String, Object> parameters=config.getParameters();
|
|
String fullName=file+parameters.toString();
|
|
Report report=CacheUtils.getReport(fullName);
|
|
if (report == null) {
|
|
ReportDefinition reportDefinition=reportRender.getReportDefinition(file);
|
|
report = reportRender.render(reportDefinition, parameters);
|
|
}
|
|
excelProducer.produceWithPaging(report, config.getOutputStream());
|
|
}
|
|
@Override
|
|
public void exportExcel97WithPaging(ExportConfigure config) {
|
|
String file=config.getFile();
|
|
Map<String, Object> parameters=config.getParameters();
|
|
String fullName=file+parameters.toString();
|
|
Report report=CacheUtils.getReport(fullName);
|
|
if (report == null) {
|
|
ReportDefinition reportDefinition=reportRender.getReportDefinition(file);
|
|
report = reportRender.render(reportDefinition, parameters);
|
|
}
|
|
excel97Producer.produceWithPaging(report, config.getOutputStream());
|
|
}
|
|
|
|
@Override
|
|
public void exportExcelWithPagingSheet(ExportConfigure config) {
|
|
String file=config.getFile();
|
|
Map<String, Object> parameters=config.getParameters();
|
|
String fullName=file+parameters.toString();
|
|
Report report=CacheUtils.getReport(fullName);
|
|
if (report == null) {
|
|
ReportDefinition reportDefinition=reportRender.getReportDefinition(file);
|
|
report = reportRender.render(reportDefinition, parameters);
|
|
}
|
|
excelProducer.produceWithSheet(report, config.getOutputStream());
|
|
}
|
|
|
|
@Override
|
|
public void exportExcel97WithPagingSheet(ExportConfigure config) {
|
|
String file=config.getFile();
|
|
Map<String, Object> parameters=config.getParameters();
|
|
String fullName=file+parameters.toString();
|
|
Report report=CacheUtils.getReport(fullName);
|
|
if (report == null) {
|
|
ReportDefinition reportDefinition=reportRender.getReportDefinition(file);
|
|
report = reportRender.render(reportDefinition, parameters);
|
|
}
|
|
excel97Producer.produceWithSheet(report, config.getOutputStream());
|
|
}
|
|
|
|
public void setReportRender(ReportRender reportRender) {
|
|
this.reportRender = reportRender;
|
|
}
|
|
}
|
|
|