mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-03 23:36:43 +02:00
106 lines
3.3 KiB
JavaScript
106 lines
3.3 KiB
JavaScript
const Command = require('../../framework/Command');
|
|
const { PermissionFlagsBits } = require('discord.js');
|
|
const { createCanvas, loadImage } = require('@napi-rs/canvas');
|
|
const { GifEncoder } = require('@skyra/gifenc');
|
|
const { MersenneTwister19937, bool } = require('random-js');
|
|
const { buffer } = require('node:stream/consumers');
|
|
const request = require('node-superfetch');
|
|
const path = require('path');
|
|
const frameCount = 52;
|
|
|
|
module.exports = class EjectCommand extends Command {
|
|
constructor(client) {
|
|
super(client, {
|
|
name: 'eject',
|
|
group: 'edit-avatar',
|
|
description: 'Ejects a user.',
|
|
throttling: {
|
|
usages: 2,
|
|
duration: 30
|
|
},
|
|
clientPermissions: [PermissionFlagsBits.AttachFiles],
|
|
credit: [
|
|
{
|
|
name: 'Wisq',
|
|
url: 'https://www.youtube.com/channel/UCrOS0iXaZgW45AdbEznGXLA',
|
|
reason: 'Images',
|
|
reasonURL: 'https://www.youtube.com/watch?v=yx4Hp8TBVtQ'
|
|
},
|
|
{
|
|
name: 'Google',
|
|
url: 'https://www.google.com/',
|
|
reason: 'Noto Font',
|
|
reasonURL: 'https://fonts.google.com/noto'
|
|
},
|
|
{
|
|
name: 'InnerSloth',
|
|
url: 'https://www.innersloth.com/',
|
|
reason: 'Original "Among Us" Game',
|
|
reasonURL: 'https://www.innersloth.com/games/among-us/'
|
|
}
|
|
],
|
|
args: [
|
|
{
|
|
key: 'user',
|
|
type: 'user',
|
|
default: msg => msg.author
|
|
}
|
|
]
|
|
});
|
|
}
|
|
|
|
async run(msg, { user }) {
|
|
const avatarURL = user.displayAvatarURL({ extension: 'png', size: 128, forceStatic: true });
|
|
const { body } = await request.get(avatarURL);
|
|
const avatar = await loadImage(body);
|
|
const random = MersenneTwister19937.seed(user.id);
|
|
const imposter = bool()(random);
|
|
const text = `${user.globalName || user.username} was${imposter ? ' ' : ' not '}An Imposter.`;
|
|
const encoder = new GifEncoder(320, 180);
|
|
const stream = encoder.createReadStream();
|
|
const canvas = createCanvas(320, 180);
|
|
const ctx = canvas.getContext('2d');
|
|
ctx.textAlign = 'center';
|
|
ctx.textBaseline = 'middle';
|
|
ctx.fillStyle = 'white';
|
|
ctx.font = this.client.fonts.get('Noto-Regular.ttf').toCanvasString(18);
|
|
encoder.start();
|
|
encoder.setRepeat(0);
|
|
encoder.setDelay(100);
|
|
encoder.setQuality(20);
|
|
for (let i = 0; i < frameCount; i++) {
|
|
const frameID = `frame_${i.toString().padStart(2, '0')}.png`;
|
|
const frame = await loadImage(path.join(__dirname, '..', '..', 'assets', 'images', 'eject', frameID));
|
|
ctx.drawImage(frame, 0, 0);
|
|
if (i <= 17) {
|
|
const x = ((320 / 15) * i) - 50;
|
|
const y = (frame.height / 2) - 25;
|
|
const rotation = (360 / 15) * i;
|
|
const angle = rotation * (Math.PI / 180);
|
|
const originX = x + 25;
|
|
const originY = y + 25;
|
|
ctx.translate(originX, originY);
|
|
ctx.rotate(-angle);
|
|
ctx.translate(-originX, -originY);
|
|
ctx.drawImage(avatar, x, y, 50, 50);
|
|
ctx.translate(originX, originY);
|
|
ctx.rotate(angle);
|
|
ctx.translate(-originX, -originY);
|
|
}
|
|
if (i > 17) {
|
|
if (i <= 27) {
|
|
const letters = Math.ceil(((text.length / 10) * (i - 17)) + 1);
|
|
const toDraw = text.slice(0, letters + 1);
|
|
ctx.fillText(toDraw, frame.width / 2, frame.height / 2, 300);
|
|
} else {
|
|
ctx.fillText(text, frame.width / 2, frame.height / 2, 300);
|
|
}
|
|
}
|
|
encoder.addFrame(ctx);
|
|
}
|
|
encoder.finish();
|
|
const attachment = await buffer(stream);
|
|
return msg.say({ files: [{ attachment, name: 'eject.gif' }] });
|
|
}
|
|
};
|