]> cloud.milkyroute.net Git - dolphin.git/blobdiff - src/dolphinmodel.cpp
Makes sense that when sorting by permissions what we want to see first is the most...
[dolphin.git] / src / dolphinmodel.cpp
index 6ca2dd8e610847fdbd58e0d583beeeb524beff27..f541fe20c48b28da9b848626d832d5bb1e985148 100644 (file)
@@ -1,6 +1,6 @@
 /**
   * This file is part of the KDE project
-  * Copyright (C) 2007 Rafael Fernández López <ereslibre@gmail.com>
+  * Copyright (C) 2007 Rafael Fernández López <ereslibre@kde.org>
   *
   * This library is free software; you can redistribute it and/or
   * modify it under the terms of the GNU Library General Public
 #include <kuser.h>
 #include <kmimetype.h>
 #include <kstandarddirs.h>
-#include <kpixmapeffect.h>
 
 #include <QList>
 #include <QSortFilterProxyModel>
 #include <QPainter>
 #include <QDir>
+#include <QFileInfo>
 
 DolphinModel::DolphinModel(QObject *parent)
     : KDirModel(parent)
@@ -58,7 +58,7 @@ DolphinModel::~DolphinModel()
 
 QVariant DolphinModel::data(const QModelIndex &index, int role) const
 {
-    if (role == KCategorizedSortFilterProxyModel::CategoryRole)
+    if (role == KCategorizedSortFilterProxyModel::CategoryDisplayRole)
     {
         QString retString;
 
@@ -143,24 +143,63 @@ QVariant DolphinModel::data(const QModelIndex &index, int role) const
                 modifiedTime.setTime_t(item.time(KIO::UDSEntry::UDS_MODIFICATION_TIME));
                 modifiedTime = modifiedTime.toLocalZone();
 
-                if (modifiedTime.daysTo(KDateTime::currentLocalDateTime()) == 0)
-                    retString = i18nc("@title:group Date", "Today");
-                else if (modifiedTime.daysTo(KDateTime::currentLocalDateTime()) == 1)
-                    retString = i18nc("@title:group Date", "Yesterday");
-                else if (modifiedTime.daysTo(KDateTime::currentLocalDateTime()) < 7)
-                    retString = i18nc("@title:group Date", "Less than a week");
-                else if (modifiedTime.daysTo(KDateTime::currentLocalDateTime()) < 31)
-                    retString = i18nc("@title:group Date", "Less than a month");
-                else if (modifiedTime.daysTo(KDateTime::currentLocalDateTime()) < 365)
-                    retString = i18nc("@title:group Date", "Less than a year");
-                else
-                    retString = i18nc("@title:group Date", "More than a year");
+                retString = modifiedTime.toString(i18nc("Prints out the month and year: %B is full month name in current locale, and %Y is full year number", "%B, %Y"));
                 break;
             }
 
             case KDirModel::Permissions:
-                retString = item.permissionsString();
+            {
+                QString user;
+                QString group;
+                QString others;
+
+                QFileInfo info(item.url().pathOrUrl());
+
+                if (info.permission(QFile::ReadUser))
+                    user = i18n("Read, ");
+
+                if (info.permission(QFile::WriteUser))
+                    user += i18n("Write, ");
+
+                if (info.permission(QFile::ExeUser))
+                    user += i18n("Execute, ");
+
+                if (user.isEmpty())
+                    user = i18n("Forbidden");
+                else
+                    user = user.mid(0, user.count() - 2);
+
+                if (info.permission(QFile::ReadGroup))
+                    group = i18n("Read, ");
+
+                if (info.permission(QFile::WriteGroup))
+                    group += i18n("Write, ");
+
+                if (info.permission(QFile::ExeGroup))
+                    group += i18n("Execute, ");
+
+                if (group.isEmpty())
+                    group = i18n("Forbidden");
+                else
+                    group = group.mid(0, group.count() - 2);
+
+                if (info.permission(QFile::ReadOther))
+                    others = i18n("Read, ");
+
+                if (info.permission(QFile::WriteOther))
+                    others += i18n("Write, ");
+
+                if (info.permission(QFile::ExeOther))
+                    others += i18n("Execute, ");
+
+                if (others.isEmpty())
+                    others = i18n("Forbidden");
+                else
+                    others = others.mid(0, others.count() - 2);
+
+                retString = i18nc("This shows files and folders permissions: user, group and others", "(User: %1) (Group: %2) (Others: %3)", user, group, others);
                 break;
+            }
 
             case KDirModel::Owner:
                 retString = item.user();
@@ -195,6 +234,82 @@ QVariant DolphinModel::data(const QModelIndex &index, int role) const
 
         return retString;
     }
+    else if (role == KCategorizedSortFilterProxyModel::CategorySortRole)
+    {
+        QVariant retVariant;
+
+        if (!index.isValid())
+        {
+            return retVariant;
+        }
+
+        const KDirModel *dirModel = qobject_cast<const KDirModel*>(index.model());
+        KFileItem item = dirModel->itemForIndex(index);
+
+        switch (index.column()) {
+        case KDirModel::Name: {
+            retVariant = data(index, KCategorizedSortFilterProxyModel::CategoryDisplayRole);
+            break;
+        }
+
+        case KDirModel::Size: {
+            const int fileSize = !item.isNull() ? item.size() : -1;
+            retVariant = fileSize;
+            break;
+        }
+
+        case KDirModel::ModifiedTime:
+        {
+            KDateTime modifiedTime;
+            modifiedTime.setTime_t(item.time(KIO::UDSEntry::UDS_MODIFICATION_TIME));
+            modifiedTime = modifiedTime.toLocalZone();
+
+            retVariant = modifiedTime.date().year() * 100 + modifiedTime.date().month();
+            break;
+        }
+
+        case KDirModel::Permissions:
+        {
+            QFileInfo info(item.url().pathOrUrl());
+
+            retVariant = -KDirSortFilterProxyModel::pointsForPermissions(info);
+            break;
+        }
+
+        case KDirModel::Owner:
+            retVariant = item.user();
+            break;
+
+        case KDirModel::Group:
+            retVariant = item.group();
+            break;
+
+        case KDirModel::Type:
+            if (item.isDir())
+                retVariant = QString(); // when sorting we want folders to be placed first
+            else
+                retVariant = item.mimeComment();
+            break;
+
+#ifdef HAVE_NEPOMUK
+        case DolphinModel::Rating: {
+            retVariant = ratingForIndex(index);
+            break;
+        }
+
+        case DolphinModel::Tags: {
+            retVariant = tagsForIndex(index).count();
+            break;
+        }
+#endif
+
+        default:
+            break;
+
+        }
+
+        return retVariant;
+    }
 
     return KDirModel::data(index, role);
 }