diff options
| author | 2022-03-16 20:10:49 -0400 | |
|---|---|---|
| committer | 2022-04-02 19:27:18 -0400 | |
| commit | e59206008dd5f597975dc7a98344f21c4678101a (patch) | |
| tree | 6ff765c82d483c8615b9142b7d16de92e8896669 | |
| parent | Merge pull request #2087 from python-discord/fix-issue-1930 (diff) | |
Replaced resources.md with Resources Cog
We can use this cog to get a URL with resources filtered by the terms
input by the user in the Discord command.
Diffstat (limited to '')
| -rw-r--r-- | bot/exts/info/resources.py | 70 | ||||
| -rw-r--r-- | bot/resources/tags/resources.md | 6 | 
2 files changed, 70 insertions, 6 deletions
| diff --git a/bot/exts/info/resources.py b/bot/exts/info/resources.py new file mode 100644 index 000000000..e27357484 --- /dev/null +++ b/bot/exts/info/resources.py @@ -0,0 +1,70 @@ +import re +from typing import Optional +from urllib.parse import quote + +from discord import Embed +from discord.ext import commands + +from bot.bot import Bot + +REGEX_CONSECUTIVE_NON_LETTERS = r"[^A-Za-z0-9]+" +RESOURCE_URL = "https://www.pythondiscord.com/resources/" + + +def to_kebabcase(resource_topic: str) -> str: +    """ +    Convert any string to kebab-case. + +    For example, convert +    "__Favorite FROOT¤#/$?is----LeMON???" to +    "favorite-froot-is-lemon" + +    Code adopted from: +    https://github.com/python-discord/site/blob/main/pydis_site/apps/resources/templatetags/to_kebabcase.py +    """ +    # First, make it lowercase, and just remove any apostrophes. +    # We remove the apostrophes because "wasnt" is better than "wasn-t" +    resource_topic = resource_topic.casefold() +    resource_topic = resource_topic.replace("'", '') + +    # Now, replace any non-alphanumerics that remains with a dash. +    # If there are multiple consecutive non-letters, just replace them with a single dash. +    # my-favorite-class is better than my-favorite------class +    resource_topic = re.sub( +        REGEX_CONSECUTIVE_NON_LETTERS, +        "-", +        resource_topic, +    ) + +    # Now we use strip to get rid of any leading or trailing dashes. +    resource_topic = resource_topic.strip("-") +    return resource_topic + + +class Resources(commands.Cog): +    """Display information about the Python Discord website Resource page.""" + +    def __init__(self, bot: Bot): +        self.bot = bot + +    @commands.command(name="resources", aliases=("res",)) +    async def resources_command(self, ctx: commands.Context, *, resource_topic: Optional[str]) -> None: +        """Display information and a link to the Python Discord website Resources page.""" +        url = RESOURCE_URL + +        if resource_topic: +            # Capture everything prior to new line allowing users to add messages below the command then prep for url +            url = f"{url}?topics={quote(to_kebabcase(resource_topic.splitlines()[0]))}" + +        embed = Embed( +            title="Resources", +            description=f"The [Resources page]({url}) on our website contains a list " +                        f"of hand-selected learning resources that we " +                        f"regularly recommend to both beginners and experts." +        ) +        await ctx.send(embed=embed) + + +def setup(bot: Bot) -> None: +    """Load the Resources cog.""" +    bot.add_cog(Resources(bot)) diff --git a/bot/resources/tags/resources.md b/bot/resources/tags/resources.md deleted file mode 100644 index 201e0eb1e..000000000 --- a/bot/resources/tags/resources.md +++ /dev/null @@ -1,6 +0,0 @@ ---- -embed: -    title: "Resources" ---- - -The [Resources page](https://www.pythondiscord.com/resources/) on our website contains a list of hand-selected learning resources that we regularly recommend to both beginners and experts. | 
