diff --git a/lib/command_chat.go b/lib/command_chat.go index ebc83b6..313a21b 100644 --- a/lib/command_chat.go +++ b/lib/command_chat.go @@ -289,6 +289,44 @@ func (o *ChatCommandChannelOption) ApplicationCommandOption() *discordgo.Applica } } +func (o *ChatCommandChannelOption) Validate() (bool, error) { + return validateOption(o) +} + +type ChatCommandRoleOption struct { + Name string + NameLocalizations map[discordgo.Locale]string + Description string + DescriptionLocalizations map[discordgo.Locale]string + Required bool + Autocomplete bool + Choices []*ChatCommandRoleOptionChoice +} + +type ChatCommandRoleOptionChoice = ChatCommandStringOptionChoice + +func (o *ChatCommandRoleOption) 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.ApplicationCommandOptionRole, + 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 },