X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/84010807786c352aaeb2320caf27e5f9048d8dec..76a46fd9094b17eb99e8a42cca8562fdc0b3814c:/src/kitemviews/kitemmodelbase.cpp diff --git a/src/kitemviews/kitemmodelbase.cpp b/src/kitemviews/kitemmodelbase.cpp index fc604e729..faabdbe1d 100644 --- a/src/kitemviews/kitemmodelbase.cpp +++ b/src/kitemviews/kitemmodelbase.cpp @@ -1,8 +1,7 @@ /*************************************************************************** * Copyright (C) 2011 by Peter Penz * * * - * 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 * @@ -22,28 +21,19 @@ #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 &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& indexes) const +QList > KItemModelBase::groups() const +{ + return QList >(); +} + +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(); +}