summaryrefslogtreecommitdiffstats
path: root/qt-mobile/DiveList.qml
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 /qt-mobile/DiveList.qml
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>
Diffstat (limited to 'qt-mobile/DiveList.qml')
-rw-r--r--qt-mobile/DiveList.qml138
1 files changed, 15 insertions, 123 deletions
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 }
}
}
}