/** * The contents of this file are subject to the license and copyright * detailed in the LICENSE and NOTICE files at the root of the source * tree and available online at * * http://www.dspace.org/license/ */ package org.dspace.app.xmlui.wing.element; import org.dspace.app.xmlui.wing.WingConstants; import org.dspace.app.xmlui.wing.WingContext; import org.dspace.app.xmlui.wing.WingException; import org.xml.sax.Attributes; import org.xml.sax.ContentHandler; import org.xml.sax.SAXException; import org.xml.sax.ext.LexicalHandler; import org.xml.sax.helpers.NamespaceSupport; /** * A class representing the page division. * * The body contains any number of divisions (div elements) which group content * into interactive and non interactive display blocks. * * @author Scott Phillips */ public class Meta extends AbstractWingElement implements WingMergeableElement { /** The name of the meta element */ public static final String E_META = "meta"; /** The divisions contained within this body */ private boolean merged = false; /** User oriented metadata associated with this document */ private UserMeta userMeta; /** Page oriented metadata associated with this document */ private PageMeta pageMeta; /** Repository oriented metadata associated with this document */ private RepositoryMeta repositoryMeta; protected Meta(WingContext context) throws WingException { // FIXME: don't statically assign authenticated status or // repositoryIdentifier. super(context); userMeta = new UserMeta(context); pageMeta = new PageMeta(context); repositoryMeta = new RepositoryMeta(context); } /** * Set a new user oriented metadata set. * * @return The user oriented metadata set. */ public UserMeta setUserMeta() throws WingException { return this.userMeta; } /** * Set a new page oriented metadata set. * * @return The page oriented metadata set. */ public PageMeta setPageMeta() throws WingException { return this.pageMeta; } /** * Set a new repository oriented metadata set. * * @return The repository oriented metadata set. */ public RepositoryMeta setRepositoryMeta() throws WingException { return this.repositoryMeta; } /** * Determine if the given SAX event is a Meta element. * * @param namespace * The element's name space * @param localName * The local, unqualified, name for this element * @param qName * The qualified name for this element * @param attributes * The element's attributes * @return True if this WingElement is equivalent to the given SAX Event. */ public boolean mergeEqual(String namespace, String localName, String qName, Attributes attributes) throws SAXException, WingException { if (!WingConstants.DRI.URI.equals(namespace)) { return false; } if (!E_META.equals(localName)) { return false; } return true; } /** * Merge the given sub-domain of metadata elements. * * @param namespace * The element's name space * @param localName * The local, unqualified, name for this element * * @param qName * The qualified name for this element * @param attributes * The element's attributes * @return The child element */ public WingMergeableElement mergeChild(String namespace, String localName, String qName, Attributes attributes) throws SAXException, WingException { // User if (this.userMeta != null && this.userMeta.mergeEqual(namespace, localName, qName, attributes)) { UserMeta userMeta = this.userMeta; this.userMeta = null; return userMeta; } // page if (this.pageMeta != null && this.pageMeta.mergeEqual(namespace, localName, qName, attributes)) { PageMeta pageMeta = this.pageMeta; this.pageMeta = null; return pageMeta; } // repository if (this.repositoryMeta != null && this.repositoryMeta.mergeEqual(namespace, localName, qName, attributes)) { RepositoryMeta repositoryMeta = this.repositoryMeta; this.repositoryMeta = null; return repositoryMeta; } return null; } /** * Notify this element that it is being merged. * * @return The attributes for this merged element */ public Attributes merge(Attributes attributes) throws SAXException, WingException { this.merged = true; return attributes; } /** * Translate to SAX events * * @param contentHandler * (Required) The registered contentHandler where SAX events * should be routed too. * @param lexicalHandler * (Required) The registered lexicalHandler where lexical * events (such as CDATA, DTD, etc) should be routed too. * @param namespaces * (Required) SAX Helper class to keep track of namespaces able * to determine the correct prefix for a given namespace URI. */ public void toSAX(ContentHandler contentHandler, LexicalHandler lexicalHandler, NamespaceSupport namespaces) throws SAXException { if (!merged) { startElement(contentHandler, namespaces, E_META, null); } if (this.userMeta != null) { this.userMeta.toSAX(contentHandler, lexicalHandler, namespaces); } if (this.pageMeta != null) { this.pageMeta.toSAX(contentHandler, lexicalHandler, namespaces); } if (this.repositoryMeta != null) { this.repositoryMeta.toSAX(contentHandler, lexicalHandler, namespaces); } if (!merged) { endElement(contentHandler, namespaces, E_META); } } /** * dispose */ public void dispose() { if (this.userMeta != null) { this.userMeta.dispose(); } if (this.pageMeta != null) { this.pageMeta.dispose(); } if (this.repositoryMeta != null) { this.repositoryMeta.dispose(); } this.userMeta = null; this.pageMeta = null; this.repositoryMeta = null; super.dispose(); } }