Skip to content

Instantly share code, notes, and snippets.

@CodyJasonBennett
Last active September 19, 2021 20:26
Show Gist options
  • Save CodyJasonBennett/36b90d78db8e13d42d2c3e277d2d3f01 to your computer and use it in GitHub Desktop.
Save CodyJasonBennett/36b90d78db8e13d42d2c3e277d2d3f01 to your computer and use it in GitHub Desktop.
THREE SSR Discord.js
<!DOCTYPE >
<html>
<head>
<meta charset="UTF-8" />
<style>
body {
margin: 0;
}
canvas {
display: block;
}
</style>
</head>
<body>
<script type="module">
import * as THREE from 'https://cdn.skypack.dev/[email protected]/build/three.module.js';
const blocks = [
{
name: 'stone',
src:
'',
},
];
const block = window.location.search.replace('?block=', '');
const target = blocks.find(({ name }) => name === block);
new THREE.TextureLoader().load(target.src, texture => {
const { innerWidth, innerHeight } = window;
const renderer = new THREE.WebGLRenderer({
antialias: false,
preserveDrawingBuffer: true,
});
renderer.setPixelRatio(2);
renderer.setSize(innerWidth, innerHeight);
document.body.appendChild(renderer.domElement);
const camera = new THREE.PerspectiveCamera(70, innerWidth / innerHeight);
camera.position.z = 2;
const scene = new THREE.Scene();
const geometry = new THREE.BoxGeometry();
const material = new THREE.MeshBasicMaterial({ map: texture });
const mesh = new THREE.Mesh(geometry, material);
scene.add(mesh);
renderer.render(scene, camera);
});
</script>
</body>
</html>
const puppeteer = require('puppeteer');
const { Client } = require('discord.js');
const renderBlock = async block => {
const browser = await puppeteer.launch({
headless: true,
args: ['--use-gl', '--use-cmd-decoder=passthrough'],
});
const page = await browser.newPage();
await page.goto(`file://${__dirname}/index.html?block=${block.toLowerCase()}`);
await page.waitForSelector('canvas');
const image = await page.evaluate(() => document.querySelector('canvas').toDataURL());
await browser.close();
return image;
};
const bot = new Client();
bot.login(process.env.TOKEN);
bot.on('message', async msg => {
if (!msg.content.startsWith('!block ')) return;
const block = msg.content.replace('!block', '').trim();
const image = await renderBlock(block);
if (!image) return msg.channel.send(`Block: ${block} not found.`);
const imageStream = new Buffer.from(image.split(',')[1], 'base64');
return msg.channel.send({ files: [imageStream] });
});
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment