mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-05-05 09:45:44 +08:00
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:
committed by
Mathew Sutcliffe
parent
988e1b70be
commit
a374146a41
@@ -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()
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
Reference in New Issue
Block a user