mirror of
https://github.com/arthur-pbty/bot-discord-coins.git
synced 2026-06-03 15:07:20 +02:00
192 lines
6.2 KiB
JavaScript
192 lines
6.2 KiB
JavaScript
const {
|
|
EmbedBuilder,
|
|
ActionRowBuilder,
|
|
StringSelectMenuBuilder,
|
|
StringSelectMenuOptionBuilder,
|
|
} = require("discord.js");
|
|
const db = require("../../fonctions/database.js");
|
|
const embedColor = require("../../fonctions/embedColor.js");
|
|
|
|
module.exports = {
|
|
aliases: ["shop", "magasin", "boutique", "store"],
|
|
description: "Affiche le shop du bot.",
|
|
emote: "🛍️",
|
|
utilisation: "",
|
|
permission: 0,
|
|
|
|
async execute(message, args, client) {
|
|
const embed = new EmbedBuilder()
|
|
.setTitle("🛍️ Shop")
|
|
.setThumbnail(message.guild.iconURL())
|
|
.setDescription(
|
|
`Sélectionnez un item à acheter. Voici les items disponibles :\n\n> 🔒 AntiRob - Protège contre les vols pendant 2 heures - Prix : 2000coins\n\n> 🗝️ Clef - Permet d'ouvrir une boite 100%gagante - Prix : 2500coins\n\n\n\n> 💰 25000 Coins - Prix : 1 reputation`,
|
|
)
|
|
.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("shop")
|
|
.setPlaceholder("Sélectionnez un item")
|
|
.addOptions(
|
|
new StringSelectMenuOptionBuilder()
|
|
.setLabel("🔒 AntiRob")
|
|
.setValue("antirob")
|
|
.setDescription("Protège contre les vols pendant 2 heures")
|
|
.setEmoji("🔒")
|
|
.setDefault(false),
|
|
new StringSelectMenuOptionBuilder()
|
|
.setLabel("🗝️ Clef")
|
|
.setValue("key")
|
|
.setDescription("Permet d'ouvrir une boite")
|
|
.setEmoji("🗝️")
|
|
.setDefault(false),
|
|
new StringSelectMenuOptionBuilder()
|
|
.setLabel("💰 25000 Coins")
|
|
.setValue("coins")
|
|
.setDescription("Vous donne 25K de coins contre 1reputation")
|
|
.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.isStringSelectMenu()) return;
|
|
|
|
if (!interaction.customId === "shop") return;
|
|
const selected = interaction.values[0];
|
|
|
|
if (selected === "antirob") {
|
|
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);
|
|
},
|
|
);
|
|
});
|
|
|
|
if (user.pocket < 2000) {
|
|
return interaction.reply({
|
|
content: "Vous n'avez pas assez d'argent pour acheter cet item.",
|
|
ephemeral: true,
|
|
});
|
|
}
|
|
|
|
db.run(
|
|
`UPDATE users SET pocket = pocket - 2000, antiRob = ? WHERE guildId = ? AND userId = ?`,
|
|
[Date.now(), message.guild.id, message.author.id],
|
|
);
|
|
|
|
const embed = new EmbedBuilder()
|
|
.setTitle("🛍️ Shop")
|
|
.setDescription(
|
|
`Vous avez acheté l'item 🔒 AntiRob pour 2000 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 (selected === "key") {
|
|
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);
|
|
},
|
|
);
|
|
});
|
|
|
|
if (user.pocket < 2500) {
|
|
return interaction.reply({
|
|
content: "Vous n'avez pas assez d'argent pour acheter cet item.",
|
|
ephemeral: true,
|
|
});
|
|
}
|
|
|
|
db.run(
|
|
`UPDATE users SET pocket = pocket - 2500, key = key + 1 WHERE guildId = ? AND userId = ?`,
|
|
[message.guild.id, message.author.id],
|
|
);
|
|
|
|
const embed = new EmbedBuilder()
|
|
.setTitle("🛍️ Shop")
|
|
.setDescription(`Vous avez acheté l'item 🗝️ clef pour 2500 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 (selected === "coins") {
|
|
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);
|
|
},
|
|
);
|
|
});
|
|
|
|
if (user.reputation < 1) {
|
|
return interaction.reply({
|
|
content:
|
|
"Vous n'avez pas assez de reputation pour acheter cet item.",
|
|
ephemeral: true,
|
|
});
|
|
}
|
|
|
|
db.run(
|
|
`UPDATE users SET pocket = pocket + 25000, reputation = reputation - 1 WHERE guildId = ? AND userId = ?`,
|
|
[message.guild.id, message.author.id],
|
|
);
|
|
|
|
const embed = new EmbedBuilder()
|
|
.setTitle("🛍️ Shop")
|
|
.setDescription(
|
|
`Vous avez acheté \`25000\`coins contre une reputation !`,
|
|
)
|
|
.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 },
|
|
});
|
|
}
|
|
});
|
|
},
|
|
};
|