From 58cfc39ac42633eafb65f17483533ef285b72c38 Mon Sep 17 00:00:00 2001 From: Nicolas Werner Date: Fri, 19 May 2023 23:19:04 +0200 Subject: Fix StickerPicker padding and names of unnamed packs --- src/GridImagePackModel.cpp | 24 ++++++++++++++++++++++-- src/GridImagePackModel.h | 2 ++ 2 files changed, 24 insertions(+), 2 deletions(-) (limited to 'src') diff --git a/src/GridImagePackModel.cpp b/src/GridImagePackModel.cpp index 59bfae80..59b1725a 100644 --- a/src/GridImagePackModel.cpp +++ b/src/GridImagePackModel.cpp @@ -8,6 +8,7 @@ #include +#include "Cache.h" #include "Cache_p.h" Q_DECLARE_METATYPE(StickerImage) @@ -104,7 +105,7 @@ GridImagePackModel::data(const QModelIndex &index, int role) const const auto &pack = packs[rowToPack[index.row()]]; switch (role) { case Roles::PackName: - return pack.packname; + return nameFromPack(pack); case Roles::Row: { std::size_t offset = static_cast(index.row()) - pack.firstRow; QList imgs; @@ -135,7 +136,7 @@ GridImagePackModel::data(const QModelIndex &index, int role) const switch (role) { case Roles::PackName: - return pack.packname; + return nameFromPack(pack); case Roles::Row: { QList imgs; for (auto img = firstIndex; @@ -162,6 +163,25 @@ GridImagePackModel::data(const QModelIndex &index, int role) const return {}; } +QString +GridImagePackModel::nameFromPack(const PackDesc &pack) const +{ + if (!pack.packname.isEmpty()) { + return pack.packname; + } + + if (!pack.state_key.empty()) { + return QString::fromStdString(pack.state_key); + } + + if (!pack.room_id.empty()) { + auto info = cache::singleRoomInfo(pack.room_id); + return QString::fromStdString(info.name); + } + + return tr("Account Pack"); +} + void GridImagePackModel::setSearchString(QString key) { diff --git a/src/GridImagePackModel.h b/src/GridImagePackModel.h index 06dfe734..8da61b8e 100644 --- a/src/GridImagePackModel.h +++ b/src/GridImagePackModel.h @@ -85,4 +85,6 @@ private: trie> trie_; std::vector> currentSearchResult; std::vector rowToFirstRowEntryFromSearch; + + QString nameFromPack(const PackDesc &pack) const; }; -- cgit 1.5.1