refs #785, use selection interface

* reselect of updates
* marked some QStandardItemModel functions as final (as suggested by MS)
* removed no longer used functions
This commit is contained in:
Klaus Basan
2016-12-17 19:12:56 +01:00
committed by Mathew Sutcliffe
parent 988e1b70be
commit a374146a41
2 changed files with 41 additions and 44 deletions

View File

@@ -223,11 +223,6 @@ namespace BlackGui
emit this->dataChanged(topLeft, bottomRight); emit this->dataChanged(topLeft, bottomRight);
} }
int CListModelBaseNonTemplate::ps_updateContainer(const CVariant &variant, bool sort)
{
return this->performUpdateContainer(variant, sort);
}
CListModelBaseNonTemplate::CListModelBaseNonTemplate(const QString &translationContext, QObject *parent) CListModelBaseNonTemplate::CListModelBaseNonTemplate(const QString &translationContext, QObject *parent)
: QStandardItemModel(parent), m_columns(translationContext), m_sortColumn(-1), m_sortOrder(Qt::AscendingOrder) : QStandardItemModel(parent), m_columns(translationContext), m_sortColumn(-1), m_sortOrder(Qt::AscendingOrder)
{ {
@@ -371,11 +366,16 @@ namespace BlackGui
// Keep sorting out of begin/end reset model // Keep sorting out of begin/end reset model
ContainerType sortedContainer; ContainerType sortedContainer;
int oldSize = this->m_container.size(); ContainerType selection;
bool performSort = sort && container.size() > 1 && this->hasValidSortColumn(); if (this->m_selectionModel)
{
selection = this->m_selectionModel->selectedObjects();
}
const int oldSize = this->m_container.size();
const bool performSort = sort && container.size() > 1 && this->hasValidSortColumn();
if (performSort) if (performSort)
{ {
int sortColumn = this->getSortColumn(); const int sortColumn = this->getSortColumn();
sortedContainer = this->sortContainerByColumn(container, sortColumn, this->m_sortOrder); sortedContainer = this->sortContainerByColumn(container, sortColumn, this->m_sortOrder);
} }
@@ -384,7 +384,12 @@ namespace BlackGui
this->updateFilteredContainer(); this->updateFilteredContainer();
this->endResetModel(); this->endResetModel();
int newSize = this->m_container.size(); if (!selection.isEmpty())
{
this->m_selectionModel->selectObjects(selection);
}
const int newSize = this->m_container.size();
Q_UNUSED(oldSize); Q_UNUSED(oldSize);
// I have to update even with same size because I cannot tell what/if data are changed // I have to update even with same size because I cannot tell what/if data are changed
this->emitModelDataChanged(); this->emitModelDataChanged();
@@ -423,7 +428,7 @@ namespace BlackGui
worker->thenWithResult<ContainerType>(this, [this](const ContainerType & sortedContainer) worker->thenWithResult<ContainerType>(this, [this](const ContainerType & sortedContainer)
{ {
if (this->m_modelDestroyed) { return; } if (this->m_modelDestroyed) { return; }
this->ps_updateContainer(CVariant::fromValue(sortedContainer), false); this->update(sortedContainer, false);
}); });
worker->then(this, &CListModelBase::asyncUpdateFinished); worker->then(this, &CListModelBase::asyncUpdateFinished);
return worker; return worker;
@@ -603,13 +608,6 @@ namespace BlackGui
return this->m_container.isEmpty(); return this->m_container.isEmpty();
} }
template <typename ObjectType, typename ContainerType, bool UseCompare>
int CListModelBase<ObjectType, ContainerType, UseCompare>::performUpdateContainer(const BlackMisc::CVariant &variant, bool sort)
{
ContainerType c(variant.to<ContainerType>());
return this->update(c, sort);
}
template <typename ObjectType, typename ContainerType, bool UseCompare> template <typename ObjectType, typename ContainerType, bool UseCompare>
void CListModelBase<ObjectType, ContainerType, UseCompare>::updateFilteredContainer() void CListModelBase<ObjectType, ContainerType, UseCompare>::updateFilteredContainer()
{ {

View File

@@ -16,6 +16,7 @@
#include "blackgui/dropbase.h" #include "blackgui/dropbase.h"
#include "blackgui/models/columns.h" #include "blackgui/models/columns.h"
#include "blackgui/models/modelfilter.h" #include "blackgui/models/modelfilter.h"
#include "blackgui/models/selectionmodel.h"
#include "blackmisc/digestsignal.h" #include "blackmisc/digestsignal.h"
#include "blackmisc/variant.h" #include "blackmisc/variant.h"
@@ -57,14 +58,14 @@ namespace BlackGui
//! \name Functions from QStandardItemModel //! \name Functions from QStandardItemModel
//! @{ //! @{
virtual int columnCount(const QModelIndex &modelIndex = QModelIndex()) const override; virtual int columnCount(const QModelIndex &modelIndex = QModelIndex()) const final override;
virtual QVariant headerData(int section, Qt::Orientation orientation, int role) const override; virtual QVariant headerData(int section, Qt::Orientation orientation, int role) const final override;
virtual QModelIndex index(int row, int column, const QModelIndex &parent = QModelIndex()) const override; virtual QModelIndex index(int row, int column, const QModelIndex &parent = QModelIndex()) const final override;
virtual QModelIndex parent(const QModelIndex &child) const override; virtual QModelIndex parent(const QModelIndex &child) const final override;
virtual Qt::ItemFlags flags(const QModelIndex &index) const override; virtual Qt::ItemFlags flags(const QModelIndex &index) const final override;
virtual Qt::DropActions supportedDragActions() const override; virtual Qt::DropActions supportedDragActions() const final override;
virtual Qt::DropActions supportedDropActions() const override; virtual Qt::DropActions supportedDropActions() const final override;
virtual QStringList mimeTypes() const override; virtual QStringList mimeTypes() const final override;
//! @} //! @}
//! Column to property index //! Column to property index
@@ -147,11 +148,6 @@ namespace BlackGui
void objectChanged(const BlackMisc::CVariant &object, const BlackMisc::CPropertyIndex &changedIndex); void objectChanged(const BlackMisc::CVariant &object, const BlackMisc::CPropertyIndex &changedIndex);
protected slots: protected slots:
//! Helper method with template free signature
//! \param variant container is transferred in variant
//! \param sort
int ps_updateContainer(const BlackMisc::CVariant &variant, bool sort);
//! Feedback when QStandardItemModel::dataChanged was called //! Feedback when QStandardItemModel::dataChanged was called
virtual void ps_onDataChanged(const QModelIndex &topLeft, const QModelIndex &bottomRight, const QVector<int> &roles) = 0; virtual void ps_onDataChanged(const QModelIndex &topLeft, const QModelIndex &bottomRight, const QVector<int> &roles) = 0;
@@ -164,9 +160,6 @@ namespace BlackGui
//! \param parent //! \param parent
CListModelBaseNonTemplate(const QString &translationContext, QObject *parent = nullptr); CListModelBaseNonTemplate(const QString &translationContext, QObject *parent = nullptr);
//! Helper method with template free signature
virtual int performUpdateContainer(const BlackMisc::CVariant &variant, bool sort) = 0;
CColumns m_columns; //!< columns metadata CColumns m_columns; //!< columns metadata
int m_sortColumn; //!< currently sorted column int m_sortColumn; //!< currently sorted column
bool m_modelDestroyed = false; //!< model is about to be destroyed bool m_modelDestroyed = false; //!< model is about to be destroyed
@@ -187,12 +180,12 @@ namespace BlackGui
//! \name Functions from QStandardItemModel //! \name Functions from QStandardItemModel
//! @{ //! @{
virtual QVariant data(const QModelIndex &index, int role) const override; virtual QVariant data(const QModelIndex &index, int role) const override;
virtual bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole) override; virtual bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole) final override;
virtual QMimeData *mimeData(const QModelIndexList &indexes) const override; virtual QMimeData *mimeData(const QModelIndexList &indexes) const final override;
virtual void sort(int column, Qt::SortOrder order) override; virtual void sort(int column, Qt::SortOrder order) final override;
virtual int rowCount(const QModelIndex &parentIndex = QModelIndex()) const override; virtual int rowCount(const QModelIndex &parentIndex = QModelIndex()) const final override;
virtual bool canDropMimeData(const QMimeData *data, Qt::DropAction action, int row, int column, const QModelIndex &parent) const override; virtual bool canDropMimeData(const QMimeData *data, Qt::DropAction action, int row, int column, const QModelIndex &parent) const final override;
virtual bool dropMimeData(const QMimeData *data, Qt::DropAction action, int row, int column, const QModelIndex &parent) override; virtual bool dropMimeData(const QMimeData *data, Qt::DropAction action, int row, int column, const QModelIndex &parent) final override;
//! @} //! @}
//! \name Functions from CListModelBaseNonTemplate //! \name Functions from CListModelBaseNonTemplate
@@ -293,13 +286,18 @@ namespace BlackGui
//! Set the filter //! Set the filter
void takeFilterOwnership(std::unique_ptr<IModelFilter<ContainerType> > &filter); void takeFilterOwnership(std::unique_ptr<IModelFilter<ContainerType> > &filter);
//! Set the selection model
void setSelectionModel(BlackGui::Models::ISelectionModel<ContainerType> *selectionModel)
{
m_selectionModel = selectionModel;
}
protected: protected:
//! Constructor //! Constructor
CListModelBase(const QString &translationContext, QObject *parent = nullptr); CListModelBase(const QString &translationContext, QObject *parent = nullptr);
//! \name Base class overrides //! \name Base class overrides
//! @{ //! @{
virtual int performUpdateContainer(const BlackMisc::CVariant &variant, bool sort) override;
virtual void ps_onDataChanged(const QModelIndex &topLeft, const QModelIndex &bottomLeft, const QVector<int> &roles) override; virtual void ps_onDataChanged(const QModelIndex &topLeft, const QModelIndex &bottomLeft, const QVector<int> &roles) override;
virtual void ps_onChangedDigest() override; virtual void ps_onChangedDigest() override;
//! @} //! @}
@@ -310,9 +308,10 @@ namespace BlackGui
//! Model changed //! Model changed
void emitModelDataChanged(); void emitModelDataChanged();
std::unique_ptr<IModelFilter<ContainerType> > m_filter; //!< Used filter
ContainerType m_container; //!< used container ContainerType m_container; //!< used container
ContainerType m_containerFiltered; //!< cache for filtered container data ContainerType m_containerFiltered; //!< cache for filtered container data
std::unique_ptr<IModelFilter<ContainerType> > m_filter; //!< used filter
ISelectionModel<ContainerType> *m_selectionModel = nullptr; //!< selection model
}; };
namespace Private namespace Private