mirror of
https://github.com/LukeHagar/sveltesociety.dev.git
synced 2025-12-06 12:47:44 +00:00
* Edit PR title/body, add $lib/data folder * Remove unused scripts/updateStars.js * Load json with import assertion
34 lines
1.3 KiB
JavaScript
34 lines
1.3 KiB
JavaScript
// @ts-check
|
|
|
|
import { writeFileSync } from 'node:fs';
|
|
import { promisify } from 'node:util';
|
|
import { exec } from 'node:child_process';
|
|
import { componentsSchema, toolsSchema } from '../src/lib/schemas.js';
|
|
import components from '../src/routes/components/components.json' assert { type: 'json' };
|
|
import tools from '../src/routes/tools/tools.json' assert { type: 'json' };
|
|
|
|
const execAsync = promisify(exec);
|
|
|
|
const data = [...componentsSchema.parse(components), ...toolsSchema.parse(tools)];
|
|
|
|
const npm = await Promise.all(
|
|
data.map((pkg) => processPackage(pkg).catch((error) => console.log(error.message)))
|
|
).then((values) => {
|
|
return values.reduce((result, value) => Object.assign(result, value), {});
|
|
});
|
|
|
|
writeFileSync('src/lib/data/npm.json', JSON.stringify(npm));
|
|
|
|
/** @param {ReturnType<typeof data>[0]} pkg */
|
|
async function processPackage(pkg) {
|
|
if (!pkg.npm) {
|
|
throw new Error(`npm field missing from ${pkg.title} (skipping)`);
|
|
}
|
|
const { stdout } = await execAsync(`npm view ${pkg.npm} --json`);
|
|
const data = JSON.parse(stdout.toString());
|
|
const version = data.version;
|
|
const date = data.time[version];
|
|
const support = data.peerDependencies?.svelte ? data.peerDependencies.svelte : 'Unknown';
|
|
return { [pkg.npm]: { version: version, date: date, support: support } };
|
|
}
|