diff options
author | Joakim Bygdell <j.bygdell@gmail.com> | 2017-07-20 20:47:17 +0200 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2017-07-23 03:20:58 +0900 |
commit | a56e98ffc627c740de600a696725cc5b351327de (patch) | |
tree | 6578b6b621b4bfef556cc3ecca710e71d5809e03 | |
parent | a5d43bc5f8113a3186036567488700a889c6ac5a (diff) | |
download | subsurface-a56e98ffc627c740de600a696725cc5b351327de.tar.gz |
QML UI: Replace checkboxes on settingspage with switches
Replace the checkboxes for location services and developer with switches.
Signed-off-by: Joakim Bygdell <j.bygdell@gmail.com>
-rw-r--r-- | mobile-widgets/qml/Settings.qml | 82 |
1 files changed, 45 insertions, 37 deletions
diff --git a/mobile-widgets/qml/Settings.qml b/mobile-widgets/qml/Settings.qml index 4d478b119..1391ef08f 100644 --- a/mobile-widgets/qml/Settings.qml +++ b/mobile-widgets/qml/Settings.qml @@ -322,38 +322,42 @@ Kirigami.ScrollablePage { } GridLayout { id: locationService - columns: 2 + columns: 4 width: parent.width - CheckBox { - id: locationCheckbox + Kirigami.Label { + text: qsTr("Run location service") + Layout.preferredWidth: settingsPage.col1Width + settingsPage.col2Width + settingsPage.col3Width + } + Switch { + id: locationButton + Layout.preferredWidth: settingsPage.col4Width visible: manager.locationServiceAvailable checked: manager.locationServiceEnabled onClicked: { manager.locationServiceEnabled = checked } indicator: Rectangle { - implicitWidth: 20 - implicitHeight: 20 - x: locationCheckbox.leftPadding + implicitWidth: Kirigami.Units.largeSpacing * 3 + implicitHeight: Kirigami.Units.largeSpacing + x: locationButton.leftPadding y: parent.height / 2 - height / 2 - radius: 4 - border.color: locationCheckbox.down ? subsurfaceTheme.primaryColor : subsurfaceTheme.darkerPrimaryColor - color: subsurfaceTheme.backgroundColor + radius: Kirigami.Units.largeSpacing * 0.5 + color: locationButton.checked ? + subsurfaceTheme.lightPrimaryColor : subsurfaceTheme.backgroundColor + border.color: subsurfaceTheme.darkerPrimaryColor Rectangle { - width: 12 - height: 12 - x: 4 - y: 4 - radius: 3 - color: locationCheckbox.down ? subsurfaceTheme.primaryColor : subsurfaceTheme.darkerPrimaryColor - visible: locationCheckbox.checked + x: locationButton.checked ? parent.width - width : 0 + y: parent.height / 2 - height / 2 + width: Kirigami.Units.largeSpacing * 1.5 + height: Kirigami.Units.largeSpacing * 1.5 + radius: height / 2 + color: locationButton.down || locationButton.checked ? + subsurfaceTheme.primaryColor : subsurfaceTheme.lightPrimaryColor + border.color: subsurfaceTheme.darkerPrimaryColor } } } - Kirigami.Label { - text: qsTr("Run location service") - } } GridLayout { id: libdclogprefs @@ -404,7 +408,7 @@ Kirigami.ScrollablePage { } GridLayout { id: developer - columns: 2 + columns: 4 width: parent.width - Kirigami.Units.gridUnit Kirigami.Heading { text: qsTr("Developer") @@ -412,38 +416,42 @@ Kirigami.ScrollablePage { level: 4 Layout.topMargin: Kirigami.Units.largeSpacing Layout.bottomMargin: Kirigami.Units.largeSpacing / 2 - Layout.columnSpan: 2 + Layout.columnSpan: 4 } - CheckBox { + Kirigami.Label { + text: qsTr("Display Developer menu") + Layout.preferredWidth: settingsPage.col1Width + settingsPage.col2Width + settingsPage.col3Width + } + Switch { id: developerButton checked: manager.developer + Layout.preferredWidth: settingsPage.col4Width onClicked: { manager.developer = checked } indicator: Rectangle { - implicitWidth: 20 - implicitHeight: 20 + implicitWidth: Kirigami.Units.largeSpacing * 3 + implicitHeight: Kirigami.Units.largeSpacing x: developerButton.leftPadding y: parent.height / 2 - height / 2 - radius: 4 - border.color: developerButton.down ? subsurfaceTheme.primaryColor : subsurfaceTheme.darkerPrimaryColor - color: subsurfaceTheme.backgroundColor + radius: Kirigami.Units.largeSpacing * 0.5 + color: developerButton.checked ? + subsurfaceTheme.lightPrimaryColor : subsurfaceTheme.backgroundColor + border.color: subsurfaceTheme.darkerPrimaryColor Rectangle { - width: 12 - height: 12 - x: 4 - y: 4 - radius: 3 - color: developerButton.down ? subsurfaceTheme.primaryColor : subsurfaceTheme.darkerPrimaryColor - visible: developerButton.checked + x: developerButton.checked ? parent.width - width : 0 + y: parent.height / 2 - height / 2 + width: Kirigami.Units.largeSpacing * 1.5 + height: Kirigami.Units.largeSpacing * 1.5 + radius: height / 2 + color: developerButton.down || developerButton.checked ? + subsurfaceTheme.primaryColor : subsurfaceTheme.lightPrimaryColor + border.color: subsurfaceTheme.darkerPrimaryColor } } } - Kirigami.Label { - text: qsTr("Display Developer menu") - } } Item { height: Kirigami.Units.gridUnit * 6 |