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;