npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

uicons-react

v0.2.5

Published

A lib of highly customizable and elegant icons for React

Downloads

7

Readme

uicons-react

Uicons is a lib of highly customizable and elegant icons, really. Explore all our icons at uicons.io.

NPM JavaScript Style Guide License

GitHub stars Follow on GitHub GitHub forks GitHub watchers

Installation

yarn add uicons-react

or

npm install uicons-react

Usage

Just import the icons you need, and add in component or page. IMPORTANT! your bundle only includes code for the icons you use.

import { Bookmark, BookmarkAdd, BookmarkBlocked, ArchiveBox } from "uicons-react";

export function Component(){
  return (
    <div>
      <Bookmark />
      <BookmarkAdd color="#fac800" weight="outline" size={32} />
      <BookmarkBlocked className="icon-class" weight="fill" size={32} />
      <ArchiveBox
        size={28}
        weight="custom"
        customColors={{
          fill: '#fff', // optional if you don't want the icon to have a fill color
          outter: '#828282',
          inner: '#fac800'
        }}
      />
    </div>
  );
};

Props

Icon components accept all props that you can pass to a normal SVG element, including inline style objects, onClick handlers, and more. The main way of styling them will usually be with the following props:

  • alt?: string – Add accessible alt text to an icon.
  • color?: string – Icon stroke/fill color. Can be any CSS color string, including hex, rgb, rgba, hsl, hsla, named colors, or the special currentColor variable.
  • customColors?: object – Icon stroke/fill color. Just like the color property used any CSS color string, but in the case of customColors you can separately customize the external and internal lines and also the filling if you want.
  • size?: number | string – Icon height & width. As with standard React elements, can be a number, or a string with units in px, %, em, rem, pt, cm, mm, in.
  • weight?: "thin" | "light" | "regular" | "bold" | "fill" | "outline" | "custom" – Icon weight/style. Can also be used, for example, to "check" the state of an icon: a Bookmark component with weight="regular" is unchecked and weight="fill" is checked..
  • inverted?: boolean – Inverts black to white, this property is active for all types of weights when color has been set.

CSS

All types of CSS writing are supported, classNames, inline styles and CSS utility class names, for example utility classes coming from the Tailwind CSS framework:

import { Bookmark, BookmarkAdd, BookmarkBlocked } from "uicons-react";

export function Component(){
  return (
    <div>
      <Bookmark style={{ color: '#fac800' }} />
      <BookmarkAdd className="text-green-500" weight="outline" size={32} /> // Tailwind utility class
      <BookmarkBlocked className="classic-element-class" weight="fill" size={32} />
    </div>
  );
};

Context

Uicons takes advantage of React Context API to make applying a default style to all icons simple. Create an IconContext.Provider at the root of the app (or anywhere above the icons in the tree) and pass in a configuration object with props to be applied by default to all icons:

IMPORTANT: Requires React 16.3 or higher.

import { IconContext, Bookmark, BookmarkAdd, BookmarkBlocked, ArchiveBox } from "uicons-react";

const App = () => {
  return (
    <IconContext.Provider
      value={{
        size: 32,
        customColors: { outter: 'cyan', inner: 'grey' },
        weight: 'custom',
      }}
    >
      {/* all chosen characteristics are applied to all icons involved by the context provider */}
      <div>
        <Bookmark />
        <BookmarkAdd />
        <BookmarkBlocked />
        <ArchiveBox />
      </div>
    </IconContext.Provider>
  );
};

You may create multiple Contexts for styling icons differently in separate regions of an application; icons use the nearest Context above them to determine their style.

THAT'S COOL: The context will also pass any provided SVG props to icon instances, which can be useful such as accessibility, classNames etc.

License

MIT © UIcons