aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/qmmpui/playlistmanager.cpp11
-rw-r--r--src/qmmpui/playlistmanager.h2
-rw-r--r--src/ui/forms/playlistbrowser.ui18
-rw-r--r--src/ui/playlistbrowser.cpp18
-rw-r--r--src/ui/playlistbrowser.h2
5 files changed, 49 insertions, 2 deletions
diff --git a/src/qmmpui/playlistmanager.cpp b/src/qmmpui/playlistmanager.cpp
index 4af84d1b4..a24d82a24 100644
--- a/src/qmmpui/playlistmanager.cpp
+++ b/src/qmmpui/playlistmanager.cpp
@@ -146,6 +146,17 @@ void PlayListManager::removePlayList(PlayListModel *model)
emit playListsChanged();
}
+void PlayListManager::move(int i, int j)
+{
+ if(i < 0 || j < 0)
+ return;
+ if(i < m_models.count() && j < m_models.count())
+ {
+ m_models.move(i,j);
+ emit playListsChanged();
+ }
+}
+
void PlayListManager::setRepeatableList(bool r)
{
if(m_repeatable == r)
diff --git a/src/qmmpui/playlistmanager.h b/src/qmmpui/playlistmanager.h
index 630ce5fa7..db887acc5 100644
--- a/src/qmmpui/playlistmanager.h
+++ b/src/qmmpui/playlistmanager.h
@@ -116,6 +116,7 @@ public slots:
void activatePlayList(PlayListModel *model);
PlayListModel *createPlayList(const QString &name = QString());
void removePlayList(PlayListModel *model);
+ void move(int i, int j);
void setRepeatableList(bool r);
void setShuffle(bool s);
/*!
@@ -191,6 +192,7 @@ public slots:
*/
void clearInvalidItems();
+
private:
void readPlayLists();
void writePlayLists();
diff --git a/src/ui/forms/playlistbrowser.ui b/src/ui/forms/playlistbrowser.ui
index 65af8c73f..200a6d935 100644
--- a/src/ui/forms/playlistbrowser.ui
+++ b/src/ui/forms/playlistbrowser.ui
@@ -29,7 +29,7 @@
<property name="spacing">
<number>6</number>
</property>
- <item row="0" column="0" colspan="3">
+ <item row="0" column="0" colspan="5">
<widget class="QListWidget" name="listWidget">
<property name="selectionMode">
<enum>QAbstractItemView::ExtendedSelection</enum>
@@ -53,7 +53,7 @@
</property>
</widget>
</item>
- <item row="1" column="2">
+ <item row="1" column="4">
<widget class="QDialogButtonBox" name="buttonBox">
<property name="orientation">
<enum>Qt::Horizontal</enum>
@@ -63,6 +63,20 @@
</property>
</widget>
</item>
+ <item row="1" column="2">
+ <widget class="QToolButton" name="downButton">
+ <property name="text">
+ <string>...</string>
+ </property>
+ </widget>
+ </item>
+ <item row="1" column="3">
+ <widget class="QToolButton" name="upButton">
+ <property name="text">
+ <string>...</string>
+ </property>
+ </widget>
+ </item>
</layout>
</widget>
<resources/>
diff --git a/src/ui/playlistbrowser.cpp b/src/ui/playlistbrowser.cpp
index f4844dadf..27cebca12 100644
--- a/src/ui/playlistbrowser.cpp
+++ b/src/ui/playlistbrowser.cpp
@@ -19,6 +19,8 @@
***************************************************************************/
#include <QAction>
+#include <QApplication>
+#include <QStyle>
#include <qmmpui/playlistmanager.h>
#include "playlistbrowser.h"
@@ -39,6 +41,8 @@ PlayListBrowser::PlayListBrowser(PlayListManager *manager, QWidget *parent) : QD
ui.listWidget->setContextMenuPolicy(Qt::ActionsContextMenu);
ui.listWidget->addAction(renameAct);
ui.listWidget->addAction(removeAct);
+ ui.downButton->setIcon(QApplication::style()->standardIcon(QStyle::SP_ArrowDown));
+ ui.upButton->setIcon(QApplication::style()->standardIcon(QStyle::SP_ArrowUp));
}
PlayListBrowser::~PlayListBrowser()
@@ -84,3 +88,17 @@ void PlayListBrowser::on_deleteButton_clicked()
foreach(PlayListModel *model, models)
m_pl_manager->removePlayList(model);
}
+
+void PlayListBrowser::on_downButton_clicked()
+{
+ int pos = m_pl_manager->indexOf(m_pl_manager->selectedPlayList());
+ if(pos < m_pl_manager->count() - 1)
+ m_pl_manager->move(pos, pos + 1);
+}
+
+void PlayListBrowser::on_upButton_clicked()
+{
+ int pos = m_pl_manager->indexOf(m_pl_manager->selectedPlayList());
+ if(pos > 0)
+ m_pl_manager->move(pos, pos - 1);
+}
diff --git a/src/ui/playlistbrowser.h b/src/ui/playlistbrowser.h
index c9ac23c77..c3eee00ec 100644
--- a/src/ui/playlistbrowser.h
+++ b/src/ui/playlistbrowser.h
@@ -42,6 +42,8 @@ private slots:
void on_listWidget_itemChanged(QListWidgetItem *item);
void rename();
void on_deleteButton_clicked();
+ void on_downButton_clicked();
+ void on_upButton_clicked();
private:
Ui::PlayListBrowser ui;
undation; either version 2 of the License, or * * (at your option) any later version. * * * * 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, write to the * * Free Software Foundation, Inc., * * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ #include <QAction> #include <QKeySequence> #include <qmmpui/playlistmanager.h> #include <qmmpui/playlistmodel.h> #include <qmmpui/mediaplayer.h> #include <qmmp/soundcore.h> #include "listwidget.h" #include "keyboardmanager.h" KeyboardManager::KeyboardManager(QObject *parent) : QObject(parent) { m_listWidget = 0; addAction(Qt::Key_Up, SLOT(processUp())); addAction(Qt::Key_Up + Qt::ShiftModifier, SLOT(processUp())); addAction(Qt::Key_Up + Qt::AltModifier, SLOT(processUp())); addAction(Qt::Key_Up + Qt::ControlModifier, SLOT(processUp())); addAction(Qt::Key_Down, SLOT(processDown())); addAction(Qt::Key_Down + Qt::ShiftModifier, SLOT(processDown())); addAction(Qt::Key_Down + Qt::AltModifier, SLOT(processDown())); addAction(Qt::Key_Down + Qt::ControlModifier, SLOT(processDown())); addAction(Qt::Key_Return, SLOT(processEnter())); addAction(Qt::Key_PageUp, SLOT(processPgUp())); addAction(Qt::Key_PageUp + Qt::ShiftModifier, SLOT(processPgUp())); addAction(Qt::Key_PageDown, SLOT(processPgDown())); addAction(Qt::Key_PageDown + Qt::ShiftModifier, SLOT(processPgDown())); addAction(Qt::Key_Home, SLOT(processHome())); addAction(Qt::Key_Home + Qt::ShiftModifier, SLOT(processHome())); addAction(Qt::Key_End, SLOT(processEnd())); addAction(Qt::Key_End + Qt::ShiftModifier, SLOT(processEnd())); } QList<QAction *> KeyboardManager::actions() { return m_actions; } void KeyboardManager::processUp() { if(!m_listWidget) return; int keys = qobject_cast<QAction *>(sender())->shortcut()[0]; QList<int> rows = m_listWidget->model()->selectedIndexes(); if(rows.isEmpty()) { m_listWidget->model()->setSelected(m_listWidget->firstVisibleIndex(), true); m_listWidget->setAnchorIndex(m_listWidget->firstVisibleIndex()); return; } if (!(keys & Qt::ShiftModifier || keys & Qt::AltModifier || keys & Qt::ControlModifier)) { m_listWidget->model()->clearSelection(); m_listWidget->setAnchorIndex(-1); } int first_visible = m_listWidget->firstVisibleIndex(); int last_visible = m_listWidget->visibleRows() + first_visible - 1; int s = SELECT_NEXT; if(rows.last() < first_visible) s = SELECT_TOP; else if(rows.first() > last_visible) s = SELECT_BOTTOM; if (keys & Qt::AltModifier) { if(rows.first() == 0) return; m_listWidget->model()->moveItems (rows.first(), rows.first() - 1); m_listWidget->setAnchorIndex (rows.first() - 1); } else if(keys & Qt::ControlModifier) { m_listWidget->setAnchorIndex (qMax(m_listWidget->anchorIndex() - 1, 0)); } else { if(s == SELECT_TOP) { m_listWidget->model()->setSelected (first_visible, true); m_listWidget->setAnchorIndex(first_visible); } else if(s == SELECT_BOTTOM) { m_listWidget->model()->setSelected (last_visible, true); m_listWidget->setAnchorIndex(last_visible); } else if(rows.first() == 0) { m_listWidget->model()->setSelected (rows.first(), true); m_listWidget->setAnchorIndex(rows.first()); } else if(rows.contains(m_listWidget->anchorIndex()) || m_listWidget->anchorIndex() < 0) { m_listWidget->model()->setSelected (rows.first() - 1, true); m_listWidget->setAnchorIndex(rows.first() - 1); } else if(m_listWidget->anchorIndex() >= 0) { m_listWidget->model()->setSelected (m_listWidget->anchorIndex(), true); } } if(m_listWidget->anchorIndex() < first_visible) { m_listWidget->scroll (m_listWidget->firstVisibleIndex() - 1); } } void KeyboardManager::processDown() { if(!m_listWidget) return; int keys = qobject_cast<QAction *>(sender())->shortcut()[0]; QList<int> rows = m_listWidget->model()->selectedIndexes(); if(rows.isEmpty()) { m_listWidget->model()->setSelected(m_listWidget->firstVisibleIndex(), true); m_listWidget->setAnchorIndex(m_listWidget->firstVisibleIndex()); return; } if (!(keys & Qt::ShiftModifier || keys & Qt::AltModifier || keys & Qt::ControlModifier)) { m_listWidget->model()->clearSelection(); m_listWidget->setAnchorIndex(-1); } int first_visible = m_listWidget->firstVisibleIndex(); int last_visible = m_listWidget->visibleRows() + first_visible - 1; int s = SELECT_NEXT; if(rows.last() < first_visible) s = SELECT_TOP; else if(rows.first() > last_visible) s = SELECT_BOTTOM; if (keys & Qt::AltModifier) { if(rows.last() == m_listWidget->model()->count() - 1) return; m_listWidget->model()->moveItems (rows.last(), rows.last() + 1); m_listWidget->setAnchorIndex (rows.last() + 1); } else if(keys & Qt::ControlModifier) { m_listWidget->setAnchorIndex (qMin(m_listWidget->anchorIndex() + 1, m_listWidget->model()->count() - 1)); } else { if(s == SELECT_TOP) { m_listWidget->model()->setSelected (first_visible, true); m_listWidget->setAnchorIndex(first_visible); } else if(s == SELECT_BOTTOM) { m_listWidget->model()->setSelected (last_visible, true); m_listWidget->setAnchorIndex(last_visible); } else if(rows.last() == m_listWidget->model()->count() - 1) { m_listWidget->model()->setSelected (rows.last(), true); m_listWidget->setAnchorIndex(rows.last()); } else if(rows.contains(m_listWidget->anchorIndex()) || m_listWidget->anchorIndex() < 0) { m_listWidget->model()->setSelected (rows.last() + 1, true); m_listWidget->setAnchorIndex(rows.last() + 1); } else if(m_listWidget->anchorIndex() >= 0) { m_listWidget->model()->setSelected (m_listWidget->anchorIndex(), true); } } if(m_listWidget->anchorIndex() > last_visible) { m_listWidget->scroll (m_listWidget->firstVisibleIndex() + 1); } } void KeyboardManager::setListWidget(ListWidget *listWidget) { m_listWidget = listWidget; }