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.JasperViewer;
35 import ar.com.fdvs.dj.domain.ColumnOperation;
36 import ar.com.fdvs.dj.domain.DJCalculation;
37 import ar.com.fdvs.dj.domain.DynamicReport;
38 import ar.com.fdvs.dj.domain.ImageBanner;
39 import ar.com.fdvs.dj.domain.Style;
40 import ar.com.fdvs.dj.domain.builders.ColumnBuilder;
41 import ar.com.fdvs.dj.domain.builders.DynamicReportBuilder;
42 import ar.com.fdvs.dj.domain.builders.GroupBuilder;
43 import ar.com.fdvs.dj.domain.constants.Border;
44 import ar.com.fdvs.dj.domain.constants.Font;
45 import ar.com.fdvs.dj.domain.constants.GroupLayout;
46 import ar.com.fdvs.dj.domain.constants.HorizontalAlign;
47 import ar.com.fdvs.dj.domain.constants.Transparency;
48 import ar.com.fdvs.dj.domain.constants.VerticalAlign;
49 import ar.com.fdvs.dj.domain.entities.DJGroup;
50 import ar.com.fdvs.dj.domain.entities.columns.AbstractColumn;
51 import ar.com.fdvs.dj.domain.entities.columns.PropertyColumn;
52
53 public class OperationColumnReportTest extends BaseDjReportTest {
54
55 public DynamicReport buildReport() throws Exception {
56
57 Style detailStyle = new Style();
58 Style headerStyle = new Style();
59 headerStyle.setFont(Font.VERDANA_MEDIUM_BOLD);
60 headerStyle.setBorderBottom(Border.PEN_2_POINT);
61 headerStyle.setHorizontalAlign(HorizontalAlign.CENTER);
62 headerStyle.setVerticalAlign(VerticalAlign.MIDDLE);
63 headerStyle.setBackgroundColor(Color.DARK_GRAY);
64 headerStyle.setTextColor(Color.WHITE);
65 headerStyle.setTransparency(Transparency.OPAQUE);
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); oddRowStyle.setBackgroundColor(Color.LIGHT_GRAY);oddRowStyle.setTransparency(Transparency.OPAQUE);
73
74 DynamicReportBuilder drb = new DynamicReportBuilder();
75 Integer margin = new Integer(20);
76 drb.setTitleStyle(titleStyle)
77 .setTitle("November 2006 sales report")
78 .setSubtitle("The items in this report correspond "
79 +"to the main products: DVDs, Books, Foods and Magazines")
80 .setDetailHeight(new Integer(15))
81 .setLeftMargin(margin)
82 .setRightMargin(margin)
83 .setTopMargin(margin)
84 .setBottomMargin(margin)
85 .setPrintBackgroundOnOddRows(true)
86 .setOddRowBackgroundStyle(oddRowStyle)
87 .addFirstPageImageBanner(System.getProperty("user.dir") +"/target/test-classes/images/logo_fdv_solutions_60.jpg", new Integer(197), new Integer(60), ImageBanner.ALIGN_LEFT)
88 .addFirstPageImageBanner(System.getProperty("user.dir") +"/target/test-classes/images/dynamicJasper_60.jpg", new Integer(300), new Integer(60), ImageBanner.ALIGN_RIGHT)
89 .addImageBanner(System.getProperty("user.dir") +"/target/test-classes/images/logo_fdv_solutions_60.jpg", new Integer(100), new Integer(30), ImageBanner.ALIGN_LEFT)
90 .addImageBanner(System.getProperty("user.dir") +"/target/test-classes/images/dynamicJasper_60.jpg", new Integer(150), new Integer(30), ImageBanner.ALIGN_RIGHT);
91
92 AbstractColumn columnState = ColumnBuilder.getNew().setColumnProperty("state", String.class.getName())
93 .setTitle("State").setWidth(new Integer(85))
94 .setStyle(titleStyle).setHeaderStyle(headerStyle).build();
95
96 AbstractColumn columnBranch = ColumnBuilder.getNew().setColumnProperty("branch", String.class.getName())
97 .setTitle("Branch").setWidth(new Integer(85))
98 .setStyle(detailStyle).setHeaderStyle(headerStyle).build();
99
100 AbstractColumn columnaProductLine = ColumnBuilder.getNew().setColumnProperty("productLine", String.class.getName())
101 .setTitle("Product Line").setWidth(new Integer(85))
102 .setStyle(detailStyle).setHeaderStyle(headerStyle).build();
103
104 AbstractColumn columnaItem = ColumnBuilder.getNew().setColumnProperty("item", String.class.getName())
105 .setTitle("Item").setWidth(new Integer(85))
106 .setStyle(detailStyle).setHeaderStyle(headerStyle).build();
107
108 AbstractColumn columnCode = ColumnBuilder.getNew().setColumnProperty("id", Long.class.getName())
109 .setTitle("ID").setWidth(new Integer(40))
110 .setStyle(importeStyle).setHeaderStyle(headerStyle).build();
111
112 AbstractColumn columnaQuantity = ColumnBuilder.getNew().setColumnProperty("quantity", Long.class.getName())
113 .setTitle("Quantity").setWidth(new Integer(80))
114 .setStyle(importeStyle).setHeaderStyle(headerStyle).build();
115
116 AbstractColumn columnAmount = ColumnBuilder.getNew().setColumnProperty("amount", Float.class.getName())
117 .setTitle("Price /u").setWidth(new Integer(90)).setPattern("$ 0.00")
118 .setStyle(importeStyle).setHeaderStyle(headerStyle).build();
119
120 AbstractColumn operation = ColumnBuilder.getNew()
121 .addColumnOperation(ColumnOperation.SUM, new AbstractColumn[]{columnaQuantity,columnAmount})
122 .setTitle("Price").setWidth(new Integer(90)).setPattern("$ 0.00")
123 .setStyle(importeStyle).setHeaderStyle(headerStyle).build();
124
125
126 GroupBuilder gb1 = new GroupBuilder();
127 DJGroup g1 = gb1.setCriteriaColumn((PropertyColumn) columnState)
128 .addFooterVariable(columnAmount,DJCalculation.SUM)
129
130
131
132 .addFooterVariable(columnaQuantity,DJCalculation.SUM)
133 .addFooterVariable(operation,DJCalculation.SUM)
134 .setGroupLayout(GroupLayout.VALUE_IN_HEADER)
135
136 .build();
137
138 GroupBuilder gb2 = new GroupBuilder();
139 DJGroup g2 = gb2.setCriteriaColumn((PropertyColumn) columnBranch)
140 .addFooterVariable(columnAmount,DJCalculation.SUM)
141 .addFooterVariable(columnaQuantity,DJCalculation.SUM)
142 .addFooterVariable(operation,DJCalculation.SUM)
143 .build();
144
145 drb.addColumn(columnState);
146 drb.addColumn(columnBranch);
147 drb.addColumn(columnaProductLine);
148 drb.addColumn(columnaItem);
149 drb.addColumn(columnCode);
150 drb.addColumn(columnaQuantity);
151 drb.addColumn(columnAmount);
152 drb.addColumn(operation);
153
154 drb.addGroup(g1);
155
156
157 drb.setUseFullPageWidth(true);
158
159 DynamicReport dr = drb.build();
160 return dr;
161 }
162
163 public static void main(String[] args) throws Exception {
164 OperationColumnReportTest test = new OperationColumnReportTest();
165 test.testReport();
166 JasperViewer.viewReport(test.jp);
167 }
168
169 }