@ikona/cli
v0.1.10
Published
Ikona CLI
Downloads
490
Maintainers
Readme
Ikona
An SVG sprite and illustration asset generator called /ikɔna/.
Motivation
Inlining SVGs in the DOM comes with a price of performance. This is why we use SVG sprites. But creating and maintaining SVG sprites is a pain. This is where Ikona comes in to help. Ikona distinguishes two types of SVGs: icons and illustrations. Icons are small and simple SVGs that use only one color. Illustrations are SVGs that are more complex and use multiple colors.
This project is inspired by this article The "best" way to manage icons in React.js.
Installation
npm i save-dev @ikona/cli
Usage
Configuration
Create a file named ikona.config.ts
in the root of your project. This file will contain the configuration for Ikona.
import { defineConfig } from '@ikona/cli';
export default defineConfig({
verbose: false,
icons: {
optimize: false,
inputDir: 'src/assets/icons',
spriteOutputDir: 'public/icons',
},
illustrations: {
inputDir: 'public/illustrations',
},
});
Generating SVG sprites
To generate SVG sprites, run the following command:
ikona
Using icons
To use icons, import the generated code to create a React component.
import React from 'react';
import { IconName } from '.ikona/types/icon-name';
import { hash } from '.ikona/hash';
export const Icon = ({ name }: { name: IconName }) => {
return (
<svg>
<use href={`/icons/sprite.${hash}.svg#${name}`} />
</svg>
);
};
Preloading SVG sprites
To preload SVG sprites, include this snippet in your HTML head
.
import { hash } from '.ikona/hash';
<link
rel="preload"
as="image"
type="image/svg+xml"
href={`icons/sprite.${hash}.svg`}
/>;
Using illustrations
To use illustrations, import the generated code to create a React component.
import React from 'react';
import { IllustrationPath } from '.ikona/types/illustration-path';
export const Illustration = ({ path }: { path: IllustrationPath }) => {
return <img src={path} />;
};
CLI
todo