Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(662)

Unified Diff: third_party/WebKit/Source/modules/keyboard_lock/NavigatorKeyboardLock.idl

Issue 2805763004: [System-Keyboard-Lock] Forward navigator functions to RenderFrameHost (Closed)
Patch Set: Synchronize latest changes Created 3 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/WebKit/Source/modules/keyboard_lock/NavigatorKeyboardLock.idl
diff --git a/third_party/WebKit/Source/modules/keyboard_lock/NavigatorKeyboardLock.idl b/third_party/WebKit/Source/modules/keyboard_lock/NavigatorKeyboardLock.idl
new file mode 100644
index 0000000000000000000000000000000000000000..988dfd3660ef06993220f3b6f44916cccbd0342e
--- /dev/null
+++ b/third_party/WebKit/Source/modules/keyboard_lock/NavigatorKeyboardLock.idl
@@ -0,0 +1,29 @@
+// Copyright 2017 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+// The supplement of Navigator to process navigator.requestKeyLock() and
+// navigator.cancelKeyLock() web APIs to implement
+// https://garykac.github.io/system-keyboard-lock/.
foolip 2017/04/17 08:46:05 Just a link to the spec will suffice, most IDL fil
Hzj_jie 2017/04/18 02:26:08 Done.
+partial interface Navigator {
+ // Requests to receive a set of key codes
foolip 2017/04/17 08:46:05 Please copy the spec'd IDL verbatim and make the m
Hzj_jie 2017/04/18 02:26:08 Done.
+ // (https://www.w3.org/TR/uievents/#interface-keyboardevent) in string
+ // format.
+ // The Promise will be rejected if the user or browser do not allow the web
+ // page to use this API. Otherwise, web page should expect to receive the
+ // key presses once the Promise has been resolved. This API does best effort
+ // to deliver the key codes: due to the platform restrictions, some keys or
+ // key combinations may not be able to receive or intercept by the user
+ // agent.
+ // - Making two requests concurrently without waiting for one Promise to
+ // finish is disallowed, the second Promise will be rejected immediately.
+ // - Making a second request after the Promise of the first one has finished
+ // is allowed; the second request will overwrite the key codes reserved.
+ // - Passing in an empty keyCodes array will reserve all keys.
+ [RuntimeEnabled=KeyboardLock, CallWith=ScriptState] Promise<void> requestKeyLock(DOMString[] keyCodes);
foolip 2017/04/17 08:46:05 The argument should be "optional sequence<DOMStrin
Hzj_jie 2017/04/18 02:26:08 Passing in an empty keyCodes array will reserve al
foolip 2017/04/18 05:10:57 OK. In that case it probably makes sense to add "
Hzj_jie 2017/04/19 00:45:54 Updated. TODOs have been added, and point to the c
+
+ // Removes all reserved keys. This function is also asynchronized, the web
+ // page may still receive reserved keys after this function has finished.
+ // Once the web page is closed, the user agent implictly executes this API.
foolip 2017/04/17 08:46:05 Is such an implicit call anywhere in the code?
Hzj_jie 2017/04/18 02:26:08 Yes, the logic is in browser process, which has no
foolip 2017/04/18 05:10:57 The spec should probably define precisely which ev
Hzj_jie 2017/04/19 00:45:54 Done. TODO has been added, and point to the corres
+ [RuntimeEnabled=KeyboardLock] void cancelKeyLock();
+};

Powered by Google App Engine
This is Rietveld 408576698