/*
* 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.pagination;
// XML
import org.xml.sax.Locator;
import org.apache.fop.apps.FOPException;
import org.apache.fop.fo.FONode;
import org.apache.fop.fo.FObj;
import org.apache.fop.fo.PropertyList;
import org.apache.fop.fo.ValidationException;
/**
* Class modelling the
* fo:conditional-page-master-reference
object.
*
* This is a reference to a page master with a set of conditions.
* The conditions must be satisfied for the referenced master to
* be used.
* This element is must be the child of a repeatable-page-master-alternatives
* element.
*/
public class ConditionalPageMasterReference extends FObj {
// The value of properties relevant for fo:conditional-page-master-reference.
private String masterReference;
private int pagePosition;
private int oddOrEven;
private int blankOrNotBlank;
// End of property values
/**
* Create a ConditionalPageMasterReference instance that is a
* child of the given {@link FONode}.
*
* @param parent {@link FONode} that is the parent of this object
*/
public ConditionalPageMasterReference(FONode parent) {
super(parent);
}
/** {@inheritDoc} */
public void bind(PropertyList pList) throws FOPException {
masterReference = pList.get(PR_MASTER_REFERENCE).getString();
pagePosition = pList.get(PR_PAGE_POSITION).getEnum();
oddOrEven = pList.get(PR_ODD_OR_EVEN).getEnum();
blankOrNotBlank = pList.get(PR_BLANK_OR_NOT_BLANK).getEnum();
if (masterReference == null || masterReference.equals("")) {
missingPropertyError("master-reference");
}
}
/** {@inheritDoc} */
protected void startOfNode() throws FOPException {
getConcreteParent().addConditionalPageMasterReference(this);
}
private RepeatablePageMasterAlternatives getConcreteParent() {
return (RepeatablePageMasterAlternatives) parent;
}
/**
* {@inheritDoc}
*
XSL Content Model: empty
*/
protected void validateChildNode(Locator loc, String nsURI, String localName)
throws ValidationException {
invalidChildError(loc, nsURI, localName);
}
/**
* Check if the conditions for this reference are met.
* checks the page number and emptyness to determine if this
* matches.
* @param isOddPage True if page number odd
* @param isFirstPage True if page is first page
* @param isLastPage True if page is last page
* @param isBlankPage True if page is blank
* @param isOnlyPage True if page is the only page
* @return True if the conditions for this reference are met
*/
protected boolean isValid(boolean isOddPage,
boolean isFirstPage,
boolean isLastPage,
boolean isOnlyPage,
boolean isBlankPage) {
// page-position
if (isOnlyPage) {
if (pagePosition != EN_ONLY) {
return false;
}
} else if (isFirstPage) {
if (pagePosition == EN_REST) {
return false;
} else if (pagePosition == EN_LAST) {
return false;
}
} else if (isLastPage) {
if (pagePosition == EN_REST) {
return false;
} else if (pagePosition == EN_FIRST) {
return false;
}
} else {
if (pagePosition == EN_FIRST) {
return false;
} else if (pagePosition == EN_LAST) {
return false;
}
}
// odd-or-even
if (isOddPage) {
if (oddOrEven == EN_EVEN) {
return false;
}
} else {
if (oddOrEven == EN_ODD) {
return false;
}
}
// blank-or-not-blank
if (isBlankPage) {
if (blankOrNotBlank == EN_NOT_BLANK) {
return false;
}
} else {
if (blankOrNotBlank == EN_BLANK) {
return false;
}
}
return true;
}
/**
* Get the value for the master-reference
property.
* @return the "master-reference" property
*/
public String getMasterReference() {
return masterReference;
}
/**
* Get the value for the page-position
property.
* @return the page-position property value
*/
public int getPagePosition() {
return this.pagePosition;
}
/** {@inheritDoc} */
public String getLocalName() {
return "conditional-page-master-reference";
}
/**
* {@inheritDoc}
* @return {@link org.apache.fop.fo.Constants#FO_CONDITIONAL_PAGE_MASTER_REFERENCE}
*/
public int getNameId() {
return FO_CONDITIONAL_PAGE_MASTER_REFERENCE;
}
}