mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-05-18 17:12:54 +00:00
Unlike ensure_web_prototype<T>(), the cached version doesn't require the prototype type to be fully formed, so we can use it without including the FooPrototype.h header. It's also a bit less verbose. :^)
64 lines
2.2 KiB
C++
64 lines
2.2 KiB
C++
/*
|
|
* Copyright (c) 2022, Luke Wilde <lukew@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <LibWeb/Bindings/AudioConstructor.h>
|
|
#include <LibWeb/Bindings/HTMLAudioElementPrototype.h>
|
|
#include <LibWeb/DOM/ElementFactory.h>
|
|
#include <LibWeb/HTML/Scripting/Environments.h>
|
|
#include <LibWeb/HTML/Window.h>
|
|
#include <LibWeb/Namespace.h>
|
|
|
|
namespace Web::Bindings {
|
|
|
|
AudioConstructor::AudioConstructor(JS::Realm& realm)
|
|
: NativeFunction(*realm.intrinsics().function_prototype())
|
|
{
|
|
}
|
|
|
|
void AudioConstructor::initialize(JS::Realm& realm)
|
|
{
|
|
auto& vm = this->vm();
|
|
auto& window = verify_cast<HTML::Window>(realm.global_object());
|
|
NativeFunction::initialize(realm);
|
|
|
|
define_direct_property(vm.names.prototype, &window.cached_web_prototype("HTMLAudioElement"), 0);
|
|
define_direct_property(vm.names.length, JS::Value(0), JS::Attribute::Configurable);
|
|
}
|
|
|
|
JS::ThrowCompletionOr<JS::Value> AudioConstructor::call()
|
|
{
|
|
return vm().throw_completion<JS::TypeError>(JS::ErrorType::ConstructorWithoutNew, "Audio");
|
|
}
|
|
|
|
// https://html.spec.whatwg.org/multipage/media.html#dom-audio
|
|
JS::ThrowCompletionOr<JS::Object*> AudioConstructor::construct(FunctionObject&)
|
|
{
|
|
auto& vm = this->vm();
|
|
|
|
// 1. Let document be the current global object's associated Document.
|
|
auto& window = verify_cast<HTML::Window>(HTML::current_global_object());
|
|
auto& document = window.impl().associated_document();
|
|
|
|
// 2. Let audio be the result of creating an element given document, audio, and the HTML namespace.
|
|
auto audio = DOM::create_element(document, HTML::TagNames::audio, Namespace::HTML);
|
|
|
|
// 3. Set an attribute value for audio using "preload" and "auto".
|
|
audio->set_attribute(HTML::AttributeNames::preload, "auto"sv);
|
|
|
|
auto src_value = vm.argument(0);
|
|
|
|
// 4. If src is given, then set an attribute value for audio using "src" and src.
|
|
// (This will cause the user agent to invoke the object's resource selection algorithm before returning.)
|
|
if (!src_value.is_undefined()) {
|
|
auto src = TRY(src_value.to_string(vm));
|
|
audio->set_attribute(HTML::AttributeNames::src, move(src));
|
|
}
|
|
|
|
// 5. Return audio.
|
|
return audio.ptr();
|
|
}
|
|
|
|
}
|