mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 15:32:46 +00:00 
			
		
		
		
	LibWeb: Implement Window.focus
This commit is contained in:
		
							parent
							
								
									a10204133a
								
							
						
					
					
						commit
						a569d02b0d
					
				
					 2 changed files with 25 additions and 0 deletions
				
			
		|  | @ -33,6 +33,7 @@ | |||
| #include <LibWeb/HTML/BrowsingContext.h> | ||||
| #include <LibWeb/HTML/EventHandler.h> | ||||
| #include <LibWeb/HTML/EventLoop/EventLoop.h> | ||||
| #include <LibWeb/HTML/Focus.h> | ||||
| #include <LibWeb/HTML/MessageEvent.h> | ||||
| #include <LibWeb/HTML/Navigator.h> | ||||
| #include <LibWeb/HTML/Origin.h> | ||||
|  | @ -775,6 +776,7 @@ void Window::initialize_web_interfaces(Badge<WindowEnvironmentSettingsObject>) | |||
|     define_native_function(realm, "cancelAnimationFrame", cancel_animation_frame, 1, attr); | ||||
|     define_native_function(realm, "atob", atob, 1, attr); | ||||
|     define_native_function(realm, "btoa", btoa, 1, attr); | ||||
|     define_native_function(realm, "focus", focus, 0, attr); | ||||
| 
 | ||||
|     define_native_function(realm, "queueMicrotask", queue_microtask, 1, attr); | ||||
| 
 | ||||
|  | @ -1082,6 +1084,28 @@ JS_DEFINE_NATIVE_FUNCTION(Window::btoa) | |||
|     return JS::js_string(vm, move(encoded)); | ||||
| } | ||||
| 
 | ||||
| // https://html.spec.whatwg.org/multipage/interaction.html#dom-window-focus
 | ||||
| JS_DEFINE_NATIVE_FUNCTION(Window::focus) | ||||
| { | ||||
|     auto* impl = TRY(impl_from(vm)); | ||||
| 
 | ||||
|     // 1. Let current be this Window object's browsing context.
 | ||||
|     auto* current = impl->browsing_context(); | ||||
| 
 | ||||
|     // 2. If current is null, then return.
 | ||||
|     if (!current) | ||||
|         return JS::js_undefined(); | ||||
| 
 | ||||
|     // 3. Run the focusing steps with current.
 | ||||
|     // FIXME: We should pass in the browsing context itself instead of the active document, however the focusing steps don't currently accept browsing contexts.
 | ||||
|     //        Passing in a browsing context always makes it resolve to its active document for focus, so this is fine for now.
 | ||||
|     run_focusing_steps(current->active_document()); | ||||
| 
 | ||||
|     // FIXME: 4. If current is a top-level browsing context, user agents are encouraged to trigger some sort of notification to indicate to the user that the page is attempting to gain focus.
 | ||||
| 
 | ||||
|     return JS::js_undefined(); | ||||
| } | ||||
| 
 | ||||
| // https://html.spec.whatwg.org/multipage/window-object.html#number-of-document-tree-child-browsing-contexts
 | ||||
| JS::ThrowCompletionOr<size_t> Window::document_tree_child_browsing_context_count() const | ||||
| { | ||||
|  |  | |||
|  | @ -256,6 +256,7 @@ private: | |||
|     JS_DECLARE_NATIVE_FUNCTION(cancel_animation_frame); | ||||
|     JS_DECLARE_NATIVE_FUNCTION(atob); | ||||
|     JS_DECLARE_NATIVE_FUNCTION(btoa); | ||||
|     JS_DECLARE_NATIVE_FUNCTION(focus); | ||||
| 
 | ||||
|     JS_DECLARE_NATIVE_FUNCTION(get_computed_style); | ||||
|     JS_DECLARE_NATIVE_FUNCTION(match_media); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Luke Wilde
						Luke Wilde