/*
* Copyright (C) 2009 Camptocamp
*
* This file is part of MapFish Server
*
* MapFish Server is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* MapFish Server 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with MapFish Server. If not, see <http://www.gnu.org/licenses/>.
*/
package org.mapfish.print.config.layout;
import com.lowagie.text.DocumentException;
import com.lowagie.text.pdf.PdfPCell;
import org.mapfish.print.InvalidValueException;
import org.mapfish.print.PDFUtils;
import org.mapfish.print.RenderingContext;
import org.mapfish.print.utils.PJsonObject;
/**
* Bean to configure an attributes block's column.
* <p/>
* See http://trac.mapfish.org/trac/mapfish/wiki/PrintModuleServer#Attributesblock
*/
public class ColumnDef {
private int columnWeight = 0;
private Block header;
private Block cell;
public void setHeader(Block header) {
this.header = header;
}
public void setCell(Block cell) {
this.cell = cell;
}
public PdfPCell createHeaderPdfCell(PJsonObject params, RenderingContext context, int col, int nbRows, int nbCols, TableConfig config) throws DocumentException {
return PDFUtils.createCell(params, context, header, 0, col, nbRows, nbCols, config);
}
public PdfPCell createContentPdfCell(PJsonObject params, RenderingContext context, int row, int col, int nbRows, int nbCols, TableConfig config) throws DocumentException {
return PDFUtils.createCell(params, context, cell, row, col, nbRows, nbCols, config);
}
public boolean isVisible(RenderingContext context, PJsonObject params) {
return header.isVisible(context, params);
}
public void validate() {
if (header == null) throw new InvalidValueException("header", "null");
if (cell == null) throw new InvalidValueException("header", "null");
header.validate();
cell.validate();
}
public void setColumnWeight(int columnWeight) {
this.columnWeight = columnWeight;
if (columnWeight < 0)
throw new InvalidValueException("columnWeight", columnWeight);
}
public int getColumnWeight() {
return columnWeight;
}
}