summaryrefslogtreecommitdiff
path: root/cogs/Levels.py
diff options
context:
space:
mode:
authorlexicade <jasonnlelong@gmail.com>2023-01-27 21:06:30 +0000
committerlexicade <jasonnlelong@gmail.com>2023-01-27 21:06:30 +0000
commit52801b4de1d63cd01191acf7fcee137977140ec0 (patch)
tree08271a1f1e3e8060486b6651c67c9934867c648e /cogs/Levels.py
parent8df873808c86805624851356f5dea76ec621de23 (diff)
Project initHEADmain
Diffstat (limited to 'cogs/Levels.py')
-rw-r--r--cogs/Levels.py81
1 files changed, 81 insertions, 0 deletions
diff --git a/cogs/Levels.py b/cogs/Levels.py
new file mode 100644
index 0000000..c74f616
--- /dev/null
+++ b/cogs/Levels.py
@@ -0,0 +1,81 @@
+from discord.ext import commands
+import discord
+import importlib
+import utils
+importlib.reload(utils)
+
+
+class Levels(commands.Cog):
+ def __init__(self, bot):
+ self.bot = bot
+
+ @commands.Cog.listener()
+ async def on_message(self, message):
+ """No Description."""
+ if message.author.bot:
+ return
+
+ msg_xp = int((len(message.content)-10)/2)+8 if len(message.content) > 15 else 10
+ msg_xp = 30 if msg_xp > 30 else msg_xp
+ user_level = await utils.sql_get("SELECT `xp` FROM `levels` WHERE `user_id`=%s AND `guild_id`=%s;",
+ (message.author.id, message.guild.id,))
+
+ await utils.sql_proc("add_xp", (message.author.id, message.guild.id, msg_xp, ), True)
+
+ # print(user_level[0])
+ c_xp = int(user_level[0]["xp"])
+
+ curr_level = 25 * c_xp * (1 + c_xp)
+ new_level = 25 * c_xp+msg_xp * (1 + c_xp+msg_xp)
+
+ # print(f"old:{curr_level} new:{new_level}")
+
+ @commands.bot_has_permissions(embed_links=True)
+ @commands.group(invoke_without_command=True)
+ async def rank(self, ctx):
+ """✓Check your rank in the server"""
+ ranks = await utils.sql_proc("levels_ranks", (ctx.guild.id,), False)
+
+ for rank in ranks:
+ if rank["user_id"] == ctx.author.id:
+ str_details = f"**Rank**: {int(rank['rank'])}/{len(ranks)} ({ctx.guild.member_count})\n" + \
+ f"**Messages**: {rank['messages']}\n" + \
+ f"**XP:** {rank['xp']}\n" + \
+ f"**Level:** {int(rank['level'])}\n"
+ emb = await utils.embed(ctx, ctx.author.name, str_details)
+
+ await ctx.send(embed=emb)
+ break
+
+ @commands.bot_has_permissions(embed_links=True)
+ @commands.group(invoke_without_command=True)
+ async def leaderboard(self, ctx):
+ """✓Check the top 10 ranks in the server"""
+ str_details = ""
+ ranks = await utils.sql_proc("levels_ranks", (ctx.guild.id,), False)
+ members = ctx.guild.members
+
+ # Obtain the top 10 members
+ for rank in ranks:
+ for tmp_member in members:
+ if rank['user_id'] == tmp_member.id:
+ member = tmp_member
+ break
+
+ str_details = str_details + f"{int(rank['rank'])}: {member.name} - {rank['xp']}\n"
+
+ if int(rank['rank']) == 10:
+ break
+
+ emb = await utils.embed(ctx, "", str_details)
+ await ctx.send(embed=emb)
+
+
+def setup(bot):
+ print("INFO: Loading [Levels]... ", end="")
+ bot.add_cog(Levels(bot))
+ print("Done!")
+
+
+def teardown(bot):
+ print("INFO: Unloading [Levels]")