/** * 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.csd05; 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.IDSimpleType; import org.nsesa.editor.gwt.an.common.client.ui.overlay.document.gen.xmlschema.NMTOKENSimpleType; import org.nsesa.editor.gwt.an.common.client.ui.overlay.document.gen.xmlschema.StringSimpleType; import org.nsesa.editor.gwt.core.client.ui.overlay.document.StructureIndicator; import java.util.LinkedHashMap; /** * The element TLCreference is a generic metadata reference to the Akoma Ntoso URI of an ontology instance of a class specified through the name attribute * This file is generated. Rather than changing this file, correct the template called <tt>overlayClass.ftl</tt>. */ public class TLCReference extends ReferenceTypeComplexType { /** * 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", "TLCReference"); span.setAttribute("data-ns", "http://docs.oasis-open.org/legaldocml/ns/akn/3.0/CSD05"); span.setClassName("widget TLCReference"); return span; } // CONSTRUCTORS ------------------ /** * Create a <code>TLCReference</code> object and set up its type */ public TLCReference() { super(create()); setType("TLCReference"); } /** * Constructor with required attributes */ public TLCReference(StringSimpleType nameAttr, AnyURISimpleType hrefAttr, IDSimpleType idAttr, StringSimpleType showAsAttr) { this(); setNameAttr(nameAttr); setHrefAttr(hrefAttr); setIdAttr(idAttr); setShowAsAttr(showAsAttr); } /** * Create a <code>TLCReference</code> object with the given DOM element */ public TLCReference(Element element) { super(element); } // FIELDS ------------------ private StringSimpleType nameAttr; /** * Return <code>nameAttr</code> property * * @return nameAttr */ public StringSimpleType getNameAttr() { if (nameAttr == null) { nameAttr = new StringSimpleType(); nameAttr.setValue(getElement().getAttribute("name")); } return nameAttr; } /** * Return <code>nameAttr</code> property in DSL way * * @return nameAttr */ public StringSimpleType nameAttr() { return getNameAttr(); } /** * Set <code>nameAttr</code> property * * @param nameAttr the new value */ public void setNameAttr(final StringSimpleType nameAttr) { this.nameAttr = nameAttr; getElement().setAttribute("name", nameAttr.getValue()); } /** * Set <code>nameAttr</code> property in DSL way * * @param nameAttr the new value * @return <code>TLCReference</code> instance */ public TLCReference nameAttr(final StringSimpleType nameAttr) { setNameAttr(nameAttr); 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> TLCReference</code> instance */ public TLCReference evolvingIdAttr(final NMTOKENSimpleType evolvingIdAttr) { setEvolvingIdAttr(evolvingIdAttr); return this; } /** * Set <code>hrefAttr</code> property in DSL way * * @param hrefAttr new value * @return <code> TLCReference</code> instance */ public TLCReference hrefAttr(final AnyURISimpleType hrefAttr) { setHrefAttr(hrefAttr); return this; } /** * Set <code>idAttr</code> property in DSL way * * @param idAttr new value * @return <code> TLCReference</code> instance */ public TLCReference idAttr(final IDSimpleType idAttr) { setIdAttr(idAttr); return this; } /** * Set <code>shortFormAttr</code> property in DSL way * * @param shortFormAttr new value * @return <code> TLCReference</code> instance */ public TLCReference shortFormAttr(final StringSimpleType shortFormAttr) { setShortFormAttr(shortFormAttr); return this; } /** * Set <code>showAsAttr</code> property in DSL way * * @param showAsAttr new value * @return <code> TLCReference</code> instance */ public TLCReference showAsAttr(final StringSimpleType showAsAttr) { setShowAsAttr(showAsAttr); return this; } /** * Set <code>wildcardContentAttr</code> property in DSL way * * @param wildcardContentAttr new value * @return <code> TLCReference</code> instance */ public TLCReference 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/CSD05"; } @Override public LinkedHashMap<String, String> getAttributes() { final LinkedHashMap<String, String> attrs = new LinkedHashMap<String, String>(); attrs.putAll(super.getAttributes()); attrs.put("name", getNameAttr() != null ? getNameAttr().getValue() : null); return attrs; } @Override public StructureIndicator getStructureIndicator() { return STRUCTURE_INDICATOR; } /** * DSL Style for html method */ @Override public TLCReference html(String s) { super.html(s); return this; } }