1 /**********************************************
2 * Copyright (C) 2010 Lukas Laag
3 * This file is part of lib-gwt-svg.
4 *
5 * libgwtsvg is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU Lesser General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
9 *
10 * libgwtsvg is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU Lesser General Public License for more details.
14 *
15 * You should have received a copy of the GNU Lesser General Public License
16 * along with libgwtsvg. If not, see http://www.gnu.org/licenses/
17 **********************************************/
18 /*
19 * Copyright (c) 2004 World Wide Web Consortium,
20 *
21 * (Massachusetts Institute of Technology, European Research Consortium for
22 * Informatics and Mathematics, Keio University). All Rights Reserved. This
23 * work is distributed under the W3C(r) Software License [1] in the hope that
24 * it will be useful, but WITHOUT ANY WARRANTY; without even the implied
25 * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
26 *
27 * [1] http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231
28 */
29
30 package org.vectomatic.dom.svg.impl;
31
32 import org.vectomatic.dom.svg.OMSVGAnimatedString;
33
34 import com.google.gwt.core.client.JavaScriptException;
35 import com.google.gwt.dom.client.Element;
36
37 /**
38 * All of the SVG DOM interfaces that correspond directly to elements in the
39 * SVG language (such as the {@link org.vectomatic.dom.svg.impl.SVGPathElement}
40 * interface for the <a href='http://www.w3.org/TR/SVG11/paths.html#PathElement'
41 * title='path element specification'>path</a> element) derive from the {@link
42 * org.vectomatic.dom.svg.impl.SVGElement} interface.
43 */
44 public class SVGElement extends Element {
45 protected SVGElement() {
46 }
47
48 // Implementation of the svg::SVGElement W3C IDL interface
49 /**
50 * Corresponds to attribute <code>xml:base</code> on the given element.
51 */
52 public final native String getXmlbase() /*-{
53 return this.xmlbase;
54 }-*/;
55 /**
56 * Corresponds to attribute <code>xml:base</code> on the given element.
57 * @throws DOMException(NO_MODIFICATION_ALLOWED_ERR) Raised on an attempt
58 * to change the value of a <a href="svgdom.html#ReadOnlyNodes">read only
59 * attribute</a>.
60 */
61 public final native void setXmlbase(String value) throws JavaScriptException /*-{
62 this.xmlbase = value;
63 }-*/;
64 /**
65 * The nearest ancestor <a href='http://www.w3.org/TR/SVG11/struct.html#SVGElement'
66 * title='svg element specification'>svg</a> element. Null if the given element
67 * is the outermost <a href='http://www.w3.org/TR/SVG11/struct.html#SVGElement'
68 * title='svg element specification'>svg</a> element.
69 */
70 public final native SVGSVGElement getOwnerSVGElement() /*-{
71 return this.ownerSVGElement;
72 }-*/;
73 /**
74 * The element which established the current viewport. Often, the nearest
75 * ancestor <a href='http://www.w3.org/TR/SVG11/struct.html#SVGElement' title='svg
76 * element specification'>svg</a> element. Null if the given element is the
77 * outermost <a href='http://www.w3.org/TR/SVG11/struct.html#SVGElement' title='svg
78 * element specification'>svg</a> element.
79 */
80 public final native SVGElement getViewportElement() /*-{
81 return this.viewportElement;
82 }-*/;
83
84 // Partial implementation of the svg::Stylable W3C IDL interface
85 // (the rest is inherited from Element)
86 public final native OMSVGAnimatedString getClassName_() /*-{
87 return this.className;
88 }-*/;
89
90 public final native String getMarkup() /*-{
91 return new XMLSerializer().serializeToString(this);
92 }-*/;
93 }