Files
bot-discord-coins/commands/casino/sell.js
T
2024-06-24 00:32:05 +02:00

263 lines
8.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: ["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 },
});
}
});
},
};