mirror of
https://github.com/lucide-icons/lucide.git
synced 2025-12-16 06:17:42 +01:00
* New setup for new NPM package * Add build scripts for dist * Add introduction readme * Refactor names * update package.json * remove log * rename variable * Factoring * Improve optimize script * Add eslint config * Eslint fixes * rename import * Move packeges * Setup rollup and build progress * Refactor scripts * fix lint error * remove lint disabler * Bring back old libraries * add indentation * reset packages directory * remove vscode setting files * 0.1.0-alpha.0 * new version * 0.1.0-alpha.1 * Fix build process * Add create element to the entry file * update version number * publish new alhpa version * fixing bugs * Add jest and tests * replace with XML createElement * set new version * Fix svg generation * Add tests for main library * Update docs * Adjust tests and selectors * update the spec * Update README.md * Update README.md * Update README.md * update version * Update README.md * Move function to helpers file * rename license, package and readme * Fix build files * rename packages Co-authored-by: Eric Fennis <eric.fennis@endurance.com>
58 lines
1.3 KiB
JavaScript
58 lines
1.3 KiB
JavaScript
/* eslint-disable import/no-extraneous-dependencies */
|
|
import Svgo from 'svgo';
|
|
import cheerio from 'cheerio';
|
|
import { format } from 'prettier';
|
|
|
|
import DEFAULT_ATTRS from './default-attrs.json';
|
|
|
|
/**
|
|
* Process SVG string.
|
|
* @param {string} svg - An SVG string.
|
|
* @param {Promise<string>}
|
|
*/
|
|
function processSvg(svg) {
|
|
return (
|
|
optimize(svg)
|
|
.then(setAttrs)
|
|
.then(format)
|
|
// remove semicolon inserted by prettier
|
|
// because prettier thinks it's formatting JSX not HTML
|
|
.then(svg => svg.replace(/;/g, ''))
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Optimize SVG with `svgo`.
|
|
* @param {string} svg - An SVG string.
|
|
* @returns {Promise<string>}
|
|
*/
|
|
function optimize(svg) {
|
|
const svgo = new Svgo({
|
|
plugins: [
|
|
{ convertShapeToPath: false },
|
|
{ mergePaths: false },
|
|
{ removeAttrs: { attrs: '(fill|stroke.*)' } },
|
|
{ removeTitle: true },
|
|
],
|
|
});
|
|
|
|
return new Promise(resolve => {
|
|
svgo.optimize(svg, ({ data }) => resolve(data));
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Set default attibutes on SVG.
|
|
* @param {string} svg - An SVG string.
|
|
* @returns {string}
|
|
*/
|
|
function setAttrs(svg) {
|
|
const $ = cheerio.load(svg);
|
|
|
|
Object.keys(DEFAULT_ATTRS).forEach(key => $('svg').attr(key, DEFAULT_ATTRS[key]));
|
|
|
|
return $('body').html();
|
|
}
|
|
|
|
export default processSvg;
|