]> cloud.milkyroute.net Git - dolphin.git/commitdiff
Allow to add menu groups like "View Mode", "Sort By"... to be added as toolbar item...
authorPeter Penz <peter.penz19@gmail.com>
Mon, 3 May 2010 15:40:24 +0000 (15:40 +0000)
committerPeter Penz <peter.penz19@gmail.com>
Mon, 3 May 2010 15:40:24 +0000 (15:40 +0000)
Thanks to Todd for the patch!

CCMAIL: toddrme2178@gmail.com

svn path=/trunk/KDE/kdebase/apps/; revision=1122320

src/dolphinmainwindow.cpp
src/dolphinpart.rc
src/dolphinui.rc
src/dolphinviewactionhandler.cpp
src/dolphinviewactionhandler.h

index eaa8ebb8aa9793fb6eb818165f4b37d7db7f6b1c..3d9b92f526ecaa73dfd39c865c7181738e19539a 100644 (file)
@@ -52,6 +52,7 @@
 
 #include <kaction.h>
 #include <kactioncollection.h>
+#include <kactionmenu.h>
 #include <kconfig.h>
 #include <kdesktopfile.h>
 #include <kdeversion.h>
@@ -1638,6 +1639,14 @@ void DolphinMainWindow::setupDockWidgets()
             this, SLOT(handlePlacesClick(KUrl, Qt::MouseButtons)));
     connect(this, SIGNAL(urlChanged(KUrl)),
             placesPanel, SLOT(setUrl(KUrl)));
+
+    KActionMenu* panelsMenu = new KActionMenu(i18nc("@action:inmenu File", "Panels"), this);
+    actionCollection()->addAction("panels", panelsMenu);
+    panelsMenu->setDelayed(false);
+    panelsMenu->addAction(placesAction);
+    panelsMenu->addAction(infoAction);
+    panelsMenu->addAction(foldersAction);
+    panelsMenu->addAction(terminalAction);
 }
 
 void DolphinMainWindow::updateEditActions()
index 7340c4dc17779bd8bb78a2bc064cbbc91819e5ce..1ff1e040f70f48efe4c2d6c02d2e6d3cf231e2a0 100644 (file)
    </Menu>
   </Menu>
   <Menu name="view"><text>&amp;View</text>
-   <Menu name="sort">
-    <text context="@title:menu">Sort By</text>
-    <Action name="sort_by_name" />
-    <Action name="sort_by_size" />
-    <Action name="sort_by_date" />
-    <Action name="sort_by_permissions" />
-    <Action name="sort_by_owner" />
-    <Action name="sort_by_group" />
-    <Action name="sort_by_type" />
-    <Action name="sort_by_rating" />
-    <Action name="sort_by_tags" />
-    <Separator/>
-    <Action name="descending" />
-    <Action name="folders_first" />
-   </Menu>
-   <Menu name="additional_info">
-    <text context="@title:menu">Additional Information</text>
-    <Action name="show_size_info" />
-    <Action name="show_date_info" />
-    <Action name="show_permissions_info" />
-    <Action name="show_owner_info" />
-    <Action name="show_group_info" />
-    <Action name="show_mime_info" />
-   </Menu>
+   <Action name="sort" />
+   <Action name="additional_info" />
    <Action name="show_preview" />
    <Action name="show_in_groups" />
    <Action name="show_hidden_files" />
index 61b7df615daec1042b17c7ad4f1d6c25a7de94b9..3ec650daa0ca2cb3798ef92562cbf0501e4e9a26 100644 (file)
             <Action name="invert_selection" />
         </Menu>
         <Menu name="view">
-            <Menu name="view_mode" >
-                <text context="@title:menu">View Mode</text>
-                <Action name="icons" />
-                <Action name="details" />
-                <Action name="columns" />
-            </Menu>
-            <Menu name="sort">
-                <text context="@title:menu">Sort By</text>
-                <Action name="sort_by_name" />
-                <Action name="sort_by_size" />
-                <Action name="sort_by_date" />
-                <Action name="sort_by_permissions" />
-                <Action name="sort_by_owner" />
-                <Action name="sort_by_group" />
-                <Action name="sort_by_type" />
-                <Action name="sort_by_rating" />
-                <Action name="sort_by_tags" />
-                <Separator/>
-                <Action name="descending" />
-                <Action name="folders_first" />
-            </Menu>
-            <Menu name="additional_info">
-                <text context="@title:menu">Additional Information</text>
-                <Action name="show_size_info" />
-                <Action name="show_date_info" />
-                <Action name="show_permissions_info" />
-                <Action name="show_owner_info" />
-                <Action name="show_group_info" />
-                <Action name="show_mime_info" />
-            </Menu>
+            <Action name="view_mode" />
+            <Action name="sort" />
+            <Action name="additional_info" />
             <Action name="show_preview" />
             <Action name="show_in_groups" />
             <Action name="show_hidden_files" />
             <Action name="reload" />
             <Action name="stop" />
             <Separator/>
-            <Menu name="panels">
-                <text context="@title:menu">Panels</text>
-                <Action name="show_places_panel" />
-                <Action name="show_info_panel" />
-                <Action name="show_folders_panel" />
-                <Action name="show_terminal_panel" />
-            </Menu>
+            <Action name="panels" />
             <Menu name="navigation_bar">
                 <text context="@title:menu">Location Bar</text>
                 <Action name="editable_location" />
index 9082e0dd0c43c877b20eaaf5a8e653a2ce5d22e2..8c07148d766d6d369df5e0b2e977f950c3e6df04 100644 (file)
@@ -26,6 +26,8 @@
 
 #include <kaction.h>
 #include <kactioncollection.h>
+#include <kactionmenu.h>
+#include <kselectaction.h>
 #include <klocale.h>
 #include <knewmenu.h>
 #include <ktoggleaction.h>
@@ -126,11 +128,16 @@ void DolphinViewActionHandler::createActions()
     connect(propertiesAction, SIGNAL(triggered()), SLOT(slotProperties()));
 
     // View menu
-
-    QActionGroup* viewModeActions = new QActionGroup(this);
-    viewModeActions->addAction(iconsModeAction());
-    viewModeActions->addAction(detailsModeAction());
-    viewModeActions->addAction(columnsModeAction());
+    KToggleAction* iconsAction = iconsModeAction();
+    KToggleAction* detailsAction = detailsModeAction();
+    KToggleAction* columnsAction = columnsModeAction();
+
+    KSelectAction* viewModeActions = m_actionCollection->add<KSelectAction>("view_mode");
+    viewModeActions->setText(i18nc("@action:intoolbar", "View Mode"));
+    viewModeActions->addAction(iconsAction);
+    viewModeActions->addAction(detailsAction);
+    viewModeActions->addAction(columnsAction);
+    viewModeActions->setToolBarMode(KSelectAction::MenuMode);
     connect(viewModeActions, SIGNAL(triggered(QAction*)), this, SLOT(slotViewModeActionTriggered(QAction*)));
 
     KStandardAction::zoomIn(this,
@@ -158,8 +165,19 @@ void DolphinViewActionHandler::createActions()
     QActionGroup* sortByActionGroup = createSortByActionGroup();
     connect(sortByActionGroup, SIGNAL(triggered(QAction*)), this, SLOT(slotSortTriggered(QAction*)));
 
-    QActionGroup* showInformationActionGroup = createAdditionalInformationActionGroup();
-    connect(showInformationActionGroup, SIGNAL(triggered(QAction*)), this, SLOT(toggleAdditionalInfo(QAction*)));
+    KActionMenu* sortActionMenu = m_actionCollection->add<KActionMenu>("sort");
+    sortActionMenu->setText(i18nc("@action:inmenu View", "Sort By"));
+    sortActionMenu->setDelayed(false);
+
+    foreach(QAction* actionItem, sortByActionGroup->actions()) {
+        sortActionMenu->addAction(actionItem);
+    }
+    sortActionMenu->addSeparator();
+    sortActionMenu->addAction(sortDescending);
+    sortActionMenu->addAction(sortFoldersFirst);
+
+    KActionMenu* showInformationActionMenu = createAdditionalInformationActionMenu();
+    connect(showInformationActionMenu, SIGNAL(triggered(QAction*)), this, SLOT(toggleAdditionalInfo(QAction*)));
 
     KToggleAction* showInGroups = m_actionCollection->add<KToggleAction>("show_in_groups");
     showInGroups->setText(i18nc("@action:inmenu View", "Show in Groups"));
@@ -183,42 +201,43 @@ void DolphinViewActionHandler::createActions()
     connect(findFile, SIGNAL(triggered()), this, SLOT(slotFindFile()));
 }
 
-QActionGroup* DolphinViewActionHandler::createAdditionalInformationActionGroup()
+KActionMenu* DolphinViewActionHandler::createAdditionalInformationActionMenu()
 {
-    QActionGroup* showInformationGroup = new QActionGroup(m_actionCollection);
-    showInformationGroup->setExclusive(false);
+    KActionMenu* showInformationMenu = m_actionCollection->add<KActionMenu>("additional_info");
+    showInformationMenu->setText(i18nc("@action:inmenu View", "Additional Information"));
+    showInformationMenu->setDelayed(false);
 
     KToggleAction* showSizeInfo = m_actionCollection->add<KToggleAction>("show_size_info");
     showSizeInfo->setText(i18nc("@action:inmenu Additional information", "Size"));
     showSizeInfo->setData(KFileItemDelegate::Size);
-    showSizeInfo->setActionGroup(showInformationGroup);
+    showInformationMenu->addAction(showSizeInfo);
 
     KToggleAction* showDateInfo = m_actionCollection->add<KToggleAction>("show_date_info");
     showDateInfo->setText(i18nc("@action:inmenu Additional information", "Date"));
     showDateInfo->setData(KFileItemDelegate::ModificationTime);
-    showDateInfo->setActionGroup(showInformationGroup);
+    showInformationMenu->addAction(showDateInfo);
 
     KToggleAction* showPermissionsInfo = m_actionCollection->add<KToggleAction>("show_permissions_info");
     showPermissionsInfo->setText(i18nc("@action:inmenu Additional information", "Permissions"));
     showPermissionsInfo->setData(KFileItemDelegate::Permissions);
-    showPermissionsInfo->setActionGroup(showInformationGroup);
+    showInformationMenu->addAction(showPermissionsInfo);
 
     KToggleAction* showOwnerInfo = m_actionCollection->add<KToggleAction>("show_owner_info");
     showOwnerInfo->setText(i18nc("@action:inmenu Additional information", "Owner"));
     showOwnerInfo->setData(KFileItemDelegate::Owner);
-    showOwnerInfo->setActionGroup(showInformationGroup);
+    showInformationMenu->addAction(showOwnerInfo);
 
     KToggleAction* showGroupInfo = m_actionCollection->add<KToggleAction>("show_group_info");
     showGroupInfo->setText(i18nc("@action:inmenu Additional information", "Group"));
     showGroupInfo->setData(KFileItemDelegate::OwnerAndGroup);
-    showGroupInfo->setActionGroup(showInformationGroup);
+    showInformationMenu->addAction(showGroupInfo);
 
     KToggleAction* showMimeInfo = m_actionCollection->add<KToggleAction>("show_mime_info");
     showMimeInfo->setText(i18nc("@action:inmenu Additional information", "Type"));
-    showMimeInfo->setData(KFileItemDelegate::FriendlyMimeType);
-    showMimeInfo->setActionGroup(showInformationGroup);
+    showMimeInfo->setData(KFileItemDelegate::FriendlyMimeType);;
+    showInformationMenu->addAction(showMimeInfo);
 
-    return showInformationGroup;
+    return showInformationMenu;
 }
 
 Q_DECLARE_METATYPE(DolphinView::Sorting)
@@ -270,6 +289,9 @@ void DolphinViewActionHandler::slotViewModeActionTriggered(QAction* action)
 {
     const DolphinView::Mode mode = action->data().value<DolphinView::Mode>();
     m_currentView->setMode(mode);
+
+    QAction* viewModeMenu = m_actionCollection->action("view_mode");
+    viewModeMenu->setIcon(KIcon(action->icon()));
 }
 
 void DolphinViewActionHandler::slotRename()
@@ -332,6 +354,9 @@ void DolphinViewActionHandler::updateViewActions()
     QAction* viewModeAction = m_actionCollection->action(currentViewModeActionName());
     if (viewModeAction != 0) {
         viewModeAction->setChecked(true);
+
+        QAction* viewModeMenu = m_actionCollection->action("view_mode");
+        viewModeMenu->setIcon(KIcon(viewModeAction->icon()));
     }
 
     QAction* showPreviewAction = m_actionCollection->action("show_preview");
@@ -346,7 +371,6 @@ void DolphinViewActionHandler::updateViewActions()
 
     QAction* showHiddenFilesAction = m_actionCollection->action("show_hidden_files");
     showHiddenFilesAction->setChecked(m_currentView->showHiddenFiles());
-
 }
 
 void DolphinViewActionHandler::zoomIn()
@@ -485,6 +509,9 @@ void DolphinViewActionHandler::slotSortingChanged(DolphinView::Sorting sorting)
 
     if (action != 0) {
         action->setChecked(true);
+
+        QAction* sortByMenu =  m_actionCollection->action("sort");
+        sortByMenu->setIcon(KIcon(action->icon()));
     }
 }
 
index 5193da71992b980638cc69cc4500beddd5bbdfe7..4186a479f65d41f74e28902064cedb12e0b8a223 100644 (file)
 
 #include "dolphinview.h"
 #include "libdolphin_export.h"
+#include <kactionmenu.h>
+#include <kselectaction.h>
 #include <QtCore/QObject>
+
 class KToggleAction;
 class QAction;
 class QActionGroup;
@@ -217,10 +220,10 @@ private:
      */
     void createActions();
     /**
-     * Creates an action group with all the "show additional information" actions in it.
+     * Creates an action menu with all the "show additional information" actions in it.
      * Helper method for createActions();
      */
-    QActionGroup* createAdditionalInformationActionGroup();
+    KActionMenu* createAdditionalInformationActionMenu();
 
     /**
      * Creates an action group with all the "sort by" actions in it.