14 changed files with 628 additions and 410 deletions
@ -1,53 +0,0 @@ |
|||
""" |
|||
The MIT License (MIT) |
|||
|
|||
Copyright (c) 2015-present Rapptz |
|||
|
|||
Permission is hereby granted, free of charge, to any person obtaining a |
|||
copy of this software and associated documentation files (the "Software"), |
|||
to deal in the Software without restriction, including without limitation |
|||
the rights to use, copy, modify, merge, publish, distribute, sublicense, |
|||
and/or sell copies of the Software, and to permit persons to whom the |
|||
Software is furnished to do so, subject to the following conditions: |
|||
|
|||
The above copyright notice and this permission notice shall be included in |
|||
all copies or substantial portions of the Software. |
|||
|
|||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
|||
OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
|||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
|||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
|||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING |
|||
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER |
|||
DEALINGS IN THE SOFTWARE. |
|||
""" |
|||
|
|||
from ..enums import Enum |
|||
|
|||
__all__ = ( |
|||
'AppCommandOptionType', |
|||
'AppCommandType', |
|||
) |
|||
|
|||
|
|||
class AppCommandOptionType(Enum): |
|||
subcommand = 1 |
|||
subcommand_group = 2 |
|||
string = 3 |
|||
integer = 4 |
|||
boolean = 5 |
|||
user = 6 |
|||
channel = 7 |
|||
role = 8 |
|||
mentionable = 9 |
|||
number = 10 |
|||
attachment = 11 |
|||
|
|||
def is_argument(self) -> bool: |
|||
return 11 >= self.value >= 3 |
|||
|
|||
|
|||
class AppCommandType(Enum): |
|||
chat_input = 1 |
|||
user = 2 |
|||
message = 3 |
@ -0,0 +1,533 @@ |
|||
.. currentmodule:: discord |
|||
|
|||
Interactions API Reference |
|||
============================ |
|||
|
|||
The following section outlines the API of interactions, as implemented by the library. |
|||
|
|||
For documentation about the rest of the library, check :doc:`api`. |
|||
|
|||
Models |
|||
-------- |
|||
|
|||
Similar to :ref:`discord_api_models`, these are not meant to be constructed by the user. |
|||
|
|||
Interaction |
|||
~~~~~~~~~~~~ |
|||
|
|||
.. attributetable:: Interaction |
|||
|
|||
.. autoclass:: Interaction() |
|||
:members: |
|||
|
|||
InteractionResponse |
|||
~~~~~~~~~~~~~~~~~~~~ |
|||
|
|||
.. attributetable:: InteractionResponse |
|||
|
|||
.. autoclass:: InteractionResponse() |
|||
:members: |
|||
|
|||
InteractionMessage |
|||
~~~~~~~~~~~~~~~~~~~ |
|||
|
|||
.. attributetable:: InteractionMessage |
|||
|
|||
.. autoclass:: InteractionMessage() |
|||
:members: |
|||
|
|||
Component |
|||
~~~~~~~~~~ |
|||
|
|||
.. attributetable:: Component |
|||
|
|||
.. autoclass:: Component() |
|||
:members: |
|||
|
|||
ActionRow |
|||
~~~~~~~~~~ |
|||
|
|||
.. attributetable:: ActionRow |
|||
|
|||
.. autoclass:: ActionRow() |
|||
:members: |
|||
|
|||
Button |
|||
~~~~~~~ |
|||
|
|||
.. attributetable:: Button |
|||
|
|||
.. autoclass:: Button() |
|||
:members: |
|||
:inherited-members: |
|||
|
|||
SelectMenu |
|||
~~~~~~~~~~~ |
|||
|
|||
.. attributetable:: SelectMenu |
|||
|
|||
.. autoclass:: SelectMenu() |
|||
:members: |
|||
:inherited-members: |
|||
|
|||
|
|||
TextInput |
|||
~~~~~~~~~~ |
|||
|
|||
.. attributetable:: TextInput |
|||
|
|||
.. autoclass:: TextInput() |
|||
:members: |
|||
:inherited-members: |
|||
|
|||
AppCommand |
|||
~~~~~~~~~~~ |
|||
|
|||
.. attributetable:: discord.app_commands.AppCommand |
|||
|
|||
.. autoclass:: discord.app_commands.AppCommand() |
|||
:members: |
|||
|
|||
AppCommandGroup |
|||
~~~~~~~~~~~~~~~~ |
|||
|
|||
.. attributetable:: discord.app_commands.AppCommandGroup |
|||
|
|||
.. autoclass:: discord.app_commands.AppCommandGroup() |
|||
:members: |
|||
|
|||
AppCommandChannel |
|||
~~~~~~~~~~~~~~~~~~ |
|||
|
|||
.. attributetable:: discord.app_commands.AppCommandChannel |
|||
|
|||
.. autoclass:: discord.app_commands.AppCommandChannel() |
|||
:members: |
|||
|
|||
AppCommandThread |
|||
~~~~~~~~~~~~~~~~~ |
|||
|
|||
.. attributetable:: discord.app_commands.AppCommandThread |
|||
|
|||
.. autoclass:: discord.app_commands.AppCommandThread() |
|||
:members: |
|||
|
|||
Argument |
|||
~~~~~~~~~~ |
|||
|
|||
.. attributetable:: discord.app_commands.Argument |
|||
|
|||
.. autoclass:: discord.app_commands.Argument() |
|||
:members: |
|||
|
|||
Data Classes |
|||
-------------- |
|||
|
|||
Similar to :ref:`discord_api_data`, these can be received and constructed by users. |
|||
|
|||
SelectOption |
|||
~~~~~~~~~~~~~ |
|||
|
|||
.. attributetable:: SelectOption |
|||
|
|||
.. autoclass:: SelectOption |
|||
:members: |
|||
|
|||
Choice |
|||
~~~~~~~ |
|||
|
|||
.. attributetable:: discord.app_commands.Choice |
|||
|
|||
.. autoclass:: discord.app_commands.Choice |
|||
:members: |
|||
|
|||
|
|||
Enumerations |
|||
------------- |
|||
|
|||
.. class:: InteractionType |
|||
|
|||
Specifies the type of :class:`Interaction`. |
|||
|
|||
.. versionadded:: 2.0 |
|||
|
|||
.. attribute:: ping |
|||
|
|||
Represents Discord pinging to see if the interaction response server is alive. |
|||
.. attribute:: application_command |
|||
|
|||
Represents a slash command interaction. |
|||
.. attribute:: component |
|||
|
|||
Represents a component based interaction, i.e. using the Discord Bot UI Kit. |
|||
.. attribute:: autocomplete |
|||
|
|||
Represents an auto complete interaction. |
|||
.. attribute:: modal_submit |
|||
|
|||
Represents submission of a modal interaction. |
|||
|
|||
.. class:: InteractionResponseType |
|||
|
|||
Specifies the response type for the interaction. |
|||
|
|||
.. versionadded:: 2.0 |
|||
|
|||
.. attribute:: pong |
|||
|
|||
Pongs the interaction when given a ping. |
|||
|
|||
See also :meth:`InteractionResponse.pong` |
|||
.. attribute:: channel_message |
|||
|
|||
Respond to the interaction with a message. |
|||
|
|||
See also :meth:`InteractionResponse.send_message` |
|||
.. attribute:: deferred_channel_message |
|||
|
|||
Responds to the interaction with a message at a later time. |
|||
|
|||
See also :meth:`InteractionResponse.defer` |
|||
.. attribute:: deferred_message_update |
|||
|
|||
Acknowledges the component interaction with a promise that |
|||
the message will update later (though there is no need to actually update the message). |
|||
|
|||
See also :meth:`InteractionResponse.defer` |
|||
.. attribute:: message_update |
|||
|
|||
Responds to the interaction by editing the message. |
|||
|
|||
See also :meth:`InteractionResponse.edit_message` |
|||
.. attribute:: autocomplete_result |
|||
|
|||
Responds to the autocomplete interaction with suggested choices. |
|||
|
|||
See also :meth:`InteractionResponse.autocomplete` |
|||
.. attribute:: modal |
|||
|
|||
Responds to the interaction with a modal. |
|||
|
|||
See also :meth:`InteractionResponse.send_modal` |
|||
|
|||
.. class:: ComponentType |
|||
|
|||
Represents the component type of a component. |
|||
|
|||
.. versionadded:: 2.0 |
|||
|
|||
.. attribute:: action_row |
|||
|
|||
Represents the group component which holds different components in a row. |
|||
.. attribute:: button |
|||
|
|||
Represents a button component. |
|||
.. attribute:: select |
|||
|
|||
Represents a select component. |
|||
|
|||
.. attribute:: text_input |
|||
|
|||
Represents a text box component. |
|||
|
|||
.. class:: ButtonStyle |
|||
|
|||
Represents the style of the button component. |
|||
|
|||
.. versionadded:: 2.0 |
|||
|
|||
.. attribute:: primary |
|||
|
|||
Represents a blurple button for the primary action. |
|||
.. attribute:: secondary |
|||
|
|||
Represents a grey button for the secondary action. |
|||
.. attribute:: success |
|||
|
|||
Represents a green button for a successful action. |
|||
.. attribute:: danger |
|||
|
|||
Represents a red button for a dangerous action. |
|||
.. attribute:: link |
|||
|
|||
Represents a link button. |
|||
|
|||
.. attribute:: blurple |
|||
|
|||
An alias for :attr:`primary`. |
|||
.. attribute:: grey |
|||
|
|||
An alias for :attr:`secondary`. |
|||
.. attribute:: gray |
|||
|
|||
An alias for :attr:`secondary`. |
|||
.. attribute:: green |
|||
|
|||
An alias for :attr:`success`. |
|||
.. attribute:: red |
|||
|
|||
An alias for :attr:`danger`. |
|||
.. attribute:: url |
|||
|
|||
An alias for :attr:`link`. |
|||
|
|||
.. class:: TextStyle |
|||
|
|||
Represents the style of the text box component. |
|||
|
|||
.. versionadded:: 2.0 |
|||
|
|||
.. attribute:: short |
|||
|
|||
Represents a short text box. |
|||
.. attribute:: paragraph |
|||
|
|||
Represents a long form text box. |
|||
.. attribute:: long |
|||
|
|||
An alias for :attr:`paragraph`. |
|||
|
|||
.. class:: AppCommandOptionType |
|||
|
|||
The application command's option type. This is usually the type of parameter an application command takes. |
|||
|
|||
.. versionadded:: 2.0 |
|||
|
|||
.. attribute:: subcommand |
|||
|
|||
A subcommand. |
|||
.. attribute:: subcommand_group |
|||
|
|||
A subcommand group. |
|||
.. attribute:: string |
|||
|
|||
A string parameter. |
|||
.. attribute:: integer |
|||
|
|||
A integer parameter. |
|||
.. attribute:: boolean |
|||
|
|||
A boolean parameter. |
|||
.. attribute:: user |
|||
|
|||
A user parameter. |
|||
.. attribute:: channel |
|||
|
|||
A channel parameter. |
|||
.. attribute:: role |
|||
|
|||
A role parameter. |
|||
.. attribute:: mentionable |
|||
|
|||
A mentionable parameter. |
|||
.. attribute:: number |
|||
|
|||
A number parameter. |
|||
.. attribute:: attachment |
|||
|
|||
An attachment parameter. |
|||
|
|||
.. class:: AppCommandType |
|||
|
|||
The type of application command. |
|||
|
|||
.. versionadded:: 2.0 |
|||
|
|||
.. attribute:: chat_input |
|||
|
|||
A slash command. |
|||
.. attribute:: user |
|||
|
|||
A user context menu command. |
|||
.. attribute:: message |
|||
|
|||
A message context menu command. |
|||
|
|||
.. _discord_ui_kit: |
|||
|
|||
Bot UI Kit |
|||
------------- |
|||
|
|||
The library has helpers to aid create component-based UIs. These are all in the ``discord.ui`` package. |
|||
|
|||
|
|||
View |
|||
~~~~~~~ |
|||
|
|||
.. attributetable:: discord.ui.View |
|||
|
|||
.. autoclass:: discord.ui.View |
|||
:members: |
|||
|
|||
Modal |
|||
~~~~~~ |
|||
|
|||
.. attributetable:: discord.ui.Modal |
|||
|
|||
.. autoclass:: discord.ui.Modal |
|||
:members: |
|||
|
|||
Item |
|||
~~~~~~~ |
|||
|
|||
.. attributetable:: discord.ui.Item |
|||
|
|||
.. autoclass:: discord.ui.Item |
|||
:members: |
|||
|
|||
Button |
|||
~~~~~~~ |
|||
|
|||
.. attributetable:: discord.ui.Button |
|||
|
|||
.. autoclass:: discord.ui.Button |
|||
:members: |
|||
:inherited-members: |
|||
|
|||
.. autofunction:: discord.ui.button |
|||
|
|||
Select |
|||
~~~~~~~ |
|||
|
|||
.. attributetable:: discord.ui.Select |
|||
|
|||
.. autoclass:: discord.ui.Select |
|||
:members: |
|||
:inherited-members: |
|||
|
|||
.. autofunction:: discord.ui.select |
|||
|
|||
TextInput |
|||
~~~~~~~~~~ |
|||
|
|||
.. attributetable:: discord.ui.TextInput |
|||
|
|||
.. autoclass:: discord.ui.TextInput |
|||
:members: |
|||
:inherited-members: |
|||
|
|||
.. _discord_app_commands: |
|||
|
|||
Application Commands |
|||
---------------------- |
|||
|
|||
The library has helpers to aid in creation of application commands. These are all in the ``discord.app_commands`` package. |
|||
|
|||
CommandTree |
|||
~~~~~~~~~~~~ |
|||
|
|||
.. attributetable:: discord.app_commands.CommandTree |
|||
|
|||
.. autoclass:: discord.app_commands.CommandTree |
|||
:members: |
|||
|
|||
Commands |
|||
~~~~~~~~~ |
|||
|
|||
Command |
|||
++++++++ |
|||
|
|||
.. attributetable:: discord.app_commands.Command |
|||
|
|||
.. autoclass:: discord.app_commands.Command |
|||
:members: |
|||
|
|||
ContextMenu |
|||
++++++++++++ |
|||
|
|||
.. attributetable:: discord.app_commands.ContextMenu |
|||
|
|||
.. autoclass:: discord.app_commands.ContextMenu |
|||
:members: |
|||
|
|||
Group |
|||
++++++ |
|||
|
|||
.. attributetable:: discord.app_commands.Group |
|||
|
|||
.. autoclass:: discord.app_commands.Group |
|||
:members: |
|||
|
|||
Decorators |
|||
+++++++++++ |
|||
|
|||
.. autofunction:: discord.app_commands.command |
|||
:decorator: |
|||
|
|||
.. autofunction:: discord.app_commands.context_menu |
|||
:decorator: |
|||
|
|||
.. autofunction:: discord.app_commands.describe |
|||
:decorator: |
|||
|
|||
.. autofunction:: discord.app_commands.choices |
|||
:decorator: |
|||
|
|||
Namespace |
|||
~~~~~~~~~~ |
|||
|
|||
.. attributetable:: discord.app_commands.Namespace |
|||
|
|||
.. autoclass:: discord.app_commands.Namespace() |
|||
:members: |
|||
|
|||
Transformers |
|||
~~~~~~~~~~~~~ |
|||
|
|||
Transformer |
|||
++++++++++++ |
|||
|
|||
.. attributetable:: discord.app_commands.Transformer |
|||
|
|||
.. autoclass:: discord.app_commands.Transformer |
|||
:members: |
|||
|
|||
Transform |
|||
++++++++++ |
|||
|
|||
.. attributetable:: discord.app_commands.Transform |
|||
|
|||
.. autoclass:: discord.app_commands.Transform |
|||
:members: |
|||
|
|||
Range |
|||
++++++ |
|||
|
|||
.. attributetable:: discord.app_commands.Range |
|||
|
|||
.. autoclass:: discord.app_commands.Range |
|||
:members: |
|||
|
|||
Exceptions |
|||
~~~~~~~~~~~ |
|||
|
|||
.. autoexception:: discord.app_commands.AppCommandError |
|||
:members: |
|||
|
|||
.. autoexception:: discord.app_commands.CommandInvokeError |
|||
:members: |
|||
|
|||
.. autoexception:: discord.app_commands.TransformerError |
|||
:members: |
|||
|
|||
.. autoexception:: discord.app_commands.CommandAlreadyRegistered |
|||
:members: |
|||
|
|||
.. autoexception:: discord.app_commands.CommandSignatureMismatch |
|||
:members: |
|||
|
|||
.. autoexception:: discord.app_commands.CommandNotFound |
|||
:members: |
|||
|
|||
Exception Hierarchy |
|||
~~~~~~~~~~~~~~~~~~~~ |
|||
|
|||
.. exception_hierarchy:: |
|||
|
|||
- :exc:`~discord.DiscordException` |
|||
- :exc:`~discord.app_commands.AppCommandError` |
|||
- :exc:`~discord.app_commands.CommandInvokeError` |
|||
- :exc:`~discord.app_commands.TransformerError` |
|||
- :exc:`~discord.app_commands.CommandAlreadyRegistered` |
|||
- :exc:`~discord.app_commands.CommandSignatureMismatch` |
|||
- :exc:`~discord.app_commands.CommandNotFound` |
Loading…
Reference in new issue