-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathIssueSpeed.java
More file actions
150 lines (133 loc) · 6.37 KB
/
IssueSpeed.java
File metadata and controls
150 lines (133 loc) · 6.37 KB
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
package Reports;
import Reports.AbstratReports.AbstractExcelReport;
import Utilz.SqlExecutor;
import Utilz.SqlProperties;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.util.CellRangeAddress;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.GregorianCalendar;
import java.util.List;
public class IssueSpeed extends AbstractExcelReport {
private String startDate = "";
private String finishDate = "";
private String currentDate = "";
public IssueSpeed(SqlProperties prop, SqlExecutor sqlExecutor) {
super(prop, sqlExecutor);
Calendar c = new GregorianCalendar();
currentDate = c.get(Calendar.DAY_OF_MONTH) + "_" + c.get(Calendar.MONTH) + "_" + c.get(Calendar.YEAR);
}
@Override
public boolean createReport(ResultSet result) {
boolean flag = false;
List<String> headerXLS = new ArrayList();
headerXLS.add("");
headerXLS.add("");
headerXLS.add("За год");
headerXLS.add("За неделю");
headerXLS.add("Количество за год");
headerXLS.add("Доля в общем количестве");
headerXLS.add("Количество за неделю");
headerXLS.add("Доля в общем количестве");
headerXLS.add("Количество за год");
headerXLS.add("Доля в общем количестве");
headerXLS.add("Количество за неделю");
headerXLS.add("Доля в общем количестве");
headerXLS.add("Количество за год");
headerXLS.add("Доля в общем количестве");
headerXLS.add("Количество за неделю");
headerXLS.add("Доля в общем количестве");
headerXLS.add("Без учета ДТ, выпущенных с применением ТУВ");
headerXLS.add("ДТ, выпущенные с применением ТУВ");
HSSFWorkbook workbook = new HSSFWorkbook();
HSSFSheet worksheet = workbook.createSheet("0008-Р");
Row[] headerRows = new Row[4];
for (int i = 0; i < 4; i++) {
headerRows[i] = worksheet.createRow(i);
}
for (int i = 0; i < headerXLS.size(); i++) {
worksheet.setColumnWidth(i, 10 * 256);
}
HSSFCellStyle style = workbook.createCellStyle();
style.setWrapText(true);
style.setAlignment(HorizontalAlignment.CENTER);
style.setVerticalAlignment(VerticalAlignment.CENTER);
HSSFFont fontHeader = workbook.createFont();
fontHeader.setFontName("Times New Roman");
fontHeader.setFontHeightInPoints((short) 12);
fontHeader.setBold(true);
style.setFont(fontHeader);
style.setRotation((short) 90);
headerRows[3].setHeight((short) (10 * 256));
createHeader(headerXLS, style, headerRows[3], 0);
Cell cell_header = headerRows[2].createCell(2, CellType.STRING);
headerRows[2].setHeight((short) (9 * 256));
worksheet.addMergedRegion(new CellRangeAddress(
2,
2,
2,
3
));
cell_header.setCellValue("Общее количество ДТ, по которым принято решение об выпуске/отказе в выпуске товаров.");
HSSFCellStyle style2 = workbook.createCellStyle();
style2.cloneStyleFrom(style);
style2.setRotation((short) 0);
cell_header.setCellStyle(style2);
Cell cell_header2 = headerRows[2].createCell(4, CellType.STRING);
worksheet.addMergedRegion(new CellRangeAddress(
2,
2,
4,
7
));
cell_header2.setCellStyle(style2);
cell_header2.setCellValue("ДТ, по которым решение о выпуске/отказе в выпуске товаров принято в сроки, регламентированные п. 1 ст. 119 ТК ЕАЭС (4 часа)");
Cell cell_header3 = headerRows[2].createCell(8, CellType.STRING);
worksheet.addMergedRegion(new CellRangeAddress(
2,
2,
8,
11
));
cell_header3.setCellStyle(style2);
cell_header3.setCellValue("ДТ, по которым решение о выпуске/отказе в выпуске товаров принято в сроки, регламентированные п. 3 ст. 119 ТК ЕАЭС (день, следующий за днем регистрации ДТ)");
Cell cell_header4 = headerRows[2].createCell(12, CellType.STRING);
worksheet.addMergedRegion(new CellRangeAddress(
2,
2,
12,
15
));
cell_header4.setCellStyle(style2);
cell_header4.setCellValue("ДТ, по которым решение о выпуске/отказе в выпуске товаров принято в сроки, превыщающие день, следующий за днем регистрации ДТ");
Cell cell_header5 = headerRows[2].createCell(16, CellType.STRING);
worksheet.addMergedRegion(new CellRangeAddress(
2,
2,
16,
17
));
cell_header5.setCellStyle(style2);
cell_header5.setCellValue("Среднее время выпуска товаров");
Cell cell_header6 = headerRows[1].createCell(0, CellType.STRING);
headerRows[1].setHeight((short) (3 * 256));
worksheet.addMergedRegion(new CellRangeAddress(
1,
1,
0,
17
));
cell_header6.setCellValue("Отчет о сроках принятия решений о выпуске/отказе в выпуске товаров с " + startDate + " по " + finishDate + ".");
style2.cloneStyleFrom(style);
style2.setRotation((short) 0);
cell_header6.setCellStyle(style2);
insertData(result, worksheet, 4);
flag = createFile(workbook);
return flag;
}
}