Files
xiao/commands/edit-image-text/ace-attorney.js
T
2024-05-21 21:02:12 -04:00

88 lines
2.7 KiB
JavaScript

const Command = require('../../framework/Command');
const { PermissionFlagsBits } = require('discord.js');
const { createCanvas, loadImage } = require('@napi-rs/canvas');
const path = require('path');
const { firstUpperCase } = require('../../util/Util');
const { wrapText, fillTextWithBreaks } = require('../../util/Canvas');
const characters = {
phoenix: ['phoenix', 'wright', 'naruhodo', 'ryuuichi', 'ryu', 'nick'],
edgeworth: ['miles', 'edgeworth', 'mitsurugi', 'reiji', 'edgey'],
godot: ['godot', 'diego', 'armando', 'souryuu', 'soryu', 'kaminogi'],
apollo: ['apollo', 'justice', 'odoroki', 'housuke', 'hosuke']
};
module.exports = class AceAttorneyCommand extends Command {
constructor(client) {
super(client, {
name: 'ace-attorney',
aliases: [
'aa',
'ace-attorney-dialogue',
'aa-dialogue',
'ace-attorney-dialog',
'aa-dialog',
'ace-attorney-quote',
'aa-quote'
],
group: 'edit-image-text',
description: 'Sends a text box from Ace Attorney with the quote and character of your choice.',
details: `**Characters:** ${Object.keys(characters).join(', ')}`,
throttling: {
usages: 2,
duration: 10
},
clientPermissions: [PermissionFlagsBits.AttachFiles],
credit: [
{
name: 'Capcom',
url: 'http://www.capcom.com/us/',
reason: 'Images, Original "Ace Attorney" Game',
reasonURL: 'http://www.ace-attorney.com/'
},
{
name: 'Enkidulga',
url: 'https://www.dafont.com/profile.php?user=736583',
reason: 'Ace Attorney Font',
reasonURL: 'https://www.dafont.com/ace-attorney.font'
}
],
args: [
{
key: 'character',
type: 'string',
oneOf: Object.values(characters).reduce((a, b) => a.concat(b)),
parse: character => character.toLowerCase()
},
{
key: 'quote',
type: 'string',
max: 250
}
]
});
}
async run(msg, { character, quote }) {
let file;
for (const [id, arr] of Object.entries(characters)) {
if (!arr.includes(character.toLowerCase())) continue;
file = id;
break;
}
const base = await loadImage(
path.join(__dirname, '..', '..', 'assets', 'images', 'ace-attorney', `${file}.png`)
);
const canvas = createCanvas(base.width, base.height);
const ctx = canvas.getContext('2d');
ctx.drawImage(base, 0, 0);
ctx.font = this.client.fonts.get('Ace-Attorney.ttf').toCanvasString(14);
ctx.fillStyle = 'white';
ctx.textBaseline = 'top';
ctx.fillText(firstUpperCase(character), 6, 176);
let text = wrapText(ctx, quote, 242);
text = text.length > 5 ? `${text.slice(0, 5).join('\n')}...` : text.join('\n');
fillTextWithBreaks(ctx, text, 7, 199);
return msg.say({ files: [{ attachment: canvas.toBuffer('image/png'), name: `ace-attorney-${character}.png` }] });
}
};