1
0
mirror of https://github.com/strawberrymusicplayer/strawberry synced 2025-01-24 06:33:41 +01:00

Playlist: Fix tag inline editing for steams

Fixes #1130
This commit is contained in:
Jonas Kvinge 2023-02-10 22:49:57 +01:00
parent 384e7dedb5
commit 3d4c98d981

View File

@ -400,7 +400,7 @@ bool Playlist::setData(const QModelIndex &idx, const QVariant &value, int role)
QPersistentModelIndex persistent_index = QPersistentModelIndex(idx); QPersistentModelIndex persistent_index = QPersistentModelIndex(idx);
QObject::connect(reply, &TagReaderReply::Finished, this, [this, reply, persistent_index, item]() { SongSaveComplete(reply, persistent_index, item->OriginalMetadata()); }, Qt::QueuedConnection); QObject::connect(reply, &TagReaderReply::Finished, this, [this, reply, persistent_index, item]() { SongSaveComplete(reply, persistent_index, item->OriginalMetadata()); }, Qt::QueuedConnection);
} }
else if (song.source() == Song::Source_Stream) { else if (song.is_radio()) {
item->SetMetadata(song); item->SetMetadata(song);
ScheduleSave(); ScheduleSave();
} }
@ -1135,6 +1135,7 @@ void Playlist::InsertSongsOrCollectionItems(const SongList &songs, const int pos
PlaylistItemList items; PlaylistItemList items;
for (const Song &song : songs) { for (const Song &song : songs) {
if (song.url().isLocalFile()) {
if (song.is_collection_song()) { if (song.is_collection_song()) {
items << std::make_shared<CollectionPlaylistItem>(song); items << std::make_shared<CollectionPlaylistItem>(song);
} }
@ -1142,6 +1143,15 @@ void Playlist::InsertSongsOrCollectionItems(const SongList &songs, const int pos
items << std::make_shared<SongPlaylistItem>(song); items << std::make_shared<SongPlaylistItem>(song);
} }
} }
else {
if (song.is_radio()) {
items << std::make_shared<RadioPlaylistItem>(song);
}
else {
items << std::make_shared<InternetPlaylistItem>(song);
}
}
}
InsertItems(items, pos, play_now, enqueue, enqueue_next); InsertItems(items, pos, play_now, enqueue, enqueue_next);
} }
@ -1188,6 +1198,7 @@ void Playlist::UpdateItems(SongList songs) {
const PlaylistItemPtr &item = items_[i]; const PlaylistItemPtr &item = items_[i];
if (item->Metadata().url() == song.url() && (item->Metadata().filetype() == Song::FileType_Unknown || item->Metadata().filetype() == Song::FileType_Stream || item->Metadata().filetype() == Song::FileType_CDDA || !item->Metadata().init_from_file())) { if (item->Metadata().url() == song.url() && (item->Metadata().filetype() == Song::FileType_Unknown || item->Metadata().filetype() == Song::FileType_Stream || item->Metadata().filetype() == Song::FileType_CDDA || !item->Metadata().init_from_file())) {
PlaylistItemPtr new_item; PlaylistItemPtr new_item;
if (song.url().isLocalFile()) {
if (song.is_collection_song()) { if (song.is_collection_song()) {
new_item = std::make_shared<CollectionPlaylistItem>(song); new_item = std::make_shared<CollectionPlaylistItem>(song);
if (collection_items_by_id_.contains(song.id(), item)) collection_items_by_id_.remove(song.id(), item); if (collection_items_by_id_.contains(song.id(), item)) collection_items_by_id_.remove(song.id(), item);
@ -1196,6 +1207,15 @@ void Playlist::UpdateItems(SongList songs) {
else { else {
new_item = std::make_shared<SongPlaylistItem>(song); new_item = std::make_shared<SongPlaylistItem>(song);
} }
}
else {
if (song.is_radio()) {
new_item = std::make_shared<RadioPlaylistItem>(song);
}
else {
new_item = std::make_shared<InternetPlaylistItem>(song);
}
}
items_[i] = new_item; items_[i] = new_item;
emit dataChanged(index(i, 0), index(i, ColumnCount - 1)); emit dataChanged(index(i, 0), index(i, ColumnCount - 1));
// Also update undo actions // Also update undo actions