a0765450a7f5799b603d63cad2efa51405a916ce
[WebKit-https.git] / Source / WebCore / html / HTMLLegendElement.cpp
1 /*
2  * Copyright (C) 1999 Lars Knoll (knoll@kde.org)
3  *           (C) 1999 Antti Koivisto (koivisto@kde.org)
4  *           (C) 2001 Dirk Mueller (mueller@kde.org)
5  * Copyright (C) 2004, 2005, 2006, 2010 Apple Inc. All rights reserved.
6  *           (C) 2006 Alexey Proskuryakov (ap@nypop.com)
7  *
8  * This library is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU Library General Public
10  * License as published by the Free Software Foundation; either
11  * version 2 of the License, or (at your option) any later version.
12  *
13  * This library is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16  * Library General Public License for more details.
17  *
18  * You should have received a copy of the GNU Library General Public License
19  * along with this library; see the file COPYING.LIB.  If not, write to
20  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
21  * Boston, MA 02110-1301, USA.
22  *
23  */
24
25 #include "config.h"
26 #include "HTMLLegendElement.h"
27
28 #include "ElementIterator.h"
29 #include "HTMLFieldSetElement.h"
30 #include "HTMLFormControlElement.h"
31 #include "HTMLNames.h"
32
33 namespace WebCore {
34
35 using namespace HTMLNames;
36
37
38 inline HTMLLegendElement::HTMLLegendElement(const QualifiedName& tagName, Document& document)
39     : HTMLElement(tagName, document)
40 {
41     ASSERT(hasTagName(legendTag));
42 }
43
44 PassRefPtr<HTMLLegendElement> HTMLLegendElement::create(const QualifiedName& tagName, Document& document)
45 {
46     return adoptRef(new HTMLLegendElement(tagName, document));
47 }
48
49 HTMLFormControlElement* HTMLLegendElement::associatedControl()
50 {
51     // Check if there's a fieldset belonging to this legend.
52     auto fieldsetAncestors = ancestorsOfType<HTMLFieldSetElement>(this);
53     auto enclosingFieldset = fieldsetAncestors.begin();
54     if (enclosingFieldset == fieldsetAncestors.end())
55         return 0;
56
57     // Find first form element inside the fieldset that is not a legend element.
58     // FIXME: Should we consider tabindex?
59     return descendantsOfType<HTMLFormControlElement>(&*enclosingFieldset).first();
60 }
61
62 void HTMLLegendElement::focus(bool, FocusDirection direction)
63 {
64     if (isFocusable())
65         Element::focus(true, direction);
66         
67     // To match other browsers' behavior, never restore previous selection.
68     if (HTMLFormControlElement* control = associatedControl())
69         control->focus(false, direction);
70 }
71
72 void HTMLLegendElement::accessKeyAction(bool sendMouseEvents)
73 {
74     if (HTMLFormControlElement* control = associatedControl())
75         control->accessKeyAction(sendMouseEvents);
76 }
77
78 HTMLFormElement* HTMLLegendElement::virtualForm() const
79 {
80     // According to the specification, If the legend has a fieldset element as
81     // its parent, then the form attribute must return the same value as the
82     // form attribute on that fieldset element. Otherwise, it must return null.
83     ContainerNode* fieldset = parentNode();
84     if (!fieldset || !fieldset->hasTagName(fieldsetTag))
85         return 0;
86
87     return static_cast<HTMLFieldSetElement*>(fieldset)->form();
88 }
89     
90 } // namespace