ImageConstructor.cpp 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. /*
  2. * Copyright (c) 2021, the SerenityOS developers.
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <LibWeb/Bindings/ExceptionOrUtils.h>
  7. #include <LibWeb/Bindings/HTMLImageElementPrototype.h>
  8. #include <LibWeb/Bindings/ImageConstructor.h>
  9. #include <LibWeb/DOM/ElementFactory.h>
  10. #include <LibWeb/HTML/Scripting/Environments.h>
  11. #include <LibWeb/HTML/Window.h>
  12. #include <LibWeb/Namespace.h>
  13. namespace Web::Bindings {
  14. ImageConstructor::ImageConstructor(JS::Realm& realm)
  15. : NativeFunction(realm.intrinsics().function_prototype())
  16. {
  17. }
  18. JS::ThrowCompletionOr<void> ImageConstructor::initialize(JS::Realm& realm)
  19. {
  20. auto& vm = this->vm();
  21. MUST_OR_THROW_OOM(NativeFunction::initialize(realm));
  22. define_direct_property(vm.names.prototype, &ensure_web_prototype<Bindings::HTMLImageElementPrototype>(realm, "HTMLImageElement"), 0);
  23. define_direct_property(vm.names.length, JS::Value(0), JS::Attribute::Configurable);
  24. return {};
  25. }
  26. JS::ThrowCompletionOr<JS::Value> ImageConstructor::call()
  27. {
  28. return vm().throw_completion<JS::TypeError>(JS::ErrorType::ConstructorWithoutNew, "Image");
  29. }
  30. // https://html.spec.whatwg.org/multipage/embedded-content.html#dom-image
  31. JS::ThrowCompletionOr<JS::NonnullGCPtr<JS::Object>> ImageConstructor::construct(FunctionObject&)
  32. {
  33. auto& vm = this->vm();
  34. // 1. Let document be the current global object's associated Document.
  35. auto& window = verify_cast<HTML::Window>(HTML::current_global_object());
  36. auto& document = window.associated_document();
  37. // 2. Let img be the result of creating an element given document, img, and the HTML namespace.
  38. auto image_element = TRY(Bindings::throw_dom_exception_if_needed(vm, [&]() { return DOM::create_element(document, HTML::TagNames::img, Namespace::HTML); }));
  39. // 3. If width is given, then set an attribute value for img using "width" and width.
  40. if (vm.argument_count() > 0) {
  41. u32 width = TRY(vm.argument(0).to_u32(vm));
  42. MUST(image_element->set_attribute(HTML::AttributeNames::width, DeprecatedString::formatted("{}", width)));
  43. }
  44. // 4. If height is given, then set an attribute value for img using "height" and height.
  45. if (vm.argument_count() > 1) {
  46. u32 height = TRY(vm.argument(1).to_u32(vm));
  47. MUST(image_element->set_attribute(HTML::AttributeNames::height, DeprecatedString::formatted("{}", height)));
  48. }
  49. // 5. Return img.
  50. return image_element;
  51. }
  52. }