feat(xp): implements xp reducer
This commit is contained in:
parent
9de1f3f90b
commit
0a6ecf6af7
4 changed files with 18 additions and 8 deletions
|
@ -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.User.ID, i.GuildID) // current copaing = member who used /rank
|
||||
xp.LastEventUpdate(c) // update xp and reset last event
|
||||
msg := "Votre niveau"
|
||||
m := i.Member
|
||||
var err error
|
||||
|
@ -24,17 +25,25 @@ 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(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)
|
||||
err = resp.Message(fmt.Sprintf(
|
||||
|
|
|
@ -9,6 +9,7 @@ import (
|
|||
)
|
||||
|
||||
func Top(s *discordgo.Session, i *discordgo.InteractionCreate) {
|
||||
xp.LastEventUpdate(xp.GetCopaing(i.User.ID, i.GuildID))
|
||||
resp := utils.ResponseBuilder{C: s, I: i}
|
||||
err := resp.IsDeferred().Send()
|
||||
if err != nil {
|
||||
|
|
|
@ -30,7 +30,7 @@ func OnMessage(s *discordgo.Session, m *discordgo.MessageCreate) {
|
|||
return
|
||||
}
|
||||
c := GetCopaing(m.Author.ID, m.GuildID)
|
||||
onLastEventUpdate(c)
|
||||
LastEventUpdate(c)
|
||||
// add xp
|
||||
trimmed := utils.TrimMessage(strings.ToLower(m.Content))
|
||||
m.Member.User = m.Author
|
||||
|
@ -63,7 +63,7 @@ func OnVoiceUpdate(s *discordgo.Session, e *discordgo.VoiceStateUpdate) {
|
|||
if e.Member.User.Bot {
|
||||
return
|
||||
}
|
||||
onLastEventUpdate(GetCopaing(e.UserID, e.GuildID))
|
||||
LastEventUpdate(GetCopaing(e.UserID, e.GuildID))
|
||||
cfg := config.GetGuildConfig(e.GuildID)
|
||||
if cfg.IsDisabled(e.ChannelID) {
|
||||
return
|
||||
|
|
|
@ -43,7 +43,7 @@ func onNewLevel(s *discordgo.Session, m *discordgo.Member, level uint) {
|
|||
}
|
||||
}
|
||||
|
||||
func onLastEventUpdate(c *Copaing) {
|
||||
func LastEventUpdate(c *Copaing) {
|
||||
h := c.HourSinceLastEvent()
|
||||
l := Lose(h, c.XP)
|
||||
xp := c.XPAlreadyRemoved()
|
||||
|
@ -57,7 +57,7 @@ func onLastEventUpdate(c *Copaing) {
|
|||
c.SetLastEvent()
|
||||
}
|
||||
|
||||
func onXPUpdate(c *Copaing) {
|
||||
func XPUpdate(c *Copaing) {
|
||||
h := c.HourSinceLastEvent()
|
||||
l := Lose(h, c.XP)
|
||||
xp := c.XPAlreadyRemoved()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue