diff --git a/app/dbus/org.kde.LatteDock.xml b/app/dbus/org.kde.LatteDock.xml
index f7dff0483..2da87da26 100644
--- a/app/dbus/org.kde.LatteDock.xml
+++ b/app/dbus/org.kde.LatteDock.xml
@@ -9,7 +9,7 @@
-
+
@@ -17,7 +17,7 @@
-
+
diff --git a/app/lattecorona.cpp b/app/lattecorona.cpp
index 63abddb05..c3ea3197d 100644
--- a/app/lattecorona.cpp
+++ b/app/lattecorona.cpp
@@ -962,9 +962,11 @@ void Corona::showSettingsWindow(int page)
QStringList Corona::contextMenuData()
{
QStringList data;
+ Types::ViewType viewType{Types::DockView};
data << QString::number((int)m_layoutManager->memoryUsage());
data << m_layoutManager->currentLayoutName();
+ data << QString::number((int)viewType);
foreach (auto layoutName, m_layoutManager->menuLayouts()) {
if (m_layoutManager->activeLayout(layoutName)) {
diff --git a/app/layout/layout.cpp b/app/layout/layout.cpp
index e34248cf4..687f1682d 100644
--- a/app/layout/layout.cpp
+++ b/app/layout/layout.cpp
@@ -816,6 +816,17 @@ QHash *Layout::latteViews()
return &m_latteViews;
}
+Types::ViewType Layout::latteViewType(int containmentId) const
+{
+ foreach (auto view, m_latteViews) {
+ if (view->containment() && view->containment()->id() == containmentId) {
+ return view->type();
+ }
+ }
+
+ return Types::DockView;
+}
+
Latte::View *Layout::highestPriorityView()
{
QList views = sortedLatteViews();
diff --git a/app/layout/layout.h b/app/layout/layout.h
index 5363fa149..ae5093e2e 100644
--- a/app/layout/layout.h
+++ b/app/layout/layout.h
@@ -21,6 +21,9 @@
#ifndef LAYOUT_H
#define LAYOUT_H
+// local
+#include "../../liblatte2/types.h"
+
// Qt
#include
#include
@@ -143,6 +146,8 @@ public:
QList sortedLatteViews();
QList viewsWithPlasmaShortcuts();
+ Types::ViewType latteViewType(int containmentId) const;
+
Latte::View *highestPriorityView();
//! Bind this latteView and its relevant containments(including systrays)
diff --git a/containmentactions/contextmenu/menu.cpp b/containmentactions/contextmenu/menu.cpp
index 5241e73a8..f0188adac 100644
--- a/containmentactions/contextmenu/menu.cpp
+++ b/containmentactions/contextmenu/menu.cpp
@@ -39,6 +39,8 @@
#include
#include
+const int LAYOUTSPOS = 3;
+
Menu::Menu(QObject *parent, const QVariantList &args)
: Plasma::ContainmentActions(parent, args)
{
@@ -107,22 +109,30 @@ QList Menu::contextualActions()
actions << m_addWidgetsAction;
actions << m_configureAction;
- m_layoutsData.clear();
+ m_data.clear();
QDBusInterface iface("org.kde.lattedock", "/Latte", "", QDBusConnection::sessionBus());
if (iface.isValid()) {
+ iface.call("contextMenuData", containment()->id());
+
QDBusReply replyData = iface.call("contextMenuData");
- m_layoutsData = replyData.value();
+ m_data = replyData.value();
}
- if (m_layoutsData.size() > 3) {
+ if (m_data.size() > LAYOUTSPOS + 1) {
m_layoutsAction->setEnabled(true);
m_layoutsAction->setVisible(true);
} else {
m_layoutsAction->setVisible(false);
}
+ Latte::Types::ViewType viewType{Latte::Types::DockView};
+
+ if (m_data.size() >= LAYOUTSPOS + 1) {
+ viewType = static_cast((m_data[2]).toInt());
+ }
+
return actions;
}
@@ -143,15 +153,15 @@ void Menu::populateLayouts()
{
m_switchLayoutsMenu->clear();
- if (m_layoutsData.size() > 3) {
+ if (m_data.size() > LAYOUTSPOS + 1) {
//when there are more than 1 layouts present
- Latte::Types::LayoutsMemoryUsage memoryUsage = static_cast((m_layoutsData[0]).toInt());
- QString currentName = m_layoutsData[1];
+ Latte::Types::LayoutsMemoryUsage memoryUsage = static_cast((m_data[0]).toInt());
+ QString currentName = m_data[1];
- for (int i = 2; i < m_layoutsData.size(); ++i) {
- bool isActive = m_layoutsData[i].startsWith("0") ? false : true;
+ for (int i = LAYOUTSPOS; i < m_data.size(); ++i) {
+ bool isActive = m_data[i].startsWith("0") ? false : true;
- QString layout = m_layoutsData[i].right(m_layoutsData[i].length() - 2);
+ QString layout = m_data[i].right(m_data[i].length() - 2);
QString currentText = (memoryUsage == Latte::Types::MultipleLayouts && layout == currentName) ?
(" " + i18nc("current layout", "(Current)")) : "";
diff --git a/containmentactions/contextmenu/menu.h b/containmentactions/contextmenu/menu.h
index e5ac561ee..f44fe3921 100644
--- a/containmentactions/contextmenu/menu.h
+++ b/containmentactions/contextmenu/menu.h
@@ -48,7 +48,7 @@ private Q_SLOTS:
private:
- QStringList m_layoutsData;
+ QStringList m_data;
QListm_actions;