From 07e7c55f39e3c2c67940b323c35842de7a5af9f9 Mon Sep 17 00:00:00 2001 From: Valentin Buira Date: Mon, 5 Aug 2024 15:37:50 +0200 Subject: [PATCH 1/2] Fix drawer content not getting the focus --- app/qml/components/MMDrawer.qml | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/app/qml/components/MMDrawer.qml b/app/qml/components/MMDrawer.qml index 6f5e75e95..4badaa59f 100644 --- a/app/qml/components/MMDrawer.qml +++ b/app/qml/components/MMDrawer.qml @@ -48,13 +48,6 @@ Drawer { height: parent.height / 2 y: parent.height / 2 } - - Keys.onReleased: function( event ) { - if ( event.key === Qt.Key_Back || event.key === Qt.Key_Escape ) { - root.close() - event.accepted = true - } - } } contentItem: Column { @@ -62,6 +55,14 @@ Drawer { anchors.fill: parent spacing: 0 + focus : true + + Keys.onReleased: function( event ) { + if ( event.key === Qt.Key_Back || event.key === Qt.Key_Escape ) { + root.close() + event.accepted = true + } + } MMListSpacer { id: topSpacer From 13a94ade43f22ef07ab6ef759a563739a65c1b6d Mon Sep 17 00:00:00 2001 From: Valentin Buira Date: Tue, 6 Aug 2024 12:07:36 +0200 Subject: [PATCH 2/2] Fix handling back event in MMFormPage --- app/qml/form/MMFormPage.qml | 36 ++++++++++++------------------------ 1 file changed, 12 insertions(+), 24 deletions(-) diff --git a/app/qml/form/MMFormPage.qml b/app/qml/form/MMFormPage.qml index c07bce48d..f12a9647f 100644 --- a/app/qml/form/MMFormPage.qml +++ b/app/qml/form/MMFormPage.qml @@ -71,6 +71,18 @@ Page { } ] + Keys.onReleased: function( event ) { + if ( event.key === Qt.Key_Back || event.key === Qt.Key_Escape ) { + if ( root.controller.hasAnyChanges ) { + saveChangesDialog.open() + } + else { + root.rollbackAndClose() + } + event.accepted = true; + } + } + property bool layerIsReadOnly: true property bool layerIsSpatial: true @@ -303,8 +315,6 @@ Page { active: fieldWidget !== 'Hidden' - Keys.forwardTo: backHandler - source: { if ( model.EditorWidget !== undefined ) { return __inputUtils.getFormEditorType( model.EditorWidget, model.EditorWidgetConfig, model.Field, model.Relation, model.Name ) @@ -404,28 +414,6 @@ Page { id: editingFailedDialog } - Item { - id: backHandler - - focus: true - Keys.onReleased: function( event ) { - if ( event.key === Qt.Key_Back || event.key === Qt.Key_Escape ) { - if ( root.controller.hasAnyChanges ) { - saveChangesDialog.open() - } - else { - root.rollbackAndClose() - } - event.accepted = true; - } - } - - onVisibleChanged: function( visible ) { - if ( visible ) - backHandler.forceActiveFocus() - } - } - Connections { target: Qt.inputMethod