aboutsummaryrefslogtreecommitdiff
path: root/commands/rank.go
diff options
context:
space:
mode:
Diffstat (limited to 'commands/rank.go')
-rw-r--r--commands/rank.go32
1 files changed, 23 insertions, 9 deletions
diff --git a/commands/rank.go b/commands/rank.go
index c659f2b..785b8c8 100644
--- a/commands/rank.go
+++ b/commands/rank.go
@@ -11,7 +11,6 @@ import (
func Rank(s *discordgo.Session, i *discordgo.InteractionCreate) {
optMap := utils.GenerateOptionMap(i)
c := user.GetCopaing(i.Member.User.ID, i.GuildID) // current user = member who used /rank
- user.LastEventUpdate(s, c) // update exp and reset last event
msg := "Votre niveau"
m := i.Member
var err error
@@ -21,13 +20,13 @@ func Rank(s *discordgo.Session, i *discordgo.InteractionCreate) {
if u.Bot {
err = resp.Message("Imagine si les bots avaient un niveau :rolling_eyes:").IsEphemeral().Send()
if err != nil {
- utils.SendAlert("rank.go - Reply error user is a bot", err.Error())
+ utils.SendAlert("commands/rank.go - Reply error user is a bot", err.Error())
}
}
m, err = s.GuildMember(i.GuildID, u.ID)
if err != nil {
utils.SendAlert(
- "rank.go - Fetching guild member",
+ "commands/rank.go - Fetching guild member",
err.Error(),
"discord_id",
u.ID,
@@ -36,24 +35,39 @@ func Rank(s *discordgo.Session, i *discordgo.InteractionCreate) {
)
err = resp.Message("Erreur : impossible de récupérer le membre").IsEphemeral().Send()
if err != nil {
- utils.SendAlert("rank.go - Reply error fetching guild member", err.Error())
+ utils.SendAlert("commands/rank.go - Reply error fetching guild member", err.Error())
}
return
}
c = user.GetCopaing(u.ID, i.GuildID) // current user = member targeted by member who wrote /rank
- user.UpdateXP(s, c) // update exp without resetting event
msg = fmt.Sprintf("Le niveau de %s", m.DisplayName())
}
- lvl := exp.Level(c.XP)
+ xp, err := c.GetXP()
+ if err != nil {
+ utils.SendAlert(
+ "commands/rank.go - Fetching XP",
+ err.Error(),
+ "discord_id",
+ c.ID,
+ "guild_id",
+ i.GuildID,
+ )
+ err = resp.Message("Erreur : impossible de récupérer l'XP").IsEphemeral().Send()
+ if err != nil {
+ utils.SendAlert("commands/rank.go - Reply error fetching xp", err.Error())
+ }
+ return
+ }
+ lvl := exp.Level(xp)
nxtLvlXP := exp.LevelXP(lvl + 1)
err = resp.Message(fmt.Sprintf(
"%s : **%d**\n> XP : %d\n> Prochain niveau dans %d XP",
msg,
lvl,
- c.XP,
- nxtLvlXP-c.XP,
+ xp,
+ nxtLvlXP-xp,
)).Send()
if err != nil {
- utils.SendAlert("rank.go - Sending rank", err.Error())
+ utils.SendAlert("commands/rank.go - Sending rank", err.Error())
}
}