Use normal QtQuick.Shortcut

This commit is contained in:
miruka 2019-12-08 12:42:40 -04:00
parent 793db51a60
commit c2f5a5bcbc
6 changed files with 41 additions and 120 deletions

View File

@ -121,14 +121,14 @@ class UISettings(JSONConfigFile):
"toggleDebugConsole": ["Alt+Shift+C"],
"reloadConfig": ["Alt+Shift+R"],
"zoomIn": ["Ctrl+Plus", "Ctrl+Shift+Plus"],
"zoomOut": ["Ctrl+Minus", "Ctrl+Shift+Minus"],
"zoomReset": ["Ctrl+Equal", "Ctrl+Shift+Backspace"],
"zoomIn": ["Ctrl++"],
"zoomOut": ["Ctrl+-"],
"zoomReset": ["Ctrl+="],
"scrollUp": ["Alt+Up", "Alt+K"],
"scrollDown": ["Alt+Down", "Alt+J"],
"scrollPageUp": ["Alt+Ctrl+Up", "Alt+Ctrl+K", "PageUp"],
"scrollPageDown": ["Alt+Ctrl+Down", "Alt+Ctrl+J", "PageDown"],
"scrollPageUp": ["Alt+Ctrl+Up", "Alt+Ctrl+K", "PgUp"],
"scrollPageDown": ["Alt+Ctrl+Down", "Alt+Ctrl+J", "PgDown"],
"scrollToTop":
["Alt+Ctrl+Shift+Up", "Alt+Ctrl+Shift+K", "Home"],
"scrollToBottom":

View File

@ -41,7 +41,5 @@ ScrollView {
event.modifiers & Qt.AltModifier ||
event.modifiers & Qt.MetaModifier
) event.accepted = true
Keys.forwardTo: mainUI.shortcuts
}
}

View File

@ -1,10 +1,5 @@
import QtQuick 2.12
QtObject {
signal pressed(var event)
signal held(var event)
signal released(var event)
property bool enabled: true
property var sequences: "" // shortcut string array of shortcut strings
Shortcut {
context: Qt.ApplicationShortcut
}

View File

@ -1,65 +0,0 @@
import QtQuick 2.12
Item {
id: shortcutHandler
Keys.onPressed: {
let shortcut = match(event)
if (! shortcut) return
event.accepted = true
event.isAutoRepeat ? shortcut.held(event) : shortcut.pressed(event)
}
Keys.onReleased: {
if (event.isAutoRepeat) return
let shortcut = match(event)
if (! shortcut) return
event.accepted = true
if (shortcut && ! event.isAutoRepeat) shortcut.released(event)
}
readonly property var modifierDict: ({
Ctrl: Qt.ControlModifier,
Shift: Qt.ShiftModifier,
Alt: Qt.AltModifier,
Meta: Qt.MetaModifier,
})
function match(event) {
for (let i = 0; i < shortcutHandler.resources.length; i++) {
let shortcut = shortcutHandler.resources[i]
if (! shortcut.enabled) continue
if (typeof(shortcut.sequences) == "string") {
shortcut.sequences = [shortcut.sequences]
}
for (let i = 0; i < shortcut.sequences.length; i++) {
if (sequenceMatches(event, shortcut.sequences[i])) {
return shortcut
}
}
}
return null
}
function sequenceMatches(event, sequence) {
let [key, ...mods] = sequence.split("+").reverse()
key = key.charAt(0).toUpperCase() + key.slice(1)
if (event.key !== Qt["Key_" + key]) return false
for (let [name, code] of Object.entries(modifierDict)) {
if (mods.includes(name) && ! (event.modifiers & code)) return false
if (! mods.includes(name) && event.modifiers & code) return false
}
return true
}
}

View File

@ -49,6 +49,4 @@ TextField {
event.modifiers & Qt.AltModifier ||
event.modifiers & Qt.MetaModifier
) event.accepted = true
Keys.forwardTo: mainUI.shortcuts
}

View File

@ -3,7 +3,9 @@ import QtQuick.Controls 2.12
import "Base"
import "utils.js" as Utils
HShortcutHandler {
Item {
visible: false
// Flickable or ListView that should be affected by scroll shortcuts
property Item flickTarget
@ -19,40 +21,40 @@ HShortcutHandler {
HShortcut {
enabled: debugMode
sequences: settings.keys.startPythonDebugger
onPressed: py.call("APP.pdb")
onActivated: py.call("APP.pdb")
}
HShortcut {
enabled: debugMode && debugConsole
sequences: settings.keys.toggleDebugConsole
onPressed: debugConsole.visible = ! debugConsole.visible
onActivated: debugConsole.visible = ! debugConsole.visible
}
HShortcut {
sequences: settings.keys.reloadConfig
onPressed: py.loadSettings(() => { mainUI.pressAnimation.start() })
onActivated: py.loadSettings(() => { mainUI.pressAnimation.start() })
}
HShortcut {
sequences: settings.keys.zoomIn
onPressed: theme.uiScale += 0.1
onActivated: theme.uiScale += 0.1
}
HShortcut {
sequences: settings.keys.zoomOut
onPressed: theme.uiScale = Math.max(0.1, theme.uiScale - 0.1)
onActivated: theme.uiScale = Math.max(0.1, theme.uiScale - 0.1)
}
HShortcut {
sequences: settings.keys.zoomReset
onPressed: theme.uiScale = 1
onActivated: theme.uiScale = 1
}
// Pages
HShortcut {
sequences: settings.keys.goToLastPage
onPressed: mainUI.pageLoader.showPrevious()
onActivated: mainUI.pageLoader.showPrevious()
}
// Page scrolling
@ -60,50 +62,44 @@ HShortcutHandler {
HShortcut {
enabled: flickTarget
sequences: settings.keys.scrollUp
onPressed: Utils.smartVerticalFlick(flickTarget, -335)
onHeld: pressed(event)
onActivated: Utils.smartVerticalFlick(flickTarget, -335)
}
HShortcut {
enabled: flickTarget
sequences: settings.keys.scrollDown
onPressed: Utils.smartVerticalFlick(flickTarget, 335)
onHeld: pressed(event)
onActivated: Utils.smartVerticalFlick(flickTarget, 335)
}
HShortcut {
enabled: flickTarget
sequences: settings.keys.scrollPageUp
onPressed: Utils.smartVerticalFlick(
onActivated: Utils.smartVerticalFlick(
flickTarget, -2.3 * flickTarget.height, 8,
)
onHeld: pressed(event)
// Ensure only a slight slip after releasing the key
onReleased: Utils.smartVerticalFlick(flickTarget, -335)
// onReleased: Utils.smartVerticalFlick(flickTarget, -335)
}
HShortcut {
enabled: flickTarget
sequences: settings.keys.scrollPageDown
onPressed: Utils.smartVerticalFlick(
onActivated: Utils.smartVerticalFlick(
flickTarget, 2.3 * flickTarget.height, 8,
)
onHeld: pressed(event)
onReleased: Utils.smartVerticalFlick(flickTarget, 335)
// onReleased: Utils.smartVerticalFlick(flickTarget, 335)
}
HShortcut {
enabled: flickTarget
sequences: settings.keys.scrollToTop
onPressed: Utils.flickToTop(flickTarget)
onHeld: pressed(event)
onActivated: Utils.flickToTop(flickTarget)
}
HShortcut {
enabled: flickTarget
sequences: settings.keys.scrollToBottom
onPressed: Utils.flickToBottom(flickTarget)
onHeld: pressed(event)
onActivated: Utils.flickToBottom(flickTarget)
}
@ -112,7 +108,7 @@ HShortcutHandler {
HShortcut {
enabled: tabsTarget
sequences: settings.keys.previousTab
onPressed: tabsTarget.setCurrentIndex(
onActivated: tabsTarget.setCurrentIndex(
Utils.numberWrapAt(tabsTarget.currentIndex - 1, tabsTarget.count),
)
}
@ -120,7 +116,7 @@ HShortcutHandler {
HShortcut {
enabled: tabsTarget
sequences: settings.keys.nextTab
onPressed: tabsTarget.setCurrentIndex(
onActivated: tabsTarget.setCurrentIndex(
Utils.numberWrapAt(tabsTarget.currentIndex + 1, tabsTarget.count),
)
}
@ -131,54 +127,53 @@ HShortcutHandler {
HShortcut {
enabled: mainUI.accountsPresent
sequences: settings.keys.focusSidePane
onPressed: mainUI.sidePane.setFocus()
onActivated: mainUI.sidePane.toggleFocus()
context: Qt.ApplicationShortcut
}
HShortcut {
enabled: mainUI.accountsPresent
sequences: settings.keys.clearRoomFilter
onPressed: mainUI.sidePane.toolBar.roomFilter = ""
onActivated: mainUI.sidePane.toolBar.roomFilter = ""
}
HShortcut {
enabled: mainUI.accountsPresent
sequences: settings.keys.addNewAccount
onPressed: mainUI.sidePane.toolBar.addAccountButton.clicked()
onActivated: mainUI.sidePane.toolBar.addAccountButton.clicked()
}
HShortcut {
enabled: mainUI.accountsPresent
sequences: settings.keys.addNewChat
onPressed: mainUI.sidePane.sidePaneList.addNewChat()
onActivated: mainUI.sidePane.sidePaneList.addNewChat()
}
HShortcut {
enabled: mainUI.accountsPresent
sequences: settings.keys.accountSettings
onPressed: mainUI.sidePane.sidePaneList.accountSettings()
onActivated: mainUI.sidePane.sidePaneList.accountSettings()
}
HShortcut {
enabled: mainUI.accountsPresent
sequences: settings.keys.toggleCollapseAccount
onPressed: mainUI.sidePane.sidePaneList.toggleCollapseAccount()
onActivated: mainUI.sidePane.sidePaneList.toggleCollapseAccount()
}
HShortcut {
enabled: mainUI.accountsPresent
sequences: settings.keys.goToPreviousRoom
onPressed: mainUI.sidePane.sidePaneList.previous()
onHeld: pressed(event)
onActivated: mainUI.sidePane.sidePaneList.previous()
}
HShortcut {
enabled: mainUI.accountsPresent
sequences: settings.keys.goToNextRoom
onPressed: mainUI.sidePane.sidePaneList.next()
onHeld: pressed(event)
onActivated: mainUI.sidePane.sidePaneList.next()
}
@ -187,7 +182,7 @@ HShortcutHandler {
HShortcut {
enabled: window.uiState.page == "Chat/Chat.qml"
sequences: settings.keys.clearRoomMessages
onPressed: Utils.makePopup(
onActivated: Utils.makePopup(
"Popups/ClearMessagesPopup.qml",
mainUI,
{
@ -200,7 +195,7 @@ HShortcutHandler {
HShortcut {
enabled: window.uiState.page == "Chat/Chat.qml"
sequences: settings.keys.sendFile
onPressed: Utils.makeObject(
onActivated: Utils.makeObject(
"Dialogs/SendFilePicker.qml",
mainUI,
{
@ -215,7 +210,7 @@ HShortcutHandler {
HShortcut {
enabled: window.uiState.page == "Chat/Chat.qml"
sequences: settings.keys.sendFileFromPathInClipboard
onPressed: Utils.sendFile(
onActivated: Utils.sendFile(
window.uiState.pageProperties.userId,
window.uiState.pageProperties.roomId,
Clipboard.text.trim(),