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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
/*
* Copyright (C) 2013, 2014, 2015, 2016
* Andrew Hayzen <ahayzen@gmail.com>
* Daniel Holm <d.holmen@gmail.com>
* Victor Thompson <victor.thompson@gmail.com>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; version 3.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
import QtQuick 2.4
import Ubuntu.Components 1.3
import Ubuntu.MediaScanner 0.1
import Ubuntu.Thumbnailer 0.1
import QtQuick.LocalStorage 2.0
import "../logic/playlists.js" as Playlists
import "../components"
import "../components/Delegates"
import "../components/Flickables"
import "../components/HeadState"
import "../components/ListItemActions"
MusicPage {
id: songsPage
objectName: "songsPage"
title: i18n.tr("Tracks")
searchable: true
searchResultsCount: songsModelFilter.count
state: "default"
states: [
SearchableHeadState {
thisPage: songsPage
searchEnabled: songsModelFilter.count > 0
},
MultiSelectHeadState {
listview: tracklist
thisPage: songsPage
},
SearchHeadState {
id: searchHeader
thisPage: songsPage
}
]
// Hack for autopilot otherwise Albums appears as MusicPage
// due to bug 1341671 it is required that there is a property so that
// qml doesn't optimise using the parent type
property bool bug1341671workaround: true
MultiSelectListView {
id: tracklist
anchors {
bottomMargin: units.gu(2)
fill: parent
topMargin: units.gu(2)
}
objectName: "trackstab-listview"
model: SortFilterModel {
id: songsModelFilter
property alias rowCount: songsModel.rowCount
model: SongsModel {
id: songsModel
store: musicStore
}
sort.property: "title"
sort.order: Qt.AscendingOrder
sortCaseSensitivity: Qt.CaseInsensitive
filter.property: "title"
filter.pattern: new RegExp(searchHeader.query, "i")
filterCaseSensitivity: Qt.CaseInsensitive
}
onStateChanged: {
if (state === "multiselectable") {
songsPage.state = "selection"
} else {
searchHeader.query = "" // force query back to default
songsPage.state = "default"
}
}
delegate: MusicListItem {
id: track
objectName: "tracksPageListItem" + index
imageSource: {"art": model.art}
multiselectable: true
subtitle {
text: model.author
}
title {
objectName: "tracktitle"
text: model.title
}
trailingActions: AddToQueueAndPlaylist {
}
onItemClicked: {
if (songsPage.state === "search") { // only play single track when searching
player.mediaPlayer.playlist.clearWrapper();
player.mediaPlayer.playlist.addItem(Qt.resolvedUrl(songsModelFilter.get(index).filename));
trackQueueClick(0)
} else {
trackClicked(songsModelFilter, index) // play track
}
}
}
}
}
|