Create use effect command #419

Open
Vylpes wants to merge 26 commits from feature/380-use-effect into develop
4 changed files with 94 additions and 28 deletions
Showing only changes of commit d874cb7a12 - Show all commits

View file

@ -1,6 +1,7 @@
import {ButtonInteraction} from "discord.js"; import {ButtonInteraction,EmbedBuilder} from "discord.js";
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";
export default class Effects extends ButtonEvent { export default class Effects extends ButtonEvent {
public override async execute(interaction: ButtonInteraction) { public override async execute(interaction: ButtonInteraction) {
@ -10,6 +11,9 @@ export default class Effects extends ButtonEvent {
case "list": case "list":
await this.List(interaction); await this.List(interaction);
break; break;
case "use":
await this.Use(interaction);
break;
} }
} }
@ -30,4 +34,53 @@ export default class Effects extends ButtonEvent {
components: [ result.row ], components: [ result.row ],
}); });
} }
private async Use(interaction: ButtonInteraction) {
const subaction = interaction.customId.split(" ")[2];
switch (subaction) {
case "confirm":
await this.UseConfirm(interaction);
break;
}
}
private async UseConfirm(interaction: ButtonInteraction) {
const id = interaction.customId.split(" ")[3];
const effectDetail = EffectDetails.get(id);
if (!effectDetail) {
await interaction.reply("Unable to find effect!");
return;
}
const now = new Date();
const whenExpires = new Date(now.getMilliseconds() + effectDetail.duration);
const result = await EffectHelper.UseEffect(interaction.user.id, id, whenExpires);
if (result) {
const embed = new EmbedBuilder()
.setTitle("Effect Used")
.setDescription("You now have an active effect!")
.addFields([
{
name: "Effect",
value: effectDetail.friendlyName,
inline: true,
},
{
name: "Expires",
value: `<t:${whenExpires.getMilliseconds()}:f>`,
inline: true,
},
]);
await interaction.update({ embeds: [ embed ] });
return;
}
await interaction.reply("Unable to use effect! Please make sure you have it in your inventory and is not on cooldown");
}
} }

View file

@ -2,6 +2,7 @@ import {CommandInteraction, EmbedBuilder, SlashCommandBuilder} from "discord.js"
import {Command} from "../type/command"; import {Command} from "../type/command";
import EffectHelper from "../helpers/EffectHelper"; import EffectHelper from "../helpers/EffectHelper";
import {EffectDetails} from "../constants/EffectDetails"; import {EffectDetails} from "../constants/EffectDetails";
import UserEffect from "../database/entities/app/UserEffect";
export default class Effects extends Command { export default class Effects extends Command {
constructor() { constructor() {
@ -67,15 +68,16 @@ export default class Effects extends Command {
return; return;
Vylpes marked this conversation as resolved
Review

I think we should log a warning in this case, since it shouldn't be possible

I think we should log a warning in this case, since it shouldn't be possible
} }
const now = new Date(); const canUseEffect = await EffectHelper.CanUseEffect(interaction.user.id, id)
const whenExpires = new Date(now.getMilliseconds() + effectDetail.duration);
const result = await EffectHelper.UseEffect(interaction.user.id, id, whenExpires); if (!canUseEffect) {
await interaction.reply("Unable to use effect! Please make sure you have it in your inventory and is not on cooldown");
return;
}
if (result) {
const embed = new EmbedBuilder() const embed = new EmbedBuilder()
.setTitle("Effect Used") .setTitle("Effect Confirmation")
.setDescription("You now have an active effect!") .setDescription("Would you like to use this effect?")
.addFields([ .addFields([
{ {
name: "Effect", name: "Effect",
@ -83,16 +85,12 @@ export default class Effects extends Command {
inline: true, inline: true,
}, },
{ {
name: "Expires", name: "Length",
value: `<t:${whenExpires.getMilliseconds()}:f>`, value: "",
inline: true, inline: true,
}, },
]); ]);
await interaction.reply({ embeds: [ embed ] }); await interaction.reply({ embeds: [ embed ] });
return;
}
await interaction.reply("Unable to use effect! Please make sure you have it in your inventory and is not on cooldown");
} }
} }

View file

@ -17,6 +17,22 @@ export default class EffectHelper {
} }
public static async UseEffect(userId: string, name: string, whenExpires: Date): Promise<boolean> { public static async UseEffect(userId: string, name: string, whenExpires: Date): Promise<boolean> {
const canUseEffect = await this.CanUseEffect(userId, name);
if (!canUseEffect) return false;
const effect = await UserEffect.FetchOneByUserIdAndName(userId, name);
if (!effect) return false;
effect.UseEffect(whenExpires);
await effect.Save(UserEffect, effect);
return true;
}
public static async CanUseEffect(userId: string, name: string): Promise<boolean> {
const effect = await UserEffect.FetchOneByUserIdAndName(userId, name); const effect = await UserEffect.FetchOneByUserIdAndName(userId, name);
const now = new Date(); const now = new Date();
@ -34,10 +50,6 @@ export default class EffectHelper {
return false; return false;
} }
effect.UseEffect(whenExpires);
await effect.Save(UserEffect, effect);
return true; return true;
} }

View file

@ -118,4 +118,7 @@ export default class TimeLengthInput {
return desNumber; return desNumber;
} }
public static ConvertFromMilliseconds(ms: number): TimeLengthInput {
Vylpes marked this conversation as resolved
Review

I want tests generated for this

I want tests generated for this
}
} }