summaryrefslogtreecommitdiffstats
path: root/mobile-widgets/qml
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2020-02-22 14:07:46 -0800
committerGravatar Dirk Hohndel <dirk@hohndel.org>2020-03-10 09:25:57 -0700
commit0683d97636647f75c10aa9150e1ca8f2ab992a95 (patch)
tree3b87f681509228223e14d7f2174573273f98be3c /mobile-widgets/qml
parenteaa1a5126bc0f50ba1e7ae59a895385b6d4e6614 (diff)
downloadsubsurface-0683d97636647f75c10aa9150e1ca8f2ab992a95.tar.gz
mobile UI: save changes to trip details
The logic when we show the save button is a little fragile (and visually I'm not sure I love the disabled button), but hey, this works. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'mobile-widgets/qml')
-rw-r--r--mobile-widgets/qml/DiveList.qml1
-rw-r--r--mobile-widgets/qml/TripDetails.qml66
2 files changed, 65 insertions, 2 deletions
diff --git a/mobile-widgets/qml/DiveList.qml b/mobile-widgets/qml/DiveList.qml
index 7013c8f28..86b361186 100644
--- a/mobile-widgets/qml/DiveList.qml
+++ b/mobile-widgets/qml/DiveList.qml
@@ -288,6 +288,7 @@ Kirigami.ScrollablePage {
text: qsTr("Edit trip details")
visible: currentItem && currentItem.myData && currentItem.myData.isTrip
onTriggered: {
+ tripEditWindow.tripId = currentItem.myData.tripId
tripEditWindow.tripLocation = currentItem.myData.tripLocation
tripEditWindow.tripNotes = currentItem.myData.tripNotes
pageStack.push(tripEditWindow)
diff --git a/mobile-widgets/qml/TripDetails.qml b/mobile-widgets/qml/TripDetails.qml
index 7f0a69be0..eca51653d 100644
--- a/mobile-widgets/qml/TripDetails.qml
+++ b/mobile-widgets/qml/TripDetails.qml
@@ -8,6 +8,7 @@ import org.kde.kirigami 2.4 as Kirigami
Kirigami.Page {
id: tripEditPage
objectName: "TripDetails"
+ property string tripId
property string tripLocation
property string tripNotes
@@ -15,7 +16,60 @@ Kirigami.Page {
state: "view"
padding: Kirigami.largeSpacing
background: Rectangle { color: subsurfaceTheme.backgroundColor }
- width: rootItem.colWidth
+ actions.main: saveAction
+ actions.right: cancelAction
+ onVisibleChanged: {
+ resetState()
+ }
+ onTripIdChanged: {
+ resetState()
+ }
+
+ function resetState() {
+ // make sure we have the right width and reset focus / state if there aren't any unsaved changes
+ width = parent.width
+ if (tripLocation === tripLocationField.text && tripNotes === tripNotesField.text) {
+ tripLocationField.focus = false
+ tripNotesField.focus = false
+ state = "view"
+ }
+
+ }
+
+ states: [
+ State {
+ name: "view"
+ PropertyChanges { target: saveAction; enabled: false }
+ },
+ State {
+ name: "edit"
+ PropertyChanges { target: saveAction; enabled: true }
+ }
+ ]
+
+ property QtObject saveAction: Kirigami.Action {
+ icon {
+ name: subsurfaceTheme.iconStyle + "/document-save.svg"
+ color: enabled ? subsurfaceTheme.primaryColor : subsurfaceTheme.backgroundColor
+ }
+ text: enabled ? qsTr("Save edits") : ""
+ onTriggered: {
+ manager.appendTextToLog("Save trip details triggered")
+ manager.updateTripDetails(tripId, tripLocationField.text, tripNotesField.text)
+ }
+ }
+ property QtObject cancelAction: Kirigami.Action {
+ text: qsTr("Cancel edit")
+ icon {
+ name: ":/icons/dialog-cancel.svg"
+ }
+ onTriggered: {
+ manager.appendTextToLog("Cancel trip details edit")
+ state = "view"
+ pageStack.pop("TripDetails")
+ }
+ }
+
Flickable {
id: tripEditFlickable
anchors.fill: parent
@@ -42,9 +96,13 @@ Kirigami.Page {
opacity: 0.6
}
SsrfTextField {
+ id: tripLocationField
Layout.fillWidth: true
text: tripLocation
flickable: tripEditFlickable
+ onFocusChanged: {
+ tripEditPage.state = "edit"
+ }
}
TemplateLabel {
Layout.columnSpan: 2
@@ -52,14 +110,18 @@ Kirigami.Page {
opacity: 0.6
}
Controls.TextArea {
+ id: tripNotesField
text: tripNotes
- textFormat: TextEdit.RichText
+ textFormat: TextEdit.PlainText
Layout.columnSpan: 2
Layout.fillWidth: true
Layout.fillHeight: true
Layout.minimumHeight: Kirigami.Units.gridUnit * 6
selectByMouse: true
wrapMode: TextEdit.WrapAtWordBoundaryOrAnywhere
+ onActiveFocusChanged: {
+ tripEditPage.state = "edit"
+ }
}
}
}