diff --git a/Userland/Libraries/LibWeb/Bindings/WindowObject.cpp b/Userland/Libraries/LibWeb/Bindings/WindowObject.cpp index 640024fff8..01e82d0d09 100644 --- a/Userland/Libraries/LibWeb/Bindings/WindowObject.cpp +++ b/Userland/Libraries/LibWeb/Bindings/WindowObject.cpp @@ -21,6 +21,7 @@ #include #include #include +#include #include #include #include @@ -78,6 +79,7 @@ void WindowObject::initialize_global_object() define_native_function("btoa", btoa, 1, attr); define_native_function("getComputedStyle", get_computed_style, 1, attr); + define_native_function("matchMedia", match_media, 1, attr); // FIXME: These properties should be [Replaceable] according to the spec, but [Writable+Configurable] is the closest we have. define_native_accessor("scrollX", scroll_x_getter, {}, attr); @@ -483,6 +485,17 @@ JS_DEFINE_NATIVE_FUNCTION(WindowObject::get_computed_style) return wrap(global_object, impl->get_computed_style(static_cast(object)->impl())); } +JS_DEFINE_NATIVE_FUNCTION(WindowObject::match_media) +{ + auto* impl = impl_from(vm, global_object); + if (!impl) + return {}; + auto media = vm.argument(0).to_string(global_object); + if (vm.exception()) + return {}; + return wrap(global_object, impl->match_media(move(media))); +} + // https://www.w3.org/TR/cssom-view/#dom-window-scrollx JS_DEFINE_NATIVE_GETTER(WindowObject::scroll_x_getter) { diff --git a/Userland/Libraries/LibWeb/Bindings/WindowObject.h b/Userland/Libraries/LibWeb/Bindings/WindowObject.h index 28a0a28980..213183cba6 100644 --- a/Userland/Libraries/LibWeb/Bindings/WindowObject.h +++ b/Userland/Libraries/LibWeb/Bindings/WindowObject.h @@ -96,6 +96,7 @@ private: JS_DECLARE_NATIVE_FUNCTION(btoa); JS_DECLARE_NATIVE_FUNCTION(get_computed_style); + JS_DECLARE_NATIVE_FUNCTION(match_media); NonnullRefPtr m_impl; diff --git a/Userland/Libraries/LibWeb/DOM/Window.cpp b/Userland/Libraries/LibWeb/DOM/Window.cpp index 80ebd93750..bf969d811b 100644 --- a/Userland/Libraries/LibWeb/DOM/Window.cpp +++ b/Userland/Libraries/LibWeb/DOM/Window.cpp @@ -195,4 +195,9 @@ NonnullRefPtr Window::get_computed_style(DOM::Element& return CSS::CSSStyleDeclaration::create(move(properties), move(custom_properties)); } +NonnullRefPtr Window::match_media(String media) +{ + return CSS::MediaQueryList::create(associated_document(), move(media)); +} + } diff --git a/Userland/Libraries/LibWeb/DOM/Window.h b/Userland/Libraries/LibWeb/DOM/Window.h index 7ad219c151..fb646f541c 100644 --- a/Userland/Libraries/LibWeb/DOM/Window.h +++ b/Userland/Libraries/LibWeb/DOM/Window.h @@ -12,6 +12,7 @@ #include #include #include +#include #include #include #include @@ -73,6 +74,7 @@ public: void set_current_event(Event* event) { m_current_event = event; } NonnullRefPtr get_computed_style(DOM::Element&) const; + NonnullRefPtr match_media(String); private: explicit Window(Document&);