aboutsummaryrefslogtreecommitdiffstats
path: root/qt-mobile/qml/TopBar.qml
blob: eb7403f9bcb5d92c37c500bb622cd538ebe4da77 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
import QtQuick 2.3
import QtQuick.Controls 1.2
import QtQuick.Controls.Styles 1.2
import QtQuick.Window 2.2
import QtQuick.Dialogs 1.2
import QtQuick.Layouts 1.1
import QtQuick.Window 2.2
import org.subsurfacedivelog.mobile 1.0

Rectangle {
	id: topPart

	property bool goBack: (stackView.depth > 1)

	color: theme.accentColor
	Layout.minimumHeight: units.gridUnit * 2 + units.smallSpacing * 2
	Layout.fillWidth: true
	Layout.margins: 0
	RowLayout {
		anchors.bottom: topPart.bottom
		anchors.bottomMargin: units.smallSpacing
		anchors.left: topPart.left
		anchors.leftMargin: units.smallSpacing
		anchors.right: topPart.right
		anchors.rightMargin: units.smallSpacing
		Image {
			source: "qrc:/qml/subsurface-mobile-icon.png"
			Layout.maximumWidth: units.gridUnit * 2
			Layout.preferredWidth: units.gridUnit * 2
			Layout.preferredHeight: units.gridUnit * 2
		}
		Text {
			text: qsTr("Subsurface")
			font.pointSize: units.fontMetrics.font.pointSize * 2
			Layout.fillWidth: false
			color: theme.accentTextColor
		}
		Item {
			Layout.fillWidth: true
		}
		Button {
			id: prefsButton
			// Display back arrow or menu button
			text: topPart.goBack ? "\u2190" : "\u22ee"
			anchors.right: parent.right
			Layout.preferredWidth: units.gridUnit * 2
			Layout.preferredHeight: parent.height
			style: ButtonStyle {
				background: Rectangle {
					implicitWidth: units.gridUnit * 2
					color: theme.accentColor
				}
				label: Text {
					id: txt
					color: theme.accentTextColor
					font.pointSize: units.fontMetrics.font.pointSize * 2
					font.bold: true
					text: control.text
					horizontalAlignment: Text.AlignHCenter
					verticalAlignment: Text.AlignVCenter
				}
			}
			onClicked: {
				if (topPart.goBack) {
					stackView.pop()
				} else {
					prefsMenu.popup()
				}
			}
		}

	}

}