613 lines
22 KiB
TypeScript
613 lines
22 KiB
TypeScript
import {
|
|
ButtonBuilder,
|
|
ButtonStyle,
|
|
ActionRowBuilder,
|
|
EmbedBuilder,
|
|
GuildMember,
|
|
GuildTextBasedChannel,
|
|
} from "discord.js"
|
|
import { color } from "../../../config/options.json"
|
|
import { largeM, smallM, ignM } from "../../../config/limitmessages.json"
|
|
import { applicationsChannel } from "../../../config/options.json"
|
|
import questions from "../../../config/questions.json"
|
|
import { guildRole } from "../../../config/roles.json"
|
|
import { getUUID } from "../../utils/Hypixel"
|
|
import mongoose from "mongoose"
|
|
import guildapp from "../../schemas/guildAppSchema"
|
|
import { Button } from "../../interfaces"
|
|
|
|
export = {
|
|
name: "guildapply",
|
|
description: "Guild application button.",
|
|
type: "button",
|
|
|
|
async execute(interaction) {
|
|
const user = interaction.member as GuildMember
|
|
const guild = interaction.guild!
|
|
const embedColor = Number(color.replace("#", "0x"))
|
|
const userRoles = user.roles.cache.map(role => role.id)
|
|
const guildQuestions = questions.guild
|
|
|
|
function qu(n: number): string {
|
|
return guildQuestions[n - 1].q
|
|
}
|
|
|
|
function rq(n: number): string {
|
|
return guildQuestions[n - 1].r
|
|
}
|
|
|
|
if (interaction.customId === "guildapply") {
|
|
await interaction.deferReply({ ephemeral: true })
|
|
|
|
if (userRoles.includes(guildRole)) {
|
|
await interaction.editReply(
|
|
"You are already a member of the guild.",
|
|
)
|
|
return
|
|
}
|
|
|
|
const application = await guildapp.findOne({ userID: user.user.id })
|
|
|
|
if (application) {
|
|
await interaction.editReply(
|
|
"You already have an application in progress.",
|
|
)
|
|
return
|
|
}
|
|
|
|
const tooLong = new EmbedBuilder()
|
|
.setDescription("You took too long to respond.")
|
|
.setColor(embedColor)
|
|
const cancelled = new EmbedBuilder()
|
|
.setDescription("You have cancelled your application.")
|
|
.setColor(embedColor)
|
|
const attachments = new EmbedBuilder()
|
|
.setDescription(
|
|
"You have uploaded an attachment. Please do not upload images, videos, or GIFS.",
|
|
)
|
|
.setColor(embedColor)
|
|
|
|
try {
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
title: "Guild Application",
|
|
description:
|
|
"Please answer the following questions to apply for the guild.\n" +
|
|
"If you wish to cancel your application, please type `cancel` at any time.\n" +
|
|
"If you wish to proceed with your application, please type `yes`.\n\n" +
|
|
"**Do not upload images, videos, or GIFS.**\n" +
|
|
"You have a minute to respond to this message.",
|
|
color: embedColor,
|
|
},
|
|
],
|
|
})
|
|
} catch (error) {
|
|
await interaction.editReply("Please enable your DMs.")
|
|
return
|
|
}
|
|
|
|
await interaction.editReply("Please check your DMs.")
|
|
|
|
const input = await user.dmChannel!.awaitMessages({
|
|
filter: m => m.author.id === user.user.id,
|
|
max: 1,
|
|
time: 1000 * 60,
|
|
})
|
|
if (input.size === 0) {
|
|
await user.send({ embeds: [tooLong] })
|
|
return
|
|
}
|
|
if (input.first()!.content.toLowerCase() !== "yes") {
|
|
await user.send({ embeds: [cancelled] })
|
|
return
|
|
}
|
|
if (input.first()!.attachments.size > 0) {
|
|
await user.send({ embeds: [attachments] })
|
|
return
|
|
}
|
|
|
|
// first question
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
title: "**Question 1**",
|
|
description:
|
|
qu(1) +
|
|
"\n\nPlease type your answer below or type `cancel` to cancel your application.\n`" +
|
|
ignM +
|
|
"`",
|
|
color: embedColor,
|
|
footer: {
|
|
text: "You have 5 minutes to respond to this message.",
|
|
},
|
|
},
|
|
],
|
|
})
|
|
const answer1 = await user.dmChannel!.awaitMessages({
|
|
filter: m => m.author.id === user.user.id,
|
|
max: 1,
|
|
time: 1000 * 60 * 5,
|
|
})
|
|
if (answer1.size === 0) {
|
|
await user.send({ embeds: [tooLong] })
|
|
return
|
|
}
|
|
if (answer1.first()!.content.toLowerCase() === "cancel") {
|
|
await user.send({ embeds: [cancelled] })
|
|
return
|
|
}
|
|
if (answer1.first()!.attachments.size > 0) {
|
|
await user.send({ embeds: [attachments] })
|
|
return
|
|
}
|
|
if (answer1.first()!.content.length > 16) {
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
description: "Max character limit is 16.",
|
|
color: embedColor,
|
|
},
|
|
],
|
|
})
|
|
return
|
|
}
|
|
const uuid = await getUUID(answer1.first()!.content)
|
|
if (!uuid) {
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
description:
|
|
"That is not a valid Minecraft username.\n" +
|
|
"Application cancelled.",
|
|
color: embedColor,
|
|
},
|
|
],
|
|
})
|
|
return
|
|
}
|
|
const answer1_1 = answer1.first()!.content
|
|
|
|
// second question
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
title: "**Question 2**",
|
|
description:
|
|
qu(2) +
|
|
"\n\nPlease type your answer below or type `cancel` to cancel your application.\n" +
|
|
"`(8 characters max)`",
|
|
color: embedColor,
|
|
footer: {
|
|
text: "You have 15 minutes to respond to this message.",
|
|
},
|
|
},
|
|
],
|
|
})
|
|
const answer2 = await user.dmChannel!.awaitMessages({
|
|
filter: m => m.author.id === user.user.id,
|
|
max: 1,
|
|
time: 1000 * 60 * 15,
|
|
})
|
|
if (answer2.size === 0) {
|
|
await user.send({ embeds: [tooLong] })
|
|
return
|
|
}
|
|
if (answer2.first()!.content.toLowerCase() === "cancel") {
|
|
await user.send({ embeds: [cancelled] })
|
|
return
|
|
}
|
|
if (answer2.first()!.attachments.size > 0) {
|
|
await user.send({ embeds: [attachments] })
|
|
return
|
|
}
|
|
if (answer2.first()!.content.length > 8) {
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
description: "Max character limit is 8.",
|
|
color: embedColor,
|
|
},
|
|
],
|
|
})
|
|
return
|
|
}
|
|
const answer2_1 = answer2.first()!.content
|
|
|
|
// third question
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
title: "**Question 3**",
|
|
description:
|
|
qu(3) +
|
|
"\n\nPlease type your answer below or type `cancel` to cancel your application.\n`" +
|
|
smallM +
|
|
"`",
|
|
color: embedColor,
|
|
footer: {
|
|
text: "You have 15 minutes to respond to this message.",
|
|
},
|
|
},
|
|
],
|
|
})
|
|
const answer3 = await user.dmChannel!.awaitMessages({
|
|
filter: m => m.author.id === user.user.id,
|
|
max: 1,
|
|
time: 1000 * 60 * 15,
|
|
})
|
|
if (answer3.size === 0) {
|
|
await user.send({ embeds: [tooLong] })
|
|
return
|
|
}
|
|
if (answer3.first()!.content.toLowerCase() === "cancel") {
|
|
await user.send({ embeds: [cancelled] })
|
|
return
|
|
}
|
|
if (answer3.first()!.attachments.size > 0) {
|
|
await user.send({ embeds: [attachments] })
|
|
return
|
|
}
|
|
if (answer3.first()!.content.length > 128) {
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
description: "Max character limit is 128.",
|
|
color: embedColor,
|
|
},
|
|
],
|
|
})
|
|
}
|
|
const answer3_1 = answer3.first()!.content
|
|
|
|
// fourth question
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
title: "**Question 4**",
|
|
description:
|
|
qu(4) +
|
|
"\n\nPlease type your answer below or type `cancel` to cancel your application." +
|
|
" `(We expect a longer answer.)`\n`" +
|
|
largeM +
|
|
"`",
|
|
color: embedColor,
|
|
footer: {
|
|
text: "You have 15 minutes to respond to this message.",
|
|
},
|
|
},
|
|
],
|
|
})
|
|
const answer4 = await user.dmChannel!.awaitMessages({
|
|
filter: m => m.author.id === user.user.id,
|
|
max: 1,
|
|
time: 1000 * 60 * 15,
|
|
})
|
|
if (answer4.size === 0) {
|
|
await user.send({ embeds: [tooLong] })
|
|
return
|
|
}
|
|
if (answer4.first()!.content.toLowerCase() === "cancel") {
|
|
await user.send({ embeds: [cancelled] })
|
|
return
|
|
}
|
|
if (answer4.first()!.attachments.size > 0) {
|
|
await user.send({ embeds: [attachments] })
|
|
return
|
|
}
|
|
if (answer4.first()!.content.length > 256) {
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
description: "Max character limit is 256.",
|
|
color: embedColor,
|
|
},
|
|
],
|
|
})
|
|
}
|
|
const answer4_1 = answer4.first()!.content
|
|
|
|
// fifth question
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
title: "**Question 5**",
|
|
description:
|
|
qu(5) +
|
|
"\n\nPlease type your answer below or type `cancel` to cancel your application.\n`" +
|
|
smallM +
|
|
"`",
|
|
color: embedColor,
|
|
footer: {
|
|
text: "You have 15 minutes to respond to this message.",
|
|
},
|
|
},
|
|
],
|
|
})
|
|
const answer5 = await user.dmChannel!.awaitMessages({
|
|
filter: m => m.author.id === user.user.id,
|
|
max: 1,
|
|
time: 1000 * 60 * 15,
|
|
})
|
|
if (answer5.size === 0) {
|
|
await user.send({ embeds: [tooLong] })
|
|
return
|
|
}
|
|
if (answer5.first()!.content.toLowerCase() === "cancel") {
|
|
await user.send({ embeds: [cancelled] })
|
|
return
|
|
}
|
|
if (answer5.first()!.attachments.size > 0) {
|
|
await user.send({ embeds: [attachments] })
|
|
return
|
|
}
|
|
if (answer5.first()!.content.length > 128) {
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
description: "Max character limit is 128.",
|
|
color: embedColor,
|
|
},
|
|
],
|
|
})
|
|
}
|
|
const answer5_1 = answer5.first()!.content
|
|
|
|
// sixth question
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
title: "**Question 6**",
|
|
description:
|
|
qu(6) +
|
|
"\n\nPlease type your answer below or type `cancel` to cancel your application.\n`" +
|
|
largeM +
|
|
"`",
|
|
color: embedColor,
|
|
footer: {
|
|
text: "You have 15 minutes to respond to this message.",
|
|
},
|
|
},
|
|
],
|
|
})
|
|
const answer6 = await user.dmChannel!.awaitMessages({
|
|
filter: m => m.author.id === user.user.id,
|
|
max: 1,
|
|
time: 1000 * 60 * 15,
|
|
})
|
|
if (answer6.size === 0) {
|
|
await user.send({ embeds: [tooLong] })
|
|
return
|
|
}
|
|
if (answer6.first()!.content.toLowerCase() === "cancel") {
|
|
await user.send({ embeds: [cancelled] })
|
|
return
|
|
}
|
|
if (answer6.first()!.attachments.size > 0) {
|
|
await user.send({ embeds: [attachments] })
|
|
return
|
|
}
|
|
if (answer6.first()!.content.length > 256) {
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
description: "Max character limit is 256.",
|
|
color: embedColor,
|
|
},
|
|
],
|
|
})
|
|
}
|
|
const answer6_1 = answer6.first()!.content
|
|
|
|
// seventh question
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
title: "**Question 7**",
|
|
description:
|
|
qu(7) +
|
|
"\n\nPlease type your answer below or type `cancel` to cancel your application.\n`" +
|
|
smallM +
|
|
"`",
|
|
color: embedColor,
|
|
footer: {
|
|
text: "You have 15 minutes to respond to this message.",
|
|
},
|
|
},
|
|
],
|
|
})
|
|
const answer7 = await user.dmChannel!.awaitMessages({
|
|
filter: m => m.author.id === user.user.id,
|
|
max: 1,
|
|
time: 1000 * 60 * 15,
|
|
})
|
|
if (answer7.size === 0) {
|
|
await user.send({ embeds: [tooLong] })
|
|
return
|
|
}
|
|
if (answer7.first()!.content.toLowerCase() === "cancel") {
|
|
await user.send({ embeds: [cancelled] })
|
|
return
|
|
}
|
|
if (answer7.first()!.attachments.size > 0) {
|
|
await user.send({ embeds: [attachments] })
|
|
return
|
|
}
|
|
if (answer7.first()!.content.length > 128) {
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
description: "Max character limit is 128.",
|
|
color: embedColor,
|
|
},
|
|
],
|
|
})
|
|
}
|
|
const answer7_1 = answer7!.first()!.content
|
|
|
|
// eighth question
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
title: "**Question 8**",
|
|
description:
|
|
qu(8) +
|
|
"\n\nPlease type your answer below or type `cancel` to cancel your application.\n" +
|
|
"`(64 characters max)`",
|
|
color: embedColor,
|
|
footer: {
|
|
text: "You have 15 minutes to respond to this message.",
|
|
},
|
|
},
|
|
],
|
|
})
|
|
const answer8 = await user.dmChannel!.awaitMessages({
|
|
filter: m => m.author.id === user.user.id,
|
|
max: 1,
|
|
time: 1000 * 60 * 15,
|
|
})
|
|
if (answer8.size === 0) {
|
|
await user.send({ embeds: [tooLong] })
|
|
return
|
|
}
|
|
if (answer8.first()!.content.toLowerCase() === "cancel") {
|
|
await user.send({ embeds: [cancelled] })
|
|
return
|
|
}
|
|
if (answer8.first()!.attachments.size > 0) {
|
|
await user.send({ embeds: [attachments] })
|
|
return
|
|
}
|
|
if (answer8.first()!.content.length > 64) {
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
description: "Max character limit is 64.",
|
|
color: embedColor,
|
|
},
|
|
],
|
|
})
|
|
}
|
|
const answer8_1 = answer8.first()!.content
|
|
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
description:
|
|
"If you want to submit your application, type `yes` if not, type `no`",
|
|
color: embedColor,
|
|
},
|
|
],
|
|
})
|
|
|
|
const final = await user.dmChannel!.awaitMessages({
|
|
filter: m => m.author.id === user.user.id,
|
|
max: 1,
|
|
time: 1000 * 60 * 5,
|
|
})
|
|
if (final.size === 0) {
|
|
await user.send({ embeds: [tooLong] })
|
|
return
|
|
}
|
|
if (final.first()!.content.toLowerCase() !== "yes") {
|
|
await user.send({ embeds: [cancelled] })
|
|
return
|
|
}
|
|
if (final.first()!.attachments.size > 0) {
|
|
await user.send({ embeds: [attachments] })
|
|
return
|
|
}
|
|
|
|
await user.send({
|
|
embeds: [
|
|
{
|
|
description: "Your application has been submitted!",
|
|
color: embedColor,
|
|
},
|
|
],
|
|
})
|
|
|
|
const newGuildApp = new guildapp({
|
|
_id: new mongoose.Types.ObjectId(),
|
|
userID: user.user.id,
|
|
uuid: uuid,
|
|
})
|
|
|
|
await newGuildApp.save()
|
|
|
|
const channel = guild.channels.cache.get(
|
|
applicationsChannel,
|
|
) as GuildTextBasedChannel
|
|
await channel.send({
|
|
embeds: [
|
|
{
|
|
title:
|
|
user.user.username +
|
|
"#" +
|
|
user.user.discriminator +
|
|
" - Guild Application",
|
|
color: embedColor,
|
|
thumbnail: {
|
|
url: user.avatarURL() || guild.iconURL()!,
|
|
},
|
|
fields: [
|
|
{
|
|
name: rq(1),
|
|
value: "```" + answer1_1 + "```",
|
|
},
|
|
{
|
|
name: rq(2),
|
|
value: "```" + answer2_1 + "```",
|
|
},
|
|
{
|
|
name: rq(3),
|
|
value: "```" + answer3_1 + "```",
|
|
},
|
|
{
|
|
name: rq(4),
|
|
value: "```" + answer4_1 + "```",
|
|
},
|
|
{
|
|
name: rq(5),
|
|
value: "```" + answer5_1 + "```",
|
|
},
|
|
{
|
|
name: rq(6),
|
|
value: "```" + answer6_1 + "```",
|
|
},
|
|
{
|
|
name: rq(7),
|
|
value: "```" + answer7_1 + "```",
|
|
},
|
|
{
|
|
name: rq(8),
|
|
value: "```" + answer8_1 + "```",
|
|
},
|
|
],
|
|
footer: {
|
|
icon_url: guild.iconURL()!,
|
|
text: "ID: " + user.user.id,
|
|
},
|
|
},
|
|
],
|
|
components: [
|
|
new ActionRowBuilder<ButtonBuilder>().addComponents(
|
|
new ButtonBuilder()
|
|
.setCustomId("guildapplicationaccept")
|
|
.setLabel("Accept")
|
|
.setStyle(ButtonStyle.Primary),
|
|
new ButtonBuilder()
|
|
.setCustomId("guildapplicationdeny")
|
|
.setLabel("Deny")
|
|
.setStyle(ButtonStyle.Danger),
|
|
new ButtonBuilder()
|
|
.setCustomId("checkstats")
|
|
.setLabel("Check Stats")
|
|
.setStyle(ButtonStyle.Secondary),
|
|
),
|
|
],
|
|
})
|
|
}
|
|
},
|
|
} as Button
|