/* * Copyright (c) 2021-2022, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include #include namespace Web::HTML { class EventHandler final : public JS::Cell { public: explicit EventHandler(String); explicit EventHandler(WebIDL::CallbackType&); // Either uncompiled source code or a callback. // https://html.spec.whatwg.org/multipage/webappapis.html#event-handler-value // NOTE: This does not contain Empty as part of the optimization of not allocating all event handler attributes up front. // FIXME: The string should actually be an "internal raw uncompiled handler" struct. This struct is just the uncompiled source code plus a source location for reporting parse errors. // https://html.spec.whatwg.org/multipage/webappapis.html#internal-raw-uncompiled-handler Variant value; // https://html.spec.whatwg.org/multipage/webappapis.html#event-handler-listener DOM::DOMEventListener* listener { nullptr }; private: virtual StringView class_name() const override { return "EventHandler"sv; } virtual void visit_edges(Cell::Visitor&) override; }; }