diff --git a/lib/command_chat.go b/lib/command_chat.go index 7ecc148..ebc83b6 100644 --- a/lib/command_chat.go +++ b/lib/command_chat.go @@ -255,6 +255,40 @@ func (o *ChatCommandUserOption) Validate() (bool, error) { return validateOption(o) } +type ChatCommandChannelOption struct { + Name string + NameLocalizations map[discordgo.Locale]string + Description string + DescriptionLocalizations map[discordgo.Locale]string + Required bool + Autocomplete bool + Choices []*ChatCommandChannelOptionChoice +} + +type ChatCommandChannelOptionChoice = ChatCommandStringOptionChoice + +func (o *ChatCommandChannelOption) ApplicationCommandOption() *discordgo.ApplicationCommandOption { + choices := make([]*discordgo.ApplicationCommandOptionChoice, len(o.Choices)) + for i, v := range o.Choices { + choices[i] = &discordgo.ApplicationCommandOptionChoice{ + Name: v.Name, + NameLocalizations: v.NameLocalizations, + Value: any(v.Value), + } + } + + return &discordgo.ApplicationCommandOption{ + Type: discordgo.ApplicationCommandOptionChannel, + Name: o.Name, + NameLocalizations: o.NameLocalizations, + Description: o.Description, + DescriptionLocalizations: o.DescriptionLocalizations, + Required: o.Required, + Autocomplete: o.Autocomplete, + Choices: choices, + } +} + func validateOption(opt interface { ApplicationCommandOption() *discordgo.ApplicationCommandOption },