Fix for bug 5298, shape=default not supported for image maps. Implement
[WebKit-https.git] / WebCore / html / HTMLMapElement.cpp
1 /**
2  * This file is part of the DOM implementation for KDE.
3  *
4  * Copyright (C) 1999 Lars Knoll (knoll@kde.org)
5  *           (C) 1999 Antti Koivisto (koivisto@kde.org)
6  * Copyright (C) 2004, 2005, 2006 Apple Computer, Inc.
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., 59 Temple Place - Suite 330,
21  * Boston, MA 02111-1307, USA.
22  */
23 #include "config.h"
24 #include "HTMLMapElement.h"
25
26 #include "Document.h"
27 #include "HTMLAreaElement.h"
28 #include "HTMLCollection.h"
29 #include "HTMLNames.h"
30
31 using namespace std;
32
33 namespace WebCore {
34
35 using namespace HTMLNames;
36
37 HTMLMapElement::HTMLMapElement(Document *doc)
38     : HTMLElement(mapTag, doc)
39 {
40 }
41
42 HTMLMapElement::~HTMLMapElement()
43 {
44     document()->removeImageMap(this);
45 }
46
47 bool HTMLMapElement::checkDTD(const Node* newChild)
48 {
49     // FIXME: This seems really odd, allowing only blocks inside map elements.
50     return newChild->hasTagName(areaTag) || newChild->hasTagName(scriptTag) || inBlockTagList(newChild);
51 }
52
53 bool HTMLMapElement::mapMouseEvent(int x, int y, const IntSize& size, RenderObject::NodeInfo& info)
54 {
55     HTMLAreaElement* defaultArea = 0;
56     Node *node = this;
57     while ((node = node->traverseNextNode(this))) {
58         if (node->hasTagName(areaTag)) {
59             HTMLAreaElement* areaElt = static_cast<HTMLAreaElement*>(node);
60             if (areaElt->isDefault()) {
61                 if (!defaultArea)
62                     defaultArea = areaElt;
63             } else if (areaElt->mapMouseEvent(x, y, size, info))
64                 return true;
65         }
66     }
67     
68     if (defaultArea) {
69         info.setInnerNode(defaultArea);
70         info.setURLElement(defaultArea);
71     }
72     return defaultArea;
73 }
74
75 void HTMLMapElement::parseMappedAttribute(MappedAttribute* attr)
76 {
77     const QualifiedName& attrName = attr->name();
78     if (attrName == idAttr || attrName == nameAttr) {
79         Document* doc = document();
80         if (attrName == idAttr) {
81             // Call base class so that hasID bit gets set.
82             HTMLElement::parseMappedAttribute(attr);
83             if (doc->htmlMode() != Document::XHtml)
84                 return;
85         }
86         doc->removeImageMap(this);
87         m_name = attr->value();
88         if (m_name[0] == '#') {
89             String mapName(m_name.domString().copy());
90             mapName.remove(0, 1);
91             m_name = mapName;
92         }
93         doc->addImageMap(this);
94     } else
95         HTMLElement::parseMappedAttribute(attr);
96 }
97
98 PassRefPtr<HTMLCollection> HTMLMapElement::areas()
99 {
100     return new HTMLCollection(this, HTMLCollection::MapAreas);
101 }
102
103 String HTMLMapElement::name() const
104 {
105     return getAttribute(nameAttr);
106 }
107
108 void HTMLMapElement::setName(const String& value)
109 {
110     setAttribute(nameAttr, value);
111 }
112
113 }