aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/plugins/Ui/qsui/dockwidgetlist.cpp4
-rw-r--r--src/plugins/Ui/qsui/mainwindow.cpp6
-rw-r--r--src/qmmpui/uiloader.cpp3
3 files changed, 12 insertions, 1 deletions
diff --git a/src/plugins/Ui/qsui/dockwidgetlist.cpp b/src/plugins/Ui/qsui/dockwidgetlist.cpp
index 78f663e04..906e12201 100644
--- a/src/plugins/Ui/qsui/dockwidgetlist.cpp
+++ b/src/plugins/Ui/qsui/dockwidgetlist.cpp
@@ -20,6 +20,8 @@ DockWidgetList::DockWidgetList(QMainWindow *parent) : QObject(parent), m_mw(pare
dockWidget->toggleViewAction()->setShortcut(desc.shortcut);
dockWidget->setObjectName(id);
dockWidget->setAllowedAreas(desc.allowedAreas);
+ if(qApp->platformName() == QLatin1String("wayland"))
+ dockWidget->setFeatures(QDockWidget::DockWidgetClosable | QDockWidget::DockWidgetMovable);
m_mw->addDockWidget(desc.area, dockWidget);
connect(dockWidget->toggleViewAction(), SIGNAL(triggered(bool)), SLOT(onViewActionTriggered(bool)));
connect(dockWidget, SIGNAL(visibilityChanged(bool)), SLOT(onVisibilityChanged(bool)));
@@ -122,6 +124,8 @@ void DockWidgetList::onWidgetAdded(const QString &id)
QDockWidget *dockWidget = new QDockWidget(desc.name, m_mw);
dockWidget->setObjectName(id);
dockWidget->setAllowedAreas(desc.allowedAreas);
+ if(qApp->platformName() == QLatin1String("wayland"))
+ dockWidget->setFeatures(QDockWidget::DockWidgetClosable | QDockWidget::DockWidgetMovable);
if(m_menu && m_beforeAction)
m_menu->insertAction(m_beforeAction, dockWidget->toggleViewAction());
m_mw->addDockWidget(desc.area, dockWidget);
diff --git a/src/plugins/Ui/qsui/mainwindow.cpp b/src/plugins/Ui/qsui/mainwindow.cpp
index 8c51aa22b..b868a66c4 100644
--- a/src/plugins/Ui/qsui/mainwindow.cpp
+++ b/src/plugins/Ui/qsui/mainwindow.cpp
@@ -860,6 +860,12 @@ void MainWindow::setTitleBarsVisible(bool visible)
m_ui.waveformSeekBarDockWidget
};
+ if(qApp->platformName() == QLatin1String("wayland"))
+ {
+ for(QDockWidget *w : qAsConst(widgetList))
+ w->setFeatures(QDockWidget::DockWidgetClosable | QDockWidget::DockWidgetMovable);
+ }
+
if(visible)
{
for(QDockWidget *w : qAsConst(widgetList))
diff --git a/src/qmmpui/uiloader.cpp b/src/qmmpui/uiloader.cpp
index 269db9577..5324fa3b2 100644
--- a/src/qmmpui/uiloader.cpp
+++ b/src/qmmpui/uiloader.cpp
@@ -19,6 +19,7 @@
***************************************************************************/
#include <QDir>
+#include <QApplication>
#include <qmmp/qmmp.h>
#include <algorithm>
#include "qmmpuiplugincache_p.h"
@@ -101,7 +102,7 @@ UiFactory *UiLoader::selected()
QSettings settings (Qmmp::configFile(), QSettings::IniFormat);
#ifdef Q_OS_UNIX
QString defaultUi = QMMP_DEFAULT_UI;
- if(defaultUi == QLatin1String("skinned") && qgetenv("XDG_SESSION_TYPE") == "wayland")
+ if(defaultUi == QLatin1String("skinned") && qApp->platformName() == QLatin1String("wayland"))
defaultUi = "qsui";
QString name = settings.value("Ui/current_plugin", defaultUi).toString();
#else