StylePageLayoutElement.java

/**
 * **********************************************************************
 *
 * <p>DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER
 *
 * <p>Copyright 2008, 2010 Oracle and/or its affiliates. All rights reserved.
 *
 * <p>Use is subject to license terms.
 *
 * <p>Licensed 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. You can also obtain a copy of the License at
 * http://odftoolkit.org/docs/license.txt
 *
 * <p>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.
 *
 * <p>See the License for the specific language governing permissions and limitations under the
 * License.
 *
 * <p>**********************************************************************
 */

/*
 * This file is automatically generated.
 * Don't edit manually.
 */
package org.odftoolkit.odfdom.dom.element.style;

import org.odftoolkit.odfdom.dom.DefaultElementVisitor;
import org.odftoolkit.odfdom.dom.OdfDocumentNamespace;
import org.odftoolkit.odfdom.dom.attribute.style.StyleNameAttribute;
import org.odftoolkit.odfdom.dom.attribute.style.StylePageUsageAttribute;
import org.odftoolkit.odfdom.dom.element.OdfStyleBase;
import org.odftoolkit.odfdom.pkg.ElementVisitor;
import org.odftoolkit.odfdom.pkg.OdfFileDom;
import org.odftoolkit.odfdom.pkg.OdfName;

/** DOM implementation of OpenDocument element {@odf.element style:page-layout}. */
public class StylePageLayoutElement extends OdfStyleBase {

  public static final OdfName ELEMENT_NAME =
      OdfName.newName(OdfDocumentNamespace.STYLE, "page-layout");

  /**
   * Create the instance of <code>StylePageLayoutElement</code>
   *
   * @param ownerDoc The type is <code>OdfFileDom</code>
   */
  public StylePageLayoutElement(OdfFileDom ownerDoc) {
    super(ownerDoc, ELEMENT_NAME);
  }

  /**
   * Get the element name
   *
   * @return return <code>OdfName</code> the name of element {@odf.element style:page-layout}.
   */
  public OdfName getOdfName() {
    return ELEMENT_NAME;
  }

  /**
   * Receives the value of the ODFDOM attribute representation <code>StyleNameAttribute</code> , See
   * {@odf.attribute style:name}
   *
   * <p>Attribute is mandatory.
   *
   * @return - the <code>String</code> , the value or <code>null</code>, if the attribute is not set
   *     and no default value defined.
   */
  public String getStyleNameAttribute() {
    StyleNameAttribute attr =
        (StyleNameAttribute) getOdfAttribute(OdfDocumentNamespace.STYLE, "name");
    if (attr != null) {
      return String.valueOf(attr.getValue());
    }
    return null;
  }

  /**
   * Sets the value of ODFDOM attribute representation <code>StyleNameAttribute</code> , See
   * {@odf.attribute style:name}
   *
   * @param styleNameValue The type is <code>String</code>
   */
  public void setStyleNameAttribute(String styleNameValue) {
    StyleNameAttribute attr = new StyleNameAttribute((OdfFileDom) this.ownerDocument);
    setOdfAttribute(attr);
    attr.setValue(styleNameValue);
  }

  /**
   * Receives the value of the ODFDOM attribute representation <code>StylePageUsageAttribute</code>
   * , See {@odf.attribute style:page-usage}
   *
   * @return - the <code>String</code> , the value or <code>null</code>, if the attribute is not set
   *     and no default value defined.
   */
  public String getStylePageUsageAttribute() {
    StylePageUsageAttribute attr =
        (StylePageUsageAttribute) getOdfAttribute(OdfDocumentNamespace.STYLE, "page-usage");
    if (attr != null) {
      return String.valueOf(attr.getValue());
    }
    return StylePageUsageAttribute.DEFAULT_VALUE;
  }

  /**
   * Sets the value of ODFDOM attribute representation <code>StylePageUsageAttribute</code> , See
   * {@odf.attribute style:page-usage}
   *
   * @param stylePageUsageValue The type is <code>String</code>
   */
  public void setStylePageUsageAttribute(String stylePageUsageValue) {
    StylePageUsageAttribute attr = new StylePageUsageAttribute((OdfFileDom) this.ownerDocument);
    setOdfAttribute(attr);
    attr.setValue(stylePageUsageValue);
  }

  /**
   * Create child element {@odf.element style:footer-style}.
   *
   * @return the element {@odf.element style:footer-style}
   */
  public StyleFooterStyleElement newStyleFooterStyleElement() {
    StyleFooterStyleElement styleFooterStyle =
        ((OdfFileDom) this.ownerDocument).newOdfElement(StyleFooterStyleElement.class);
    this.appendChild(styleFooterStyle);
    return styleFooterStyle;
  }

  /**
   * Create child element {@odf.element style:header-style}.
   *
   * @return the element {@odf.element style:header-style}
   */
  public StyleHeaderStyleElement newStyleHeaderStyleElement() {
    StyleHeaderStyleElement styleHeaderStyle =
        ((OdfFileDom) this.ownerDocument).newOdfElement(StyleHeaderStyleElement.class);
    this.appendChild(styleHeaderStyle);
    return styleHeaderStyle;
  }

  /**
   * Create child element {@odf.element style:page-layout-properties}.
   *
   * @param styleNumFormatValue the <code>String</code> value of <code>StyleNumFormatAttribute
   *     </code>, see {@odf.attribute style:num-format} at specification
   * @return the element {@odf.element style:page-layout-properties}
   */
  public StylePageLayoutPropertiesElement newStylePageLayoutPropertiesElement(
      String styleNumFormatValue) {
    StylePageLayoutPropertiesElement stylePageLayoutProperties =
        ((OdfFileDom) this.ownerDocument).newOdfElement(StylePageLayoutPropertiesElement.class);
    stylePageLayoutProperties.setStyleNumFormatAttribute(styleNumFormatValue);
    this.appendChild(stylePageLayoutProperties);
    return stylePageLayoutProperties;
  }

  @Override
  public void accept(ElementVisitor visitor) {
    if (visitor instanceof DefaultElementVisitor) {
      DefaultElementVisitor defaultVisitor = (DefaultElementVisitor) visitor;
      defaultVisitor.visit(this);
    } else {
      visitor.visit(this);
    }
  }
}