]>
cloud.milkyroute.net Git - dolphin.git/blob - src/dolphinmodel.cpp
2 * This file is part of the KDE project
3 * Copyright (C) 2007 Rafael Fernández López <ereslibre@kde.org>
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Library General Public
7 * License as published by the Free Software Foundation; either
8 * version 2 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Library General Public License for more details.
15 * You should have received a copy of the GNU Library General Public License
16 * along with this library; see the file COPYING.LIB. If not, write to
17 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
18 * Boston, MA 02110-1301, USA.
21 #include "dolphinmodel.h"
23 #include "dolphinsortfilterproxymodel.h"
25 #include "kcategorizedview.h"
27 #include <config-nepomuk.h>
29 #include <nepomuk/global.h>
30 #include <nepomuk/resource.h>
31 #include <nepomuk/tag.h>
34 #include <kdatetime.h>
35 #include <kdirmodel.h>
36 #include <kfileitem.h>
37 #include <kiconloader.h>
41 #include <kmimetype.h>
42 #include <kstandarddirs.h>
45 #include <QSortFilterProxyModel>
50 static const char * others
= I18N_NOOP2 ( "@title:group Name" , "Others" );
52 DolphinModel :: DolphinModel ( QObject
* parent
)
57 DolphinModel ::~ DolphinModel ()
61 QVariant
DolphinModel :: data ( const QModelIndex
& index
, int role
) const
63 if ( role
== KCategorizedSortFilterProxyModel :: CategoryDisplayRole
) {
66 if (! index
. isValid ()) {
70 const KDirModel
* dirModel
= qobject_cast
< const KDirModel
*>( index
. model ());
71 KFileItem item
= dirModel
-> itemForIndex ( index
);
73 switch ( index
. column ()) {
74 case KDirModel :: Name
: {
75 // KDirModel checks columns to know to which role are
77 QModelIndex theIndex
= index
. model ()-> index ( index
. row (),
81 if (! theIndex
. isValid ()) {
84 QVariant data
= theIndex
. model ()-> data ( theIndex
, Qt :: DisplayRole
);
85 QString name
= data
. toString ();
86 if (! name
. isEmpty ()) {
87 if (! item
. isHidden () && name
. at ( 0 ). isLetter ())
88 retString
= name
. at ( 0 ). toUpper ();
89 else if ( item
. isHidden ()) {
90 if ( name
. at ( 0 ) == '.' ) {
91 if ( name
. size () > 1 && name
. at ( 1 ). isLetter ()) {
92 retString
= name
. at ( 1 ). toUpper ();
94 retString
= i18nc ( "@title:group Name" , others
);
97 retString
= name
. at ( 0 ). toUpper ();
100 bool validCategory
= false ;
102 const QString
str ( name
. toUpper ());
103 const QChar
* currA
= str
. unicode ();
104 while (! currA
-> isNull () && ! validCategory
) {
105 if ( currA
-> isLetter ()) {
106 validCategory
= true ;
107 } else if ( currA
-> isDigit ()) {
108 return i18nc ( "@title:group Name" , others
);
114 if (! validCategory
) {
115 retString
= validCategory
? * currA
: i18nc ( "@title:group Name" , others
);
124 case KDirModel :: Size
: {
125 const int fileSize
= ! item
. isNull () ? item
. size () : - 1 ;
126 if (! item
. isNull () && item
. isDir ()) {
127 retString
= i18nc ( "@title:group Size" , "Folders" );
128 } else if ( fileSize
< 5242880 ) {
129 retString
= i18nc ( "@title:group Size" , "Small" );
130 } else if ( fileSize
< 10485760 ) {
131 retString
= i18nc ( "@title:group Size" , "Medium" );
133 retString
= i18nc ( "@title:group Size" , "Big" );
138 case KDirModel :: ModifiedTime
: {
139 KDateTime modifiedTime
;
140 modifiedTime
. setTime_t ( item
. time ( KIO :: UDSEntry :: UDS_MODIFICATION_TIME
));
141 modifiedTime
= modifiedTime
. toLocalZone ();
143 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 " ));
147 case KDirModel :: Permissions
: {
152 QFileInfo
info ( item
. url (). pathOrUrl ());
154 if ( info
. permission ( QFile :: ReadUser
))
155 user
= i18n ( "Read, " );
157 if ( info
. permission ( QFile :: WriteUser
))
158 user
+= i18n ( "Write, " );
160 if ( info
. permission ( QFile :: ExeUser
))
161 user
+= i18n ( "Execute, " );
164 user
= i18n ( "Forbidden" );
166 user
= user
. mid ( 0 , user
. count () - 2 );
168 if ( info
. permission ( QFile :: ReadGroup
))
169 group
= i18n ( "Read, " );
171 if ( info
. permission ( QFile :: WriteGroup
))
172 group
+= i18n ( "Write, " );
174 if ( info
. permission ( QFile :: ExeGroup
))
175 group
+= i18n ( "Execute, " );
178 group
= i18n ( "Forbidden" );
180 group
= group
. mid ( 0 , group
. count () - 2 );
182 if ( info
. permission ( QFile :: ReadOther
))
183 others
= i18n ( "Read, " );
185 if ( info
. permission ( QFile :: WriteOther
))
186 others
+= i18n ( "Write, " );
188 if ( info
. permission ( QFile :: ExeOther
))
189 others
+= i18n ( "Execute, " );
191 if ( others
. isEmpty ())
192 others
= i18n ( "Forbidden" );
194 others
= others
. mid ( 0 , others
. count () - 2 );
196 retString
= i18nc ( "This shows files and folders permissions: user, group and others" , "(User: %1 ) (Group: %2 ) (Others: %3 )" , user
, group
, others
);
200 case KDirModel :: Owner
:
201 retString
= item
. user ();
204 case KDirModel :: Group
:
205 retString
= item
. group ();
208 case KDirModel :: Type
:
209 retString
= item
. mimeComment ();
213 case DolphinModel :: Rating
: {
214 const quint32 rating
= ratingForIndex ( index
);
216 retString
= QString :: number ( rating
);
220 case DolphinModel :: Tags
: {
221 retString
= tagsForIndex ( index
);
223 if ( retString
. isEmpty ()) {
224 retString
= i18nc ( "@title:group Tags" , "Not yet tagged" );
233 else if ( role
== KCategorizedSortFilterProxyModel :: CategorySortRole
) {
236 if (! index
. isValid ()) {
240 const KDirModel
* dirModel
= qobject_cast
< const KDirModel
*>( index
. model ());
241 KFileItem item
= dirModel
-> itemForIndex ( index
);
243 switch ( index
. column ()) {
244 case KDirModel :: Name
: {
245 retVariant
= data ( index
, KCategorizedSortFilterProxyModel :: CategoryDisplayRole
);
247 if ( retVariant
== i18nc ( "@title:group Name" , others
))
248 retVariant
= QString ( QChar ( QChar :: ReplacementCharacter
));
253 case KDirModel :: Size
: {
254 const int fileSize
= ! item
. isNull () ? item
. size () : - 1 ;
257 } else if ( fileSize
< 5242880 ) {
259 } else if ( fileSize
< 10485760 ) {
267 case KDirModel :: ModifiedTime
: {
268 KDateTime modifiedTime
;
269 modifiedTime
. setTime_t ( item
. time ( KIO :: UDSEntry :: UDS_MODIFICATION_TIME
));
270 modifiedTime
= modifiedTime
. toLocalZone ();
272 retVariant
= -( modifiedTime
. date (). year () * 100 + modifiedTime
. date (). month ());
276 case KDirModel :: Permissions
: {
277 QFileInfo
info ( item
. url (). pathOrUrl ());
279 retVariant
= - KDirSortFilterProxyModel :: pointsForPermissions ( info
);
283 case KDirModel :: Owner
:
284 retVariant
= item
. user ();
287 case KDirModel :: Group
:
288 retVariant
= item
. group ();
291 case KDirModel :: Type
:
293 retVariant
= QString (); // when sorting we want folders to be placed first
295 retVariant
= item
. mimeComment ();
299 case DolphinModel :: Rating
: {
300 retVariant
= ratingForIndex ( index
);
304 case DolphinModel :: Tags
: {
305 retVariant
= tagsForIndex ( index
). count ();
318 return KDirModel :: data ( index
, role
);
321 int DolphinModel :: columnCount ( const QModelIndex
& parent
) const
323 return KDirModel :: columnCount ( parent
) + ( ExtraColumnCount
- ColumnCount
);
326 quint32
DolphinModel :: ratingForIndex ( const QModelIndex
& index
)
331 const DolphinModel
* dolphinModel
= static_cast < const DolphinModel
*>( index
. model ());
332 KFileItem item
= dolphinModel
-> itemForIndex ( index
);
333 if (! item
. isNull ()) {
334 const Nepomuk :: Resource
resource ( item
. url (). url (), Nepomuk :: NFO :: File ());
335 rating
= resource
. rating ();
344 QString
DolphinModel :: tagsForIndex ( const QModelIndex
& index
)
349 const DolphinModel
* dolphinModel
= static_cast < const DolphinModel
*>( index
. model ());
350 KFileItem item
= dolphinModel
-> itemForIndex ( index
);
351 if (! item
. isNull ()) {
352 const Nepomuk :: Resource
resource ( item
. url (). url (), Nepomuk :: NFO :: File ());
353 const QList
< Nepomuk :: Tag
> tags
= resource
. tags ();
354 QStringList stringList
;
355 foreach ( const Nepomuk :: Tag
& tag
, tags
) {
356 stringList
. append ( tag
. label ());
360 foreach ( const QString
& str
, stringList
) {
365 if (! tagsString
. isEmpty ()) {
366 tagsString
. resize ( tagsString
. size () - 2 );