1 | |
package org.jtheque.films.services.impl.utils.file.exports; |
2 | |
|
3 | |
|
4 | |
|
5 | |
|
6 | |
|
7 | |
|
8 | |
|
9 | |
|
10 | |
|
11 | |
|
12 | |
|
13 | |
|
14 | |
|
15 | |
|
16 | |
|
17 | |
|
18 | |
|
19 | |
import net.sf.jasperreports.engine.JRException; |
20 | |
import net.sf.jasperreports.engine.JRExporterParameter; |
21 | |
import net.sf.jasperreports.engine.JasperCompileManager; |
22 | |
import net.sf.jasperreports.engine.JasperFillManager; |
23 | |
import net.sf.jasperreports.engine.JasperPrint; |
24 | |
import net.sf.jasperreports.engine.JasperReport; |
25 | |
import net.sf.jasperreports.engine.design.JasperDesign; |
26 | |
import net.sf.jasperreports.engine.export.JExcelApiExporter; |
27 | |
import net.sf.jasperreports.engine.export.JExcelApiExporterParameter; |
28 | |
import net.sf.jasperreports.engine.export.JRXlsAbstractExporter; |
29 | |
import net.sf.jasperreports.engine.xml.JRXmlLoader; |
30 | |
import org.jtheque.core.managers.Managers; |
31 | |
import org.jtheque.core.managers.language.ILanguageManager; |
32 | |
import org.jtheque.core.managers.log.ILoggingManager; |
33 | |
import org.jtheque.films.services.impl.utils.file.exports.datasources.FilmsDatasource; |
34 | |
import org.jtheque.films.utils.Constants.Files.FileType; |
35 | |
import org.jtheque.films.utils.Constants.Properties.Film; |
36 | |
import org.jtheque.films.utils.Constants.Properties.Form001; |
37 | |
import org.jtheque.films.utils.Constants.Report; |
38 | |
import org.jtheque.films.utils.Constants.Report.Form001_Parameters; |
39 | |
|
40 | |
import java.util.HashMap; |
41 | |
import java.util.Map; |
42 | |
|
43 | |
|
44 | |
|
45 | |
|
46 | |
|
47 | |
|
48 | 0 | public final class XLSExporter extends AbstractExporter<org.jtheque.films.persistence.od.able.Film> { |
49 | |
@Override |
50 | |
public boolean canExportTo(FileType fileType) { |
51 | 0 | return fileType == FileType.XLS; |
52 | |
} |
53 | |
|
54 | |
@Override |
55 | |
public void export(String path) { |
56 | |
try { |
57 | 0 | JasperDesign jasperDesign = JRXmlLoader.load(getClass().getClassLoader().getResourceAsStream(Report.FORM001_TABLE)); |
58 | 0 | JasperReport jasperReport = JasperCompileManager.compileReport(jasperDesign); |
59 | |
|
60 | 0 | JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, getParameters(), new FilmsDatasource(getDatas())); |
61 | |
|
62 | 0 | JRXlsAbstractExporter xlsExporter = new JExcelApiExporter(); |
63 | 0 | xlsExporter.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint); |
64 | 0 | xlsExporter.setParameter(JRExporterParameter.OUTPUT_FILE_NAME, path); |
65 | 0 | xlsExporter.setParameter(JExcelApiExporterParameter.IS_REMOVE_EMPTY_SPACE_BETWEEN_ROWS, Boolean.TRUE); |
66 | 0 | xlsExporter.setParameter(JExcelApiExporterParameter.IS_REMOVE_EMPTY_SPACE_BETWEEN_COLUMNS, Boolean.TRUE); |
67 | 0 | xlsExporter.setParameter(JExcelApiExporterParameter.IS_IGNORE_CELL_BORDER, Boolean.TRUE); |
68 | |
|
69 | 0 | xlsExporter.exportReport(); |
70 | 0 | } catch (JRException e) { |
71 | 0 | Managers.getManager(ILoggingManager.class).getLogger(getClass()).error(e); |
72 | 0 | } |
73 | 0 | } |
74 | |
|
75 | |
|
76 | |
|
77 | |
|
78 | |
|
79 | |
|
80 | |
private static Map<String, String> getParameters() { |
81 | 0 | Map<String, String> parameters = new HashMap<String, String>(9); |
82 | 0 | parameters.put(Form001_Parameters.TITLE, Managers.getManager(ILanguageManager.class).getMessage(Form001.TITLE)); |
83 | 0 | parameters.put(Form001_Parameters.KIND, Managers.getManager(ILanguageManager.class).getMessage(Film.KIND)); |
84 | 0 | parameters.put(Form001_Parameters.FILM, Managers.getManager(ILanguageManager.class).getMessage(Film.TITLE)); |
85 | 0 | parameters.put(Form001_Parameters.TYPE, Managers.getManager(ILanguageManager.class).getMessage(Film.TYPE)); |
86 | 0 | parameters.put(Form001_Parameters.REALIZER, Managers.getManager(ILanguageManager.class).getMessage(Film.REALIZER)); |
87 | 0 | parameters.put(Form001_Parameters.YEAR, Managers.getManager(ILanguageManager.class).getMessage(Film.YEAR)); |
88 | 0 | parameters.put(Form001_Parameters.DURATION, Managers.getManager(ILanguageManager.class).getMessage(Film.DURATION)); |
89 | 0 | parameters.put(Form001_Parameters.LANGUAGE, Managers.getManager(ILanguageManager.class).getMessage(Film.LANGUAGE)); |
90 | 0 | parameters.put(Form001_Parameters.ACTORS, Managers.getManager(ILanguageManager.class).getMessage(Film.ACTORS)); |
91 | 0 | return parameters; |
92 | |
} |
93 | |
} |