| import { |
| CommandInteraction, |
| DMChannel, |
| Message, |
| MessageActionRow, |
| MessageButton, |
| PartialGroupDMChannel, |
| TextChannel |
| } from "discord.js"; |
| import EmojiEmbed from "../utils/generateEmojiEmbed.js"; |
| import getEmojiByName from "../utils/getEmojiByName.js"; |
| import { PasteClient, Publicity, ExpireDate } from "pastebin-api"; |
| import config from "../config/main.json" assert { type: "json" }; |
| import client from "../utils/client.js"; |
| |
| const pbClient = new PasteClient(config.pastebinApiKey); |
| |
| export default async function (interaction: CommandInteraction) { |
| if (interaction.channel === null) return; |
| if (interaction.channel instanceof DMChannel) return; |
| const { log, NucleusColors, entry, renderUser, renderDelta } = client.logger; |
| |
| let messages: Message[] = []; |
| let deletedCount: number; |
| |
| do { |
| const fetched = await (interaction.channel as TextChannel).messages.fetch({ limit: 100 }); |
| const deleted = await (interaction.channel as TextChannel).bulkDelete(fetched, true); |
| deletedCount = deleted.size; |
| messages = messages.concat(Array.from(deleted.values())); |
| } while (deletedCount === 100); |
| |
| let out = ""; |
| messages.reverse().forEach((message) => { |
| if (!message.author.bot) { |
| const sentDate = new Date(message.createdTimestamp); |
| out += `${message.author.username}#${message.author.discriminator} (${ |
| message.author.id |
| }) [${sentDate.toUTCString()}]\n`; |
| const lines = message.content.split("\n"); |
| lines.forEach((line) => { |
| out += `> ${line}\n`; |
| }); |
| out += "\n\n"; |
| } |
| }); |
| const member = interaction.channel.guild.members.cache.get(interaction.channel.topic.split(" ")[0]); |
| let m; |
| if (out !== "") { |
| const url = await pbClient.createPaste({ |
| code: out, |
| expireDate: ExpireDate.Never, |
| name: `Ticket Transcript for ${member.user.username}#${member.user.discriminator} (Created at ${new Date( |
| interaction.channel.createdTimestamp |
| ).toDateString()})`, |
| publicity: Publicity.Unlisted |
| }); |
| const guildConfig = await client.database.guilds.read(interaction.guild.id); |
| m = await interaction.reply({ |
| embeds: [ |
| new EmojiEmbed() |
| .setTitle("Transcript") |
| .setDescription( |
| "You can view the transcript using the link below. You can save the link for later" + |
| (guildConfig.logging.logs.channel |
| ? ` or find it in <#${guildConfig.logging.logs.channel}> once you press delete below. After this the channel will be deleted.` |
| : ".") |
| ) |
| .setStatus("Success") |
| .setEmoji("CONTROL.DOWNLOAD") |
| ], |
| components: [ |
| new MessageActionRow().addComponents([ |
| new MessageButton().setLabel("View").setStyle("LINK").setURL(url), |
| new MessageButton() |
| .setLabel("Delete") |
| .setStyle("DANGER") |
| .setCustomId("close") |
| .setEmoji(getEmojiByName("CONTROL.CROSS", "id")) |
| ]) |
| ], |
| fetchReply: true |
| }); |
| } else { |
| m = await interaction.reply({ |
| embeds: [ |
| new EmojiEmbed() |
| .setTitle("Transcript") |
| .setDescription( |
| "The transcript was empty, so no changes were made. To delete this ticket, press the delete button below." |
| ) |
| .setStatus("Success") |
| .setEmoji("CONTROL.DOWNLOAD") |
| ], |
| components: [ |
| new MessageActionRow().addComponents([ |
| new MessageButton() |
| .setLabel("Delete") |
| .setStyle("DANGER") |
| .setCustomId("close") |
| .setEmoji(getEmojiByName("CONTROL.CROSS", "id")) |
| ]) |
| ], |
| fetchReply: true |
| }); |
| } |
| let i; |
| try { |
| i = await m.awaitMessageComponent({ time: 300000 }); |
| i.deferUpdate(); |
| } catch { |
| return; |
| } |
| const data = { |
| meta: { |
| type: "ticketDeleted", |
| displayName: "Ticket Deleted", |
| calculateType: "ticketUpdate", |
| color: NucleusColors.red, |
| emoji: "GUILD.TICKET.CLOSE", |
| timestamp: new Date().getTime() |
| }, |
| list: { |
| ticketFor: entry( |
| interaction.channel.topic.split(" ")[0], |
| renderUser((await interaction.guild.members.fetch(interaction.channel.topic.split(" ")[0])).user) |
| ), |
| deletedBy: entry(interaction.member.user.id, renderUser(interaction.member.user)), |
| deleted: entry(new Date().getTime(), renderDelta(new Date().getTime())) |
| }, |
| hidden: { |
| guild: interaction.guild.id |
| } |
| }; |
| log(data); |
| await interaction.channel.delete(); |
| return; |
| } |