/* Fannyapp - Application to view the cover plan of the Fanny-Leicht-Gymnasium ins Stuttgart Vaihingen, Germany Copyright (C) 2019 Itsblue Development This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see . */ import QtQuick 2.0 import QtQuick.Controls 2.4 import "../Components" Page { id: root title: "Einstellungen" signal opened() property bool locked: false onOpened: {} Column { id: settingsCol anchors.fill: parent SettingsDelegate { width: parent.width onClicked: { formStack.push(filterForm) } title: "Filter" description: "Wähle die Klassen(stufen) bzw. Lehrerkürzel aus, für die du den Vertretungsplan ansehen möchtest" } SwitchDelegate { width: parent.width height: 10 + shortDescription.height + 2 + longDescription.height + 10 checked: _cppAppSettings.loadSetting("teacherMode") === "true" onCheckedChanged: { _cppAppSettings.writeSetting("teacherMode", checked) } Label { id: shortDescription anchors { top: parent.top left: parent.left margins: 10 } font.pixelSize: longDescription.font.pixelSize * 1.4 text: "Lehrermodus" color: app.style.style.textColor } Label { id: longDescription anchors { top: shortDescription.bottom topMargin: 2 left: parent.left leftMargin: 10 } width: parent.width * 0.9 wrapMode: Label.Wrap text: "Lehrermodus aktivieren" color: app.style.style.textColor } indicator: Rectangle { property bool checked: parent.checked property bool down: parent.down property int set_height: parent.font.pixelSize * 1.4 implicitWidth: set_height * 1.84 implicitHeight: set_height x: parent.width - width - parent.rightPadding y: parent.height / 2 - height / 2 radius: implicitHeight * 0.5 color: parent.checked ? "#17a81a" : "transparent" border.color: parent.checked ? "#17a81a" : "#cccccc" Behavior on color{ ColorAnimation{ duration: 200 } } Rectangle { x: parent.checked ? parent.width - width : 0 width: parent.height height: parent.height radius: height * 0.5 color: parent.down ? "#cccccc" : "#ffffff" border.color: parent.checked ? (parent.down ? "#17a81a" : "#21be2b") : "#999999" Behavior on x{ NumberAnimation { property: "x" duration: 200 easing.type: Easing.InOutQuad } } } } } SwitchDelegate { width: parent.width height: 10 + shortDescription_.height + 2 + longDescription_.height + 10 checked: _cppAppSettings.loadSetting("theme") === "Dark" onCheckedChanged: { _cppAppSettings.writeSetting("theme", checked ? "Dark":"Light") app.style.refreshTheme() } Label { id: shortDescription_ anchors { top: parent.top left: parent.left margins: 10 } font.pixelSize: longDescription_.font.pixelSize * 1.4 text: "Dunkler Modus" color: app.style.style.textColor } Label { id: longDescription_ anchors { top: shortDescription_.bottom topMargin: 2 left: parent.left leftMargin: 10 } width: parent.width * 0.9 wrapMode: Label.Wrap text: "Dunklen Modus aktivieren" color: app.style.style.textColor } indicator: Rectangle { property bool checked: parent.checked property bool down: parent.down property int set_height: parent.font.pixelSize * 1.4 implicitWidth: set_height * 1.84 implicitHeight: set_height x: parent.width - width - parent.rightPadding y: parent.height / 2 - height / 2 radius: implicitHeight * 0.5 color: parent.checked ? "#17a81a" : "transparent" border.color: parent.checked ? "#17a81a" : "#cccccc" Behavior on color{ ColorAnimation{ duration: 200 } } Rectangle { x: parent.checked ? parent.width - width : 0 width: parent.height height: parent.height radius: height * 0.5 color: parent.down ? "#cccccc" : "#ffffff" border.color: parent.checked ? (parent.down ? "#17a81a" : "#21be2b") : "#999999" Behavior on x{ NumberAnimation { property: "x" duration: 200 easing.type: Easing.InOutQuad } } } } } } }