Fix server columns text other than name being invisible (#4475)
This commit is contained in:
@@ -112,11 +112,7 @@ struct Server {
|
|||||||
QByteArray m_icon;
|
QByteArray m_icon;
|
||||||
|
|
||||||
// Data - temporary
|
// Data - temporary
|
||||||
bool m_checked = false;
|
|
||||||
bool m_up = false;
|
|
||||||
QString m_motd; // https://mctools.org/motd-creator
|
|
||||||
std::optional<int> m_currentPlayers; // nullopt if not calculated/calculating
|
std::optional<int> m_currentPlayers; // nullopt if not calculated/calculating
|
||||||
int m_maxPlayers = 0;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static std::unique_ptr<nbt::tag_compound> parseServersDat(const QString& filename)
|
static std::unique_ptr<nbt::tag_compound> parseServersDat(const QString& filename)
|
||||||
@@ -312,8 +308,7 @@ class ServersModel : public QAbstractListModel {
|
|||||||
|
|
||||||
switch (role) {
|
switch (role) {
|
||||||
case Qt::DecorationRole: {
|
case Qt::DecorationRole: {
|
||||||
switch (column) {
|
if (column == 0) {
|
||||||
case 0: {
|
|
||||||
auto& bytes = m_servers[row].m_icon;
|
auto& bytes = m_servers[row].m_icon;
|
||||||
if (bytes.size()) {
|
if (bytes.size()) {
|
||||||
QPixmap px;
|
QPixmap px;
|
||||||
@@ -321,28 +316,25 @@ class ServersModel : public QAbstractListModel {
|
|||||||
return QIcon(px);
|
return QIcon(px);
|
||||||
}
|
}
|
||||||
return QIcon::fromTheme("unknown_server");
|
return QIcon::fromTheme("unknown_server");
|
||||||
}
|
|
||||||
case 1:
|
|
||||||
return m_servers[row].m_address;
|
|
||||||
default:
|
|
||||||
return QVariant();
|
|
||||||
}
|
|
||||||
case 2:
|
|
||||||
if (role == Qt::DisplayRole) {
|
|
||||||
if (m_servers[row].m_currentPlayers) {
|
|
||||||
return *m_servers[row].m_currentPlayers;
|
|
||||||
} else {
|
|
||||||
return "...";
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
return QVariant();
|
return QVariant();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
case Qt::DisplayRole:
|
case Qt::DisplayRole:
|
||||||
if (column == 0)
|
switch (column) {
|
||||||
|
case 0:
|
||||||
return m_servers[row].m_name;
|
return m_servers[row].m_name;
|
||||||
else
|
case 1:
|
||||||
|
return m_servers[row].m_address;
|
||||||
|
case 2:
|
||||||
|
if (m_servers[row].m_currentPlayers) {
|
||||||
|
return *m_servers[row].m_currentPlayers;
|
||||||
|
} else {
|
||||||
|
return "...";
|
||||||
|
}
|
||||||
|
default:
|
||||||
return QVariant();
|
return QVariant();
|
||||||
|
}
|
||||||
case ServerPtrRole:
|
case ServerPtrRole:
|
||||||
if (column == 0)
|
if (column == 0)
|
||||||
return QVariant::fromValue<void*>((void*)&m_servers[row]);
|
return QVariant::fromValue<void*>((void*)&m_servers[row]);
|
||||||
|
|||||||
Reference in New Issue
Block a user