Défis de compétition et remisage
This commit is contained in:
parent
3cd8bf82dc
commit
a3c71800af
29
bot.py
29
bot.py
@ -229,6 +229,33 @@ async def tirage(ctx: commands.Context, nb_defis: int = 5):
|
|||||||
await ctx.send("Les mains de départ ont bien été tirées ! Le contenu vous a été envoyé en MP.")
|
await ctx.send("Les mains de départ ont bien été tirées ! Le contenu vous a été envoyé en MP.")
|
||||||
|
|
||||||
|
|
||||||
|
@bot.command()
|
||||||
|
async def competition(ctx: commands.Context):
|
||||||
|
defi_competition = random.choice([defi for defi in DEFIS['competition'] if defi['id'] not in data['defis']['tires_competition']])
|
||||||
|
data['defis']['tires_competition'].append(defi_competition['id'])
|
||||||
|
embed = discord.Embed(title=defi_competition['nom'], description=defi_competition['description'])
|
||||||
|
embed.set_footer(text=f"Défi de compétition n°{defi_competition['id']}")
|
||||||
|
with DATA_FILE.open('w') as data_file:
|
||||||
|
json.dump(data, data_file, indent=2)
|
||||||
|
await ctx.send("@everyone Un canton est attaqué ! L'équipe vainqueure de ce défi conservera son contrôle jusqu'à la fin du jeu :", embed=embed)
|
||||||
|
|
||||||
|
|
||||||
|
@bot.command()
|
||||||
|
async def remiser(ctx: commands.Context, type_defi: Literal['capture', 'competition'] = "capture", id_defi: int | None = None):
|
||||||
|
defis = DEFIS[type_defi]
|
||||||
|
try:
|
||||||
|
defi = next(defi for defi in defis if defi['id'] == id_defi)
|
||||||
|
except StopIteration:
|
||||||
|
raise commands.BadArgument(f"Le défi de {type_defi} n°{id_defi} n'existe pas.")
|
||||||
|
if id_defi in data['defis'][f'tires_{type_defi}']:
|
||||||
|
data['defis'][f'tires_{type_defi}'].remove(id_defi)
|
||||||
|
with DATA_FILE.open('w') as data_file:
|
||||||
|
json.dump(data, data_file, indent=2)
|
||||||
|
await ctx.reply(f"Le défi de {type_defi} n°{id_defi} ({defi['nom']}) a été retiré de la défausse et pourra à nouveau être tiré au sort.")
|
||||||
|
else:
|
||||||
|
await ctx.reply(f"Le défi de {type_defi} n°{id_defi} ({defi['nom']}) n'était déjà pas dans la défausse.")
|
||||||
|
|
||||||
|
|
||||||
@bot.command(name="main")
|
@bot.command(name="main")
|
||||||
async def afficher_main(ctx: commands.Context, mode: Literal['public', 'prive'] = "prive", author_id: int | None = None):
|
async def afficher_main(ctx: commands.Context, mode: Literal['public', 'prive'] = "prive", author_id: int | None = None):
|
||||||
author_id = author_id or ctx.author.id
|
author_id = author_id or ctx.author.id
|
||||||
@ -404,6 +431,8 @@ async def save(ctx: commands.Context):
|
|||||||
@defis.error
|
@defis.error
|
||||||
@description.error
|
@description.error
|
||||||
@tirage.error
|
@tirage.error
|
||||||
|
@competition.error
|
||||||
|
@remiser.error
|
||||||
@afficher_main.error
|
@afficher_main.error
|
||||||
@terminer.error
|
@terminer.error
|
||||||
@echange.error
|
@echange.error
|
||||||
|
Loading…
x
Reference in New Issue
Block a user