X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/2cb45d81a5d61fbb703c8dac342d9945aed35e41..13b2fc55704fbc734cd4f9cbae56cfc2ef3ec0ce:/src/dolphincontroller.cpp diff --git a/src/dolphincontroller.cpp b/src/dolphincontroller.cpp index 1831c15c3..8a5ba5518 100644 --- a/src/dolphincontroller.cpp +++ b/src/dolphincontroller.cpp @@ -19,14 +19,19 @@ #include "dolphincontroller.h" -#include +#include +#include +#include +#include -DolphinController::DolphinController(QObject* parent) : - QObject(parent), - m_showPreview(false), - m_showAdditionalInfo(false), +DolphinController::DolphinController(DolphinView* dolphinView) : + QObject(dolphinView), m_zoomInPossible(false), - m_zoomOutPossible(false) + m_zoomOutPossible(false), + m_openTab(false), + m_url(), + m_dolphinView(dolphinView), + m_itemView(0) { } @@ -34,22 +39,51 @@ DolphinController::~DolphinController() { } +void DolphinController::setUrl(const KUrl& url) +{ + if (m_url != url) { + m_url = url; + emit urlChanged(url); + } +} + +void DolphinController::setItemView(QAbstractItemView* view) +{ + if (m_itemView != 0) { + disconnect(m_itemView, SIGNAL(pressed(const QModelIndex&)), + this, SLOT(updateOpenTabState())); + } + + m_itemView = view; + + // TODO: this is a workaround until Qt-issue 176832 has been fixed + connect(m_itemView, SIGNAL(pressed(const QModelIndex&)), + this, SLOT(updateOpenTabState())); +} + +void DolphinController::triggerUrlChangeRequest(const KUrl& url) +{ + if (m_url != url) { + emit requestUrlChange(url); + } +} + void DolphinController::triggerContextMenuRequest(const QPoint& pos) { emit activated(); emit requestContextMenu(pos); } -void DolphinController::triggerActivation() +void DolphinController::requestActivation() { emit activated(); } void DolphinController::indicateDroppedUrls(const KUrl::List& urls, - const QModelIndex& index, - QWidget* source) + const KUrl& destPath, + const KFileItem& destItem) { - emit urlsDropped(urls, index, source); + emit urlsDropped(urls, destPath, destItem); } @@ -63,20 +97,14 @@ void DolphinController::indicateSortOrderChange(Qt::SortOrder order) emit sortOrderChanged(order); } -void DolphinController::setShowPreview(bool show) +void DolphinController::indicateAdditionalInfoChange(const KFileItemDelegate::InformationList& info) { - if (m_showPreview != show) { - m_showPreview = show; - emit showPreviewChanged(show); - } + emit additionalInfoChanged(info); } -void DolphinController::setShowAdditionalInfo(bool show) +void DolphinController::indicateActivationChange(bool active) { - if (m_showAdditionalInfo != show) { - m_showAdditionalInfo = show; - emit showAdditionalInfoChanged(show); - } + emit activationChanged(active); } void DolphinController::triggerZoomIn() @@ -89,41 +117,69 @@ 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 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); + } + } +} + +void DolphinController::replaceUrlByClipboard() +{ + QClipboard* clipboard = QApplication::clipboard(); + const QMimeData* mimeData = clipboard->mimeData(); + if (mimeData->hasText()) { + const QString text = mimeData->text(); + m_dolphinView->setUrl(KUrl(text)); + } +} - 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(); +KFileItem DolphinController::itemForIndex(const QModelIndex& index) const +{ + Q_ASSERT(m_itemView != 0); - painter.setRenderHint(QPainter::Antialiasing); - painter.fillPath(path, blendedBrush); - painter.restore(); + 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 QModelIndex& index) { - emit itemTriggered(index); + const bool openTab = m_openTab; + m_openTab = false; + + const KFileItem item = itemForIndex(index); + if (index.isValid() && (index.column() == KDirModel::Name)) { + if (openTab && (item.isDir() || m_dolphinView->isTabsForFilesEnabled())) { + emit tabRequested(item.url()); + } else { + emit itemTriggered(item); + } + } else { + m_itemView->clearSelection(); + if (!openTab) { + emit itemEntered(item); + } + } } void DolphinController::emitItemEntered(const QModelIndex& index) { - emit itemEntered(index); + KFileItem item = itemForIndex(index); + if (!item.isNull()) { + emit itemEntered(item); + } } void DolphinController::emitViewportEntered() @@ -131,4 +187,9 @@ void DolphinController::emitViewportEntered() emit viewportEntered(); } +void DolphinController::updateOpenTabState() +{ + m_openTab = QApplication::mouseButtons() & Qt::MidButton; +} + #include "dolphincontroller.moc"