diff options
| author | 2021-06-04 19:31:52 +0100 | |
|---|---|---|
| committer | 2021-06-04 19:31:52 +0100 | |
| commit | a40d5ad2e4a6b87bfdfef0112610cefd9ed55637 (patch) | |
| tree | 0ca0b361101e25892862d5bb6130c464a696499c /bot/exts | |
| parent | Merge pull request #764 from OculusMode/contri-readme-change (diff) | |
| parent | Merge branch 'main' into feature/pride-leaders (diff) | |
Merge pull request #614 from Shivansh-007/feature/pride-leaders
Tech Leaders Pride 
Diffstat (limited to 'bot/exts')
| -rw-r--r-- | bot/exts/pride/pride_leader.py | 117 | 
1 files changed, 117 insertions, 0 deletions
| diff --git a/bot/exts/pride/pride_leader.py b/bot/exts/pride/pride_leader.py new file mode 100644 index 00000000..c3426ad1 --- /dev/null +++ b/bot/exts/pride/pride_leader.py @@ -0,0 +1,117 @@ +import json +import logging +import random +from pathlib import Path +from typing import Optional + +import discord +from discord.ext import commands +from fuzzywuzzy import fuzz + +from bot import bot +from bot import constants + +log = logging.getLogger(__name__) + +PRIDE_RESOURCE = json.loads(Path("bot/resources/pride/prideleader.json").read_text("utf8")) +MINIMUM_FUZZ_RATIO = 40 + + +class PrideLeader(commands.Cog): +    """Gives information about Pride Leaders.""" + +    def __init__(self, bot: bot.Bot): +        self.bot = bot + +    def invalid_embed_generate(self, pride_leader: str) -> discord.Embed: +        """ +        Generates Invalid Embed. + +        The invalid embed contains a list of closely matched names of the invalid pride +        leader the user gave. If no closely matched names are found it would list all +        the available pride leader names. + +        Wikipedia is a useful place to learn about pride leaders and we don't have all +        the pride leaders, so the bot would add a field containing the wikipedia +        command to execute. +        """ +        embed = discord.Embed( +            color=constants.Colours.soft_red +        ) +        valid_names = [] +        pride_leader = pride_leader.title() +        for name in PRIDE_RESOURCE: +            if fuzz.ratio(pride_leader, name) >= MINIMUM_FUZZ_RATIO: +                valid_names.append(name) + +        if not valid_names: +            valid_names = ", ".join(PRIDE_RESOURCE) +            error_msg = "Sorry your input didn't match any stored names, here is a list of available names:" +        else: +            valid_names = "\n".join(valid_names) +            error_msg = "Did you mean?" + +        embed.description = f"{error_msg}\n```{valid_names}```" +        embed.set_footer(text="To add more pride leaders, feel free to open a pull request!") + +        return embed + +    def embed_builder(self, pride_leader: dict) -> discord.Embed: +        """Generate an Embed with information about a pride leader.""" +        name = [name for name, info in PRIDE_RESOURCE.items() if info == pride_leader][0] + +        embed = discord.Embed( +            title=name, +            description=pride_leader["About"], +            color=constants.Colours.blue +        ) +        embed.add_field( +            name="Known for", +            value=pride_leader["Known for"], +            inline=False +        ) +        embed.add_field( +            name="D.O.B and Birth place", +            value=pride_leader["Born"], +            inline=False +        ) +        embed.add_field( +            name="Awards and honors", +            value=pride_leader["Awards"], +            inline=False +        ) +        embed.add_field( +            name="For More Information", +            value=f"Do `{constants.Client.prefix}wiki {name}`" +                  f" in <#{constants.Channels.community_bot_commands}>", +            inline=False +        ) +        embed.set_thumbnail(url=pride_leader["url"]) +        return embed + +    @commands.command(aliases=("pl", "prideleader")) +    async def pride_leader(self, ctx: commands.Context, *, pride_leader_name: Optional[str]) -> None: +        """ +        Information about a Pride Leader. + +        Returns information about the specified pride leader +        and if there is no pride leader given, return a random pride leader. +        """ +        if not pride_leader_name: +            leader = random.choice(list(PRIDE_RESOURCE.values())) +        else: +            leader = PRIDE_RESOURCE.get(pride_leader_name.title()) +            if not leader: +                log.trace(f"Got a Invalid pride leader: {pride_leader_name}") + +                embed = self.invalid_embed_generate(pride_leader_name) +                await ctx.send(embed=embed) +                return + +        embed = self.embed_builder(leader) +        await ctx.send(embed=embed) + + +def setup(bot: bot.Bot) -> None: +    """Load the Pride Leader Cog.""" +    bot.add_cog(PrideLeader(bot)) | 
