/**
* Copyright 2013 European Parliament
*
* Licensed under the EUPL, Version 1.1 or - as soon they will be approved by the European Commission - subsequent versions of the EUPL (the "Licence");
* You may not use this work except in compliance with the Licence.
* You may obtain a copy of the Licence at:
*
* http://joinup.ec.europa.eu/software/page/eupl
*
* Unless required by applicable law or agreed to in writing, software distributed under the Licence is distributed on an "AS IS" basis,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the Licence for the specific language governing permissions and limitations under the Licence.
*/
package org.nsesa.editor.gwt.an.common.client.ui.overlay.document.gen.csd02;
import com.google.gwt.dom.client.Element;
import com.google.gwt.user.client.DOM;
import org.nsesa.editor.gwt.an.common.client.ui.overlay.document.gen.xmlschema.AnyURISimpleType;
import org.nsesa.editor.gwt.an.common.client.ui.overlay.document.gen.xmlschema.DurationSimpleType;
import org.nsesa.editor.gwt.an.common.client.ui.overlay.document.gen.xmlschema.IDSimpleType;
import org.nsesa.editor.gwt.an.common.client.ui.overlay.document.gen.xmlschema.NMTOKENSimpleType;
import org.nsesa.editor.gwt.core.client.ui.overlay.document.StructureIndicator;
import java.util.LinkedHashMap;
/**
* Generated class
* This file is generated. Rather than changing this file, correct the template called <tt>overlayClass.ftl</tt>.
*/
public class TimeInterval extends MetaoptComplexType {
/**
* Stores a structure indicator coming from xsd structure *
*/
private static StructureIndicator STRUCTURE_INDICATOR = new StructureIndicator.DefaultStructureIndicator(1, 1
);
/**
* Create a browser DOM span element and set up "type", "ns" and css class attributes
*/
public static Element create() {
com.google.gwt.user.client.Element span = DOM.createSpan();
span.setAttribute("data-type", "timeInterval");
span.setAttribute("data-ns", "http://docs.oasis-open.org/legaldocml/ns/akn/3.0/CSD02");
span.setClassName("widget timeInterval");
return span;
}
// CONSTRUCTORS ------------------
/**
* Create a <code>TimeInterval</code> object and set up its type
*/
public TimeInterval() {
super(create());
setType("timeInterval");
}
/**
* Constructor with required attributes
*/
public TimeInterval(AnyURISimpleType refersToAttr) {
this();
setRefersToAttr(refersToAttr);
}
/**
* Create a <code>TimeInterval</code> object with the given DOM element
*/
public TimeInterval(Element element) {
super(element);
}
// FIELDS ------------------
private DurationSimpleType durationAttr;
private AnyURISimpleType endAttr;
private AnyURISimpleType refersToAttr;
private AnyURISimpleType startAttr;
/**
* Return <code>durationAttr</code> property
*
* @return durationAttr
*/
public DurationSimpleType getDurationAttr() {
if (durationAttr == null) {
durationAttr = new DurationSimpleType();
durationAttr.setValue(getElement().getAttribute("duration"));
}
return durationAttr;
}
/**
* Return <code>durationAttr</code> property in DSL way
*
* @return durationAttr
*/
public DurationSimpleType durationAttr() {
return getDurationAttr();
}
/**
* Set <code>durationAttr</code> property
*
* @param durationAttr the new value
*/
public void setDurationAttr(final DurationSimpleType durationAttr) {
this.durationAttr = durationAttr;
getElement().setAttribute("duration", durationAttr.getValue());
}
/**
* Set <code>durationAttr</code> property in DSL way
*
* @param durationAttr the new value
* @return <code>TimeInterval</code> instance
*/
public TimeInterval durationAttr(final DurationSimpleType durationAttr) {
setDurationAttr(durationAttr);
return this;
}
/**
* Return <code>endAttr</code> property
*
* @return endAttr
*/
public AnyURISimpleType getEndAttr() {
if (endAttr == null) {
endAttr = new AnyURISimpleType();
endAttr.setValue(getElement().getAttribute("end"));
}
return endAttr;
}
/**
* Return <code>endAttr</code> property in DSL way
*
* @return endAttr
*/
public AnyURISimpleType endAttr() {
return getEndAttr();
}
/**
* Set <code>endAttr</code> property
*
* @param endAttr the new value
*/
public void setEndAttr(final AnyURISimpleType endAttr) {
this.endAttr = endAttr;
getElement().setAttribute("end", endAttr.getValue());
}
/**
* Set <code>endAttr</code> property in DSL way
*
* @param endAttr the new value
* @return <code>TimeInterval</code> instance
*/
public TimeInterval endAttr(final AnyURISimpleType endAttr) {
setEndAttr(endAttr);
return this;
}
/**
* Return <code>refersToAttr</code> property
*
* @return refersToAttr
*/
public AnyURISimpleType getRefersToAttr() {
if (refersToAttr == null) {
refersToAttr = new AnyURISimpleType();
refersToAttr.setValue(getElement().getAttribute("refersTo"));
}
return refersToAttr;
}
/**
* Return <code>refersToAttr</code> property in DSL way
*
* @return refersToAttr
*/
public AnyURISimpleType refersToAttr() {
return getRefersToAttr();
}
/**
* Set <code>refersToAttr</code> property
*
* @param refersToAttr the new value
*/
public void setRefersToAttr(final AnyURISimpleType refersToAttr) {
this.refersToAttr = refersToAttr;
getElement().setAttribute("refersTo", refersToAttr.getValue());
}
/**
* Set <code>refersToAttr</code> property in DSL way
*
* @param refersToAttr the new value
* @return <code>TimeInterval</code> instance
*/
public TimeInterval refersToAttr(final AnyURISimpleType refersToAttr) {
setRefersToAttr(refersToAttr);
return this;
}
/**
* Return <code>startAttr</code> property
*
* @return startAttr
*/
public AnyURISimpleType getStartAttr() {
if (startAttr == null) {
startAttr = new AnyURISimpleType();
startAttr.setValue(getElement().getAttribute("start"));
}
return startAttr;
}
/**
* Return <code>startAttr</code> property in DSL way
*
* @return startAttr
*/
public AnyURISimpleType startAttr() {
return getStartAttr();
}
/**
* Set <code>startAttr</code> property
*
* @param startAttr the new value
*/
public void setStartAttr(final AnyURISimpleType startAttr) {
this.startAttr = startAttr;
getElement().setAttribute("start", startAttr.getValue());
}
/**
* Set <code>startAttr</code> property in DSL way
*
* @param startAttr the new value
* @return <code>TimeInterval</code> instance
*/
public TimeInterval startAttr(final AnyURISimpleType startAttr) {
setStartAttr(startAttr);
return this;
}
//Override all attributes methods to be conformant with DSL approach
/**
* Set <code>evolvingIdAttr</code> property in DSL way
*
* @param evolvingIdAttr new value
* @return <code> TimeInterval</code> instance
*/
public TimeInterval evolvingIdAttr(final NMTOKENSimpleType evolvingIdAttr) {
setEvolvingIdAttr(evolvingIdAttr);
return this;
}
/**
* Set <code>idAttr</code> property in DSL way
*
* @param idAttr new value
* @return <code> TimeInterval</code> instance
*/
public TimeInterval idAttr(final IDSimpleType idAttr) {
setIdAttr(idAttr);
return this;
}
/**
* Set <code>wildcardContentAttr</code> property in DSL way
*
* @param wildcardContentAttr new value
* @return <code> TimeInterval</code> instance
*/
public TimeInterval wildcardContentAttr(final String wildcardContentAttr) {
setWildcardContentAttr(wildcardContentAttr);
return this;
}
/**
* Returns the namespace URI of this amendable widget.
*
* @return The namesapce as String
*/
@Override
public String getNamespaceURI() {
return "http://docs.oasis-open.org/legaldocml/ns/akn/3.0/CSD02";
}
@Override
public LinkedHashMap<String, String> getAttributes() {
final LinkedHashMap<String, String> attrs = new LinkedHashMap<String, String>();
attrs.putAll(super.getAttributes());
attrs.put("duration", getDurationAttr() != null ? getDurationAttr().getValue() : null);
attrs.put("end", getEndAttr() != null ? getEndAttr().getValue() : null);
attrs.put("refersTo", getRefersToAttr() != null ? getRefersToAttr().getValue() : null);
attrs.put("start", getStartAttr() != null ? getStartAttr().getValue() : null);
return attrs;
}
@Override
public StructureIndicator getStructureIndicator() {
return STRUCTURE_INDICATOR;
}
/**
* DSL Style for html method
*/
@Override
public TimeInterval html(String s) {
super.html(s);
return this;
}
}