You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

generate-svg.js 1.7KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import fastGlob from 'fast-glob';
  2. import {optimize, extendDefaultPlugins} from 'svgo';
  3. import {resolve, parse, dirname} from 'path';
  4. import {readFile, writeFile, mkdir} from 'fs/promises';
  5. import {fileURLToPath} from 'url';
  6. const __dirname = dirname(fileURLToPath(import.meta.url));
  7. const glob = (pattern) => fastGlob.sync(pattern, {cwd: resolve(__dirname), absolute: true});
  8. const outputDir = resolve(__dirname, '../public/img/svg');
  9. function exit(err) {
  10. if (err) console.error(err);
  11. process.exit(err ? 1 : 0);
  12. }
  13. async function processFile(file, {prefix, fullName} = {}) {
  14. let name;
  15. if (fullName) {
  16. name = fullName;
  17. } else {
  18. name = parse(file).name;
  19. if (prefix) name = `${prefix}-${name}`;
  20. if (prefix === 'octicon') name = name.replace(/-[0-9]+$/, ''); // chop of '-16' on octicons
  21. }
  22. const {data} = optimize(await readFile(file, 'utf8'), {
  23. plugins: extendDefaultPlugins([
  24. 'removeXMLNS',
  25. 'removeDimensions',
  26. {
  27. name: 'addClassesToSVGElement',
  28. params: {classNames: ['svg', name]},
  29. },
  30. {
  31. name: 'addAttributesToSVGElement',
  32. params: {attributes: [{'width': '16'}, {'height': '16'}, {'aria-hidden': 'true'}]},
  33. },
  34. ]),
  35. });
  36. await writeFile(resolve(outputDir, `${name}.svg`), data);
  37. }
  38. function processFiles(pattern, opts) {
  39. return glob(pattern).map((file) => processFile(file, opts));
  40. }
  41. async function main() {
  42. try {
  43. await mkdir(outputDir);
  44. } catch {}
  45. await Promise.all([
  46. ...processFiles('../node_modules/@primer/octicons/build/svg/*-16.svg', {prefix: 'octicon'}),
  47. ...processFiles('../web_src/svg/*.svg'),
  48. ...processFiles('../public/img/gitea.svg', {fullName: 'gitea-gitea'}),
  49. ]);
  50. }
  51. main().then(exit).catch(exit);