Fixed leaderboard dumping every single player.
This commit is contained in:
parent
4d324993fd
commit
4ef8b55021
|
@ -73,7 +73,7 @@ function getLeaderboard(game, { user, room, command }) {
|
|||
return;
|
||||
}
|
||||
|
||||
game.sendMessage(`The top ${Math.min(Object.keys(leaderboard).length, 10)} ${style.italic(game.name)} players are: ${getLeaders(leaderboard, user, false)}`, room.id);
|
||||
game.sendMessage(`The top ${Math.min(Object.keys(leaderboard).length, 10)} ${style.italic(game.name)} players are: ${getLeaders(leaderboard, user, false, 10)}`, room.id);
|
||||
}
|
||||
|
||||
/* eslint-disable no-irregular-whitespace */
|
||||
|
|
|
@ -3,16 +3,20 @@
|
|||
const config = require('config');
|
||||
const style = require('./style');
|
||||
|
||||
function getLeaders(points, user, ping = true) {
|
||||
return Object.entries(points).sort(([, scoreA], [, scoreB]) => scoreB - scoreA).map(([userKey, score], index) => {
|
||||
const username = userKey.split(':')[1] || userKey; // process the points file
|
||||
function getLeaders(points, user, ping = true, limit = Infinity) {
|
||||
return Object.entries(points)
|
||||
.sort(([, scoreA], [, scoreB]) => scoreB - scoreA)
|
||||
.slice(0, limit)
|
||||
.map(([userKey, score], index) => {
|
||||
const username = userKey.split(':')[1] || userKey; // process the points file
|
||||
|
||||
if (index === 0) {
|
||||
return `${style.bold(style.yellow(`${ping ? config.usernamePrefix : ''}${username}`))} with ${style.bold(`${score}`)} points`;
|
||||
}
|
||||
if (index === 0) {
|
||||
return `${style.bold(style.yellow(`${ping ? config.usernamePrefix : ''}${username}`))} with ${style.bold(`${score}`)} points`;
|
||||
}
|
||||
|
||||
return `${style.bold(style.cyan(`${ping ? config.usernamePrefix : ''}${username}`))} with ${style.bold(`${score}`)} points`;
|
||||
}).join(', ');
|
||||
return `${style.bold(style.cyan(`${ping ? config.usernamePrefix : ''}${username}`))} with ${style.bold(`${score}`)} points`;
|
||||
})
|
||||
.join(', ');
|
||||
}
|
||||
|
||||
module.exports = getLeaders;
|
||||
|
|
Loading…
Reference in New Issue