summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Jan Mulder <jlmulder@xs4all.nl>2018-09-27 11:54:28 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2018-09-27 06:36:22 -0700
commit0ad7df985972bee42f925d2e2853587307e3ef7a (patch)
tree4284c0e69d226e4c036d79856a5d6f9f651da44a
parent890d4c3d649dd55817d4bb85d62ad433a61cebe4 (diff)
downloadsubsurface-0ad7df985972bee42f925d2e2853587307e3ef7a.tar.gz
mobile, QML UI: Settings page scalability
A relatively big change for such a simple page. Most relevant changes are: 1) Do not use Kirigami.Header anymore. It appears that this header has word wrapping on (and we cannot override that). This is annoying on this page, as headings seems randomly be split over 2 lines, even in cases where there is more than enhough room to display it on one line. And as the Kirigami.Header is just a trivial wrapper of a Text field, we can simple replace it. 2) A lot of the toplevel GridLayouts had width properties set. These are not needed (and confused my debugging code), so they are removed withput any visual change. As a general rule, do not try to set properties that are not needed. In general, it can only lead to binding loops or undefined behavior. 3) Add a font size to our Theme. The step from regular to title size was a little too big. 4) And, obviously, numerous font.pointSize lines are added to actually resize the font. Signed-off-by: Jan Mulder <jlmulder@xs4all.nl>
-rw-r--r--mobile-widgets/qml/Settings.qml90
-rw-r--r--mobile-widgets/qml/main.qml1
2 files changed, 53 insertions, 38 deletions
diff --git a/mobile-widgets/qml/Settings.qml b/mobile-widgets/qml/Settings.qml
index 65940cc67..293701fd2 100644
--- a/mobile-widgets/qml/Settings.qml
+++ b/mobile-widgets/qml/Settings.qml
@@ -28,31 +28,28 @@ Kirigami.ScrollablePage {
GridLayout {
id: cloudSetting
columns: 3
- Layout.bottomMargin: Kirigami.Units.gridUnit
- Kirigami.Heading {
+ Controls.Label {
text: qsTr("Cloud status")
+ font.pointSize: subsurfaceTheme.headingPointSize
+ font.weight: Font.Light
color: subsurfaceTheme.textColor
- level: 4
Layout.topMargin: Kirigami.Units.largeSpacing
Layout.bottomMargin: Kirigami.Units.largeSpacing / 2
Layout.columnSpan: 3
}
Controls.Label {
text: qsTr("Email")
- Layout.alignment: Qt.AlignRight
+ font.pointSize: subsurfaceTheme.regularPointSize
Layout.preferredWidth: gridWidth * 0.15
- Layout.preferredHeight: Kirigami.Units.gridUnit * 2
}
Controls.Label {
text: prefs.credentialStatus === CloudStatus.CS_NOCLOUD ? qsTr("Not applicable") : prefs.cloudUserName
- Layout.alignment: Qt.AlignRight
+ font.pointSize: subsurfaceTheme.regularPointSize
Layout.preferredWidth: gridWidth * 0.60
- Layout.preferredHeight: Kirigami.Units.gridUnit * 2
}
SsrfButton {
id: changeCloudSettings
- Layout.alignment: Qt.AlignRight
text: qsTr("Change")
onClicked: {
prefs.cancelCredentialsPinSetup()
@@ -61,15 +58,15 @@ Kirigami.ScrollablePage {
}
Controls.Label {
text: qsTr("Status")
- Layout.alignment: Qt.AlignRight
+ font.pointSize: subsurfaceTheme.regularPointSize
Layout.preferredWidth: gridWidth * 0.15
- Layout.preferredHeight: Kirigami.Units.gridUnit * 2
+ Layout.preferredHeight: Kirigami.Units.gridUnit * 1.5
}
Controls.Label {
text: describe[prefs.credentialStatus]
- Layout.alignment: Qt.AlignRight
+ font.pointSize: subsurfaceTheme.regularPointSize
Layout.preferredWidth: gridWidth * 0.60
- Layout.preferredHeight: Kirigami.Units.gridUnit * 2
+ Layout.preferredHeight: Kirigami.Units.gridUnit * 1.5
}
}
@@ -82,18 +79,19 @@ Kirigami.ScrollablePage {
GridLayout {
id: themeSettings
columns: 3
- Layout.bottomMargin: Kirigami.Units.gridUnit
- Kirigami.Heading {
+ Controls.Label {
text: qsTr("Theme")
+ font.pointSize: subsurfaceTheme.headingPointSize
+ font.weight: Font.Light
color: subsurfaceTheme.textColor
- level: 4
Layout.topMargin: Kirigami.Units.largeSpacing
Layout.bottomMargin: Kirigami.Units.largeSpacing / 2
Layout.columnSpan: 3
}
Controls.Label {
text: qsTr("Blue")
+ font.pointSize: subsurfaceTheme.regularPointSize
color: subsurfaceTheme.textColor
rightPadding: Kirigami.Units.gridUnit
Layout.preferredWidth: gridWidth * 0.15
@@ -109,6 +107,7 @@ Kirigami.ScrollablePage {
Text {
id: sampleRegularBlue
text: qsTr("regular text")
+ font.pointSize: subsurfaceTheme.regularPointSize
color: subsurfaceTheme.blueTextColor
anchors {
horizontalCenter: parent.horizontalCenter
@@ -124,6 +123,7 @@ Kirigami.ScrollablePage {
Text {
id: sampleHighlightBlue
text: qsTr("Highlight")
+ font.pointSize: subsurfaceTheme.regularPointSize
color: subsurfaceTheme.bluePrimaryTextColor
anchors {
horizontalCenter: parent.horizontalCenter
@@ -146,6 +146,7 @@ Kirigami.ScrollablePage {
Controls.Label {
id: pinkLabel
text: qsTr("Pink")
+ font.pointSize: subsurfaceTheme.regularPointSize
rightPadding: Kirigami.Units.gridUnit
Layout.preferredWidth: gridWidth * 0.15
}
@@ -160,6 +161,7 @@ Kirigami.ScrollablePage {
Text {
id: sampleRegularPink
text: qsTr("regular text")
+ font.pointSize: subsurfaceTheme.regularPointSize
color: subsurfaceTheme.pinkTextColor
anchors {
horizontalCenter: parent.horizontalCenter
@@ -175,6 +177,7 @@ Kirigami.ScrollablePage {
Text {
id: sampleHighlightPink
text: qsTr("Highlight")
+ font.pointSize: subsurfaceTheme.regularPointSize
color: subsurfaceTheme.pinkPrimaryTextColor
anchors {
horizontalCenter: parent.horizontalCenter
@@ -197,6 +200,7 @@ Kirigami.ScrollablePage {
Controls.Label {
text: qsTr("Dark")
+ font.pointSize: subsurfaceTheme.regularPointSize
color: subsurfaceTheme.textColor
rightPadding: Kirigami.Units.gridUnit
Layout.preferredWidth: gridWidth * 0.15
@@ -212,6 +216,7 @@ Kirigami.ScrollablePage {
Text {
id: sampleRegularDark
text: qsTr("regular text")
+ font.pointSize: subsurfaceTheme.regularPointSize
color: subsurfaceTheme.darkTextColor
anchors {
horizontalCenter: parent.horizontalCenter
@@ -227,6 +232,7 @@ Kirigami.ScrollablePage {
Text {
id: sampleHighlightDark
text: qsTr("Highlight")
+ font.pointSize: subsurfaceTheme.regularPointSize
color: subsurfaceTheme.darkPrimaryTextColor
anchors {
horizontalCenter: parent.horizontalCenter
@@ -245,10 +251,11 @@ Kirigami.ScrollablePage {
PrefDisplay.theme = subsurfaceTheme.currentTheme
}
}
- Kirigami.Heading {
+ Controls.Label {
text: qsTr("Scaling")
+ font.pointSize: subsurfaceTheme.headingPointSize
+ font.weight: Font.Light
color: subsurfaceTheme.textColor
- level: 4
Layout.topMargin: Kirigami.Units.largeSpacing
Layout.bottomMargin: Kirigami.Units.largeSpacing / 2
Layout.columnSpan: 3
@@ -294,12 +301,12 @@ Kirigami.ScrollablePage {
GridLayout {
id: gpsPrefs
columns: 2
- width: parent.width
- Kirigami.Heading {
+ Controls.Label {
text: qsTr("GPS location service")
+ font.pointSize: subsurfaceTheme.headingPointSize
+ font.weight: Font.Light
color: subsurfaceTheme.textColor
- level: 4
Layout.topMargin: Kirigami.Units.largeSpacing
Layout.bottomMargin: Kirigami.Units.largeSpacing / 2
Layout.columnSpan: 2
@@ -307,13 +314,14 @@ Kirigami.ScrollablePage {
Controls.Label {
text: qsTr("Distance threshold (meters)")
- Layout.alignment: Qt.AlignRight
+ font.pointSize: subsurfaceTheme.regularPointSize
Layout.preferredWidth: gridWidth * 0.75
}
Controls.TextField {
id: distanceThreshold
text: PrefLocationService.distance_threshold
+ font.pointSize: subsurfaceTheme.regularPointSize
Layout.preferredWidth: gridWidth * 0.25
onEditingFinished: {
PrefLocationService.distance_threshold = distanceThreshold.text
@@ -322,13 +330,14 @@ Kirigami.ScrollablePage {
Controls.Label {
text: qsTr("Time threshold (minutes)")
- Layout.alignment: Qt.AlignRight
+ font.pointSize: subsurfaceTheme.regularPointSize
Layout.preferredWidth: gridWidth * 0.75
}
Controls.TextField {
id: timeThreshold
text: PrefLocationService.time_threshold / 60
+ font.pointSize: subsurfaceTheme.regularPointSize
Layout.preferredWidth: gridWidth * 0.25
onEditingFinished: {
PrefLocationService.time_threshold = timeThreshold.text * 60
@@ -342,27 +351,29 @@ Kirigami.ScrollablePage {
opacity: 0.5
Layout.fillWidth: true
}
+
GridLayout {
id: defaultCylinder
columns: 2
- width: parent.width - Kirigami.Units.gridUnit
+ Layout.rightMargin: Kirigami.Units.gridUnit * 1.5
- Kirigami.Heading {
+ Controls.Label {
text: qsTr("Default Cylinder")
+ font.pointSize: subsurfaceTheme.headingPointSize
+ font.weight: Font.Light
color: subsurfaceTheme.textColor
- level: 4
Layout.topMargin: Kirigami.Units.largeSpacing
Layout.bottomMargin: Kirigami.Units.largeSpacing / 2
Layout.columnSpan: 2
}
Controls.Label {
- Layout.alignment: Qt.AlignRight
text: qsTr("Cylinder:")
- font.pointSize: subsurfaceTheme.smallPointSize
+ font.pointSize: subsurfaceTheme.regularPointSize
}
Controls.ComboBox {
id: defaultCylinderBox
- flat: true
+ font.pointSize: subsurfaceTheme.regularPointSize
+ Layout.preferredHeight: fontMetrics.height * 2.5
inputMethodHints: Qt.ImhNoPredictiveText
Layout.fillWidth: true
onActivated: {
@@ -370,7 +381,6 @@ Kirigami.ScrollablePage {
}
}
}
-
Rectangle {
color: subsurfaceTheme.darkerPrimaryColor
height: 1
@@ -381,17 +391,18 @@ Kirigami.ScrollablePage {
GridLayout {
id: divecomputers
columns: 2
- width: parent.width - Kirigami.Units.gridUnit
- Kirigami.Heading {
+ Controls.Label {
text: qsTr("Dive computers")
+ font.pointSize: subsurfaceTheme.headingPointSize
+ font.weight: Font.Light
color: subsurfaceTheme.textColor
- level: 4
Layout.topMargin: Kirigami.Units.largeSpacing
Layout.bottomMargin: Kirigami.Units.largeSpacing
Layout.columnSpan: 2
}
Controls.Label {
text: qsTr("Forget remembered dive computers")
+ font.pointSize: subsurfaceTheme.regularPointSize
Layout.preferredWidth: gridWidth * 0.75
}
SsrfButton {
@@ -417,11 +428,11 @@ Kirigami.ScrollablePage {
GridLayout {
id: unit_system
columns: 2
- width: parent.width - Kirigami.Units.gridUnit
- Kirigami.Heading {
+ Controls.Label {
text: qsTr("Units")
+ font.pointSize: subsurfaceTheme.headingPointSize
+ font.weight: Font.Light
color: subsurfaceTheme.textColor
- level: 4
Layout.topMargin: Kirigami.Units.largeSpacing
Layout.bottomMargin: Kirigami.Units.largeSpacing / 2
Layout.columnSpan: 2
@@ -429,6 +440,7 @@ Kirigami.ScrollablePage {
Controls.Label {
text: qsTr("Use Imperial Units")
+ font.pointSize: subsurfaceTheme.regularPointSize
Layout.preferredWidth: gridWidth * 0.75
}
SsrfSwitch {
@@ -444,6 +456,7 @@ Kirigami.ScrollablePage {
}
Controls.Label {
text: qsTr("Use Metric Units")
+ font.pointSize: subsurfaceTheme.regularPointSize
Layout.preferredWidth: gridWidth * 0.75
}
SsrfSwitch {
@@ -469,11 +482,11 @@ Kirigami.ScrollablePage {
GridLayout {
id: developer
columns: 2
- width: parent.width - Kirigami.Units.gridUnit
- Kirigami.Heading {
+ Controls.Label {
text: qsTr("Developer")
+ font.pointSize: subsurfaceTheme.headingPointSize
+ font.weight: Font.Light
color: subsurfaceTheme.textColor
- level: 4
Layout.topMargin: Kirigami.Units.largeSpacing
Layout.bottomMargin: Kirigami.Units.largeSpacing / 2
Layout.columnSpan: 2
@@ -481,6 +494,7 @@ Kirigami.ScrollablePage {
Controls.Label {
text: qsTr("Display Developer menu")
+ font.pointSize: subsurfaceTheme.regularPointSize
Layout.preferredWidth: gridWidth * 0.75
}
SsrfSwitch {
diff --git a/mobile-widgets/qml/main.qml b/mobile-widgets/qml/main.qml
index 743b4caa1..72d37134a 100644
--- a/mobile-widgets/qml/main.qml
+++ b/mobile-widgets/qml/main.qml
@@ -455,6 +455,7 @@ if you have network connectivity and want to sync your data to cloud storage."),
property double regularPointSize: fontMetrics.font.pointSize
property double titlePointSize: regularPointSize * 1.5
+ property double headingPointSize: regularPointSize * 1.2
property double smallPointSize: regularPointSize * 0.8
// colors currently in use