if (!theIndex.isValid()) {
return retString;
}
-
QVariant data = theIndex.model()->data(theIndex, Qt::DisplayRole);
- if (data.toString().size()) {
- if (!item.isHidden() && data.toString().at(0).isLetter())
- retString = data.toString().toUpper().at(0);
- else if (item.isHidden() && data.toString().at(0) == '.' &&
- data.toString().at(1).isLetter())
- retString = data.toString().toUpper().at(1);
- else if (item.isHidden() && data.toString().at(0) == '.' &&
- !data.toString().at(1).isLetter())
- retString = i18nc("@title:group Name", "Others");
- else if (item.isHidden() && data.toString().at(0) != '.')
- retString = data.toString().toUpper().at(0);
- else if (item.isHidden())
- retString = data.toString().toUpper().at(0);
- else
- {
+ QString name = data.toString();
+ if (!name.isEmpty()) {
+ if (!item.isHidden() && name.at(0).isLetter())
+ retString = name.at(0).toUpper();
+ else if (item.isHidden()) {
+ if (name.at(0) == '.') {
+ if (name.size() > 1 && name.at(1).isLetter()) {
+ retString = name.at(1).toUpper();
+ } else {
+ retString = i18nc("@title:group Name", "Others");
+ }
+ } else {
+ retString = name.at(0).toUpper();
+ }
+ } else {
bool validCategory = false;
- const QString str(data.toString().toUpper());
+ const QString str(name.toUpper());
const QChar* currA = str.unicode();
while (!currA->isNull() && !validCategory) {
- if (currA->isLetter())
+ if (currA->isLetter()) {
validCategory = true;
- else if (currA->isDigit())
+ } else if (currA->isDigit()) {
return i18nc("@title:group", "Others");
- else
+ } else {
++currA;
+ }
}
- if (!validCategory)
- retString = i18nc("@title:group Name", "Others");
- else
+ if (!validCategory) {
+ retString = validCategory ? *currA : i18nc("@title:group Name", "Others");
+ } else {
retString = *currA;
+ }
}
}
break;
case DolphinModel::Tags: {
retString = tagsForIndex(index);
- if (retString.isEmpty())
+ if (retString.isEmpty()) {
retString = i18nc("@title:group Tags", "Not yet tagged");
-
+ }
break;
}
#endif
modifiedTime.setTime_t(item.time(KIO::UDSEntry::UDS_MODIFICATION_TIME));
modifiedTime = modifiedTime.toLocalZone();
- retVariant = modifiedTime.date().year() * 100 + modifiedTime.date().month();
+ retVariant = -(modifiedTime.date().year() * 100 + modifiedTime.date().month());
break;
}