mirror of
https://github.com/arthur-pbty/bot-discord-coins.git
synced 2026-06-03 23:36:29 +02:00
upgrade rep
This commit is contained in:
+64
-36
@@ -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: '<membre-id|@membre>',
|
||||
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 } });
|
||||
},
|
||||
};
|
||||
Reference in New Issue
Block a user