Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

svg-to-ts

kreuzerk68.9kISC12.0.0TypeScript support: included

Build amazing svg icon libraries

SVG, TypeScript, Icons, Build-tool

readme

Logo

Supports Angular Supports React Supports Vanilla JS / TS

npm GitHub Repo stars

npms.io (final) GitHub Workflow GitHub npm

All Contributors

What is svg-to-ts?

svg-to-ts is a helper tool that converts your SVG icons to TypeScript or TSX. svg-to-ts can convert SVGs to either one TypeScript / TSX file with exported constants, multiple TypeScript files or even compiled JavaScript files with according TS declaration files. Furthermore, it generates all typings in form of interfaces and types.

The generated output can then be used in combination with a iconregistry to create a tree shakable icon library. (More informations...)

Who is this for?

svg-to-ts is designed for autors of component libraries, icon libraries and SPA authors. Our examples and tutorials are made with Angular, however svg-to-ts can also be used with other frameworks such as React or vanilla TypeScript / JavaScript.

Why you should use svg-to-ts

  • svg-to-ts helps you provide icons in a tree shakable and performant way.
  • You get free step to step guides in form of blog posts, that walk you through the process of creating your own tree shakable icon library
  • svg-to-ts optimizes your SVG icons under the hood
  • svg-to-ts automatically generates types and interfaces for your icons to improve typesafety
  • svg-to-ts was developed based on the experiences of providin an icon library for a large enterprise.
  • svg-to-ts offers the possibility to generate TSX files (react components).
  • offers three different conversion modes ('object', 'constants' and 'files')
  • each method is highly configurable to supports multiple use cases.

Step by step guide on how to create your icon library

We created multiple tutorials to show you how you can use svg-to-ts in the best way. We have two step by step guides. A video course and a blog post. Both cover the same content. Feel free to choose the format you prefer.

Video tutorials

IMAGE ALT TEXT HERE

Written tutorial

This blog post guides you through the process of building your own icon library with svg-to-ts. Logo

How to use svg-to-ts

svg-to-ts is a command line tool, it can either be used directly in your terminal or via npm script.

Usage

Binaries

svg-to-ts provides three different binaries.

  • svg-to-ts-object
  • svg-to-ts-constants
  • svg-to-ts-files

You can either run those binaries with npx

npx -p svg-to-ts svg-to-ts-object

or you can add a new script in your package.json.

"name": "my-icon-library",
"version": "3.4.0",
"scripts": {
  "generate-icons": "svg-to-ts"
}

Configuration

When executing a binary svg-to-ts automatically applies some defaults. However, you have multiple ways to configure svg-to-ts. To get a list of available options you can either execute the binary of your choice with the --help argument or you can find all the available options for your conversion type here in the docs:

Once you found your configurations you have the following possibilities to configure svg-to-ts:

  • Passing arguments to the binary
  • Adding a configuration object in the package.json
  • Adding a .svg-to-tsrc file (javascript, json , yaml or yml) in the root of your project or a path of you choice.

Passing arguments to the binary

When choosing this option you directly pass the arguments to your binary.

svg-to-ts-files -s './inputfiles/*.svg' --compileSources true --additionalModelOutputPath ./additional

A complete list of the available arguments can be found by using the --help argument.

svg-to-ts-files --help

When you start using svg-to-ts in bigger projects, configuration may get more sophisticated. At this point command line arguments are hard to read.

Configure svg-to-ts over package.json

To configure svg-to-ts over package.json you can add a svg-to-ts key in your package.json and use the config options. Once you run svg-to-ts those configurations will be picked up. The config object can eiter be an object or an array containing multiple configurations.

{
  "name": "my-icon-library",
  "version": "3.4.0",
  "scripts": {
    "generate-icons": "svg-to-ts"
  },
  "svg-to-ts": {
    "srcFiles": ["./projects/dinosaur-icons/icons/**/*.svg"],
    "outputDirectory": "./projects/dinosaur-icons/icons",
    "interfaceName": "DinosaurIcon",
    "typeName": "dinosaurIcon",
    "prefix": "dinosaurIcon",
    "svgoConfig": {
      "plugins": ["cleanupAttrs"]
    },
    "fileName": "dinosaur-icon.model",
    "additionalModelOutputPath": "./projects/dinosaur-icons/src/lib",
    "compileSources": true
  }
}

#

Configuration file

To configure svg-to-ts over a .rc file you can add a .svg-to-tsrc file in the root of your project and use the config options. Once you run svg-to-ts those configurations will be picked up.

{
  "srcFiles": ["./projects/dinosaur-icons/icons/**/*.svg"],
  "outputDirectory": "./projects/dinosaur-icons/icons",
  "interfaceName": "DinosaurIcon",
  "typeName": "dinosaurIcon",
  "prefix": "dinosaurIcon",
  "fileName": "dinosaur-icon.model",
  "svgoConfig": {
    "plugins": ["cleanupAttrs"]
  },
  "additionalModelOutputPath": "./projects/dinosaur-icons/src/lib",
  "compileSources": true
}

An alternative for bigger projects is to use a JavaScript-based configuration file. The main advantage here is there you can create dynamic configurations, but also use plain-old JavaScript objects, allowing you to add comments, etc. This is useful for more complex configurations where comments can clarify why options are defined in a certain way.

JS configurations must be defined as a CommonJS module. Whenever you want to use a JS configuration file your rc file has to end with .js.

Here's an example:

const svgToTsConfig = {
  srcFiles: ['./libs/web-icons/icons/**/*.svg'],
  outputDirectory: './libs/web-icons/src/lib',
  interfaceName: 'MyIcon',
  typeName: 'MyIconName',
  generateType: true,
  modelFileName: 'whatever-icon.model',
  additionalModelOutputPath: './libs/web-icons/src/lib',
  iconsFolderName: 'generated',
  delimiter: 'SNAKE',
  barrelFileName: 'generated-icons-barrel',
  svgoConfig: {
    plugins: ['cleanupAttrs']
  },
  compileSources: false
};

module.exports = svgToTsConfig;

Using a custom path

In case you want to put your configuration under a custom path, you can use the --config property to specify a path your configuration. For example svg-to-ts --config ./myconfig.json.

ConversionTypes

svg-to-ts offers three different kinds of conversion types; Converting your icons to a single object, converting your icons to constants or converting your icons to single files. Each approach is designed to solve a specific kind of problem. You can switch between approaches by passing conversionType property (object, constants or files).

1. Converting to a single object (conversionType==='object')

In this scenario the SVG icons are converted to a single object. It's an approach that is suitable if your icon registry accepts an object with the filename as key and the svg data as key.

Available options:

--version type default description
fileName string my-icons file name of the generated file
tsx boolean false Generate TSX file which can be used as React components out of the box
delimiter CAMEL, KEBAB, SNAKE, UPPER, NONE CAMEL delimiter which is used to generate the types and name properties
svgoConfig null or config object check help command - to large to display by default we search for a svgo.config.js file in the root or an inline configuration object
srcFiles string "/*.svg" input files matching the given filename pattern
outputDirectory string "./dist" name of the output directory
objectName string default - export name of the exported const - if nothing is set - default export will be used
verbose boolean false defines if the log should contain additional information. Can be useful for debugging
generateType boolean true defines if a type should be generated
typeName string MyIconType name of the type to be used when generateType is set to true
namePrefix string | prefix to be used for the name property included in the generated constant

Example usage

Let's say we have the following four svg files in a inputfiles folder.

  • expressionless.svg
  • full.svg
  • laughing.svg
  • smiling-face.svg

We can now run svg-to-ts-object -s ./inputfiles -o ./dist and we end up with the following file in our dist folder.

Sample output

export default {
  expressionLess: '<svg xmlns="http://ww...',
  full: '<svg xmlns="http://...',
  laughing: '<svg xmlns="http://ww...',
  smilingFace: '<svg xmlns="http://www....'
} as { [key in MyIconType]: string };

export type MyIconType = 'expressionLess' | 'full' | 'laughing' | 'smilingFace';

2. Multiple constants - Treeshakable and typesafe with one file (conversionType==='constants')

This approach converts your svg icons into multiple constants in the same file so that they can be used in combination with an icon registry. It furthermore also generates all necssary types. We wrote a step to step guide that explains this approach further and helps you create an icon library with this approach. Find out more in this blogpost

Output scenario one Only the icons included in the consuming SPA also end up in the final bundle of the SPA.

Available options:

--version type default description
tsx boolean false Generate TSX file which can be used as React components out of the box
generateType boolean false defines if a type should be generated
typeName string myIcons name of the type to be used when generateType is set to true
generateTypeObject boolean false generate type object
generateEnum boolean false generate enum object
prefix string myIcon prefix for the generated svg constants
namePrefix string | prefix to be used for the name property included in the generated constant
interfaceName string MyIcon name for the generated interface
fileName string my-icons file name of the generated file
enumName string MyIcons name for the generated enum
delimiter CAMEL, KEBAB, SNAKE, UPPER, NONE SNAKE delimiter which is used to generate the types and name properties
svgoConfig string or config object check help command - to large to display a path to your svgoConfiguration JSON file or an inline configuration object
srcFiles string "/*.svg" input files matching the given filename pattern
outputDirectory string "./dist" name of the output directory
exportCompleteIconSet boolean true exports a complete icon set
completeIconSetName string completeIconSet Default name of the exported variable
verbose boolean false defines if the log should contain additional information. Can be useful for debugging

Example usage

Let's say we have the following four svg files in a inputfiles folder.

  • expressionless.svg
  • full.svg
  • laughing.svg
  • smiling-face.svg

We can now run svg-to-ts-constants -s ./inputfiles -o ./dist and we end up with the following file in our dist folder.

Sample output

export const myIconExpressionLess: {
  name: 'expression_less',
  data: string
} = {
  name: 'expression_less',
  data: `<svg xmlns="http://...`
};
export const myIconFull: {
  name: 'full',
  data: string
} = {
  name: 'full',
  data: `<svg xmlns="http://www...`
};
export const myIconLaughing: {
  name: 'laughing',
  data: string
} = {
  name: 'laughing',
  data: `<svg xmlns="http://www.w...`
};
export const myIconSmilingFace: {
  name: 'smiling_face',
  data: string
} = {
  name: 'smiling_face',
  data: `<svg xmlns="http://www.w3...`
};
/* ⚠️ Do not edit this file - this file is generated by svg-to-ts*/

export type myIcons = 'expression_less' | 'full' | 'laughing' | 'smiling_face';
export interface MyIcon {
  name: myIcons;
  data: string;
}

3. Tree shakable and optimized for lazy loading (conversionType==='files')

This is the most sophisticated approach and also the approach that doesn't only support tree shaking but also supports code splitting which is especially usefull in scenarios where you are using lazy loading.

(Previously, this was the optimizeForLazyLoading option but it has been removed in version 4.3.0.)

Here's a step by step guide on how to create an icon library that is optimized for tree shaking

fully tree shakable Often, having the SVGs in a single file is enough. However, if you are in a more complex environment with bigger business applications, you may want to make the icons even more tree shakable.

In Angular, for example, having all icons in a single file shakes out the icons that are not used. However, icons always end up together in a chunk. The conversionOption = files allows you to configure svg-to-ts that icons are generated in a way that they can even be split to lazy loaded chunks. Means not only the amount of the icons in the chunk gets reduced, but also, where they end up. Means, an icon that is only used in a lazy loaded Angular feature module, will only end up there.

Available options:

--version type default description
barrelFileName string index name of the generated type
tsx boolean false Generate TSX file which can be used as React components out of the box
generateType boolean false defines if a type should be generated
typeName string myIcons name of the type to be used when generateType is set to true
generateTypeObject boolean false generate type object
generateEnum boolean false generate enum object
exportCompleteIconSet boolean false Specifies if the complete icon set should be exported or not (can be very handy for showcases)
completeIconSetName string completeIconSet Name of the generated complete icon set (only effective if exportCompleteIconSet is set to true)
prefix string myIcon prefix for the generated svg constants
namePrefix string | prefix to be used for the name property included in the generated constant
interfaceName string MyIcon name for the generated interface
modelFileName string my-icons file name of the generated file
enumName string MyIcons name for the generated enum
delimiter CAMEL, KEBAB, SNAKE, UPPER, NONE SNAKE delimiter which is used to generate the types and name properties
srcFiles string "/*.svg" input files matching the given filename pattern
svgoConfig null or config object check help command - to large to display by default we search for a svgo.config.js file in the root or an inline configuration object
outputDirectory string "./dist" name of the output directory
additionalModelOutputPath string null if a path is specified we will generate an additional file containing interface and type to this path - can be useful to improve type safety
iconsFolderName string "build" name of the folder we will build the TypeScript files to
compileSources boolean false If set to false, we generate a TypeScript file for each SVG. If set to true we will allready compile those TypeScript files and generate JavaScript files and declaration files
compilationOutput ESM, UMD, ESM_AND_UMD ESM Sets the compilation output. This depends on your target audience. Some consumers require, ESM some UMD. You can choose the correct one or even compile to both.
verbose boolean false defines if the log should contain additional information. Can be useful for debugging

Generating UMD and ESM bundles

When you choose to generate UMD and ESM bundles the generated output will end up in a folder named cjs and esm. In order to correctly access those folders you have to add a exports map to the package.json of your library.

  "main": "./umd/index.js",
  "module": "./esm/index.mjs",
  "exports": {
    ".": {
      "import": "./esm/index.mjs",
      "require": "./umd/index.js"
    }
  }

Example usage

Let's say we have the following four svg files in a inputfiles folder.

  • expressionless.svg
  • full.svg
  • laughing.svg
  • smiling-face.svg

We can now run svg-to-ts-files -s ./inputfiles -o ./dist and we end up with the following file in our dist folder.

Sample output

Output scenario two

SVGO - SVG optimization

Under the hood we use the svgo project to optimize the svg icons. To configure SVGO you can add a svgo.config.js file to your root. Check out the official svgo page for further docs about the configuration.

Note: If you dont pass any options, svgo will apply some default options (more)

Starter project

If you want to build a standalone icon library we recommend you to checkout the svg-icon-lib-starter project on GitHub. This project allows you to build an astonishing framework-agnostic SVG icon library with ease. Out of the box icon optimization, build process, and icon showcase. 🚀

Angular builder

In case you are working with Angular and prefer the usage of a builder we recommend you to check out our offical Angular builder.

FAQ

Which approach should I use

This depends on your use case. If you have a simple application, it's probably enought to go with the single file or even a object. If you build a framework that is used by multiple teams, then you should probably go with the fully tree shakable scenario (generating multiple files).

Is it possilbe to create a standalone library?

Yes, it is. The current configurations also allow you to put your icon registry inside the component library and the icons in a dedicated npm package. This has the following advantages:

  • Icons can be used with different registries
  • Simplified build process
  • Icons can be released independent of the component library
  • No need to let svg-to-ts compile the icons - just set the compile flag to false.

Can I use the icons to generate a type?

If you have a method that decides which icon should be returned its useful to add a return type. To do so you can take advantage of the name subset helper generated by svg-to-ts. The name of the helper will be dynamically generated depending upon the value provided for the interfaceName property. An interfaceName of MyIcon will generate a helper called MyIconNameSubset as shown in the following example.

import {IconNameSubset, myIconSmile, myIconLaugh} from 'my-icon-lib';

type emojiIcons = MyIconNameSubset<[typeof myIconSmile, typeof myIconLaugh]>;

// resulting type is equal to type = 'smile' | 'laugh';

myMethod(): emojiIcons {
  // do stuff here
}

Contributors ✨

Thanks goes to these wonderful people (emoji key):

Kevin Kreuzer
Kevin Kreuzer

💻 🎨 📖 🤔 🚇 🚧 ⚠️
Shahar Kazaz
Shahar Kazaz

💻 📖 🤔 🚧 ⚠️
Felipe Plets
Felipe Plets

💻 📖 🤔 🚧 ⚠️
Raphael Ochsenbein
Raphael Ochsenbein

💻 📖 🤔 🚧 ⚠️
Guillaume M
Guillaume M

💻 📖 🤔 🚧 ⚠️
Jaime Velay Valor
Jaime Velay Valor

💻
Glenn Greibesland
Glenn Greibesland

💻
MrP
MrP

📖
Sebastien Dubois
Sebastien Dubois

📖
Andrew Polhill
Andrew Polhill

💻 🐛 📖 🤔
Joshua Vinters
Joshua Vinters

📖
Matthäus G. Chajdas
Matthäus G. Chajdas

📖
Julian Kimmig
Julian Kimmig

💻
Fernando Montoya
Fernando Montoya

📖
Alexey Evenkov
Alexey Evenkov

💻
nmastereal
nmastereal

💻
Katya Pavlenko
Katya Pavlenko

💻 📖 🤔
Liran Tal
Liran Tal

📖
Ikko Ashimine
Ikko Ashimine

📖
Theo Tonge
Theo Tonge

💻 📖 ⚠️
Kasper Christensen
Kasper Christensen

📖
Antonio
Antonio

📖
weihsma
weihsma

💻 📖
Tomas Trajan
Tomas Trajan

💻
Cory Lewis
Cory Lewis

📖
Logan Cool
Logan Cool

🐛
Justin Dietz
Justin Dietz

🐛 💻 🤔 ⚠️

This project follows the all-contributors specification. Contributions of any kind welcome!

changelog

12.0.0 (2024-02-18)

Features

  • updates generateTypeHelper to use type keyword and updates prettier version (2f3d9ee), closes #242

BREAKING CHANGES

  • Typescript < 3.8 is no longer supported, please update to typescript >= 3.8

11.0.1 (2023-11-14)

Bug Fixes

  • tsx: use the correct type for tsx props (00348a9), closes #226

11.0.0 (2023-10-31)

Features

  • esm: use .mjs ext in import / export statements of compiled files (67de319)

BREAKING CHANGES

  • esm: add .mjs extenstion in import / export statements

  • support for esbuild

10.1.0 (2023-09-03)

Features

  • delimiter: introduce new delimiter type NONE (70e47e3)

10.0.0 (2023-03-07)

Features

  • svgo: bump svgo to the latest version (06f2fad), closes #207

BREAKING CHANGES

  • svgo: SVGO 3 - See config changes on the official svgo side

9.0.0 (2023-01-03)

Bug Fixes

  • esm: deliver correct esm files (a16137d), closes #201

BREAKING CHANGES

  • esm: Previously esm files were delivered with a .js ending. Now they will be delivered with a .mjs ending

8.9.0 (2022-10-13)

Features

  • adds-pops-to-tsx-const-svg-components (3180fac)

8.8.1 (2022-06-21)

Bug Fixes

  • error for too many icons in completeIconSet (664beba)
  • missing argument for generateCompleteIconSet (1f1a4b5)

8.8.0 (2022-06-17)

Features

8.7.1 (2022-06-14)

Bug Fixes

  • compilation: adjust generated UMD output directory (4b9d12a)

8.7.0 (2022-06-14)

Features

  • compilation: add new compilation outputs (257edf8)

8.6.1 (2022-04-30)

Bug Fixes

  • badges: reference correct badge in README (e5b273f)

8.6.0 (2022-04-30)

Features

  • enum: generate enums for constants (dc20ced), closes #165

8.5.0 (2022-04-24)

Features

  • (tsx): add tsx constants conversion (5baac39), closes #159
  • (tsx): generate SVG constants into multiple TSX files (f482cdd), closes #159
  • (tsx) add tsx option and add object converter: accepts a TSX flag for object conversion (76729aa), closes #159

8.4.0 (2022-03-21)

Features

  • converter: add notification about using default values (493865a)
  • converter: add typeName for object generation (e9c6194)
  • converter: fix default typeName + use it in options collector (9052b44)

8.3.1 (2022-02-21)

Bug Fixes

  • flag handling: only apply default for non provided flags (e2b42f1), closes #156

8.3.0 (2022-02-04)

Bug Fixes

  • configoptions: add export complete icon set as config options (6df1b7e)

Features

  • constants: export all generated constants by default and add configuration option (cd43dcb), closes #132

8.2.0 (2022-02-03)

Features

  • read: fail early if no srcFiles are found (c8a1a31), closes #150

8.1.0 (2022-02-03)

Features

  • completeiconset: add option to configure the name of the complete icon set (4cd5c53), closes #148

8.0.1 (2022-02-03)

Bug Fixes

  • infomessage: log correct conversion type (bb50299), closes #146

8.0.0 (2022-02-02)

Bug Fixes

  • imports: remove leftover imports (6d26dec)
  • options: adjust scripts and add missing options (9efd1c9)

Features

  • binaries: export 3 new binaries (0c389eb)
  • binaries: provide new binaries (cd8ddc0)

BREAKING CHANGES

  • binaries: Instead of providing one binary, svg-to-ts we now provide 3 binaries, one for file, object and one for constants

143

7.1.1 (2022-01-15)

Bug Fixes

  • file-helper: add missing comma and release latest file helper fix (ea0c1ab)

7.1.0 (2021-10-24)

Features

  • enum: add enum type option (630f8f4)

7.0.0 (2021-10-05)

chore

  • (svgo) update svgo to v2: update svgo to v2 - config object change (688223e), closes #127

BREAKING CHANGES

  • (svgo) update svgo to v2: svg-to-ts now ships with svgo 2. SVGO 2 has different syntax of passing configuration. Furthermore we use the SVGO default object and dont introduce a custom fallback anymore

6.0.2 (2021-09-06)

Bug Fixes

  • typo: Generate barrel file (03f58e1)

6.0.1 (2021-04-09)

Bug Fixes

  • 🐛 handle large icon sets > 10k. Closes: 115 (133e16b)

6.0.0 (2020-12-06)

Bug Fixes

  • 🐛 ensures name subset helper always has a unique name (d1a5d69), closes #91
  • 🐛 start spinner on generation start (6f34ab0)

Features

  • 🎸 add verbose logging feature (068eb1f)
  • 🎸 logging steps with spinners (55d7685)

BREAKING CHANGES

  • The IconNameSubset helper is now dynamically generated based off of the interfaceName property. Any references to this will need updating.

5.7.1 (2020-10-31)

Bug Fixes

  • 🐛 handle file names with special characters (475c333)

5.7.0 (2020-10-27)

Features

  • 🎸 export helpers and converters for usage in JS/TS (66182e8)

5.6.2 (2020-10-19)

Bug Fixes

  • remove svg-to-ts attribute from .svg-to-tsrc example (f1f575a)
  • replace 'modelFileName' by 'fileName' in exemple (7d0c43a)

5.6.1 (2020-10-14)

Bug Fixes

  • 🐛 add prettier as dependency instead of dev dependency (dcfff2e)

5.6.0 (2020-10-13)

Features

  • 🎸 add IconNameSubset helper type (d56e890)

5.5.2 (2020-10-13)

Bug Fixes

  • 🐛 generate correct interface for SVG contants (d21138f), closes #79

5.5.1 (2020-10-11)

Bug Fixes

  • 🐛 fix wrong import of svgo (d0e38e2)

5.5.0 (2020-10-08)

Features

  • type-name: add new delimiter UPPER (8bbd77f)

5.4.0 (2020-10-07)

Features

  • 🎸 handle multiple configurations (bc8befc)

5.3.0 (2020-10-06)

Features

5.2.2 (2020-10-05)

Bug Fixes

5.2.1 (2020-10-04)

Bug Fixes

  • 🐛 apply default barrel file name in conversion options (f8d4e9e)

5.2.0 (2020-09-03)

Features

  • completeIconSet: add exportCompleteIconSet option (43becd2)

5.1.0 (2020-09-02)

Bug Fixes

  • filecomment: add new line after comment (1deaa3f)

Features

  • comments: prepend generated files with file comment (cc6f6dd)

5.0.4 (2020-09-02)

Bug Fixes

  • typeobject: generate type object for icons with special character (f5d96b8)

5.0.3 (2020-09-02)

Bug Fixes

  • log: fix logging of error message (040ea28)

5.0.2 (2020-08-25)

Bug Fixes

  • exitcodes: add propper exit codes on failure (902d09c)

5.0.1 (2020-06-28)

Bug Fixes

5.0.0 (2020-06-16)

Bug Fixes

  • args: use passed delimiter or default (9d2a125)
  • objectconvertion: respect delimiter (b0b307a)

Features

  • args: add shortcut for convertionType (f061efc)
  • converting: add new convertion option to convert svg-icons to objects (9459f36)
  • convertionOptions: add new convertion options (4886eef)
  • defaultexport: use default export if no objectname is specified (d5c8635)
  • export: add possibility for default exports (4246587)

BREAKING CHANGES

  • options: conversion option is required

4.3.0 (2020-06-04)

Features

  • svgo: automatically prefix svg ids with filename (5bb989b)

4.2.3 (2020-06-04)

Bug Fixes

  • svgo: correctly pick up options from external config file (9b8d138)

4.2.2 (2020-05-05)

Bug Fixes

  • prefix: allow empty prefixes (6fa8f1f)

4.2.1 (2020-04-12)

Bug Fixes

  • docs: add missing options for single file conversion (0c6c3e1)

4.2.0 (2020-04-12)

Features

  • config: add options to not generate type and to generate type object (9e120b3)
  • config: add options to not generate type and to generate type object (8bbec6f)

4.1.1 (2020-03-28)

Bug Fixes

  • escaping: Use template literals instead of ' quotes to encapsulate svgs, as the quote character can occur in svgs. (a5fd0a4)

4.1.0 (2020-03-25)

Bug Fixes

Features

  • svgo: use configuration to config svgo (de279ae)
  • svgoconfig: accept svgo config as parameter (b2466e2)

4.0.5 (2020-03-25)

Bug Fixes

  • args: rename preCompileSources to compileSources (556203b)

4.0.4 (2020-03-25)

Bug Fixes

  • readme: fix API in README (f8e547b)

4.0.3 (2020-03-23)

Bug Fixes

  • README: link blogpost with step to step guide (be96c5f)

4.0.2 (2020-03-23)

Bug Fixes

  • image: rename generated file example (1427eae)
  • previewimage: adjust image path (6aea6d1)

4.0.1 (2020-03-23)

Bug Fixes

  • image: overwrite example src image (2fa0d9f)

4.0.0 (2020-03-23)

Features

  • optimizeforlazyloading: add compile sources flag (b177737)

BREAKING CHANGES

  • optimizeforlazyloading: Rename preCompile sources to compileSources

3.5.1 (2020-03-18)

Bug Fixes

  • helpmenu: add typescript as dependency (65655e5)

3.5.0 (2020-03-15)

Features

  • modelOutput: add additional model output path (614b37a)
  • modelOutput: add warning icon (8bde4d8)

3.4.0 (2020-03-15)

Features

  • precompilation: add flag to precompile sources (0f59a83)

3.3.2 (2020-03-11)

Bug Fixes

  • modelfile: remove output path (9f03426)

3.3.1 (2020-03-10)

Bug Fixes

  • compile: do not compile typescript sources (ef8b79d)

3.3.0 (2020-03-08)

Features

  • config: read config from package.json, rc file and args (524655f)

3.2.1 (2020-03-05)

Bug Fixes

  • icon: generate name as type any (08bd563)

3.2.0 (2020-03-05)

Features

  • model: generate model to a different path (c10d322)

3.1.4 (2020-03-04)

Bug Fixes

  • compiler: emit on error (edb1ea7)

3.1.3 (2020-03-04)

Bug Fixes

  • compiler: emit compiled sources (592ef68)

3.1.2 (2020-03-04)

Bug Fixes

  • compiler: reduce strictness (19f6480)

3.1.1 (2020-03-04)

Bug Fixes

  • generation: fix generated folder name (680f1f1)

3.1.0 (2020-03-04)

Features

  • compiler: compile ts files (a911b7c)
  • converter: convert to multiple files (fe13a4c)
  • multifiles: generate multiple files (d933e1e)

3.0.0 (2020-02-25)

Features

  • input: Handle regex as sourceDir (12d7bf9)
  • sources: use source files as regex (69547dd)

BREAKING CHANGES

  • sources: srcDirectories is gone and we should now use srcFiles

2.2.1 (2020-02-10)

Bug Fixes

  • conversion: check to allow only svg files (9fc3111)

2.2.0 (2019-12-31)

Features

  • delimiter: add delimiter option to allow a custom delimiter (c69358e)
  • type: generate the types with the correct delimiter (c6d1ebc)

2.1.0 (2019-12-13)

Bug Fixes

  • types: Fix error in type generation when last item is a folder (c70c15d)

Features

  • input: Handle multiple sourceDir (fe9fd84)

2.0.3 (2019-12-10)

Bug Fixes

  • input: Exclude folders to source directory (d2878a7)

2.0.2 (2019-12-10)

Bug Fixes

  • type: add missing export statement (ddab6ae)

2.0.1 (2019-12-10)

Bug Fixes

  • conversion: use camel case for variable names (89acef3)

2.0.0 (2019-12-10)

Features

  • conversion: use snake case instead of camel case (8963ce7)

BREAKING CHANGES

  • conversion: Generate types and variable names in snake case instead of camel case

1.1.2 (2019-12-09)

Bug Fixes

  • output: generate output with single quotes instead of double quotes (bbd38f6)

1.1.1 (2019-12-09)

Bug Fixes

  • bin: fix wrong path to bin file (bbb9565)

1.1.0 (2019-12-09)

Features

  • filename: accept fileName as input property (b99809d)

1.0.1 (2019-12-05)

Bug Fixes

  • camelcase: fix camel case is not a function (dd6af14)

1.0.0 (2019-11-21)

Features

  • converting: optimize output (fa6f42e)
  • prettier: integrate prettier to format final Typescript (9284eac)
  • setup: setup library (6b42a67)