2023-09-05 20:05:29 +01:00
|
|
|
import { ActionRowBuilder, AttachmentBuilder, ButtonBuilder, ButtonStyle, CommandInteraction, DiscordAPIError, EmbedBuilder, SlashCommandBuilder } from "discord.js";
|
2023-09-03 20:27:29 +01:00
|
|
|
import { Command } from "../type/command";
|
|
|
|
import CardDropHelper from "../helpers/CardDropHelper";
|
|
|
|
import { CardRarityToColour, CardRarityToString } from "../constants/CardRarity";
|
|
|
|
import { readFileSync } from "fs";
|
|
|
|
import { CoreClient } from "../client/client";
|
|
|
|
import { v4 } from "uuid";
|
2023-09-05 20:45:33 +01:00
|
|
|
import Card from "../database/entities/card/Card";
|
2023-10-20 17:33:22 +01:00
|
|
|
import Inventory from "../database/entities/app/Inventory";
|
2023-09-03 20:27:29 +01:00
|
|
|
|
|
|
|
export default class Drop extends Command {
|
|
|
|
constructor() {
|
|
|
|
super();
|
|
|
|
|
|
|
|
super.CommandBuilder = new SlashCommandBuilder()
|
|
|
|
.setName('drop')
|
|
|
|
.setDescription('Summon a new card drop');
|
|
|
|
}
|
|
|
|
|
|
|
|
public override async execute(interaction: CommandInteraction) {
|
2023-09-05 19:34:25 +01:00
|
|
|
let randomCard = await CardDropHelper.GetRandomCard();
|
|
|
|
|
|
|
|
if (process.env.DROP_RARITY && Number(process.env.DROP_RARITY) > 0) {
|
|
|
|
randomCard = await CardDropHelper.GetRandomCardByRarity(Number(process.env.DROP_RARITY));
|
2023-09-05 20:45:33 +01:00
|
|
|
} else if (process.env.DROP_CARD && process.env.DROP_CARD != '-1') {
|
|
|
|
let card = await Card.FetchOneByCardNumber(process.env.DROP_CARD, [ "Series" ]);
|
|
|
|
|
|
|
|
if (!card) {
|
|
|
|
await interaction.reply("Card not found");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
randomCard = card;
|
2023-09-05 19:34:25 +01:00
|
|
|
}
|
2023-09-03 20:27:29 +01:00
|
|
|
|
|
|
|
const image = readFileSync(randomCard.Path);
|
|
|
|
|
2023-09-04 13:02:02 +01:00
|
|
|
await interaction.deferReply();
|
|
|
|
|
|
|
|
const attachment = new AttachmentBuilder(image, { name: randomCard.FileName });
|
2023-09-03 20:27:29 +01:00
|
|
|
|
2023-10-20 17:33:22 +01:00
|
|
|
const inventory = await Inventory.FetchOneByCardNumberAndUserId(interaction.user.id, randomCard.CardNumber);
|
|
|
|
const quantityClaimed = inventory ? inventory.Quantity : 0;
|
|
|
|
|
|
|
|
let embedDescription = "";
|
|
|
|
embedDescription += `Series: ${randomCard.Series.Name}\n`;
|
|
|
|
embedDescription += `Claimed: ${quantityClaimed || 0}\n`;
|
|
|
|
|
2023-09-03 20:27:29 +01:00
|
|
|
const embed = new EmbedBuilder()
|
|
|
|
.setTitle(randomCard.Name)
|
2023-10-20 17:33:22 +01:00
|
|
|
.setDescription(embedDescription)
|
2023-09-03 20:27:29 +01:00
|
|
|
.setFooter({ text: CardRarityToString(randomCard.Rarity) })
|
|
|
|
.setColor(CardRarityToColour(randomCard.Rarity))
|
2023-09-04 13:02:02 +01:00
|
|
|
.setImage(`attachment://${randomCard.FileName}`);
|
2023-09-03 20:27:29 +01:00
|
|
|
|
|
|
|
const row = new ActionRowBuilder<ButtonBuilder>();
|
|
|
|
|
|
|
|
const claimId = v4();
|
|
|
|
|
|
|
|
row.addComponents(
|
|
|
|
new ButtonBuilder()
|
2023-09-13 15:06:53 +01:00
|
|
|
.setCustomId(`claim ${randomCard.CardNumber} ${claimId} ${interaction.user.id}`)
|
2023-09-03 20:27:29 +01:00
|
|
|
.setLabel("Claim")
|
|
|
|
.setStyle(ButtonStyle.Primary),
|
|
|
|
new ButtonBuilder()
|
|
|
|
.setCustomId(`reroll`)
|
|
|
|
.setLabel("Reroll")
|
|
|
|
.setStyle(ButtonStyle.Secondary));
|
|
|
|
|
2023-09-05 20:05:29 +01:00
|
|
|
try {
|
|
|
|
await interaction.editReply({
|
|
|
|
embeds: [ embed ],
|
|
|
|
files: [ attachment ],
|
|
|
|
components: [ row ],
|
|
|
|
});
|
|
|
|
} catch (e) {
|
|
|
|
console.error(e);
|
|
|
|
|
|
|
|
|
|
|
|
if (e instanceof DiscordAPIError) {
|
|
|
|
await interaction.editReply(`Unable to send next drop. Please try again, and report this if it keeps happening. Code: ${e.code}`);
|
|
|
|
} else {
|
|
|
|
await interaction.editReply(`Unable to send next drop. Please try again, and report this if it keeps happening. Code: UNKNOWN`);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-09-03 20:27:29 +01:00
|
|
|
CoreClient.ClaimId = claimId;
|
|
|
|
}
|
|
|
|
}
|