]> cloud.milkyroute.net Git - dolphin.git/blobdiff - src/kitemviews/kitemmodelbase.cpp
Fix selection rect after porting from QFontMetrics::width()
[dolphin.git] / src / kitemviews / kitemmodelbase.cpp
index fc604e729f9bb54f72ec89f73971f7d0879fe6fd..faabdbe1dccbac882b18d6a66b3e9107ec39379c 100644 (file)
@@ -1,8 +1,7 @@
 /***************************************************************************
  *   Copyright (C) 2011 by Peter Penz <peter.penz19@gmail.com>             *
  *                                                                         *
- *   Based on the Itemviews NG project from Trolltech Labs:                *
- *   http://qt.gitorious.org/qt-labs/itemviews-ng                          *
+ *   Based on the Itemviews NG project from Trolltech Labs                 *
  *                                                                         *
  *   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  *
 
 #include "kitemmodelbase.h"
 
-KItemRange::KItemRange(int index, int count) :
-    index(index),
-    count(count)
-{
-}
-
-bool KItemRange::operator == (const KItemRange& other) const
-{
-    return index == other.index && count == other.count;
-}
-
 KItemModelBase::KItemModelBase(QObject* parent) :
     QObject(parent),
-    m_groupRole(),
-    m_sortRole()
+    m_groupedSorting(false),
+    m_sortRole(),
+    m_sortOrder(Qt::AscendingOrder)
 {
 }
 
-KItemModelBase::KItemModelBase(const QByteArray& groupRole, const QByteArray& sortRole, QObject* parent) :
+KItemModelBase::KItemModelBase(const QByteArray& sortRole, QObject* parent) :
     QObject(parent),
-    m_groupRole(groupRole),
-    m_sortRole(sortRole)
+    m_groupedSorting(false),
+    m_sortRole(sortRole),
+    m_sortOrder(Qt::AscendingOrder)
 {
 }
 
@@ -53,42 +43,31 @@ KItemModelBase::~KItemModelBase()
 
 bool KItemModelBase::setData(int index, const QHash<QByteArray, QVariant> &values)
 {
-    Q_UNUSED(index);
-    Q_UNUSED(values);
+    Q_UNUSED(index)
+    Q_UNUSED(values)
     return false;
 }
 
-bool KItemModelBase::supportsGrouping() const
+void KItemModelBase::setGroupedSorting(bool grouped)
 {
-    return false;
-}
-
-void KItemModelBase::setGroupRole(const QByteArray& role)
-{
-    if (supportsGrouping() && role != m_groupRole) {
-        const QByteArray previous = m_groupRole;
-        m_groupRole = role;
-        onGroupRoleChanged(role, previous);
-        emit groupRoleChanged(role, previous);
+    if (m_groupedSorting != grouped) {
+        m_groupedSorting = grouped;
+        onGroupedSortingChanged(grouped);
+        emit groupedSortingChanged(grouped);
     }
 }
 
-QByteArray KItemModelBase::groupRole() const
+bool KItemModelBase::groupedSorting() const
 {
-    return m_groupRole;
+    return m_groupedSorting;
 }
 
-bool KItemModelBase::supportsSorting() const
+void KItemModelBase::setSortRole(const QByteArray& role, bool resortItems)
 {
-    return false;
-}
-
-void KItemModelBase::setSortRole(const QByteArray& role)
-{
-    if (supportsSorting() && role != m_sortRole) {
+    if (role != m_sortRole) {
         const QByteArray previous = m_sortRole;
         m_sortRole = role;
-        onSortRoleChanged(role, previous);
+        onSortRoleChanged(role, previous, resortItems);
         emit sortRoleChanged(role, previous);
     }
 }
@@ -98,27 +77,104 @@ QByteArray KItemModelBase::sortRole() const
     return m_sortRole;
 }
 
+void KItemModelBase::setSortOrder(Qt::SortOrder order)
+{
+    if (order != m_sortOrder) {
+        const Qt::SortOrder previous = m_sortOrder;
+        m_sortOrder = order;
+        onSortOrderChanged(order, previous);
+        emit sortOrderChanged(order, previous);
+    }
+}
+
 QString KItemModelBase::roleDescription(const QByteArray& role) const
 {
     return role;
 }
 
-QMimeData* KItemModelBase::createMimeData(const QSet<int>& indexes) const
+QList<QPair<int, QVariant> > KItemModelBase::groups() const
+{
+    return QList<QPair<int, QVariant> >();
+}
+
+bool KItemModelBase::setExpanded(int index, bool expanded)
+{
+    Q_UNUSED(index)
+    Q_UNUSED(expanded)
+    return false;
+}
+
+bool KItemModelBase::isExpanded(int index) const
+{
+    Q_UNUSED(index)
+    return false;
+}
+
+bool KItemModelBase::isExpandable(int index) const
 {
-    Q_UNUSED(indexes);
+    Q_UNUSED(index)
+    return false;
+}
+
+int KItemModelBase::expandedParentsCount(int index) const
+{
+    Q_UNUSED(index)
     return 0;
 }
 
-void KItemModelBase::onGroupRoleChanged(const QByteArray& current, const QByteArray& previous)
+QMimeData* KItemModelBase::createMimeData(const KItemSet& indexes) const
+{
+    Q_UNUSED(indexes)
+    return nullptr;
+}
+
+int KItemModelBase::indexForKeyboardSearch(const QString& text, int startFromIndex) const
+{
+    Q_UNUSED(text)
+    Q_UNUSED(startFromIndex)
+    return -1;
+}
+
+bool KItemModelBase::supportsDropping(int index) const
+{
+    Q_UNUSED(index)
+    return false;
+}
+
+QString KItemModelBase::blacklistItemDropEventMimeType() const
 {
-    Q_UNUSED(current);
-    Q_UNUSED(previous);
+    return QStringLiteral("application/x-dolphin-blacklist-drop");
 }
 
-void KItemModelBase::onSortRoleChanged(const QByteArray& current, const QByteArray& previous)
+void KItemModelBase::onGroupedSortingChanged(bool current)
 {
-    Q_UNUSED(current);
-    Q_UNUSED(previous);
+    Q_UNUSED(current)
 }
 
-#include "kitemmodelbase.moc"
+void KItemModelBase::onSortRoleChanged(const QByteArray& current, const QByteArray& previous, bool resortItems)
+{
+    Q_UNUSED(current)
+    Q_UNUSED(previous)
+    Q_UNUSED(resortItems)
+}
+
+void KItemModelBase::onSortOrderChanged(Qt::SortOrder current, Qt::SortOrder previous)
+{
+    Q_UNUSED(current)
+    Q_UNUSED(previous)
+}
+
+QUrl KItemModelBase::url(int index) const
+{
+    return data(index).value("url").toUrl();
+}
+
+bool KItemModelBase::isDir(int index) const
+{
+    return data(index).value("isDir").toBool();
+}
+
+QUrl KItemModelBase::directory() const
+{
+    return QUrl();
+}