94 lines
2.5 KiB
QML
94 lines
2.5 KiB
QML
import "root:/widgets"
|
|
import "root:/services"
|
|
import "root:/config"
|
|
import Quickshell
|
|
import Quickshell.Widgets
|
|
import QtQuick
|
|
|
|
Item {
|
|
id: root
|
|
|
|
required property Schemes.Scheme modelData
|
|
required property var list
|
|
|
|
implicitHeight: Config.launcher.sizes.itemHeight
|
|
|
|
anchors.left: parent?.left
|
|
anchors.right: parent?.right
|
|
|
|
StateLayer {
|
|
radius: Appearance.rounding.full
|
|
|
|
function onClicked(): void {
|
|
root.modelData?.onClicked(root.list);
|
|
}
|
|
}
|
|
|
|
Item {
|
|
anchors.fill: parent
|
|
anchors.leftMargin: Appearance.padding.larger
|
|
anchors.rightMargin: Appearance.padding.larger
|
|
anchors.margins: Appearance.padding.smaller
|
|
|
|
StyledRect {
|
|
id: preview
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
border.width: 1
|
|
border.color: Qt.alpha(`#${root.modelData?.colours?.outline}`, 0.5)
|
|
|
|
color: `#${root.modelData?.colours?.surface}`
|
|
radius: Appearance.rounding.full
|
|
implicitWidth: parent.height * 0.8
|
|
implicitHeight: parent.height * 0.8
|
|
|
|
Item {
|
|
anchors.top: parent.top
|
|
anchors.bottom: parent.bottom
|
|
anchors.right: parent.right
|
|
|
|
implicitWidth: parent.implicitWidth / 2
|
|
clip: true
|
|
|
|
StyledRect {
|
|
anchors.top: parent.top
|
|
anchors.bottom: parent.bottom
|
|
anchors.right: parent.right
|
|
|
|
implicitWidth: preview.implicitWidth
|
|
color: `#${root.modelData?.colours?.primary}`
|
|
radius: Appearance.rounding.full
|
|
}
|
|
}
|
|
}
|
|
|
|
Column {
|
|
anchors.left: preview.right
|
|
anchors.leftMargin: Appearance.spacing.normal
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
width: parent.width - preview.width
|
|
spacing: 0
|
|
|
|
StyledText {
|
|
id: name
|
|
|
|
text: root.modelData?.name ?? ""
|
|
font.pointSize: Appearance.font.size.normal
|
|
}
|
|
|
|
StyledText {
|
|
id: comment
|
|
|
|
text: root.modelData?.flavour ?? ""
|
|
font.pointSize: Appearance.font.size.small
|
|
color: Colours.palette.m3outline
|
|
|
|
elide: Text.ElideRight
|
|
width: parent.width - Appearance.rounding.normal * 2
|
|
}
|
|
}
|
|
}
|
|
}
|