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

fontawesome-user-agent

v0.2.1

Published

Get browser, os and platform Font Awesome icons from user-agent string.

Downloads

1,153

Readme

fontawesome-user-agent

NPM Version Build Status Greenkeeper badge Coverage Status

A simple, yet extensible, TypeScript (and JavaScript) library which tries to determine browser, os and platform Font Awesome icons from user-agent string (thanks to Bowser).

Installation

npm

npm install --save fontawesome-user-agent

yarn

yarn add fontawesome-user-agent

Usage

The most basic usage should look like this:

import { faUserAgent } from "faUserAgent";

const userAgent = "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.100 Safari/537.36";

const icons = faUserAgent(userAgent);

// Content of icons:
{
  browser: {
    name: "chrome",
    style: "fab",
    html: "<i class=\"fab fa-chrome\"/>"
  },
  os: {
    name: "apple",
    style: "fab",
    html: "<i class=\"fab fa-apple\"/>"
  },
  platform: {
    name: "desktop",
    style: "fas",
    html: "<i class=\"fas fa-desktop\"/>"
  }
}

Simplified content of doc/demo.html:

<html>
    <head>
        <link rel="stylesheet" type="text/css" media="all" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.9.0/css/all.min.css" />
    </head>
    <body>
        <p id="demo"></p>
        <script>
            var icons = FaUserAgent.faUserAgent(navigator.userAgent);
            html = icons.browser.html + icons.os.html + icons.platform.html;
            document.getElementById("demo").innerHTML = html;
        </script>
    </body>
</html>

Options

If you need to customize some options, you can use the optional options argument:

const icons = faUserAgent(userAgent, options => {
    options.prefix = "";
    options.icons.os.macOS = {
        name: "money-bill",
        style: "fas"
    }
    options.default.os = {
        name: "skull-crossbones",
        style: "solid"
    }
});

Available options:

FaUserAgentOptions

Name | Type | Description --- | --- | --- prefix | string | Icon name prefix (e.g. fa-). icons.browser.<name> | FaUserAgentIconBase | Icon for browser with name <name>. icons.os.<name> | FaUserAgentIconBase | Icon for OS with name <name>. icons.platform.<name> | FaUserAgentIconBase | Icon for platform with name <name>. default.browser | FaUserAgentIconBase | Default browser icon to use when not found in icon set. default.os | FaUserAgentIconBase | Default OS icon to use when not found in icon set. default.platform | FaUserAgentIconBase | Default platform icon to use when not found in icon set.

FaUserAgentIconBase

Name | Type | Description --- | --- | --- name | string | Font Awesome icon class name. style | string | Font Awesome icon Style Prefix class name.

See Font Awesome Basic Use for more information about how to use these properties.

Supported Icons

See doc/default-options.md for a list of the supported browsers, platforms and OS icons.

Develop

  • build: npm run build
  • test: npm run test
  • code coverage: npm run coverage

License

MIT