require('dotenv/config'); const fs = require('fs'); const fetch = require('node-fetch'); const Jimp = require('jimp'); process.chdir(__dirname); const base = `https://api.github.com/repos/sveltejs/svelte/contributors`; const { GITHUB_CLIENT_ID, GITHUB_CLIENT_SECRET } = process.env; const SIZE = 64; async function main() { const contributors = []; let page = 1; while (true) { const res = await fetch(`${base}?client_id=${GITHUB_CLIENT_ID}&client_secret=${GITHUB_CLIENT_SECRET}&per_page=100&page=${page++}`); const list = await res.json(); if (list.length === 0) break; contributors.push(...list); } const authors = contributors .sort((a, b) => b.contributions - a.contributions); const sprite = new Jimp(SIZE * authors.length, SIZE); for (let i = 0; i < authors.length; i += 1) { const author = authors[i]; console.log(`${i + 1} / ${authors.length}: ${author.login}`); const image_data = await fetch(author.avatar_url); const buffer = await image_data.arrayBuffer(); const image = await Jimp.read(buffer); image.resize(SIZE, SIZE); sprite.composite(image, i * SIZE, 0); } await sprite.quality(80).write(`../static/contributors.jpg`); // TODO: Optimizing the static/contributors.jpg image should probably get automated as well console.log('remember to additionally optimize the resulting /static/contributors.jpg image file via e.g. https://squoosh.app '); const str = `[\n\t${authors.map(a => `'${a.login}'`).join(',\n\t')}\n]`; fs.writeFileSync(`../src/routes/_contributors.js`, `export default ${str};`); } main();