forked from Shinonome/dots-hyprland
ags keybinds: allow multiple binds, make modifiers case-insensitive
This commit is contained in:
@@ -200,9 +200,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"keybinds": {
|
"keybinds": {
|
||||||
// Format: Mod1+Mod2+key. CaSe SeNsItIvE!
|
// Format: "Modifier_1+...+Modifier_n+key". The key is CaSe SeNsItIvE!
|
||||||
// Modifiers: Shift Ctrl Alt Hyper Meta
|
// Modifiers: Shift Ctrl Alt Hyper Meta
|
||||||
// See https://docs.gtk.org/gdk3/index.html#constants for the other keys (they are listed as KEY_key)
|
// See https://docs.gtk.org/gdk3/index.html#constants for keys (listed as KEY_key)
|
||||||
|
// You can assign multiple keybinds for the same action. Just split them with a comma
|
||||||
|
// Example: "Ctrl+Page_Down, ctrl+Tab"
|
||||||
"overview": {
|
"overview": {
|
||||||
"altMoveLeft": "Ctrl+B",
|
"altMoveLeft": "Ctrl+B",
|
||||||
"altMoveRight": "Ctrl+F",
|
"altMoveRight": "Ctrl+F",
|
||||||
|
|||||||
@@ -1,20 +1,20 @@
|
|||||||
const { Gdk } = imports.gi;
|
const { Gdk } = imports.gi;
|
||||||
|
|
||||||
const MODS = {
|
const MODS = {
|
||||||
'Shift': Gdk.ModifierType.SHIFT_MASK,
|
'shift': Gdk.ModifierType.SHIFT_MASK,
|
||||||
'Ctrl': Gdk.ModifierType.CONTROL_MASK,
|
'ctrl': Gdk.ModifierType.CONTROL_MASK,
|
||||||
'Alt': Gdk.ModifierType.ALT_MASK,
|
'alt': Gdk.ModifierType.ALT_MASK,
|
||||||
'Hyper': Gdk.ModifierType.HYPER_MASK,
|
'hyper': Gdk.ModifierType.HYPER_MASK,
|
||||||
'Meta': Gdk.ModifierType.META_MASK
|
'meta': Gdk.ModifierType.META_MASK
|
||||||
}
|
}
|
||||||
|
|
||||||
export const checkKeybind = (event, keybind) => {
|
const checkSingleKeybind = (event, keybind) => {
|
||||||
const pressedModMask = event.get_state()[1];
|
const pressedModMask = event.get_state()[1];
|
||||||
const pressedKey = event.get_keyval()[1];
|
const pressedKey = event.get_keyval()[1];
|
||||||
const keys = keybind.split('+');
|
const keys = keybind.split('+');
|
||||||
for (let i = 0; i < keys.length; i++) {
|
for (let i = 0; i < keys.length; i++) {
|
||||||
if (keys[i] in MODS) {
|
if (keys[i].toLowerCase() in MODS) {
|
||||||
if (!(pressedModMask & MODS[keys[i]])) {
|
if (!(pressedModMask & MODS[keys[i].toLowerCase()])) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
} else if (pressedKey !== Gdk[`KEY_${keys[i]}`] && pressedKey !== Gdk[`KEY_${keys[i].toLowerCase()}`]) {
|
} else if (pressedKey !== Gdk[`KEY_${keys[i]}`] && pressedKey !== Gdk[`KEY_${keys[i].toLowerCase()}`]) {
|
||||||
@@ -23,3 +23,12 @@ export const checkKeybind = (event, keybind) => {
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export const checkKeybind = (event, keybind) => {
|
||||||
|
const keybinds = keybind.replace(' ', '').split(',');
|
||||||
|
for (let i = 0; i < keybinds.length; i++) {
|
||||||
|
if (checkSingleKeybind(event, keybinds[i])) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user