blob: d41182595aac80c013823a082efd1bd30f0f2a86 [file] [log] [blame]
/*
* Copyright (C) 1999 Lars Knoll ([email protected])
* (C) 1999 Antti Koivisto ([email protected])
* Copyright (C) 2004-2019 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.
*
*/
#pragma once
#include <WebCore/HTMLFrameOwnerElement.h>
#include <WebCore/Image.h>
#include <WebCore/JSValueInWrappedObject.h>
#include <WebCore/RenderEmbeddedObject.h>
#include <wtf/Platform.h>
namespace JSC {
namespace Bindings {
class Instance;
}
}
namespace WebCore {
class HTMLImageLoader;
class PluginReplacement;
class PluginViewBase;
class RenderWidget;
class VoidCallback;
enum class CreatePlugins : bool { No, Yes };
class HTMLPlugInElement : public HTMLFrameOwnerElement {
WTF_MAKE_TZONE_ALLOCATED(HTMLPlugInElement);
WTF_OVERRIDE_DELETE_FOR_CHECKED_PTR(HTMLPlugInElement);
public:
virtual ~HTMLPlugInElement();
void resetInstance();
JSC::Bindings::Instance* bindingsInstance();
enum class PluginLoadingPolicy { DoNotLoad, Load };
WEBCORE_EXPORT PluginViewBase* pluginWidget(PluginLoadingPolicy = PluginLoadingPolicy::Load) const;
enum class DisplayState : uint8_t {
Playing,
PreparingPluginReplacement,
DisplayingPluginReplacement,
};
DisplayState displayState() const { return m_displayState; }
void setDisplayState(DisplayState);
bool isCapturingMouseEvents() const { return m_isCapturingMouseEvents; }
void setIsCapturingMouseEvents(bool capturing) { m_isCapturingMouseEvents = capturing; }
#if PLATFORM(IOS_FAMILY)
bool willRespondToMouseMoveEvents() const final { return false; }
#endif
bool willRespondToMouseClickEventsWithEditability(Editability) const final;
WEBCORE_EXPORT void pluginDestroyedWithPendingPDFTestCallback(RefPtr<VoidCallback>&&);
WEBCORE_EXPORT RefPtr<VoidCallback> takePendingPDFTestCallback();
RenderEmbeddedObject* renderEmbeddedObject() const;
virtual void updateWidget(CreatePlugins) = 0;
const String& serviceType() const { return m_serviceType; }
const String& url() const { return m_url; }
bool needsWidgetUpdate() const { return m_needsWidgetUpdate; }
void setNeedsWidgetUpdate(bool needsWidgetUpdate) { m_needsWidgetUpdate = needsWidgetUpdate; }
bool shouldBypassCSPForPDFPlugin(const String& contentType) const;
protected:
HTMLPlugInElement(const QualifiedName& tagName, Document&, OptionSet<TypeFlag> = { });
bool canContainRangeEndPoint() const override { return false; }
void willDetachRenderers() override;
bool hasPresentationalHintsForAttribute(const QualifiedName&) const override;
void collectPresentationalHintsForAttribute(const QualifiedName&, const AtomString&, MutableStyleProperties&) override;
virtual bool useFallbackContent() const { return false; }
InsertedIntoAncestorResult insertedIntoAncestor(InsertionType, ContainerNode& parentOfInsertedTree) override;
void removedFromAncestor(RemovalType, ContainerNode& oldParentOfRemovedTree) override;
void defaultEventHandler(Event&) final;
void didMoveToNewDocument(Document& oldDocument, Document& newDocument) override;
bool requestObject(const String& url, const String& mimeType, const Vector<AtomString>& paramNames, const Vector<AtomString>& paramValues);
RenderPtr<RenderElement> createElementRenderer(RenderStyle&&, const RenderTreePosition&) override;
bool isReplaced(const RenderStyle* = nullptr) const final;
void didAddUserAgentShadowRoot(ShadowRoot&) final;
// This will load the plugin if necessary.
virtual CheckedPtr<RenderWidget> renderWidgetLoadingPlugin() const;
bool isImageType();
HTMLImageLoader* imageLoader() { return m_imageLoader.get(); }
void updateImageLoaderWithNewURLSoon();
bool canLoadURL(const String& relativeURL) const;
bool wouldLoadAsPlugIn(const String& relativeURL, const String& serviceType);
void scheduleUpdateForAfterStyleResolution();
String m_serviceType;
String m_url;
private:
void swapRendererTimerFired();
bool shouldOverridePlugin(const String& url, const String& mimeType);
bool supportsFocus() const final;
bool isKeyboardFocusable(const FocusEventData&) const final;
bool isPluginElement() const final;
bool canLoadScriptURL(const URL&) const final;
bool canLoadPlugInContent(const String& relativeURL, const String& mimeType) const;
bool canLoadURL(const URL&) const;
RenderPtr<RenderElement> createPluginRenderer(RenderStyle&&, const RenderTreePosition&);
bool childShouldCreateRenderer(const Node&) const override;
void willRecalcStyle(OptionSet<Style::Change>) final;
void didRecalcStyle(OptionSet<Style::Change>) final;
void didAttachRenderers() final;
void prepareForDocumentSuspension() final;
void resumeFromDocumentSuspension() final;
void updateAfterStyleResolution();
constexpr static OptionSet<TypeFlag> pluginElementTypeFlags();
RefPtr<JSC::Bindings::Instance> m_instance;
Timer m_swapRendererTimer;
const RefPtr<PluginReplacement> m_pluginReplacement;
bool m_isCapturingMouseEvents { false };
DisplayState m_displayState { DisplayState::Playing };
RefPtr<VoidCallback> m_pendingPDFTestCallback;
bool m_needsWidgetUpdate { false };
bool m_needsDocumentActivationCallbacks { false };
const std::unique_ptr<HTMLImageLoader> m_imageLoader;
bool m_needsImageReload { false };
bool m_hasUpdateScheduledForAfterStyleResolution { false };
};
} // namespace WebCore
SPECIALIZE_TYPE_TRAITS_BEGIN(WebCore::HTMLPlugInElement)
static bool isType(const WebCore::Node& node) { return node.isPluginElement(); }
SPECIALIZE_TYPE_TRAITS_END()