aboutsummaryrefslogtreecommitdiffstats
path: root/mobile-widgets/qml/Settings.qml
diff options
context:
space:
mode:
authorGravatar Joakim Bygdell <j.bygdell@gmail.com>2017-07-22 12:04:27 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2017-07-23 03:20:58 +0900
commit1659390a5488fd4110faed23ac305105f312f834 (patch)
tree1b9a73b66c4cf9c8685342e68b5861b92a34874f /mobile-widgets/qml/Settings.qml
parenta80394d5b6f3d98c3095eaac5a202749aaf6de2a (diff)
downloadsubsurface-1659390a5488fd4110faed23ac305105f312f834.tar.gz
QML UI: simplify settings page code
In stead of using the fixed 4 column code introduced in f2fcad89b0db9b164d8fd3f89218ad27ca362bd3 use percentages of page width to allow for a more flexible layout since no block really has 4 columns. Signed-off-by: Joakim Bygdell <j.bygdell@gmail.com>
Diffstat (limited to 'mobile-widgets/qml/Settings.qml')
-rw-r--r--mobile-widgets/qml/Settings.qml51
1 files changed, 22 insertions, 29 deletions
diff --git a/mobile-widgets/qml/Settings.qml b/mobile-widgets/qml/Settings.qml
index 3cb7cb51e..4c9e73574 100644
--- a/mobile-widgets/qml/Settings.qml
+++ b/mobile-widgets/qml/Settings.qml
@@ -13,10 +13,6 @@ Kirigami.ScrollablePage {
title: qsTr("Settings")
anchors.margins: Kirigami.Units.gridUnit / 2
property real gridWidth: settingsPage.width - 2 * Kirigami.Units.gridUnit
- property real col1Width: gridWidth * 0.25
- property real col2Width: gridWidth * 0.25
- property real col3Width: gridWidth * 0.25
- property real col4Width: gridWidth * 0.25
ColumnLayout {
width: parent.width - Kirigami.Units.gridUnit
@@ -35,7 +31,7 @@ Kirigami.ScrollablePage {
}
GridLayout {
id: themeSettings
- columns: 4
+ columns: 3
Layout.bottomMargin: Kirigami.Units.gridUnit
Kirigami.Heading {
@@ -44,16 +40,15 @@ Kirigami.ScrollablePage {
level: 4
Layout.topMargin: Kirigami.Units.largeSpacing
Layout.bottomMargin: Kirigami.Units.largeSpacing / 2
- Layout.columnSpan: 4
+ Layout.columnSpan: 3
}
Kirigami.Label {
text: qsTr("Blue")
color: subsurfaceTheme.textColor
rightPadding: Kirigami.Units.gridUnit
- Layout.preferredWidth: settingsPage.col1Width * 0.8
+ Layout.preferredWidth: gridWidth * 0.2
}
Row {
- Layout.columnSpan: 2
Layout.preferredWidth: gridwidth * 0.6
// Layout.alignment: Qt.AlignLeft
Rectangle {
@@ -90,7 +85,7 @@ Kirigami.ScrollablePage {
}
RadioButton {
id: bluebutton
- Layout.preferredWidth: settingsPage.col4Width * 0.5
+ Layout.preferredWidth: gridWidth * 0.125
Layout.alignment: Qt.AlignRight
checked: subsurfaceTheme.currentTheme === "Blue"
onClicked: {
@@ -123,10 +118,9 @@ Kirigami.ScrollablePage {
text: qsTr("Pink")
color: subsurfaceTheme.textColor
rightPadding: Kirigami.Units.gridUnit
- Layout.preferredWidth: settingsPage.col1Width * 0.5
+ Layout.preferredWidth: gridWidth * 0.125
}
Row {
- Layout.columnSpan: 2
Layout.preferredWidth: settingsPage.col2Width + settingsPage.col3Width
Rectangle {
id: pinkRect
@@ -164,7 +158,7 @@ Kirigami.ScrollablePage {
RadioButton {
id: pinkbutton
checked: subsurfaceTheme.currentTheme === "Pink"
- Layout.preferredWidth: settingsPage.col4Width * 0.5
+ Layout.preferredWidth: gridWidth * 0.125
Layout.alignment: Qt.AlignRight
onClicked: {
pinkTheme()
@@ -196,10 +190,9 @@ Kirigami.ScrollablePage {
text: qsTr("Dark")
color: subsurfaceTheme.textColor
rightPadding: Kirigami.Units.gridUnit
- Layout.preferredWidth: settingsPage.col1Width * 0.5
+ Layout.preferredWidth: gridWidth * 0.125
}
Row {
- Layout.columnSpan: 2
Layout.preferredWidth: settingsPage.col2Width + settingsPage.col3Width
Rectangle {
id: blackRect
@@ -236,7 +229,7 @@ Kirigami.ScrollablePage {
RadioButton {
id: darkbutton
checked: subsurfaceTheme.currentTheme === "Dark"
- Layout.preferredWidth: settingsPage.col4Width * 0.5
+ Layout.preferredWidth: gridWidth * 0.125
Layout.alignment: Qt.AlignRight
onClicked: {
darkTheme()
@@ -287,13 +280,13 @@ Kirigami.ScrollablePage {
Kirigami.Label {
text: qsTr("Distance threshold (meters)")
Layout.alignment: Qt.AlignRight
- Layout.preferredWidth: settingsPage.col1Width + settingsPage.col2Width + settingsPage.col3Width
+ Layout.preferredWidth:gridWidth * 0.75
}
TextField {
id: distanceThreshold
text: manager.distanceThreshold
- Layout.preferredWidth: settingsPage.col4Width
+ Layout.preferredWidth: gridWidth * 0.25
onEditingFinished: {
manager.distanceThreshold = distanceThreshold.text
manager.savePreferences()
@@ -303,13 +296,13 @@ Kirigami.ScrollablePage {
Kirigami.Label {
text: qsTr("Time threshold (minutes)")
Layout.alignment: Qt.AlignRight
- Layout.preferredWidth: settingsPage.col1Width + settingsPage.col2Width + settingsPage.col3Width
+ Layout.preferredWidth: gridWidth * 0.75
}
TextField {
id: timeThreshold
text: manager.timeThreshold
- Layout.preferredWidth: settingsPage.col4Width
+ Layout.preferredWidth: gridWidth * 0.25
onEditingFinished: {
manager.timeThreshold = timeThreshold.text
manager.savePreferences()
@@ -319,11 +312,11 @@ Kirigami.ScrollablePage {
Kirigami.Label {
text: qsTr("Run location service")
Layout.alignment: Qt.AlignRight
- Layout.preferredWidth: settingsPage.col1Width + settingsPage.col2Width + settingsPage.col3Width
+ Layout.preferredWidth: gridWidth * 0.75
}
Switch {
id: locationButton
- Layout.preferredWidth: settingsPage.col4Width
+ Layout.preferredWidth: gridWidth * 0.25
visible: manager.locationServiceAvailable
checked: manager.locationServiceEnabled
onClicked: {
@@ -360,7 +353,7 @@ Kirigami.ScrollablePage {
}
GridLayout {
id: libdclogprefs
- columns: 4
+ columns: 2
width: parent.width
Kirigami.Heading {
text: qsTr("Dive computer")
@@ -368,17 +361,17 @@ Kirigami.ScrollablePage {
level: 4
Layout.topMargin: Kirigami.Units.largeSpacing
Layout.bottomMargin: Kirigami.Units.largeSpacing / 2
- Layout.columnSpan: 4
+ Layout.columnSpan: 2
}
Kirigami.Label {
text: qsTr("Save detailed log")
- Layout.preferredWidth: settingsPage.col1Width + settingsPage.col2Width + settingsPage.col3Width
+ Layout.preferredWidth: gridWidth * 0.75
}
Switch {
id: libdclogButton
checked: manager.libdcLog
- Layout.preferredWidth: settingsPage.col4Width
+ Layout.preferredWidth: gridWidth * 0.25
onClicked: {
manager.libdcLog = checked
}
@@ -413,7 +406,7 @@ Kirigami.ScrollablePage {
}
GridLayout {
id: developer
- columns: 4
+ columns: 2
width: parent.width - Kirigami.Units.gridUnit
Kirigami.Heading {
text: qsTr("Developer")
@@ -421,17 +414,17 @@ Kirigami.ScrollablePage {
level: 4
Layout.topMargin: Kirigami.Units.largeSpacing
Layout.bottomMargin: Kirigami.Units.largeSpacing / 2
- Layout.columnSpan: 4
+ Layout.columnSpan: 2
}
Kirigami.Label {
text: qsTr("Display Developer menu")
- Layout.preferredWidth: settingsPage.col1Width + settingsPage.col2Width + settingsPage.col3Width
+ Layout.preferredWidth: gridWidth * 0.75
}
Switch {
id: developerButton
checked: manager.developer
- Layout.preferredWidth: settingsPage.col4Width
+ Layout.preferredWidth: gridWidth * 0.25
onClicked: {
manager.developer = checked
}