]> cloud.milkyroute.net Git - dolphin.git/blobdiff - src/dolphinmainwindow.cpp
For all Zecke thoughts a nice solution could be found during the last weeks :-)
[dolphin.git] / src / dolphinmainwindow.cpp
index dc46a942984bf539eec0c3be440331d570af488d..5183f993d31971e0c895df9343a4ca2549ad0c4c 100644 (file)
@@ -22,8 +22,6 @@
 #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
@@ -58,6 +56,7 @@
 #include <kmenu.h>\r
 #include <kmessagebox.h>\r
 #include <konqmimedata.h>\r
+#include <konq_operations.h>\r
 #include <kpropertiesdialog.h>\r
 #include <kprotocolinfo.h>\r
 #include <ktoggleaction.h>\r
@@ -106,7 +105,7 @@ DolphinMainWindow::~DolphinMainWindow()
 \r
 void DolphinMainWindow::setActiveView(DolphinView* view)\r
 {\r
-    assert((view == m_view[PrimaryIdx]) || (view == m_view[SecondaryIdx]));\r
+    Q_ASSERT((view == m_view[PrimaryIdx]) || (view == m_view[SecondaryIdx]));\r
     if (m_activeView == view) {\r
         return;\r
     }\r
@@ -203,6 +202,12 @@ void DolphinMainWindow::dropUrls(const KUrl::List& urls,
     }\r
 }\r
 \r
+void DolphinMainWindow::rename(const KUrl& oldUrl, const KUrl& newUrl)\r
+{\r
+    KonqOperations::rename(this, oldUrl, newUrl);\r
+    m_undoCommandTypes.append(KonqUndoManager::RENAME);\r
+}\r
+\r
 void DolphinMainWindow::refreshViews()\r
 {\r
     const bool split = DolphinSettings::instance().generalSettings()->splitView();\r
@@ -232,7 +237,7 @@ void DolphinMainWindow::refreshViews()
     }\r
 \r
     m_activeView = isPrimaryViewActive ? m_view[PrimaryIdx] : m_view[SecondaryIdx];\r
-    assert(m_activeView != 0);\r
+    Q_ASSERT(m_activeView != 0);\r
 \r
     updateViewActions();\r
     emit activeViewChanged();\r
@@ -303,11 +308,40 @@ void DolphinMainWindow::slotSortOrderChanged(Qt::SortOrder order)
     descending->setChecked(sortDescending);\r
 }\r
 \r
+void DolphinMainWindow::slotAdditionalInfoChanged(KFileItemDelegate::AdditionalInformation info)\r
+{\r
+    QAction* action = 0;\r
+    switch (info) {\r
+        case KFileItemDelegate::FriendlyMimeType:\r
+            action = actionCollection()->action("show_mime_info");\r
+            break;\r
+        case KFileItemDelegate::Size:\r
+            action = actionCollection()->action("show_size_info");\r
+            break;\r
+        case KFileItemDelegate::ModificationTime:\r
+            action = actionCollection()->action("show_date_info");\r
+            break;\r
+        case KFileItemDelegate::NoInformation:\r
+        default:\r
+            action = actionCollection()->action("clear_info");\r
+            break;\r
+    }\r
+\r
+    if (action != 0) {\r
+        KToggleAction* toggleAction = static_cast<KToggleAction*>(action);\r
+        toggleAction->setChecked(true);\r
+\r
+        QActionGroup* group = toggleAction->actionGroup();\r
+        Q_ASSERT(group != 0);\r
+        group->setEnabled(m_activeView->mode() == DolphinView::IconsView);\r
+    }\r
+}\r
+\r
 void DolphinMainWindow::slotSelectionChanged()\r
 {\r
     updateEditActions();\r
 \r
-    assert(m_view[PrimaryIdx] != 0);\r
+    Q_ASSERT(m_view[PrimaryIdx] != 0);\r
     int selectedUrlsCount = m_view[PrimaryIdx]->selectedUrls().count();\r
     if (m_view[SecondaryIdx] != 0) {\r
         selectedUrlsCount += m_view[SecondaryIdx]->selectedUrls().count();\r
@@ -415,7 +449,7 @@ void DolphinMainWindow::moveToTrash()
     clearStatusBar();\r
     const KUrl::List selectedUrls = m_activeView->selectedUrls();\r
     KonqOperations::del(this, KonqOperations::TRASH, selectedUrls);\r
-    m_undoOperations.append(KonqOperations::TRASH);\r
+    m_undoCommandTypes.append(KonqUndoManager::TRASH);\r
 }\r
 \r
 void DolphinMainWindow::deleteItems()\r
@@ -424,7 +458,7 @@ void DolphinMainWindow::deleteItems()
 \r
     KUrl::List list = m_activeView->selectedUrls();\r
     const uint itemCount = list.count();\r
-    assert(itemCount >= 1);\r
+    Q_ASSERT(itemCount >= 1);\r
 \r
     QString text;\r
     if (itemCount > 1) {\r
@@ -485,26 +519,36 @@ void DolphinMainWindow::slotUndoAvailable(bool available)
         undoAction->setEnabled(available);\r
     }\r
 \r
-    if (available && (m_undoOperations.count() > 0)) {\r
-        const KonqOperations::Operation op = m_undoOperations.takeFirst();\r
+    if (available && (m_undoCommandTypes.count() > 0)) {\r
+        const KonqUndoManager::CommandType command = m_undoCommandTypes.takeFirst();\r
         DolphinStatusBar* statusBar = m_activeView->statusBar();\r
-        switch (op) {\r
-            case KonqOperations::COPY:\r
+        switch (command) {\r
+            case KonqUndoManager::COPY:\r
                 statusBar->setMessage(i18n("Copy operation completed."),\r
                                       DolphinStatusBar::OperationCompleted);\r
                 break;\r
-            case KonqOperations::MOVE:\r
+            case KonqUndoManager::MOVE:\r
                 statusBar->setMessage(i18n("Move operation completed."),\r
                                       DolphinStatusBar::OperationCompleted);\r
                 break;\r
-            case KonqOperations::LINK:\r
+            case KonqUndoManager::LINK:\r
                 statusBar->setMessage(i18n("Link operation completed."),\r
                                       DolphinStatusBar::OperationCompleted);\r
                 break;\r
-            case KonqOperations::TRASH:\r
+            case KonqUndoManager::TRASH:\r
                 statusBar->setMessage(i18n("Move to trash operation completed."),\r
                                       DolphinStatusBar::OperationCompleted);\r
                 break;\r
+            case KonqUndoManager::RENAME:\r
+                statusBar->setMessage(i18n("Renaming operation completed."),\r
+                                      DolphinStatusBar::OperationCompleted);\r
+                break;\r
+\r
+           case KonqUndoManager::MKDIR:\r
+                statusBar->setMessage(i18n("Created directory."),\r
+                                      DolphinStatusBar::OperationCompleted);\r
+                break;\r
+\r
             default:\r
                 break;\r
         }\r
@@ -528,11 +572,32 @@ void DolphinMainWindow::undo()
 \r
 void DolphinMainWindow::cut()\r
 {\r
+    QClipboard* clipboard = QApplication::clipboard();\r
+    const QMimeData* currentMimeData = clipboard->mimeData();\r
+    const bool hadCutSelection = KonqMimeData::decodeIsCutSelection(currentMimeData);\r
+\r
     QMimeData* mimeData = new QMimeData();\r
     const KUrl::List kdeUrls = m_activeView->selectedUrls();\r
     const KUrl::List mostLocalUrls;\r
     KonqMimeData::populateMimeData(mimeData, kdeUrls, mostLocalUrls, true);\r
     QApplication::clipboard()->setMimeData(mimeData);\r
+\r
+    if (hadCutSelection) {\r
+        // If an old cut selection has been applied, the view must\r
+        // be reloaded to get the original icons of the items without an\r
+        // applied item effect.\r
+        m_view[PrimaryIdx]->reload();\r
+        if (m_view[SecondaryIdx] != 0) {\r
+            m_view[SecondaryIdx]->reload();\r
+        }\r
+    }\r
+    else {\r
+        // apply an item effect for the icons of all cut items\r
+        m_view[PrimaryIdx]->updateCutItems();\r
+        if (m_view[SecondaryIdx] != 0) {\r
+            m_view[SecondaryIdx]->updateCutItems();\r
+        }\r
+    }\r
 }\r
 \r
 void DolphinMainWindow::copy()\r
@@ -595,13 +660,7 @@ void DolphinMainWindow::updatePasteAction()
     if (!urls.isEmpty()) {\r
         pasteAction->setEnabled(true);\r
 \r
-        const int count = urls.count();\r
-        if (count == 1) {\r
-            pasteAction->setText(i18n("Paste 1 File"));\r
-        }\r
-        else {\r
-            pasteAction->setText(i18n("Paste %1 Files", count));\r
-        }\r
+        pasteAction->setText(i18np("Paste One File", "Paste %1 Files", urls.count()));\r
     }\r
     else {\r
         pasteAction->setEnabled(false);\r
@@ -689,6 +748,29 @@ void DolphinMainWindow::toggleSortOrder()
     m_activeView->setSortOrder(order);\r
 }\r
 \r
+void DolphinMainWindow::clearInfo()\r
+{\r
+    m_activeView->setAdditionalInfo(KFileItemDelegate::NoInformation);\r
+}\r
+\r
+void DolphinMainWindow::showMimeInfo()\r
+{\r
+    clearStatusBar();\r
+    m_activeView->setAdditionalInfo(KFileItemDelegate::FriendlyMimeType);\r
+}\r
+\r
+void DolphinMainWindow::showSizeInfo()\r
+{\r
+    clearStatusBar();\r
+    m_activeView->setAdditionalInfo(KFileItemDelegate::Size);\r
+}\r
+\r
+void DolphinMainWindow::showDateInfo()\r
+{\r
+    clearStatusBar();\r
+    m_activeView->setAdditionalInfo(KFileItemDelegate::ModificationTime);\r
+}\r
+\r
 void DolphinMainWindow::toggleSplitView()\r
 {\r
     if (m_view[SecondaryIdx] == 0) {\r
@@ -845,7 +927,7 @@ void DolphinMainWindow::compareFiles()
     // - both in the secondary view\r
     // - one in the primary view and the other in the secondary\r
     //   view\r
-    assert(m_view[PrimaryIdx] != 0);\r
+    Q_ASSERT(m_view[PrimaryIdx] != 0);\r
 \r
     KUrl urlA;\r
     KUrl urlB;\r
@@ -853,9 +935,9 @@ void DolphinMainWindow::compareFiles()
 \r
     switch (urls.count()) {\r
         case 0: {\r
-            assert(m_view[SecondaryIdx] != 0);\r
+            Q_ASSERT(m_view[SecondaryIdx] != 0);\r
             urls = m_view[SecondaryIdx]->selectedUrls();\r
-            assert(urls.count() == 2);\r
+            Q_ASSERT(urls.count() == 2);\r
             urlA = urls[0];\r
             urlB = urls[1];\r
             break;\r
@@ -863,9 +945,9 @@ void DolphinMainWindow::compareFiles()
 \r
         case 1: {\r
             urlA = urls[0];\r
-            assert(m_view[SecondaryIdx] != 0);\r
+            Q_ASSERT(m_view[SecondaryIdx] != 0);\r
             urls = m_view[SecondaryIdx]->selectedUrls();\r
-            assert(urls.count() == 1);\r
+            Q_ASSERT(urls.count() == 1);\r
             urlB = urls[0];\r
             break;\r
         }\r
@@ -879,7 +961,7 @@ void DolphinMainWindow::compareFiles()
         default: {\r
             // may not happen: compareFiles may only get invoked if 2\r
             // files are selected\r
-            assert(false);\r
+            Q_ASSERT(false);\r
         }\r
     }\r
 \r
@@ -916,7 +998,7 @@ void DolphinMainWindow::init()
     DolphinSettings& settings = DolphinSettings::instance();\r
 \r
     KBookmarkManager* manager = settings.bookmarkManager();\r
-    assert(manager != 0);\r
+    Q_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
@@ -1112,6 +1194,28 @@ void DolphinMainWindow::setupActions()
     sortDescending->setText(i18n("Descending"));\r
     connect(sortDescending, SIGNAL(triggered()), this, SLOT(toggleSortOrder()));\r
 \r
+    KToggleAction* clearInfo = actionCollection()->add<KToggleAction>("clear_info");\r
+    clearInfo->setText(i18n("No Information"));\r
+    connect(clearInfo, SIGNAL(triggered()), this, SLOT(clearInfo()));\r
+\r
+    KToggleAction* showMimeInfo = actionCollection()->add<KToggleAction>("show_mime_info");\r
+    showMimeInfo->setText(i18n("Type"));\r
+    connect(showMimeInfo, SIGNAL(triggered()), this, SLOT(showMimeInfo()));\r
+\r
+    KToggleAction* showSizeInfo = actionCollection()->add<KToggleAction>("show_size_info");\r
+    showSizeInfo->setText(i18n("Size"));\r
+    connect(showSizeInfo, SIGNAL(triggered()), this, SLOT(showSizeInfo()));\r
+\r
+    KToggleAction* showDateInfo = actionCollection()->add<KToggleAction>("show_date_info");\r
+    showDateInfo->setText(i18n("Date"));\r
+    connect(showDateInfo, SIGNAL(triggered()), this, SLOT(showDateInfo()));\r
+\r
+    QActionGroup* infoGroup = new QActionGroup(this);\r
+    infoGroup->addAction(clearInfo);\r
+    infoGroup->addAction(showMimeInfo);\r
+    infoGroup->addAction(showSizeInfo);\r
+    infoGroup->addAction(showDateInfo);\r
+\r
     KToggleAction* showPreview = actionCollection()->add<KToggleAction>("show_preview");\r
     showPreview->setText(i18n("Preview"));\r
     showPreview->setIcon(KIcon("thumbnail-show"));\r
@@ -1316,6 +1420,7 @@ void DolphinMainWindow::updateViewActions()
 \r
     slotSortingChanged(m_activeView->sorting());\r
     slotSortOrderChanged(m_activeView->sortOrder());\r
+    slotAdditionalInfoChanged(m_activeView->additionalInfo());\r
 \r
     KToggleAction* showFilterBarAction =\r
         static_cast<KToggleAction*>(actionCollection()->action("show_filter_bar"));\r
@@ -1347,19 +1452,19 @@ void DolphinMainWindow::updateGoActions()
 void DolphinMainWindow::copyUrls(const KUrl::List& source, const KUrl& dest)\r
 {\r
     KonqOperations::copy(this, KonqOperations::COPY, source, dest);\r
-    m_undoOperations.append(KonqOperations::COPY);\r
+    m_undoCommandTypes.append(KonqUndoManager::COPY);\r
 }\r
 \r
 void DolphinMainWindow::moveUrls(const KUrl::List& source, const KUrl& dest)\r
 {\r
     KonqOperations::copy(this, KonqOperations::MOVE, source, dest);\r
-    m_undoOperations.append(KonqOperations::MOVE);\r
+    m_undoCommandTypes.append(KonqUndoManager::MOVE);\r
 }\r
 \r
 void DolphinMainWindow::linkUrls(const KUrl::List& source, const KUrl& dest)\r
 {\r
     KonqOperations::copy(this, KonqOperations::LINK, source, dest);\r
-    m_undoOperations.append(KonqOperations::LINK);\r
+    m_undoCommandTypes.append(KonqUndoManager::LINK);\r
 }\r
 \r
 void DolphinMainWindow::clearStatusBar()\r
@@ -1380,6 +1485,8 @@ void DolphinMainWindow::connectViewSignals(int viewIndex)
             this, SLOT(slotSortingChanged(DolphinView::Sorting)));\r
     connect(view, SIGNAL(sortOrderChanged(Qt::SortOrder)),\r
             this, SLOT(slotSortOrderChanged(Qt::SortOrder)));\r
+    connect(view, SIGNAL(additionalInfoChanged(KFileItemDelegate::AdditionalInformation)),\r
+            this, SLOT(slotAdditionalInfoChanged(KFileItemDelegate::AdditionalInformation)));\r
     connect(view, SIGNAL(selectionChanged()),\r
             this, SLOT(slotSelectionChanged()));\r
     connect(view, SIGNAL(showFilterBarChanged(bool)),\r
@@ -1397,7 +1504,7 @@ DolphinMainWindow::UndoUiInterface::UndoUiInterface(DolphinMainWindow* mainWin)
     KonqUndoManager::UiInterface(mainWin),\r
     m_mainWin(mainWin)\r
 {\r
-    assert(m_mainWin != 0);\r
+    Q_ASSERT(m_mainWin != 0);\r
 }\r
 \r
 DolphinMainWindow::UndoUiInterface::~UndoUiInterface()\r