Skip to content

Commit

Permalink
Update achievement leaderboard from pr review.
Browse files Browse the repository at this point in the history
Rename "Leaderboard" to "AchievementsLeaderboard".

Implement the code and database improvements to make the page load faster.
  • Loading branch information
somiaj committed Nov 23, 2024
1 parent 61bd8ee commit 30586c1
Show file tree
Hide file tree
Showing 4 changed files with 18 additions and 15 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -14,12 +14,12 @@
################################################################################

# Leader board for achievements.
package WeBWorK::ContentGenerator::Leaderboard;
package WeBWorK::ContentGenerator::AchievementsLeaderboard;
use Mojo::Base 'WeBWorK::ContentGenerator', -signatures;

=head1 NAME
WeBWorK::ContentGenerator::Leaderboard - Leaderboard for achievements,
WeBWorK::ContentGenerator::AchievementsLeaderboard - Leaderboard for achievements,
which lists the total number of achievement points, level, and badges
earned for each user with the 'include_in_stats' status.
Expand All @@ -41,35 +41,38 @@ sub initialize ($c) {
return unless $c->authz->hasPermissions($c->{userName}, 'view_leaderboard');

# Get list of all users (except set-level proctors) and achievements.
my @allUsers = $db->getUsersWhere({ user_id => { not_like => 'set_id:%' } });
my @achievements = sortAchievements($db->getAchievementsWhere);
my %achievementsById = map { $_->achievement_id => $_ } @achievements;
my %globalUserAchievements =
map { $_->user_id => $_ } $db->getGlobalUserAchievementsWhere({ user_id => { not_like => 'set_id:%' } });

my @allBadgeIDs = $db->listAchievements;
my @allBadges = @allBadgeIDs ? sortAchievements($db->getAchievements(@allBadgeIDs)) : ();

$c->{showUserNames} = $c->authz->hasPermissions($c->{userName}, 'view_leaderboard_usernames');
$c->{showLevels} = 0; # Hide level column unless at least one user has a level achievement.

my @rows;
for my $user (@allUsers) {
for my $user ($db->getUsersWhere({ user_id => { not_like => 'set_id:%' } })) {
# Only include users who can be shown in stats.
next unless $ce->status_abbrev_has_behavior($user->status, 'include_in_stats');

# Skip unless user has achievement data.
my $globalData = $db->getGlobalUserAchievement($user->user_id);
my $globalData = $globalUserAchievements{ $user->user_id };
next unless $globalData;

my $level = $globalData->level_achievement_id ? $db->getAchievement($globalData->level_achievement_id) : '';
my $level = $globalData->level_achievement_id ? $achievementsById{ $globalData->level_achievement_id } : '';

my @badges;
for my $badge (@allBadges) {
for my $achievement (@achievements) {
# Skip level achievements and only show earned achievements.
last if $badge->category eq 'level';
next unless $db->existsUserAchievement($user->user_id, $badge->achievement_id);
last if $achievement->category eq 'level';

my $userBadge = $db->getUserAchievement($user->user_id, $badge->achievement_id);
push(@badges, $badge) if $badge->enabled && $userBadge->earned;
my $userBadge = $db->getUserAchievement($user->user_id, $achievement->achievement_id);
push(@badges, $achievement) if $userBadge && $achievement->enabled && $userBadge->earned;
}

push(@rows, [ $globalData->achievement_points, $level, $user, \@badges ]);
push(@rows, [ $globalData->achievement_points || 0, $level, $user, \@badges ]);
}

# Sort rows descending by achievement points (or number of badges if achievement points are equal)
Expand Down
4 changes: 2 additions & 2 deletions lib/WeBWorK/Utils/Routes.pm
Original file line number Diff line number Diff line change
Expand Up @@ -287,8 +287,8 @@ my %routeParameters = (
unrestricted => 1
},
achievements_leaderboard => {
title => x('Leaderboard'),
module => 'Leaderboard',
title => x('Achievements Leaderboard'),
module => 'AchievementsLeaderboard',
path => '/leaderboard',
unrestricted => 1
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
%################################################################################
%
% layout 'help_macro';
% title maketext('Leaderboard Help');
% title maketext('Achievements Leaderboard Help');
%
<p>
<%= maketext('The leaderboard orders the achievement points earned from the greatest to the least. '
Expand Down

0 comments on commit 30586c1

Please sign in to comment.