summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--qt-mobile/qml/DiveDetails.qml14
-rw-r--r--qt-mobile/qml/DiveDetailsView.qml115
2 files changed, 78 insertions, 51 deletions
diff --git a/qt-mobile/qml/DiveDetails.qml b/qt-mobile/qml/DiveDetails.qml
index d46777e41..452b29974 100644
--- a/qt-mobile/qml/DiveDetails.qml
+++ b/qt-mobile/qml/DiveDetails.qml
@@ -45,11 +45,12 @@ MobileComponents.Page {
contextualActions: [
Action {
- text: "Save Changes"
+ text: "Save"
enabled: diveDetailsWindow.state == "edit"
iconName: "document-save"
onTriggered: {
manager.saveChanges();
+ contextDrawer.close();
}
},
Action {
@@ -57,7 +58,9 @@ MobileComponents.Page {
checkable: true
iconName: checked ? "view-readermode" : "document-edit"
onTriggered: {
- diveDetailsWindow.state = checked ? "edit" : "view"
+ diveDetailsWindow.state = checked ? "edit" : "view";
+ contextDrawer.close();
+ // close drawer?
}
}
@@ -69,6 +72,7 @@ MobileComponents.Page {
id: flick
anchors.fill: parent
contentHeight: content.height
+ interactive: contentHeight > height
clip: true
Item {
id: content
@@ -81,8 +85,9 @@ MobileComponents.Page {
left: parent.left
right: parent.right
top: parent.top
- margins: MobileComponents.Units.smallSpacing
+ margins: MobileComponents.Units.gridUnit / 2
}
+ visible: opacity > 0
Behavior on opacity {
NumberAnimation { duration: MobileComponents.Units.shortDuration }
@@ -94,8 +99,9 @@ MobileComponents.Page {
left: parent.left
right: parent.right
top: parent.top
- margins: MobileComponents.Units.smallSpacing
+ margins: MobileComponents.Units.gridUnit / 2
}
+ visible: opacity > 0
Behavior on opacity {
NumberAnimation { duration: MobileComponents.Units.shortDuration }
diff --git a/qt-mobile/qml/DiveDetailsView.qml b/qt-mobile/qml/DiveDetailsView.qml
index 867761c05..099bf13eb 100644
--- a/qt-mobile/qml/DiveDetailsView.qml
+++ b/qt-mobile/qml/DiveDetailsView.qml
@@ -6,10 +6,14 @@ import QtQuick.Layouts 1.1
import org.subsurfacedivelog.mobile 1.0
import org.kde.plasma.mobilecomponents 0.2 as MobileComponents
-ColumnLayout {
+GridLayout {
id: detailsView
- spacing: MobileComponents.Units.smallSpacing
+ columns: 4
+ rowSpacing: MobileComponents.Units.smallSpacing * 2
+ columnSpacing: MobileComponents.Units.smallSpacing
+
+ property int labelWidth: MobileComponents.Units.gridUnit * 10
Connections {
target: diveDetailsWindow
@@ -21,28 +25,27 @@ ColumnLayout {
MobileComponents.Heading {
id: detailsViewHeading
- Layout.columnSpan: 2
+ Layout.fillWidth: true
text: location
+ Layout.columnSpan: 4
+ }
+
+ MobileComponents.Label {
+ Layout.alignment: Qt.AlignRight
+ id: depthLabel
+ text: "Depth: "
+ opacity: 0.6
+ }
+ MobileComponents.Label {
+ text: depth
+ Layout.minimumWidth: Math.max(MobileComponents.Units.gridUnit * 4, paintedWidth) // helps vertical alignment throughout listview
+ }
+ MobileComponents.Label {
+ Layout.alignment: Qt.AlignRight
+ text: "Duration: "
+ opacity: 0.6
}
RowLayout {
-// anchors {
-// left: parent.left
-// right: parent.right
-// bottom: numberText.bottom
-// }
- Layout.columnSpan: 2
- MobileComponents.Label {
- text: 'Depth: '
- opacity: 0.6
- }
- MobileComponents.Label {
- text: depth
- Layout.minimumWidth: Math.max(MobileComponents.Units.gridUnit * 4, paintedWidth) // helps vertical alignment throughout listview
- }
- MobileComponents.Label {
- text: 'Duration: '
- opacity: 0.6
- }
MobileComponents.Label {
text: duration
}
@@ -54,38 +57,37 @@ ColumnLayout {
id: numberText
text: "#" + diveNumber
color: MobileComponents.Theme.textColor
- //opacity: 0.6
}
}
- Item {
- Layout.columnSpan: 2
+ QMLProfile {
+ id: qmlProfile
Layout.fillWidth: true
- Layout.preferredHeight: qmlProfile.height
- QMLProfile {
- id: qmlProfile
- //height: MobileComponents.Units.gridUnit * 25
- height: width * 0.66
- anchors {
- top: parent.top
- left: parent.left
- right: parent.right
- }
- //Rectangle { color: "green"; opacity: 0.4; anchors.fill: parent } // used for debugging the dive profile sizing, will be removed later
+ Layout.preferredHeight: width * 0.66
+ Layout.columnSpan: 4
+
+ Rectangle {
+ color: "transparent"
+ opacity: 0.6
+ border.width: 1
+ border.color: MobileComponents.Theme.textColor;
+ anchors.fill: parent
+
}
+ //Rectangle { color: "green"; opacity: 0.4; anchors.fill: parent } // used for debugging the dive profile sizing, will be removed later
}
- MobileComponents.Label {
- Layout.alignment: Qt.AlignRight
- text: "Location:"
- }
- MobileComponents.Label {
- id: txtLocation; text: location;
+
+ MobileComponents.Heading {
Layout.fillWidth: true
+ level: 3
+ text: "Dive Details"
+ Layout.columnSpan: 4
}
MobileComponents.Label {
Layout.alignment: Qt.AlignRight
text: "Air Temp:"
+ opacity: 0.6
}
MobileComponents.Label {
id: txtAirTemp
@@ -96,6 +98,7 @@ ColumnLayout {
MobileComponents.Label {
Layout.alignment: Qt.AlignRight
text: "Water Temp:"
+ opacity: 0.6
}
MobileComponents.Label {
id: txtWaterTemp
@@ -106,7 +109,7 @@ ColumnLayout {
MobileComponents.Label {
Layout.alignment: Qt.AlignRight
text: "Suit:"
-
+ opacity: 0.6
}
MobileComponents.Label {
id: txtSuit
@@ -116,7 +119,19 @@ ColumnLayout {
MobileComponents.Label {
Layout.alignment: Qt.AlignRight
+ text: "Weight:"
+ opacity: 0.6
+ }
+ MobileComponents.Label {
+ id: txtWeight
+ text: weight
+ Layout.fillWidth: true
+ }
+
+ MobileComponents.Label {
+ Layout.alignment: Qt.AlignRight
text: "Buddy:"
+ opacity: 0.6
}
MobileComponents.Label {
id: txtBuddy
@@ -127,6 +142,7 @@ ColumnLayout {
MobileComponents.Label {
Layout.alignment: Qt.AlignRight
text: "Dive Master:"
+ opacity: 0.6
}
MobileComponents.Label {
id: txtDiveMaster
@@ -134,21 +150,26 @@ ColumnLayout {
Layout.fillWidth: true
}
- MobileComponents.Label {
- Layout.alignment: Qt.AlignRight
- text: "Notes:"
+ MobileComponents.Heading {
+ Layout.fillWidth: true
+ level: 3
+ text: "Notes"
+ Layout.columnSpan: 4
}
+
MobileComponents.Label {
id: txtNotes
text: notes
focus: true
+ Layout.columnSpan: 4
Layout.fillWidth: true
Layout.fillHeight: true
//selectByMouse: true
wrapMode: TextEdit.WrapAtWordBoundaryOrAnywhere
}
Item {
- height: MobileComponents.Units.gridUnit * 3
- width: height // just to make sure the spacer doesn't produce scrollbars, but also isn't null
+ Layout.columnSpan: 4
+ Layout.fillWidth: true
+ Layout.minimumHeight: MobileComponents.Units.gridUnit * 3
}
}