123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- /*
- * Copyright (c) 2024, Jelle Raaijmakers <jelle@ladybird.org>
- *
- * SPDX-License-Identifier: BSD-2-Clause
- */
- #include <LibWeb/HTML/Focus.h>
- #include <LibWeb/HTML/HTMLElement.h>
- #include <LibWeb/HTML/HTMLOrSVGElement.h>
- #include <LibWeb/MathML/MathMLElement.h>
- #include <LibWeb/SVG/SVGElement.h>
- namespace Web::HTML {
- // https://html.spec.whatwg.org/multipage/dom.html#dom-dataset-dev
- template<typename ElementBase>
- GC::Ref<DOMStringMap> HTMLOrSVGElement<ElementBase>::dataset()
- {
- if (!m_dataset)
- m_dataset = DOMStringMap::create(*static_cast<ElementBase*>(this));
- return *m_dataset;
- }
- // https://html.spec.whatwg.org/multipage/interaction.html#dom-focus
- template<typename ElementBase>
- void HTMLOrSVGElement<ElementBase>::focus()
- {
- // FIXME: below are the focus(options) steps, also implement focus()
- // 1. If the element is marked as locked for focus, then return.
- if (m_locked_for_focus)
- return;
- // 2. Mark the element as locked for focus.
- m_locked_for_focus = true;
- // 3. Run the focusing steps for the element.
- run_focusing_steps(static_cast<ElementBase*>(this));
- // FIXME: 4. If the value of the preventScroll dictionary member of options is false,
- // then scroll the element into view with scroll behavior "auto",
- // block flow direction position set to an implementation-defined value,
- // and inline base direction position set to an implementation-defined value.
- // 5. Unmark the element as locked for focus.
- m_locked_for_focus = false;
- }
- // https://html.spec.whatwg.org/multipage/interaction.html#dom-blur
- template<typename ElementBase>
- void HTMLOrSVGElement<ElementBase>::blur()
- {
- // The blur() method, when invoked, should run the unfocusing steps for the element on which the method was called.
- run_unfocusing_steps(static_cast<ElementBase*>(this));
- // User agents may selectively or uniformly ignore calls to this method for usability reasons.
- }
- // https://html.spec.whatwg.org/#dom-noncedelement-nonce
- template<typename ElementBase>
- void HTMLOrSVGElement<ElementBase>::attribute_changed(FlyString const& local_name, Optional<String> const&, Optional<String> const& value, Optional<FlyString> const& namespace_)
- {
- // 1. If element does not include HTMLOrSVGElement, then return.
- // 2. If localName is not nonce or namespace is not null, then return.
- if (local_name != HTML::AttributeNames::nonce || namespace_.has_value())
- return;
- // 3. If value is null, then set element's [[CryptographicNonce]] to the empty string.
- if (!value.has_value()) {
- m_cryptographic_nonce = {};
- }
- // 4. Otherwise, set element's [[CryptographicNonce]] to value.
- else {
- m_cryptographic_nonce = value.value();
- }
- }
- // https://html.spec.whatwg.org/#dom-noncedelement-nonce
- template<typename ElementBase>
- WebIDL::ExceptionOr<void> HTMLOrSVGElement<ElementBase>::cloned(DOM::Node& copy, bool)
- {
- // The cloning steps for elements that include HTMLOrSVGElement must set the
- // [[CryptographicNonce]] slot on the copy to the value of the slot on the element being cloned.
- static_cast<ElementBase&>(copy).m_cryptographic_nonce = m_cryptographic_nonce;
- return {};
- }
- // https://html.spec.whatwg.org/#dom-noncedelement-nonce
- template<typename ElementBase>
- void HTMLOrSVGElement<ElementBase>::inserted()
- {
- // Whenever an element including HTMLOrSVGElement becomes browsing-context connected, the user
- // agent must execute the following steps on the element:
- DOM::Element& element = *static_cast<ElementBase*>(this);
- // FIXME: 1. Let CSP list be element's shadow-including root's policy container's CSP list.
- [[maybe_unused]] auto policy_container = element.shadow_including_root().document().policy_container();
- // FIXME: 2. If CSP list contains a header-delivered Content Security Policy, and element has a
- // nonce content attribute attr whose value is not the empty string, then:
- if (true && element.has_attribute(HTML::AttributeNames::nonce)) {
- // 2.1. Let nonce be element's [[CryptographicNonce]].
- auto nonce = m_cryptographic_nonce;
- // 2.2. Set an attribute value for element using "nonce" and the empty string.
- element.set_attribute_value(HTML::AttributeNames::nonce, {});
- // 2.3. Set element's [[CryptographicNonce]] to nonce.
- m_cryptographic_nonce = nonce;
- }
- }
- template<typename ElementBase>
- void HTMLOrSVGElement<ElementBase>::visit_edges(JS::Cell::Visitor& visitor)
- {
- visitor.visit(m_dataset);
- }
- template class HTMLOrSVGElement<HTMLElement>;
- template class HTMLOrSVGElement<MathML::MathMLElement>;
- template class HTMLOrSVGElement<SVG::SVGElement>;
- }
|