#ifndef HTMLElement_h
#define HTMLElement_h
#include "StyledElement.h"
namespace WebCore {
class DocumentFragment;
class HTMLCollection;
class HTMLFormElement;
#if ENABLE(MICRODATA)
class HTMLPropertiesCollection;
class MicroDataItemValue;
#endif
enum TranslateAttributeMode {
TranslateAttributeYes,
TranslateAttributeNo,
TranslateAttributeInherit
};
class HTMLElement : public StyledElement {
public:
static PassRefPtr<HTMLElement> create(const QualifiedName& tagName, Document*);
PassRefPtr<HTMLCollection> children();
virtual String title() const OVERRIDE FINAL;
virtual short tabIndex() const OVERRIDE;
void setTabIndex(int);
String innerHTML() const;
String outerHTML() const;
void setInnerHTML(const String&, ExceptionCode&);
void setOuterHTML(const String&, ExceptionCode&);
void setInnerText(const String&, ExceptionCode&);
void setOuterText(const String&, ExceptionCode&);
Element* insertAdjacentElement(const String& where, Element* newChild, ExceptionCode&);
void insertAdjacentHTML(const String& where, const String& html, ExceptionCode&);
void insertAdjacentText(const String& where, const String& text, ExceptionCode&);
virtual bool hasCustomFocusLogic() const;
virtual bool supportsFocus() const OVERRIDE;
String contentEditable() const;
void setContentEditable(const String&, ExceptionCode&);
virtual bool draggable() const;
void setDraggable(bool);
bool spellcheck() const;
void setSpellcheck(bool);
bool translate() const;
void setTranslate(bool);
void click();
virtual void accessKeyAction(bool sendMouseEvents);
bool ieForbidsInsertHTML() const;
virtual bool rendererIsNeeded(const NodeRenderingContext&);
virtual RenderObject* createRenderer(RenderArena*, RenderStyle*);
HTMLFormElement* form() const { return virtualForm(); }
HTMLFormElement* findFormAncestor() const;
bool hasDirectionAuto() const;
TextDirection directionalityIfhasDirAutoAttribute(bool& isAuto) const;
#if ENABLE(MICRODATA)
void setItemValue(const String&, ExceptionCode&);
PassRefPtr<MicroDataItemValue> itemValue() const;
PassRefPtr<HTMLPropertiesCollection> properties();
void getItemRefElements(Vector<HTMLElement*>&);
#endif
virtual bool isHTMLUnknownElement() const { return false; }
virtual bool isLabelable() const { return false; }
protected:
HTMLElement(const QualifiedName& tagName, Document*, ConstructionType);
void addHTMLLengthToStyle(MutableStylePropertySet*, CSSPropertyID, const String& value);
void addHTMLColorToStyle(MutableStylePropertySet*, CSSPropertyID, const String& color);
void applyAlignmentAttributeToStyle(const AtomicString&, MutableStylePropertySet*);
void applyBorderAttributeToStyle(const AtomicString&, MutableStylePropertySet*);
virtual void parseAttribute(const QualifiedName&, const AtomicString&) OVERRIDE;
virtual bool isPresentationAttribute(const QualifiedName&) const OVERRIDE;
virtual void collectStyleForPresentationAttribute(const QualifiedName&, const AtomicString&, MutableStylePropertySet*) OVERRIDE;
unsigned parseBorderWidthAttribute(const AtomicString&) const;
virtual void childrenChanged(bool changedByParser = false, Node* beforeChange = 0, Node* afterChange = 0, int childCountDelta = 0);
void calculateAndAdjustDirectionality();
virtual bool isURLAttribute(const Attribute&) const OVERRIDE;
private:
virtual String nodeName() const OVERRIDE FINAL;
void mapLanguageAttributeToLocale(const AtomicString&, MutableStylePropertySet*);
virtual HTMLFormElement* virtualForm() const;
Node* insertAdjacent(const String& where, Node* newChild, ExceptionCode&);
PassRefPtr<DocumentFragment> textToFragment(const String&, ExceptionCode&);
void dirAttributeChanged(const AtomicString&);
void adjustDirectionalityIfNeededAfterChildAttributeChanged(Element* child);
void adjustDirectionalityIfNeededAfterChildrenChanged(Node* beforeChange, int childCountDelta);
TextDirection directionality(Node** strongDirectionalityTextNode= 0) const;
TranslateAttributeMode translateAttributeMode() const;
AtomicString eventNameForAttributeName(const QualifiedName& attrName) const;
#if ENABLE(MICRODATA)
virtual String itemValueText() const;
virtual void setItemValueText(const String&, ExceptionCode&);
#endif
};
inline HTMLElement* toHTMLElement(Node* node)
{
ASSERT_WITH_SECURITY_IMPLICATION(!node || node->isHTMLElement());
return static_cast<HTMLElement*>(node);
}
inline const HTMLElement* toHTMLElement(const Node* node)
{
ASSERT_WITH_SECURITY_IMPLICATION(!node || node->isHTMLElement());
return static_cast<const HTMLElement*>(node);
}
void toHTMLElement(const HTMLElement*);
inline HTMLElement::HTMLElement(const QualifiedName& tagName, Document* document, ConstructionType type = CreateHTMLElement)
: StyledElement(tagName, document, type)
{
ASSERT(tagName.localName().impl());
}
}
#endif // HTMLElement_h