summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2020-03-25 20:29:05 -0700
committerGravatar Dirk Hohndel <dirk@hohndel.org>2020-03-26 11:49:05 -0700
commitf2a48e813f6967bd6b02f5e7f92d82534b175959 (patch)
tree72da1ea4388d0901444ceb616c649ff26d8e1297
parent69272eefa82493db2993d90cf82884dd5ee46ee2 (diff)
downloadsubsurface-f2a48e813f6967bd6b02f5e7f92d82534b175959.tar.gz
mobile/page-selection: consistently use showPage to select a page
We still used pageStack.push() all over the place. Also, in showPage, disable the map hack if the user actively picks a different page. This should fix an issue where the user picked the map and then tried to add a dive to the dive list - and instead of the dive edit was shown the map again. Reported-by: Hartley Horwitz <hhrwtz@gmail.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--mobile-widgets/qml/DiveList.qml9
-rw-r--r--mobile-widgets/qml/main.qml28
2 files changed, 17 insertions, 20 deletions
diff --git a/mobile-widgets/qml/DiveList.qml b/mobile-widgets/qml/DiveList.qml
index 383e1f930..cda60bf59 100644
--- a/mobile-widgets/qml/DiveList.qml
+++ b/mobile-widgets/qml/DiveList.qml
@@ -65,12 +65,7 @@ Kirigami.ScrollablePage {
manager.appendTextToLog("clicked on dive")
if (detailsWindow.state === "view") {
manager.selectRow(model.row);
- // switch to detailsWindow (or push it if it's not in the stack)
- var i = rootItem.pageIndex(detailsWindow)
- if (i === -1)
- pageStack.push(detailsWindow)
- else
- pageStack.currentIndex = i
+ showPage(detailsWindow)
}
}
}
@@ -305,7 +300,7 @@ Kirigami.ScrollablePage {
tripEditWindow.tripId = currentItem.myData.tripId
tripEditWindow.tripLocation = currentItem.myData.tripLocation
tripEditWindow.tripNotes = currentItem.myData.tripNotes
- pageStack.push(tripEditWindow)
+ showPage(tripEditWindow)
}
}
diff --git a/mobile-widgets/qml/main.qml b/mobile-widgets/qml/main.qml
index c26d91247..5511f7385 100644
--- a/mobile-widgets/qml/main.qml
+++ b/mobile-widgets/qml/main.qml
@@ -78,6 +78,8 @@ Kirigami.ApplicationWindow {
}
function showPage(page) {
+ if (page !== mapPage)
+ hackToOpenMap = 0 // we really want a different page
if (globalDrawer.drawerOpen)
globalDrawer.close()
var i=pageIndex(page)
@@ -139,7 +141,7 @@ Kirigami.ApplicationWindow {
detailsWindow.startpressure = []
detailsWindow.endpressure = []
detailsWindow.gpsCheckbox = false
- pageStack.push(detailsWindow)
+ showPage(detailsWindow)
}
contextDrawer: Kirigami.ContextDrawer {
@@ -152,7 +154,7 @@ Kirigami.ApplicationWindow {
height: rootItem.height
rightPadding: 0
enabled: (Backend.cloud_verification_status === Enums.CS_NOCLOUD ||
- Backend.cloud_verification_status === Enums.CS_VERIFIED)
+ Backend.cloud_verification_status === Enums.CS_VERIFIED)
topContent: Image {
source: "qrc:/qml/icons/dive.jpg"
Layout.fillWidth: true
@@ -269,7 +271,7 @@ Kirigami.ApplicationWindow {
onTriggered: {
globalDrawer.close()
downloadFromDc.dcImportModel.clearTable()
- pageStack.push(downloadFromDc)
+ showPage(downloadFromDc)
}
}
Kirigami.Action {
@@ -328,7 +330,7 @@ if you have network connectivity and want to sync your data to cloud storage."),
text: qsTr("Dive summary")
onTriggered: {
globalDrawer.close()
- pageStack.push(diveSummaryWindow)
+ showPage(diveSummaryWindow)
detailsWindow.endEditMode()
}
}
@@ -339,7 +341,7 @@ if you have network connectivity and want to sync your data to cloud storage."),
text: qsTr("Export")
onTriggered: {
globalDrawer.close()
- pageStack.push(exportWindow)
+ showPage(exportWindow)
detailsWindow.endEditMode()
}
}
@@ -375,7 +377,7 @@ if you have network connectivity and want to sync your data to cloud storage."),
globalDrawer.close()
returnTopPage()
manager.populateGpsData();
- pageStack.push(gpsWindow)
+ showPage(gpsWindow)
}
}
@@ -410,7 +412,7 @@ if you have network connectivity and want to sync your data to cloud storage."),
globalDrawer.close()
settingsWindow.defaultCylinderModel = manager.cylinderInit
PrefEquipment.default_cylinder === "" ? defaultCylinderIndex = "-1" : defaultCylinderIndex = settingsWindow.defaultCylinderModel.indexOf(PrefEquipment.default_cylinder)
- pageStack.push(settingsWindow)
+ showPage(settingsWindow)
detailsWindow.endEditMode()
}
},
@@ -433,7 +435,7 @@ if you have network connectivity and want to sync your data to cloud storage."),
text: qsTr("About")
onTriggered: {
globalDrawer.close()
- pageStack.push(aboutWindow)
+ showPage(aboutWindow)
detailsWindow.endEditMode()
}
}
@@ -488,7 +490,7 @@ if you have network connectivity and want to sync your data to cloud storage."),
text: qsTr("App log")
onTriggered: {
globalDrawer.close()
- pageStack.push(logWindow)
+ showPage(logWindow)
}
}
Kirigami.Action {
@@ -511,7 +513,7 @@ if you have network connectivity and want to sync your data to cloud storage."),
text: qsTr("Theme information")
onTriggered: {
globalDrawer.close()
- pageStack.push(themetest)
+ showPage(themetest)
}
}
@@ -649,7 +651,7 @@ if you have network connectivity and want to sync your data to cloud storage."),
/* I really want an enum, but those are painful in QML, so let's use numbers
* 0 (Otherpage) - the last page selected was a non-map page
* 1 (MapSelected) - the map page was selected by the user
- * 2 (MapForced) - the map page was forced by out hack
+ * 2 (MapForced) - the map page was forced by this hack
*/
pageStack.onCurrentItemChanged: {
@@ -671,8 +673,8 @@ if you have network connectivity and want to sync your data to cloud storage."),
manager.appendTextToLog("pageStack forced back to map")
}
} else if (pageStack.currentItem.objectName !== mapPage.objectName &&
- pageStack.lastItem.objectName === mapPage.objectName &&
- hackToOpenMap === 1 /* MapSelected */) {
+ pageStack.lastItem.objectName === mapPage.objectName &&
+ hackToOpenMap === 1 /* MapSelected */) {
// if we just picked the mapPage and are suddenly back on a different page
// force things back to the mapPage
manager.appendTextToLog("pageStack wrong page, switching back to map")