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
2023-12-16 17:49:34 +03:30
# include <AK/ByteString.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>
2023-11-19 19:47:52 +01:00
# include <LibJS/Heap/CellAllocator.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 {
2023-03-20 13:37:11 -07:00
JS_CELL ( EventHandler , JS : : Cell ) ;
2023-11-19 19:47:52 +01:00
JS_DECLARE_ALLOCATOR ( EventHandler ) ;
2023-03-20 13:37:11 -07:00
2022-08-08 14:12:01 +02:00
public :
2023-12-16 17:49:34 +03:30
explicit EventHandler ( ByteString ) ;
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
2023-12-16 17:49:34 +03:30
Variant < ByteString , JS : : GCPtr < WebIDL : : CallbackType > > value ;
2021-10-14 18:03:08 +01:00
// https://html.spec.whatwg.org/multipage/webappapis.html#event-handler-listener
2023-02-26 16:09:02 -07:00
JS : : GCPtr < DOM : : DOMEventListener > listener ;
2022-08-08 14:12:01 +02:00
private :
virtual void visit_edges ( Cell : : Visitor & ) override ;
2021-02-03 22:47:50 +01:00
} ;
}