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

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