2023-04-04 09:28:59 -04:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2023, Tim Flynn <trflynn89@serenityos.org>
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <LibWeb/Bindings/Intrinsics.h>
|
|
|
|
#include <LibWeb/Bindings/TrackEventPrototype.h>
|
|
|
|
#include <LibWeb/HTML/TrackEvent.h>
|
|
|
|
|
|
|
|
namespace Web::HTML {
|
|
|
|
|
2023-12-23 09:15:27 -05:00
|
|
|
JS_DEFINE_ALLOCATOR(TrackEvent);
|
|
|
|
|
2023-08-13 07:05:26 -04:00
|
|
|
JS::NonnullGCPtr<TrackEvent> TrackEvent::create(JS::Realm& realm, FlyString const& event_name, TrackEventInit event_init)
|
2023-04-04 09:28:59 -04:00
|
|
|
{
|
2023-08-13 07:05:26 -04:00
|
|
|
return realm.heap().allocate<TrackEvent>(realm, realm, event_name, move(event_init));
|
2023-04-04 09:28:59 -04:00
|
|
|
}
|
|
|
|
|
2023-06-13 10:55:03 -04:00
|
|
|
WebIDL::ExceptionOr<JS::NonnullGCPtr<TrackEvent>> TrackEvent::construct_impl(JS::Realm& realm, FlyString const& event_name, TrackEventInit event_init)
|
2023-04-04 09:28:59 -04:00
|
|
|
{
|
2023-06-13 10:55:03 -04:00
|
|
|
return create(realm, event_name, move(event_init));
|
2023-04-04 09:28:59 -04:00
|
|
|
}
|
|
|
|
|
2023-06-13 10:55:03 -04:00
|
|
|
TrackEvent::TrackEvent(JS::Realm& realm, FlyString const& event_name, TrackEventInit event_init)
|
2023-04-06 10:12:33 -04:00
|
|
|
: DOM::Event(realm, event_name, event_init)
|
2023-06-13 10:55:03 -04:00
|
|
|
, m_track(move(event_init.track))
|
2023-04-04 09:28:59 -04:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2023-08-07 02:41:28 -04:00
|
|
|
void TrackEvent::initialize(JS::Realm& realm)
|
2023-04-04 09:28:59 -04:00
|
|
|
{
|
2023-08-07 02:41:28 -04:00
|
|
|
Base::initialize(realm);
|
2023-11-21 18:55:21 -05:00
|
|
|
set_prototype(&Bindings::ensure_web_prototype<Bindings::TrackEventPrototype>(realm, "TrackEvent"_fly_string));
|
2023-04-04 09:28:59 -04:00
|
|
|
}
|
|
|
|
|
2023-06-13 10:55:03 -04:00
|
|
|
Variant<Empty, JS::Handle<VideoTrack>, JS::Handle<AudioTrack>> TrackEvent::track() const
|
|
|
|
{
|
|
|
|
// FIXME: This is a bit awkward. When creating a nullable union, our IDL generator creates a type of
|
|
|
|
// Optional<Variant<...>>, using an empty Optional to represent null. But when retrieving the
|
|
|
|
// attribute, it expects a type of Variant<Empty, ...>, using Empty to represent null.
|
|
|
|
if (!m_track.has_value())
|
|
|
|
return Empty {};
|
|
|
|
|
|
|
|
return *m_track;
|
|
|
|
}
|
|
|
|
|
2023-04-04 09:28:59 -04:00
|
|
|
}
|