All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.docx4j.wml.SdtContentBlock Maven / Gradle / Ivy

There is a newer version: 11.5.0
Show newest version
/*
 *  Copyright 2007-2013, Plutext Pty Ltd.
 *   
 *  This file is part of docx4j.

    docx4j is 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 

    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.

 */


package org.docx4j.wml; 


import java.util.List;

import jakarta.xml.bind.JAXBElement;
import jakarta.xml.bind.Unmarshaller;
import jakarta.xml.bind.annotation.XmlAccessType;
import jakarta.xml.bind.annotation.XmlAccessorType;
import jakarta.xml.bind.annotation.XmlElementRef;
import jakarta.xml.bind.annotation.XmlElementRefs;
import jakarta.xml.bind.annotation.XmlRootElement;
import jakarta.xml.bind.annotation.XmlTransient;
import jakarta.xml.bind.annotation.XmlType;

import org.docx4j.math.CTOMath;
import org.docx4j.math.CTOMathPara;
import org.jvnet.jaxb2_commons.ppp.Child;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;


/**
 * 

Java class for CT_SdtContentBlock complex type. * *

The following schema fragment specifies the expected content contained within this class. * *

 * <complexType name="CT_SdtContentBlock">
 *   <complexContent>
 *     <restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
 *       <group ref="{http://schemas.openxmlformats.org/wordprocessingml/2006/main}EG_ContentBlockContent" maxOccurs="unbounded" minOccurs="0"/>
 *     </restriction>
 *   </complexContent>
 * </complexType>
 * 
* * or altChunk (added for 3.0.1) * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "CT_SdtContentBlock", propOrder = { "content" }) @XmlRootElement(name = "sdtContent") public class SdtContentBlock extends SdtContent implements Child { private static Logger log = LoggerFactory.getLogger(SdtContentBlock.class); @XmlElementRefs({ @XmlElementRef(name = "moveToRangeStart", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "permEnd", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "ins", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = RunIns.class), @XmlElementRef(name = "p", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = P.class), @XmlElementRef(name = "moveFrom", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "customXmlDelRangeEnd", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "proofErr", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = ProofErr.class), @XmlElementRef(name = "commentRangeEnd", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = CommentRangeEnd.class), @XmlElementRef(name = "customXmlInsRangeStart", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "del", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = RunDel.class), @XmlElementRef(name = "moveTo", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "customXml", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "sdt", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = SdtBlock.class), @XmlElementRef(name = "oMathPara", namespace = "http://schemas.openxmlformats.org/officeDocument/2006/math", type = JAXBElement.class), @XmlElementRef(name = "moveFromRangeStart", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "customXmlDelRangeStart", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "customXmlMoveToRangeStart", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "tbl", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "moveFromRangeEnd", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "bookmarkStart", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "customXmlMoveFromRangeEnd", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "moveToRangeEnd", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "commentRangeStart", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = CommentRangeStart.class), @XmlElementRef(name = "customXmlMoveToRangeEnd", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "customXmlInsRangeEnd", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "permStart", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "oMath", namespace = "http://schemas.openxmlformats.org/officeDocument/2006/math", type = JAXBElement.class), @XmlElementRef(name = "customXmlMoveFromRangeStart", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "bookmarkEnd", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class), @XmlElementRef(name = "altChunk", namespace = "http://schemas.openxmlformats.org/wordprocessingml/2006/main", type = JAXBElement.class) }) protected List content = new ArrayListWml(this); @XmlTransient private Object parent; /** * Gets the value of the content property. * *

* This accessor method returns a reference to the live list, * not a snapshot. Therefore any modification you make to the * returned list will be present inside the JAXB object. * This is why there is not a set method for the content property. * *

* For example, to add a new item, do as follows: *

     *    getContent().add(newItem);
     * 
* * *

* Objects of the following type(s) are allowed in the list * {@link JAXBElement }{@code <}{@link CTMoveBookmark }{@code >} * {@link JAXBElement }{@code <}{@link CTPerm }{@code >} * {@link RunIns } * {@link P } * {@link JAXBElement }{@code <}{@link RunTrackChange }{@code >} * {@link JAXBElement }{@code <}{@link CTMarkup }{@code >} * {@link ProofErr } * {@link CommentRangeEnd } * {@link JAXBElement }{@code <}{@link CTTrackChange }{@code >} * {@link RunDel } * {@link JAXBElement }{@code <}{@link RunTrackChange }{@code >} * {@link JAXBElement }{@code <}{@link CTCustomXmlBlock }{@code >} * {@link SdtBlock } * {@link JAXBElement }{@code <}{@link CTOMathPara }{@code >} * {@link JAXBElement }{@code <}{@link CTMoveBookmark }{@code >} * {@link JAXBElement }{@code <}{@link CTTrackChange }{@code >} * {@link JAXBElement }{@code <}{@link CTTrackChange }{@code >} * {@link JAXBElement }{@code <}{@link Tbl }{@code >} * {@link JAXBElement }{@code <}{@link CTMoveFromRangeEnd }{@code >} * {@link JAXBElement }{@code <}{@link CTBookmark }{@code >} * {@link JAXBElement }{@code <}{@link CTMarkup }{@code >} * {@link JAXBElement }{@code <}{@link CTMoveToRangeEnd }{@code >} * {@link CommentRangeStart } * {@link JAXBElement }{@code <}{@link CTMarkup }{@code >} * {@link JAXBElement }{@code <}{@link CTMarkup }{@code >} * {@link JAXBElement }{@code <}{@link RangePermissionStart }{@code >} * {@link JAXBElement }{@code <}{@link CTOMath }{@code >} * {@link JAXBElement }{@code <}{@link CTTrackChange }{@code >} * {@link JAXBElement }{@code <}{@link CTMarkupRange }{@code >} * {@link JAXBElement }{@code <}{@link CTAltChunk }{@code >} // since 3.0.1 * * @since 2.7 */ public List getContent() { if (content == null) { content = new ArrayListWml(this); } return this.content; } @Deprecated public List getEGContentBlockContent() { return getContent(); } /** * Gets the parent object in the object tree representing the unmarshalled xml document. * * @return * The parent object. */ public Object getParent() { return this.parent; } public void setParent(Object parent) { this.parent = parent; } /** * This method is invoked by the JAXB implementation on each instance when unmarshalling completes. * * @param parent * The parent object in the object tree. * @param unmarshaller * The unmarshaller that generated the instance. */ public void afterUnmarshal(Unmarshaller unmarshaller, Object parent) { setParent(parent); } public void replaceElement(Object current, List insertions) { int index = getContent().indexOf(current); if (index > -1 ) { getContent().addAll(index+1, insertions); Object removed = getContent().remove(index); // sanity check if (!current.equals(removed)) { log.error("removed wrong object?"); } } else { // Not found log.error("Couldn't find replacement target."); } /* List newList = new ArrayList(); for (Object o : getBlockLevelElements() ) { if (o.equals(current)) { log.debug(".. found target "); for (Object o2 : insertions ) { newList.add(o2); log.debug(".. .. inserted "); } } else { newList.add(o); } } blockLevelElements = newList; */ } }