package org.sigmah.server.servlet.exporter;
/*
* #%L
* Sigmah
* %%
* Copyright (C) 2010 - 2016 URD
* %%
* This program 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, either version 3 of the
* License, or (at your option) any later version.
*
* This program 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/gpl-3.0.html>.
* #L%
*/
import java.io.OutputStream;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
import javax.persistence.EntityManager;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.odftoolkit.simple.SpreadsheetDocument;
import org.sigmah.client.page.RequestParameter;
import org.sigmah.server.domain.Project;
import org.sigmah.server.servlet.base.ServletExecutionContext;
import org.sigmah.server.servlet.exporter.base.Exporter;
import org.sigmah.server.servlet.exporter.data.IndicatorEntryData;
import org.sigmah.server.servlet.exporter.data.LogFrameExportData;
import org.sigmah.server.servlet.exporter.data.ProjectSynthesisData;
import org.sigmah.server.servlet.exporter.data.SpreadsheetDataUtil;
import org.sigmah.server.servlet.exporter.utils.ContactsSynthesisCalcTemplate;
import org.sigmah.server.servlet.exporter.utils.ContactsSynthesisExcelTemplate;
import org.sigmah.server.servlet.exporter.utils.ContactsSynthesisUtils;
import org.sigmah.server.servlet.exporter.template.ExportTemplate;
import org.sigmah.server.servlet.exporter.template.IndicatorEntryCalcTemplate;
import org.sigmah.server.servlet.exporter.template.IndicatorEntryExcelTemplate;
import org.sigmah.server.servlet.exporter.template.LogFrameCalcTemplate;
import org.sigmah.server.servlet.exporter.template.LogFrameExcelTemplate;
import org.sigmah.server.servlet.exporter.template.ProjectSynthesisCalcTemplate;
import org.sigmah.server.servlet.exporter.template.ProjectSynthesisExcelTemplate;
import org.sigmah.server.servlet.exporter.utils.ExportConstants;
import org.sigmah.shared.util.ExportUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.google.inject.Injector;
public class ProjectSynthesisExporter extends Exporter {
/**
* Logger.
*/
private static final Logger LOG = LoggerFactory.getLogger(ProjectSynthesisExporter.class);
public ProjectSynthesisExporter(final Injector injector, final HttpServletRequest req, ServletExecutionContext context) throws Exception {
super(injector, req, context);
}
@Override
public String getFileName() {
SimpleDateFormat format = new SimpleDateFormat("yyyyMMddHHmmss");
return localize("projectSynthesis") + "_" + format.format(new Date()) + getExtention();
}
@Override
public void export(OutputStream output) throws Exception {
// The project id.
final String idString = requireParameter(RequestParameter.ID);
final Integer projectId;
try {
projectId = Integer.parseInt(idString);
} catch (NumberFormatException e) {
LOG.error("[export] The id '" + idString + "' is invalid.", e);
throw new Exception("The id '" + idString + "' is invalid.", e);
}
try {
// appending options
final String typeString = requireParameter(RequestParameter.TYPE);
final ExportUtils.ExportType type = ExportUtils.ExportType.valueOfOrNull(typeString);
final String withContactsString = requireParameter(RequestParameter.WITH_CONTACTS);
final boolean withContacts = "true".equals(withContactsString);
// data
final ProjectSynthesisData synthesisData = prepareSynthesisData(projectId, withContacts);
LogFrameExportData logFrameData = null;
IndicatorEntryData indicatorData = null;
List<ContactsSynthesisUtils.ContactSheetData> contactSheetDatas = null;
switch (type) {
case PROJECT_SYNTHESIS_LOGFRAME: {
final Project project = injector.getInstance(EntityManager.class).find(Project.class, projectId);
logFrameData = SpreadsheetDataUtil.prepareLogFrameData(project, this);
}
break;
case PROJECT_SYNTHESIS_INDICATORS: {
indicatorData = SpreadsheetDataUtil.prepareIndicatorsData(projectId, this);
}
break;
case PROJECT_SYNTHESIS_LOGFRAME_INDICATORS: {
final Project project = injector.getInstance(EntityManager.class).find(Project.class, projectId);
// logframe data
logFrameData = SpreadsheetDataUtil.prepareLogFrameData(project, this);
logFrameData.setIndicatorsSheetExist(true);
// indicator data
indicatorData = SpreadsheetDataUtil.prepareIndicatorsData(projectId, this);
}
break;
default:
// TODO Throw exception ?
break;
}
if (withContacts) {
contactSheetDatas = ContactsSynthesisUtils.createProjectContactListData(projectId, this, getI18ntranslator(), getLanguage());
}
ExportTemplate template = null;
switch (exportFormat) {
case XLS: {
final HSSFWorkbook wb = new HSSFWorkbook();
template = new ProjectSynthesisExcelTemplate(synthesisData, wb, getContext(), getI18ntranslator(), getLanguage(), injector);
if (logFrameData != null)
template = new LogFrameExcelTemplate(logFrameData, wb);
if (indicatorData != null)
template = new IndicatorEntryExcelTemplate(indicatorData, wb);
if (contactSheetDatas != null) {
template = new ContactsSynthesisExcelTemplate(contactSheetDatas, wb, ExportConstants.CONTACT_SHEET_PREFIX);
((ContactsSynthesisExcelTemplate) template).generate();
}
}
break;
case ODS: {
final SpreadsheetDocument doc = SpreadsheetDocument.newSpreadsheetDocument();
template = new ProjectSynthesisCalcTemplate(synthesisData, doc, getContext(), getI18ntranslator(), getLanguage(), injector);
if (logFrameData != null)
template = new LogFrameCalcTemplate(logFrameData, doc);
if (indicatorData != null)
template = new IndicatorEntryCalcTemplate(indicatorData, doc);
if (contactSheetDatas != null) {
template = new ContactsSynthesisCalcTemplate(contactSheetDatas, doc, ExportConstants.CONTACT_SHEET_PREFIX);
((ContactsSynthesisCalcTemplate)template).generate();
}
}
break;
default:
LOG.error("[export] The export format '" + exportFormat + "' is unknown.");
throw new ServletException("The export format '" + exportFormat + "' is unknown.");
}
template.write(output);
} catch (Throwable e) {
LOG.error("[export] Error during the workbook writing.", e);
throw new Exception("Error during the workbook writing.", e);
}
}
private ProjectSynthesisData prepareSynthesisData(Integer projectId, boolean withContacts) throws Throwable {
return new ProjectSynthesisData(this, projectId, injector, withContacts);
}
}