X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=resources%2Fjs%2Fhelpers%2FParticipant.js;h=1a24f8efef9ee242be68ec7e0af9a271fda6010a;hb=cce28e8619fe87d4be33f82df9a5ec16b2ad9cf6;hp=8545e0335c2f37c9fb854138e1a930211d18648e;hpb=d32516335ea2534e15256c948e9c38d3de40794b;p=alttp.git diff --git a/resources/js/helpers/Participant.js b/resources/js/helpers/Participant.js index 8545e03..1a24f8e 100644 --- a/resources/js/helpers/Participant.js +++ b/resources/js/helpers/Participant.js @@ -1,3 +1,22 @@ +import User from './User'; + +export const compareFinished = round => (a, b) => { + const a_result = findResult(a, round); + const b_result = findResult(b, round); + const a_finished = a_result && a_result.has_finished; + const b_finished = b_result && b_result.has_finished; + if (a_finished) { + if (b_finished) { + return compareUsername(a, b); + } + return -1; + } + if (b_finished) { + return 1; + } + return compareUsername(a, b); +}; + export const comparePlacement = (a, b) => { if (a.placement < b.placement) return -1; if (b.placement < a.placement) return 1; @@ -24,8 +43,8 @@ export const compareResult = round => (a, b) => { }; export const compareUsername = (a, b) => { - const a_name = a && a.user && a.user.username ? a.user.username : ''; - const b_name = b && b.user && b.user.username ? b.user.username : ''; + const a_name = getUserName(a); + const b_name = getUserName(b); return a_name.localeCompare(b_name); }; @@ -35,12 +54,21 @@ export const findResult = (participant, round) => { return round.results.find(result => result.user_id === participant.user_id); }; +export const getUserName = participant => + participant.user ? User.getUserName(participant.user) : ''; + export const isRunner = participant => participant && participant.roles && participant.roles.includes('runner'); export const isTournamentAdmin = participant => participant && participant.roles && participant.roles.includes('admin'); +export const isTournamentCrew = participant => + isTournamentAdmin(participant) || isTournamentMonitor(participant); + +export const isTournamentMonitor = participant => + participant && participant.roles && participant.roles.includes('monitor'); + export const patchUser = (participant, user) => { if (!participant || !user) return participant; if (participant.user_id != user.id) return participant; @@ -53,18 +81,36 @@ export const patchUser = (participant, user) => { }; }; +export const sortByFinished = (participants, round) => { + if (!participants || !participants.length) return participants; + if (!round || !round.results || !round.results.length) return participants; + return participants.sort(compareFinished(round)); +}; + export const sortByResult = (participants, round) => { if (!participants || !participants.length) return participants; if (!round || !round.results || !round.results.length) return participants; return participants.sort(compareResult(round)); }; +export const sortByUsername = (participants, round) => { + if (!participants || !participants.length) return participants; + if (!round || !round.results || !round.results.length) return participants; + return participants.sort(compareUsername); +}; + export default { + compareFinished, compareResult, compareUsername, findResult, + getUserName, isRunner, isTournamentAdmin, + isTournamentCrew, + isTournamentMonitor, patchUser, + sortByFinished, sortByResult, + sortByUsername, };