ladybird/Libraries/LibWeb/SVG/SVGURIReference.h

56 lines
1.8 KiB
C
Raw Normal View History

2023-11-14 00:20:44 +00:00
/*
* Copyright (c) 2023, Luke Wilde <lukew@serenityos.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#pragma once
#include <LibWeb/Namespace.h>
2023-11-14 00:20:44 +00:00
#include <LibWeb/SVG/AttributeNames.h>
#include <LibWeb/SVG/SVGAnimatedString.h>
namespace Web::SVG {
enum class SupportsXLinkHref {
No,
Yes,
};
// https://svgwg.org/svg2-draft/types.html#InterfaceSVGURIReference
template<SupportsXLinkHref supports_xlink_href>
class SVGURIReferenceMixin {
public:
virtual ~SVGURIReferenceMixin() = default;
GC::Ref<SVGAnimatedString> href()
2023-11-14 00:20:44 +00:00
{
// The href IDL attribute represents the value of the href attribute, and, on elements that are defined to support
// it, the deprecated xlink:href attribute. On getting href, an SVGAnimatedString object is returned that:
// - reflects the href attribute, and
// - if the element is defined to support the deprecated xlink:href attribute, additionally reflects that
// deprecated attribute.
if (!m_href_animated_string) {
auto& this_svg_element = as<SVGElement>(*this);
m_href_animated_string = SVGAnimatedString::create(this_svg_element.realm(),
this_svg_element,
DOM::QualifiedName { AttributeNames::href, OptionalNone {}, OptionalNone {} },
supports_xlink_href == SupportsXLinkHref::Yes
? Optional<DOM::QualifiedName> { DOM::QualifiedName { AttributeNames::href, "xlink"_fly_string, Namespace::XLink } }
: OptionalNone {});
2023-11-14 00:20:44 +00:00
}
return *m_href_animated_string;
}
protected:
void visit_edges(JS::Cell::Visitor& visitor)
{
visitor.visit(m_href_animated_string);
}
private:
GC::Ptr<SVGAnimatedString> m_href_animated_string;
2023-11-14 00:20:44 +00:00
};
}