blob: a626776e0d4a46ab905d0e331e6cab9a753a223c [file] [log] [blame]
/*
* Copyright (C) 1999 Lars Knoll (knoll@kde.org)
* (C) 1999 Antti Koivisto (koivisto@kde.org)
* Copyright (C) 2004, 2006, 2007, 2008, 2009, 2012 Apple Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*
*/
#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 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
};
DisplayState displayState() const { return m_displayState; }
virtual void setDisplayState(DisplayState state) { m_displayState = state; }
virtual void updateSnapshot(PassRefPtr<Image>) { }
virtual void dispatchPendingMouseClick() { }
virtual bool isRestartedPlugin() const { return false; }
#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;
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&, MutableStylePropertySet&) OVERRIDE;
virtual bool useFallbackContent() const { return false; }
virtual void defaultEventHandler(Event*) OVERRIDE;
// Subclasses should use guardedDispatchBeforeLoadEvent instead of calling dispatchBeforeLoadEvent directly.
bool guardedDispatchBeforeLoadEvent(const String& sourceURL);
bool m_inBeforeLoadEventHandler;
private:
bool dispatchBeforeLoadEvent(const String& sourceURL); // Not implemented, generates a compile error if subclasses call this by mistake.
virtual bool areAuthorShadowsAllowed() const OVERRIDE { return false; }
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;
#if ENABLE(NETSCAPE_PLUGIN_API)
NPObject* m_NPObject;
#endif
bool m_isCapturingMouseEvents;
DisplayState m_displayState;
};
void isHTMLPlugInElement(const HTMLPlugInElement&); // Catch unnecessary runtime check of type known at compile time.
inline bool isHTMLPlugInElement(const Node& node) { return node.isPluginElement(); }
NODE_TYPE_CASTS(HTMLPlugInElement)
} // namespace WebCore
#endif // HTMLPlugInElement_h