diff options
Diffstat (limited to 'build')
-rwxr-xr-x | build/generate-images.js | 17 | ||||
-rwxr-xr-x | build/generate-svg.js | 31 |
2 files changed, 19 insertions, 29 deletions
diff --git a/build/generate-images.js b/build/generate-images.js index c9108ce713..bea36321e3 100755 --- a/build/generate-images.js +++ b/build/generate-images.js @@ -2,7 +2,7 @@ 'use strict'; const imageminZopfli = require('imagemin-zopfli'); -const Svgo = require('svgo'); +const {optimize, extendDefaultPlugins} = require('svgo'); const {fabric} = require('fabric'); const {readFile, writeFile} = require('fs').promises; const {resolve} = require('path'); @@ -24,14 +24,15 @@ function loadSvg(svg) { async function generate(svg, outputFile, {size, bg}) { if (outputFile.endsWith('.svg')) { - const svgo = new Svgo({ - plugins: [ - {removeDimensions: true}, - {addAttributesToSVGElement: {attributes: [{width: size}, {height: size}]}}, - ], + const {data} = optimize(svg, { + plugins: extendDefaultPlugins([ + 'removeDimensions', + { + name: 'addAttributesToSVGElement', + params: {attributes: [{width: size}, {height: size}]} + }, + ]), }); - - const {data} = await svgo.optimize(svg); await writeFile(outputFile, data); return; } diff --git a/build/generate-svg.js b/build/generate-svg.js index 09e08e48dc..97053a2958 100755 --- a/build/generate-svg.js +++ b/build/generate-svg.js @@ -2,7 +2,7 @@ 'use strict'; const fastGlob = require('fast-glob'); -const Svgo = require('svgo'); +const {optimize, extendDefaultPlugins} = require('svgo'); const {resolve, parse} = require('path'); const {readFile, writeFile, mkdir} = require('fs').promises; @@ -25,31 +25,20 @@ async function processFile(file, {prefix, fullName} = {}) { if (prefix === 'octicon') name = name.replace(/-[0-9]+$/, ''); // chop of '-16' on octicons } - const svgo = new Svgo({ - plugins: [ - {removeXMLNS: true}, - {removeDimensions: true}, + const {data} = optimize(await readFile(file, 'utf8'), { + plugins: extendDefaultPlugins([ + 'removeXMLNS', + 'removeDimensions', { - addClassesToSVGElement: { - classNames: [ - 'svg', - name, - ], - }, + name: 'addClassesToSVGElement', + params: {classNames: ['svg', name]}, }, { - addAttributesToSVGElement: { - attributes: [ - {'width': '16'}, - {'height': '16'}, - {'aria-hidden': 'true'}, - ], - }, + name: 'addAttributesToSVGElement', + params: {attributes: [{'width': '16'}, {'height': '16'}, {'aria-hidden': 'true'}]}, }, - ], + ]), }); - - const {data} = await svgo.optimize(await readFile(file, 'utf8')); await writeFile(resolve(outputDir, `${name}.svg`), data); } |