blob: 33cbff884652147ce6c37edfa532d60aef0886f8 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/* $Id$ */
package org.apache.fop.fo.flow.table;
// XML
import org.xml.sax.Locator;
import org.apache.fop.apps.FOPException;
import org.apache.fop.datatypes.Length;
import org.apache.fop.fo.Constants;
import org.apache.fop.fo.FONode;
import org.apache.fop.fo.PropertyList;
import org.apache.fop.fo.ValidationException;
import org.apache.fop.fo.expr.PropertyException;
import org.apache.fop.fo.properties.CommonBorderPaddingBackground;
import org.apache.fop.fo.properties.Property;
import org.apache.fop.fo.properties.TableColLength;
import org.apache.fop.layoutmgr.table.CollapsingBorderModel;
/**
* Class modelling the <a href="http://www.w3.org/TR/xsl/#fo_table-column">
* <code>fo:table-column</code></a> object.
*/
public class TableColumn extends TableFObj {
// The value of properties relevant for fo:table-column.
private CommonBorderPaddingBackground commonBorderPaddingBackground;
private int columnNumber;
private Length columnWidth;
private int numberColumnsRepeated;
private int numberColumnsSpanned;
private boolean isHeader;
// Unused but valid items, commented out for performance:
// private int visibility;
// End of property values
private boolean implicitColumn;
private PropertyList pList = null;
/**
* Create a TableColumn instance with the given {@link FONode}
* as parent.
*
* @param parent {@link FONode} that is the parent of this object
*/
public TableColumn(FONode parent) {
this(parent, false);
}
/**
* Create a TableColumn instance with the given {@link FONode}
* as parent
*
* @param parent FONode that is the parent of this object
* @param implicit true if this table-column has automatically been created (does not
* correspond to an explicit fo:table-column in the input document)
*/
public TableColumn(FONode parent, boolean implicit) {
super(parent);
this.implicitColumn = implicit;
}
/** {@inheritDoc} */
public void bind(PropertyList pList) throws FOPException {
commonBorderPaddingBackground = pList.getBorderPaddingBackgroundProps();
columnNumber = pList.get(PR_COLUMN_NUMBER).getNumeric().getValue();
columnWidth = pList.get(PR_COLUMN_WIDTH).getLength();
numberColumnsRepeated = pList.get(PR_NUMBER_COLUMNS_REPEATED)
.getNumeric().getValue();
numberColumnsSpanned = pList.get(PR_NUMBER_COLUMNS_SPANNED)
.getNumeric().getValue();
super.bind(pList);
if (numberColumnsRepeated <= 0) {
TableEventProducer eventProducer = TableEventProducer.Provider.get(
getUserAgent().getEventBroadcaster());
eventProducer.valueMustBeBiggerGtEqOne(this,
"number-columns-repeated", numberColumnsRepeated, getLocator());
}
if (numberColumnsSpanned <= 0) {
TableEventProducer eventProducer = TableEventProducer.Provider.get(
getUserAgent().getEventBroadcaster());
eventProducer.valueMustBeBiggerGtEqOne(this,
"number-columns-spanned", numberColumnsSpanned, getLocator());
}
/* check for unspecified width and replace with default of
* proportional-column-width(1), in case of fixed table-layout
* warn only for explicit columns
*/
if (columnWidth.getEnum() == EN_AUTO) {
if (!this.implicitColumn && !getTable().isAutoLayout()) {
TableEventProducer eventProducer = TableEventProducer.Provider.get(
getUserAgent().getEventBroadcaster());
eventProducer.warnImplicitColumns(this, getLocator());
}
columnWidth = new TableColLength(1.0, this);
}
/* in case of explicit columns, from-table-column()
* can be used on descendants of the table-cells, so
* we need a reference to the column's property list
* (cleared in Table.endOfNode())
*/
if (!this.implicitColumn) {
this.pList = pList;
}
isHeader = (pList.get(Constants.PR_X_HEADER_COLUMN).getEnum() == Constants.EN_TRUE);
}
/** {@inheritDoc} */
public void startOfNode() throws FOPException {
super.startOfNode();
getFOEventHandler().startColumn(this);
}
void setCollapsedBorders(CollapsingBorderModel collapsingBorderModel) {
this.collapsingBorderModel = collapsingBorderModel;
setCollapsedBorders();
}
/** {@inheritDoc} */
public void endOfNode() throws FOPException {
getFOEventHandler().endColumn(this);
}
/**
* {@inheritDoc}
* <br>XSL Content Model: empty
*/
protected void validateChildNode(Locator loc,
String nsURI, String localName)
throws ValidationException {
if (FO_URI.equals(nsURI)) {
invalidChildError(loc, nsURI, localName);
}
}
/**
* Get the {@link CommonBorderPaddingBackground} instance
* attached to this TableColumn.
* @return the {@link CommonBorderPaddingBackground} instance
*/
public CommonBorderPaddingBackground getCommonBorderPaddingBackground() {
return commonBorderPaddingBackground;
}
/**
* Get a {@link Length} instance corresponding to the
* <code>column-width</code> property.
* @return the "column-width" property.
*/
public Length getColumnWidth() {
return columnWidth;
}
/**
* Sets the column width.
* @param columnWidth the column width
*/
public void setColumnWidth(Length columnWidth) {
this.columnWidth = columnWidth;
}
/**
* Get the value of the <code>column-number</code> property
* @return the "column-number" property.
*/
public int getColumnNumber() {
return columnNumber;
}
/**
* Used for setting the column-number for an implicit column
* @param columnNumber the number to set
*/
protected void setColumnNumber(int columnNumber) {
this.columnNumber = columnNumber;
}
/** @return value for number-columns-repeated. */
public int getNumberColumnsRepeated() {
return numberColumnsRepeated;
}
/** @return value for number-columns-spanned. */
public int getNumberColumnsSpanned() {
return numberColumnsSpanned;
}
/** {@inheritDoc} */
public String getLocalName() {
return "table-column";
}
/**
* {@inheritDoc}
* @return {@link org.apache.fop.fo.Constants#FO_TABLE_COLUMN}
*/
public int getNameId() {
return FO_TABLE_COLUMN;
}
/**
* Indicates whether this table-column has been created as
* default column for this table in case no table-columns
* have been defined.
* Note that this only used to provide better
* user feedback (see ColumnSetup).
* @return true if this table-column has been created as default column
*/
public boolean isImplicitColumn() {
return implicitColumn;
}
/** {@inheritDoc} */
public String toString() {
StringBuffer sb = new StringBuffer("fo:table-column");
sb.append(" column-number=").append(getColumnNumber());
if (getNumberColumnsRepeated() > 1) {
sb.append(" number-columns-repeated=")
.append(getNumberColumnsRepeated());
}
if (getNumberColumnsSpanned() > 1) {
sb.append(" number-columns-spanned=")
.append(getNumberColumnsSpanned());
}
sb.append(" column-width=").append(((Property)getColumnWidth()).getString());
return sb.toString();
}
/**
* Retrieve a property value through its Id; used by
* from-table-column() function
*
* @param propId the id for the property to retrieve
* @return the requested Property
* @throws PropertyException if there is a problem evaluating the property
*/
public Property getProperty(int propId) throws PropertyException {
return this.pList.get(propId);
}
/**
* Clear the reference to the PropertyList (retained for
* from-table-column())
*/
protected void releasePropertyList() {
this.pList = null;
}
/**
* Returns {@code true} if this column is made of header cells.
*
* @return {@code true} if cells in this column are like TH cells in HTML
*/
public boolean isHeader() {
return isHeader;
}
}