#ifndef HTMLPlugInElement_h
#define HTMLPlugInElement_h
#include "bindings/v8/SharedPersistent.h"
#include "core/html/HTMLFrameOwnerElement.h"
struct NPObject;
namespace WebCore {
class HTMLImageLoader;
class RenderEmbeddedObject;
class RenderWidget;
class Widget;
enum PreferPlugInsForImagesOption {
ShouldPreferPlugInsForImages,
ShouldNotPreferPlugInsForImages
};
class HTMLPlugInElement : public HTMLFrameOwnerElement {
public:
virtual ~HTMLPlugInElement();
void resetInstance();
SharedPersistent<v8::Object>* pluginWrapper();
Widget* pluginWidget() const;
NPObject* getNPObject();
bool canProcessDrag() const;
const String& url() const { return m_url; }
bool needsWidgetUpdate() const { return m_needsWidgetUpdate; }
void setNeedsWidgetUpdate(bool needsWidgetUpdate) { m_needsWidgetUpdate = needsWidgetUpdate; }
void updateWidget();
void requestPluginCreationWithoutRendererIfPossible();
void createPluginWithoutRenderer();
protected:
HTMLPlugInElement(const QualifiedName& tagName, Document&, bool createdByParser, PreferPlugInsForImagesOption);
virtual void didMoveToNewDocument(Document& oldDocument) OVERRIDE;
virtual bool isPresentationAttribute(const QualifiedName&) const OVERRIDE;
virtual void collectStyleForPresentationAttribute(const QualifiedName&, const AtomicString&, MutableStylePropertySet*) OVERRIDE;
virtual bool useFallbackContent() const;
virtual RenderWidget* renderWidgetForJSBindings() const;
bool isImageType();
bool shouldPreferPlugInsForImages() const { return m_shouldPreferPlugInsForImages; }
RenderEmbeddedObject* renderEmbeddedObject() const;
bool allowedToLoadFrameURL(const String& url);
bool requestObject(const String& url, const String& mimeType, const Vector<String>& paramNames, const Vector<String>& paramValues);
bool shouldUsePlugin(const KURL&, const String& mimeType, bool hasFallback, bool& useFallback);
void dispatchErrorEvent();
String m_serviceType;
String m_url;
KURL m_loadedUrl;
OwnPtr<HTMLImageLoader> m_imageLoader;
bool m_isDelayingLoadEvent;
private:
virtual void removeAllEventListeners() OVERRIDE FINAL;
virtual bool canContainRangeEndPoint() const OVERRIDE { return false; }
virtual bool willRespondToMouseClickEvents() OVERRIDE FINAL;
virtual void defaultEventHandler(Event*) OVERRIDE FINAL;
virtual void attach(const AttachContext& = AttachContext()) OVERRIDE FINAL;
virtual void detach(const AttachContext& = AttachContext()) OVERRIDE FINAL;
virtual void finishParsingChildren() OVERRIDE FINAL;
virtual RenderObject* createRenderer(RenderStyle*) OVERRIDE;
virtual void willRecalcStyle(StyleRecalcChange) OVERRIDE FINAL;
virtual bool supportsFocus() const OVERRIDE FINAL { return true; }
virtual bool rendererIsFocusable() const OVERRIDE FINAL;
virtual bool isKeyboardFocusable() const OVERRIDE FINAL;
virtual void didAddUserAgentShadowRoot(ShadowRoot&) OVERRIDE FINAL;
virtual void didAddShadowRoot(ShadowRoot&) OVERRIDE FINAL;
virtual bool hasCustomFocusLogic() const OVERRIDE;
virtual bool isPluginElement() const OVERRIDE FINAL;
virtual RenderWidget* existingRenderWidget() const = 0;
virtual void updateWidgetInternal() = 0;
enum DisplayState {
Restarting,
RestartingWithPendingMouseClick,
Playing
};
DisplayState displayState() const { return m_displayState; }
void setDisplayState(DisplayState state) { m_displayState = state; }
const String loadedMimeType() const;
bool loadPlugin(const KURL&, const String& mimeType, const Vector<String>& paramNames, const Vector<String>& paramValues, bool useFallback, bool requireRenderer);
bool pluginIsLoadable(const KURL&, const String& mimeType);
bool wouldLoadAsNetscapePlugin(const String& url, const String& serviceType);
mutable RefPtr<SharedPersistent<v8::Object> > m_pluginWrapper;
NPObject* m_NPObject;
bool m_isCapturingMouseEvents;
bool m_needsWidgetUpdate;
bool m_shouldPreferPlugInsForImages;
DisplayState m_displayState;
RefPtr<Widget> m_persistedPluginWidget;
};
inline bool isHTMLPlugInElement(const Element& element)
{
return element.isHTMLElement() && toHTMLElement(element).isPluginElement();
}
inline bool isHTMLPlugInElement(const HTMLElement& element)
{
return element.isPluginElement();
}
DEFINE_HTMLELEMENT_TYPE_CASTS_WITH_FUNCTION(HTMLPlugInElement);
}
#endif