mirror of
https://github.com/idanoo/GoDiscMoji
synced 2025-07-03 03:12:15 +00:00
Orders
This commit is contained in:
parent
4454b0ad1b
commit
2d8c45afb2
2 changed files with 50 additions and 25 deletions
|
@ -3,6 +3,7 @@ package bot
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"log/slog"
|
"log/slog"
|
||||||
|
"sort"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/bwmarrin/discordgo"
|
"github.com/bwmarrin/discordgo"
|
||||||
|
@ -92,18 +93,30 @@ func showTopEmojis(s *discordgo.Session, i *discordgo.InteractionCreate) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Sort keys
|
||||||
|
keys := make([]int, 0)
|
||||||
|
for k, _ := range top {
|
||||||
|
keys = append(keys, k)
|
||||||
|
}
|
||||||
|
sort.Ints(keys)
|
||||||
msg := "Most used emojis:\n"
|
msg := "Most used emojis:\n"
|
||||||
for _, v := range top {
|
for _, v := range keys {
|
||||||
topUsers, err := b.Db.GetTopUsersForGuildEmoji(i.GuildID, v.EmojiID, 3)
|
topUsers, err := b.Db.GetTopUsersForGuildEmoji(i.GuildID, top[v].EmojiID, 3)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
slog.Error("Error getting top users for guild emoji", "err", err)
|
slog.Error("Error getting top users for guild emoji", "err", err)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
subkeys := make([]int, 0)
|
||||||
|
for k, _ := range topUsers {
|
||||||
|
subkeys = append(subkeys, k)
|
||||||
|
}
|
||||||
|
sort.Ints(subkeys)
|
||||||
|
|
||||||
users := []string{}
|
users := []string{}
|
||||||
msg += fmt.Sprintf("%s: %d", v.EmojiID, v.Count)
|
msg += fmt.Sprintf("%s: %d", top[v].EmojiID, top[v].Count)
|
||||||
for sk, sv := range topUsers {
|
for _, sv := range subkeys {
|
||||||
users = append(users, fmt.Sprintf("<@%s>: %d", sk, sv))
|
users = append(users, fmt.Sprintf("<@%s>: %d", topUsers[sv].EmojiID, topUsers[sv].Count))
|
||||||
}
|
}
|
||||||
msg += " (" + strings.Join(users, ", ") + ")\n"
|
msg += " (" + strings.Join(users, ", ") + ")\n"
|
||||||
}
|
}
|
||||||
|
@ -137,19 +150,31 @@ func showTopUsers(s *discordgo.Session, i *discordgo.InteractionCreate) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Sort keys
|
||||||
|
keys := make([]int, 0)
|
||||||
|
for k, _ := range top {
|
||||||
|
keys = append(keys, k)
|
||||||
|
}
|
||||||
|
sort.Ints(keys)
|
||||||
|
|
||||||
msg := "Users who use the most emojis:\n"
|
msg := "Users who use the most emojis:\n"
|
||||||
for k, v := range top {
|
for _, v := range keys {
|
||||||
slog.Error("Error getting top emojis for guild user", "user_id", k, "count", v)
|
topUsers, err := b.Db.GetTopEmojisForGuildUser(i.GuildID, top[v].EmojiID, 3)
|
||||||
topUsers, err := b.Db.GetTopEmojisForGuildUser(i.GuildID, k, 3)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
slog.Error("Error getting top emojis for guild user", "err", err)
|
slog.Error("Error getting top emojis for guild user", "err", err)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
subkeys := make([]int, 0)
|
||||||
|
for k, _ := range topUsers {
|
||||||
|
subkeys = append(subkeys, k)
|
||||||
|
}
|
||||||
|
sort.Ints(subkeys)
|
||||||
|
|
||||||
users := []string{}
|
users := []string{}
|
||||||
msg += fmt.Sprintf("<@%s>: %d", k, v)
|
msg += fmt.Sprintf("<@%s>: %d", top[v].EmojiID, top[v].Count)
|
||||||
for _, sv := range topUsers {
|
for _, sv := range subkeys {
|
||||||
users = append(users, fmt.Sprintf("%s: %d", sv.EmojiID, sv.Count))
|
users = append(users, fmt.Sprintf("%s: %d", topUsers[sv].EmojiID, topUsers[sv].Count))
|
||||||
}
|
}
|
||||||
msg += " (" + strings.Join(users, ", ") + ")\n"
|
msg += " (" + strings.Join(users, ", ") + ")\n"
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,5 @@
|
||||||
package db
|
package db
|
||||||
|
|
||||||
import "log/slog"
|
|
||||||
|
|
||||||
type EmojiMap struct {
|
type EmojiMap struct {
|
||||||
EmojiID string
|
EmojiID string
|
||||||
Count int64
|
Count int64
|
||||||
|
@ -18,8 +16,8 @@ func (db *Database) LogEmojiUsage(guildID, channelID, userID, emojiID string) er
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetTopUsersForGuild - Report usage
|
// GetTopUsersForGuild - Report usage
|
||||||
func (db *Database) GetTopUsersForGuild(guildID string, num int64) (map[string]int64, error) {
|
func (db *Database) GetTopUsersForGuild(guildID string, num int64) (map[int]EmojiMap, error) {
|
||||||
data := make(map[string]int64)
|
data := make(map[int]EmojiMap)
|
||||||
row, err := db.db.Query(
|
row, err := db.db.Query(
|
||||||
"SELECT user_id, count(*) FROM `emoji_usage` WHERE `guild_id` = ? GROUP BY user_id ORDER BY count(*) DESC LIMIT ?",
|
"SELECT user_id, count(*) FROM `emoji_usage` WHERE `guild_id` = ? GROUP BY user_id ORDER BY count(*) DESC LIMIT ?",
|
||||||
guildID,
|
guildID,
|
||||||
|
@ -31,20 +29,20 @@ func (db *Database) GetTopUsersForGuild(guildID string, num int64) (map[string]i
|
||||||
}
|
}
|
||||||
|
|
||||||
defer row.Close()
|
defer row.Close()
|
||||||
|
i := 0
|
||||||
for row.Next() {
|
for row.Next() {
|
||||||
var user string
|
var name string
|
||||||
var count int64
|
var count int64
|
||||||
row.Scan(&user, &count)
|
row.Scan(&name, &count)
|
||||||
slog.Error("Error getting top emojis for guild user", "user_id", user, "count", count)
|
data[i] = EmojiMap{EmojiID: name, Count: count}
|
||||||
data[user] = count
|
i++
|
||||||
}
|
}
|
||||||
|
|
||||||
return data, nil
|
return data, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetTopUsersForGuildEmoji - Report usage
|
// GetTopUsersForGuildEmoji - Report usage
|
||||||
func (db *Database) GetTopUsersForGuildEmoji(guildID string, emojiID string, num int) (map[string]int64, error) {
|
func (db *Database) GetTopUsersForGuildEmoji(guildID string, emojiID string, num int) (map[int]EmojiMap, error) {
|
||||||
data := make(map[string]int64)
|
data := make(map[int]EmojiMap)
|
||||||
row, err := db.db.Query(
|
row, err := db.db.Query(
|
||||||
"SELECT user_id, count(*) FROM `emoji_usage` WHERE `guild_id` = ? AND `emoji_id` = ? GROUP BY emoji_id, user_id ORDER BY count(*) DESC LIMIT ?",
|
"SELECT user_id, count(*) FROM `emoji_usage` WHERE `guild_id` = ? AND `emoji_id` = ? GROUP BY emoji_id, user_id ORDER BY count(*) DESC LIMIT ?",
|
||||||
guildID,
|
guildID,
|
||||||
|
@ -57,11 +55,13 @@ func (db *Database) GetTopUsersForGuildEmoji(guildID string, emojiID string, num
|
||||||
}
|
}
|
||||||
|
|
||||||
defer row.Close()
|
defer row.Close()
|
||||||
|
i := 0
|
||||||
for row.Next() {
|
for row.Next() {
|
||||||
var user string
|
var name string
|
||||||
var count int64
|
var count int64
|
||||||
row.Scan(&user, &count)
|
row.Scan(&name, &count)
|
||||||
data[user] = count
|
data[i] = EmojiMap{EmojiID: name, Count: count}
|
||||||
|
i++
|
||||||
}
|
}
|
||||||
|
|
||||||
return data, nil
|
return data, nil
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue