feat(command): use gokord new handle for config
This commit is contained in:
parent
376b3ec296
commit
3d89f9c354
2 changed files with 155 additions and 165 deletions
|
@ -123,18 +123,7 @@ func Config(_ *discordgo.Session, i *discordgo.InteractionCreate, _ cmd.OptionMa
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func ConfigXP(s *discordgo.Session, i *discordgo.InteractionCreate) {
|
func ConfigModifyXPRole(_ *discordgo.Session, _ *discordgo.InteractionCreate, _ discordgo.MessageComponentInteractionData, resp *cmd.ResponseBuilder) {
|
||||||
if i.Type != discordgo.InteractionMessageComponent {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
cfg := config.GetGuildConfig(i.GuildID)
|
|
||||||
|
|
||||||
resp := cmd.NewResponseBuilder(s, i)
|
|
||||||
|
|
||||||
msgData := i.MessageComponentData()
|
|
||||||
switch msgData.CustomID {
|
|
||||||
case ConfigModifyXpRole:
|
|
||||||
err := resp.IsEphemeral().
|
err := resp.IsEphemeral().
|
||||||
SetMessage("Action à réaliser").
|
SetMessage("Action à réaliser").
|
||||||
SetComponents(component.New().Add(component.NewActionRow().Add(
|
SetComponents(component.New().Add(component.NewActionRow().Add(
|
||||||
|
@ -158,9 +147,11 @@ func ConfigXP(s *discordgo.Session, i *discordgo.InteractionCreate) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logger.Alert("config/guild.go - Sending config", err.Error())
|
logger.Alert("config/guild.go - Sending config", err.Error())
|
||||||
}
|
}
|
||||||
case XpRoleAdd, XpRoleEdit:
|
}
|
||||||
|
|
||||||
|
func ConfigXPRoleAddEdit(_ *discordgo.Session, _ *discordgo.InteractionCreate, data discordgo.MessageComponentInteractionData, resp *cmd.ResponseBuilder) {
|
||||||
cID := XpRoleAddLevel
|
cID := XpRoleAddLevel
|
||||||
if msgData.CustomID == XpRoleEdit {
|
if data.CustomID == XpRoleEdit {
|
||||||
cID = XpRoleEditLevel
|
cID = XpRoleEditLevel
|
||||||
}
|
}
|
||||||
err := resp.IsModal().
|
err := resp.IsModal().
|
||||||
|
@ -174,10 +165,13 @@ func ConfigXP(s *discordgo.Session, i *discordgo.InteractionCreate) {
|
||||||
))).
|
))).
|
||||||
Send()
|
Send()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logger.Alert("config/guild.go - Sending modal to add", err.Error())
|
logger.Alert("config/guild.go - Sending modal to add/edit", err.Error())
|
||||||
}
|
}
|
||||||
case XpRoleAddRole:
|
}
|
||||||
roleId := msgData.Values[0]
|
|
||||||
|
func ConfigXPRoleAddRole(_ *discordgo.Session, i *discordgo.InteractionCreate, data discordgo.MessageComponentInteractionData, resp *cmd.ResponseBuilder) {
|
||||||
|
cfg := config.GetGuildConfig(i.GuildID)
|
||||||
|
roleId := data.Values[0]
|
||||||
for _, r := range cfg.XpRoles {
|
for _, r := range cfg.XpRoles {
|
||||||
if r.RoleID == roleId {
|
if r.RoleID == roleId {
|
||||||
err := resp.SetMessage("Le rôle est déjà présent dans la config").Send()
|
err := resp.SetMessage("Le rôle est déjà présent dans la config").Send()
|
||||||
|
@ -204,8 +198,11 @@ func ConfigXP(s *discordgo.Session, i *discordgo.InteractionCreate) {
|
||||||
if err = resp.IsEphemeral().SetMessage("Rôle ajouté.").Send(); err != nil {
|
if err = resp.IsEphemeral().SetMessage("Rôle ajouté.").Send(); err != nil {
|
||||||
logger.Alert("commands/config.go - Sending success", err.Error())
|
logger.Alert("commands/config.go - Sending success", err.Error())
|
||||||
}
|
}
|
||||||
case XpRoleEditRole:
|
}
|
||||||
roleId := msgData.Values[0]
|
|
||||||
|
func ConfigXPRoleEditRole(_ *discordgo.Session, i *discordgo.InteractionCreate, data discordgo.MessageComponentInteractionData, resp *cmd.ResponseBuilder) {
|
||||||
|
cfg := config.GetGuildConfig(i.GuildID)
|
||||||
|
roleId := data.Values[0]
|
||||||
_, r := cfg.FindXpRole(roleId)
|
_, r := cfg.FindXpRole(roleId)
|
||||||
if r == nil {
|
if r == nil {
|
||||||
err := resp.SetMessage("Le rôle n'a pas été trouvé dans la config.").Send()
|
err := resp.SetMessage("Le rôle n'a pas été trouvé dans la config.").Send()
|
||||||
|
@ -228,7 +225,9 @@ func ConfigXP(s *discordgo.Session, i *discordgo.InteractionCreate) {
|
||||||
if err = resp.IsEphemeral().SetMessage("Rôle modifié.").Send(); err != nil {
|
if err = resp.IsEphemeral().SetMessage("Rôle modifié.").Send(); err != nil {
|
||||||
logger.Alert("commands/config.go - Sending success", err.Error())
|
logger.Alert("commands/config.go - Sending success", err.Error())
|
||||||
}
|
}
|
||||||
case XpRoleDel:
|
}
|
||||||
|
|
||||||
|
func ConfigXPRoleDel(_ *discordgo.Session, _ *discordgo.InteractionCreate, _ discordgo.MessageComponentInteractionData, resp *cmd.ResponseBuilder) {
|
||||||
err := resp.IsEphemeral().
|
err := resp.IsEphemeral().
|
||||||
SetMessage("Rôle à supprimer").
|
SetMessage("Rôle à supprimer").
|
||||||
SetComponents(component.New().Add(component.NewActionRow().Add(component.NewRoleSelect(XpRoleDelRole)))).
|
SetComponents(component.New().Add(component.NewActionRow().Add(component.NewRoleSelect(XpRoleDelRole)))).
|
||||||
|
@ -236,13 +235,16 @@ func ConfigXP(s *discordgo.Session, i *discordgo.InteractionCreate) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logger.Alert("config/guild.go - Sending response to del", err.Error())
|
logger.Alert("config/guild.go - Sending response to del", err.Error())
|
||||||
}
|
}
|
||||||
case XpRoleDelRole:
|
}
|
||||||
roleId := msgData.Values[0]
|
|
||||||
|
func ConfigXPRoleDelRole(_ *discordgo.Session, i *discordgo.InteractionCreate, data discordgo.MessageComponentInteractionData, resp *cmd.ResponseBuilder) {
|
||||||
|
cfg := config.GetGuildConfig(i.GuildID)
|
||||||
|
roleId := data.Values[0]
|
||||||
_, r := cfg.FindXpRole(roleId)
|
_, r := cfg.FindXpRole(roleId)
|
||||||
if r == nil {
|
if r == nil {
|
||||||
err := resp.SetMessage("Le rôle n'a pas été trouvé dans la config.").Send()
|
err := resp.SetMessage("Le rôle n'a pas été trouvé dans la config.").Send()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logger.Alert("commands/config.go - Role not found (del)", err.Error())
|
logger.Alert("commands/config.go - Sending role not found (del)", err.Error())
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -259,28 +261,10 @@ func ConfigXP(s *discordgo.Session, i *discordgo.InteractionCreate) {
|
||||||
if err = resp.IsEphemeral().SetMessage("Rôle supprimé.").Send(); err != nil {
|
if err = resp.IsEphemeral().SetMessage("Rôle supprimé.").Send(); err != nil {
|
||||||
logger.Alert("commands/config.go - Sending success", err.Error())
|
logger.Alert("commands/config.go - Sending success", err.Error())
|
||||||
}
|
}
|
||||||
default:
|
|
||||||
err := resp.SetMessage("Le type d'action n'est pas valide.").Send()
|
|
||||||
if err != nil {
|
|
||||||
logger.Alert("commands/config.go - Invalid action type", err.Error())
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func ConfigXPModal(s *discordgo.Session, i *discordgo.InteractionCreate) {
|
func ConfigXPRoleLevel(_ *discordgo.Session, i *discordgo.InteractionCreate, data discordgo.ModalSubmitInteractionData, resp *cmd.ResponseBuilder) {
|
||||||
if i.Type != discordgo.InteractionModalSubmit {
|
input := data.Components[0].(*discordgo.ActionsRow).Components[0].(*discordgo.TextInput)
|
||||||
return
|
|
||||||
}
|
|
||||||
resp := cmd.NewResponseBuilder(s, i)
|
|
||||||
|
|
||||||
modalData := i.ModalSubmitData()
|
|
||||||
|
|
||||||
if modalData.CustomID != XpRoleAddLevel && modalData.CustomID != XpRoleEditLevel {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
input := modalData.Components[0].(*discordgo.ActionsRow).Components[0].(*discordgo.TextInput)
|
|
||||||
|
|
||||||
k := getKeyConfigRole(i)
|
k := getKeyConfigRole(i)
|
||||||
in, err := strconv.Atoi(input.Value)
|
in, err := strconv.Atoi(input.Value)
|
||||||
|
@ -300,7 +284,7 @@ func ConfigXPModal(s *discordgo.Session, i *discordgo.InteractionCreate) {
|
||||||
|
|
||||||
cID := XpRoleAddRole
|
cID := XpRoleAddRole
|
||||||
resp.SetMessage("Rôle à ajouter")
|
resp.SetMessage("Rôle à ajouter")
|
||||||
if modalData.CustomID == XpRoleEditLevel {
|
if data.CustomID == XpRoleEditLevel {
|
||||||
cID = XpRoleEditLevel
|
cID = XpRoleEditLevel
|
||||||
resp.SetMessage("Rôle à modifier")
|
resp.SetMessage("Rôle à modifier")
|
||||||
}
|
}
|
||||||
|
|
38
main.go
38
main.go
|
@ -116,31 +116,37 @@ func main() {
|
||||||
resetUserCmd,
|
resetUserCmd,
|
||||||
creditsCmd,
|
creditsCmd,
|
||||||
},
|
},
|
||||||
AfterInit: afterInit,
|
AfterInit: func(dg *discordgo.Session) {
|
||||||
|
stopPeriodicReducer = gokord.NewTimer(24*time.Hour, func(stop chan<- interface{}) {
|
||||||
|
user.PeriodicReducer(dg)
|
||||||
|
})
|
||||||
|
},
|
||||||
Innovations: innovations,
|
Innovations: innovations,
|
||||||
Version: &Version,
|
Version: &Version,
|
||||||
Intents: discordgo.IntentsAllWithoutPrivileged |
|
Intents: discordgo.IntentsAllWithoutPrivileged |
|
||||||
discordgo.IntentsMessageContent |
|
discordgo.IntentsMessageContent |
|
||||||
discordgo.IntentGuildMembers,
|
discordgo.IntentGuildMembers,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// interaction: /config
|
||||||
|
bot.HandleMessageComponent(commands.ConfigModifyXPRole, commands.ConfigModifyXpRole)
|
||||||
|
bot.HandleMessageComponent(commands.ConfigXPRoleAddEdit, commands.XpRoleAdd)
|
||||||
|
bot.HandleMessageComponent(commands.ConfigXPRoleAddEdit, commands.XpRoleEdit)
|
||||||
|
bot.HandleMessageComponent(commands.ConfigXPRoleAddRole, commands.XpRoleAddRole)
|
||||||
|
bot.HandleMessageComponent(commands.ConfigXPRoleEditRole, commands.XpRoleEditRole)
|
||||||
|
bot.HandleMessageComponent(commands.ConfigXPRoleDel, commands.XpRoleDel)
|
||||||
|
bot.HandleMessageComponent(commands.ConfigXPRoleDelRole, commands.XpRoleDelRole)
|
||||||
|
bot.HandleModal(commands.ConfigXPRoleLevel, commands.XpRoleAddLevel)
|
||||||
|
bot.HandleModal(commands.ConfigXPRoleLevel, commands.XpRoleEditLevel)
|
||||||
|
|
||||||
|
// xp handlers
|
||||||
|
bot.AddHandler(OnMessage)
|
||||||
|
bot.AddHandler(OnVoiceUpdate)
|
||||||
|
bot.AddHandler(OnLeave)
|
||||||
|
|
||||||
bot.Start()
|
bot.Start()
|
||||||
|
|
||||||
if stopPeriodicReducer != nil {
|
if stopPeriodicReducer != nil {
|
||||||
stopPeriodicReducer <- true
|
stopPeriodicReducer <- true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func afterInit(dg *discordgo.Session) {
|
|
||||||
// handlers
|
|
||||||
dg.AddHandler(OnMessage)
|
|
||||||
dg.AddHandler(OnVoiceUpdate)
|
|
||||||
dg.AddHandler(OnLeave)
|
|
||||||
|
|
||||||
stopPeriodicReducer = gokord.NewTimer(24*time.Hour, func(stop chan<- interface{}) {
|
|
||||||
user.PeriodicReducer(dg)
|
|
||||||
})
|
|
||||||
|
|
||||||
//interaction: /config
|
|
||||||
dg.AddHandler(commands.ConfigXP)
|
|
||||||
dg.AddHandler(commands.ConfigXPModal)
|
|
||||||
}
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue