]> cloud.milkyroute.net Git - dolphin.git/blobdiff - src/dolphinmainwindow.cpp
get rid of nasty separator at the top of the information sidebar (thanks to Luca...
[dolphin.git] / src / dolphinmainwindow.cpp
index a25c61038194f1bc6fba2660bc5da3ecdaba4340..102e544049ef0e1445dae36ab426ee7bee5d8d06 100644 (file)
  *   51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA            *\r
  ***************************************************************************/\r
 \r
+#include <config-kmetadata.h>\r
 #include "dolphinmainwindow.h"\r
 \r
 #include <assert.h>\r
 \r
+#include "bookmarkssidebarpage.h"\r
 #include "dolphinapplication.h"\r
 #include "dolphinnewmenu.h"\r
 #include "dolphinsettings.h"\r
 #include "dolphinsettingsdialog.h"\r
 #include "dolphinstatusbar.h"\r
-#include "dolphinapplication.h"\r
-#include "urlnavigator.h"\r
-#include "dolphinsettings.h"\r
-#include "bookmarkssidebarpage.h"\r
 #include "infosidebarpage.h"\r
-#include "generalsettings.h"\r
+#include "metadataloader.h"\r
+#include "mainwindowadaptor.h"\r
+#include "treeviewsidebarpage.h"\r
+#include "urlnavigator.h"\r
 #include "viewpropertiesdialog.h"\r
 #include "viewproperties.h"\r
-#include "mainwindowadaptor.h"\r
+\r
+#include "dolphin_generalsettings.h"\r
 \r
 #include <kaction.h>\r
 #include <kactioncollection.h>\r
@@ -152,21 +154,21 @@ void DolphinMainWindow::dropUrls(const KUrl::List& urls,
 \r
         QString seq = QKeySequence(Qt::ShiftModifier).toString();\r
         seq.chop(1); // chop superfluous '+'\r
-        QAction* moveAction = popup.addAction(KIcon("goto"),\r
-                                              i18n("&Move Here") + "\t" + seq);\r
+        QAction* moveAction = popup.addAction(KIcon("goto-page"),\r
+                                              i18n("&Move Here") + '\t' + seq);\r
 \r
         seq = QKeySequence(Qt::ControlModifier).toString();\r
         seq.chop(1);\r
-        QAction* copyAction = popup.addAction(KIcon("editcopy"),\r
-                                              i18n("&Copy Here") + "\t" + seq);\r
+        QAction* copyAction = popup.addAction(KIcon("edit-copy"),\r
+                                              i18n("&Copy Here") + '\t' + seq);\r
 \r
         seq = QKeySequence(Qt::ControlModifier + Qt::ShiftModifier).toString();\r
         seq.chop(1);\r
         QAction* linkAction = popup.addAction(KIcon("www"),\r
-                                              i18n("&Link Here") + "\t" + seq);\r
+                                              i18n("&Link Here") + '\t' + seq);\r
 \r
         popup.addSeparator();\r
-        popup.addAction(KIcon("stop"), i18n("Cancel"));\r
+        popup.addAction(KIcon("process-stop"), i18n("Cancel"));\r
 \r
         QAction* activatedAction = popup.exec(QCursor::pos());\r
         if (activatedAction == moveAction) {\r
@@ -248,6 +250,13 @@ void DolphinMainWindow::slotViewModeChanged()
     updateViewActions();\r
 }\r
 \r
+void DolphinMainWindow::slotShowPreviewChanged()\r
+{\r
+    // It is not enough to update the 'Show Preview' action, also\r
+    // the 'Zoom In' and 'Zoom Out' actions must be adapted.\r
+    updateViewActions();\r
+}\r
+\r
 void DolphinMainWindow::slotShowHiddenFilesChanged()\r
 {\r
     KToggleAction* showHiddenFilesAction =\r
@@ -320,6 +329,7 @@ void DolphinMainWindow::slotHistoryChanged()
 void DolphinMainWindow::slotUrlChanged(const KUrl& url)\r
 {\r
     updateEditActions();\r
+    updateViewActions();\r
     updateGoActions();\r
     setCaption(url.fileName());\r
 }\r
@@ -360,28 +370,28 @@ void DolphinMainWindow::closeEvent(QCloseEvent* event)
 \r
 void DolphinMainWindow::saveProperties(KConfig* config)\r
 {\r
-    config->setGroup("Primary view");\r
-    config->writeEntry("Url", m_view[PrimaryIdx]->url().url());\r
-    config->writeEntry("Editable Url", m_view[PrimaryIdx]->isUrlEditable());\r
+    KConfigGroup primaryView = config->group("Primary view");\r
+    primaryView.writeEntry("Url", m_view[PrimaryIdx]->url().url());\r
+    primaryView.writeEntry("Editable Url", m_view[PrimaryIdx]->isUrlEditable());\r
     if (m_view[SecondaryIdx] != 0) {\r
-        config->setGroup("Secondary view");\r
-        config->writeEntry("Url", m_view[SecondaryIdx]->url().url());\r
-        config->writeEntry("Editable Url", m_view[SecondaryIdx]->isUrlEditable());\r
+        KConfigGroup secondaryView = config->group("Secondary view");\r
+        secondaryView.writeEntry("Url", m_view[SecondaryIdx]->url().url());\r
+        secondaryView.writeEntry("Editable Url", m_view[SecondaryIdx]->isUrlEditable());\r
     }\r
 }\r
 \r
 void DolphinMainWindow::readProperties(KConfig* config)\r
 {\r
-    config->setGroup("Primary view");\r
-    m_view[PrimaryIdx]->setUrl(config->readEntry("Url"));\r
-    m_view[PrimaryIdx]->setUrlEditable(config->readEntry("Editable Url", false));\r
+    const KConfigGroup primaryView = config->group("Primary view");\r
+    m_view[PrimaryIdx]->setUrl(primaryView.readEntry("Url"));\r
+    m_view[PrimaryIdx]->setUrlEditable(primaryView.readEntry("Editable Url", false));\r
     if (config->hasGroup("Secondary view")) {\r
-        config->setGroup("Secondary view");\r
+        const KConfigGroup secondaryView = config->group("Secondary view");\r
         if (m_view[SecondaryIdx] == 0) {\r
             toggleSplitView();\r
         }\r
-        m_view[SecondaryIdx]->setUrl(config->readEntry("Url"));\r
-        m_view[SecondaryIdx]->setUrlEditable(config->readEntry("Editable Url", false));\r
+        m_view[SecondaryIdx]->setUrl(secondaryView.readEntry("Url"));\r
+        m_view[SecondaryIdx]->setUrlEditable(secondaryView.readEntry("Editable Url", false));\r
     }\r
     else if (m_view[SecondaryIdx] != 0) {\r
         toggleSplitView();\r
@@ -427,8 +437,8 @@ void DolphinMainWindow::deleteItems()
 \r
     const bool del = KMessageBox::warningContinueCancel(this,\r
                                                         text,\r
-                                                        QString::null,\r
-                                                        KGuiItem(i18n("Delete"), KIcon("editdelete"))\r
+                                                        QString(),\r
+                                                        KGuiItem(i18n("Delete"), KIcon("edit-delete"))\r
                                                        ) == KMessageBox::Continue;\r
     if (del) {\r
         KIO::Job* job = KIO::del(list);\r
@@ -590,7 +600,7 @@ void DolphinMainWindow::updatePasteAction()
             pasteAction->setText(i18n("Paste 1 File"));\r
         }\r
         else {\r
-            pasteAction->setText(i18n("Paste %1 Files").arg(count));\r
+            pasteAction->setText(i18n("Paste %1 Files"count));\r
         }\r
     }\r
     else {\r
@@ -909,16 +919,16 @@ void DolphinMainWindow::init()
     assert(manager != 0);\r
     KBookmarkGroup root = manager->root();\r
     if (root.first().isNull()) {\r
-        root.addBookmark(manager, i18n("Home"), settings.generalSettings()->homeUrl(), "folder_home");\r
+        root.addBookmark(manager, i18n("Home"), settings.generalSettings()->homeUrl(), "user-home");\r
         root.addBookmark(manager, i18n("Storage Media"), KUrl("media:/"), "blockdevice");\r
-        root.addBookmark(manager, i18n("Network"), KUrl("remote:/"), "network_local");\r
+        root.addBookmark(manager, i18n("Network"), KUrl("remote:/"), "network-workgroup");\r
         root.addBookmark(manager, i18n("Root"), KUrl("/"), "folder_red");\r
-        root.addBookmark(manager, i18n("Trash"), KUrl("trash:/"), "trashcan_full");\r
+        root.addBookmark(manager, i18n("Trash"), KUrl("trash:/"), "user-trash-full");\r
     }\r
 \r
     setupActions();\r
 \r
-    const KUrl& homeUrl = root.first().url();\r
+    const KUrl& homeUrl = settings.generalSettings()->homeUrl();\r
     setCaption(homeUrl.fileName());\r
     ViewProperties props(homeUrl);\r
     m_view[PrimaryIdx] = new DolphinView(this,\r
@@ -952,6 +962,10 @@ void DolphinMainWindow::init()
         // assure a proper default size if Dolphin runs the first time\r
         resize(640, 480);\r
     }\r
+    #ifdef HAVE_KMETADATA\r
+    if (!DolphinApplication::app()->metadataLoader()->storageUp())\r
+        activeView()->statusBar()->setMessage(i18n("Failed to contact Nepomuk service, annotation and tagging are disabled."), DolphinStatusBar::Error);\r
+    #endif\r
 }\r
 \r
 void DolphinMainWindow::loadSettings()\r
@@ -984,14 +998,15 @@ void DolphinMainWindow::setupActions()
     m_newMenu = new DolphinNewMenu(this);\r
     KMenu* menu = m_newMenu->menu();\r
     menu->setTitle(i18n("Create New..."));\r
-    menu->setIcon(SmallIcon("filenew"));\r
+    menu->setIcon(SmallIcon("document-new"));\r
     connect(menu, SIGNAL(aboutToShow()),\r
             this, SLOT(updateNewMenu()));\r
 \r
-    QAction* action = actionCollection()->addAction("new_window");\r
-    action->setIcon(KIcon("window_new"));\r
-    action->setText(i18n("New &Window"));\r
-    connect(action, SIGNAL(triggered()), this, SLOT(openNewMainWindow()));\r
+    QAction* newWindow = actionCollection()->addAction("new_window");\r
+    newWindow->setIcon(KIcon("window-new"));\r
+    newWindow->setText(i18n("New &Window"));\r
+    newWindow->setShortcut(Qt::CTRL | Qt::Key_N);\r
+    connect(newWindow, SIGNAL(triggered()), this, SLOT(openNewMainWindow()));\r
 \r
     QAction* rename = actionCollection()->addAction("rename");\r
     rename->setText(i18n("Rename"));\r
@@ -1000,14 +1015,14 @@ void DolphinMainWindow::setupActions()
 \r
     QAction* moveToTrash = actionCollection()->addAction("move_to_trash");\r
     moveToTrash->setText(i18n("Move to Trash"));\r
-    moveToTrash->setIcon(KIcon("edittrash"));\r
+    moveToTrash->setIcon(KIcon("edit-trash"));\r
     moveToTrash->setShortcut(QKeySequence::Delete);\r
     connect(moveToTrash, SIGNAL(triggered()), this, SLOT(moveToTrash()));\r
 \r
     QAction* deleteAction = actionCollection()->addAction("delete");\r
     deleteAction->setText(i18n("Delete"));\r
-    deleteAction->setShortcut(Qt::ALT | Qt::Key_Delete);\r
-    deleteAction->setIcon(KIcon("editdelete"));\r
+    deleteAction->setShortcut(Qt::SHIFT | Qt::Key_Delete);\r
+    deleteAction->setIcon(KIcon("edit-delete"));\r
     connect(deleteAction, SIGNAL(triggered()), this, SLOT(deleteItems()));\r
 \r
     QAction* properties = actionCollection()->addAction("properties");\r
@@ -1054,7 +1069,7 @@ void DolphinMainWindow::setupActions()
     KToggleAction* detailsView = actionCollection()->add<KToggleAction>("details");\r
     detailsView->setText(i18n("Details"));\r
     detailsView->setShortcut(Qt::CTRL | Qt::Key_2);\r
-    detailsView->setIcon(KIcon("view_text"));\r
+    detailsView->setIcon(KIcon("fileview-text"));\r
     connect(detailsView, SIGNAL(triggered()), this, SLOT(setDetailsView()));\r
 \r
     QActionGroup* viewModeGroup = new QActionGroup(this);\r
@@ -1115,12 +1130,12 @@ void DolphinMainWindow::setupActions()
     QAction* reload = actionCollection()->addAction("reload");\r
     reload->setText(i18n("Reload"));\r
     reload->setShortcut(Qt::Key_F5);\r
-    reload->setIcon(KIcon("reload"));\r
+    reload->setIcon(KIcon("view-refresh"));\r
     connect(reload, SIGNAL(triggered()), this, SLOT(reloadView()));\r
 \r
     QAction* stop = actionCollection()->addAction("stop");\r
     stop->setText(i18n("Stop"));\r
-    stop->setIcon(KIcon("stop"));\r
+    stop->setIcon(KIcon("process-stop"));\r
     connect(stop, SIGNAL(triggered()), this, SLOT(stopLoading()));\r
 \r
     // TODO: the URL navigator must emit a signal if the editable state has been\r
@@ -1156,7 +1171,7 @@ void DolphinMainWindow::setupActions()
     QAction* findFile = actionCollection()->addAction("find_file");\r
     findFile->setText(i18n("Find File..."));\r
     findFile->setShortcut(Qt::Key_F);\r
-    findFile->setIcon(KIcon("filefind"));\r
+    findFile->setIcon(KIcon("file-find"));\r
     connect(findFile, SIGNAL(triggered()), this, SLOT(findFile()));\r
 \r
     KToggleAction* showFilterBar = actionCollection()->add<KToggleAction>("show_filter_bar");\r
@@ -1176,6 +1191,10 @@ void DolphinMainWindow::setupActions()
 \r
 void DolphinMainWindow::setupDockWidgets()\r
 {\r
+    // TODO: there's a lot copy/paste code here. Provide a generic approach\r
+    // after the dock concept has been finalized.\r
+\r
+    // setup "Bookmarks"\r
     QDockWidget* shortcutsDock = new QDockWidget(i18n("Bookmarks"));\r
     shortcutsDock->setObjectName("bookmarksDock");\r
     shortcutsDock->setAllowedAreas(Qt::LeftDockWidgetArea | Qt::RightDockWidgetArea);\r
@@ -1186,6 +1205,7 @@ void DolphinMainWindow::setupDockWidgets()
 \r
     addDockWidget(Qt::LeftDockWidgetArea, shortcutsDock);\r
 \r
+    // setup "Information"\r
     QDockWidget* infoDock = new QDockWidget(i18n("Information"));\r
     infoDock->setObjectName("infoDock");\r
     infoDock->setAllowedAreas(Qt::LeftDockWidgetArea | Qt::RightDockWidgetArea);\r
@@ -1195,6 +1215,23 @@ void DolphinMainWindow::setupDockWidgets()
     actionCollection()->addAction("show_info_panel", infoDock->toggleViewAction());\r
 \r
     addDockWidget(Qt::RightDockWidgetArea, infoDock);\r
+\r
+    // setup "Tree View"\r
+    QDockWidget* treeViewDock = new QDockWidget(i18n("Folders")); // TODO: naming?\r
+    treeViewDock->setObjectName("treeViewDock");\r
+    treeViewDock->setAllowedAreas(Qt::LeftDockWidgetArea | Qt::RightDockWidgetArea);\r
+    treeViewDock->setWidget(new TreeViewSidebarPage(this));\r
+\r
+    treeViewDock->toggleViewAction()->setText(i18n("Show Folders Panel"));\r
+    actionCollection()->addAction("show_folders_panel", treeViewDock->toggleViewAction());\r
+\r
+    addDockWidget(Qt::LeftDockWidgetArea, treeViewDock);\r
+\r
+    const bool firstRun = DolphinSettings::instance().generalSettings()->firstRun();\r
+    if (firstRun) {\r
+        infoDock->hide();\r
+        treeViewDock->hide();\r
+    }\r
 }\r
 \r
 void DolphinMainWindow::updateHistory()\r
@@ -1283,6 +1320,10 @@ void DolphinMainWindow::updateViewActions()
         static_cast<KToggleAction*>(actionCollection()->action("show_filter_bar"));\r
     showFilterBarAction->setChecked(m_activeView->isFilterBarVisible());\r
 \r
+    KToggleAction* showPreviewAction =\r
+        static_cast<KToggleAction*>(actionCollection()->action("show_preview"));\r
+    showPreviewAction->setChecked(m_activeView->showPreview());\r
+\r
     KToggleAction* showHiddenFilesAction =\r
         static_cast<KToggleAction*>(actionCollection()->action("show_hidden_files"));\r
     showHiddenFilesAction->setChecked(m_activeView->showHiddenFiles());\r
@@ -1330,6 +1371,8 @@ void DolphinMainWindow::connectViewSignals(int viewIndex)
     DolphinView* view = m_view[viewIndex];\r
     connect(view, SIGNAL(modeChanged()),\r
             this, SLOT(slotViewModeChanged()));\r
+    connect(view, SIGNAL(showPreviewChanged()),\r
+            this, SLOT(slotShowPreviewChanged()));\r
     connect(view, SIGNAL(showHiddenFilesChanged()),\r
             this, SLOT(slotShowHiddenFilesChanged()));\r
     connect(view, SIGNAL(sortingChanged(DolphinView::Sorting)),\r