File: SongListDelegate.qml

package info (click to toggle)
qt6-declarative 6.9.1%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 308,920 kB
  • sloc: cpp: 775,911; javascript: 514,247; xml: 10,855; python: 2,806; ansic: 2,253; java: 810; sh: 262; makefile: 41; php: 27
file content (93 lines) | stat: -rw-r--r-- 3,016 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
// Copyright (C) 2025 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause

import QtQuick
import QtQuick.Controls.Universal

MouseArea {
    id: delegateRoot
    signal songSelected(albumName: string, albumArt: string, artistName: string, songTitle: string)

    implicitHeight: 60
    enabled: model.albumArt !== ""
    onClicked: songSelected(model.album, model.albumArt, model.artist, model.song)
    BusyIndicator {
        id: loadingIndicator
        anchors.verticalCenter: parent.verticalCenter
        anchors.right: loadingText.left
        anchors.rightMargin: 5
        height: loadingText.implicitHeight
        width: height
        running: model.loadingText === "" && model.isLoadingElement
    }
    Text {
        id: loadingText
        anchors.centerIn: parent
        font.pixelSize: delegateRoot.implicitHeight / 4
        text: model.loadingText === "" ? qsTr("Loading...") : model.loadingText
        visible: model.isLoadingElement
    }
    Item {
        anchors.fill: parent
        visible: !loadingIndicator.running
        Image {
            id: albumArtImage
            anchors.left: parent.left
            anchors.top: parent.top
            anchors.bottom: parent.bottom
            anchors.leftMargin: 1
            anchors.topMargin: 1
            anchors.bottomMargin: 1
            source: model.albumArt
            width: height
            fillMode: Image.PreserveAspectCrop
        }
        Text {
            id: artistName
            anchors.left: albumArtImage.right
            anchors.right: parent.right
            anchors.top: parent.top
            anchors.topMargin: 1
            anchors.leftMargin: 1
            anchors.rightMargin: 1
            font.pixelSize: delegateRoot.implicitHeight / 5
            text: model.artist
        }
        Text {
            id: songName
            anchors.left: albumArtImage.right
            anchors.right: parent.right
            anchors.top: artistName.bottom
            anchors.topMargin: 1
            anchors.leftMargin: 1
            anchors.rightMargin: 1
            font.pixelSize: delegateRoot.implicitHeight / 4
            text: model.song
        }
        Text {
            id: albumName
            anchors.left: albumArtImage.right
            anchors.right: parent.right
            anchors.top: songName.bottom
            anchors.topMargin: 1
            anchors.leftMargin: 1
            anchors.rightMargin: 1
            font.pixelSize: delegateRoot.implicitHeight / 5
            text: model.album
        }
    }
    Rectangle {
        anchors.left: parent.left
        anchors.right: parent.right
        anchors.bottom: parent.bottom
        implicitHeight: 1
        color: "lightgray"
    }
    Text {
        anchors.right: parent.right
        anchors.rightMargin: delegateRoot.implicitHeight / 2
        anchors.verticalCenter: parent.verticalCenter
        font.pixelSize: delegateRoot.implicitHeight / 4
        text: "#"+(index+1)
    }
}