galactic-bot/structure/extensions/Message.js

117 lines
3.7 KiB
JavaScript
Raw Normal View History

2020-04-08 18:08:46 +02:00
const { Structures } = require('discord.js');
2020-04-19 21:55:26 +02:00
const escapeRegex = require('escape-string-regexp');
const emojis = require('../../util/emojis.json');
2020-05-05 01:35:01 +02:00
const { Util } = require('../../util/');
2020-04-08 18:08:46 +02:00
const Message = Structures.extend('Message', (Message) => {
class ExtendedMessage extends Message {
constructor(...args) {
super(...args);
this.command = null; //Will set to command if the message induces a command.
this.args = null;
this.parameters = null;
this._pending = null;
}
format(index, parameters = { }, code = false) {
2020-04-19 21:55:26 +02:00
let language = this.author._settings.locale || 'en_us';
if(this.guild && this.guild._settings.locale) language = this.guild._settings.locale;
2020-05-01 16:10:55 +02:00
parameters.prefix = this.guild && this.guild._settings.prefix ? this.guild._settings.prefix : this.client._options.bot.prefix ;
2020-04-19 21:55:26 +02:00
let template = this.client.localeLoader.template(language, index); //.languages[language][index];
2020-04-19 21:55:26 +02:00
for (const [param, val] of Object.entries(parameters)) {
template = template.replace(new RegExp(`{${escapeRegex(param.toLowerCase())}}`, 'gi'), val);
}
template = template.replace(new RegExp(`\r`, 'gi'), '\n');
if(code) {
try {
template = eval(template);
} catch(error) {
this.command.client.logger.error(`Error in locale ${language}:${index} while executing code.\n${error.stack || error}`);
}
}
2020-04-19 21:55:26 +02:00
return template;
}
async resolve() {
2020-05-05 15:33:14 +02:00
if (this.command.showUsage && !this.parameters.length) {
2020-05-05 01:35:01 +02:00
return this._showUsage();
}
try {
const resolved = this.command.execute(this, {
params: this.parameters,
args: this.args
});
if(resolved instanceof Promise) await resolved;
return { error: false };
} catch(error) {
return { error: true, message: error.stack || error };
}
2020-04-08 18:08:46 +02:00
}
2020-04-19 21:55:26 +02:00
async embed(embed, opts = {}) {
2020-05-01 16:10:55 +02:00
if (!embed.color) embed.color = 619452;
2020-04-19 21:55:26 +02:00
let send = { content: opts.reply ? `<@${this.author.id}>` : '', embed };
this._pending = await this.channel.send(send);
return this._pending;
}
async respond(str, opts = {}) {
if(typeof str === 'string') {
if(opts.emoji) {
const emoji = emojis[opts.emoji];
if(!emoji) this.command.client.logger.warn(`Invalid emoji provided to command ${this.command.resolveable}: "${opts.emoji}".`);
str = `${emoji} ${str}`;
}
if(opts.reply) str = `<@!${this.author.id}> ${str}`;
}
this._pending = await this.channel.send(str);
return this._pending;
}
async edit(str, opts) {
if(!this.editable) return null;
if(typeof str === 'string') {
if(opts.emoji) str = `${emojis[opts.emoji]} ${str}`;
if(opts.reply) str = `<@!${this.author.id}> ${str}`;
}
return super.edit(str);
}
2020-05-05 15:33:14 +02:00
async _showUsage() {
2020-05-05 01:35:01 +02:00
//TODO: format this
return await this.embed({
title: `**${this.command.name.toUpperCase()} USAGE**`,
2020-05-06 15:48:20 +02:00
description: `${this.format(`C_${this.command.name.toUpperCase()}_USAGE`)}\n${this.format(`C_${this.command.name.toUpperCase()}_EXAMPLES`)}`
2020-05-05 01:35:01 +02:00
});
}
2020-04-08 18:08:46 +02:00
}
return ExtendedMessage;
});
module.exports = Message;