mirror of
https://github.com/Hessenuk/DiscordTickets.git
synced 2025-09-02 16:41:25 +03:00
progress
This commit is contained in:
@@ -20,6 +20,8 @@ module.exports = {
|
||||
args: true,
|
||||
async execute(client, message, args, Ticket) {
|
||||
|
||||
const guild = client.guilds.cache.get(config.guild);
|
||||
|
||||
const notTicket = new Discord.MessageEmbed()
|
||||
.setColor(config.err_colour)
|
||||
.setAuthor(message.author.username, message.author.displayAvatarURL())
|
||||
@@ -27,7 +29,7 @@ module.exports = {
|
||||
.setDescription('Use this command in the ticket channel you want to add a user to, or mention the channel.')
|
||||
.addField('Usage', `\`${config.prefix}${this.name} ${this.usage}\`\n`)
|
||||
.addField('Help', `Type \`${config.prefix}help ${this.name}\` for more information`)
|
||||
.setFooter(message.guild.name, message.guild.iconURL());
|
||||
.setFooter(guild.name, guild.iconURL());
|
||||
|
||||
let ticket;
|
||||
|
||||
@@ -60,12 +62,12 @@ module.exports = {
|
||||
.setDescription(`You don't have permission to alter ${channel} as it does not belong to you and you are not staff.`)
|
||||
.addField('Usage', `\`${config.prefix}${this.name} ${this.usage}\`\n`)
|
||||
.addField('Help', `Type \`${config.prefix}help ${this.name}\` for more information`)
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
|
||||
|
||||
|
||||
let member = message.guild.member(message.mentions.users.first() || message.guild.members.cache.get(args[0]));
|
||||
let member = guild.member(message.mentions.users.first() || guild.members.cache.get(args[0]));
|
||||
|
||||
if(!member)
|
||||
return message.channel.send(
|
||||
@@ -76,7 +78,7 @@ module.exports = {
|
||||
.setDescription('Please mention a valid member.')
|
||||
.addField('Usage', `\`${config.prefix}${this.name} ${this.usage}\`\n`)
|
||||
.addField('Help', `Type \`${config.prefix}help ${this.name}\` for more information`)
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
|
||||
try {
|
||||
@@ -94,7 +96,7 @@ module.exports = {
|
||||
.setAuthor(member.user.username, member.user.displayAvatarURL())
|
||||
.setTitle('**Member added**')
|
||||
.setDescription(`${member} has been added by ${message.author}`)
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
|
||||
|
||||
@@ -105,7 +107,7 @@ module.exports = {
|
||||
.setAuthor(member.user.username, member.user.displayAvatarURL())
|
||||
.setTitle(':white_check_mark: **Member added**')
|
||||
.setDescription(`${member} has been added to <#${ticket.get('channel')}>`)
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
|
||||
log.info(`${message.author.tag} added a user to a ticket (#${message.channel.id})`);
|
||||
|
@@ -10,6 +10,7 @@ const ChildLogger = require('leekslazylogger').ChildLogger;
|
||||
const log = new ChildLogger();
|
||||
const Discord = require('discord.js');
|
||||
const config = require('../../user/config');
|
||||
const fs = require('fs');
|
||||
|
||||
module.exports = {
|
||||
name: 'close',
|
||||
@@ -19,6 +20,8 @@ module.exports = {
|
||||
example: 'close #ticket-17',
|
||||
args: false,
|
||||
async execute(client, message, args, Ticket) {
|
||||
|
||||
const guild = client.guilds.cache.get(config.guild);
|
||||
|
||||
const notTicket = new Discord.MessageEmbed()
|
||||
.setColor(config.err_colour)
|
||||
@@ -27,30 +30,18 @@ module.exports = {
|
||||
.setDescription('Use this command in the ticket channel you want to close, or mention the channel.')
|
||||
.addField('Usage', `\`${config.prefix}${this.name} ${this.usage}\`\n`)
|
||||
.addField('Help', `Type \`${config.prefix}help ${this.name}\` for more information`)
|
||||
.setFooter(message.guild.name, message.guild.iconURL());
|
||||
.setFooter(guild.name, guild.iconURL());
|
||||
|
||||
let ticket;
|
||||
const channel = message.mentions.channels.first();
|
||||
// let channel = message.guild.channels.resolve(message.mentions.channels.first()); // not necessary
|
||||
let channel = message.mentions.channels.first();
|
||||
// || client.channels.resolve(await Ticket.findOne({ where: { id: args[0] } }).channel) // channels.fetch()
|
||||
|
||||
if(!channel) {
|
||||
channel = message.channel;
|
||||
|
||||
ticket = await Ticket.findOne({ where: { channel: message.channel.id } });
|
||||
ticket = await Ticket.findOne({ where: { channel: channel.id } });
|
||||
if(!ticket)
|
||||
return message.channel.send(notTicket);
|
||||
|
||||
ticket.update({ open: false}, { where: { channel: message.channel.id } });
|
||||
|
||||
message.channel.send(
|
||||
new Discord.MessageEmbed()
|
||||
.setColor(config.colour)
|
||||
.setAuthor(message.author.username, message.author.displayAvatarURL())
|
||||
.setTitle(`:white_check_mark: **Ticket ${ticket.id} closed**`)
|
||||
.setDescription('The channel will be automatically deleted once the contents have been archived.')
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
);
|
||||
|
||||
setTimeout(() => message.channel.delete(), 5000);
|
||||
return channel.send(notTicket);
|
||||
|
||||
} else {
|
||||
|
||||
@@ -59,11 +50,11 @@ module.exports = {
|
||||
notTicket
|
||||
.setTitle(':x: **Channel is not a ticket**')
|
||||
.setDescription(`${channel} is not a ticket channel.`);
|
||||
return message.channel.send(notTicket);
|
||||
return channel.send(notTicket);
|
||||
}
|
||||
|
||||
if(message.author.id !== ticket.get('creator') && !message.member.roles.cache.has(config.staff_role))
|
||||
return message.channel.send(
|
||||
return channel.send(
|
||||
new Discord.MessageEmbed()
|
||||
.setColor(config.err_colour)
|
||||
.setAuthor(message.author.username, message.author.displayAvatarURL())
|
||||
@@ -71,36 +62,92 @@ module.exports = {
|
||||
.setDescription(`You don't have permission to close ${channel} as it does not belong to you and you are not staff.`)
|
||||
.addField('Usage', `\`${config.prefix}${this.name} ${this.usage}\`\n`)
|
||||
.addField('Help', `Type \`${config.prefix}help ${this.name}\` for more information`)
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
}
|
||||
|
||||
let success;
|
||||
let pre = fs.existsSync(`user/transcripts/text/${channel.id}.txt`)
|
||||
|| fs.existsSync(`user/transcripts/raw/${channel.id}.log`) ?
|
||||
`You will be able to view an archived version later with \`${config.prefix}transcript ${ticket.get('id')}\``
|
||||
: '';
|
||||
|
||||
let confirm = await message.channel.send(
|
||||
new Discord.MessageEmbed()
|
||||
.setColor(config.colour)
|
||||
.setAuthor(message.author.username, message.author.displayAvatarURL())
|
||||
.setTitle(':grey_question: Are you sure?')
|
||||
.setDescription(`${pre}\n**React with :white_check_mark: to confirm.**`)
|
||||
.setFooter(guild.name + ' | Expires in 15 seconds', guild.iconURL())
|
||||
);
|
||||
|
||||
await confirm.react('✅');
|
||||
|
||||
const collector = confirm.createReactionCollector(
|
||||
(r, u) => r.emoji.name === '✅' && u.id === message.author.id,
|
||||
{ time: 15000 });
|
||||
|
||||
collector.on('collect', () => {
|
||||
if (channel.id !== message.channel.id)
|
||||
channel.send(
|
||||
new Discord.MessageEmbed()
|
||||
.setColor(config.colour)
|
||||
.setAuthor(message.author.username, message.author.displayAvatarURL())
|
||||
.setTitle('**Ticket closed**')
|
||||
.setDescription(`Ticket closed by ${message.author}`)
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
|
||||
ticket.update({ open: false}, { where: { channel: channel.id } });
|
||||
|
||||
message.channel.send(
|
||||
confirm.reactions.removeAll();
|
||||
confirm.edit(
|
||||
new Discord.MessageEmbed()
|
||||
.setColor(config.colour)
|
||||
.setAuthor(message.author.username, message.author.displayAvatarURL())
|
||||
.setTitle(`:white_check_mark: **Ticket ${ticket.id} closed**`)
|
||||
.setDescription('The channel will be automatically deleted once the contents have been archived.')
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setDescription('The channel will be automatically deleted in a few seconds, once the contents have been archived.')
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
|
||||
setTimeout(() => channel.delete(), 5000);
|
||||
}
|
||||
success = true;
|
||||
ticket.update({ open: false}, { where: { channel: channel.id } });
|
||||
setTimeout(() => {
|
||||
channel.delete();
|
||||
if (channel.id !== message.channel.id)
|
||||
message.delete()
|
||||
.then(() => confirm.delete());
|
||||
}, 15000);
|
||||
|
||||
log.info(`${message.author.tag} closed a ticket (#ticket-${ticket.get('id')})`);
|
||||
log.info(`${message.author.tag} closed a ticket (#ticket-${ticket.get('id')})`);
|
||||
|
||||
if (config.logs.discord.enabled)
|
||||
client.channels.cache.get(config.logs.discord.channel).send(
|
||||
new Discord.MessageEmbed()
|
||||
.setColor(config.colour)
|
||||
.setAuthor(message.author.username, message.author.displayAvatarURL())
|
||||
.setTitle('Ticket closed')
|
||||
.addField('Creator', `<@${ticket.get('creator')}>` , true)
|
||||
.addField('Closed by', message.author, true)
|
||||
.setFooter(client.user.username, client.user.avatarURL())
|
||||
.setTimestamp()
|
||||
);
|
||||
if (config.logs.discord.enabled)
|
||||
client.channels.cache.get(config.logs.discord.channel).send(
|
||||
new Discord.MessageEmbed()
|
||||
.setColor(config.colour)
|
||||
.setAuthor(message.author.username, message.author.displayAvatarURL())
|
||||
.setTitle('Ticket closed')
|
||||
.addField('Creator', `<@${ticket.get('creator')}>` , true)
|
||||
.addField('Closed by', message.author, true)
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
.setTimestamp()
|
||||
);
|
||||
});
|
||||
|
||||
|
||||
collector.on('end', () => {
|
||||
if(!success) {
|
||||
confirm.reactions.removeAll();
|
||||
confirm.edit(
|
||||
new Discord.MessageEmbed()
|
||||
.setColor(config.err_colour)
|
||||
.setAuthor(message.author.username, message.author.displayAvatarURL())
|
||||
.setTitle(':x: **Expired**')
|
||||
.setDescription('You took to long to react; confirmation failed.')
|
||||
.setFooter(guild.name, guild.iconURL()));
|
||||
|
||||
message.delete({ timeout: 10000 })
|
||||
.then(() => confirm.delete());
|
||||
}
|
||||
});
|
||||
|
||||
},
|
||||
}
|
||||
};
|
||||
|
@@ -19,6 +19,8 @@ module.exports = {
|
||||
example: 'help new',
|
||||
args: false,
|
||||
execute(client, message, args) {
|
||||
|
||||
const guild = client.guilds.cache.get(config.guild);
|
||||
|
||||
const commands = Array.from(client.commands.values());
|
||||
|
||||
@@ -47,7 +49,7 @@ module.exports = {
|
||||
\n${cmds.join('\n\n')}
|
||||
\nPlease contact a member of staff if you require assistance.`
|
||||
)
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
.setTimestamp()
|
||||
).catch((error) => {
|
||||
log.warn('Could not send help menu');
|
||||
|
@@ -21,15 +21,16 @@ module.exports = {
|
||||
args: false,
|
||||
async execute(client, message, args, Ticket) {
|
||||
|
||||
|
||||
const supportRole = message.guild.roles.cache.get(config.staff_role);
|
||||
const guild = client.guilds.cache.get(config.guild);
|
||||
|
||||
const supportRole = guild.roles.cache.get(config.staff_role);
|
||||
if (!supportRole)
|
||||
return message.channel.send(
|
||||
new Discord.MessageEmbed()
|
||||
.setColor(config.err_colour)
|
||||
.setTitle(':x: **Error**')
|
||||
.setDescription(`${config.name} has not been set up correctly. Could not find a 'support team' role with the id \`${config.staff_role}\``)
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
|
||||
|
||||
@@ -44,9 +45,9 @@ module.exports = {
|
||||
if (tickets.count >= config.tickets.max) {
|
||||
let ticketList = [];
|
||||
for (let t in tickets.rows) {
|
||||
let desc = tickets.rows[t].topic.substring(0, 20);
|
||||
let desc = tickets.rows[t].topic.substring(0, 30);
|
||||
ticketList
|
||||
.push(`<#${tickets.rows[t].channel}>: \`${desc}${desc.length > 20 ? '...' : ''}\``);
|
||||
.push(`<#${tickets.rows[t].channel}>: \`${desc}${desc.length > 30 ? '...' : ''}\``);
|
||||
}
|
||||
|
||||
let m = await message.channel.send(
|
||||
@@ -55,7 +56,7 @@ module.exports = {
|
||||
.setAuthor(message.author.username, message.author.displayAvatarURL())
|
||||
.setTitle(`:x: **You already have ${tickets.count} or more open tickets**`)
|
||||
.setDescription(`Use \`${config.prefix}close\` to close unneeded tickets.\n\n${ticketList.join(',\n')}`)
|
||||
.setFooter(message.guild.name + ' | This message will be deleted in 15 seconds', message.guild.iconURL())
|
||||
.setFooter(guild.name + ' | This message will be deleted in 15 seconds', guild.iconURL())
|
||||
);
|
||||
|
||||
return setTimeout(async () => {
|
||||
@@ -73,7 +74,7 @@ module.exports = {
|
||||
.setAuthor(message.author.username, message.author.displayAvatarURL())
|
||||
.setTitle(':x: **Description too long**')
|
||||
.setDescription('Please limit your ticket topic to less than 256 characters. A short sentence will do.')
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
else if (topic.length < 1)
|
||||
topic = 'No topic given';
|
||||
@@ -89,12 +90,12 @@ module.exports = {
|
||||
|
||||
let name = 'ticket-' + ticket.get('id');
|
||||
|
||||
message.guild.channels.create(name, {
|
||||
guild.channels.create(name, {
|
||||
type: 'text',
|
||||
topic: `${message.author} | ${topic}`,
|
||||
parent: config.tickets.category,
|
||||
permissionOverwrites: [{
|
||||
id: message.guild.roles.everyone,
|
||||
id: guild.roles.everyone,
|
||||
deny: ['VIEW_CHANNEL', 'SEND_MESSAGES']
|
||||
},
|
||||
{
|
||||
@@ -130,7 +131,8 @@ module.exports = {
|
||||
await message.delete();
|
||||
await m.delete();
|
||||
}, 15000);
|
||||
|
||||
|
||||
require('../utils/archive').create(client, c); // create files
|
||||
|
||||
let ping;
|
||||
switch (config.tickets.ping) {
|
||||
@@ -167,7 +169,7 @@ module.exports = {
|
||||
.setAuthor(message.author.username, message.author.displayAvatarURL())
|
||||
.setDescription(text)
|
||||
.addField('Topic', `\`${topic}\``)
|
||||
.setFooter(client.user.username, client.user.avatarURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
|
||||
if (config.tickets.pin)
|
||||
@@ -183,7 +185,7 @@ module.exports = {
|
||||
.setDescription(`\`${topic}\``)
|
||||
.addField('Creator', message.author, true)
|
||||
.addField('Channel', c, true)
|
||||
.setFooter(client.user.username, client.user.avatarURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
.setTimestamp()
|
||||
);
|
||||
|
||||
|
63
src/commands/panel.js
Normal file
63
src/commands/panel.js
Normal file
@@ -0,0 +1,63 @@
|
||||
/**
|
||||
*
|
||||
* @name DiscordTickets
|
||||
* @author eartharoid <contact@eartharoid.me>
|
||||
* @license GNU-GPLv3
|
||||
*
|
||||
*/
|
||||
|
||||
const ChildLogger = require('leekslazylogger').ChildLogger;
|
||||
const log = new ChildLogger();
|
||||
const Discord = require('discord.js');
|
||||
const config = require('../../user/config');
|
||||
|
||||
module.exports = {
|
||||
name: 'panel',
|
||||
description: 'Create or a panel widget in the channel the command is used in. Note that there can only be 1 panel.',
|
||||
usage: '',
|
||||
aliases: ['widget'],
|
||||
example: '',
|
||||
args: false,
|
||||
permission: 'MANAGE_SERVER',
|
||||
async execute(client, message, args, Ticket, Setting) {
|
||||
|
||||
const guild = client.guilds.cache.get(config.guild);
|
||||
|
||||
let msgID = await Setting.findOne({ where: { key: 'panel_msg_id' } });
|
||||
let chanID = await Setting.findOne({ where: { key: 'panel_chan_id' } });
|
||||
let panel;
|
||||
|
||||
if(!chanID)
|
||||
chanID = await Setting.create({
|
||||
key: 'panel_chan_id',
|
||||
value: message.channel.id,
|
||||
});
|
||||
|
||||
if(!msgID) {
|
||||
msgID = await Setting.create({
|
||||
key: 'panel_msg_id',
|
||||
value: '',
|
||||
});
|
||||
} else {
|
||||
panel = await client.channels.cache.get(chanID.get('value')).messages.fetch(msgID.get('value')); // get old panel message
|
||||
if (panel)
|
||||
panel.delete({ reason: 'Creating new panel/widget' }).then(() => log.info('Deleted old panel')); // delete old panel
|
||||
}
|
||||
|
||||
message.delete();
|
||||
|
||||
panel = await message.channel.send(
|
||||
new Discord.MessageEmbed()
|
||||
.setColor(config.colour)
|
||||
.setTitle(config.panel.title)
|
||||
.setDescription(config.panel.description)
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
.setTimestamp()
|
||||
); // send new panel
|
||||
|
||||
panel.react(config.panel.reaction); // add reaction
|
||||
Setting.update({ value: panel.id }, { where: { key: 'panel_msg_id' }}); // update database
|
||||
|
||||
log.info(`${message.author.tag} created a panel widget`);
|
||||
}
|
||||
};
|
@@ -20,6 +20,8 @@ module.exports = {
|
||||
args: true,
|
||||
async execute(client, message, args, Ticket) {
|
||||
|
||||
const guild = client.guilds.cache.get(config.guild);
|
||||
|
||||
const notTicket = new Discord.MessageEmbed()
|
||||
.setColor(config.err_colour)
|
||||
.setAuthor(message.author.username, message.author.displayAvatarURL())
|
||||
@@ -27,7 +29,7 @@ module.exports = {
|
||||
.setDescription('Use this command in the ticket channel you want to remove a user from, or mention the channel.')
|
||||
.addField('Usage', `\`${config.prefix}${this.name} ${this.usage}\`\n`)
|
||||
.addField('Help', `Type \`${config.prefix}help ${this.name}\` for more information`)
|
||||
.setFooter(message.guild.name, message.guild.iconURL());
|
||||
.setFooter(guild.name, guild.iconURL());
|
||||
|
||||
let ticket;
|
||||
|
||||
@@ -60,12 +62,12 @@ module.exports = {
|
||||
.setDescription(`You don't have permission to alter ${channel} as it does not belong to you and you are not staff.`)
|
||||
.addField('Usage', `\`${config.prefix}${this.name} ${this.usage}\`\n`)
|
||||
.addField('Help', `Type \`${config.prefix}help ${this.name}\` for more information`)
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
|
||||
|
||||
|
||||
let member = message.guild.member(message.mentions.users.first() || message.guild.members.cache.get(args[0]));
|
||||
let member = guild.member(message.mentions.users.first() || guild.members.cache.get(args[0]));
|
||||
|
||||
if(!member)
|
||||
return message.channel.send(
|
||||
@@ -76,7 +78,7 @@ module.exports = {
|
||||
.setDescription('Please mention a valid member.')
|
||||
.addField('Usage', `\`${config.prefix}${this.name} ${this.usage}\`\n`)
|
||||
.addField('Help', `Type \`${config.prefix}help ${this.name}\` for more information`)
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
|
||||
try {
|
||||
@@ -94,7 +96,7 @@ module.exports = {
|
||||
.setAuthor(member.user.username, member.user.displayAvatarURL())
|
||||
.setTitle('**Member remove**')
|
||||
.setDescription(`${member} has been removed by ${message.author}`)
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
|
||||
|
||||
@@ -105,7 +107,7 @@ module.exports = {
|
||||
.setAuthor(member.user.username, member.user.displayAvatarURL())
|
||||
.setTitle(':white_check_mark: **Member removed**')
|
||||
.setDescription(`${member} has been removed from <#${ticket.get('channel')}>`)
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
|
||||
log.info(`${message.author.tag} removed a user from a ticket (#${message.channel.id})`);
|
||||
|
23
src/commands/stats.js
Normal file
23
src/commands/stats.js
Normal file
@@ -0,0 +1,23 @@
|
||||
/**
|
||||
*
|
||||
* @name DiscordTickets
|
||||
* @author eartharoid <contact@eartharoid.me>
|
||||
* @license GNU-GPLv3
|
||||
*
|
||||
*/
|
||||
|
||||
const ChildLogger = require('leekslazylogger').ChildLogger;
|
||||
const log = new ChildLogger();
|
||||
const Discord = require('discord.js');
|
||||
const config = require('../../user/config');
|
||||
|
||||
module.exports = {
|
||||
name: 'stats',
|
||||
description: 'View ticket stats.',
|
||||
usage: '',
|
||||
aliases: ['data'],
|
||||
example: '',
|
||||
args: false,
|
||||
async execute(client, message, args, Ticket) {
|
||||
}
|
||||
};
|
@@ -18,22 +18,23 @@ module.exports = {
|
||||
example: '',
|
||||
args: false,
|
||||
async execute(client, message, args, Ticket) {
|
||||
|
||||
|
||||
const supportRole = message.guild.roles.cache.get(config.staff_role);
|
||||
const guild = client.guilds.cache.get(config.guild);
|
||||
|
||||
const supportRole = guild.roles.cache.get(config.staff_role);
|
||||
if (!supportRole)
|
||||
return message.channel.send(
|
||||
new Discord.MessageEmbed()
|
||||
.setColor(config.err_colour)
|
||||
.setTitle(':x: **Error**')
|
||||
.setDescription(`${config.name} has not been set up correctly. Could not find a 'support team' role with the id \`${config.staff_role}\``)
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
|
||||
let context;
|
||||
let user = message.mentions.users.first() || message.guild.members.cache.get(args[0]);
|
||||
let context = 'self';
|
||||
let user = message.mentions.users.first() || guild.members.cache.get(args[0]);
|
||||
|
||||
if(!user) {
|
||||
if(user) {
|
||||
if(!message.member.roles.cache.has(config.staff_role))
|
||||
return message.channel.send(
|
||||
new Discord.MessageEmbed()
|
||||
@@ -43,14 +44,13 @@ module.exports = {
|
||||
.setDescription('You don\'t have permission to list others\' tickets as you are not staff.')
|
||||
.addField('Usage', `\`${config.prefix}${this.name} ${this.usage}\`\n`)
|
||||
.addField('Help', `Type \`${config.prefix}help ${this.name}\` for more information`)
|
||||
.setFooter(message.guild.name, message.guild.iconURL())
|
||||
.setFooter(guild.name, guild.iconURL())
|
||||
);
|
||||
|
||||
user = message.author;
|
||||
context = 'staff';
|
||||
} else {
|
||||
user = message.author;
|
||||
}
|
||||
|
||||
context = 'self';
|
||||
|
||||
|
||||
let openTickets = await Ticket.findAndCountAll({
|
||||
@@ -71,9 +71,9 @@ module.exports = {
|
||||
|
||||
let embed = new Discord.MessageEmbed()
|
||||
.setColor(config.colour)
|
||||
.setAuthor(message.author.username, message.author.displayAvatarURL())
|
||||
.setTitle('Your tickets')
|
||||
.setFooter(message.guild.name + ' | This message will be deleted in 60 seconds', message.guild.iconURL());
|
||||
.setAuthor(user.username, user.displayAvatarURL())
|
||||
.setTitle(`${context === 'self' ? 'Your' : user.username + '\'s'} tickets`)
|
||||
.setFooter(guild.name + ' | This message will be deleted in 60 seconds', guild.iconURL());
|
||||
|
||||
if(config.transcripts.web.enabled)
|
||||
embed.setDescription(`You can access all of your ticket archives on the [web portal](${config.transcripts.web.server}/${user.id}).`);
|
||||
@@ -91,13 +91,14 @@ module.exports = {
|
||||
for (let t in closedTickets.rows) {
|
||||
let desc = closedTickets.rows[t].topic.substring(0, 30);
|
||||
let transcript = '';
|
||||
if(fs.existsSync(`user/transcripts/text/${closedTickets.rows[t].channel}.txt`))
|
||||
let c = closedTickets.rows[t].channel;
|
||||
if(fs.existsSync(`user/transcripts/text/${c}.txt`) || fs.existsSync(`user/transcripts/raw/${c}.log`))
|
||||
transcript = `\n> Type \`${config.prefix}transcript ${closedTickets.rows[t].id}\` to download text transcript.`;
|
||||
|
||||
closed.push(`> #${closedTickets.rows[t].id}: \`${desc}${desc.length > 20 ? '...' : ''}\`${transcript}`);
|
||||
|
||||
}
|
||||
let pre = context === 'self' ? 'You have' : user + ' has';
|
||||
let pre = context === 'self' ? 'You have' : user.username + ' has';
|
||||
embed.addField('Open tickets', openTickets.count === 0 ? `${pre} no open tickets.` : open.join('\n\n'), false);
|
||||
embed.addField('Closed tickets', closedTickets.count === 0 ? `${pre} no old tickets` : closed.join('\n\n'), false);
|
||||
|
||||
|
@@ -18,6 +18,9 @@ module.exports = {
|
||||
example: 'transcript 57',
|
||||
args: false,
|
||||
async execute(client, message, args, Ticket) {
|
||||
/** @TODO TRY TO SEND ATTACHMENT TO DM */
|
||||
/**
|
||||
* @TODO TRY TO SEND ATTACHMENT TO DM
|
||||
* @TODO ONLY ALLOW CREATOR AND STAFF TO RUN CMD
|
||||
*/
|
||||
}
|
||||
};
|
Reference in New Issue
Block a user