2021-02-03 22:47:50 +01:00
/*
2022-08-08 14:12:01 +02:00
* Copyright ( c ) 2021 - 2022 , Andreas Kling < kling @ serenityos . org >
2021-02-03 22:47:50 +01:00
*
2021-04-22 01:24:48 -07:00
* SPDX - License - Identifier : BSD - 2 - Clause
2021-02-03 22:47:50 +01:00
*/
# pragma once
2022-12-04 18:02:33 +00:00
# include <AK/DeprecatedString.h>
2021-10-14 18:03:08 +01:00
# include <AK/Variant.h>
2022-08-08 14:12:01 +02:00
# include <LibJS/Heap/Cell.h>
2022-09-24 16:02:41 +01:00
# include <LibWeb/WebIDL/CallbackType.h>
2021-02-03 22:47:50 +01:00
namespace Web : : HTML {
2022-08-08 14:12:01 +02:00
class EventHandler final : public JS : : Cell {
public :
2022-12-04 18:02:33 +00:00
explicit EventHandler ( DeprecatedString ) ;
2022-09-24 16:02:41 +01:00
explicit EventHandler ( WebIDL : : CallbackType & ) ;
2021-02-03 22:47:50 +01:00
2021-10-14 18:03:08 +01:00
// 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
2022-12-04 18:02:33 +00:00
Variant < DeprecatedString , WebIDL : : CallbackType * > value ;
2021-10-14 18:03:08 +01:00
// https://html.spec.whatwg.org/multipage/webappapis.html#event-handler-listener
2022-08-08 14:12:01 +02:00
DOM : : DOMEventListener * listener { nullptr } ;
private :
virtual StringView class_name ( ) const override { return " EventHandler " sv ; }
virtual void visit_edges ( Cell : : Visitor & ) override ;
2021-02-03 22:47:50 +01:00
} ;
}