/* SPDX-FileCopyrightText: 2015 Klarälvdalens Datakonsult AB, a KDAB Group company SPDX-FileContributor: David Faure SPDX-License-Identifier: LGPL-2.0-or-later */ #ifndef REARRANGECOLUMNSPROXYMODEL_H #define REARRANGECOLUMNSPROXYMODEL_H #include "kitemmodels_export.h" #include #include class KRearrangeColumnsProxyModelPrivate; /** * @class KRearrangeColumnsProxyModel krearrangecolumnsproxymodel.h KRearrangeColumnsProxyModel * * This proxy shows specific columns from the source model, in any order. * This allows to reorder columns, as well as not showing all of them. * * The proxy supports source models that have a tree structure. * It also supports editing, and propagating changes from the source model. * * Showing the same source column more than once is not supported. * * Author: David Faure, KDAB * @since 5.12 */ class KITEMMODELS_EXPORT KRearrangeColumnsProxyModel : public QIdentityProxyModel { Q_OBJECT public: /** * Creates a KRearrangeColumnsProxyModel proxy. * Remember to call setSourceModel afterwards. */ explicit KRearrangeColumnsProxyModel(QObject *parent = nullptr); /** * Destructor. */ ~KRearrangeColumnsProxyModel() override; // API /** * Set the chosen source columns, in the desired order for the proxy columns * columns[proxyColumn=0] is the source column to show in the first proxy column, etc. * * Example: QList() << 2 << 1; * This examples configures the proxy to hide column 0, show column 2 from the source model, * then show column 1 from the source model. */ void setSourceColumns(const QList &columns); // Implementation /// @reimp int columnCount(const QModelIndex &parent = QModelIndex()) const override; /// @reimp int rowCount(const QModelIndex &parent = QModelIndex()) const override; /// @reimp QModelIndex index(int row, int column, const QModelIndex &parent = QModelIndex()) const override; /// @reimp QModelIndex parent(const QModelIndex &child) const override; /// @reimp QModelIndex mapFromSource(const QModelIndex &sourceIndex) const override; /// @reimp QModelIndex mapToSource(const QModelIndex &proxyIndex) const override; /// @reimp QVariant headerData(int section, Qt::Orientation orientation, int role = Qt::DisplayRole) const override; /// @reimp bool hasChildren(const QModelIndex &parent = QModelIndex()) const override; /// @reimp QModelIndex sibling(int row, int column, const QModelIndex &idx) const override; /** * Returns the proxy column for the given source column * or -1 if the source column isn't shown in the proxy. * @since 5.56 */ int proxyColumnForSourceColumn(int sourceColumn) const; /** * Returns the source column for the given proxy column. * @since 5.56 */ int sourceColumnForProxyColumn(int proxyColumn) const; private: std::unique_ptr const d_ptr; }; #endif