Skip to main content

An alternative component handler for hikari, inspired by discord.py's views.

Project description

hikari-miru

An optional component handler for hikari, inspired by discord.py's views.

Installation

pip install -U hikari-miru

Usage

import hikari
import miru


class MyView(miru.View):

    @miru.button(label="Rock", emoji=chr(129704), style=hikari.ButtonStyle.PRIMARY)
    async def rock_button(self, button: miru.Button, interaction: miru.Interaction):
        await interaction.send_message(content="Paper!")

    @miru.button(label="Paper", emoji=chr(128220), style=hikari.ButtonStyle.PRIMARY)
    async def paper_button(self, button: miru.Button, interaction: miru.Interaction):
        await interaction.send_message(content="Scissors!")

    @miru.button(label="Scissors", emoji=chr(9986), style=hikari.ButtonStyle.PRIMARY)
    async def scissors_button(self, button: miru.Button, interaction: miru.Interaction):
        await interaction.send_message(content="Rock!")

    @miru.button(emoji=chr(9209), style=hikari.ButtonStyle.DANGER, row=2)
    async def stop_button(self, button: miru.Button, interaction: miru.Interaction):
        self.stop() # Stop listening for interactions


bot = hikari.GatewayBot(token="...")


@bot.listen()
async def buttons(event: hikari.GuildMessageCreateEvent) -> None:

    if event.is_bot or not event.content:
        return

    if event.content.startswith("hm.buttons"):
        view = MyView(bot, timeout=60)  # Create a new view
        message = await event.message.respond("Rock Paper Scissors!", components=view.build())
        view.start(message)  # Start listening for interactions
        await view.wait() # Wait until the view times out or gets stopped
        await event.message.respond("Thank you for playing!")

bot.run()

Issues and support

For general usage help or questions, see the #hikari-miru channel in the hikari discord, if you have found a bug or have a feature request, feel free to open an issue!

Contributing

If you wish to contribute, be sure to first enable the formatting pre-commit hook via git config core.hooksPath .githooks, then make your changes.

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

hikari-miru-0.5.1.tar.gz (10.5 kB view details)

Uploaded Source

Built Distribution

hikari_miru-0.5.1-py3-none-any.whl (15.4 kB view details)

Uploaded Python 3

File details

Details for the file hikari-miru-0.5.1.tar.gz.

File metadata

  • Download URL: hikari-miru-0.5.1.tar.gz
  • Upload date:
  • Size: 10.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.8.1 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.1

File hashes

Hashes for hikari-miru-0.5.1.tar.gz
Algorithm Hash digest
SHA256 dd32af79829ecc43582d2bcaab093c6d871181fc4c5aeea45cba2fd4b0491949
MD5 f331279724d6b853e7e2eb051821dd80
BLAKE2b-256 ef5a8fbab022ffaafbe1ed857d485790623004721be5757e0538d72f48a45bfc

See more details on using hashes here.

File details

Details for the file hikari_miru-0.5.1-py3-none-any.whl.

File metadata

  • Download URL: hikari_miru-0.5.1-py3-none-any.whl
  • Upload date:
  • Size: 15.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.8.1 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.1

File hashes

Hashes for hikari_miru-0.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 84094c36501dcbb0d4ad53d1d8e3f9f18e44e7a5d1ed8a3afc690120d5e170dd
MD5 41a1896a4b80dd3507aea3a4b1a89ff8
BLAKE2b-256 d6b1c4d841c3d80c46b7a19775ec50951a7e1daf198d2a4189f308eb65fb92d2

See more details on using hashes here.

Supported by

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