HTMLPlugInElement.h [plain text]
#ifndef HTMLPlugInElement_h
#define HTMLPlugInElement_h
#include "HTMLFrameOwnerElement.h"
#include "Image.h"
#if ENABLE(NETSCAPE_PLUGIN_API)
struct NPObject;
#endif
namespace JSC {
namespace Bindings {
class Instance;
}
}
namespace WebCore {
class PluginReplacement;
class RenderEmbeddedObject;
class RenderWidget;
class Widget;
class HTMLPlugInElement : public HTMLFrameOwnerElement {
public:
virtual ~HTMLPlugInElement();
void resetInstance();
PassRefPtr<JSC::Bindings::Instance> getInstance();
Widget* pluginWidget() const;
enum DisplayState {
WaitingForSnapshot,
DisplayingSnapshot,
Restarting,
RestartingWithPendingMouseClick,
Playing,
PreparingPluginReplacement,
DisplayingPluginReplacement,
};
DisplayState displayState() const { return m_displayState; }
virtual void setDisplayState(DisplayState);
virtual void updateSnapshot(PassRefPtr<Image>) { }
virtual void dispatchPendingMouseClick() { }
virtual bool isRestartedPlugin() const { return false; }
JSC::JSObject* scriptObjectForPluginReplacement();
#if ENABLE(NETSCAPE_PLUGIN_API)
NPObject* getNPObject();
#endif
bool isCapturingMouseEvents() const { return m_isCapturingMouseEvents; }
void setIsCapturingMouseEvents(bool capturing) { m_isCapturingMouseEvents = capturing; }
virtual bool canContainRangeEndPoint() const override { return false; }
bool canProcessDrag() const;
#if PLATFORM(IOS)
virtual bool willRespondToMouseMoveEvents() override { return false; }
#endif
virtual bool willRespondToMouseClickEvents() override;
virtual bool isPlugInImageElement() const { return false; }
protected:
HTMLPlugInElement(const QualifiedName& tagName, Document&);
virtual void willDetachRenderers() override;
virtual bool isPresentationAttribute(const QualifiedName&) const override;
virtual void collectStyleForPresentationAttribute(const QualifiedName&, const AtomicString&, MutableStyleProperties&) override;
virtual bool useFallbackContent() const { return false; }
virtual void defaultEventHandler(Event*) override;
virtual bool requestObject(const String& url, const String& mimeType, const Vector<String>& paramNames, const Vector<String>& paramValues);
virtual RenderPtr<RenderElement> createElementRenderer(PassRef<RenderStyle>) override;
virtual void didAddUserAgentShadowRoot(ShadowRoot*) override;
bool guardedDispatchBeforeLoadEvent(const String& sourceURL);
bool m_inBeforeLoadEventHandler;
private:
void swapRendererTimerFired(Timer<HTMLPlugInElement>&);
bool shouldOverridePlugin(const String& url, const String& mimeType);
bool dispatchBeforeLoadEvent(const String& sourceURL);
virtual RenderWidget* renderWidgetForJSBindings() const = 0;
virtual bool supportsFocus() const override;
virtual bool isKeyboardFocusable(KeyboardEvent*) const override;
virtual bool isPluginElement() const override final;
RefPtr<JSC::Bindings::Instance> m_instance;
Timer<HTMLPlugInElement> m_swapRendererTimer;
RefPtr<PluginReplacement> m_pluginReplacement;
#if ENABLE(NETSCAPE_PLUGIN_API)
NPObject* m_NPObject;
#endif
bool m_isCapturingMouseEvents;
DisplayState m_displayState;
};
void isHTMLPlugInElement(const HTMLPlugInElement&); inline bool isHTMLPlugInElement(const Node& node) { return node.isPluginElement(); }
NODE_TYPE_CASTS(HTMLPlugInElement)
}
#endif // HTMLPlugInElement_h