X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;ds=sidebyside;f=resources%2Fjs%2Fhelpers%2Fpermissions.js;h=18d03bffce1c6be3f56d04de783b42d734578588;hb=cd36cb0ba2718e6bfa08765e7702d57dfe7fd733;hp=2ff823a955143dc166d4169b263a1d87890b5a61;hpb=1c91e5dcedd930bea5fe44ea95a77a9ecd0177a4;p=alttp.git diff --git a/resources/js/helpers/permissions.js b/resources/js/helpers/permissions.js index 2ff823a..18d03bf 100644 --- a/resources/js/helpers/permissions.js +++ b/resources/js/helpers/permissions.js @@ -9,6 +9,21 @@ export const isSameUser = (user, subject) => user && subject && user.id === subj // Tournaments +export const isApplicant = (user, tournament) => { + if (!user || !tournament || !tournament.applications) { + return false; + } + return tournament.applications.find(p => p.user && p.user.id == user.id); +}; + +export const isDeniedApplicant = (user, tournament) => { + if (!user || !tournament || !tournament.applications) { + return false; + } + const applicant = tournament.applications.find(p => p.user && p.user.id == user.id); + return applicant && applicant.denied; +}; + export const isParticipant = (user, tournament) => user && tournament && tournament.participants && tournament.participants.find(p => p.user && p.user.id == user.id); @@ -37,17 +52,24 @@ export const hasFinished = (user, round) => export const mayAddRounds = (user, tournament) => !tournament.locked && - (isAdmin(user) || isRunner(user, tournament) || isTournamentAdmin(user, tournament)); + (isRunner(user, tournament) || isTournamentAdmin(user, tournament)); + +export const mayApply = (user, tournament) => + user && tournament && tournament.accept_applications && + !isRunner(user, tournament) && !isApplicant(user, tournament); + +export const mayHandleApplications = (user, tournament) => + tournament && tournament.accept_applications && isTournamentAdmin(user, tournament); export const mayLockRound = (user, tournament) => - !tournament.locked && (isAdmin(user) || isTournamentAdmin(user, tournament)); + !tournament.locked && isTournamentAdmin(user, tournament); export const maySetSeed = (user, tournament, round) => !round.locked && - (isAdmin(user) || isRunner(user, tournament) || isTournamentAdmin(user, tournament)); + (isRunner(user, tournament) || isTournamentAdmin(user, tournament)); export const mayViewProtocol = (user, tournament) => - isAdmin(user) || isTournamentCrew(user, tournament); + isTournamentCrew(user, tournament); export const maySeeResults = (user, tournament, round) => round.locked || @@ -59,7 +81,7 @@ export const maySeeResults = (user, tournament, round) => // Users export const mayEditNickname = (user, subject) => - isAdmin(user) || isSameUser(user, subject); + isSameUser(user, subject); export const mayEditStreamLink = (user, subject) => - isAdmin(user) || isSameUser(user, subject); + isSameUser(user, subject);