2024-07-07 17:38:08 +02:00
|
|
|
|
//
|
|
|
|
|
// This file is part of SDDM Sugar Candy.
|
|
|
|
|
// A theme for the Simple Display Desktop Manager.
|
|
|
|
|
//
|
|
|
|
|
// Copyright (C) 2018–2020 Marian Arlt
|
|
|
|
|
//
|
|
|
|
|
// SDDM Sugar Candy is free software: you can redistribute it and/or modify it
|
|
|
|
|
// under the terms of the GNU General Public License as published by the
|
|
|
|
|
// Free Software Foundation, either version 3 of the License, or any later version.
|
|
|
|
|
//
|
|
|
|
|
// You are required to preserve this and any additional legal notices, either
|
|
|
|
|
// contained in this file or in other files that you received along with
|
|
|
|
|
// SDDM Sugar Candy that refer to the author(s) in accordance with
|
|
|
|
|
// sections §4, §5 and specifically §7b of the GNU General Public License.
|
|
|
|
|
//
|
|
|
|
|
// SDDM Sugar Candy 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 General Public License for more details.
|
|
|
|
|
//
|
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
|
// along with SDDM Sugar Candy. If not, see <https://www.gnu.org/licenses/>
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
import QtQuick 2.11
|
|
|
|
|
import QtQuick.Layouts 1.11
|
|
|
|
|
import QtQuick.Controls 2.4
|
|
|
|
|
|
|
|
|
|
RowLayout {
|
|
|
|
|
|
|
|
|
|
spacing: root.font.pointSize
|
|
|
|
|
|
2024-08-01 02:19:19 +02:00
|
|
|
|
property var suspend: [" ", config.TranslateSuspend || textConstants.suspend, sddm.canSuspend]
|
|
|
|
|
property var hibernate: [" ", config.TranslateHibernate || textConstants.hibernate, sddm.canHibernate]
|
|
|
|
|
property var reboot: [" ", config.TranslateReboot || textConstants.reboot, sddm.canReboot]
|
|
|
|
|
property var shutdown: [" ", config.TranslateShutdown || textConstants.shutdown, sddm.canPowerOff]
|
2024-07-07 17:38:08 +02:00
|
|
|
|
|
|
|
|
|
property Control exposedSession
|
|
|
|
|
|
|
|
|
|
Repeater {
|
|
|
|
|
|
|
|
|
|
id: systemButtons
|
|
|
|
|
model: [suspend, hibernate, reboot, shutdown]
|
|
|
|
|
|
|
|
|
|
RoundButton {
|
|
|
|
|
text: modelData[1]
|
2024-07-31 23:26:26 +02:00
|
|
|
|
font.family: config.Font
|
2024-08-01 02:19:19 +02:00
|
|
|
|
font.pointSize: root.font.pointSize * 4
|
2024-07-07 17:38:08 +02:00
|
|
|
|
Layout.alignment: Qt.AlignHCenter
|
2024-08-01 02:19:19 +02:00
|
|
|
|
// icon.source: modelData ? Qt.resolvedUrl("../Assets/" + modelData[0] + ".svgz") : ""
|
|
|
|
|
// icon.height: 2 * Math.round((root.font.pointSize * 3) / 2)
|
|
|
|
|
// icon.width: 2 * Math.round((root.font.pointSize * 3) / 2)
|
2024-07-07 17:38:08 +02:00
|
|
|
|
display: AbstractButton.TextUnderIcon
|
|
|
|
|
visible: config.ForceHideSystemButtons != "true" && modelData[2]
|
|
|
|
|
hoverEnabled: true
|
|
|
|
|
palette.buttonText: root.palette.text
|
|
|
|
|
background: Rectangle {
|
|
|
|
|
height: 2
|
|
|
|
|
color: "transparent"
|
|
|
|
|
width: parent.width
|
|
|
|
|
border.width: parent.activeFocus ? 1 : 0
|
|
|
|
|
border.color: "transparent"
|
|
|
|
|
anchors.top: parent.bottom
|
|
|
|
|
}
|
|
|
|
|
Keys.onReturnPressed: clicked()
|
|
|
|
|
onClicked: {
|
|
|
|
|
parent.forceActiveFocus()
|
|
|
|
|
index == 0 ? sddm.suspend() : index == 1 ? sddm.hibernate() : index == 2 ? sddm.reboot() : sddm.powerOff()
|
|
|
|
|
}
|
|
|
|
|
KeyNavigation.up: exposedSession
|
|
|
|
|
KeyNavigation.left: parent.children[index-1]
|
|
|
|
|
|
|
|
|
|
states: [
|
|
|
|
|
State {
|
|
|
|
|
name: "pressed"
|
|
|
|
|
when: parent.children[index].down
|
|
|
|
|
PropertyChanges {
|
|
|
|
|
target: parent.children[index]
|
|
|
|
|
palette.buttonText: Qt.darker(root.palette.highlight, 1.1)
|
|
|
|
|
}
|
|
|
|
|
PropertyChanges {
|
|
|
|
|
target: parent.children[index].background
|
|
|
|
|
border.color: Qt.darker(root.palette.highlight, 1.1)
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
State {
|
|
|
|
|
name: "hovered"
|
|
|
|
|
when: parent.children[index].hovered
|
|
|
|
|
PropertyChanges {
|
|
|
|
|
target: parent.children[index]
|
|
|
|
|
palette.buttonText: Qt.lighter(root.palette.highlight, 1.1)
|
|
|
|
|
}
|
|
|
|
|
PropertyChanges {
|
|
|
|
|
target: parent.children[index].background
|
|
|
|
|
border.color: Qt.lighter(root.palette.highlight, 1.1)
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
State {
|
|
|
|
|
name: "focused"
|
|
|
|
|
when: parent.children[index].activeFocus
|
|
|
|
|
PropertyChanges {
|
|
|
|
|
target: parent.children[index]
|
|
|
|
|
palette.buttonText: root.palette.highlight
|
|
|
|
|
}
|
|
|
|
|
PropertyChanges {
|
|
|
|
|
target: parent.children[index].background
|
|
|
|
|
border.color: root.palette.highlight
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
transitions: [
|
|
|
|
|
Transition {
|
|
|
|
|
PropertyAnimation {
|
|
|
|
|
properties: "palette.buttonText, border.color"
|
|
|
|
|
duration: 150
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|