mirror of
https://github.com/arthur-pbty/bot-discord-coins.git
synced 2026-06-15 15:55:45 +02:00
Add sell.js
This commit is contained in:
@@ -0,0 +1,182 @@
|
||||
const { EmbedBuilder, ActionRowBuilder, StringSelectMenuBuilder, StringSelectMenuOptionBuilder } = require('discord.js');
|
||||
const db = require('../../fonctions/database.js');
|
||||
const embedColor = require('../../fonctions/embedColor.js');
|
||||
|
||||
module.exports = {
|
||||
aliases: ['vendre'],
|
||||
description: 'Affiche le menu de vente des objets.',
|
||||
emote: '🛍️',
|
||||
utilisation: '',
|
||||
permission: 0,
|
||||
|
||||
async execute(message, args, client) {
|
||||
const user = 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 embed = new EmbedBuilder()
|
||||
.setTitle('🛍️ Shop')
|
||||
.setThumbnail(message.guild.iconURL())
|
||||
.setDescription(`Sélectionnez un nombre d'objet à vendre.\n\nVous avez \`${user.objet}\`objet.\nAttention, il est possible que de petit pourboire de client soit rajouté.`)
|
||||
.setColor(await embedColor(message.author.id, message.guild.id))
|
||||
.setTimestamp()
|
||||
.setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() });
|
||||
|
||||
const select = new StringSelectMenuBuilder()
|
||||
.setCustomId('sell')
|
||||
.setPlaceholder('Sélectionnez un nombre d\'objet')
|
||||
.addOptions(
|
||||
new StringSelectMenuOptionBuilder()
|
||||
.setLabel('👶 Debutant')
|
||||
.setValue('1')
|
||||
.setDescription('Vend un objet, pour \`200\`coins.')
|
||||
.setEmoji('👶')
|
||||
.setDefault(false)
|
||||
)
|
||||
.addOptions(
|
||||
new StringSelectMenuOptionBuilder()
|
||||
.setLabel('🚸 Enfant')
|
||||
.setValue('2')
|
||||
.setDescription('Vend deux objet, pour \`400\`coins.')
|
||||
.setEmoji('🚸')
|
||||
.setDefault(false)
|
||||
)
|
||||
.addOptions(
|
||||
new StringSelectMenuOptionBuilder()
|
||||
.setLabel('🔞 Mineur')
|
||||
.setValue('3')
|
||||
.setDescription('Vend trois objet, pour \`600\`coins.')
|
||||
.setEmoji('🔞')
|
||||
.setDefault(false)
|
||||
)
|
||||
.addOptions(
|
||||
new StringSelectMenuOptionBuilder()
|
||||
.setLabel('🧐 Expert')
|
||||
.setValue('4')
|
||||
.setDescription('Vend quatre objet, pour \`800\`coins.')
|
||||
.setEmoji('🧐')
|
||||
.setDefault(false),
|
||||
)
|
||||
.addOptions(
|
||||
new StringSelectMenuOptionBuilder()
|
||||
.setLabel('👑 Mythique')
|
||||
.setValue('5')
|
||||
.setDescription('Vend cinq objet, pour \`1 000\`coins.')
|
||||
.setEmoji('👑')
|
||||
.setDefault(false),
|
||||
)
|
||||
.addOptions(
|
||||
new StringSelectMenuOptionBuilder()
|
||||
.setLabel('👑 Legendaire')
|
||||
.setValue('10')
|
||||
.setDescription('Vend dix objet, pour \`10 000\`coins !')
|
||||
.setEmoji('👑')
|
||||
.setDefault(false),
|
||||
)
|
||||
.addOptions(
|
||||
new StringSelectMenuOptionBuilder()
|
||||
.setLabel('👑 Ultime')
|
||||
.setValue('25')
|
||||
.setDescription('Vend 25 objet, pour \`30 000\`coins !')
|
||||
.setEmoji('👑')
|
||||
.setDefault(false),
|
||||
)
|
||||
|
||||
const row = new ActionRowBuilder()
|
||||
.addComponents(select);
|
||||
|
||||
message.reply({ embeds: [embed], components: [row], allowedMentions: { repliedUser: false } });
|
||||
|
||||
client.on('interactionCreate', async (interaction) => {
|
||||
if (!interaction.user.id !== message.author.id) return;
|
||||
if (!interaction.isSelectMenu()) return;
|
||||
|
||||
if (!interaction.customId === 'sell') return
|
||||
const selected = interaction.values[0];
|
||||
|
||||
if (selected === '1') {
|
||||
if (user.objet < 1) {
|
||||
return interaction.reply({ content: 'Vous n\'avez pas assez d\'objet pour en vendre autant.', ephemeral: true });
|
||||
}
|
||||
db.run(`UPDATE users SET objet = objet - 1, pocket = pocket + 200 WHERE guildId = ? AND userId = ?`, [message.guild.id, message.author.id]);
|
||||
}
|
||||
|
||||
if (selected === '2') {
|
||||
if (user.objet < 2) {
|
||||
return interaction.reply({ content: 'Vous n\'avez pas assez d\'objet pour en vendre autant.', ephemeral: true });
|
||||
}
|
||||
db.run(`UPDATE users SET objet = objet - 2, pocket = pocket + 400 WHERE guildId = ? AND userId = ?`, [message.guild.id, message.author.id]);
|
||||
}
|
||||
|
||||
if (selected === '3') {
|
||||
if (user.objet < 3) {
|
||||
return interaction.reply({ content: 'Vous n\'avez pas assez d\'objet pour en vendre autant.', ephemeral: true });
|
||||
}
|
||||
db.run(`UPDATE users SET objet = objet - 3, pocket = pocket + 600 WHERE guildId = ? AND userId = ?`, [message.guild.id, message.author.id]);
|
||||
}
|
||||
|
||||
if (selected === '4') {
|
||||
if (user.objet < 4) {
|
||||
return interaction.reply({ content: 'Vous n\'avez pas assez d\'objet pour en vendre autant.', ephemeral: true });
|
||||
}
|
||||
db.run(`UPDATE users SET objet = objet - 4, pocket = pocket + 850 WHERE guildId = ? AND userId = ?`, [message.guild.id, message.author.id]);
|
||||
}
|
||||
|
||||
if (selected === '5') {
|
||||
if (user.objet < 5) {
|
||||
return interaction.reply({ content: 'Vous n\'avez pas assez d\'objet pour en vendre autant.', ephemeral: true });
|
||||
}
|
||||
db.run(`UPDATE users SET objet = objet - 5, pocket = pocket + 1500 WHERE guildId = ? AND userId = ?`, [message.guild.id, message.author.id]);
|
||||
}
|
||||
|
||||
if (selected === '10') {
|
||||
if (user.objet < 10) {
|
||||
return interaction.reply({ content: 'Vous n\'avez pas assez d\'objet pour en vendre autant.', ephemeral: true });
|
||||
}
|
||||
db.run(`UPDATE users SET objet = objet - 10, pocket = pocket + 10500 WHERE guildId = ? AND userId = ?`, [message.guild.id, message.author.id]);
|
||||
}
|
||||
|
||||
if (selected === '25') {
|
||||
if (user.objet < 25) {
|
||||
return interaction.reply({ content: 'Vous n\'avez pas assez d\'objet pour en vendre autant.', ephemeral: true });
|
||||
}
|
||||
db.run(`UPDATE users SET objet = objet - 25, pocket = pocket + 31000 WHERE guildId = ? AND userId = ?`, [message.guild.id, message.author.id]);
|
||||
}
|
||||
|
||||
|
||||
if (select <= 9) {
|
||||
const embed = new EmbedBuilder()
|
||||
.setTitle('🛍️ Shop')
|
||||
.setDescription(`Vous avez vendu \`${select}\`objet pour \`${200 * select}\`coins !`)
|
||||
.setColor(await embedColor(message.author.id, message.guild.id))
|
||||
.setTimestamp()
|
||||
.setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() });
|
||||
|
||||
interaction.reply({ embeds: [embed], allowedMentions: { repliedUser: false } });
|
||||
}
|
||||
else if (select === 10){
|
||||
const embed = new EmbedBuilder()
|
||||
.setTitle('🛍️ Shop')
|
||||
.setDescription(`Vous avez vendu \`${select}\`objet pour \`10000\`coins !`)
|
||||
.setColor(await embedColor(message.author.id, message.guild.id))
|
||||
.setTimestamp()
|
||||
.setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() });
|
||||
|
||||
interaction.reply({ embeds: [embed], allowedMentions: { repliedUser: false } });
|
||||
}
|
||||
else if (select === 25){
|
||||
const embed = new EmbedBuilder()
|
||||
.setTitle('🛍️ Shop')
|
||||
.setDescription(`Vous avez vendu \`${select}\`objet pour \`30000\`coins !`)
|
||||
.setColor(await embedColor(message.author.id, message.guild.id))
|
||||
.setTimestamp()
|
||||
.setFooter({ text: `Demandé par ${message.author.tag}`, iconURL: message.author.displayAvatarURL() });
|
||||
|
||||
interaction.reply({ embeds: [embed], allowedMentions: { repliedUser: false } });
|
||||
}
|
||||
});
|
||||
},
|
||||
};
|
||||
Reference in New Issue
Block a user