1 /***************************************************************************
2 * Copyright (C) 2011 by Peter Penz <peter.penz19@gmail.com> *
4 * This program is free software; you can redistribute it and/or modify *
5 * it under the terms of the GNU General Public License as published by *
6 * the Free Software Foundation; either version 2 of the License, or *
7 * (at your option) any later version. *
9 * This program is distributed in the hope that it will be useful, *
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
12 * GNU General Public License for more details. *
14 * You should have received a copy of the GNU General Public License *
15 * along with this program; if not, write to the *
16 * Free Software Foundation, Inc., *
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
18 ***************************************************************************/
20 #ifndef KFILEITEMLISTVIEW_H
21 #define KFILEITEMLISTVIEW_H
23 #include "dolphin_export.h"
25 #include <kitemviews/kstandarditemlistview.h>
27 class KFileItemModelRolesUpdater
;
31 * @brief View that allows to show the content of file-items.
33 * The corresponding model set by the controller must be an instance
34 * of KFileItemModel. Per default KFileItemListWidget is set as widget creator
35 * value and KItemListGroupHeader as group-header creator value. Use
36 * KItemListView::setWidgetCreator() and KItemListView::setGroupHeaderCreator()
37 * to apply customized generators.
39 class DOLPHIN_EXPORT KFileItemListView
: public KStandardItemListView
44 KFileItemListView(QGraphicsWidget
* parent
= 0);
45 virtual ~KFileItemListView();
47 void setPreviewsShown(bool show
);
48 bool previewsShown() const;
51 * If enabled a small preview gets upscaled to the icon size in case where
52 * the icon size is larger than the preview. Per default enlarging is
55 void setEnlargeSmallPreviews(bool enlarge
);
56 bool enlargeSmallPreviews() const;
59 * Sets the list of enabled thumbnail plugins that are used for previews.
60 * Per default all plugins enabled in the KConfigGroup "PreviewSettings"
63 * For a list of available plugins, call KServiceTypeTrader::self()->query("ThumbCreator").
67 void setEnabledPlugins(const QStringList
& list
);
70 * Returns the list of enabled thumbnail plugins.
71 * @see setEnabledPlugins
73 QStringList
enabledPlugins() const;
75 virtual QPixmap
createDragPixmap(const KItemSet
& indexes
) const Q_DECL_OVERRIDE
;
78 virtual KItemListWidgetCreatorBase
* defaultWidgetCreator() const Q_DECL_OVERRIDE
;
79 virtual void initializeItemListWidget(KItemListWidget
* item
) Q_DECL_OVERRIDE
;
80 virtual void onPreviewsShownChanged(bool shown
);
81 virtual void onItemLayoutChanged(ItemLayout current
, ItemLayout previous
) Q_DECL_OVERRIDE
;
82 virtual void onModelChanged(KItemModelBase
* current
, KItemModelBase
* previous
) Q_DECL_OVERRIDE
;
83 virtual void onScrollOrientationChanged(Qt::Orientation current
, Qt::Orientation previous
) Q_DECL_OVERRIDE
;
84 virtual void onItemSizeChanged(const QSizeF
& current
, const QSizeF
& previous
) Q_DECL_OVERRIDE
;
85 virtual void onScrollOffsetChanged(qreal current
, qreal previous
) Q_DECL_OVERRIDE
;
86 virtual void onVisibleRolesChanged(const QList
<QByteArray
>& current
, const QList
<QByteArray
>& previous
) Q_DECL_OVERRIDE
;
87 virtual void onStyleOptionChanged(const KItemListStyleOption
& current
, const KItemListStyleOption
& previous
) Q_DECL_OVERRIDE
;
88 virtual void onSupportsItemExpandingChanged(bool supportsExpanding
) Q_DECL_OVERRIDE
;
89 virtual void onTransactionBegin() Q_DECL_OVERRIDE
;
90 virtual void onTransactionEnd() Q_DECL_OVERRIDE
;
91 virtual void resizeEvent(QGraphicsSceneResizeEvent
* event
) Q_DECL_OVERRIDE
;
94 virtual void slotItemsRemoved(const KItemRangeList
& itemRanges
) Q_DECL_OVERRIDE
;
95 virtual void slotSortRoleChanged(const QByteArray
& current
, const QByteArray
& previous
) Q_DECL_OVERRIDE
;
98 void triggerVisibleIndexRangeUpdate();
99 void updateVisibleIndexRange();
101 void triggerIconSizeUpdate();
102 void updateIconSize();
106 * Applies the roles defined by KItemListView::visibleRoles() to the
107 * KFileItemModel and KFileItemModelRolesUpdater. As the model does not
108 * distinct between visible and invisible roles also internal roles
109 * are applied that are mandatory for having a working KFileItemModel.
111 void applyRolesToModel();
114 * @return Size that is available for the icons. The size might be larger than specified by
115 * KItemListStyleOption::iconSize: With the IconsLayout also the empty left area left
116 * and right of an icon will be included.
118 QSize
availableIconSize() const;
121 KFileItemModelRolesUpdater
* m_modelRolesUpdater
;
122 QTimer
* m_updateVisibleIndexRangeTimer
;
123 QTimer
* m_updateIconSizeTimer
;
125 friend class KFileItemListViewTest
; // For unit testing