From dfec3ac55066d0265a5c8076c2f5fbeebe5eb56d Mon Sep 17 00:00:00 2001 From: Ken Moore Date: Tue, 1 Dec 2015 14:43:26 -0500 Subject: Re-do the "App Menu" plugin a bit. Now it uses a self-contained menu with a "Leave" option at the bottom. We can add/change it more later as needed. --- .../panel-plugins/appmenu/LAppMenuPlugin.cpp | 104 +++++++++++++++++++-- .../panel-plugins/appmenu/LAppMenuPlugin.h | 5 +- 2 files changed, 98 insertions(+), 11 deletions(-) (limited to 'lumina-desktop/panel-plugins/appmenu') diff --git a/lumina-desktop/panel-plugins/appmenu/LAppMenuPlugin.cpp b/lumina-desktop/panel-plugins/appmenu/LAppMenuPlugin.cpp index c64f934b..928a93d9 100644 --- a/lumina-desktop/panel-plugins/appmenu/LAppMenuPlugin.cpp +++ b/lumina-desktop/panel-plugins/appmenu/LAppMenuPlugin.cpp @@ -13,14 +13,17 @@ LAppMenuPlugin::LAppMenuPlugin(QWidget *parent, QString id, bool horizontal) : L button = new QToolButton(this); button->setAutoRaise(true); button->setToolButtonStyle(Qt::ToolButtonTextBesideIcon); - button->setMenu( LSession::handle()->applicationMenu() ); - connect(button->menu(), SIGNAL(aboutToHide()), this, SIGNAL(MenuClosed())); + mainmenu = new QMenu(this); + button->setMenu( mainmenu ); button->setPopupMode(QToolButton::InstantPopup); this->layout()->setContentsMargins(0,0,0,0); this->layout()->addWidget(button); - + connect(mainmenu, SIGNAL(aboutToHide()), this, SIGNAL(MenuClosed())); + connect(mainmenu, SIGNAL(triggered(QAction*)), this, SLOT(LaunchItem(QAction*)) ); + connect(LSession::handle()->applicationMenu(), SIGNAL(AppMenuUpdated()), this, SIGNAL(UpdateMenu())); QTimer::singleShot(0,this, SLOT(OrientationChange())); //Update icons/sizes + QTimer::singleShot(0,this, SLOT(UpdateMenu()) ); } LAppMenuPlugin::~LAppMenuPlugin(){ @@ -37,12 +40,95 @@ void LAppMenuPlugin::updateButtonVisuals(){ // ======================== // PRIVATE FUNCTIONS // ======================== -/*void LAppMenuPlugin::openMenu(){ - usermenu->UpdateMenu(); - menu->popup(this->mapToGlobal(QPoint(0,0))); +void LAppMenuPlugin::LaunchItem(QAction* item){ + QString appFile = item->whatsThis(); + if(appFile.startsWith("internal::")){ + appFile = appFile.section("::",1,50); //cut off the "internal" flag + if(appFile=="logout"){ LSession::handle()->systemWindow(); } + }else if(!appFile.isEmpty()){ + LSession::LaunchApplication("lumina-open "+appFile); + } } -void LAppMenuPlugin::closeMenu(){ - menu->hide(); -}*/ +void LAppMenuPlugin::UpdateMenu(){ + mainmenu->clear(); + QHash > *HASH = LSession::handle()->applicationMenu()->currentAppHash(); + //Now Re-create the menu (orignally copied from the AppMenu class) + bool ok; //for checking inputs + //Add link to the file manager + QAction *tmpact = mainmenu->addAction( LXDG::findIcon("user-home", ""), tr("Browse Files") ); + tmpact->setWhatsThis("~"); + //--Look for the app store + XDGDesktop store = LXDG::loadDesktopFile(LOS::AppStoreShortcut(), ok); + if(ok){ + tmpact = mainmenu->addAction( LXDG::findIcon(store.icon, ""), tr("Install Applications") ); + tmpact->setWhatsThis("\""+store.filePath+"\""); + } + //--Look for the control panel + store = LXDG::loadDesktopFile(LOS::ControlPanelShortcut(), ok); + if(ok){ + tmpact = mainmenu->addAction( LXDG::findIcon(store.icon, ""), tr("Control Panel") ); + tmpact->setWhatsThis("\""+store.filePath+"\""); + } + mainmenu->addSeparator(); + //--Now create the sub-menus + QStringList cats = HASH->keys(); + cats.sort(); //make sure they are alphabetical + for(int i=0; isetIcon(LXDG::findIcon(icon,"")); + QList appL = HASH->value(cats[i]); + for( int a=0; asetToolTip(appL[a].comment); + act->setWhatsThis("\""+appL[a].filePath+"\""); + menu->addAction(act); + }else{ + //This app has additional actions - make this a sub menu + // - first the main menu/action + QMenu *submenu = new QMenu(appL[a].name, menu); + submenu->setIcon( LXDG::findIcon(appL[a].icon,"") ); + //This is the normal behavior - not a special sub-action (although it needs to be at the top of the new menu) + QAction *act = new QAction(LXDG::findIcon(appL[a].icon, ""), appL[a].name, submenu); + act->setToolTip(appL[a].comment); + act->setWhatsThis(appL[a].filePath); + submenu->addAction(act); + //Now add entries for every sub-action listed + for(int sa=0; sasetToolTip(appL[a].comment); + sact->setWhatsThis("-action \""+appL[a].actions[sa].ID+"\" \""+appL[a].filePath+"\""); + submenu->addAction(sact); + } + menu->addMenu(submenu); + } + }//end loop over apps within this category + mainmenu->addMenu(menu); + } //end loop over categories + //Now add any logout options + mainmenu->addSeparator(); + //QMenu *tmpmenu = mainmenu->addMenu(LXDG::findIcon("system-log-out",""), tr("Leave")); + tmpact =mainmenu->addAction(LXDG::findIcon("system-log-out"),tr("Leave")); + tmpact->setWhatsThis("internal::logout"); + +} diff --git a/lumina-desktop/panel-plugins/appmenu/LAppMenuPlugin.h b/lumina-desktop/panel-plugins/appmenu/LAppMenuPlugin.h index cd8d1c1e..36cd8605 100644 --- a/lumina-desktop/panel-plugins/appmenu/LAppMenuPlugin.h +++ b/lumina-desktop/panel-plugins/appmenu/LAppMenuPlugin.h @@ -30,12 +30,13 @@ public: private: QToolButton *button; + QMenu *mainmenu; void updateButtonVisuals(); private slots: - //void openMenu(); - //void closeMenu(); + void LaunchItem(QAction* item); + void UpdateMenu(); public slots: void OrientationChange(){ -- cgit