1
0
mirror of https://github.com/clementine-player/Clementine synced 2025-01-21 06:13:29 +01:00

Connect up signals for queuing tracks so that the view is updated correctly.

Fixes issue #548
This commit is contained in:
John Maguire 2010-07-26 15:53:06 +00:00
parent b3d3bca314
commit 14dd723e3a
2 changed files with 16 additions and 5 deletions

View File

@ -78,6 +78,10 @@ Playlist::Playlist(PlaylistBackend* backend, TaskManager* task_manager,
connect(queue_, SIGNAL(rowsAboutToBeRemoved(QModelIndex,int,int)),
SLOT(TracksAboutToBeDequeued(QModelIndex,int,int)));
connect(queue_, SIGNAL(rowsRemoved(QModelIndex,int,int)), SLOT(TracksDequeued()));
connect(queue_, SIGNAL(rowsInserted(const QModelIndex&, int, int)),
SLOT(TracksEnqueued(const QModelIndex&, int, int)));
connect(queue_, SIGNAL(layoutChanged()), SLOT(QueueLayoutChanged()));
}
@ -1103,20 +1107,26 @@ PlaylistItemList Playlist::library_items_by_id(int id) const {
void Playlist::TracksAboutToBeDequeued(const QModelIndex&, int begin, int end) {
for (int i=begin ; i<=end ; ++i) {
temp_queue_change_indexes_ << queue_->mapToSource(queue_->index(i, Column_Title));
temp_dequeue_change_indexes_ << queue_->mapToSource(queue_->index(i, Column_Title));
}
}
void Playlist::TracksDequeued() {
foreach (const QModelIndex& index, temp_queue_change_indexes_) {
foreach (const QModelIndex& index, temp_dequeue_change_indexes_) {
emit dataChanged(index, index);
}
temp_queue_change_indexes_.clear();
temp_dequeue_change_indexes_.clear();
}
void Playlist::TracksEnqueued(const QModelIndex&, int begin, int end) {
const QModelIndex& b = queue_->mapToSource(queue_->index(begin, Column_Title));
const QModelIndex& e = queue_->mapToSource(queue_->index(end, Column_Title));
emit dataChanged(b, e);
}
void Playlist::QueueLayoutChanged() {
for (int i=0 ; i<queue_->rowCount() ; ++i) {
const QModelIndex index = queue_->mapToSource(queue_->index(i, Column_Title));
const QModelIndex& index = queue_->mapToSource(queue_->index(i, Column_Title));
emit dataChanged(index, index);
}
}

View File

@ -200,13 +200,14 @@ class Playlist : public QAbstractListModel {
private slots:
void TracksAboutToBeDequeued(const QModelIndex&, int begin, int end);
void TracksDequeued();
void TracksEnqueued(const QModelIndex&, int begin, int end);
void QueueLayoutChanged();
private:
PlaylistFilter* proxy_;
Queue* queue_;
QList<QModelIndex> temp_queue_change_indexes_;
QList<QModelIndex> temp_dequeue_change_indexes_;
PlaylistBackend* backend_;
TaskManager* task_manager_;