summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mobile-widgets/qml/main.qml24
1 files changed, 22 insertions, 2 deletions
diff --git a/mobile-widgets/qml/main.qml b/mobile-widgets/qml/main.qml
index b90ebac15..e7678688d 100644
--- a/mobile-widgets/qml/main.qml
+++ b/mobile-widgets/qml/main.qml
@@ -34,6 +34,7 @@ Kirigami.ApplicationWindow {
property bool firstChange: true
property int lastOrientation: undefined
property int colWidth: undefined
+ property bool hackToOpenMap: false
onNotificationTextChanged: {
if (notificationText != "") {
@@ -615,12 +616,31 @@ if you have network connectivity and want to sync your data to cloud storage."),
}
pageStack.onCurrentItemChanged: {
- // This is called whenever the user navigates using the breadcrumbs in the header
+ // This is called whenever the user navigates using the breadcrumbs in the header
- // disable the left swipe to go back when on the map page
if (pageStack.currentItem === null) {
console.log("there's no current page")
} else {
+ // horrible, insane hack to make picking the mapPage work
+ // for some reason I cannot figure out, whenever the mapPage is selected
+ // we immediately switch back to the page before it - so force-prevent
+ // that undersired behavior
+ if (pageStack.currentItem.objectName === mapPage.objectName) {
+ // remember that we actively picked the mapPage
+ hackToOpenMap = true
+ } else if (pageStack.currentItem.objectName !== mapPage.objectName &&
+ pageStack.lastItem.objectName === mapPage.objectName &&
+ hackToOpenMap) {
+ // if we just picked the mapPage and are suddenly back on a different page
+ // force things back to the mapPage
+ pageStack.currentIndex = pageStack.contentItem.contentChildren.length - 1
+ hackToOpenMap = false
+ } else {
+ // if we picked a different page reset the mapPage hack
+ hackToOpenMap = false
+ }
+
+ // disable the left swipe to go back when on the map page
pageStack.interactive = pageStack.currentItem.objectName !== mapPage.objectName
// is there a better way to reload the map markers instead of doing that