2021-11-29 21:11:15 +00:00
|
|
|
|
const baseUrl = new URL('https://github.com/withastro/astro/blob/main/');
|
|
|
|
|
|
2021-12-02 20:04:11 +00:00
|
|
|
|
const emojis = ['🎉', '🥳', '🚀', '🧑🚀', '🎊', '🏆', '✅', '🤩', '🤖', '🙌'];
|
2021-12-07 22:08:49 +00:00
|
|
|
|
const descriptors = ['new releases', 'hot and fresh updates', 'shiny updates', 'exciting changes', 'package updates', 'awesome updates', 'bug fixes and features', 'updates'];
|
2021-12-02 20:04:11 +00:00
|
|
|
|
const verbs = [
|
2021-12-22 21:11:05 +00:00
|
|
|
|
'just went out!',
|
|
|
|
|
'just launched!',
|
|
|
|
|
'now available!',
|
|
|
|
|
'in the wild!',
|
|
|
|
|
'now live!',
|
|
|
|
|
'hit the registry!',
|
|
|
|
|
'to share!',
|
|
|
|
|
'for you!',
|
|
|
|
|
'for y’all! 🤠',
|
|
|
|
|
'comin’ your way!',
|
|
|
|
|
'comin’ atcha!',
|
|
|
|
|
'comin’ in hot!',
|
|
|
|
|
'freshly minted on the blockchain! (jk)',
|
|
|
|
|
'[is] out (now with 100% more reticulated splines!)',
|
|
|
|
|
'(as seen on TV!)',
|
|
|
|
|
'just dropped!',
|
|
|
|
|
'– artisanally hand-crafted just for you.',
|
|
|
|
|
'– oh happy day!',
|
|
|
|
|
'– enjoy!',
|
|
|
|
|
'now out. Be the first on your block to download!',
|
|
|
|
|
'made with love 💕',
|
|
|
|
|
'[is] out! Our best [version] yet!',
|
|
|
|
|
'[is] here. DOWNLOAD! DOWNLOAD! DOWNLOAD!',
|
|
|
|
|
'... HUZZAH!',
|
|
|
|
|
'[has] landed!',
|
|
|
|
|
'landed! The internet just got a little more fun.',
|
|
|
|
|
'– from our family to yours.',
|
|
|
|
|
'– go forth and build!',
|
2021-12-02 20:04:11 +00:00
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
function item(items) {
|
2021-12-22 21:11:05 +00:00
|
|
|
|
return items[Math.floor(Math.random() * items.length)];
|
2021-12-02 20:04:11 +00:00
|
|
|
|
}
|
|
|
|
|
|
2021-12-07 22:08:49 +00:00
|
|
|
|
const plurals = new Map([
|
2021-12-22 21:11:05 +00:00
|
|
|
|
['is', 'are'],
|
|
|
|
|
['has', 'have'],
|
2021-12-07 22:09:46 +00:00
|
|
|
|
]);
|
2021-12-07 22:08:49 +00:00
|
|
|
|
|
|
|
|
|
function pluralize(text) {
|
2021-12-22 21:11:05 +00:00
|
|
|
|
return text.replace(/(\[([^\]]+)\])/gm, (_, _full, match) => (plurals.has(match) ? plurals.get(match) : `${match}s`));
|
2021-12-07 22:08:49 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function singularlize(text) {
|
2021-12-22 21:11:05 +00:00
|
|
|
|
return text.replace(/(\[([^\]]+)\])/gm, (_, _full, match) => `${match}`);
|
2021-12-07 22:08:49 +00:00
|
|
|
|
}
|
|
|
|
|
|
2022-03-08 16:48:12 +00:00
|
|
|
|
const packageMap = new Map([
|
|
|
|
|
['astro', './packages/astro'],
|
|
|
|
|
['@astrojs/parser', './packages/astro-parser'],
|
|
|
|
|
['@astrojs/prism', './packages/astro-prism'],
|
|
|
|
|
['create-astro', './packages/create-astro'],
|
|
|
|
|
['@astrojs/markdown-remark', './packages/markdown/remark'],
|
|
|
|
|
['@astrojs/renderer-lit', './packages/renderers/renderer-lit'],
|
|
|
|
|
['@astrojs/renderer-preact', './packages/renderers/renderer-preact'],
|
|
|
|
|
['@astrojs/renderer-react', './packages/renderers/renderer-react'],
|
|
|
|
|
['@astrojs/renderer-solid', './packages/renderers/renderer-solid'],
|
|
|
|
|
['@astrojs/renderer-solid', './packages/renderers/renderer-solid'],
|
|
|
|
|
['@astrojs/renderer-svelte', './packages/renderers/renderer-svelte'],
|
|
|
|
|
['@astrojs/renderer-vue', './packages/renderers/renderer-vue'],
|
|
|
|
|
['@astrojs/webapi', './packages/webapi'],
|
2022-03-08 16:49:21 +00:00
|
|
|
|
]);
|
2022-03-08 16:48:12 +00:00
|
|
|
|
|
2021-11-29 21:11:15 +00:00
|
|
|
|
async function run() {
|
2021-12-22 21:11:05 +00:00
|
|
|
|
const releases = process.argv.slice(2)[0];
|
|
|
|
|
const data = JSON.parse(releases);
|
|
|
|
|
const packages = await Promise.all(
|
|
|
|
|
data.map(({ name, version }) => {
|
2022-03-08 16:48:12 +00:00
|
|
|
|
const p = packageMap.get(name);
|
|
|
|
|
if (!p) {
|
|
|
|
|
throw new Error(`Unable to find entrypoint for "${name}"!`);
|
|
|
|
|
}
|
2021-12-22 21:11:05 +00:00
|
|
|
|
return { name, version, url: new URL(`${p}/CHANGELOG.md#${version.replace(/\./g, '')}`, baseUrl).toString() };
|
|
|
|
|
})
|
|
|
|
|
);
|
2021-11-29 21:11:15 +00:00
|
|
|
|
|
2021-12-22 21:11:05 +00:00
|
|
|
|
const emoji = item(emojis);
|
|
|
|
|
const descriptor = item(descriptors);
|
|
|
|
|
const verb = item(verbs);
|
2021-12-02 20:04:11 +00:00
|
|
|
|
|
2021-12-22 21:11:05 +00:00
|
|
|
|
if (packages.length === 1) {
|
|
|
|
|
const { name, version, url } = packages[0];
|
|
|
|
|
console.log(`${emoji} \`${name}@${version}\` ${singularlize(verb)}\nRead the [release notes →](<${url}>)`);
|
|
|
|
|
} else {
|
|
|
|
|
console.log(`${emoji} Some ${descriptor} ${pluralize(verb)}\n`);
|
|
|
|
|
for (const { name, version, url } of packages) {
|
|
|
|
|
console.log(`• \`${name}@${version}\` Read the [release notes →](<${url}>)`);
|
|
|
|
|
}
|
|
|
|
|
}
|
2021-11-29 21:11:15 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
run();
|