2024-12-28 20:41:18 +01:00
|
|
|
#!/usr/bin/python3
|
|
|
|
|
2025-01-25 11:58:34 +01:00
|
|
|
from PyQt6.QtCore import pyqtSignal
|
2025-01-25 17:21:43 +01:00
|
|
|
from PyQt6.QtGui import QDropEvent, QIcon
|
2025-01-25 11:58:34 +01:00
|
|
|
from PyQt6.QtWidgets import QTreeWidget, QAbstractItemView
|
2025-01-25 22:41:29 +01:00
|
|
|
|
2025-01-25 17:21:43 +01:00
|
|
|
from .track import TrackItem
|
2024-12-28 20:41:18 +01:00
|
|
|
|
|
|
|
|
|
|
|
class PlaylistView(QTreeWidget):
|
2025-01-25 11:58:34 +01:00
|
|
|
itemDropped = pyqtSignal(QTreeWidget, list)
|
|
|
|
|
|
|
|
def __init__(self, playlist, parent=None):
|
|
|
|
super().__init__(parent)
|
|
|
|
|
|
|
|
self.playlist = playlist
|
2025-01-25 17:21:43 +01:00
|
|
|
self.app = playlist.app
|
|
|
|
|
|
|
|
playlist.view = self
|
2025-01-25 11:58:34 +01:00
|
|
|
|
|
|
|
self.setDragDropMode(QAbstractItemView.DragDropMode.InternalMove)
|
|
|
|
self.setSelectionMode(QAbstractItemView.SelectionMode.ExtendedSelection)
|
2024-12-28 20:41:18 +01:00
|
|
|
|
2024-12-29 18:55:55 +01:00
|
|
|
self.setColumnCount(4)
|
2024-12-28 20:41:18 +01:00
|
|
|
|
2025-01-26 13:51:31 +01:00
|
|
|
self.playing_mark = QIcon.fromTheme(QIcon.ThemeIcon.MediaPlaybackStart)
|
2025-01-25 17:21:43 +01:00
|
|
|
|
2024-12-28 20:41:18 +01:00
|
|
|
headers = [
|
2024-12-29 18:55:55 +01:00
|
|
|
"",
|
2024-12-28 20:41:18 +01:00
|
|
|
"#",
|
|
|
|
"Title",
|
|
|
|
"Artist",
|
2024-12-29 15:10:51 +01:00
|
|
|
"Album",
|
|
|
|
"# Custom Sorting"
|
2024-12-28 20:41:18 +01:00
|
|
|
]
|
|
|
|
|
2025-01-25 11:58:34 +01:00
|
|
|
self.setHeaderLabels(headers)
|
|
|
|
|
2025-01-25 17:21:43 +01:00
|
|
|
self.load_tracks()
|
|
|
|
|
|
|
|
self.itemActivated.connect(self.on_track_activation)
|
|
|
|
|
2025-01-25 18:04:46 +01:00
|
|
|
def on_user_sort(self):
|
|
|
|
num_tracks = self.topLevelItemCount()
|
|
|
|
|
|
|
|
i = 0
|
|
|
|
|
|
|
|
while i < num_tracks:
|
|
|
|
track_item = self.topLevelItem(i)
|
|
|
|
track = track_item.track
|
|
|
|
|
|
|
|
track_item.index_user_sort = i
|
2025-01-26 16:49:09 +01:00
|
|
|
track_item.index = i
|
|
|
|
|
2025-01-25 18:04:46 +01:00
|
|
|
track_item.setText(5, str(i + 1))
|
|
|
|
|
|
|
|
self.playlist.tracks[i] = track
|
|
|
|
|
2025-01-26 16:49:09 +01:00
|
|
|
track.set_occurrences()
|
|
|
|
|
2025-01-25 18:04:46 +01:00
|
|
|
i += 1
|
|
|
|
|
2025-01-26 16:49:09 +01:00
|
|
|
if self.app.player.current_playlist.has_tracks():
|
|
|
|
self.app.player.cache_next_track()
|
2025-01-25 11:58:34 +01:00
|
|
|
|
|
|
|
def dropEvent(self, event: QDropEvent):
|
2025-01-25 22:41:29 +01:00
|
|
|
# receive items that were dropped and create new items from its tracks (new items bc. widgets can only have
|
|
|
|
# one parent)
|
|
|
|
if event.source() == self:
|
|
|
|
items = self.selectedItems() # dragged items are always selected items
|
|
|
|
|
|
|
|
self.itemDropped.emit(self, items)
|
|
|
|
|
|
|
|
else:
|
|
|
|
items = self.app.gui.dropped
|
|
|
|
|
|
|
|
i = 0
|
|
|
|
|
|
|
|
for item in items:
|
|
|
|
track = item.track
|
2025-01-25 11:58:34 +01:00
|
|
|
|
2025-01-25 22:59:19 +01:00
|
|
|
self.playlist.tracks.append(track)
|
|
|
|
|
2025-01-25 22:41:29 +01:00
|
|
|
track_item = TrackItem(track, i, self)
|
|
|
|
|
|
|
|
i += 1
|
2025-01-25 11:58:34 +01:00
|
|
|
|
|
|
|
super().dropEvent(event)
|
|
|
|
|
2025-01-25 22:41:29 +01:00
|
|
|
event.accept()
|
|
|
|
|
2025-01-25 22:59:19 +01:00
|
|
|
self.on_user_sort()
|
|
|
|
|
2025-01-25 22:41:29 +01:00
|
|
|
def dragEnterEvent(self, event):
|
|
|
|
# store dragged items in gui.dropped, so the other playlist can receive it
|
|
|
|
if event.source() == self:
|
|
|
|
items = self.selectedItems()
|
|
|
|
|
|
|
|
self.app.gui.dropped = items
|
|
|
|
|
|
|
|
super().dragEnterEvent(event)
|
2025-01-25 18:04:46 +01:00
|
|
|
|
2025-01-25 11:58:34 +01:00
|
|
|
event.accept()
|
|
|
|
|
2025-01-25 17:21:43 +01:00
|
|
|
def load_tracks(self):
|
2025-01-25 18:04:46 +01:00
|
|
|
i = 0
|
|
|
|
|
2025-01-25 17:21:43 +01:00
|
|
|
for track in self.playlist.tracks:
|
2025-01-25 18:04:46 +01:00
|
|
|
track_item = TrackItem(track, i, self)
|
|
|
|
|
|
|
|
i += 1
|
2025-01-25 17:21:43 +01:00
|
|
|
|
|
|
|
def on_track_activation(self, item, column):
|
2025-01-25 22:59:19 +01:00
|
|
|
if not self.app.player.current_playlist == self.playlist:
|
|
|
|
self.app.player.current_playlist = self.playlist
|
|
|
|
|
2025-01-25 17:21:43 +01:00
|
|
|
index = self.indexOfTopLevelItem(item)
|
|
|
|
self.app.player.play_track_in_playlist(index)
|
|
|
|
|
|
|
|
def on_track_change(self, previous_track, track):
|
2025-01-26 13:51:31 +01:00
|
|
|
# remove playing mark from first track bc it may not be in the history
|
2025-01-26 16:49:09 +01:00
|
|
|
#self.topLevelItem(0).setIcon(0, QIcon(None))
|
2025-01-26 13:51:31 +01:00
|
|
|
|
2025-01-25 17:21:43 +01:00
|
|
|
# unmark the previous track and mark the current track as playing
|
|
|
|
if previous_track:
|
2025-01-26 16:49:09 +01:00
|
|
|
for item in previous_track.items:
|
|
|
|
item.setIcon(0, QIcon(None))
|
2025-01-25 17:21:43 +01:00
|
|
|
|
|
|
|
if track:
|
2025-01-26 16:49:09 +01:00
|
|
|
item = self.topLevelItem(self.app.player.current_playlist.current_track_index)
|
|
|
|
item.setIcon(0, self.playing_mark)
|
2025-01-26 13:51:31 +01:00
|
|
|
|
|
|
|
def append_track(self, track):
|
|
|
|
TrackItem(track, self.topLevelItemCount() - 1, self)
|
2025-01-25 17:21:43 +01:00
|
|
|
|