diff options
| author | Peter Penz <[email protected]> | 2012-03-11 19:02:45 +0100 |
|---|---|---|
| committer | Peter Penz <[email protected]> | 2012-03-11 19:05:56 +0100 |
| commit | 2ba5c2cfc2cea534cccd860f94a7198530b83594 (patch) | |
| tree | 787ee40d007b243a01ba581e778fc67aa179e361 /src/views/additionalinfoaccessor.h | |
| parent | d28081338577bfe0104f42c20e167bb0ce70e094 (diff) | |
First step to introduce dynamic roles
Currently Dolphin is only capable of showing a fixed number of
roles (e.g. name, size, date, owner, ...). Dolphin 2.1 should
support also other roles like rating, tags, comments or other
meta-information of images or audio-files.
To support this the sorting-type and additional-type from
DolphinView has been replaced by a role-type represented as
QByteArray.
Diffstat (limited to 'src/views/additionalinfoaccessor.h')
| -rw-r--r-- | src/views/additionalinfoaccessor.h | 101 |
1 files changed, 0 insertions, 101 deletions
diff --git a/src/views/additionalinfoaccessor.h b/src/views/additionalinfoaccessor.h deleted file mode 100644 index 0fd7eed0c..000000000 --- a/src/views/additionalinfoaccessor.h +++ /dev/null @@ -1,101 +0,0 @@ -/*************************************************************************** - * Copyright (C) 2010 by Peter Penz <[email protected]> * - * * - * 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 * - * the Free Software Foundation; either version 2 of the License, or * - * (at your option) any later version. * - * * - * This program is distributed in the hope that it will be useful, * - * but WITHOUT ANY WARRANTY; without even the implied warranty of * - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * - * GNU General Public License for more details. * - * * - * You should have received a copy of the GNU General Public License * - * along with this program; if not, write to the * - * Free Software Foundation, Inc., * - * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * - ***************************************************************************/ - -#ifndef ADDITIONALINFOACCESSOR_H -#define ADDITIONALINFOACCESSOR_H - -#include <libdolphin_export.h> -#include <KFileItemDelegate> -#include <views/dolphinview.h> - -#include <QList> -#include <QMap> - -/** - * @brief Allows to access the information that is available by KFileItemDelegate::Information. - * - * The information that is available by KFileItemDelegate::Information will be shown - * in Dolphin the following way: - * - As additional columns in the details view - * - As additional lines in the icons view - * - As menu entries in the "Sort By" and "Additional Information" groups - * - As popup menu entries in the details view header popup - * - As checkable entries in the View Properties dialog - * - * The AdditionalInfoAccessor provides a central place to get all available keys, - * the corresponding translations, action names, etc., so that modifications or - * extensions in KFileItemDelegate only require adjustments in the implementation - * of this class. - */ -class LIBDOLPHINPRIVATE_EXPORT AdditionalInfoAccessor -{ -public: - enum ActionCollectionType { - /// Action collection from "View -> Sort By" - SortByType, - /// Action collection from "View -> Additional Information" - AdditionalInfoType - }; - - static AdditionalInfoAccessor& instance(); - - /** - * @return List of all available information entries of KFileItemDelegate. - * All entries of this list are keys for accessing the corresponding - * data (see actionCollectionName(), translation(), bitValue()). - */ - QList<DolphinView::AdditionalInfo> keys() const; - - QByteArray role(DolphinView::AdditionalInfo info) const; - - DolphinView::AdditionalInfo additionalInfo(const QByteArray& role) const; - - QString actionCollectionName(DolphinView::AdditionalInfo info, ActionCollectionType type) const; - - QString translation(DolphinView::AdditionalInfo info) const; - - /** - * @return String representation of the value that is stored in the .directory - * by ViewProperties. - */ - // TODO Dolphin 3.0: Deprecate - just use role() instead. - QString value(DolphinView::AdditionalInfo info) const; - - DolphinView::Sorting sorting(DolphinView::AdditionalInfo info) const; - -protected: - AdditionalInfoAccessor(); - virtual ~AdditionalInfoAccessor(); - friend class AdditionalInfoAccessorSingleton; - -private: - struct AdditionalInfo { - const char* const role; - const char* const roleTranslationContext; - const char* const roleTranslation; - const char* const value; // TODO Dolphin 3.0: Deprecate and use role instead - const DolphinView::Sorting sorting; - }; - - QMap<DolphinView::AdditionalInfo, const AdditionalInfo*> m_map; - QHash<QByteArray, DolphinView::AdditionalInfo> m_infoForRole; -}; - -#endif - |
