ladybird/Userland/Libraries/LibWeb/HTML/HTMLTemplateElement.cpp
Luke 62c015dc96 LibWeb: Implement the adoption steps for <template> elements
While I'm here with the cloning steps, let's implement this too.
2021-07-05 12:39:46 +02:00

65 lines
2.2 KiB
C++

/*
* Copyright (c) 2020, the SerenityOS developers.
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#include <LibWeb/DOM/Document.h>
#include <LibWeb/HTML/HTMLTemplateElement.h>
namespace Web::HTML {
HTMLTemplateElement::HTMLTemplateElement(DOM::Document& document, QualifiedName qualified_name)
: HTMLElement(document, move(qualified_name))
{
m_content = adopt_ref(*new DOM::DocumentFragment(appropriate_template_contents_owner_document(document)));
m_content->set_host(*this);
}
HTMLTemplateElement::~HTMLTemplateElement()
{
}
DOM::Document& HTMLTemplateElement::appropriate_template_contents_owner_document(DOM::Document& document)
{
if (!document.created_for_appropriate_template_contents()) {
if (!document.associated_inert_template_document()) {
auto new_document = DOM::Document::create();
new_document->set_created_for_appropriate_template_contents(true);
// FIXME: If doc is an HTML document, mark new doc as an HTML document also.
document.set_associated_inert_template_document(new_document);
}
return *document.associated_inert_template_document();
}
return document;
}
// https://html.spec.whatwg.org/multipage/scripting.html#the-template-element:concept-node-adopt-ext
void HTMLTemplateElement::adopted_from(DOM::Document&)
{
// NOTE: It seems the spec has been changed since appropriate_template_contents_owner_document was written above.
// That function is now part of document, which ends up returning associated_inert_template_document in the new version anyway.
appropriate_template_contents_owner_document(document()).adopt_node(content());
}
// https://html.spec.whatwg.org/multipage/scripting.html#the-template-element:concept-node-clone-ext
void HTMLTemplateElement::cloned(Node& copy, bool clone_children)
{
if (!clone_children)
return;
auto& template_clone = verify_cast<HTMLTemplateElement>(copy);
content()->for_each_child([&](auto& child) {
auto cloned_child = child.clone_node(&template_clone.content()->document(), true);
// FIXME: Should this use TreeNode::append_child instead?
template_clone.content()->append_child(cloned_child);
});
}
}