mirror of
https://github.com/LinuxBeginnings/simple-sddm-2.git
synced 2026-01-12 07:21:01 -03:00
150 lines
4.4 KiB
QML
150 lines
4.4 KiB
QML
// Config created by Keyitdev https://github.com/Keyitdev/sddm-astronaut-theme
|
|
// Copyright (C) 2022-2025 Keyitdev
|
|
// Based on https://github.com/MarianArlt/sddm-sugar-dark
|
|
// Distributed under the GPLv3+ License https://www.gnu.org/licenses/gpl-3.0.html
|
|
|
|
import QtQuick 2.15
|
|
import QtQuick.Controls 2.15
|
|
|
|
Item {
|
|
id: sessionButton
|
|
|
|
height: root.font.pointSize
|
|
width: parent.width / 2
|
|
|
|
property var selectedSession: selectSession.currentIndex
|
|
property string textConstantSession
|
|
property int loginButtonWidth
|
|
property ComboBox exposeSession: selectSession
|
|
|
|
ComboBox {
|
|
id: selectSession
|
|
|
|
// important
|
|
// change also in errorMessage
|
|
height: root.font.pointSize * 2
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
hoverEnabled: true
|
|
model: sessionModel
|
|
currentIndex: model.lastIndex
|
|
textRole: "name"
|
|
|
|
Keys.onPressed: function(event) {
|
|
if ((event.key == Qt.Key_Left || event.key == Qt.Key_Right) && !popup.opened) {
|
|
popup.open();
|
|
}
|
|
}
|
|
|
|
delegate: ItemDelegate {
|
|
// minus padding
|
|
width: popupHandler.width - 20
|
|
anchors.horizontalCenter: popupHandler.horizontalCenter
|
|
|
|
contentItem: Text {
|
|
verticalAlignment: Text.AlignVCenter
|
|
horizontalAlignment: Text.AlignHCenter
|
|
|
|
text: model.name
|
|
font.pointSize: root.font.pointSize * 0.8
|
|
font.family: root.font.family
|
|
color: config.DropdownTextColor
|
|
}
|
|
|
|
background: Rectangle {
|
|
color: selectSession.highlightedIndex === index ? config.DropdownSelectedBackgroundColor : "transparent"
|
|
}
|
|
}
|
|
|
|
indicator {
|
|
visible: false
|
|
}
|
|
|
|
contentItem: Text {
|
|
id: displayedItem
|
|
|
|
verticalAlignment: Text.AlignVCenter
|
|
|
|
text: (config.TranslateSessionSelection || "Session") + " (" + selectSession.currentText + ")"
|
|
color: config.SessionButtonTextColor
|
|
font.pointSize: root.font.pointSize * 0.8
|
|
font.family: root.font.family
|
|
|
|
Keys.onReleased: parent.popup.open()
|
|
}
|
|
|
|
background: Rectangle {
|
|
height: parent.visualFocus ? 2 : 0
|
|
width: displayedItem.implicitWidth
|
|
|
|
color: "transparent"
|
|
}
|
|
|
|
popup: Popup {
|
|
id: popupHandler
|
|
|
|
implicitHeight: contentItem.implicitHeight
|
|
width: sessionButton.width
|
|
y: parent.height - 1
|
|
x: -popupHandler.width/2 + displayedItem.width/2
|
|
padding: 10
|
|
|
|
contentItem: ListView {
|
|
implicitHeight: contentHeight + 20
|
|
|
|
clip: true
|
|
model: selectSession.popup.visible ? selectSession.delegateModel : null
|
|
currentIndex: selectSession.highlightedIndex
|
|
ScrollIndicator.vertical: ScrollIndicator { }
|
|
}
|
|
|
|
background: Rectangle {
|
|
radius: config.RoundCorners / 2
|
|
color: config.DropdownBackgroundColor
|
|
layer.enabled: true
|
|
}
|
|
|
|
enter: Transition {
|
|
NumberAnimation { property: "opacity"; from: 0; to: 1 }
|
|
}
|
|
}
|
|
|
|
states: [
|
|
State {
|
|
name: "pressed"
|
|
when: selectSession.down
|
|
PropertyChanges {
|
|
target: displayedItem
|
|
color: Qt.darker(config.HoverSessionButtonTextColor, 1.1)
|
|
}
|
|
},
|
|
State {
|
|
name: "hovered"
|
|
when: selectSession.hovered
|
|
PropertyChanges {
|
|
target: displayedItem
|
|
color: Qt.lighter(config.HoverSessionButtonTextColor, 1.1)
|
|
}
|
|
},
|
|
State {
|
|
name: "focused"
|
|
when: selectSession.visualFocus
|
|
PropertyChanges {
|
|
target: displayedItem
|
|
color: config.HoverSessionButtonTextColor
|
|
}
|
|
}
|
|
]
|
|
transitions: [
|
|
Transition {
|
|
PropertyAnimation {
|
|
properties: "color"
|
|
duration: 150
|
|
}
|
|
}
|
|
]
|
|
|
|
}
|
|
|
|
}
|