views/dolphincolumnview.cpp
views/dolphincolumnviewcontainer.cpp
views/dolphinmodel.cpp
- views/dolphinnewmenuobserver.cpp
+ views/dolphinnewfilemenuobserver.cpp
views/dolphinremoteencoding.cpp
views/dolphinsortfilterproxymodel.cpp
views/dolphinviewactionhandler.cpp
set(dolphin_SRCS
dolphinapplication.cpp
dolphinmainwindow.cpp
- dolphinnewmenu.cpp
+ dolphinnewfilemenu.cpp
dolphinviewcontainer.cpp
dolphincontextmenu.cpp
filterbar/filterbar.cpp
#include "dolphincontextmenu.h"
#include "dolphinmainwindow.h"
-#include "dolphinnewmenu.h"
+#include "dolphinnewfilemenu.h"
#include "settings/dolphinsettings.h"
#include "dolphinviewcontainer.h"
#include "dolphin_generalsettings.h"
#include <kmenubar.h>
#include <kmessagebox.h>
#include <kmimetypetrader.h>
-#include <knewmenu.h>
+#include <knewfilemenu.h>
#include <konqmimedata.h>
#include <konq_operations.h>
#include <kfileitemactions.h>
KMenu* popup = new KMenu(m_mainWindow);
if (m_fileInfo.isDir() && (m_selectedUrls.count() == 1)) {
// setup 'Create New' menu
- DolphinNewMenu* newMenu = new DolphinNewMenu(popup, m_mainWindow);
+ DolphinNewFileMenu* newFileMenu = new DolphinNewFileMenu(popup, m_mainWindow);
const DolphinView* view = m_mainWindow->activeViewContainer()->view();
- newMenu->setViewShowsHiddenFiles(view->showHiddenFiles());
- newMenu->checkUpToDate();
- newMenu->setPopupFiles(m_fileInfo.url());
- newMenu->setEnabled(capabilities().supportsWriting());
+ newFileMenu->setViewShowsHiddenFiles(view->showHiddenFiles());
+ newFileMenu->checkUpToDate();
+ newFileMenu->setPopupFiles(m_fileInfo.url());
+ newFileMenu->setEnabled(capabilities().supportsWriting());
- KMenu* menu = newMenu->menu();
+ KMenu* menu = newFileMenu->menu();
menu->setTitle(i18nc("@title:menu Create new folder, file, link, etc.", "Create New"));
menu->setIcon(KIcon("document-new"));
- popup->addMenu(newMenu->menu());
+ popup->addMenu(menu);
popup->addSeparator();
// insert 'Open in new window' and 'Open in new tab' entries
popup->addSeparator();
- // insert 'Bookmark This Folder' entry if exactly one item is selected
- QAction* addToPlacesAction = 0;
- if (m_fileInfo.isDir() && (m_selectedUrls.count() == 1)) {
- addToPlacesAction = popup->addAction(KIcon("bookmark-new"),
- i18nc("@action:inmenu Add selected folder to places", "Add to Places"));
- // Don't show if url is already in places
- if (placeExists(m_fileInfo.url())) {
- addToPlacesAction->setVisible(false);
- }
- }
+ KFileItemActions fileItemActions;
+ fileItemActions.setItemListProperties(capabilities());
+ addServiceActions(popup, fileItemActions);
- KFileItemActions menuActions;
- menuActions.setParentWidget(m_mainWindow);
- menuActions.setItemListProperties(m_selectedItems);
-
- // insert 'Open With...' action or sub menu
- menuActions.addOpenWithActionsTo(popup, "DesktopEntryName != 'dolphin'");
-
- // insert 'Actions' sub menu
- if (menuActions.addServiceActionsTo(popup)) {
- popup->addSeparator();
- }
-
- // insert version control actions
addVersionControlActions(popup);
// insert 'Copy To' and 'Move To' sub menus
popup->addSeparator();
}
+ // insert 'Add to Places' entry if exactly one item is selected
+ QAction* addToPlacesAction = 0;
+ if (m_fileInfo.isDir() && (m_selectedUrls.count() == 1) && !placeExists(m_fileInfo.url())) {
+ addToPlacesAction = popup->addAction(KIcon("bookmark-new"),
+ i18nc("@action:inmenu Add selected folder to places", "Add to Places"));
+ }
+
// insert 'Properties...' entry
QAction* propertiesAction = m_mainWindow->actionCollection()->action("properties");
popup->addAction(propertiesAction);
addShowMenubarAction(popup);
// setup 'Create New' menu
- KNewFileMenu* newMenu = m_mainWindow->newMenu();
+ KNewFileMenu* newFileMenu = m_mainWindow->newFileMenu();
const DolphinView* view = m_mainWindow->activeViewContainer()->view();
- newMenu->setViewShowsHiddenFiles(view->showHiddenFiles());
- newMenu->checkUpToDate();
- newMenu->setPopupFiles(m_baseUrl);
- popup->addMenu(newMenu->menu());
+ newFileMenu->setViewShowsHiddenFiles(view->showHiddenFiles());
+ newFileMenu->checkUpToDate();
+ newFileMenu->setPopupFiles(m_baseUrl);
+ popup->addMenu(newFileMenu->menu());
+ popup->addSeparator();
+
+ // insert 'Open in new window' and 'Open in new tab' entries
+ popup->addAction(m_mainWindow->actionCollection()->action("open_in_new_window"));
+ popup->addAction(m_mainWindow->actionCollection()->action("open_in_new_tab"));
popup->addSeparator();
QAction* pasteAction = createPasteAction();
popup->addAction(pasteAction);
-
- // setup 'View Mode' menu
- KMenu* viewModeMenu = new KMenu(i18nc("@title:menu", "View Mode"), popup);
-
- QAction* iconsMode = m_mainWindow->actionCollection()->action("icons");
- viewModeMenu->addAction(iconsMode);
-
- QAction* detailsMode = m_mainWindow->actionCollection()->action("details");
- viewModeMenu->addAction(detailsMode);
-
- QAction* columnsMode = m_mainWindow->actionCollection()->action("columns");
- viewModeMenu->addAction(columnsMode);
-
- popup->addMenu(viewModeMenu);
-
popup->addSeparator();
- addVersionControlActions(popup);
+ // insert service actions
+ const KFileItem item(KFileItem::Unknown, KFileItem::Unknown, m_baseUrl);
+ const KFileItemListProperties baseUrlProperties(KFileItemList() << item);
+ KFileItemActions fileItemActions;
+ fileItemActions.setItemListProperties(baseUrlProperties);
+ addServiceActions(popup, fileItemActions);
- QAction* addToPlacesAction = popup->addAction(KIcon("bookmark-new"),
- i18nc("@action:inmenu Add current folder to places", "Add to Places"));
+ addVersionControlActions(popup);
- // Don't show if url is already in places
- if (placeExists(m_mainWindow->activeViewContainer()->url())) {
- addToPlacesAction->setVisible(false);
+ // insert 'Add to Places' entry if exactly one item is selected
+ QAction* addToPlacesAction = 0;
+ if (!placeExists(m_mainWindow->activeViewContainer()->url())) {
+ addToPlacesAction = popup->addAction(KIcon("bookmark-new"),
+ i18nc("@action:inmenu Add current folder to places", "Add to Places"));
}
addCustomActions(popup);
KPropertiesDialog* dialog = new KPropertiesDialog(url, m_mainWindow);
dialog->setAttribute(Qt::WA_DeleteOnClose);
dialog->show();
- } else if (action == addToPlacesAction) {
+ } else if ((addToPlacesAction != 0) && (action == addToPlacesAction)) {
const KUrl& url = m_mainWindow->activeViewContainer()->url();
if (url.isValid()) {
DolphinSettings::instance().placesModel()->addPlace(placesName(url), url);
return *m_capabilities;
}
+void DolphinContextMenu::addServiceActions(KMenu* menu, KFileItemActions& fileItemActions)
+{
+ fileItemActions.setParentWidget(m_mainWindow);
+
+ // insert 'Open With...' action or sub menu
+ fileItemActions.addOpenWithActionsTo(menu, "DesktopEntryName != 'dolphin'");
+
+ // insert 'Actions' sub menu
+ if (fileItemActions.addServiceActionsTo(menu)) {
+ menu->addSeparator();
+ }
+}
+
void DolphinContextMenu::addVersionControlActions(KMenu* menu)
{
const DolphinView* view = m_mainWindow->activeViewContainer()->view();
class KFileItem;
class QAction;
class DolphinMainWindow;
+class KFileItemActions;
class KFileItemListProperties;
/**
private:
KFileItemListProperties& capabilities();
+ void addServiceActions(KMenu* menu, KFileItemActions& fileItemActions);
void addVersionControlActions(KMenu* menu);
void addCustomActions(KMenu* menu);
#include "dolphinapplication.h"
#include "dolphincontextmenu.h"
-#include "dolphinnewmenu.h"
+#include "dolphinnewfilemenu.h"
#include "dolphinviewcontainer.h"
#include "mainwindowadaptor.h"
#include "panels/folders/folderspanel.h"
DolphinMainWindow::DolphinMainWindow(int id) :
KXmlGuiWindow(0),
- m_newMenu(0),
+ m_newFileMenu(0),
m_showMenuBar(0),
m_tabBar(0),
m_activeViewContainer(0),
void DolphinMainWindow::updateNewMenu()
{
- m_newMenu->setViewShowsHiddenFiles(activeViewContainer()->view()->showHiddenFiles());
- m_newMenu->checkUpToDate();
- m_newMenu->setPopupFiles(activeViewContainer()->url());
+ m_newFileMenu->setViewShowsHiddenFiles(activeViewContainer()->view()->showHiddenFiles());
+ m_newFileMenu->checkUpToDate();
+ m_newFileMenu->setPopupFiles(activeViewContainer()->url());
}
void DolphinMainWindow::createDirectory()
{
- m_newMenu->setViewShowsHiddenFiles(activeViewContainer()->view()->showHiddenFiles());
- m_newMenu->setPopupFiles(activeViewContainer()->url());
- m_newMenu->createDirectory();
+ m_newFileMenu->setViewShowsHiddenFiles(activeViewContainer()->view()->showHiddenFiles());
+ m_newFileMenu->setPopupFiles(activeViewContainer()->url());
+ m_newFileMenu->createDirectory();
}
void DolphinMainWindow::quit()
void DolphinMainWindow::slotWriteStateChanged(bool isFolderWritable)
{
- newMenu()->setEnabled(isFolderWritable);
+ newFileMenu()->setEnabled(isFolderWritable);
}
void DolphinMainWindow::openContextMenu(const KFileItem& item,
void DolphinMainWindow::setupActions()
{
// setup 'File' menu
- m_newMenu = new DolphinNewMenu(this, this);
- KMenu* menu = m_newMenu->menu();
+ m_newFileMenu = new DolphinNewFileMenu(this, this);
+ KMenu* menu = m_newFileMenu->menu();
menu->setTitle(i18nc("@title:menu Create new folder, file, link, etc.", "Create New"));
menu->setIcon(KIcon("document-new"));
connect(menu, SIGNAL(aboutToShow()),
* Returns the 'Create New...' sub menu which also can be shared
* with other menus (e. g. a context menu).
*/
- KNewFileMenu* newMenu() const;
+ KNewFileMenu* newFileMenu() const;
/**
* Returns the 'Show Menubar' action which can be shared with
virtual void jobError(KIO::Job* job);
};
- KNewFileMenu* m_newMenu;
+ KNewFileMenu* m_newFileMenu;
KActionMenu* m_recentTabsMenu;
KAction* m_showMenuBar;
KTabBar* m_tabBar;
return m_viewTab[m_tabIndex].secondaryView != 0;
}
-inline KNewFileMenu* DolphinMainWindow::newMenu() const
+inline KNewFileMenu* DolphinMainWindow::newFileMenu() const
{
- return m_newMenu;
+ return m_newFileMenu;
}
inline KAction* DolphinMainWindow::showMenuBarAction() const
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
***************************************************************************/
-#include "dolphinnewmenu.h"
+#include "dolphinnewfilemenu.h"
#include "dolphinmainwindow.h"
#include "dolphinviewcontainer.h"
#include "statusbar/dolphinstatusbar.h"
-#include "views/dolphinnewmenuobserver.h"
+#include "views/dolphinnewfilemenuobserver.h"
#include "views/dolphinview.h"
#include <kactioncollection.h>
#include <kio/job.h>
-DolphinNewMenu::DolphinNewMenu(QWidget* parent, DolphinMainWindow* mainWin) :
+DolphinNewFileMenu::DolphinNewFileMenu(QWidget* parent, DolphinMainWindow* mainWin) :
KNewFileMenu(mainWin->actionCollection(), "create_new", parent),
m_mainWin(mainWin)
{
- DolphinNewMenuObserver::instance().attach(this);
+ DolphinNewFileMenuObserver::instance().attach(this);
}
-DolphinNewMenu::~DolphinNewMenu()
+DolphinNewFileMenu::~DolphinNewFileMenu()
{
- DolphinNewMenuObserver::instance().detach(this);
+ DolphinNewFileMenuObserver::instance().detach(this);
}
-void DolphinNewMenu::slotResult(KJob* job)
+void DolphinNewFileMenu::slotResult(KJob* job)
{
if (job->error()) {
DolphinStatusBar* statusBar = m_mainWin->activeViewContainer()->statusBar();
}
}
-#include "dolphinnewmenu.moc"
+#include "dolphinnewfilemenu.moc"
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
***************************************************************************/
-#ifndef DOLPHINNEWMENU_H
-#define DOLPHINNEWMENU_H
+#ifndef DOLPHINNEWFILEMENU_H
+#define DOLPHINNEWFILEMENU_H
-#include <knewmenu.h>
+#include <knewfilemenu.h>
class DolphinMainWindow;
class KJob;
* All errors are shown in the status bar of Dolphin
* instead as modal error dialog with an OK button.
*/
-class DolphinNewMenu : public KNewFileMenu
+class DolphinNewFileMenu : public KNewFileMenu
{
Q_OBJECT
public:
- DolphinNewMenu(QWidget* parent, DolphinMainWindow* mainWin);
- virtual ~DolphinNewMenu();
+ DolphinNewFileMenu(QWidget* parent, DolphinMainWindow* mainWin);
+ virtual ~DolphinNewFileMenu();
protected slots:
/** @see KNewFileMenu::slotResult() */
#include "views/dolphinviewactionhandler.h"
#include "views/dolphinsortfilterproxymodel.h"
#include "views/dolphinmodel.h"
-#include "views/dolphinnewmenuobserver.h"
+#include "views/dolphinnewfilemenuobserver.h"
#include "views/dolphinremoteencoding.h"
#include <QActionGroup>
DolphinPart::~DolphinPart()
{
DolphinSettings::instance().save();
- DolphinNewMenuObserver::instance().detach(m_newMenu);
+ DolphinNewFileMenuObserver::instance().detach(m_newFileMenu);
delete m_dirLister;
}
{
// Edit menu
- m_newMenu = new KNewFileMenu(actionCollection(), "new_menu", this);
- m_newMenu->setParentWidget(widget());
- DolphinNewMenuObserver::instance().attach(m_newMenu);
- connect(m_newMenu->menu(), SIGNAL(aboutToShow()),
+ m_newFileMenu = new KNewFileMenu(actionCollection(), "new_menu", this);
+ m_newFileMenu->setParentWidget(widget());
+ DolphinNewFileMenuObserver::instance().attach(m_newFileMenu);
+ connect(m_newFileMenu->menu(), SIGNAL(aboutToShow()),
this, SLOT(updateNewMenu()));
KAction *editMimeTypeAction = actionCollection()->addAction( "editMimeType" );
void DolphinPart::updateNewMenu()
{
// As requested by KNewFileMenu :
- m_newMenu->checkUpToDate();
- m_newMenu->setViewShowsHiddenFiles(m_view->showHiddenFiles());
+ m_newFileMenu->checkUpToDate();
+ m_newFileMenu->setViewShowsHiddenFiles(m_view->showHiddenFiles());
// And set the files that the menu apply on :
- m_newMenu->setPopupFiles(url());
+ m_newFileMenu->setPopupFiles(url());
}
void DolphinPart::updateStatusBar()
void DolphinPart::createDirectory()
{
- m_newMenu->setViewShowsHiddenFiles(m_view->showHiddenFiles());
- m_newMenu->setPopupFiles(url());
- m_newMenu->createDirectory();
+ m_newFileMenu->setViewShowsHiddenFiles(m_view->showHiddenFiles());
+ m_newFileMenu->setPopupFiles(url());
+ m_newFileMenu->createDirectory();
}
void DolphinPart::setFilesToSelect(const KUrl::List& files)
DolphinModel* m_dolphinModel;
DolphinSortFilterProxyModel* m_proxyModel;
DolphinPartBrowserExtension* m_extension;
- KNewFileMenu* m_newMenu;
+ KNewFileMenu* m_newFileMenu;
QString m_nameFilter;
Q_DISABLE_COPY(DolphinPart)
};
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
***************************************************************************/
-#include "dolphinnewmenuobserver.h"
+#include "dolphinnewfilemenuobserver.h"
#include <kglobal.h>
#include <knewmenu.h>
-class DolphinNewMenuObserverSingleton
+class DolphinNewFileMenuObserverSingleton
{
public:
- DolphinNewMenuObserver instance;
+ DolphinNewFileMenuObserver instance;
};
-K_GLOBAL_STATIC(DolphinNewMenuObserverSingleton, s_dolphinNewMenuObserver)
+K_GLOBAL_STATIC(DolphinNewFileMenuObserverSingleton, s_DolphinNewFileMenuObserver)
-DolphinNewMenuObserver& DolphinNewMenuObserver::instance()
+DolphinNewFileMenuObserver& DolphinNewFileMenuObserver::instance()
{
- return s_dolphinNewMenuObserver->instance;
+ return s_DolphinNewFileMenuObserver->instance;
}
-void DolphinNewMenuObserver::attach(const KNewFileMenu* menu)
+void DolphinNewFileMenuObserver::attach(const KNewFileMenu* menu)
{
connect(menu, SIGNAL(fileCreated(const KUrl&)),
this, SIGNAL(itemCreated(const KUrl&)));
this, SIGNAL(itemCreated(const KUrl&)));
}
-void DolphinNewMenuObserver::detach(const KNewFileMenu* menu)
+void DolphinNewFileMenuObserver::detach(const KNewFileMenu* menu)
{
disconnect(menu, SIGNAL(fileCreated(const KUrl&)),
this, SIGNAL(itemCreated(const KUrl&)));
this, SIGNAL(itemCreated(const KUrl&)));
}
-DolphinNewMenuObserver::DolphinNewMenuObserver() :
+DolphinNewFileMenuObserver::DolphinNewFileMenuObserver() :
QObject(0)
{
}
-DolphinNewMenuObserver::~DolphinNewMenuObserver()
+DolphinNewFileMenuObserver::~DolphinNewFileMenuObserver()
{
}
-#include "dolphinnewmenuobserver.moc"
+#include "dolphinnewfilemenuobserver.moc"
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
***************************************************************************/
-#ifndef DOLPHINNEWMENUOBSERVER_H
-#define DOLPHINNEWMENUOBSERVER_H
+#ifndef DOLPHINNEWFILEMENUOBSERVER_H
+#define DOLPHINNEWFILEMENUOBSERVER_H
#include <QObject>
/**
* @brief Allows to observe new file items that have been created
- * by a DolphinNewMenu instance.
+ * by a DolphinNewFileMenu instance.
*
- * As soon as a DolphinNewMenu instance created a new item,
+ * As soon as a DolphinNewFileMenu instance created a new item,
* the observer will emit the signal itemCreated().
*/
-class LIBDOLPHINPRIVATE_EXPORT DolphinNewMenuObserver : public QObject
+class LIBDOLPHINPRIVATE_EXPORT DolphinNewFileMenuObserver : public QObject
{
Q_OBJECT
public:
- static DolphinNewMenuObserver& instance();
+ static DolphinNewFileMenuObserver& instance();
void attach(const KNewFileMenu* menu);
void detach(const KNewFileMenu* menu);
void itemCreated(const KUrl& url);
private:
- DolphinNewMenuObserver();
- virtual ~DolphinNewMenuObserver();
+ DolphinNewFileMenuObserver();
+ virtual ~DolphinNewFileMenuObserver();
- friend class DolphinNewMenuObserverSingleton;
+ friend class DolphinNewFileMenuObserverSingleton;
};
#endif
#include "dolphinviewcontroller.h"
#include "dolphindetailsview.h"
#include "dolphinfileitemdelegate.h"
-#include "dolphinnewmenuobserver.h"
+#include "dolphinnewfilemenuobserver.h"
#include "dolphinsortfilterproxymodel.h"
#include "dolphin_detailsmodesettings.h"
#include "dolphiniconsview.h"
// When a new item has been created by the "Create New..." menu, the item should
// get selected and it must be assured that the item will get visible. As the
// creation is done asynchronously, several signals must be checked:
- connect(&DolphinNewMenuObserver::instance(), SIGNAL(itemCreated(const KUrl&)),
+ connect(&DolphinNewFileMenuObserver::instance(), SIGNAL(itemCreated(const KUrl&)),
this, SLOT(observeCreatedItem(const KUrl&)));
m_selectionChangedTimer = new QTimer(this);