2020-07-12 18:10:56 +09:00
|
|
|
#!/usr/bin/env node
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const fastGlob = require('fast-glob');
|
|
|
|
const Svgo = require('svgo');
|
|
|
|
const {resolve, parse} = require('path');
|
|
|
|
const {readFile, writeFile, mkdir} = require('fs').promises;
|
|
|
|
|
|
|
|
const glob = (pattern) => fastGlob.sync(pattern, {cwd: resolve(__dirname), absolute: true});
|
|
|
|
const outputDir = resolve(__dirname, '../public/img/svg');
|
|
|
|
|
|
|
|
function exit(err) {
|
|
|
|
if (err) console.error(err);
|
|
|
|
process.exit(err ? 1 : 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
async function processFile(file, {prefix = ''} = {}) {
|
2020-07-18 00:15:12 +09:00
|
|
|
let name = parse(file).name;
|
|
|
|
if (prefix) name = `${prefix}-${name}`;
|
|
|
|
if (prefix === 'octicon') name = name.replace(/-[0-9]+$/, ''); // chop of '-16' on octicons
|
2020-07-12 18:10:56 +09:00
|
|
|
|
|
|
|
const svgo = new Svgo({
|
|
|
|
plugins: [
|
|
|
|
{removeXMLNS: true},
|
|
|
|
{removeDimensions: true},
|
|
|
|
{
|
|
|
|
addClassesToSVGElement: {
|
|
|
|
classNames: [
|
|
|
|
'svg',
|
|
|
|
name,
|
|
|
|
],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
addAttributesToSVGElement: {
|
|
|
|
attributes: [
|
|
|
|
{'width': '16'},
|
|
|
|
{'height': '16'},
|
|
|
|
{'aria-hidden': 'true'},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
});
|
|
|
|
|
|
|
|
const {data} = await svgo.optimize(await readFile(file, 'utf8'));
|
|
|
|
await writeFile(resolve(outputDir, `${name}.svg`), data);
|
|
|
|
}
|
|
|
|
|
|
|
|
async function main() {
|
|
|
|
try {
|
|
|
|
await mkdir(outputDir);
|
|
|
|
} catch {}
|
|
|
|
|
2020-07-18 00:15:12 +09:00
|
|
|
for (const file of glob('../node_modules/@primer/octicons/build/svg/*-16.svg')) {
|
|
|
|
await processFile(file, {prefix: 'octicon'});
|
2020-07-12 18:10:56 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
for (const file of glob('../web_src/svg/*.svg')) {
|
|
|
|
await processFile(file);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
main().then(exit).catch(exit);
|
|
|
|
|