2022-07-31 17:08:00 +05:00
|
|
|
const { SlashCommandBuilder, EmbedBuilder, ActionRowBuilder, SelectMenuBuilder, InteractionCollector } = require("discord.js");
|
2022-07-29 23:31:08 +05:00
|
|
|
const BaseCommand = require("../../base/BaseCommand"),
|
|
|
|
fetch = require("node-fetch");
|
|
|
|
|
|
|
|
class NSFW extends BaseCommand {
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param {import("../base/JaBa")} client
|
|
|
|
*/
|
|
|
|
constructor(client) {
|
|
|
|
super({
|
|
|
|
command: new SlashCommandBuilder()
|
|
|
|
.setName("nsfw")
|
|
|
|
.setDescription(client.translate("nsfw/nsfw:DESCRIPTION")),
|
|
|
|
aliases: [],
|
|
|
|
dirname: __dirname,
|
|
|
|
guildOnly: true,
|
|
|
|
ownerOnly: false
|
|
|
|
});
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param {import("../../base/JaBa")} client
|
|
|
|
*/
|
|
|
|
async onLoad() {
|
|
|
|
//...
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param {import("../../base/JaBa")} client
|
|
|
|
* @param {import("discord.js").CommandInteraction} interaction
|
|
|
|
* @param {Array} data
|
|
|
|
*/
|
|
|
|
async execute(client, interaction) {
|
|
|
|
if (!interaction.channel.nsfw) return interaction.replyT("misc:NSFW_COMMAND", null, { ephemeral: true });
|
|
|
|
|
|
|
|
const tags = ["hentai", "ecchi", "lewdanimegirls", "hentaifemdom", "animefeets", "animebooty", "biganimetiddies", "sideoppai", "ahegao"].map(tag =>
|
|
|
|
JSON.parse(JSON.stringify({
|
|
|
|
label: tag,
|
|
|
|
value: tag
|
|
|
|
}))
|
|
|
|
);
|
|
|
|
|
2022-07-31 17:08:00 +05:00
|
|
|
const row = new ActionRowBuilder()
|
2022-07-29 23:31:08 +05:00
|
|
|
.addComponents(
|
2022-07-31 17:08:00 +05:00
|
|
|
new SelectMenuBuilder()
|
2022-07-29 23:31:08 +05:00
|
|
|
.setCustomId("nsfw_select")
|
2022-07-31 17:08:00 +05:00
|
|
|
.setPlaceholder(client.translate("common:NOTHING_SELECTED"))
|
2022-07-29 23:31:08 +05:00
|
|
|
.addOptions(tags)
|
|
|
|
);
|
|
|
|
|
|
|
|
const msg = await interaction.reply({
|
2022-07-31 17:08:00 +05:00
|
|
|
content: interaction.translate("common:AVAILABLE_CATEGORIES"),
|
2022-07-29 23:31:08 +05:00
|
|
|
ephemeral: true,
|
2022-07-31 17:08:00 +05:00
|
|
|
components: [row],
|
|
|
|
fetchReply: true
|
2022-07-29 23:31:08 +05:00
|
|
|
});
|
|
|
|
|
|
|
|
const collector = new InteractionCollector(client, {
|
|
|
|
message: msg,
|
2022-07-31 17:08:00 +05:00
|
|
|
idle: 60 * 1000
|
2022-07-29 23:31:08 +05:00
|
|
|
});
|
|
|
|
|
|
|
|
collector.on("collect", async (msg) => {
|
|
|
|
const tag = msg?.values[0];
|
|
|
|
const res = await fetch(`https://meme-api.herokuapp.com/gimme/${tag}`).then(response => response.json());
|
|
|
|
|
2022-07-31 17:08:00 +05:00
|
|
|
const embed = new EmbedBuilder()
|
2022-07-29 23:31:08 +05:00
|
|
|
.setColor(client.config.embed.color)
|
|
|
|
.setFooter({
|
|
|
|
text: client.config.embed.footer
|
|
|
|
})
|
|
|
|
.setTitle(`${res.title}\n${interaction.translate("fun/memes:SUBREDDIT")}: ${res.subreddit}\n${interaction.translate("common:AUTHOR")}: ${res.author}\n${interaction.translate("fun/memes:UPS")}: ${res.ups}`)
|
|
|
|
.setImage(res.url)
|
|
|
|
.setTimestamp();
|
|
|
|
|
|
|
|
msg.update({
|
|
|
|
embeds: [embed]
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = NSFW;
|