From e5bb39cf29efbf9563e50231d079b385a2ce3bb7 Mon Sep 17 00:00:00 2001 From: Valentin Buira Date: Tue, 3 Dec 2024 12:24:12 +0100 Subject: [PATCH] Fix unneccessary confirmation dialog when saving and reopening a feature form --- app/qml/form/MMFormStackController.qml | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/app/qml/form/MMFormStackController.qml b/app/qml/form/MMFormStackController.qml index 603232f81..f0da6b64a 100644 --- a/app/qml/form/MMFormStackController.qml +++ b/app/qml/form/MMFormStackController.qml @@ -15,9 +15,8 @@ Item { /* * MMFormsStackManager component is responsible for viewing feature forms, both preview and fullscreen form - * It contains a stackview where instances of FormWrapper are pushed. Latest form is not destroyed, but reused - * for next feature to reduce a cost of initializing form and AttributeController each time user selects feature. - */ + * It contains a stackview where instances of FormWrapper are pushed. + */ property var project @@ -113,8 +112,7 @@ Item { function closeAll() { // close permanetly all drawers (not only hide) - let form = formsStack.get( 0 ) - formsStack.pop( form ) + formsStack.clear() } function reopenAll() { @@ -257,11 +255,16 @@ Item { id: formsStack function popOneOrClose() { - formsStack.pop() + if ( formsStack.depth > 1 ) { + formsStack.pop() + } + else{ + formsStack.clear() + } - if ( formsStack.depth <= 1 ) + if ( formsStack.depth === 0 ) { - root.closed() // this is the top most form, we want to keep it instantiated, just invisible + root.closed() } }