Create use effect command #419
4 changed files with 94 additions and 28 deletions
|
@ -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");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
|||||||
}
|
}
|
||||||
|
|
||||||
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");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -118,4 +118,7 @@ export default class TimeLengthInput {
|
||||||
|
|
||||||
return desNumber;
|
return desNumber;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static ConvertFromMilliseconds(ms: number): TimeLengthInput {
|
||||||
Vylpes marked this conversation as resolved
VylpesTester
commented
I want tests generated for this I want tests generated for this
|
|||||||
|
}
|
||||||
}
|
}
|
Loading…
Reference in a new issue
I think we should log a warning in this case, since it shouldn't be possible