diff --git a/commands/casino/rep.js b/commands/casino/rep.js index 58e9505..8b08451 100644 --- a/commands/casino/rep.js +++ b/commands/casino/rep.js @@ -4,61 +4,89 @@ const embedColor = require('../../fonctions/embedColor.js'); module.exports = { aliases: ['reputation'], - description: `Ajoute un point de reputation a un membre. (Ne pas confondre avec ${db.get(`SELECT value FROM config WHERE guildId = ? AND name = ?`, [message.guild.id, 'prefix'])?.value || '&'}trep qui ajoute une reputation a une team)`, + description: `Ajoute un point de reputation a un membre.`, emote: '➕', utilisation: '', permission: 0, async execute(message, args, client) { - if (args.length > 0) { - const userArgs = args[0].toLowerCase() - const userID = userArgs.replace(`<`, ``).replace(`@`, ``).replace(`>`, ``) + const member = message.mentions.members.first()?.id || args[0]; + if (args.length < 1 && !member) { + return message.reply({ embeds: [ + new EmbedBuilder() + .setTitle('Erreur') + .setDescription('❌ Veuillez spécifier un membre du serveur.') + .setColor(await embedColor(message.author.id, message.guild.id)) + .setTimestamp() + .setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() }) + ], allowedMentions: { repliedUser: false } }); + } - const author = await new Promise((resolve, reject) => { - db.get(`SELECT * FROM users WHERE guildId = ? AND userId = ?`, [message.guild.id, message.author.id], (err, row) => { - if (err) reject(err); - resolve(row); - }); - }); - const lastRep = author.lastRep - const user = await new Promise((resolve, reject) => { - db.get(`SELECT * FROM users WHERE guildId = ? AND userId = ?`, [message.guild.id, userID], (err, row) => { - if (err) reject(err); - resolve(row); - }); + const lastRep = await new Promise((resolve, reject) => { + db.get(`SELECT * FROM users WHERE guildId = ? AND userId = ?`, [message.guild.id, message.author.id], (err, row) => { + if (err) reject(err); + resolve(row.lastRep); }); + }); - if (lastRep > Date.now() - 5400000) { - const embed = new EmbedBuilder() + if (lastRep > Date.now() - 7200000) { + return message.reply({ embeds: [ + new EmbedBuilder() .setTitle('Ajout Impossible') .setDescription(`❌ Vous avez déjà ajouter une reputation récemment. Veuillez attendre ${Math.floor((lastRep + 5400000 - Date.now()) / 60000)} minutes avant de pouvoir ajouter une reputation à nouveau.`) .setColor(await embedColor(message.author.id, message.guild.id)) .setTimestamp() - .setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() }); + .setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() }) + ], allowedMentions: { repliedUser: false } }); + } - return message.reply({ embeds: [embed], allowedMentions: { repliedUser: false } }); + const userReputation = await new Promise((resolve, reject) => { + db.get(`SELECT * FROM users WHERE guildId = ? AND userId = ?`, [message.guild.id, member], async (err, row) => { + if (err) reject(err); + if (!row) { + return message.reply({ embeds: [ + new EmbedBuilder() + .setTitle('Erreur') + .setDescription('❌ L\'utilisateur spécifié n\'existe pas.') + .setColor(await embedColor(message.author.id, message.guild.id)) + .setTimestamp() + .setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() }) + ], allowedMentions: { repliedUser: false } }); } - - db.run(`UPDATE users SET lastRep =? WHERE guildId =? AND userId =?`, [Date.now(), message.guild.id, message.author.id], (err) => { - if (err) { - console.log(`${err}`.red) - } + resolve(parseInt(row.reputation)); }); + }); - db.run(`UPDATE users SET reputation = reputation + 1 WHERE guildId =? AND userId =?`, [message.guild.id, userID], (err) => { - if (err) { - console.log(`${err}`.red) - } - }); + if (member === message.author.id) { + return message.reply({ embeds: [ + new EmbedBuilder() + .setTitle('Erreur') + .setDescription('❌ Vous ne pouvez pas vous donner une réputation à vous-même.') + .setColor(await embedColor(message.author.id, message.guild.id)) + .setTimestamp() + .setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() }) + ], allowedMentions: { repliedUser: false } }); + } - const embed = new EmbedBuilder() + db.run(`UPDATE users SET lastRep = ? WHERE guildId = ? AND userId = ?`, [Date.now(), message.guild.id, message.author.id], (err) => { + if (err) { + console.log(`${err}`.red) + } + }); + + db.run(`UPDATE users SET reputation = reputation + 1 WHERE guildId = ? AND userId = ?`, [message.guild.id, member], (err) => { + if (err) { + console.log(`${err}`.red) + } + }); + + message.reply({ embeds: [ + new EmbedBuilder() .setTitle('Reputation ajouté !') - .setDescription('Vous avez ajouter une reputation à <@' + userID + '>, qui a maintement `' + user.reputation + 1 + '` reputation !') + .setDescription('Vous avez ajouter une reputation à <@' + member + '>, qui a maintement `' + userReputation + 1 + '` reputation !') .setColor(await embedColor(message.author.id, message.guild.id)) .setTimestamp() - .setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() }); - - message.reply({ embeds: [embed], allowedMentions: { repliedUser: false } }); - } + .setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() }) + ], allowedMentions: { repliedUser: false } }); }, }; \ No newline at end of file diff --git a/fonctions/database.js b/fonctions/database.js index 101dc12..7a930aa 100644 --- a/fonctions/database.js +++ b/fonctions/database.js @@ -40,7 +40,7 @@ db.run(`CREATE TABLE IF NOT EXISTS teams ( description TEXT, icon TEXT, banner TEXT, - reputation INTERGER DEFAULT 0,ça avan + reputation INTERGER DEFAULT 0, bank INTEGER DEFAULT 0, level INTEGER DEFAULT 1, padlock INTEGER DEFAULT 5,