Hezaerd
DIdiscord.js - Imagine ❄
•Created by Hezaerd on 6/30/2024 in #djs-questions
"chained" StringSelect
Hi, is there anyway to send a message with a default embed + a select component, and depend of the select interaction, edit the embed.
For now I've achieved to do it once
But it only work the first time, after what the interaction keep failing even if I don't have error in my console
export async function run({ interaction }: SlashCommandProps) {
const user: User = interaction.options.getUser("user") || interaction.user;
const selectOptions = [
{
label: "Profile",
value: "1",
description: "Show your profile",
},
{
label: "Stats",
value: "2",
description: "Show your stats",
},
];
const selectMenu = new StringSelectMenuBuilder()
.setCustomId(interaction.id)
.setPlaceholder("Select a category")
.setMinValues(1)
.setMaxValues(1)
.addOptions(
selectOptions.map((option) =>
new StringSelectMenuOptionBuilder()
.setLabel(option.label)
.setValue(option.value)
.setDescription(option.description)
)
);
const actionRow = new ActionRowBuilder().addComponents(selectMenu);
const reply = await interaction.reply({
embeds: [getProfileEmbed(interaction)],
components: [actionRow],
});
const collector = reply.createMessageComponentCollector({
componentType: ComponentType.StringSelect,
filter: (i) => i.user.id === user.id && i.customId === interaction.id,
});
collector.on("collect", async (i) => {
const value = i.values[0];
if (value === "1") {
console.log(`${user.username} selected profile`);
reply.edit({
embeds: [getProfileEmbed(interaction)],
components: [actionRow],
});
} else if (value === "2") {
console.log(`${user.username} selected stats`);
reply.edit({
embeds: [getStatsEmbed(interaction)],
components: [actionRow],
});
}
});
}
function getProfileEmbed(interaction: ChatInputCommandInteraction): Embed {
const profileEmbed = new EmbedBuilder();
profileEmbed.setTitle(`${interaction.user.username}'s profile`);
profileEmbed.setColor(0x9b59b6);
profileEmbed.setTimestamp(new Date().getTime());
return profileEmbed;
}
function getStatsEmbed(interaction: ChatInputCommandInteraction): Embed {
const statsEmbed = new EmbedBuilder();
statsEmbed.setTitle(`${interaction.user.username}'s stats`);
statsEmbed.setColor(0x9b59b6);
statsEmbed.setTimestamp(new Date().getTime());
return statsEmbed;
}
export async function run({ interaction }: SlashCommandProps) {
const user: User = interaction.options.getUser("user") || interaction.user;
const selectOptions = [
{
label: "Profile",
value: "1",
description: "Show your profile",
},
{
label: "Stats",
value: "2",
description: "Show your stats",
},
];
const selectMenu = new StringSelectMenuBuilder()
.setCustomId(interaction.id)
.setPlaceholder("Select a category")
.setMinValues(1)
.setMaxValues(1)
.addOptions(
selectOptions.map((option) =>
new StringSelectMenuOptionBuilder()
.setLabel(option.label)
.setValue(option.value)
.setDescription(option.description)
)
);
const actionRow = new ActionRowBuilder().addComponents(selectMenu);
const reply = await interaction.reply({
embeds: [getProfileEmbed(interaction)],
components: [actionRow],
});
const collector = reply.createMessageComponentCollector({
componentType: ComponentType.StringSelect,
filter: (i) => i.user.id === user.id && i.customId === interaction.id,
});
collector.on("collect", async (i) => {
const value = i.values[0];
if (value === "1") {
console.log(`${user.username} selected profile`);
reply.edit({
embeds: [getProfileEmbed(interaction)],
components: [actionRow],
});
} else if (value === "2") {
console.log(`${user.username} selected stats`);
reply.edit({
embeds: [getStatsEmbed(interaction)],
components: [actionRow],
});
}
});
}
function getProfileEmbed(interaction: ChatInputCommandInteraction): Embed {
const profileEmbed = new EmbedBuilder();
profileEmbed.setTitle(`${interaction.user.username}'s profile`);
profileEmbed.setColor(0x9b59b6);
profileEmbed.setTimestamp(new Date().getTime());
return profileEmbed;
}
function getStatsEmbed(interaction: ChatInputCommandInteraction): Embed {
const statsEmbed = new EmbedBuilder();
statsEmbed.setTitle(`${interaction.user.username}'s stats`);
statsEmbed.setColor(0x9b59b6);
statsEmbed.setTimestamp(new Date().getTime());
return statsEmbed;
}
3 replies