[gnome-shell/wip/carlosg/osk-events-in-grab: 1/2] grabHelper: Special case event funneling towards the OSK
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-shell/wip/carlosg/osk-events-in-grab: 1/2] grabHelper: Special case event funneling towards the OSK
- Date: Wed, 9 Mar 2022 23:15:13 +0000 (UTC)
commit 0f1f690cdb1a8d38f4f344d5c1fbbfb3fbf900dc
Author: Carlos Garnacho <carlosg gnome org>
Date: Wed Mar 9 23:11:03 2022 +0100
grabHelper: Special case event funneling towards the OSK
In the case of bringing up the OSK while there is a grab (like, every
GNOME Shell entry), we used to special case event capturing so events
directed to the OSK would be let through.
When Clutter.Grab came around, events would be propagated only within
the actor hierarchy that holds the grab, which rendered this special
case just as useless as the OSK while a grab was hold. Since it wouldn't
be part of the grab hierarchy, clicking on the OSK would do nothing.
In order to let the OSK handle events, double down on the special case
and let it forward the event directly to the actor under the device,
instead of trying to let it through somehow. Since the actor under the
device are usually OSK buttons in this case, we don't need further
propagation to make it work, which makes the OSK functional again while
the shell holds a grab.
js/ui/grabHelper.js | 2 +-
js/ui/keyboard.js | 12 +++++++++---
2 files changed, 10 insertions(+), 4 deletions(-)
---
diff --git a/js/ui/grabHelper.js b/js/ui/grabHelper.js
index af4641014a..c4028fc38b 100644
--- a/js/ui/grabHelper.js
+++ b/js/ui/grabHelper.js
@@ -272,7 +272,7 @@ var GrabHelper = class GrabHelper {
this.currentGrab.actor.contains(targetActor))
return Clutter.EVENT_PROPAGATE;
- if (Main.keyboard.shouldTakeEvent(event))
+ if (Main.keyboard.maybeHandleEvent(event))
return Clutter.EVENT_PROPAGATE;
if (button || touchBegin) {
diff --git a/js/ui/keyboard.js b/js/ui/keyboard.js
index 6512bf0d23..af195dccfd 100644
--- a/js/ui/keyboard.js
+++ b/js/ui/keyboard.js
@@ -1263,13 +1263,19 @@ var KeyboardManager = class KeyBoardManager {
this._keyboard.resetSuggestions();
}
- shouldTakeEvent(event) {
+ maybeHandleEvent(event) {
if (!this._keyboard)
return false;
const actor = global.stage.get_event_actor(event);
- return Main.layoutManager.keyboardBox.contains(actor) ||
- !!actor._extendedKeys || !!actor.extendedKey;
+
+ if (Main.layoutManager.keyboardBox.contains(actor) ||
+ !!actor._extendedKeys || !!actor.extendedKey) {
+ actor.event(event);
+ return true;
+ }
+
+ return false;
}
};
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]