Class GenericComponentInteractionCreateEvent
java.lang.Object
net.dv8tion.jda.api.events.Event
net.dv8tion.jda.api.events.interaction.GenericInteractionCreateEvent
net.dv8tion.jda.api.events.interaction.component.GenericComponentInteractionCreateEvent
- All Implemented Interfaces:
ISnowflake,GenericEvent,IDeferrableCallback,IMessageEditCallback,IReplyCallback,ComponentInteraction,Interaction
- Direct Known Subclasses:
ButtonInteractionEvent,SelectMenuInteractionEvent
public class GenericComponentInteractionCreateEvent
extends GenericInteractionCreateEvent
implements ComponentInteraction
Indicates that a
Every component interaction event is derived from this event.
ComponentInteraction was created in a channel.
Every component interaction event is derived from this event.
Requirements
To receive these events, you must unset the Interactions Endpoint URL in your application dashboard. You can simply remove the URL for this endpoint in your settings at the Discord Developers Portal.-
Constructor Summary
ConstructorsConstructorDescriptionGenericComponentInteractionCreateEvent(JDA api, long responseNumber, ComponentInteraction interaction) -
Method Summary
Modifier and TypeMethodDescriptionNo-op acknowledgement of this interaction.Acknowledge this interaction and defer the reply to a later time.The channel this interaction happened in.TheActionComponentinstance.The custom component ID provided to the component when it was originally created.TheComponent.TypegetHook()TheInteractionHookwhich can be used to send deferred replies or followup messages.TheInteractioninstance.TheMessageinstance.longThe id of the message.Methods inherited from class net.dv8tion.jda.api.events.interaction.GenericInteractionCreateEvent
getGuild, getGuildLocale, getIdLong, getMember, getToken, getTypeRaw, getUser, getUserLocale, isAcknowledgedMethods inherited from class net.dv8tion.jda.api.events.Event
getJDA, getResponseNumberMethods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface net.dv8tion.jda.api.interactions.components.ComponentInteraction
getMessageIdMethods inherited from interface net.dv8tion.jda.api.interactions.callbacks.IMessageEditCallback
editComponents, editComponents, editMessage, editMessage, editMessageEmbeds, editMessageEmbeds, editMessageFormatMethods inherited from interface net.dv8tion.jda.api.interactions.Interaction
getChannelType, getGuild, getGuildChannel, getGuildLocale, getJDA, getMember, getMessageChannel, getNewsChannel, getPrivateChannel, getTextChannel, getThreadChannel, getToken, getType, getTypeRaw, getUser, getUserLocale, getVoiceChannel, isAcknowledged, isFromGuildMethods inherited from interface net.dv8tion.jda.api.interactions.callbacks.IReplyCallback
deferReply, reply, reply, replyEmbeds, replyEmbeds, replyFile, replyFile, replyFile, replyFile, replyFormatMethods inherited from interface net.dv8tion.jda.api.entities.ISnowflake
getId, getIdLong, getTimeCreated
-
Constructor Details
-
GenericComponentInteractionCreateEvent
public GenericComponentInteractionCreateEvent(@Nonnull JDA api, long responseNumber, @Nonnull ComponentInteraction interaction)
-
-
Method Details
-
getInteraction
Description copied from class:GenericInteractionCreateEventTheInteractioninstance.
Note that this event is a delegate which implements the same interface.- Overrides:
getInteractionin classGenericInteractionCreateEvent- Returns:
- The
Interaction
-
getChannel
Description copied from interface:InteractionThe channel this interaction happened in.
This is currently never null, but might be nullable in the future.- Specified by:
getChannelin interfaceComponentInteraction- Specified by:
getChannelin interfaceInteraction- Overrides:
getChannelin classGenericInteractionCreateEvent- Returns:
- The channel or null if this interaction is not from a channel context
-
getComponentId
Description copied from interface:ComponentInteractionThe custom component ID provided to the component when it was originally created.
This value should be used to determine what action to take in regard to this interaction.
This id does not have to be numerical.- Specified by:
getComponentIdin interfaceComponentInteraction- Returns:
- The component ID
- See Also:
-
getComponent
Description copied from interface:ComponentInteractionTheActionComponentinstance.- Specified by:
getComponentin interfaceComponentInteraction- Returns:
- The
ActionComponent
-
getMessage
Description copied from interface:ComponentInteractionTheMessageinstance.- Specified by:
getMessagein interfaceComponentInteraction- Returns:
- The
Message
-
getMessageIdLong
public long getMessageIdLong()Description copied from interface:ComponentInteractionThe id of the message.- Specified by:
getMessageIdLongin interfaceComponentInteraction- Returns:
- The message id
-
getComponentType
Description copied from interface:ComponentInteractionTheComponent.Type- Specified by:
getComponentTypein interfaceComponentInteraction- Returns:
- The
Component.Type
-
deferEdit
Description copied from interface:IMessageEditCallbackNo-op acknowledgement of this interaction.
This tells discord you intend to update the message that the triggering component is a part of using theInteractionHookinstead of sending a reply message. You are not required to actually update the message, this will simply acknowledge that you accepted the interaction.You only have 3 seconds to acknowledge an interaction!
When the acknowledgement is sent after the interaction expired, you will receiveErrorResponse.UNKNOWN_INTERACTION.Use
IMessageEditCallback.editMessage(String)to edit it directly.- Specified by:
deferEditin interfaceIMessageEditCallback- Returns:
MessageEditCallbackActionthat can be used to update the message- See Also:
-
getHook
Description copied from interface:IDeferrableCallbackTheInteractionHookwhich can be used to send deferred replies or followup messages.- Specified by:
getHookin interfaceIDeferrableCallback- Returns:
- The interaction hook
-
deferReply
Description copied from interface:IReplyCallbackAcknowledge this interaction and defer the reply to a later time.
This will send a<Bot> is thinking...message in chat that will be updated later through eitherInteractionHook.editOriginal(String)orWebhookClient.sendMessage(String).You can use
deferReply(true)to send a deferred ephemeral reply. If your initial deferred message is not ephemeral it cannot be made ephemeral later. Your first message to theInteractionHookwill inherit whether the message is ephemeral or not from this deferred reply.You only have 3 seconds to acknowledge an interaction!
When the acknowledgement is sent after the interaction expired, you will receiveErrorResponse.UNKNOWN_INTERACTION.Use
IReplyCallback.reply(String)to reply directly.- Specified by:
deferReplyin interfaceIReplyCallback- Returns:
ReplyCallbackAction
-