import "../services" import qs.components import qs.services import qs.config import QtQuick Item { id: root required property M3Variants.Variant modelData required property var list implicitHeight: Config.launcher.sizes.itemHeight anchors.left: parent?.left anchors.right: parent?.right StateLayer { radius: Appearance.rounding.normal 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 MaterialIcon { id: icon text: root.modelData?.icon ?? "" font.pointSize: Appearance.font.size.extraLarge anchors.verticalCenter: parent.verticalCenter } Column { anchors.left: icon.right anchors.leftMargin: Appearance.spacing.larger anchors.verticalCenter: icon.verticalCenter width: parent.width - icon.width - anchors.leftMargin - (current.active ? current.width + Appearance.spacing.normal : 0) spacing: 0 StyledText { text: root.modelData?.name ?? "" font.pointSize: Appearance.font.size.normal } StyledText { text: root.modelData?.description ?? "" font.pointSize: Appearance.font.size.small color: Colours.palette.m3outline elide: Text.ElideRight anchors.left: parent.left anchors.right: parent.right } } Loader { id: current anchors.right: parent.right anchors.verticalCenter: parent.verticalCenter active: root.modelData?.variant === Schemes.currentVariant asynchronous: true sourceComponent: MaterialIcon { text: "check" color: Colours.palette.m3onSurfaceVariant font.pointSize: Appearance.font.size.large } } } }