summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Grace Karanja <gracie.karanja89@gmail.com>2015-07-21 15:00:29 +0300
committerGravatar Grace Karanja <gracie.karanja89@gmail.com>2015-07-22 09:53:19 +0300
commitab44c789939fc4472dfc8106b9cb5f709cbe7e1c (patch)
tree6fc40b626c89cec6e3017289cd3138d46e961c62
parentea11eff27900b0929068c2fd18728db6412484cf (diff)
downloadsubsurface-ab44c789939fc4472dfc8106b9cb5f709cbe7e1c.tar.gz
QML UI: Move DiveDetails to the StackView
Add a DiveDetails.qml to hold the dive details, and display it in the stack view when the user taps on a dive. Signed-off-by: Grace Karanja <gracie.karanja89@gmail.com>
-rw-r--r--qt-mobile/DiveDetails.qml85
-rw-r--r--qt-mobile/DiveList.qml138
-rw-r--r--qt-mobile/main.qml4
-rw-r--r--qt-mobile/mobile-resources.qrc1
4 files changed, 105 insertions, 123 deletions
diff --git a/qt-mobile/DiveDetails.qml b/qt-mobile/DiveDetails.qml
new file mode 100644
index 000000000..5dfefdff8
--- /dev/null
+++ b/qt-mobile/DiveDetails.qml
@@ -0,0 +1,85 @@
+import QtQuick 2.3
+import QtQuick.Controls 1.2
+import QtQuick.Window 2.2
+import QtQuick.Dialogs 1.2
+import QtQuick.Layouts 1.1
+import org.subsurfacedivelog.mobile 1.0
+
+Item {
+ id: diveDetailsWindow
+ width: parent.width
+
+ property string location
+ property string dive_id
+ property string airtemp
+ property string watertemp
+ property string suit
+ property string buddy
+ property string divemaster;
+ property string notes;
+
+ onDive_idChanged: {
+ qmlProfile.diveId = dive_id
+ qmlProfile.update()
+ }
+
+ Flickable {
+ id: flick
+ width: parent.width
+ anchors { top: parent.top; bottom: parent.bottom }
+ contentHeight: parent.height
+ clip: true
+ ColumnLayout {
+ width: parent.width
+ RowLayout {
+ Button {
+ text: "Back"
+ onClicked: {
+ manager.commitChanges(
+ dive_id,
+ suit,
+ buddy,
+ divemaster,
+ notes
+ )
+ stackView.pop();
+ }
+ }
+ }
+
+ GridLayout {
+ id: editorDetails
+ width: parent.width
+ columns: 2
+ Text { }
+ QMLProfile {
+ id: qmlProfile
+ height: 500
+ Layout.fillWidth: true
+ }
+ Text { text: "Location:"; font.bold: true }
+ TextField { id: txtLocation; text: location; Layout.fillWidth: true }
+ Text { text: "Air Temp:"; font.bold: true }
+ TextField { id: txtAirTemp; text: airtemp; Layout.fillWidth: true }
+ Text { text: "Water Temp:"; font.bold: true }
+ TextField { id: txtWaterTemp; text: watertemp; Layout.fillWidth: true }
+ Text { text: "Suit:"; font.bold: true }
+ TextField { id: txtSuit; text: suit; Layout.fillWidth: true }
+ Text { text: "Buddy:"; font.bold: true }
+ TextField { id: txtBuddy; text: buddy; Layout.fillWidth: true }
+ Text { text: "Dive Master:"; font.bold: true }
+ TextField { id: txtDiveMaster; text: divemaster; Layout.fillWidth: true}
+ Text { text: "Notes:"; font.bold: true }
+ TextEdit{
+ id: txtNotes
+ text: notes
+ focus: true
+ Layout.fillWidth: true
+ Layout.fillHeight: true
+ selectByMouse: true
+ wrapMode: TextEdit.WrapAtWordBoundaryOrAnywhere
+ }
+ }
+ }
+ }
+}
diff --git a/qt-mobile/DiveList.qml b/qt-mobile/DiveList.qml
index 7fa7a53f0..e2f6857b7 100644
--- a/qt-mobile/DiveList.qml
+++ b/qt-mobile/DiveList.qml
@@ -10,7 +10,6 @@ Rectangle {
Component {
id: diveDelegate
-
Item {
id: dive
@@ -24,14 +23,25 @@ Rectangle {
id: background
x: 2; y: 2; width: parent.width - x*2; height: parent.height - y*2;
color: "ivory"
- border.color: "orange"
+ border.color: "lightblue"
radius: 5
}
//Mouse region: When clicked, the mode changes to details view
MouseArea {
anchors.fill: parent
- onClicked: dive.state = 'Details'
+ onClicked: {
+ detailsWindow.width = parent.width
+ detailsWindow.location = location
+ detailsWindow.dive_id = id
+ detailsWindow.buddy = buddy
+ detailsWindow.suit = suit
+ detailsWindow.airtemp = airtemp
+ detailsWindow.watertemp = watertemp
+ detailsWindow.divemaster = divemaster
+ detailsWindow.notes = notes
+ stackView.push(detailsWindow)
+ }
}
//Layout of the page: (mini profile, dive no, date at the tio
@@ -39,7 +49,6 @@ Rectangle {
Row {
id: topLayout
x: 10; y: 10; height: childrenRect.height; width: parent.width
- spacing: 10
Column {
width: background.width; height: childrenRect.height * 1.1
@@ -48,125 +57,8 @@ Rectangle {
Text {
text: diveNumber + ' (' + date + ')'
}
- Text { text: location; width: details.width }
- Text { text: '<b>Depth:</b> ' + depth + ' <b>Duration:</b>' + duration; width: details.width }
- }
- }
-
- Item {
- id: details
- x: 10; width: parent.width - 20
- anchors { top: topLayout.bottom; topMargin: 10; bottom:parent.bottom; bottomMargin: 10 }
- opacity: dive.detailsOpacity
-
- Text {
- id: detailsTitle
- anchors.top: parent.top
- text: "Dive Details"
- font.pointSize: 12; font.bold: true
- }
-
- Flickable {
- id: flick
- width: parent.width
- anchors { top: detailsTitle.bottom; bottom: parent.bottom }
- contentHeight: editorDetails.height
- clip: true
-
- GridLayout {
- id: editorDetails
- width: detailsPage.width
- columns: 2
- Text { }
- QMLProfile {
- diveId: id
- height: 400
- Layout.fillWidth: true
- }
-
- Text { text: "Location:"; font.bold: true }
- TextField { id: txtLocation; text: location; Layout.fillWidth: true }
- Text { text: "Air Temp:"; font.bold: true }
- TextField { id: txtAirTemp; text: airtemp; Layout.fillWidth: true }
- Text { text: "Water Temp:"; font.bold: true }
- TextField { id: txtWaterTemp; text: watertemp; Layout.fillWidth: true }
- Text { text: "Suit:"; font.bold: true }
- TextField { id: txtSuit; text: suit; Layout.fillWidth: true }
- Text { text: "Buddy:"; font.bold: true }
- TextField { id: txtBuddy; text: buddy; Layout.fillWidth: true }
- Text { text: "Dive Master:"; font.bold: true }
- TextField { id: txtDiveMaster; text: divemaster; Layout.fillWidth: true}
- Text { text: "Notes:"; font.bold: true }
- TextEdit{
- id: txtNotes
- text: notes
- focus: true
- Layout.fillWidth: true
- Layout.fillHeight: true
- selectByMouse: true
- wrapMode: TextEdit.WrapAtWordBoundaryOrAnywhere
- }
- }
- }
- }
-
- TextButton {
- y: 10
- anchors { right: background.right; rightMargin: 10 }
- opacity: dive.detailsOpacity
- text: "Close"
-
- onClicked: {
- manager.commitChanges(
- id,
- txtSuit.text,
- txtBuddy.text,
- txtDiveMaster.text,
- txtNotes.text
- )
- dive.state = '';
- }
- }
-
- states: State {
- name: "Details"
-
- PropertyChanges {
- target: background
- color: "white"
- }
-
- PropertyChanges {
- target: dive
- detailsOpacity: 1; x:0 //Make details visible
- height: diveListView.height //Fill entire list area with the details
- }
-
- //Move the list so that this item is at the top
- PropertyChanges {
- target: dive.ListView.view
- explicit: true
- contentY: dive.y
- }
-
- //Disable flicking while we are in detailed view
- PropertyChanges {
- target: dive.ListView.view
- interactive: false
- }
- }
-
- transitions: Transition {
- //make the state changes smooth
- ParallelAnimation {
- ColorAnimation {
- property: "color"
- duration: 500
- }
- NumberAnimation {
- duration: 300
- properties: "detailsOpacity,x,contentY,height,width"
- }
+ Text { text: location; width: parent.width }
+ Text { text: '<b>Depth:</b> ' + depth + ' <b>Duration:</b>' + duration; width: parent.width }
}
}
}
diff --git a/qt-mobile/main.qml b/qt-mobile/main.qml
index d64c27760..adceb9a02 100644
--- a/qt-mobile/main.qml
+++ b/qt-mobile/main.qml
@@ -104,4 +104,8 @@ ApplicationWindow {
visible: false
}
+ DiveDetails {
+ id: detailsWindow
+ visible: false
+ }
}
diff --git a/qt-mobile/mobile-resources.qrc b/qt-mobile/mobile-resources.qrc
index d0fe06701..a82976eb0 100644
--- a/qt-mobile/mobile-resources.qrc
+++ b/qt-mobile/mobile-resources.qrc
@@ -4,5 +4,6 @@
<file>TextButton.qml</file>
<file>Preferences.qml</file>
<file>DiveList.qml</file>
+ <file>DiveDetails.qml</file>
</qresource>
</RCC>