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

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. import fastGlob from 'fast-glob';
  2. import {optimize} 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: [
  25. {name: 'preset-default'},
  26. {name: 'removeXMLNS'},
  27. {name: 'removeDimensions'},
  28. {name: 'prefixIds', params: {prefix: () => name}},
  29. {name: 'addClassesToSVGElement', params: {classNames: ['svg', name]}},
  30. {name: 'addAttributesToSVGElement', params: {attributes: [{'width': '16'}, {'height': '16'}, {'aria-hidden': 'true'}]}},
  31. ],
  32. });
  33. await writeFile(resolve(outputDir, `${name}.svg`), data);
  34. }
  35. function processFiles(pattern, opts) {
  36. return glob(pattern).map((file) => processFile(file, opts));
  37. }
  38. async function main() {
  39. try {
  40. await mkdir(outputDir);
  41. } catch {}
  42. await Promise.all([
  43. ...processFiles('../node_modules/@primer/octicons/build/svg/*-16.svg', {prefix: 'octicon'}),
  44. ...processFiles('../web_src/svg/*.svg'),
  45. ...processFiles('../public/img/gitea.svg', {fullName: 'gitea-gitea'}),
  46. ]);
  47. }
  48. main().then(exit).catch(exit);