#include "dolphincontroller.h"
-#include <QPainter>
+#include <kdirmodel.h>
+#include <QAbstractProxyModel>
+#include <QApplication>
-DolphinController::DolphinController(QObject* parent) :
- QObject(parent),
- m_showPreview(false),
+DolphinController::DolphinController(DolphinView* dolphinView) :
+ QObject(dolphinView),
m_zoomInPossible(false),
m_zoomOutPossible(false),
- m_additionalInfoCount(0),
- m_url()
+ m_openTab(false),
+ m_url(),
+ m_dolphinView(dolphinView),
+ m_itemView(0)
{
}
}
}
+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 KUrl& destPath,
- const QModelIndex& destIndex,
- QWidget* source)
+ const KFileItem& destItem)
{
- emit urlsDropped(urls, destPath, destIndex, source);
+ emit urlsDropped(urls, destPath, destItem);
}
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::setAdditionalInfoCount(int count)
+void DolphinController::indicateActivationChange(bool active)
{
- if (m_additionalInfoCount != count) {
- m_additionalInfoCount = count;
- emit additionalInfoCountChanged(count);
- }
+ emit activationChanged(active);
}
void DolphinController::triggerZoomIn()
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);
+ }
+ }
+}
- 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<QAbstractProxyModel*>(m_itemView->model());
+ KDirModel* dirModel = static_cast<KDirModel*>(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()
emit viewportEntered();
}
+void DolphinController::updateOpenTabState()
+{
+ m_openTab = QApplication::mouseButtons() & Qt::MidButton;
+}
+
#include "dolphincontroller.moc"