Coder Social home page Coder Social logo

jacobzyy / tools Goto Github PK

View Code? Open in Web Editor NEW

This project forked from iconify/tools

0.0 0.0 0.0 4.03 MB

Library for working with SVG: importing, validating, parsing, exporting.

Home Page: https://iconify.design/docs/libraries/tools/

License: MIT License

JavaScript 1.39% TypeScript 95.53% CSS 0.26% HTML 0.09% Vue 0.14% Svelte 2.59%

tools's Introduction

Iconify Tools

This library is a collection of tools for importing, exporting and processing SVG images.

Its main purpose is to convert icon sets and fonts to Iconify JSON collections, but it can be used for other purposes.

Installation

First install it by running this command:

npm install @iconify/tools --save

Functions

Functions incuded in Iconify Tools:

  • Download packages from git repository, GitHub API, GitLab API, NPM repository.
  • Import SVGs from directory (and downloaded package), Figma API.
  • Clean up, optimise, validate icons.
  • Parse or change icon palette.
  • Export icon sets in various formats.

See Iconify Tools documentation.

Limitations

This library is optinionated.

It does not allow the following content in icons:

  • Scripts and event listeners.
  • Any remote resources: images, fonts, links, etc...
  • Raster images. They do not belong in scalable icons.
  • Text. Text is rendered differently in various operating systems, so it should not be used in SVG. Convert text to shapes.
  • All tags and attributes that are not approved are removed, including all XML namespaces.

All limitations listed above are by design.

Iconify Tools library is designed to export icons that are safe to use in any environment and render identically for all users.

Example

The following code example does the following:

  • Imports set of SVG from directory.
  • Cleans up all icons.
  • Changes colors in all icons to currentColor.
  • Optimises icons.
  • Exports icons as IconifyJSON icon set.
import { promises as fs } from 'fs';
import { importDirectory } from '@iconify/tools/lib/import/directory';
import { cleanupSVG } from '@iconify/tools/lib/svg/cleanup';
import { runSVGO } from '@iconify/tools/lib/optimise/svgo';
import { parseColors, isEmptyColor } from '@iconify/tools/lib/colors/parse';

(async () => {
	// Import icons
	const iconSet = await importDirectory('svg/test', {
		prefix: 'test',
	});

	// Validate, clean up, fix palette and optimise
	iconSet.forEachSync((name, type) => {
		if (type !== 'icon') {
			return;
		}

		const svg = iconSet.toSVG(name);
		if (!svg) {
			// Invalid icon
			iconSet.remove(name);
			return;
		}

		// Clean up and optimise icons
		try {
			cleanupSVG(svg);
			parseColors(svg, {
				defaultColor: 'currentColor',
				callback: (attr, colorStr, color) => {
					return !color || isEmptyColor(color)
						? colorStr
						: 'currentColor';
				},
			});
			runSVGO(svg);
		} catch (err) {
			// Invalid icon
			console.error(`Error parsing ${name}:`, err);
			iconSet.remove(name);
			return;
		}

		// Update icon
		iconSet.fromSVG(name, svg);
	});

	// Export as IconifyJSON
	const exported = JSON.stringify(iconSet.export(), null, '\t') + '\n';

	// Save to file
	await fs.writeFile(`output/${iconSet.prefix}.json`, exported, 'utf8');
})();

Documentation

Full documentation is too big for simple README file. See Iconify Tools documentation for detailed documentation with code samples.

Sponsors

License

Library is released with MIT license.

© 2021-PRESENT Vjacheslav Trushkin

tools's People

Contributors

cyberalien avatar yunsii avatar dependabot[bot] avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.