2020-10-13 21:02:40 +02:00
|
|
|
from decorators import help
|
|
|
|
import discord
|
|
|
|
from discord.ext import commands
|
|
|
|
from enums.help_categories import Category
|
|
|
|
from functions import colours
|
|
|
|
import random
|
|
|
|
import requests
|
|
|
|
import json
|
|
|
|
|
|
|
|
|
|
|
|
class Random(commands.Cog):
|
|
|
|
def __init__(self, client):
|
|
|
|
self.client = client
|
|
|
|
|
|
|
|
# Don't allow any commands to work when locked
|
|
|
|
def cog_check(self, ctx):
|
|
|
|
return not self.client.locked
|
|
|
|
|
|
|
|
# Creates an alias
|
|
|
|
@commands.command(name="Choice", aliases=["Choose"], usage="[Argumenten]")
|
|
|
|
async def choose(self, ctx, *options):
|
|
|
|
await self.choice(ctx, options)
|
|
|
|
|
|
|
|
@commands.command(name="Shuffle", usage="[Argumenten]")
|
|
|
|
async def _shuffle(self, ctx, *options):
|
|
|
|
await self.shuffle(ctx, options)
|
|
|
|
|
|
|
|
@commands.group(name="Random", aliases=["R", "Rand", "RNG"], case_insensitive=True, invoke_without_command=True)
|
|
|
|
@help.Category(category=Category.Random, unpack=True)
|
|
|
|
async def random(self, ctx):
|
|
|
|
pass
|
|
|
|
|
|
|
|
@random.command(name="Choice", usage="[Argumenten]")
|
|
|
|
async def choice(self, ctx, *options):
|
2020-11-27 12:23:43 +01:00
|
|
|
if not options or not options[0]:
|
2020-10-13 21:02:40 +02:00
|
|
|
await ctx.send("Geef een geldige reeks op.")
|
|
|
|
return
|
|
|
|
|
|
|
|
await ctx.send(random.choice(options))
|
|
|
|
|
|
|
|
@random.command(name="Number", aliases=["Int"], usage="[Van]* [Tot]*")
|
|
|
|
async def number(self, ctx, to=100, start=1):
|
|
|
|
# This allows number(to) to work, as well as number(start, to)
|
|
|
|
if start > to:
|
|
|
|
start, to = to, start
|
|
|
|
|
|
|
|
await ctx.send(random.randint(start, to))
|
|
|
|
|
|
|
|
@number.error
|
|
|
|
async def on_number_error(self, ctx, error):
|
|
|
|
if isinstance(error, discord.ext.commands.BadArgument):
|
|
|
|
await ctx.send("Dit is geen geldig getal.")
|
|
|
|
else:
|
|
|
|
raise error
|
|
|
|
|
|
|
|
@random.command(name="Name")
|
2020-11-27 12:23:43 +01:00
|
|
|
async def name(self, ctx):
|
2020-10-13 21:02:40 +02:00
|
|
|
try:
|
|
|
|
name = requests.get("https://randomuser.me/api/").json()
|
|
|
|
except json.decoder.JSONDecodeError:
|
|
|
|
await ctx.send("Er ging iets mis. Probeer het opnieuw.")
|
|
|
|
return
|
|
|
|
|
|
|
|
name = name["results"][0]["name"]
|
|
|
|
await ctx.send("{} {} {}".format(name["title"], name["first"], name["last"]))
|
|
|
|
|
|
|
|
@random.command(name="Identity", aliases=["Id"])
|
2020-11-27 12:23:43 +01:00
|
|
|
async def identity(self, ctx):
|
2020-10-13 21:02:40 +02:00
|
|
|
try:
|
|
|
|
identity = requests.get("https://randomuser.me/api/").json()
|
|
|
|
except json.decoder.JSONDecodeError:
|
|
|
|
await ctx.send("Er ging iets mis. Probeer het opnieuw.")
|
|
|
|
return
|
|
|
|
|
|
|
|
identity = identity["results"][0]
|
|
|
|
name = identity["name"]
|
|
|
|
name = "{} {} {}".format(name["title"], name["first"], name["last"])
|
|
|
|
|
|
|
|
gender = identity["gender"]
|
|
|
|
street = "{} {}".format(identity["location"]["street"]["number"], identity["location"]["street"]["name"])
|
|
|
|
location = "{}, {}, {}, {}".format(street, identity["location"]["city"],
|
|
|
|
identity["location"]["state"], identity["location"]["country"])
|
|
|
|
age = identity["dob"]["age"]
|
|
|
|
|
|
|
|
await ctx.send("{}\n{}, {}\n{}".format(name, age, gender, location))
|
|
|
|
|
|
|
|
@random.command(name="Shuffle", aliases=["Order"], usage="[Argumenten]")
|
|
|
|
async def shuffle(self, ctx, *args):
|
|
|
|
if not args:
|
|
|
|
await ctx.send("Geef een geldige reeks op.")
|
|
|
|
return
|
|
|
|
|
|
|
|
# Allows shuffle alias to pass in it's args too
|
|
|
|
if isinstance(args[0], tuple):
|
|
|
|
args = args[0]
|
|
|
|
|
|
|
|
args = list(args)
|
|
|
|
|
|
|
|
random.shuffle(args)
|
|
|
|
|
|
|
|
await ctx.send(" - ".join(args))
|
|
|
|
|
|
|
|
@random.command(name="Colour", aliases=["Color"])
|
2020-11-27 12:23:43 +01:00
|
|
|
async def colour(self, ctx):
|
2020-10-13 21:02:40 +02:00
|
|
|
r, g, b = colours.randomRGB()
|
|
|
|
|
|
|
|
embed = discord.Embed(colour=discord.Colour.from_rgb(r, g, b))
|
|
|
|
embed.set_author(name="Random Colour")
|
|
|
|
embed.add_field(name="RGB", value="{}, {}, {}".format(r, g, b), inline=False)
|
|
|
|
embed.add_field(name="HEX", value=colours.RGBToHEX(r, g, b), inline=False)
|
|
|
|
embed.add_field(name="HSL", value="{}°, {}%, {}%".format(*colours.RGBToHSL(r, g, b)), inline=False)
|
|
|
|
embed.add_field(name="HSV", value="{}°, {}%, {}%".format(*colours.RGBToHSV(r, g, b)), inline=False)
|
|
|
|
await ctx.send(embed=embed)
|
|
|
|
|
|
|
|
@random.command(name="Timestamp", aliases=["Time", "Ts"])
|
2020-11-27 12:23:43 +01:00
|
|
|
async def timestamp(self, ctx):
|
2020-10-13 21:02:40 +02:00
|
|
|
hour = str(random.randint(0, 23))
|
|
|
|
hour = ("0" if len(hour) == 1 else "") + hour
|
|
|
|
minutes = str(random.randint(0, 23))
|
|
|
|
minutes = ("0" if len(minutes) == 1 else "") + minutes
|
|
|
|
await ctx.send("{}:{}".format(hour, minutes))
|
|
|
|
|
|
|
|
@random.command(name="Fact", aliases=["Knowledge"])
|
2020-11-27 12:23:43 +01:00
|
|
|
async def fact(self, ctx):
|
2020-10-13 21:02:40 +02:00
|
|
|
randomFact = requests.get("https://uselessfacts.jsph.pl/random.json?language=en").json()
|
|
|
|
await ctx.send(randomFact["text"])
|
|
|
|
|
|
|
|
@commands.command(name="Yes/No", aliases=["Yn"])
|
|
|
|
@help.Category(Category.Random)
|
2020-11-27 12:23:43 +01:00
|
|
|
async def yesno(self, ctx):
|
2020-10-13 21:02:40 +02:00
|
|
|
await ctx.send(random.choice(["Ja.", "Nee."]))
|
|
|
|
|
|
|
|
|
|
|
|
def setup(client):
|
|
|
|
client.add_cog(Random(client))
|