45 lines
1.9 KiB
JavaScript
45 lines
1.9 KiB
JavaScript
import ImageCommand from "../../classes/imageCommand.js";
|
|
const allowedFonts = ["futura", "impact", "helvetica", "arial", "roboto", "noto", "times"];
|
|
|
|
class MemeCommand extends ImageCommand {
|
|
params(url) {
|
|
const newArgs = this.options.text ?? this.args.filter(item => !item.includes(url)).join(" ");
|
|
const [topText, bottomText] = newArgs.split(/(?<!\\),/).map(elem => elem.trim());
|
|
return {
|
|
top: (this.options.case ? topText : topText.toUpperCase()).replaceAll("&", "&").replaceAll(">", ">").replaceAll("<", "<").replaceAll("\"", """).replaceAll("'", "'").replaceAll("\\n", "\n"),
|
|
bottom: bottomText ? (this.options.case ? bottomText : bottomText.toUpperCase()).replaceAll("&", "&").replaceAll(">", ">").replaceAll("<", "<").replaceAll("\"", """).replaceAll("'", "'").replaceAll("\\n", "\n") : "",
|
|
font: this.options.font && allowedFonts.includes(this.options.font.toLowerCase()) ? this.options.font.toLowerCase() : "impact"
|
|
};
|
|
}
|
|
|
|
static init() {
|
|
super.init();
|
|
this.flags.push({
|
|
name: "case",
|
|
description: "Make the meme text case-sensitive (allows for lowercase text)",
|
|
type: 5
|
|
}, {
|
|
name: "font",
|
|
type: 3,
|
|
choices: (() => {
|
|
const array = [];
|
|
for (const font of allowedFonts) {
|
|
array.push({ name: font, value: font });
|
|
}
|
|
return array;
|
|
})(),
|
|
description: "Specify the font you want to use (default: impact)"
|
|
});
|
|
return this;
|
|
}
|
|
|
|
static description = "Generates a meme from an image (separate top/bottom text with a comma)";
|
|
static arguments = ["[top text]", "{bottom text}"];
|
|
|
|
static requiresText = true;
|
|
static noText = "You need to provide some text to generate a meme!";
|
|
static noImage = "You need to provide an image/GIF to generate a meme!";
|
|
static command = "meme";
|
|
}
|
|
|
|
export default MemeCommand;
|