Files
lucide/scripts/writeReleaseMetadata.mjs
Eric Fennis 5bfc736b61 New site! 🚀 (#1275)
* add new docs

* Add styling

* Move files

* Add active selection

* improve grid overview

* improve grid

* Add icon detail page

* Minor changes

* Fix icon preview

* optimize home card

* Add code examples

* Add gitignore

* correct temp directory

* Add first cusotmizer

* Add customizer

* fix images paths

* Add reset function

* Adjust category rendering

* Add packages section

* Some fixes

* Fix vercel build icon

* Small code adjustment

* move file

* Try this

* Add code groups with syntax highlighting

* Add search icon

* Cleanup

* update lockfile

* turnoff 404

* remove docs/iconMetaData.ts

* fix build

* Fix build 2

* cleanup

* Add icon customizer

* Fix build

* Add steps

* Add Button menu

* A lot off fixes!

* cleanup

* Fix build

* Css fixes

* Override menu icon

* try this to improve preformance

* minor improvements

* add comment

* add readme

* Add title

* minor fixes

* Fixes sliders + removes random backticks from index

* Added package list base, still WIP

* Added Guide+Source buttons to package list items

* Responsive support for XS screens

* Map categories count

* Adjust tooltip hover position

* Add see in action icon

* Add download options

* Aligns category list items to baseline and decreases category count weight

* Fixes event target error for categorylistitems

* Added icon release metadata builder

* Adds version badges to hero + icon detail overlay

* Added contributors.
Added Copy Angular.
Added release info to icon page.

* Centres contributor tooltip

* Fixed stroke step + added reset button

* Extracted reset button as a separate component for reusability

* Makes HomeIconCustomizerIcons less dense

* Fixes Button menu

* adjust versions and contributors styling on detail page

* Fix build?

* Fix build 2?

* Fix build 3

* Fix build 4

* Fix build 5?

* Add latest gh-icon changes

* Add comment

* Try fetch tags to retrieve release data

* try fetch all tags

* Add related icons

* Add stikcy search bar

* Add no results components

* Try to fix animation

* Try optimizing for categories

* Hide buggy animated icon

* minor fixes

* Add footer

* Add contributute link in footer

* Add copy name

* Add 100% preview icons

* remove site directory

* clean up

* Add redirects

* Fix build?

* fix redirect?

* minor improvements

* Fix icons preview on mobile

* Small preformance improvement

* Dark mode fixes for package icons

* Sort related icons by similarity + somewhat better name similarity matching

* Replace icon design guide images with uniform SVGs

* update lockfile

* Adds git clone to manually fetch the main repository for creating release metadata

* Remove initial v0.0.0 from release metadata

* Add extra CTA to no results behaviour

* Remove tags, as they are too overused

* Revert "Remove tags, as they are too overused"

This reverts commit 909b7563c0.

* Checkout icons from main

* Add absoluteStrokeWidth switch

* Add absolute strokewidth to home customizer

* Add absolute strokewidth to copy code button

* remove unused import

* compare build time

* improve build speed

* Try new release meta data script

* add fetch tags

* try with branch and remote

* try with url

* try without ssh

* Fix fetch tags in build file

* Cleanup

* Fix fallback

* improve release data

* delete relatedIcons.json, because it should be gitignored

* Add icon details

* Fix import

* minor fixes

* Try running script parallel

* Revert icon details

* include aliases in  release meta data

* Final fixes

* Final fixes 2

* minor code adjustment

* Fix build

* test

* Revert concurrent build flow

* switch back to concurrent build strategy

* revert icon changes

* update package.json

* update package.json

* dedube packages

---------

Co-authored-by: Karsa <karsa@karsa.org>
2023-06-04 16:59:38 +02:00

169 lines
4.3 KiB
JavaScript

/* eslint-disable no-restricted-syntax, no-await-in-loop */
import { simpleGit } from 'simple-git';
import semver from 'semver';
import fs from 'fs';
import path from 'path';
import { readSvgDirectory } from './helpers.mjs';
const DATE_OF_FORK = '2020-06-08T16:39:52+0100';
const git = simpleGit();
const currentDir = process.cwd();
const ICONS_DIR = path.resolve(currentDir, '../icons');
const iconJsonFiles = readSvgDirectory(ICONS_DIR, '.json');
const location = path.resolve(currentDir, '.vitepress/data', 'releaseMetaData.json');
if (fs.existsSync(location)) {
fs.unlinkSync(location);
}
const fetchAllReleases = async () => {
await git.fetch('https://github.com/lucide-icons/lucide.git', '--tags');
return Promise.all(
(await git.tag(['-l']))
.trim()
.split(/\n/)
.filter((tag) => semver.valid(tag))
.sort(semver.compare),
);
};
const tags = await fetchAllReleases();
const comparisonsPromises = tags.map(async (tag, index) => {
const previousTag = tags[index - 1];
if (!previousTag) return undefined;
const diff = await git.diff(['--name-status', '--oneline', previousTag, tag]);
const files = diff.split('\n').map((line) => {
const [status, file, renamedFile] = line.split('\t');
return { status, file, renamedFile };
});
const iconFiles = files.filter(({ file }) => file != null && file.startsWith('icons/'));
let date = (await git.show(['-s', '--format=%cI', tag])).trim();
// Fallback to dat of fork if date is not valid
if (!date.startsWith('20')) {
date = DATE_OF_FORK;
}
return {
tag,
date,
iconFiles,
};
});
const comparisons = await Promise.all(comparisonsPromises);
const newReleaseMetaData = {};
comparisons.forEach(({ tag, iconFiles, date } = {}) => {
if (tag == null) return;
iconFiles.forEach(({ status, file, renamedFile }) => {
if (file.endsWith('.json')) return;
const version = tag.replace('v', '');
const iconName = path.basename(file, '.svg');
if (newReleaseMetaData[iconName] == null) newReleaseMetaData[iconName] = {};
const releaseData = {
version,
date,
};
if (status.startsWith('R')) {
// Make sure set the old one as well
newReleaseMetaData[iconName].changedRelease = {
version,
date,
};
const renamedIconName = path.basename(renamedFile, '.svg');
if (newReleaseMetaData[renamedIconName] == null) {
newReleaseMetaData[renamedIconName] = {};
}
newReleaseMetaData[renamedIconName].changedRelease = {
version,
date,
};
}
if (status === 'A') {
if ('changedRelease' in newReleaseMetaData[iconName]) {
throw new Error(`Icon '${iconName}' has already changedRelease set.`);
}
newReleaseMetaData[iconName].createdRelease = releaseData;
newReleaseMetaData[iconName].changedRelease = releaseData;
}
if (status === 'M') {
newReleaseMetaData[iconName].changedRelease = {
version,
date,
};
}
});
});
const defaultReleaseMetaData = {
createdRelease: {
version: '0.0.0',
date: DATE_OF_FORK,
},
changedRelease: {
version: '0.0.0',
date: DATE_OF_FORK,
},
};
try {
const releaseMetaData = await Promise.all(
iconJsonFiles.map(async (iconJsonFile) => {
const iconName = path.basename(iconJsonFile, '.json');
if (iconName in newReleaseMetaData === false) {
console.error(`Could not find release metadata for icon '${iconName}'.`);
}
const contents = {
...defaultReleaseMetaData,
...(newReleaseMetaData[iconName] ?? {}),
};
const metaData = await fs.promises.readFile(path.join(ICONS_DIR, iconJsonFile), 'utf-8');
const iconMetaData = JSON.parse(metaData);
const aliases = iconMetaData.aliases ?? [];
if (aliases.length) {
aliases.forEach((alias) => {
if (alias in newReleaseMetaData === false) {
return;
}
contents.createdRelease = newReleaseMetaData[alias].createdRelease;
});
}
return [iconName, contents];
}),
);
await fs.promises.writeFile(
location,
JSON.stringify(Object.fromEntries(releaseMetaData), null, 2),
'utf-8',
);
console.log('Successfully written icon release meta files');
} catch (error) {
throw new Error(`Something went wrong generating icon release meta cache file,\n ${error}`);
}