blob: 2367e8e372a05d3b389e07c8bbf52134cbfb2767 [file] [log] [blame]
/*
* Copyright (C) 2015 Apple Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
* THE POSSIBILITY OF SUCH DAMAGE.
*/
#pragma once
#if ENABLE(ATTACHMENT_ELEMENT)
#include "AttachmentTypes.h"
#include "HTMLElement.h"
namespace WebCore {
class AttachmentDataReader;
class File;
class HTMLImageElement;
class HTMLVideoElement;
class RenderAttachment;
class SharedBuffer;
class HTMLAttachmentElement final : public HTMLElement {
WTF_MAKE_ISO_ALLOCATED(HTMLAttachmentElement);
public:
static Ref<HTMLAttachmentElement> create(const QualifiedName&, Document&);
WEBCORE_EXPORT URL blobURL() const;
WEBCORE_EXPORT File* file() const;
enum class UpdateDisplayAttributes { No, Yes };
void setFile(RefPtr<File>&&, UpdateDisplayAttributes = UpdateDisplayAttributes::No);
String uniqueIdentifier() const { return m_uniqueIdentifier; }
void setUniqueIdentifier(const String& uniqueIdentifier) { m_uniqueIdentifier = uniqueIdentifier; }
WEBCORE_EXPORT void updateDisplayMode(AttachmentDisplayMode);
WEBCORE_EXPORT void updateFileWithData(Ref<SharedBuffer>&& data, std::optional<String>&& newContentType = std::nullopt, std::optional<String>&& newFilename = std::nullopt);
InsertedIntoAncestorResult insertedIntoAncestor(InsertionType, ContainerNode&) final;
void removedFromAncestor(RemovalType, ContainerNode&) final;
WEBCORE_EXPORT String attachmentTitle() const;
String attachmentType() const;
String attachmentPath() const;
RenderAttachment* attachmentRenderer() const;
WEBCORE_EXPORT void requestInfo(Function<void(const AttachmentInfo&)>&& callback);
void destroyReader(AttachmentDataReader&);
private:
HTMLAttachmentElement(const QualifiedName&, Document&);
virtual ~HTMLAttachmentElement();
RenderPtr<RenderElement> createElementRenderer(RenderStyle&&, const RenderTreePosition&) final;
Ref<HTMLImageElement> ensureInnerImage();
Ref<HTMLVideoElement> ensureInnerVideo();
RefPtr<HTMLImageElement> innerImage() const;
RefPtr<HTMLVideoElement> innerVideo() const;
void populateShadowRootIfNecessary();
void invalidateShadowRootChildrenIfNecessary();
AttachmentDisplayMode defaultDisplayMode() const
{
// FIXME: For now, all attachment elements automatically display using a file icon.
// In a followup patch, we'll change the default behavior to use in-place presentation
// for certain image MIME types.
return AttachmentDisplayMode::AsIcon;
}
bool shouldSelectOnMouseDown() final {
#if PLATFORM(IOS)
return false;
#else
return true;
#endif
}
bool canContainRangeEndPoint() const final { return false; }
void parseAttribute(const QualifiedName&, const AtomicString&) final;
RefPtr<File> m_file;
Vector<std::unique_ptr<AttachmentDataReader>> m_attachmentReaders;
String m_uniqueIdentifier;
};
} // namespace WebCore
#endif // ENABLE(ATTACHMENT_ELEMENT)