mirror of
https://github.com/JonnyBro/JaBa.git
synced 2025-01-07 19:23:02 +05:00
Compare commits
No commits in common. "4b89b8f447fbfc706d1c7bfb2653b2e4d27bc33c" and "69675817881fd5d49a5bc94dd2a16eaf6966a5b8" have entirely different histories.
4b89b8f447
...
6967581788
6 changed files with 57 additions and 67 deletions
|
@ -15,8 +15,6 @@ class CommandHandler extends BaseEvent {
|
||||||
* @param {import("discord.js").CommandInteraction} interaction
|
* @param {import("discord.js").CommandInteraction} interaction
|
||||||
*/
|
*/
|
||||||
async execute(client, interaction) {
|
async execute(client, interaction) {
|
||||||
if (interaction.isButton() && interaction.customId === "quote_delete" && interaction.message.deletable) return interaction.message.delete();
|
|
||||||
|
|
||||||
const command = client.commands.get(interaction.commandName);
|
const command = client.commands.get(interaction.commandName);
|
||||||
if (!command) return interaction.reply({ content: "Command not found!", ephemeral: true });
|
if (!command) return interaction.reply({ content: "Command not found!", ephemeral: true });
|
||||||
|
|
||||||
|
@ -29,6 +27,7 @@ class CommandHandler extends BaseEvent {
|
||||||
|
|
||||||
interaction.data = data;
|
interaction.data = data;
|
||||||
|
|
||||||
|
if (interaction.isButton() && interaction.customId === "quote_delete" && interaction.message.deletable) return interaction.message.delete();
|
||||||
if (interaction.isAutocomplete()) return await command.autocompleteRun(client, interaction);
|
if (interaction.isAutocomplete()) return await command.autocompleteRun(client, interaction);
|
||||||
if (interaction.type !== InteractionType.ApplicationCommand || !interaction.isCommand()) return;
|
if (interaction.type !== InteractionType.ApplicationCommand || !interaction.isCommand()) return;
|
||||||
|
|
||||||
|
@ -48,13 +47,13 @@ class CommandHandler extends BaseEvent {
|
||||||
|
|
||||||
await interaction.data.user.save();
|
await interaction.data.user.save();
|
||||||
|
|
||||||
const message = {
|
const achievementMessage = {
|
||||||
content: interaction.user.toString(),
|
content: interaction.user.toString(),
|
||||||
files: [{ name: "achievement_unlocked2.png", attachment: "./assets/img/achievements/achievement_unlocked2.png" }],
|
files: [{ name: "achievement_unlocked2.png", attachment: "./assets/img/achievements/achievement_unlocked2.png" }],
|
||||||
};
|
};
|
||||||
|
|
||||||
try {
|
try {
|
||||||
await interaction.user.send(message);
|
await interaction.user.send(achievementMessage);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
client.logger.warn("Failed to send achievement message to user:", e);
|
client.logger.warn("Failed to send achievement message to user:", e);
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,18 @@ class MessageCreate extends BaseEvent {
|
||||||
*/
|
*/
|
||||||
async execute(client, message) {
|
async execute(client, message) {
|
||||||
if (message.author.bot) return;
|
if (message.author.bot) return;
|
||||||
|
if (message.content.match(new RegExp(`^<@!?${client.user.id}>( |)$`))) return message.replyT("misc:HELLO_SERVER", null, { mention: true });
|
||||||
|
|
||||||
|
const data = await this.initializeMessageData(client, message);
|
||||||
|
message.data = data;
|
||||||
|
|
||||||
|
if (message.guild)
|
||||||
|
await this.handleGuildMessage(client, message);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
async initializeMessageData(client, message) {
|
||||||
const data = { user: await client.getUserData(message.author.id) };
|
const data = { user: await client.getUserData(message.author.id) };
|
||||||
|
|
||||||
if (message.guild) {
|
if (message.guild) {
|
||||||
|
@ -27,28 +38,20 @@ class MessageCreate extends BaseEvent {
|
||||||
data.guild = await client.getGuildData(message.guildId);
|
data.guild = await client.getGuildData(message.guildId);
|
||||||
data.member = await client.getMemberData(message.author.id, message.guildId);
|
data.member = await client.getMemberData(message.author.id, message.guildId);
|
||||||
}
|
}
|
||||||
message.data = data;
|
|
||||||
|
|
||||||
if (message.content.match(new RegExp(`^<@!?${client.user.id}>( |)$`))) return message.replyT("misc:HELLO_SERVER", null, { mention: true, locale: message.data.guild.language });
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
if (message.guild) {
|
async handleGuildMessage(client, message) {
|
||||||
await this.updateXp(message);
|
await updateXp(message);
|
||||||
|
|
||||||
if (message.content.match(/(https|http):\/\/(ptb\.|canary\.)?(discord.com)\/(channels)\/\d+\/\d+\/\d+/g)) return await this.handleLinkQuote(client, message);
|
if (message.content.match(/(https|http):\/\/(ptb\.|canary\.)?(discord.com)\/(channels)\/\d+\/\d+\/\d+/g)) await this.handleLinkQuote(client, message);
|
||||||
if (message.data.guild.plugins.automod.enabled && !message.data.guild.plugins.automod.ignored.includes(message.channelId)) await this.checkAutomod(message);
|
if (message.data.guild.plugins.automod.enabled && !message.data.guild.plugins.automod.ignored.includes(message.channelId)) await this.checkAutomod(message);
|
||||||
|
|
||||||
await this.checkAfkStatus(client, message);
|
await this.checkAfkStatus(client, message);
|
||||||
await this.checkMentionedUsersAfk(client, message);
|
await this.checkMentionedUsersAfk(client, message);
|
||||||
}
|
}
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param {import("../base/Client")} client
|
|
||||||
* @param {import("discord.js").Message} message
|
|
||||||
*/
|
|
||||||
async handleLinkQuote(client, message) {
|
async handleLinkQuote(client, message) {
|
||||||
const link = message.content.match(/(https|http):\/\/(ptb\.|canary\.)?(discord.com)\/(channels)\/\d+\/\d+\/\d+/g)[0];
|
const link = message.content.match(/(https|http):\/\/(ptb\.|canary\.)?(discord.com)\/(channels)\/\d+\/\d+\/\d+/g)[0];
|
||||||
const ids = link.match(/\d+/g);
|
const ids = link.match(/\d+/g);
|
||||||
|
@ -91,10 +94,6 @@ class MessageCreate extends BaseEvent {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param {import("discord.js").Message} message
|
|
||||||
*/
|
|
||||||
async checkAutomod(message) {
|
async checkAutomod(message) {
|
||||||
const inviteRegex = /(discord\.(gg|io|me|li)\/.+|discordapp\.com\/invite\/.+)/i;
|
const inviteRegex = /(discord\.(gg|io|me|li)\/.+|discordapp\.com\/invite\/.+)/i;
|
||||||
if (inviteRegex.test(message.content) && !message.channel.permissionsFor(message.member).has(PermissionsBitField.Flags.ManageMessages)) {
|
if (inviteRegex.test(message.content) && !message.channel.permissionsFor(message.member).has(PermissionsBitField.Flags.ManageMessages)) {
|
||||||
|
@ -103,11 +102,6 @@ class MessageCreate extends BaseEvent {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param {import("../base/Client")} client
|
|
||||||
* @param {import("discord.js").Message} message
|
|
||||||
*/
|
|
||||||
async checkAfkStatus(client, message) {
|
async checkAfkStatus(client, message) {
|
||||||
if (message.data.user.afk) {
|
if (message.data.user.afk) {
|
||||||
message.data.user.afk = null;
|
message.data.user.afk = null;
|
||||||
|
@ -117,11 +111,6 @@ class MessageCreate extends BaseEvent {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @param {import("../base/Client")} client
|
|
||||||
* @param {import("discord.js").Message} message
|
|
||||||
*/
|
|
||||||
async checkMentionedUsersAfk(client, message) {
|
async checkMentionedUsersAfk(client, message) {
|
||||||
for (const user of message.mentions.users.values()) {
|
for (const user of message.mentions.users.values()) {
|
||||||
const userData = await client.getUserData(user.id);
|
const userData = await client.getUserData(user.id);
|
||||||
|
@ -129,12 +118,15 @@ class MessageCreate extends BaseEvent {
|
||||||
if (userData.afk) message.replyT("general/afk:IS_AFK", { user: user.getUsername(), message: userData.afk }, { ephemeral: true });
|
if (userData.afk) message.replyT("general/afk:IS_AFK", { user: user.getUsername(), message: userData.afk }, { ephemeral: true });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
* @param {import("../base/Client")} client
|
||||||
* @param {import("discord.js").Message} message
|
* @param {import("discord.js").Message} message
|
||||||
|
* @returns
|
||||||
*/
|
*/
|
||||||
async updateXp(message) {
|
async function updateXp(message) {
|
||||||
const memberData = message.data.member;
|
const memberData = message.data.member;
|
||||||
const isInCooldown = xpCooldown[message.author.id];
|
const isInCooldown = xpCooldown[message.author.id];
|
||||||
|
|
||||||
|
@ -157,7 +149,6 @@ class MessageCreate extends BaseEvent {
|
||||||
}
|
}
|
||||||
|
|
||||||
await memberData.save();
|
await memberData.save();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = MessageCreate;
|
module.exports = MessageCreate;
|
||||||
|
|
|
@ -41,7 +41,7 @@
|
||||||
|
|
||||||
"MONITORING": {
|
"MONITORING": {
|
||||||
"DELETE": {
|
"DELETE": {
|
||||||
"TITLE": "{{user}}'s message was deleted!",
|
"TITLE": "{{user}} deleted a message!",
|
||||||
"DESCRIPTION": "Message content was: ```{{content}}```\nChannel: {{channel}}\nTime created: {{time}}"
|
"DESCRIPTION": "Message content was: ```{{content}}```\nChannel: {{channel}}\nTime created: {{time}}"
|
||||||
},
|
},
|
||||||
"UPDATE": {
|
"UPDATE": {
|
||||||
|
|
|
@ -41,7 +41,7 @@
|
||||||
|
|
||||||
"MONITORING": {
|
"MONITORING": {
|
||||||
"DELETE": {
|
"DELETE": {
|
||||||
"TITLE": "Сообщение {{user}} удалено!",
|
"TITLE": "{{user}} удалил сообщение!",
|
||||||
"DESCRIPTION": "Содержимое сообщения было: ```{{content}}```\nКанал: {{channel}}\nВремя создания: {{time}}"
|
"DESCRIPTION": "Содержимое сообщения было: ```{{content}}```\nКанал: {{channel}}\nВремя создания: {{time}}"
|
||||||
},
|
},
|
||||||
"UPDATE": {
|
"UPDATE": {
|
||||||
|
|
|
@ -41,7 +41,7 @@
|
||||||
|
|
||||||
"MONITORING": {
|
"MONITORING": {
|
||||||
"DELETE": {
|
"DELETE": {
|
||||||
"TITLE": "Повідомлення {{user}} видалено!",
|
"TITLE": "{{user}} видалив повідомлення!",
|
||||||
"DESCRIPTION": "Вміст повідомлення було: ```{{content}}```\nКанал: {{channel}}\nЧас створення: {{time}}"
|
"DESCRIPTION": "Вміст повідомлення було: ```{{content}}```\nКанал: {{channel}}\nЧас створення: {{time}}"
|
||||||
},
|
},
|
||||||
"UPDATE": {
|
"UPDATE": {
|
||||||
|
|
Loading…
Reference in a new issue