Files
xiao/commands/edit-image/undertale.js
T
2020-06-15 21:00:17 -04:00

141 lines
4.1 KiB
JavaScript

const Command = require('../../structures/Command');
const { createCanvas, loadImage, registerFont } = require('canvas');
const path = require('path');
const { list } = require('../../util/Util');
const { wrapText } = require('../../util/Canvas');
const characters = require('../../assets/json/undertale');
registerFont(path.join(__dirname, '..', '..', 'assets', 'fonts', 'DeterminationMono.ttf'), {
family: 'DeterminationMono'
});
registerFont(path.join(__dirname, '..', '..', 'assets', 'fonts', 'UndertalePapyrus.ttf'), {
family: 'UndertalePapyrus'
});
registerFont(path.join(__dirname, '..', '..', 'assets', 'fonts', 'UndertaleSans.ttf'), { family: 'UndertaleSans' });
registerFont(path.join(__dirname, '..', '..', 'assets', 'fonts', 'pixelated-wingdings.ttf'), {
family: 'Pixelated Wingdings'
});
registerFont(path.join(__dirname, '..', '..', 'assets', 'fonts', 'apple_kid.ttf'), { family: 'Apple Kid' });
module.exports = class UndertaleCommand extends Command {
constructor(client) {
super(client, {
name: 'undertale',
aliases: [
'ut',
'undertale-dialogue',
'ut-dialogue',
'undertale-dialog',
'ut-dialog',
'undertale-quote',
'ut-quote'
],
group: 'edit-image',
memberName: 'undertale',
description: 'Sends a text box from Undertale with the quote and character of your choice.',
details: `**Characters:** ${characters.join(', ')}`,
throttling: {
usages: 1,
duration: 10
},
clientPermissions: ['ATTACH_FILES'],
credit: [
{
name: 'UNDERTALE',
url: 'https://undertale.com/',
reason: 'Original Game'
},
{
name: 'Demirramon',
url: 'https://www.demirramon.com/',
reason: 'Images',
reasonURL: 'https://www.demirramon.com/en/generators/undertale_text_box_generator'
},
{
name: 'Carter Sande',
url: 'https://gitlab.com/cartr',
reason: 'DeterminationMono, UndertaleSans, and UndertalePapyrus Fonts',
reasonURL: 'https://gitlab.com/cartr/undertale-fonts/tree/master'
},
{
name: 'Sigmath Bits',
url: 'https://fontstruct.com/fontstructors/1280718/sigmath6',
reason: 'Pixelated Wingdings Font',
reasonURL: 'https://fontstruct.com/fontstructions/show/1218140/pixelated-wingdings'
},
{
name: 'EarthBound Central',
url: 'https://earthboundcentral.com/',
reason: 'Apple Kid Font',
reasonURL: 'https://earthboundcentral.com/2009/11/ultimate-earthbound-font-pack/'
},
{
name: 'Overtime2005',
url: 'https://github.com/Overtime2005',
reason: 'Concept'
}
],
args: [
{
key: 'character',
prompt: `What character do you want to use? Either ${list(characters, 'or')}.`,
type: 'string',
oneOf: characters,
parse: character => character.toLowerCase()
},
{
key: 'quote',
prompt: 'What should the character say?',
type: 'string',
max: 250
}
]
});
}
async run(msg, { character, quote }) {
const base = await loadImage(
path.join(__dirname, '..', '..', 'assets', 'images', 'undertale', `${character}.png`)
);
const canvas = createCanvas(base.width, base.height);
const ctx = canvas.getContext('2d');
ctx.drawImage(base, 0, 0);
let font = 'DeterminationMono';
let space = -3;
switch (character) {
case 'sans':
font = 'UndertaleSans';
quote = quote.toLowerCase();
space = -4;
break;
case 'papyrus':
font = 'UndertalePapyrus';
quote = quote.toUpperCase();
space = -5;
break;
case 'napstablook':
quote = quote.toLowerCase();
break;
case 'gaster':
font = 'Pixelated Wingdings';
space = -4;
break;
case 'ness':
font = 'Apple Kid';
space = -2;
break;
case 'temmie':
quote = this.client.registry.commands.get('temmie').temmize(quote);
break;
}
ctx.font = `32px ${font}`;
ctx.fillStyle = 'white';
ctx.textBaseline = 'top';
const text = await wrapText(ctx, quote, 385);
const lines = text.length > 3 ? 3 : text.length;
for (let i = 0; i < lines; i++) {
ctx.fillText(text[i], 174, 22 + (22 * i) + (22 * i) + (space * i));
}
return msg.say({ files: [{ attachment: canvas.toBuffer(), name: `undertale-${character}.png` }] });
}
};