/////////////////////////////////////////////////////////////////////////////
//
// Project ProjectForge Community Edition
// www.projectforge.org
//
// Copyright (C) 2001-2014 Kai Reinhard (k.reinhard@micromata.de)
//
// ProjectForge is dual-licensed.
//
// This community edition is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as published
// by the Free Software Foundation; version 3 of the License.
//
// This community edition is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
// Public License for more details.
//
// You should have received a copy of the GNU General Public License along
// with this program; if not, see http://www.gnu.org/licenses/.
//
/////////////////////////////////////////////////////////////////////////////
package org.projectforge.web.fibu;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import org.apache.commons.lang.Validate;
import org.apache.wicket.markup.html.form.upload.FileUpload;
import org.apache.wicket.request.mapper.parameter.PageParameters;
import org.apache.wicket.spring.injection.annot.SpringBean;
import org.projectforge.common.ImportedElement;
import org.projectforge.common.ImportedSheet;
import org.projectforge.fibu.datev.DatevImportDao;
import org.projectforge.fibu.kost.AccountingConfig;
import org.projectforge.fibu.kost.BuchungssatzDO;
import org.projectforge.fibu.kost.BusinessAssessment;
import org.projectforge.user.UserRightId;
import org.projectforge.user.UserRightValue;
import org.projectforge.web.core.importstorage.AbstractImportPage;
public class DatevImportPage extends AbstractImportPage<DatevImportForm>
{
private static final long serialVersionUID = 3158445617725488919L;
private static final org.apache.log4j.Logger log = org.apache.log4j.Logger.getLogger(DatevImportPage.class);
@SpringBean(name = "datevImportDao")
private DatevImportDao datevImportDao;
public DatevImportPage(final PageParameters parameters)
{
super(parameters);
form = new DatevImportForm(this);
body.add(form);
form.init();
}
protected void importAccountList()
{
checkAccess();
final FileUpload fileUpload = form.fileUploadField.getFileUpload();
if (fileUpload != null) {
try {
final InputStream is = fileUpload.getInputStream();
actionLog.reset();
final String clientFileName = fileUpload.getClientFileName();
setStorage(datevImportDao.importKontenplan(is, clientFileName, actionLog));
} catch (final Exception ex) {
log.error(ex.getMessage(), ex);
error("An error occurred (see log files for details): " + ex.getMessage());
clear();
}
}
}
protected void importAccountRecords()
{
checkAccess();
final FileUpload fileUpload = form.fileUploadField.getFileUpload();
if (fileUpload != null) {
try {
final InputStream is = fileUpload.getInputStream();
actionLog.reset();
final String clientFileName = fileUpload.getClientFileName();
setStorage(datevImportDao.importBuchungsdaten(is, clientFileName, actionLog));
} catch (final Exception ex) {
log.error(ex.getMessage(), ex);
error("An error occurred (see log files for details): " + ex.getMessage());
clear();
}
}
}
@Override
protected ImportedSheet< ? > reconcile(final String sheetName)
{
checkAccess();
final ImportedSheet< ? > sheet = super.reconcile(sheetName);
datevImportDao.reconcile(getStorage(), sheetName);
return sheet;
}
@Override
protected ImportedSheet< ? > commit(final String sheetName)
{
checkAccess();
final ImportedSheet< ? > sheet = super.commit(sheetName);
datevImportDao.commit(getStorage(), sheetName);
return sheet;
}
@Override
protected void selectAll(final String sheetName)
{
checkAccess();
super.selectAll(sheetName);
}
@Override
protected void select(final String sheetName, final int number)
{
checkAccess();
super.select(sheetName, number);
}
@Override
protected void deselectAll(final String sheetName)
{
checkAccess();
super.deselectAll(sheetName);
}
protected void showBusinessAssessment(final String sheetName)
{
final ImportedSheet< ? > sheet = getStorage().getNamedSheet(sheetName);
Validate.notNull(sheet);
final List<BuchungssatzDO> list = new ArrayList<BuchungssatzDO>();
for (final ImportedElement< ? > element : sheet.getElements()) {
final BuchungssatzDO satz = (BuchungssatzDO) element.getValue();
list.add(satz);
}
final BusinessAssessment businessAssessment = new BusinessAssessment(AccountingConfig.getInstance().getBusinessAssessmentConfig(),
(Integer) sheet.getProperty("year"), (Integer) sheet.getProperty("month"));
form.setBusinessAssessment(businessAssessment);
businessAssessment.setAccountRecords(list);
}
private void checkAccess()
{
accessChecker.checkLoggedInUserRight(UserRightId.FIBU_DATEV_IMPORT, UserRightValue.TRUE);
accessChecker.checkRestrictedOrDemoUser();
}
@Override
protected String getTitle()
{
return getString("fibu.datev.import");
}
}