Skip to main content

A UI kit containing reusable, dynamic, and intuitive views for Discord bots.

Project description

😻 Bot UI Kitty

Development Status Latest Version on PyPI Supported Python Versions Build Status CodeQL Status CodeFactor Grade

A collection of reusable, dynamic, and intuitive Discord UI views, built on top of Pycord's Bot UI Kit.

This project was originally created for personal use in my (way too many) Discord bots, but I decided to make it more easily accessible just in case other bot developers find it helpful. 💜

Currently, the only supported Discord library is Pycord, because that's the one that most of my bots happen to use. I'd love to extend support to other libraries too, but I'm not sure when I'll be able to make the time to do so. In the meantime, if you're using a different library, check out my other utility kit for Discord bots – Botstrap!

Contributions to this project are very welcome, as long as they pass all the checks to keep it green and healthy. ✅

Installation

pip install -U bot-ui-kitty

Python 3.10 or higher is required. It's also generally a good idea to upgrade pip (python -m pip install -U pip).

For Development

git clone https://github.com/nuztalgia/bot-ui-kitty.git
cd bot-ui-kitty
pip install -e .

This will create an editable installation of bot-ui-kitty in your current environment. Any changes you make to the code will immediately take effect, so using a virtual env is highly recommended!

Available Views

Dynamic Select

This view is designed to handle any use case that calls for selecting a single item from a sequence of possible options. It'll automatically choose to display either a row of buttons, a dropdown menu, or a combination of both (to emulate pagination) depending on the number of options you throw at it! 🤹

  • Example 1: Choose your starter Pokemon! (3 options)

    image

    number = await uikitty.dynamic_select(
        ctx,
        content="Choose your starter Pokemon!",
        **{"🌱 Bulbasaur": 1, "🔥 Charmander": 4, "💧 Squirtle": 7},
    )
    await ctx.edit(content=f"Your Pokemon's number is **#00{number}**!", view=None)
    

  • Example 2: What time is it, Mr. Wolf? (24 options)

    image

    time = await uikitty.dynamic_select(
        ctx,
        *[f"{str(i).zfill(2)}:00" for i in range(24)],
        select_placeholder="What time is it, Mr. Wolf?",
    )
    await ctx.edit(content=f"It's ~~{time}~~ **DINNER TIME!!!**", view=None)
    

  • Example 3: I heard you like chemistry... (119 options)

    image

    element = await uikitty.dynamic_select(
        ctx,
        embed=Embed(title="Select an element to learn more about it!", color=color),
        **elements_data,
    )
    embed = Embed(
        title=element["name"], description=element["summary"], url=element["source"],
    )
    await ctx.edit(embed=embed, view=None)
    

    Note: elements_data in the above snippet is sourced from Bowserinator/Periodic-Table-JSON.


More types of views will be coming soon. Watch this space! 👀

License

Copyright © 2022 Nuztalgia. Released under the Apache License, Version 2.0.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bot-ui-kitty-0.1.5.tar.gz (18.2 kB view details)

Uploaded Source

Built Distribution

bot_ui_kitty-0.1.5-py3-none-any.whl (14.2 kB view details)

Uploaded Python 3

File details

Details for the file bot-ui-kitty-0.1.5.tar.gz.

File metadata

  • Download URL: bot-ui-kitty-0.1.5.tar.gz
  • Upload date:
  • Size: 18.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.1

File hashes

Hashes for bot-ui-kitty-0.1.5.tar.gz
Algorithm Hash digest
SHA256 cfdf6992800f25804b0b3a9fd970cc01e94104bdacf944d5d80c5cdfab325a48
MD5 6fca22f1d3c45db564a413eec493b082
BLAKE2b-256 877c2bbe474b182980cd3e9c274790fc68a90563586d98534fc79e68b9e53f9b

See more details on using hashes here.

File details

Details for the file bot_ui_kitty-0.1.5-py3-none-any.whl.

File metadata

File hashes

Hashes for bot_ui_kitty-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 bd97e1473a10231c8f1182a41805a037f0f15a42183099217bbb42a75fa1a747
MD5 cec3100143896bfcd540344747563e1d
BLAKE2b-256 edb9b04a1a7f17e31835ab1f0aec537e8292a782a289a5b46eab527b1436a72b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page