Files
illogical-impulse/dots/.config/quickshell/ii/modules/sidebarLeft/ScrollToBottomButton.qml
T
2025-10-17 18:00:11 +02:00

58 lines
1.7 KiB
QML

import qs.services
import qs.modules.common
import qs.modules.common.widgets
import QtQuick
import QtQuick.Layouts
RippleButton {
id: root
required property ListView target
anchors {
bottom: parent.bottom
horizontalCenter: parent.horizontalCenter
bottomMargin: 10
}
opacity: !target.atYEnd ? 1 : 0
scale: !target.atYEnd ? 1 : 0.7
visible: opacity > 0
Behavior on opacity {
animation: Appearance.animation.elementMoveFast.numberAnimation.createObject(this)
}
Behavior on scale {
animation: Appearance.animation.elementResize.numberAnimation.createObject(this)
}
implicitWidth: contentItem.implicitWidth + 8 * 2
implicitHeight: contentItem.implicitHeight + 4 * 2
colBackground: Appearance.colors.colSecondary
colBackgroundHover: Appearance.colors.colSecondaryHover
colRipple: Appearance.colors.colSecondaryActive
buttonRadius: Appearance.rounding.verysmall
downAction: () => {
target.positionViewAtEnd()
}
contentItem: Row {
id: contentItem
spacing: 4
MaterialSymbol {
anchors.verticalCenter: parent.verticalCenter
text: "arrow_downward"
font.pixelSize: Appearance.font.pixelSize.larger
color: Appearance.colors.colOnSecondary
verticalAlignment: Text.AlignVCenter
}
StyledText {
anchors.verticalCenter: parent.verticalCenter
text: Translation.tr("Scroll to Bottom")
font.pixelSize: Appearance.font.pixelSize.smallie
color: Appearance.colors.colOnSecondary
verticalAlignment: Text.AlignVCenter
}
}
}