Create use effect command #419

Merged
Vylpes merged 26 commits from feature/380-use-effect into develop 2025-01-25 17:29:01 +00:00
2 changed files with 81 additions and 3 deletions
Showing only changes of commit dd1f259170 - Show all commits

View file

@ -1,7 +1,9 @@
import {ButtonInteraction,EmbedBuilder} from "discord.js"; import {ActionRowBuilder, ButtonBuilder, ButtonInteraction,ButtonStyle,Embed,EmbedBuilder} from "discord.js";
Vylpes marked this conversation as resolved Outdated

Fix spacing

Fix spacing
import {ButtonEvent} from "../type/buttonEvent"; import {ButtonEvent} from "../type/buttonEvent";
import EffectHelper from "../helpers/EffectHelper"; import EffectHelper from "../helpers/EffectHelper";
import { EffectDetails } from "../constants/EffectDetails"; import { EffectDetails } from "../constants/EffectDetails";
import TimeLengthInput from "../helpers/TimeLengthInput";
import EmbedColours from "../constants/EmbedColours";
export default class Effects extends ButtonEvent { export default class Effects extends ButtonEvent {
public override async execute(interaction: ButtonInteraction) { public override async execute(interaction: ButtonInteraction) {
@ -42,6 +44,9 @@ export default class Effects extends ButtonEvent {
case "confirm": case "confirm":
await this.UseConfirm(interaction); await this.UseConfirm(interaction);
break; break;
case "cancel":
await this.UseCancel(interaction);
break;
} }
} }
@ -64,6 +69,7 @@ export default class Effects extends ButtonEvent {
const embed = new EmbedBuilder() const embed = new EmbedBuilder()
.setTitle("Effect Used") .setTitle("Effect Used")
.setDescription("You now have an active effect!") .setDescription("You now have an active effect!")
.setColor(EmbedColours.Green)
.addFields([ .addFields([
{ {
name: "Effect", name: "Effect",
@ -77,10 +83,76 @@ export default class Effects extends ButtonEvent {
}, },
]); ]);
await interaction.update({ embeds: [ embed ] }); const row = new ActionRowBuilder<ButtonBuilder>()
.addComponents([
new ButtonBuilder()
.setLabel("Confirm")
.setCustomId(`effects use confirm ${effectDetail.id}`)
.setStyle(ButtonStyle.Primary)
.setDisabled(true),
new ButtonBuilder()
.setLabel("Cancel")
.setCustomId(`effects use cancel ${effectDetail.id}`)
.setStyle(ButtonStyle.Danger)
.setDisabled(true),
]);
await interaction.update({
embeds: [ embed ],
components: [ row ],
});
return; return;
} }
await interaction.reply("Unable to use effect! Please make sure you have it in your inventory and is not on cooldown"); await interaction.reply("Unable to use effect! Please make sure you have it in your inventory and is not on cooldown");
} }
private async UseCancel(interaction: ButtonInteraction) {
const id = interaction.customId.split(" ")[3];
Vylpes marked this conversation as resolved Outdated

I don't like that thats public

I don't like that thats public
const effectDetail = EffectDetails.get(id);
if (!effectDetail) {
await interaction.reply("Unable to find effect!");
return;
Vylpes marked this conversation as resolved Outdated

The error message 'Unable to find effect!' is unclear. It should be 'Effect not found in the system!'.

The error message 'Unable to find effect!' is unclear. It should be 'Effect not found in the system!'.
}
const timeLengthInput = TimeLengthInput.ConvertFromMilliseconds(effectDetail.duration);
const embed = new EmbedBuilder()
.setTitle("Effect Use Cancelled")
.setDescription("The effect from your inventory has not been used")
.setColor(EmbedColours.Grey)
.addFields([
{
name: "Effect",
value: effectDetail.friendlyName,
inline: true,
},
{
name: "Expires",
value: timeLengthInput.GetLengthShort(),
inline: true,
},
]);
const row = new ActionRowBuilder<ButtonBuilder>()
.addComponents([
new ButtonBuilder()
.setLabel("Confirm")
.setCustomId(`effects use confirm ${effectDetail.id}`)
.setStyle(ButtonStyle.Primary)
.setDisabled(true),
new ButtonBuilder()
.setLabel("Cancel")
.setCustomId(`effects use cancel ${effectDetail.id}`)
.setStyle(ButtonStyle.Danger)
.setDisabled(true),
]);
await interaction.update({
embeds: [ embed ],
components: [ row ],
});
}
} }

View file

@ -4,6 +4,7 @@ import EffectHelper from "../helpers/EffectHelper";
import {EffectDetails} from "../constants/EffectDetails"; import {EffectDetails} from "../constants/EffectDetails";
import UserEffect from "../database/entities/app/UserEffect"; import UserEffect from "../database/entities/app/UserEffect";
import TimeLengthInput from "../helpers/TimeLengthInput"; import TimeLengthInput from "../helpers/TimeLengthInput";
import EmbedColours from "../constants/EmbedColours";
export default class Effects extends Command { export default class Effects extends Command {
constructor() { constructor() {
@ -81,6 +82,7 @@ export default class Effects extends Command {
const embed = new EmbedBuilder() const embed = new EmbedBuilder()
.setTitle("Effect Confirmation") .setTitle("Effect Confirmation")
.setDescription("Would you like to use this effect?") .setDescription("Would you like to use this effect?")
.setColor(EmbedColours.Ok)
.addFields([ .addFields([
{ {
name: "Effect", name: "Effect",
@ -100,6 +102,10 @@ export default class Effects extends Command {
.setLabel("Confirm") .setLabel("Confirm")
.setCustomId(`effects use confirm ${effectDetail.id}`) .setCustomId(`effects use confirm ${effectDetail.id}`)
.setStyle(ButtonStyle.Primary), .setStyle(ButtonStyle.Primary),
new ButtonBuilder()
.setLabel("Cancel")
.setCustomId(`effects use cancel ${effectDetail.id}`)
.setStyle(ButtonStyle.Danger),
]); ]);
await interaction.reply({ await interaction.reply({