Skip to main content

An extension for discord.py that allows your bot to use buttons

Project description

Usage

ButtonPaginator

from discord.ext import commands
from dpy_button_utils import ButtonPaginator

bot = commands.Bot(command_prefix="!", help_command=None)

@bot.command()
async def page_plain_text(ctx: commands.Context):
    paginator = ButtonPaginator(bot, messages=[f"Option {x}" for x in range(10)], timeout=10)
    await paginator.run(ctx)


@bot.command()
async def page_embeds(ctx: commands.Context):
    paginator = ButtonPaginator(bot, embeds=[
        discord.Embed(title="bonk", description=f"Option {x}") for x in range(10)
    ])
    await paginator.run(ctx)


bot.run("TOKEN")

After the paginator is done, you can access the page it left off on with paginator.counter.

ButtonConfirmation

from discord.ext import commands

from dpy_button_utils.confirmation import ButtonConfirmation

bot = commands.Bot(command_prefix="!", help_command=None)

@bot.command()
async def confirm(ctx: commands.Context):
    if await ButtonConfirmation(ctx, "Do the bad thing?", destructive=True, confirm="YES", cancel="no pls").run():
        await ctx.send("yes :D")
    else:
        await ctx.send(":(")


@bot.command()
async def confirm2(ctx: commands.Context):
    if await ButtonConfirmation(ctx, "Do the thing?", destructive=False, confirm="YES", cancel="no pls").run():
        await ctx.send("yes :D")
    else:
        await ctx.send(":(")

bot.run("TOKEN")

ButtonConfirmation takes a few different keyword arguments, after the Context and message.

  • destructive - can either be True or False. True causes a red confirm button, and False causes a blue one
  • timeout - Time in seconds for the confirmation to auto-cancel
  • confirm - Confirmation button label
  • cancel - Cancel button label
  • confirm_message - Text to change to on a confirmation
  • cancel_message - Text to change to on a cancel

The defaults are:

  • destructive - False
  • timeout - 60
  • confirm - Confirm
  • cancel - Cancel
  • confirm_message - None - this appends Confirmed to the original message
  • cancel_message - None - this appends Cancelled to the original message

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

dpy_button_utils-1.1.0.tar.gz (7.4 kB view hashes)

Uploaded Source

Built Distribution

dpy_button_utils-1.1.0-py3-none-any.whl (8.4 kB view hashes)

Uploaded Python 3

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