Merge pull request #12929 from LillyJadeKatrin/retroachievements-leaderboard-fixes

Fix Leaderboards Tab
This commit is contained in:
Admiral H. Curtiss 2024-07-14 16:47:59 +02:00 committed by GitHub
commit a0fc8e6b13
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 18 additions and 2 deletions

View File

@ -843,6 +843,22 @@ void AchievementManager::LoadGameCallback(int result, const char* error_message,
instance.m_update_callback({.all = true}); instance.m_update_callback({.all = true});
// Set this to a value that will immediately trigger RP // Set this to a value that will immediately trigger RP
instance.m_last_rp_time = std::chrono::steady_clock::now() - std::chrono::minutes{2}; instance.m_last_rp_time = std::chrono::steady_clock::now() - std::chrono::minutes{2};
std::lock_guard lg{instance.GetLock()};
auto* leaderboard_list =
rc_client_create_leaderboard_list(client, RC_CLIENT_LEADERBOARD_LIST_GROUPING_NONE);
for (u32 bucket = 0; bucket < leaderboard_list->num_buckets; bucket++)
{
const auto& leaderboard_bucket = leaderboard_list->buckets[bucket];
for (u32 board = 0; board < leaderboard_bucket.num_leaderboards; board++)
{
const auto& leaderboard = leaderboard_bucket.leaderboards[board];
instance.m_leaderboard_map.insert(
std::pair(leaderboard->id, LeaderboardStatus{.name = leaderboard->title,
.description = leaderboard->description}));
}
}
rc_client_destroy_leaderboard_list(leaderboard_list);
} }
void AchievementManager::ChangeMediaCallback(int result, const char* error_message, void AchievementManager::ChangeMediaCallback(int result, const char* error_message,

View File

@ -87,7 +87,7 @@ void AchievementLeaderboardWidget::UpdateData(bool clean_all)
} }
for (auto row : m_leaderboard_order) for (auto row : m_leaderboard_order)
{ {
UpdateRow(row.second); UpdateRow(row.first);
} }
} }
@ -98,7 +98,7 @@ void AchievementLeaderboardWidget::UpdateData(
{ {
if (update_ids.contains(row.first)) if (update_ids.contains(row.first))
{ {
UpdateRow(row.second); UpdateRow(row.first);
} }
} }
} }