MimeTypeArray.cpp 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. /*
  2. * Copyright (c) 2023, Luke Wilde <lukew@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <LibWeb/Bindings/Intrinsics.h>
  7. #include <LibWeb/Bindings/MimeTypeArrayPrototype.h>
  8. #include <LibWeb/HTML/MimeTypeArray.h>
  9. #include <LibWeb/HTML/Scripting/Environments.h>
  10. #include <LibWeb/HTML/Window.h>
  11. #include <LibWeb/Page/Page.h>
  12. namespace Web::HTML {
  13. GC_DEFINE_ALLOCATOR(MimeTypeArray);
  14. MimeTypeArray::MimeTypeArray(JS::Realm& realm)
  15. : Bindings::PlatformObject(realm)
  16. {
  17. m_legacy_platform_object_flags = LegacyPlatformObjectFlags {
  18. .supports_indexed_properties = true,
  19. .supports_named_properties = true,
  20. .has_legacy_unenumerable_named_properties_interface_extended_attribute = true,
  21. };
  22. }
  23. MimeTypeArray::~MimeTypeArray() = default;
  24. void MimeTypeArray::initialize(JS::Realm& realm)
  25. {
  26. Base::initialize(realm);
  27. WEB_SET_PROTOTYPE_FOR_INTERFACE(MimeTypeArray);
  28. }
  29. // https://html.spec.whatwg.org/multipage/system-state.html#pdf-viewing-support:support-named-properties-2
  30. Vector<FlyString> MimeTypeArray::supported_property_names() const
  31. {
  32. // The MimeTypeArray interface supports named properties. If the user agent's PDF viewer supported is true, then they are the PDF viewer mime types. Otherwise, they are the empty list.
  33. auto const& window = verify_cast<HTML::Window>(HTML::relevant_global_object(*this));
  34. if (!window.page().pdf_viewer_supported())
  35. return {};
  36. // https://html.spec.whatwg.org/multipage/system-state.html#pdf-viewer-mime-types
  37. static Vector<FlyString> const mime_types = {
  38. "application/pdf"_fly_string,
  39. "text/pdf"_fly_string,
  40. };
  41. return mime_types;
  42. }
  43. // https://html.spec.whatwg.org/multipage/system-state.html#dom-mimetypearray-length
  44. size_t MimeTypeArray::length() const
  45. {
  46. // The MimeTypeArray interface's length getter steps are to return this's relevant global object's PDF viewer mime type objects's size.
  47. auto& window = verify_cast<HTML::Window>(HTML::relevant_global_object(*this));
  48. return window.pdf_viewer_mime_type_objects().size();
  49. }
  50. // https://html.spec.whatwg.org/multipage/system-state.html#dom-mimetypearray-item
  51. GC::Ptr<MimeType> MimeTypeArray::item(u32 index) const
  52. {
  53. // 1. Let mimeTypes be this's relevant global object's PDF viewer mime type objects.
  54. auto& window = verify_cast<HTML::Window>(HTML::relevant_global_object(*this));
  55. auto mime_types = window.pdf_viewer_mime_type_objects();
  56. // 2. If index < mimeType's size, then return mimeTypes[index].
  57. if (index < mime_types.size())
  58. return mime_types[index];
  59. // 3. Return null.
  60. return nullptr;
  61. }
  62. // https://html.spec.whatwg.org/multipage/system-state.html#dom-mimetypearray-nameditem
  63. GC::Ptr<MimeType> MimeTypeArray::named_item(FlyString const& name) const
  64. {
  65. // 1. For each MimeType mimeType of this's relevant global object's PDF viewer mime type objects: if mimeType's type is name, then return mimeType.
  66. auto& window = verify_cast<HTML::Window>(HTML::relevant_global_object(*this));
  67. auto mime_types = window.pdf_viewer_mime_type_objects();
  68. for (auto& mime_type : mime_types) {
  69. if (mime_type->type() == name)
  70. return mime_type;
  71. }
  72. // 2. Return null.
  73. return nullptr;
  74. }
  75. Optional<JS::Value> MimeTypeArray::item_value(size_t index) const
  76. {
  77. auto return_value = item(index);
  78. if (!return_value)
  79. return {};
  80. return return_value.ptr();
  81. }
  82. JS::Value MimeTypeArray::named_item_value(FlyString const& name) const
  83. {
  84. auto return_value = named_item(name);
  85. if (!return_value)
  86. return JS::js_null();
  87. return return_value.ptr();
  88. }
  89. }