X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/d52282f8a2a727ad332d4cceeeaa6b79af9267c1..f42d1d2c02eb7e608564f137ce97f9424d9c49f6:/src/dolphindetailsview.cpp diff --git a/src/dolphindetailsview.cpp b/src/dolphindetailsview.cpp index e04ff7618..411a410d3 100644 --- a/src/dolphindetailsview.cpp +++ b/src/dolphindetailsview.cpp @@ -19,19 +19,40 @@ ***************************************************************************/ #include "dolphindetailsview.h" -#include "dolphinmainwindow.h" -#include "dolphinview.h" +#include "dolphincontroller.h" +#include "dolphinsortfilterproxymodel.h" +#include "viewproperties.h" + +#include +#include #include -DolphinDetailsView::DolphinDetailsView(DolphinView* parent) : +DolphinDetailsView::DolphinDetailsView(QWidget* parent, DolphinController* controller) : QTreeView(parent), - m_parentView(parent) + m_controller(controller) { + assert(controller != 0); + setAcceptDrops(true); setRootIsDecorated(false); setSortingEnabled(true); setUniformRowHeights(true); + + const ViewProperties props(controller->url()); + setSortIndicatorSection(props.sorting()); + setSortIndicatorOrder(props.sortOrder()); + + connect(header(), SIGNAL(sectionClicked(int)), + this, SLOT(synchronizeSortingState(int))); + + connect(parent, SIGNAL(sortingChanged(DolphinView::Sorting)), + this, SLOT(setSortIndicatorSection(DolphinView::Sorting))); + connect(parent, SIGNAL(sortOrderChanged(Qt::SortOrder)), + this, SLOT(setSortIndicatorOrder(Qt::SortOrder))); + + connect(this, SIGNAL(clicked(const QModelIndex&)), + controller, SLOT(triggerItem(const QModelIndex&))); } DolphinDetailsView::~DolphinDetailsView() @@ -70,21 +91,14 @@ QStyleOptionViewItem DolphinDetailsView::viewOptions() const void DolphinDetailsView::contextMenuEvent(QContextMenuEvent* event) { QTreeView::contextMenuEvent(event); - - KFileItem* item = 0; - - const QModelIndex index = indexAt(event->pos()); - if (index.isValid()) { - item = m_parentView->fileItem(index); - } - - m_parentView->openContextMenu(item, event->globalPos()); + m_controller->triggerContextMenuRequest(event->pos(), + event->globalPos()); } void DolphinDetailsView::mouseReleaseEvent(QMouseEvent* event) { QTreeView::mouseReleaseEvent(event); - m_parentView->declareViewActive(); + m_controller->triggerActivation(); } void DolphinDetailsView::dragEnterEvent(QDragEnterEvent* event) @@ -96,15 +110,40 @@ void DolphinDetailsView::dragEnterEvent(QDragEnterEvent* event) void DolphinDetailsView::dropEvent(QDropEvent* event) { - const KUrl::List urls = KUrl::List::fromMimeData(event->mimeData()); + QTreeView::dropEvent(event); + // TODO: temporary deactivated until DolphinController will support this + + /*const KUrl::List urls = KUrl::List::fromMimeData(event->mimeData()); if (!urls.isEmpty()) { event->acceptProposedAction(); // TODO: handle dropping above a directory - const KUrl& destination = m_parentView->url(); - m_parentView->mainWindow()->dropUrls(urls, destination); - } + const KUrl& destination = m_controller->url(); + m_controller->emitDropUrlsSignal(urls, destination); + }*/ +} + +void DolphinDetailsView::setSortIndicatorSection(DolphinView::Sorting sorting) +{ + QHeaderView* headerView = header(); + headerView->setSortIndicator(sorting, headerView->sortIndicatorOrder()); +} + +void DolphinDetailsView::setSortIndicatorOrder(Qt::SortOrder sortOrder) +{ + QHeaderView* headerView = header(); + headerView->setSortIndicator(headerView->sortIndicatorSection(), sortOrder); +} + +void DolphinDetailsView::synchronizeSortingState(int column) +{ + // The sorting has already been changed in QTreeView if this slot is + // invoked, but Dolphin is not informed about this. + DolphinView::Sorting sorting = DolphinSortFilterProxyModel::sortingForColumn(column); + const Qt::SortOrder sortOrder = header()->sortIndicatorOrder(); + m_controller->indicateSortingChange(sorting); + m_controller->indicateSortOrderChange(sortOrder); } #include "dolphindetailsview.moc"