forked from Shinonome/dots-hyprland
63 lines
1.9 KiB
QML
63 lines
1.9 KiB
QML
import "root:/modules/common"
|
|
import "root:/modules/common/widgets/"
|
|
import "root:/modules/common/functions/color_utils.js" as ColorUtils
|
|
import QtQuick
|
|
import QtQuick.Controls
|
|
import QtQuick.Layouts
|
|
import Quickshell
|
|
import Quickshell.Io
|
|
|
|
RippleButton {
|
|
id: button
|
|
|
|
property string buttonIcon
|
|
property string buttonText
|
|
property bool keyboardDown: false
|
|
property real size: 120
|
|
|
|
buttonRadius: (button.focus || button.down) ? size / 2 : Appearance.rounding.verylarge
|
|
colBackground: button.keyboardDown ? Appearance.colors.colSecondaryContainerActive :
|
|
button.focus ? Appearance.m3colors.m3primary :
|
|
Appearance.m3colors.m3secondaryContainer
|
|
colBackgroundHover: Appearance.m3colors.m3primary
|
|
colRipple: Appearance.colors.colPrimaryActive
|
|
property color colText: (button.down || button.keyboardDown || button.focus || button.hovered) ?
|
|
Appearance.m3colors.m3onPrimary : Appearance.colors.colOnLayer0
|
|
|
|
Layout.alignment: Qt.AlignHCenter | Qt.AlignVCenter
|
|
background.implicitHeight: size
|
|
background.implicitWidth: size
|
|
|
|
Behavior on buttonRadius {
|
|
animation: Appearance.animation.elementMoveFast.numberAnimation.createObject(this)
|
|
}
|
|
|
|
Keys.onPressed: (event) => {
|
|
if (event.key === Qt.Key_Return || event.key === Qt.Key_Enter) {
|
|
keyboardDown = true
|
|
button.clicked()
|
|
event.accepted = true;
|
|
}
|
|
}
|
|
Keys.onReleased: (event) => {
|
|
if (event.key === Qt.Key_Return || event.key === Qt.Key_Enter) {
|
|
keyboardDown = false
|
|
event.accepted = true;
|
|
}
|
|
}
|
|
|
|
contentItem: MaterialSymbol {
|
|
id: icon
|
|
anchors.fill: parent
|
|
color: button.colText
|
|
horizontalAlignment: Text.AlignHCenter
|
|
iconSize: 45
|
|
text: buttonIcon
|
|
}
|
|
|
|
StyledToolTip {
|
|
content: buttonText
|
|
}
|
|
|
|
}
|