X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/7e61bb47d742c116fcd63223778cf9dda8b6aaac..abf17941f7:/src/dolphiniconsview.cpp diff --git a/src/dolphiniconsview.cpp b/src/dolphiniconsview.cpp index 840d7f5fb..0f619ff30 100644 --- a/src/dolphiniconsview.cpp +++ b/src/dolphiniconsview.cpp @@ -1,6 +1,5 @@ /*************************************************************************** - * Copyright (C) 2006 by Peter Penz * - * peter.penz@gmx.at * + * Copyright (C) 2006 by Peter Penz (peter.penz@gmx.at) * * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * @@ -19,8 +18,8 @@ ***************************************************************************/ #include "dolphiniconsview.h" -#include "dolphinmainwindow.h" -#include "dolphinview.h" + +#include "dolphincontroller.h" #include #include @@ -28,11 +27,20 @@ #include -DolphinIconsView::DolphinIconsView(DolphinView* parent) : +DolphinIconsView::DolphinIconsView(QWidget* parent, DolphinController* controller) : QListView(parent), - m_dolphinView(parent) + m_controller(controller) { + assert(controller != 0); + setResizeMode(QListView::Adjust); + + // TODO: read out settings + setViewMode(QListView::IconMode); + setGridSize(QSize(128, 96)); + + connect(this, SIGNAL(clicked(const QModelIndex&)), + controller, SLOT(triggerItem(const QModelIndex&))); } DolphinIconsView::~DolphinIconsView() @@ -57,21 +65,13 @@ QStyleOptionViewItem DolphinIconsView::viewOptions() const void DolphinIconsView::contextMenuEvent(QContextMenuEvent* event) { QListView::contextMenuEvent(event); - - KFileItem* item = 0; - - const QModelIndex index = indexAt(event->pos()); - if (index.isValid()) { - item = m_dolphinView->fileItem(index); - } - - m_dolphinView->openContextMenu(item, event->globalPos()); + m_controller->triggerContextMenuRequest(event->pos()); } void DolphinIconsView::mouseReleaseEvent(QMouseEvent* event) { QListView::mouseReleaseEvent(event); - m_dolphinView->declareViewActive(); + m_controller->triggerActivation(); } void DolphinIconsView::dragEnterEvent(QDragEnterEvent* event) @@ -83,27 +83,13 @@ void DolphinIconsView::dragEnterEvent(QDragEnterEvent* event) void DolphinIconsView::dropEvent(QDropEvent* event) { - KFileItem* directory = 0; - bool dropIntoDirectory = false; - const QModelIndex index = indexAt(event->pos()); - if (index.isValid()) { - KFileItem* item = m_dolphinView->fileItem(index); - assert(item != 0); - dropIntoDirectory = item->isDir(); - if (dropIntoDirectory) { - directory = item; - } - } - const KUrl::List urls = KUrl::List::fromMimeData(event->mimeData()); - if (urls.isEmpty() || (event->source() == this) && !dropIntoDirectory) { + if (urls.isEmpty() || (event->source() == this)) { QListView::dropEvent(event); } else { event->acceptProposedAction(); - const KUrl& destination = (directory == 0) ? m_dolphinView->url() : - directory->url(); - m_dolphinView->mainWindow()->dropUrls(urls, destination); + m_controller->indicateDroppedUrls(urls, event->pos()); } }