Sort Mana cost using CMC
This commit is contained in:
parent
0e203b3ac2
commit
25290227ca
2 changed files with 7 additions and 4 deletions
|
@ -32,7 +32,7 @@ QVariant CardDatabaseModel::data(const QModelIndex &index, int role) const
|
||||||
return QVariant();
|
return QVariant();
|
||||||
if ((index.row() >= cardList.size()) || (index.column() >= CARDDBMODEL_COLUMNS))
|
if ((index.row() >= cardList.size()) || (index.column() >= CARDDBMODEL_COLUMNS))
|
||||||
return QVariant();
|
return QVariant();
|
||||||
if (role != Qt::DisplayRole)
|
if (role != Qt::DisplayRole && role != SortRole)
|
||||||
return QVariant();
|
return QVariant();
|
||||||
|
|
||||||
CardInfo *card = cardList.at(index.row());
|
CardInfo *card = cardList.at(index.row());
|
||||||
|
@ -45,7 +45,9 @@ QVariant CardDatabaseModel::data(const QModelIndex &index, int role) const
|
||||||
setList << sets[i]->getShortName();
|
setList << sets[i]->getShortName();
|
||||||
return setList.join(", ");
|
return setList.join(", ");
|
||||||
}
|
}
|
||||||
case ManaCostColumn: return card->getManaCost();
|
case ManaCostColumn: return role == SortRole ?
|
||||||
|
QString("%1%2").arg(card->getCmc(), 4, QChar('0')).arg(card->getManaCost()) :
|
||||||
|
card->getManaCost();
|
||||||
case CardTypeColumn: return card->getCardType();
|
case CardTypeColumn: return card->getCardType();
|
||||||
case PTColumn: return card->getPowTough();
|
case PTColumn: return card->getPowTough();
|
||||||
default: return QVariant();
|
default: return QVariant();
|
||||||
|
@ -122,8 +124,8 @@ CardDatabaseDisplayModel::CardDatabaseDisplayModel(QObject *parent)
|
||||||
|
|
||||||
bool CardDatabaseDisplayModel::lessThan(const QModelIndex &left, const QModelIndex &right) const {
|
bool CardDatabaseDisplayModel::lessThan(const QModelIndex &left, const QModelIndex &right) const {
|
||||||
|
|
||||||
QString leftString = sourceModel()->data(left).toString();
|
QString leftString = sourceModel()->data(left, CardDatabaseModel::SortRole).toString();
|
||||||
QString rightString = sourceModel()->data(right).toString();
|
QString rightString = sourceModel()->data(right, CardDatabaseModel::SortRole).toString();
|
||||||
|
|
||||||
if (!cardName.isEmpty() && left.column() == CardDatabaseModel::NameColumn)
|
if (!cardName.isEmpty() && left.column() == CardDatabaseModel::NameColumn)
|
||||||
{
|
{
|
||||||
|
|
|
@ -13,6 +13,7 @@ class CardDatabaseModel : public QAbstractListModel {
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
enum Columns { NameColumn, SetListColumn, ManaCostColumn, CardTypeColumn, PTColumn, CMCColumn };
|
enum Columns { NameColumn, SetListColumn, ManaCostColumn, CardTypeColumn, PTColumn, CMCColumn };
|
||||||
|
enum Role { SortRole=Qt::UserRole };
|
||||||
CardDatabaseModel(CardDatabase *_db, QObject *parent = 0);
|
CardDatabaseModel(CardDatabase *_db, QObject *parent = 0);
|
||||||
~CardDatabaseModel();
|
~CardDatabaseModel();
|
||||||
int rowCount(const QModelIndex &parent = QModelIndex()) const;
|
int rowCount(const QModelIndex &parent = QModelIndex()) const;
|
||||||
|
|
Loading…
Reference in a new issue