import QtQuick 2.12 import QtQuick.Layouts 1.12 HButton { id: tile signal activated() property HListView view: ListView.view property bool shouldBeCurrent: false readonly property var delegateModel: model default property var additionalItems: [] readonly property alias title: title readonly property alias additionalInfo: additionalInfo readonly property alias rightInfo: rightInfo readonly property alias subtitle: subtitle property HMenu contextMenu: HMenu {} property Item image property Item details: HColumnLayout { Layout.fillWidth: true HRowLayout { spacing: tile.spacing HLabel { id: title text: "Missing title" elide: Text.ElideRight verticalAlignment: Qt.AlignVCenter Layout.fillWidth: true } HRowLayout { id: additionalInfo } HLabel { id: rightInfo font.pixelSize: theme.fontSize.small visible: Layout.maximumWidth > 0 Layout.maximumWidth: text && tile.width >= 200 ? implicitWidth : 0 Behavior on Layout.maximumWidth { HNumberAnimation {} } } } HRichLabel { id: subtitle textFormat: Text.StyledText font.pixelSize: theme.fontSize.small elide: Text.ElideRight visible: Layout.maximumHeight > 0 Layout.maximumHeight: text ? implicitWidth : 0 Layout.fillWidth: true Behavior on Layout.maximumHeight { HNumberAnimation {} } } } contentItem: HRowLayout { spacing: tile.spacing children: [image, details].concat(additionalItems) } onActivated: view.currentIndex = model.index Timer { interval: 100 repeat: true // running: true // Component.onCompleted won't work for this onTriggered: if (shouldBeCurrent) view.currentIndex = model.index } TapHandler { acceptedButtons: Qt.LeftButton onTapped: { view.highlightRangeMode = ListView.NoHighlightRange view.highlightMoveDuration = 0 activated() view.highlightRangeMode = ListView.ApplyRange view.highlightMoveDuration = theme.animationDuration } } TapHandler { acceptedButtons: Qt.RightButton onTapped: if (contextMenu.count > 0) contextMenu.popup() } TapHandler { acceptedButtons: Qt.LeftButton | Qt.RightButton onLongPressed: if (contextMenu.count > 0) contextMenu.popup() } }