forked from Supositware/Haha-Yes
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
69 lines
2.5 KiB
JavaScript
69 lines
2.5 KiB
JavaScript
6 years ago
|
const { Command } = require('discord.js-commando');
|
||
|
const Discord = require('discord.js');
|
||
|
const { createCanvas, loadImage, getContext } = require('canvas')
|
||
|
const superagent = require('superagent')
|
||
|
|
||
|
|
||
|
module.exports = class idubbbzCommand extends Command {
|
||
|
constructor(client) {
|
||
|
super(client, {
|
||
|
name: 'idubbbz',
|
||
|
aliases: ['idubbz', 'edups'],
|
||
|
group: 'fun',
|
||
|
memberName: 'idubbbz',
|
||
|
description: `Put the text you send in idubbbz piece of paper`,
|
||
|
args: [
|
||
|
{
|
||
|
key: 'text',
|
||
|
prompt: 'What do you the paper to say?',
|
||
|
type: 'string',
|
||
|
default: 'Nigger Faggot'
|
||
|
}
|
||
|
]
|
||
|
});
|
||
|
}
|
||
|
|
||
|
async run(message, { text }) {
|
||
|
let Attachment = (message.attachments).array();
|
||
|
let image = null
|
||
|
if (!Attachment[0])
|
||
|
image = message.author.displayAvatarURL
|
||
|
else
|
||
|
image = Attachment[0].url
|
||
|
|
||
|
const applyText = (canvas, text) => {
|
||
|
const ctx = canvas.getContext('2d');
|
||
|
|
||
|
// Declare a base size of the font
|
||
|
let fontSize = 50;
|
||
|
|
||
|
do {
|
||
|
// Assign the font to the context and decrement it so it can be measured again
|
||
|
ctx.font = `${fontSize -= 10}px sans-serif`;
|
||
|
// Compare pixel width of the text to the canvas minus the approximate avatar size
|
||
|
} while (ctx.measureText(text).width > canvas.width - 300);
|
||
|
|
||
|
// Return the result to use in the actual canvas
|
||
|
return ctx.font;
|
||
|
};
|
||
|
|
||
|
const canvas = createCanvas(1281, 627)
|
||
|
const ctx = canvas.getContext('2d')
|
||
|
const background = await loadImage(image);
|
||
|
ctx.drawImage(background, 620, 100, 200, 200);
|
||
|
const { body: buffer } = await superagent.get('https://image.noelshack.com/fichiers/2018/41/7/1539510207-untitled.png');
|
||
|
const bg = await loadImage(buffer);
|
||
|
ctx.drawImage(bg, 0, 0, canvas.width, canvas.height);
|
||
|
ctx.font = applyText(canvas, text)
|
||
|
//ctx.font = '40px sans-serif';
|
||
|
// Select the style that will be used to fill the text in
|
||
|
ctx.fillStyle = '#000000';
|
||
|
// Actually fill the text with a solid color
|
||
|
ctx.fillText(text, canvas.width / 2.1, canvas.height / 1.5);
|
||
|
|
||
|
const attachment = new Discord.Attachment(canvas.toBuffer(), 'test.png');
|
||
|
|
||
|
message.say(attachment);
|
||
|
|
||
|
}
|
||
|
};
|