X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/d9f5e191a6bd32a4dc15b3a3eb34795cda7697dd..bd925ea49a7e4e7c6e652f4529dcd0c4e25fd19a:/src/dolphincontroller.cpp diff --git a/src/dolphincontroller.cpp b/src/dolphincontroller.cpp index 58f6f681f..a0aa1d895 100644 --- a/src/dolphincontroller.cpp +++ b/src/dolphincontroller.cpp @@ -19,14 +19,16 @@ #include "dolphincontroller.h" -#include +#include +#include DolphinController::DolphinController(DolphinView* dolphinView) : QObject(dolphinView), m_zoomInPossible(false), m_zoomOutPossible(false), m_url(), - m_dolphinView(dolphinView) + m_dolphinView(dolphinView), + m_itemView(0) { } @@ -42,6 +44,11 @@ void DolphinController::setUrl(const KUrl& url) } } +void DolphinController::setItemView(QAbstractItemView* view) +{ + m_itemView = view; +} + void DolphinController::triggerUrlChangeRequest(const KUrl& url) { if (m_url != url) { @@ -98,41 +105,50 @@ void DolphinController::triggerZoomOut() emit zoomOut(); } -void DolphinController::drawHoverIndication(QWidget* widget, - const QRect& bounds, - const QBrush& brush) +void DolphinController::handleKeyPressEvent(QKeyEvent* event) { - QPainter painter(widget); - painter.save(); - QBrush blendedBrush(brush); - QColor color = blendedBrush.color(); - color.setAlpha(64); - blendedBrush.setColor(color); + Q_ASSERT(m_itemView != 0); - const int radius = 10; - QPainterPath path(QPointF(bounds.left(), bounds.top() + radius)); - path.quadTo(bounds.left(), bounds.top(), bounds.left() + radius, bounds.top()); - path.lineTo(bounds.right() - radius, bounds.top()); - path.quadTo(bounds.right(), bounds.top(), bounds.right(), bounds.top() + radius); - path.lineTo(bounds.right(), bounds.bottom() - radius); - path.quadTo(bounds.right(), bounds.bottom(), bounds.right() - radius, bounds.bottom()); - path.lineTo(bounds.left() + radius, bounds.bottom()); - path.quadTo(bounds.left(), bounds.bottom(), bounds.left(), bounds.bottom() - radius); - path.closeSubpath(); + const QItemSelectionModel* selModel = m_itemView->selectionModel(); + const QModelIndex currentIndex = selModel->currentIndex(); + const bool trigger = currentIndex.isValid() + && (event->key() == Qt::Key_Return) + && (selModel->selectedIndexes().count() > 0); + if (trigger) { + const QModelIndexList indexList = selModel->selectedIndexes(); + foreach (const QModelIndex& index, indexList) { + triggerItem(index); + } + } +} - painter.setRenderHint(QPainter::Antialiasing); - painter.fillPath(path, blendedBrush); - painter.restore(); +KFileItem DolphinController::itemForIndex(const QModelIndex& index) const +{ + Q_ASSERT(m_itemView != 0); + + QAbstractProxyModel* proxyModel = static_cast(m_itemView->model()); + KDirModel* dirModel = static_cast(proxyModel->sourceModel()); + const QModelIndex dirIndex = proxyModel->mapToSource(index); + return dirModel->itemForIndex(dirIndex); } -void DolphinController::triggerItem(const KFileItem& item) +void DolphinController::triggerItem(const QModelIndex& index) { - emit itemTriggered(item); + const KFileItem item = itemForIndex(index); + if (index.isValid() && (index.column() == KDirModel::Name)) { + emit itemTriggered(item); + } else { + m_itemView->clearSelection(); + emit itemEntered(item); + } } -void DolphinController::emitItemEntered(const KFileItem& item) +void DolphinController::emitItemEntered(const QModelIndex& index) { - emit itemEntered(item); + KFileItem item = itemForIndex(index); + if (!item.isNull()) { + emit itemEntered(item); + } } void DolphinController::emitViewportEntered()