2022-06-06 12:27:25 +09:00
|
|
|
#!/usr/bin/env node
|
2021-04-08 19:41:57 +09:00
|
|
|
import fastGlob from 'fast-glob';
|
2021-08-17 14:32:48 +09:00
|
|
|
import {optimize} from 'svgo';
|
2022-12-21 07:15:47 +09:00
|
|
|
import {parse} from 'node:path';
|
|
|
|
import {readFile, writeFile, mkdir} from 'node:fs/promises';
|
|
|
|
import {fileURLToPath} from 'node:url';
|
2024-02-24 07:07:27 +09:00
|
|
|
import {exit} from 'node:process';
|
2020-07-12 18:10:56 +09:00
|
|
|
|
2022-06-06 12:27:25 +09:00
|
|
|
const glob = (pattern) => fastGlob.sync(pattern, {
|
|
|
|
cwd: fileURLToPath(new URL('..', import.meta.url)),
|
|
|
|
absolute: true,
|
|
|
|
});
|
2020-07-12 18:10:56 +09:00
|
|
|
|
2024-02-24 07:07:27 +09:00
|
|
|
function doExit(err) {
|
2020-07-12 18:10:56 +09:00
|
|
|
if (err) console.error(err);
|
2024-02-24 07:07:27 +09:00
|
|
|
exit(err ? 1 : 0);
|
2020-07-12 18:10:56 +09:00
|
|
|
}
|
|
|
|
|
2020-12-05 19:09:09 +09:00
|
|
|
async function processFile(file, {prefix, fullName} = {}) {
|
|
|
|
let name;
|
|
|
|
if (fullName) {
|
|
|
|
name = fullName;
|
|
|
|
} else {
|
|
|
|
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
|
|
|
|
2023-03-21 14:39:27 +09:00
|
|
|
// Set the `xmlns` attribute so that the files are displayable in standalone documents
|
|
|
|
// The svg backend module will strip the attribute during startup for inline display
|
2021-03-22 13:04:19 +09:00
|
|
|
const {data} = optimize(await readFile(file, 'utf8'), {
|
2021-08-17 14:32:48 +09:00
|
|
|
plugins: [
|
|
|
|
{name: 'preset-default'},
|
|
|
|
{name: 'removeDimensions'},
|
2021-09-09 16:06:54 +09:00
|
|
|
{name: 'prefixIds', params: {prefix: () => name}},
|
2021-08-17 14:32:48 +09:00
|
|
|
{name: 'addClassesToSVGElement', params: {classNames: ['svg', name]}},
|
2023-03-21 14:39:27 +09:00
|
|
|
{
|
|
|
|
name: 'addAttributesToSVGElement', params: {
|
|
|
|
attributes: [
|
|
|
|
{'xmlns': 'http://www.w3.org/2000/svg'},
|
|
|
|
{'width': '16'}, {'height': '16'}, {'aria-hidden': 'true'},
|
|
|
|
]
|
|
|
|
}
|
|
|
|
},
|
2021-08-17 14:32:48 +09:00
|
|
|
],
|
2020-07-12 18:10:56 +09:00
|
|
|
});
|
2022-06-06 12:27:25 +09:00
|
|
|
|
2023-07-19 01:06:43 +09:00
|
|
|
await writeFile(fileURLToPath(new URL(`../public/assets/img/svg/${name}.svg`, import.meta.url)), data);
|
2020-07-12 18:10:56 +09:00
|
|
|
}
|
|
|
|
|
2020-12-05 19:09:09 +09:00
|
|
|
function processFiles(pattern, opts) {
|
|
|
|
return glob(pattern).map((file) => processFile(file, opts));
|
|
|
|
}
|
|
|
|
|
2020-07-12 18:10:56 +09:00
|
|
|
async function main() {
|
|
|
|
try {
|
2023-07-19 01:06:43 +09:00
|
|
|
await mkdir(fileURLToPath(new URL('../public/assets/img/svg', import.meta.url)), {recursive: true});
|
2020-07-12 18:10:56 +09:00
|
|
|
} catch {}
|
|
|
|
|
2020-12-05 19:09:09 +09:00
|
|
|
await Promise.all([
|
2022-06-06 12:27:25 +09:00
|
|
|
...processFiles('node_modules/@primer/octicons/build/svg/*-16.svg', {prefix: 'octicon'}),
|
|
|
|
...processFiles('web_src/svg/*.svg'),
|
2020-12-05 19:09:09 +09:00
|
|
|
]);
|
2020-07-12 18:10:56 +09:00
|
|
|
}
|
|
|
|
|
2024-02-17 06:41:23 +09:00
|
|
|
try {
|
2024-02-24 07:07:27 +09:00
|
|
|
doExit(await main());
|
2024-02-17 06:41:23 +09:00
|
|
|
} catch (err) {
|
2024-02-24 07:07:27 +09:00
|
|
|
doExit(err);
|
2024-02-17 06:41:23 +09:00
|
|
|
}
|