upgrade rep

This commit is contained in:
arthur
2024-05-27 21:44:43 +02:00
parent 0d2e57eb69
commit 58bccbad42
2 changed files with 65 additions and 37 deletions
+64 -36
View File
@@ -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 } });
},
};