react-svg-ionicons v0.2.3
react-svg-ionicons
Flexible and performant SVG Ionicon component for React.
From the Ionicon site
Ionicons is a completely open-source icon set with 700+ icons crafted for web, iOS, Android, and desktop apps. Ionicons was built for Ionic Framework, so icons have both Material Design and iOS versions.
react-svg-ionicons exports an IonIcon component, similar to the Ionic's ion-icon Web Component, to render SVG icons in web pages with automatic detection of the icon style (iOS or Material Design) based on your platform.
WARNING: This package is WIP, so breaking changes are expected. Please check the Changelog for more information. The API will stabilize in v0.3.0
Thanks to the Ionic Framework team for their awesome work!
Install
$ yarn add react-svg-ionicons
# or
$ npm i react-svg-ionicons -SUsage
This package consists of one component, some utility functions and ~380 subcomponents with dual and logo icons, covering the entire set of the Ionicons.
Before using the main IonIcon component, you must add subcomponents (SVGIcon) through the addIcons function.
I include three convenience bundles in the folder "bundles":
- all: The full icon set.
- generic: All the dual icons.
- logos: Only the "logo" icons.
import { IonIcon, addIcons } from 'react-svg-ionicons'
import bundle from 'react-svg-ionicons/bundles/all'
// This loads the full Ionicon set
addIcons(bundle)
// From here, you can use the loaded icons anywhere in your App
<IonIcon name="heart" size="large" color="red" strokeWidth={3} />But you can create your own by importing individual icons from the folder "icons".
In addition to the styles and classes that you define (applied to the <svg> tag), each icon has an internal className formed with the prefix "ion-" and the name of the icon. For example, the "apps" icon has the class name "ion-apps". This allows control of each icon using specific CSS rules, the recommended way to stylize and transform svg the elements.
API
IonIcon
<IonIcon name="icon-name" {...props} />This is the main component of react-svg-ionicons and will render an unwrapped <svg> with the default and instance properties.
IonIcon accepts almost any valid SVG attribute in (react) camel-case notation, along the following properties:
- name - The icon name is the only required property, as seen in the Ionicos site, without the "md-" or "ios-" prefix. 
- color - String with a color to apply to the - strokeand- fillattributes, in any format accepted by the 'color' CSS rule.- The predefined value is "currentColor", you can change or remove it with setDefaults. - Precedence: specific - fill/strokeor- color-> default- fill/stroke-> default- color.
- size - String, number, or named size applied to the - widthand- heightattributes.- The predefined value is "1rem", but you can change or remove it with setDefaults. - Precedence: specific - width/heightor- size-> default- width/height-> default- size.
- mode - The - modeproperty determines which platform styles to use, either- "ios"or- "md".- By using this property you will override the automatic detection of the platform. 
- title - Overrides the default title of the icon (the default is the icon name in Title Case). 
- innerRef - A - React.refto the- svgelement (don't use strings).
addIcons
addIcons(bundle: { [k: string]: SVGIcon | null }): voidAdds a group of icons to the registration table.
bundle is a JS object where each key is the name of an icon and its value is the component to use.
This charging mode allows great flexibility. You can personalize the icon names or even create new icons.
Also, if you want to reduce the size of your App, you can create a custom bundle with only the icons you require, the rest will be excluded from your App.
To remove an already loaded icon, pass null as its value.
Example using TypeScript:
import { addIcons, IonIcon } from 'react-svg-ionicons'
import alarm from 'react-svg-ionicons/icons/alarm'
import trash from 'react-svg-ionicons/icons/trash'
import arrowBack from 'react-svg-ionicons/icons/arrow-back'
const bundle = {
  alarm,
  trash,
  back: arrowBack,
}
type IconNames = keyof typeof bundle
addIcons(bundle)
interface Icon extends IonIcon<IconNames> {}
const Icon = IonIcon
export { Icon }setDefaults
setDefaults(settings: SVGAttributes<SVGSVGElement>): voidThis function accepts a JS object with valid SVG attributes that are mixed with the defaults used when rendering the icons.
Deep merge is only applied to objects like style, and the attributes xmlns y viewBox are ignored.
Even if an attribute is accepted, it may have no effect on the icon. You will need to experiment to get the desired effect.
To remove existing attributes, pass null or undefined as its value.
Predefined values:
{
  display: 'inline-block',
  fill: 'currentColor',
  stroke: 'currentColor',
  size: '1em',
}You can see the SVGAttributes definition in the @types/react package (you are using TypeScript, right?) or in MDN SVG element reference (mostly in kebab-case notation).
setSizes
setSizes(sizes: { [k: string]: string | number | null }): voidAdds or removes values of the named sizes map, a JS object used to translate names to CSS sizes.
You can add your own translations, or remove the existent ones by settings its value to null.
Predefined values, consistent with ion-icon:
{
  small: '18px',
  large: '32px',
}You can use this values through the size property of IonIcon:
<IonIcon name="app" size="large" />The value will be applied to the width and height attributes of the <svg> element.
setTitles
setTitles(iconTitles: { [k: string]: string | null })This function allows you configure the default icon-name -> title translations.
In accordance with the accessibility recommendations each icon includes a <title> element. By default it is the name of the icon in title-case.
setBaseClass
setBaseClass(classes: string | null)Determines the base class that will be added to the default or specific className property to form the final class attribute for all the icons.
This setting has no default value, but a common one is "icon".
TODO
- Tests.
- SVG Sprites.
- Custom bundle generator.
- Examples.
Support my Work
I'm a full-stack developer with more than 20 year of experience and I try to share most of my work for free and help others, but this takes a significant amount of time and effort so, if you like my work, please consider...
Of course, feedback, PRs, and stars are also welcome 🙃
Thanks for your support!
License
The MIT Licence
© 2019, Alberto Martínez