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

sf-symbols-typescript

v2.0.0

Published

```ts import type { SFSymbol } from 'sf-symbols-typescript'

Downloads

500,257

Readme

🍏 SF Symbols for TypeScript

import type { SFSymbol } from 'sf-symbols-typescript'

const icon: SFSymbol = 'arrow.up'

A simple TypeScript utility to get the names of SF Symbols. Mainly useful for React Native libraries and apps that utilize SF Symbols.

I made this for Zeego and Burnt.

It has zero dependencies, and zero runtime code.

Installation

yarn add sf-symbols-typescript

Usage

import type { SFSymbol } from 'sf-symbols-typescript'

const icon: SFSymbol = 'arrow.up'

Restricting symbols

By default, this library exposes all available symbols for the current version of SF Symbols.

Depending on the platforms your app targets, you may want to restrict the types to specific versions of SF Symbols.

Globally

You can restrict the SFSymbol type to a specific version of SF Symbols through declaration merging.

This library exposes an interface called Overrides with a property SFSymbolsVersion that can be overidden.

declare module 'sf-symbols-typescript' {
  interface Overrides {
    // globally restrict symbols to those found in SF Symbols 4.2
    SFSymbolsVersion: '4.2'
  }
}

Individually

If you require more granular control, this library also exposes individual type definitions for each version of SF Symbols.

They are named with this pattern: SFSymbols{major}_{minor}

import type { SFSymbols4_2, SFSymbols5_0 } from 'sf-symbols-typescript'

Version Support Table

Here are the platforms supported by each version of SF Symbols:

| SFSymbols | iOS | macOS | tvOS | visionOS | watchOS | | --------- | ---- | ----- | ---- | -------- | ------- | | 1.0 | 13.0 | 11.0 | 13.0 | 1.0 | 6.0 | | 1.1 | 13.1 | 11.0 | 13.0 | 1.0 | 6.1 | | 2.0 | 14.0 | 11.0 | 14.0 | 1.0 | 7.0 | | 2.1 | 14.2 | 11.0 | 14.2 | 1.0 | 7.1 | | 2.2 | 14.5 | 11.3 | 14.5 | 1.0 | 7.4 | | 3.0 | 15.0 | 12.0 | 15.0 | 1.0 | 8.0 | | 3.1 | 15.1 | 12.0 | 15.1 | 1.0 | 8.1 | | 3.2 | 15.2 | 12.1 | 15.2 | 1.0 | 8.3 | | 3.3 | 15.4 | 12.3 | 15.4 | 1.0 | 8.5 | | 4.0 | 16.0 | 13.0 | 16.0 | 1.0 | 9.0 | | 4.1 | 16.1 | 13.0 | 16.1 | 1.0 | 9.1 | | 4.2 | 16.4 | 13.3 | 16.4 | 1.0 | 9.4 | | 5.0 | 17.0 | 14.0 | 17.0 | 1.0 | 10.0 |

Contributing

To update this package's icons, you will need Bun installed on your machine.

You will also need a copy of the plist resources from the SF Symbols desktop application.

  • Right click the SF Symbols application in Finder and choose "Show Package Contents"
  • Navigate to ./Contents/Resources/Metadata. The required plist resources are here.

Alternatively, you may be able to find those same resource files in the source code of the unofficial SFSafeSymbols Swift library.

  1. Clone this repo
  2. Copy the SF Symbols plist resource files into the ./src/data directory of the repo
  3. Run bun run build
  4. Push your changes and open a PR

Disclaimer

It is your responsibility to check Apple's rules about when certain icons can be used. You can check the SF Symbols desktop application for more info.

I am purposefully not displaying any icons themselves to avoid violating any licenses. This library isn't associated with Apple, and is only intended to expose the names of the icons themselves.

Credits

This project is based on Apple's SF Symbols

Previous versions of this library used data sourced from the now-defunct SFSymbols.com. Thanks to Noah Sark for your open source contributions.

License

MIT License