diff --git a/fullscreen.bs b/fullscreen.bs index a772f2c..3f5e163 100644 --- a/fullscreen.bs +++ b/fullscreen.bs @@ -57,6 +57,12 @@ unset.
All <{iframe}> elements have an associated iframe fullscreen flag. Unless stated otherwise it is unset. +
All documents have an associated keyboard lock flag. This flag indicates +whether the keyboard lock is active for the document. When the flag is set, the document captures +and handles key inputs as specified by a passed {{FullscreenKeyboardLock}} enum value. When the +flag is not set, keyboard inputs are processed in the default manner by the user agent and the +operating system. +
All documents have an associated fullscreen element. The fullscreen element is the topmost element in the document's top layer whose fullscreen flag is set, if any, and null otherwise. @@ -178,7 +184,14 @@ enum FullscreenNavigationUI { "hide" }; +enum FullscreenKeyboardLock { + "application", + "none", + "system" +} + dictionary FullscreenOptions { + FullscreenKeyboardLock keyboardLock = "none"; FullscreenNavigationUI navigationUI = "auto"; }; @@ -218,6 +231,18 @@ partial interface mixin DocumentOrShadowRoot { free to honor user preference over the application's. The default value "{{FullscreenNavigationUI/auto}}" indicates no application preference. +
document . {{Document/fullscreenEnabled}}
Returns true if document has the ability to display elements fullscreen and fullscreen is supported, or false otherwise. @@ -340,6 +365,12 @@ are: steps. +
Let fullscreenElements be an ordered set initially consisting of this. @@ -379,6 +410,16 @@ are: doc's list of pending fullscreen events. +
Apply an [=application-level keyboard lock=]. +
Apply a [=system-level keyboard lock=]. +
The order in which elements are fullscreened is not observable, because run the fullscreen steps is invoked in tree order. @@ -494,6 +535,8 @@ could be an open <{dialog}> element.
Return promise, and run the remaining steps in parallel. +
Run [=the release the keyboard lock steps=] with doc. +
Run the [=fully unlock the screen orientation steps=] with doc.
If resize is true, resize doc's viewport to its "normal" dimensions. @@ -583,6 +626,11 @@ corresponding event handler content attributes for {{Element}} objects in
The user agent may end any fullscreen session without instruction from the end user or call to {{Document/exitFullscreen()}} whenever the user agent deems it necessary. +
Users should be clearly notified when [=keyboard locking=] is active, possibly through browser +UI indicators. + +
There should be a simple and intuitive method for users to override keyboard locking, reverting +control back to the system or user agent.
keyboard Locking enhances the functionality of web applications running in fullscreen by allowing +them to intercept certain key inputs that would typically be handled by either the system or the +user agent. This is useful in scenarios such as gaming or remote desktop applications, where keys +like ESC or function keys are integral to the application's functionality. + +
A keyboard lock enables web applications to capture and handle key inputs directly, +bypassing the default behavior typically executed by the user agent (in the case of +"{{FullscreenKeyboardLock/application}}") or operating system (in the case of +"{{FullscreenKeyboardLock/system}}"). When the [=keyboard lock flag=] is set for a [=document=], key +events that would normally trigger user agent or system-level actions are instead redirected to the +web application in fullscreen. + +
Captures all keys that the user agent would ordinarily receive, except those reserved for + critical system functions or security shortcuts (e.g., Ctrl+Alt+Del). +
capture a wider range of keys, including those used for system-level navigation and + shortcuts (e.g., Alt+Tab), subject to user consent and user agent implementation. +
This prevents e.g. content from third parties to go fullscreen without explicit permission. +
When applying a [=keyboard lock=], only a limited set of keys, primarily those not involving +system control or privacy risks (like Alt+Tab, Ctrl+Alt+Del), can be locked via the API. + +
When applying a [=keyboard lock=], user agents should implement safeguards to prevent abuse of +this feature, such as allowing users to override the lock. +