/*
 * Copyright (c) 2023, Luke Wilde <lukew@serenityos.org>
 *
 * SPDX-License-Identifier: BSD-2-Clause
 */

#pragma once

#include <LibWeb/Namespace.h>
#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()
    {
        // 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 {});
        }
        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;
};

}
