KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > org > enhydra > xml > lazydom > html > HTMLFormElementImpl


1 /*
2  * The Apache Software License, Version 1.1
3  *
4  *
5  * Copyright (c) 1999,2000 The Apache Software Foundation. All rights
6  * reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  *
12  * 1. Redistributions of source code must retain the above copyright
13  * notice, this list of conditions and the following disclaimer.
14  *
15  * 2. Redistributions in binary form must reproduce the above copyright
16  * notice, this list of conditions and the following disclaimer in
17  * the documentation and/or other materials provided with the
18  * distribution.
19  *
20  * 3. The end-user documentation included with the redistribution,
21  * if any, must include the following acknowledgment:
22  * "This product includes software developed by the
23  * Apache Software Foundation (http://www.apache.org/)."
24  * Alternately, this acknowledgment may appear in the software itself,
25  * if and wherever such third-party acknowledgments normally appear.
26  *
27  * 4. The names "Xerces" and "Apache Software Foundation" must
28  * not be used to endorse or promote products derived from this
29  * software without prior written permission. For written
30  * permission, please contact apache@apache.org.
31  *
32  * 5. Products derived from this software may not be called "Apache",
33  * nor may "Apache" appear in their name, without prior written
34  * permission of the Apache Software Foundation.
35  *
36  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
37  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
38  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
39  * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
40  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
41  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
42  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
43  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
44  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
45  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
46  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
47  * SUCH DAMAGE.
48  * ====================================================================
49  *
50  * This software consists of voluntary contributions made by many
51  * individuals on behalf of the Apache Software Foundation and was
52  * originally based on software copyright (c) 1999, International
53  * Business Machines, Inc., http://www.apache.org. For more
54  * information on the Apache Software Foundation, please see
55  * <http://www.apache.org/>.
56  */

57 package org.enhydra.xml.lazydom.html;
58 import org.enhydra.xml.lazydom.LazyElement;
59 import org.enhydra.xml.lazydom.LazyElementNoNS;
60 import org.w3c.dom.Node JavaDoc;
61 import org.w3c.dom.NodeList JavaDoc;
62 import org.w3c.dom.html.HTMLCollection;
63 import org.w3c.dom.html.HTMLFormElement;
64
65
66 /**
67  * @version $Revision: 1.3 $ $Date: 2005/01/26 08:29:24 $
68  * @author <a HREF="mailto:arkin@exoffice.com">Assaf Arkin</a>
69  * @see org.w3c.dom.html.HTMLFormElement
70  * @see LazyElementNoNS
71  */

72 public class HTMLFormElementImpl
73     extends LazyHTMLElement
74     implements HTMLFormElement
75 {
76
77     
78     public HTMLCollection getElements()
79     {
80         if ( _elements == null )
81             _elements = new HTMLCollectionImpl( this, HTMLCollectionImpl.ELEMENT );
82         return _elements;
83     }
84   
85
86     public int getLength()
87     {
88         return getElements().getLength();
89     }
90   
91   
92     public String JavaDoc getName()
93     {
94         return getAttribute( "name" );
95     }
96     
97     
98     public void setName( String JavaDoc name )
99     {
100         setAttribute( "name", name );
101     }
102
103     
104     public String JavaDoc getAcceptCharset()
105     {
106         return getAttribute( "accept-charset" );
107     }
108     
109     
110     public void setAcceptCharset( String JavaDoc acceptCharset )
111     {
112         setAttribute( "accept-charset", acceptCharset );
113     }
114
115   
116       public String JavaDoc getAction()
117     {
118         return getAttribute( "action" );
119     }
120     
121     
122     public void setAction( String JavaDoc action )
123     {
124         setAttribute( "action", action );
125     }
126   
127   
128       public String JavaDoc getEnctype()
129     {
130         return getAttribute( "enctype" );
131     }
132     
133     
134     public void setEnctype( String JavaDoc enctype )
135     {
136         setAttribute( "enctype", enctype );
137     }
138
139     
140       public String JavaDoc getMethod()
141     {
142         return capitalize( getAttribute( "method" ) );
143     }
144     
145     
146     public void setMethod( String JavaDoc method )
147     {
148         setAttribute( "method", method );
149     }
150   
151   
152     public String JavaDoc getTarget()
153     {
154         return getAttribute( "target" );
155     }
156     
157     
158     public void setTarget( String JavaDoc target )
159     {
160         setAttribute( "target", target );
161     }
162
163     
164     public void submit()
165     {
166         // No scripting in server-side DOM. This method is moot.
167
}
168
169     
170     public void reset()
171     {
172         // No scripting in server-side DOM. This method is moot.
173
}
174
175     /*
176      * Explicit implementation of getChildNodes() to avoid problems with
177      * overriding the getLength() method hidden in the super class.
178      */

179     public NodeList JavaDoc getChildNodes() {
180          if (!areChildrenExpanded()) {
181              expandChildren();
182          }
183
184         return getChildNodesUnoptimized();
185     }
186     
187     /**
188      * Explicit implementation of cloneNode() to ensure that cache used
189      * for getElements() gets cleared.
190      */

191     public Node JavaDoc cloneNode( boolean deep ) {
192         HTMLFormElementImpl clonedNode = (HTMLFormElementImpl)super.cloneNode( deep );
193         clonedNode._elements = null;
194         return clonedNode;
195     }
196
197     /**
198      * Constructor requires owner document.
199      *
200      * @param owner The owner HTML document
201      */

202     public HTMLFormElementImpl( LazyHTMLDocument owner, LazyElement template, String JavaDoc name )
203     {
204         super( owner, template, name );
205     }
206   
207     
208     /**
209      * Collection of all elements contained in this FORM.
210      */

211     private HTMLCollectionImpl _elements;
212     
213 }
214
215
Popular Tags