{
if (objects == null || objects.length == 0)
throw new ApplicationException(i18n.tr("Bitte w�hlen Sie die zu exportierenden Ums�tze aus"));
Umsatz u = (Umsatz) objects[0];
Date startDate = u.getDatum();
Date endDate = u.getDatum();
Hashtable umsaetze = new Hashtable();
if (monitor != null)
{
monitor.setStatusText(i18n.tr("Ermittle zu exportierende Ums�tze und Konten"));
monitor.addPercentComplete(1);
}
for (int i=0;i<objects.length;++i)
{
u = (Umsatz) objects[i];
Konto k = u.getKonto();
// Wir ermitteln bei der Gelegenheit das Maximal- und Minimal-Datum
Date date = u.getDatum();
if (date != null)
{
if (endDate != null && date.after(endDate)) endDate = date;
if (startDate != null && date.before(startDate)) startDate = date;
}
// Wir gruppieren die Umsaetze nach Konto.
ArrayList list = (ArrayList) umsaetze.get(k.getID());
if (list == null)
{
list = new ArrayList();
umsaetze.put(k.getID(),list);
}
list.add(u);
}
// Falls wir die Datumsfelder als optionale Parameter erhalten haben,
// nehmen wir die.
Date d = (Date) Exporter.SESSION.get("pdf.start");
if (d != null) startDate = d;
d = (Date) Exporter.SESSION.get("pdf.end");
if (d != null) endDate = d;
Boolean filter = (Boolean) Exporter.SESSION.get("filtered");
Boolean b = (Boolean) Exporter.SESSION.get(ExportSaldoExtension.KEY_SALDO_HIDE);
boolean showSaldo = (b == null || !b.booleanValue());
Reporter reporter = null;
try
{
// Der Export
String subTitle = i18n.tr("{0} - {1}", new String[]{startDate == null ? "" : HBCI.DATEFORMAT.format(startDate),endDate == null ? "" : HBCI.DATEFORMAT.format(endDate)});
reporter = new Reporter(os,monitor,i18n.tr("Ums�tze") + (filter != null && filter.booleanValue() ? (" (" + i18n.tr("gefiltert") + ")") : ""), subTitle, objects.length );
reporter.addHeaderColumn(i18n.tr("Valuta / Buchungsdatum"), Element.ALIGN_CENTER, 30, BaseColor.LIGHT_GRAY);
reporter.addHeaderColumn(i18n.tr("Empf�nger/Einzahler"), Element.ALIGN_CENTER,100, BaseColor.LIGHT_GRAY);
reporter.addHeaderColumn(i18n.tr("Zahlungsgrund"), Element.ALIGN_CENTER,120, BaseColor.LIGHT_GRAY);
reporter.addHeaderColumn(i18n.tr("Betrag"), Element.ALIGN_CENTER, 30, BaseColor.LIGHT_GRAY);
if (showSaldo)
reporter.addHeaderColumn(i18n.tr("Saldo"), Element.ALIGN_CENTER, 30, BaseColor.LIGHT_GRAY);
reporter.createHeader();
// Iteration ueber Umsaetze
Enumeration konten = umsaetze.keys();
while (konten.hasMoreElements())
{
String id = (String) konten.nextElement();
Konto konto = (Konto) Settings.getDBService().createObject(Konto.class,id);
PdfPCell cell = reporter.getDetailCell(konto.getLongName(), Element.ALIGN_CENTER,BaseColor.LIGHT_GRAY);
cell.setColspan(showSaldo ? 5 : 4);
reporter.addColumn(cell);
ArrayList list = (ArrayList) umsaetze.get(id);
if (list.size() == 0)
{
PdfPCell empty = reporter.getDetailCell(i18n.tr("Keine Ums�tze"), Element.ALIGN_CENTER,BaseColor.LIGHT_GRAY);
empty.setColspan(5);
reporter.addColumn(empty);
continue;
}
for (int i=0;i<list.size();++i)
{
u = (Umsatz)list.get(i);
String valuta = (u.getValuta() != null ? HBCI.DATEFORMAT.format(u.getValuta()) : "" );
String datum = (u.getDatum() != null ? HBCI.DATEFORMAT.format(u.getDatum()) : "");
BaseColor color = null;
int style = Font.NORMAL;
if (u.hasFlag(Umsatz.FLAG_NOTBOOKED))
{
color = BaseColor.GRAY;
style = Font.ITALIC;
}
reporter.addColumn(reporter.getDetailCell(valuta + "\n" + datum, Element.ALIGN_LEFT,null,color,style));
reporter.addColumn(reporter.getDetailCell(reporter.notNull(u.getGegenkontoName()) + "\n" + reporter.notNull(u.getArt()), Element.ALIGN_LEFT,null,color,style));
reporter.addColumn(reporter.getDetailCell(VerwendungszweckUtil.toString(u,"\n"), Element.ALIGN_LEFT,null,color,style));
reporter.addColumn(reporter.getDetailCell(u.getBetrag()));
if (showSaldo)
reporter.addColumn(reporter.getDetailCell(u.getSaldo()));
reporter.setNextRecord();
}
}
if (monitor != null) monitor.setStatus(ProgressMonitor.STATUS_DONE);
}