aboutsummaryrefslogtreecommitdiff
path: root/commands/rank.go
diff options
context:
space:
mode:
Diffstat (limited to 'commands/rank.go')
-rw-r--r--commands/rank.go21
1 files changed, 15 insertions, 6 deletions
diff --git a/commands/rank.go b/commands/rank.go
index cd37a0c..219977d 100644
--- a/commands/rank.go
+++ b/commands/rank.go
@@ -9,7 +9,8 @@ import (
func Rank(s *discordgo.Session, i *discordgo.InteractionCreate) {
optMap := utils.GenerateOptionMap(i)
- c := xp.Copaing{DiscordID: i.Member.User.ID, GuildID: i.GuildID}
+ c := xp.GetCopaing(i.Member.User.ID, i.GuildID) // current copaing = member who used /rank
+ xp.LastEventUpdate(s, c) // update xp and reset last event
msg := "Votre niveau"
m := i.Member
var err error
@@ -24,25 +25,33 @@ func Rank(s *discordgo.Session, i *discordgo.InteractionCreate) {
}
m, err = s.GuildMember(i.GuildID, u.ID)
if err != nil {
- utils.SendAlert("rank.go - Fetching guild member", err.Error())
+ utils.SendAlert(
+ "rank.go - Fetching guild member",
+ err.Error(),
+ "discord_id",
+ u.ID,
+ "guild_id",
+ i.GuildID,
+ )
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())
}
return
}
- c.DiscordID = u.ID
+ c.DiscordID = u.ID // current copaing = member targeted by member who wrote /rank
+ c.Load() // reload copaing (change line before)
+ xp.XPUpdate(s, c) // update xp without resetting event
msg = fmt.Sprintf("Le niveau de %s", m.DisplayName())
}
- c.Load()
lvl := xp.Level(c.XP)
- nxtLvl := xp.XPForLevel(lvl + 1)
+ nxtLvlXP := xp.XPForLevel(lvl + 1)
err = resp.Message(fmt.Sprintf(
"%s : **%d**\n> XP : %d\n> Prochain niveau dans %d XP",
msg,
lvl,
c.XP,
- nxtLvl-lvl,
+ nxtLvlXP-c.XP,
)).Send()
if err != nil {
utils.SendAlert("rank.go - Sending rank", err.Error())