From da7c4209e34c9f6016b99c863c86a3c9f7a02d75 Mon Sep 17 00:00:00 2001 From: trialuser02 Date: Mon, 28 Nov 2011 18:17:34 +0000 Subject: fixed plugin hotkeys (Closes issue 511) git-svn-id: http://svn.code.sf.net/p/qmmp-dev/code/trunk/qmmp@2519 90c681e8-e032-0410-971d-27865f9a5e38 --- src/plugins/Ui/skinned/dock.cpp | 18 ++++++++++++++++-- src/plugins/Ui/skinned/dock.h | 3 +++ src/plugins/Ui/skinned/mainwindow.cpp | 3 +++ 3 files changed, 22 insertions(+), 2 deletions(-) (limited to 'src/plugins/Ui/skinned') diff --git a/src/plugins/Ui/skinned/dock.cpp b/src/plugins/Ui/skinned/dock.cpp index c5ec1cf0b..d8ca5f49a 100644 --- a/src/plugins/Ui/skinned/dock.cpp +++ b/src/plugins/Ui/skinned/dock.cpp @@ -255,9 +255,18 @@ bool Dock::isDocked (QWidget* mv, QWidget* st) void Dock::addActions (QList actions) { - m_actions << actions; + QList new_actions; + foreach(QAction *action, actions) + { + if(!m_actions.contains(action)) + { + connect(action, SIGNAL(destroyed(QObject *)), SLOT(removeAction(QObject *))); + new_actions.append(action); + m_actions.append(action); + } + } for (int i = 0; iaddActions (actions); + m_widgetList.at (i)->addActions (new_actions); } bool Dock::isUnder(QWidget* upper, QWidget* nether, int dy) @@ -278,3 +287,8 @@ void Dock::align(QWidget* w, int dy) } } } + +void Dock::removeAction(QObject *action) +{ + m_actions.removeAll(qobject_cast (action)); +} diff --git a/src/plugins/Ui/skinned/dock.h b/src/plugins/Ui/skinned/dock.h index 0b5791fa7..eb5572475 100644 --- a/src/plugins/Ui/skinned/dock.h +++ b/src/plugins/Ui/skinned/dock.h @@ -45,6 +45,9 @@ public: void addActions(QList actions); void align(QWidget*, int dy); +private slots: + void removeAction(QObject *action); + private: QPoint snapDesktop(QPoint, QWidget*); QPoint snap(QPoint, QWidget*, QWidget*); diff --git a/src/plugins/Ui/skinned/mainwindow.cpp b/src/plugins/Ui/skinned/mainwindow.cpp index afede3eaa..ad3b84802 100644 --- a/src/plugins/Ui/skinned/mainwindow.cpp +++ b/src/plugins/Ui/skinned/mainwindow.cpp @@ -294,6 +294,9 @@ void MainWindow::readSettings() m_hideOnClose = settings.value("hide_on_close", false).toBool(); settings.endGroup(); + + Dock::instance()->addActions(m_uiHelper->actions(UiHelper::PLAYLIST_MENU)); + Dock::instance()->addActions(m_uiHelper->actions(UiHelper::TOOLS_MENU)); } void MainWindow::writeSettings() -- cgit v1.2.3-13-gbd6f