1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30 package ar.com.fdvs.dj.test;
31
32 import java.awt.Color;
33
34 import net.sf.jasperreports.view.JasperDesignViewer;
35 import net.sf.jasperreports.view.JasperViewer;
36 import ar.com.fdvs.dj.core.DynamicJasperHelper;
37 import ar.com.fdvs.dj.domain.ColumnsGroupVariableOperation;
38 import ar.com.fdvs.dj.domain.DJChart;
39 import ar.com.fdvs.dj.domain.DJChartOptions;
40 import ar.com.fdvs.dj.domain.DynamicReport;
41 import ar.com.fdvs.dj.domain.Style;
42 import ar.com.fdvs.dj.domain.builders.ColumnBuilder;
43 import ar.com.fdvs.dj.domain.builders.DJChartBuilder;
44 import ar.com.fdvs.dj.domain.builders.DynamicReportBuilder;
45 import ar.com.fdvs.dj.domain.builders.GroupBuilder;
46 import ar.com.fdvs.dj.domain.constants.Border;
47 import ar.com.fdvs.dj.domain.constants.Font;
48 import ar.com.fdvs.dj.domain.constants.GroupLayout;
49 import ar.com.fdvs.dj.domain.constants.HorizontalAlign;
50 import ar.com.fdvs.dj.domain.constants.Transparency;
51 import ar.com.fdvs.dj.domain.constants.VerticalAlign;
52 import ar.com.fdvs.dj.domain.entities.ColumnsGroup;
53 import ar.com.fdvs.dj.domain.entities.columns.AbstractColumn;
54 import ar.com.fdvs.dj.domain.entities.columns.PropertyColumn;
55
56 public class ChartReportTest extends BaseDjReportTest {
57
58 public DynamicReport buildReport() throws Exception {
59
60 Style detailStyle = new Style();
61 Style headerStyle = new Style();
62 headerStyle.setFont(Font.ARIAL_MEDIUM_BOLD);
63 headerStyle.setBorder(Border.PEN_2_POINT);
64 headerStyle.setHorizontalAlign(HorizontalAlign.CENTER);
65 headerStyle.setVerticalAlign(VerticalAlign.MIDDLE);
66
67 Style titleStyle = new Style();
68 titleStyle.setFont(new Font(18, Font._FONT_VERDANA, true));
69 Style importeStyle = new Style();
70 importeStyle.setHorizontalAlign(HorizontalAlign.RIGHT);
71 Style oddRowStyle = new Style();
72 oddRowStyle.setBorder(Border.NO_BORDER);
73 oddRowStyle.setBackgroundColor(Color.LIGHT_GRAY);
74 oddRowStyle.setTransparency(Transparency.OPAQUE);
75
76 DynamicReportBuilder drb = new DynamicReportBuilder();
77 int margin = 20;
78 drb
79 .setTitleStyle(titleStyle)
80 .setTitle("November 2006 sales report")
81 .setSubtitle("The items in this report correspond "
82 +"to the main products: DVDs, Books, Foods and Magazines")
83 .setDetailHeight(new Integer(15)).setLeftMargin(margin)
84 .setMargins(margin, margin, margin, margin)
85
86 .setPrintColumnNames(false)
87 .setOddRowBackgroundStyle(oddRowStyle);
88
89 AbstractColumn columnState = ColumnBuilder.getInstance()
90 .setColumnProperty("state", String.class.getName()).setTitle(
91 "State").setWidth(new Integer(85))
92 .setStyle(detailStyle).setHeaderStyle(headerStyle).build();
93
94 AbstractColumn columnBranch = ColumnBuilder.getInstance()
95 .setColumnProperty("branch", String.class.getName()).setTitle(
96 "Branch").setWidth(new Integer(85)).setStyle(
97 detailStyle).setHeaderStyle(headerStyle).build();
98
99 AbstractColumn columnaProductLine = ColumnBuilder.getInstance()
100 .setColumnProperty("productLine", String.class.getName())
101 .setTitle("Product Line").setWidth(new Integer(85)).setStyle(
102 detailStyle).setHeaderStyle(headerStyle).build();
103
104 AbstractColumn columnaItem = ColumnBuilder.getInstance()
105 .setColumnProperty("item", String.class.getName()).setTitle(
106 "Item").setWidth(new Integer(85)).setStyle(detailStyle)
107 .setHeaderStyle(headerStyle).build();
108
109 AbstractColumn columnCode = ColumnBuilder.getInstance()
110 .setColumnProperty("id", Long.class.getName()).setTitle("ID")
111 .setWidth(new Integer(40)).setStyle(importeStyle)
112 .setHeaderStyle(headerStyle).build();
113
114 AbstractColumn columnaQuantity = ColumnBuilder.getInstance()
115 .setColumnProperty("quantity", Long.class.getName()).setTitle(
116 "Quantity").setWidth(new Integer(80)).setStyle(
117 importeStyle).setHeaderStyle(headerStyle).build();
118
119 AbstractColumn columnAmount = ColumnBuilder.getInstance()
120 .setColumnProperty("amount", Float.class.getName()).setTitle(
121 "Amount").setWidth(new Integer(90))
122 .setPattern("$ 0.00").setStyle(importeStyle).setHeaderStyle(
123 headerStyle).build();
124
125 GroupBuilder gb1 = new GroupBuilder();
126
127
128 ColumnsGroup g1 = gb1.setCriteriaColumn((PropertyColumn) columnState).addFooterVariable(columnAmount,
129 ColumnsGroupVariableOperation.SUM)
130 .addFooterVariable(columnaQuantity,
131 ColumnsGroupVariableOperation.SUM)
132 .setGroupLayout(GroupLayout.DEFAULT_WITH_HEADER)
133 .build();
134
135
136 GroupBuilder gb2 = new GroupBuilder();
137 ColumnsGroup g2 = gb2.setCriteriaColumn((PropertyColumn) columnBranch)
138 .addFooterVariable(columnAmount,
139 ColumnsGroupVariableOperation.SUM)
140 .addFooterVariable(columnaQuantity,
141 ColumnsGroupVariableOperation.SUM).build();
142
143 drb.addColumn(columnState);
144 drb.addColumn(columnBranch);
145 drb.addColumn(columnaProductLine);
146 drb.addColumn(columnaItem);
147 drb.addColumn(columnCode);
148 drb.addColumn(columnaQuantity);
149 drb.addColumn(columnAmount);
150
151 drb.addGroup(g1);
152 drb.addGroup(g2);
153
154 drb.setUseFullPageWidth(true);
155
156 DJChartBuilder cb = new DJChartBuilder();
157 DJChart chart = cb.addType(DJChart.BAR_CHART)
158 .addOperation(DJChart.CALCULATION_SUM)
159 .addColumnsGroup(g2)
160 .addColumn(columnAmount)
161 .addColumn(columnaQuantity)
162 .setPosition(DJChartOptions.POSITION_FOOTER)
163 .setShowLabels(true)
164 .build();
165
166 drb.addChart(chart);
167
168 DynamicReport dr = drb.build();
169
170 return dr;
171 }
172
173 public static void main(String[] args) throws Exception {
174 ChartReportTest test = new ChartReportTest();
175 test.testReport();
176 JasperViewer.viewReport(test.jp);
177 JasperDesignViewer.viewReportDesign(DynamicJasperHelper.generateJasperReport(test.dr, test.getLayoutManager(),test.params));
178 }
179
180 }