forked from teamnwah/openmw-tes3coop
71 lines
2.2 KiB
C++
71 lines
2.2 KiB
C++
|
|
#include "idtableproxymodel.hpp"
|
|
|
|
#include <vector>
|
|
|
|
#include "idtablebase.hpp"
|
|
|
|
void CSMWorld::IdTableProxyModel::updateColumnMap()
|
|
{
|
|
mColumnMap.clear();
|
|
|
|
if (mFilter)
|
|
{
|
|
std::vector<int> columns = mFilter->getReferencedColumns();
|
|
|
|
const IdTableBase& table = dynamic_cast<const IdTableBase&> (*sourceModel());
|
|
|
|
for (std::vector<int>::const_iterator iter (columns.begin()); iter!=columns.end(); ++iter)
|
|
mColumnMap.insert (std::make_pair (*iter,
|
|
table.searchColumnIndex (static_cast<CSMWorld::Columns::ColumnId> (*iter))));
|
|
}
|
|
}
|
|
|
|
bool CSMWorld::IdTableProxyModel::filterAcceptsRow (int sourceRow, const QModelIndex& sourceParent)
|
|
const
|
|
{
|
|
if (!mFilter)
|
|
return true;
|
|
|
|
return mFilter->test (
|
|
dynamic_cast<IdTableBase&> (*sourceModel()), sourceRow, mColumnMap);
|
|
}
|
|
|
|
CSMWorld::IdTableProxyModel::IdTableProxyModel (QObject *parent)
|
|
: QSortFilterProxyModel (parent)
|
|
{
|
|
setSortCaseSensitivity (Qt::CaseInsensitive);
|
|
}
|
|
|
|
QModelIndex CSMWorld::IdTableProxyModel::getModelIndex (const std::string& id, int column) const
|
|
{
|
|
return mapFromSource (dynamic_cast<IdTableBase&> (*sourceModel()).getModelIndex (id, column));
|
|
}
|
|
|
|
void CSMWorld::IdTableProxyModel::setFilter (const boost::shared_ptr<CSMFilter::Node>& filter)
|
|
{
|
|
mFilter = filter;
|
|
updateColumnMap();
|
|
invalidateFilter();
|
|
}
|
|
|
|
bool CSMWorld::IdTableProxyModel::lessThan(const QModelIndex &left, const QModelIndex &right) const
|
|
{
|
|
if(headerData(left.column(), Qt::Horizontal).toString() != "ID")
|
|
return QSortFilterProxyModel::lessThan(left, right);
|
|
|
|
QRegExp cellPattern = QRegExp("^#(\\D?\\d+) +(\\D?\\d+)");
|
|
|
|
int leftResult = cellPattern.indexIn(sourceModel()->data(left).toString());
|
|
int leftX = cellPattern.cap(1).toInt();
|
|
int leftY = cellPattern.cap(2).toInt();
|
|
|
|
int rightResult = cellPattern.indexIn(sourceModel()->data(right).toString());
|
|
int rightX = cellPattern.cap(1).toInt();
|
|
int rightY = cellPattern.cap(2).toInt();
|
|
|
|
if(leftResult != -1 && rightResult != -1)
|
|
return(leftX < rightX) || (leftX == rightX && leftY <= rightY);
|
|
else
|
|
return QSortFilterProxyModel::lessThan(left, right);
|
|
}
|