/* * Copyright (C) 2008, 2009, 2011, 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 HTMLPlugInImageElement_h #define HTMLPlugInImageElement_h #include "HTMLPlugInElement.h" #include "RenderStyle.h" #include namespace WebCore { class HTMLImageLoader; class FrameLoader; class MouseEvent; enum PluginCreationOption { CreateAnyWidgetType, CreateOnlyNonNetscapePlugins, }; enum PreferPlugInsForImagesOption { ShouldPreferPlugInsForImages, ShouldNotPreferPlugInsForImages }; // Base class for HTMLObjectElement and HTMLEmbedElement class HTMLPlugInImageElement : public HTMLPlugInElement, public ImageLoaderClientBase { public: virtual ~HTMLPlugInImageElement(); RenderEmbeddedObject* renderEmbeddedObject() const; virtual void updateWidget(PluginCreationOption) = 0; const String& serviceType() const { return m_serviceType; } const String& url() const { return m_url; } bool shouldPreferPlugInsForImages() const { return m_shouldPreferPlugInsForImages; } // Public for FrameView::addWidgetToUpdate() bool needsWidgetUpdate() const { return m_needsWidgetUpdate; } void setNeedsWidgetUpdate(bool needsWidgetUpdate) { m_needsWidgetUpdate = needsWidgetUpdate; } void setPendingClickEvent(PassRefPtr); protected: HTMLPlugInImageElement(const QualifiedName& tagName, Document*, bool createdByParser, PreferPlugInsForImagesOption); bool isImageType(); OwnPtr m_imageLoader; String m_serviceType; String m_url; static void updateWidgetCallback(Node*, unsigned = 0); virtual void attach(); virtual void detach(); bool allowedToLoadFrameURL(const String& url); bool wouldLoadAsNetscapePlugin(const String& url, const String& serviceType); virtual void didMoveToNewDocument(Document* oldDocument) OVERRIDE; virtual void documentWillSuspendForPageCache() OVERRIDE; virtual void documentDidResumeFromPageCache() OVERRIDE; virtual PassRefPtr customStyleForRenderer() OVERRIDE; private: virtual RenderObject* createRenderer(RenderArena*, RenderStyle*); virtual bool willRecalcStyle(StyleChange); virtual void finishParsingChildren(); void updateWidgetIfNecessary(); virtual bool useFallbackContent() const { return false; } virtual void updateSnapshot(PassRefPtr) OVERRIDE; virtual void dispatchPendingMouseClick() OVERRIDE; void simulatedMouseClickTimerFired(DeferrableOneShotTimer*); bool m_needsWidgetUpdate; bool m_shouldPreferPlugInsForImages; bool m_needsDocumentActivationCallbacks; RefPtr m_customStyleForPageCache; RefPtr m_pendingClickEventFromSnapshot; DeferrableOneShotTimer m_simulatedMouseClickTimer; }; } // namespace WebCore #endif // HTMLPlugInImageElement_h