#include "dolphin_generalsettings.h"
#include <kactioncollection.h>
-#include <kfileplacesmodel.h>
#include <kdesktopfile.h>
+#include <kfileitemlistproperties.h>
+#include <kfileplacesmodel.h>
#include <kglobal.h>
#include <kiconloader.h>
#include <kio/netaccess.h>
#include <kmimetypetrader.h>
#include <knewmenu.h>
#include <konqmimedata.h>
-#include <konq_fileitemcapabilities.h>
#include <konq_operations.h>
#include <konq_menuactions.h>
-#include <konq_popupmenuinformation.h>
#include <klocale.h>
#include <kpropertiesdialog.h>
#include <krun.h>
{
// The context menu either accesses the URLs of the selected items
// or the items itself. To increase the performance both lists are cached.
- DolphinView* view = m_mainWindow->activeViewContainer()->view();
+ const DolphinView* view = m_mainWindow->activeViewContainer()->view();
m_selectedUrls = view->selectedUrls();
m_selectedItems = view->selectedItems();
}
m_context |= TrashContext;
}
- if (!m_fileInfo.isNull() && (m_selectedItems.count() > 0)) {
+ if (!m_fileInfo.isNull() && !m_selectedItems.isEmpty()) {
m_context |= ItemContext;
// TODO: handle other use cases like devices + desktop files
}
i18nc("@action:inmenu Add selected folder to places", "Add to Places"));
}
- KonqPopupMenuInformation popupInfo;
- popupInfo.setItems(m_selectedItems);
- popupInfo.setParentWidget(m_mainWindow);
KonqMenuActions menuActions;
- menuActions.setPopupMenuInfo(popupInfo);
+ menuActions.setParentWidget(m_mainWindow);
+ menuActions.setItemListProperties(m_selectedItems);
// insert 'Open With...' action or sub menu
menuActions.addOpenWithActionsTo(popup, "DesktopEntryName != 'dolphin'");
popup->addSeparator();
}
+ // insert revision control actions
+ addRevisionControlActions(popup);
+
// insert 'Copy To' and 'Move To' sub menus
if (DolphinSettings::instance().generalSettings()->showCopyMoveMenu()) {
m_copyToMenu.setItems(m_selectedItems);
popup->addAction(pasteAction);
// setup 'View Mode' menu
- KMenu* viewModeMenu = new KMenu(i18nc("@title:menu", "View Mode"));
+ KMenu* viewModeMenu = new KMenu(i18nc("@title:menu", "View Mode"), popup);
QAction* iconsMode = m_mainWindow->actionCollection()->action("icons");
viewModeMenu->addAction(iconsMode);
popup->addSeparator();
+ addRevisionControlActions(popup);
+
QAction* addToPlacesAction = popup->addAction(KIcon("bookmark-new"),
i18nc("@action:inmenu Add current folder to places", "Add to Places"));
addCustomActions(popup);
QAction* propertiesAction = popup->addAction(i18nc("@action:inmenu", "Properties"));
-
+ propertiesAction->setIcon(KIcon("document-properties"));
QAction* action = popup->exec(QCursor::pos());
if (action == propertiesAction) {
const KUrl& url = m_mainWindow->activeViewContainer()->url();
return action;
}
-KonqFileItemCapabilities& DolphinContextMenu::capabilities()
+KFileItemListProperties& DolphinContextMenu::capabilities()
{
if (m_capabilities == 0) {
- m_capabilities = new KonqFileItemCapabilities(m_selectedItems);
+ m_capabilities = new KFileItemListProperties(m_selectedItems);
}
return *m_capabilities;
}
+void DolphinContextMenu::addRevisionControlActions(KMenu* menu)
+{
+ const DolphinView* view = m_mainWindow->activeViewContainer()->view();
+ const QList<QAction*> revControlActions = view->revisionControlActions(m_selectedItems);
+ if (!revControlActions.isEmpty()) {
+ foreach (QAction* action, revControlActions) {
+ menu->addAction(action);
+ }
+ menu->addSeparator();
+ }
+}
+
void DolphinContextMenu::addCustomActions(KMenu* menu)
{
foreach (QAction* action, m_customActions) {