diff options
| author | trialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38> | 2021-01-16 15:52:48 +0000 |
|---|---|---|
| committer | trialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38> | 2021-01-16 15:52:48 +0000 |
| commit | 886f9be488970798b2725ad2e9ddf26b5cadee07 (patch) | |
| tree | ed8c11574352818cafb69139f111c65110f2763b /src/plugins/General/library/librarymodel.cpp | |
| parent | e336a9c15821384f6a45c3ef76bc133c133e35e5 (diff) | |
| download | qmmp-886f9be488970798b2725ad2e9ddf26b5cadee07.tar.gz qmmp-886f9be488970798b2725ad2e9ddf26b5cadee07.tar.bz2 qmmp-886f9be488970798b2725ad2e9ddf26b5cadee07.zip | |
library: add context menu
git-svn-id: http://svn.code.sf.net/p/qmmp-dev/code/trunk/qmmp@9639 90c681e8-e032-0410-971d-27865f9a5e38
Diffstat (limited to 'src/plugins/General/library/librarymodel.cpp')
| -rw-r--r-- | src/plugins/General/library/librarymodel.cpp | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/src/plugins/General/library/librarymodel.cpp b/src/plugins/General/library/librarymodel.cpp index fef15669f..d02e9ba27 100644 --- a/src/plugins/General/library/librarymodel.cpp +++ b/src/plugins/General/library/librarymodel.cpp @@ -26,8 +26,11 @@ #include <QHash> #include <QJsonDocument> #include <QJsonObject> +#include <QWidget> #include <qmmp/qmmp.h> #include <qmmpui/playlistparser.h> +#include <qmmpui/playlistmanager.h> +#include <qmmpui/detailsdialog.h> #include "librarymodel.h" #define CONNECTION_NAME "qmmp_library_view" @@ -303,6 +306,39 @@ void LibraryModel::refresh() endResetModel(); } +void LibraryModel::add(const QModelIndexList &indexes) +{ + QList<PlayListTrack *> tracks; + + for(const QModelIndex &index : indexes) + { + if(index.isValid()) + { + tracks << getTracks(index); + } + } + + PlayListManager::instance()->add(tracks); +} + +void LibraryModel::showInformation(const QModelIndexList &indexes, QWidget *parent) +{ + QList<PlayListTrack *> tracks; + + for(const QModelIndex &index : indexes) + { + if(index.isValid()) + { + tracks << getTracks(index); + } + } + + DetailsDialog *dialog = new DetailsDialog(tracks, parent); + dialog->setAttribute(Qt::WA_DeleteOnClose, true); + dialog->show(); + connect(dialog, &QObject::destroyed, [=]() { qDeleteAll(tracks); }); +} + QList<PlayListTrack *> LibraryModel::getTracks(const QModelIndex &index) const { QSqlDatabase db = QSqlDatabase::database(CONNECTION_NAME); |
