@andresmarpz/favicons
TypeScript icon, indicating that this package has built-in type declarations

1.1.3 • Public • Published

favicons

npm shield displaying the current package version typescript shield

Utility package to get favicons from the web. I don't know why, but it's so damn hard to get favicons just right. You may get different sizes, quality, background and other variables that make it a pain to work with.

Roadmap

Usage

Warning: this is a library meant to be run on Node.js (server-side).
First, install the package:

npm install @andresmarpz/favicons

Favicon

The Favicon object has the following structure

interface Favicon {
  url: string;
  size: number; // in bytes
  extension: "ico" | "png" | "gif" | "jpg" | "jpeg" | "svg";
}

getFavicons

This is the most common import, so it's probably what you are looking for.

import { getFavicons } from '@andresmarpz/favicons';

..
const favicons = await getFavicons('nextjs.org');
..

getFavicon

Function to return only the biggest favicon from an URL.

import { getFavicon } from '@andresmarpz/favicons';

..
const favicon = await getFavicon('nextjs.org');
..

extractFavicons

Method used to extract favicon hrefs from a html string or head element string. Returns a string[] with urls.

import { extractFavicons } from '@andresmarpz/favicons';

..
const request = await fetch('nextjs.org');
const html = await request.text();
const favicons = extractFavicons(html);
..

getFaviconFrom

Get the Favicon object from the given URL.

import { getFaviconFrom } from "favicons";

const favicon = await getFaviconFrom("https://nextjs.com/favicon.ico");

getFaviconsFrom

Get a Favicon[] from a string[] of favicon urls.

import { requestFavicons } from "favicons";

const favicons = await requestFavicons(["https://nextjs.com/favicon.ico", "https://nextjs.com/favicon.png"]);

Project structure

This repo uses turborepo to manage apps and packages in a monorepo setup.

Codebase Description
apps/web Next.js landing
packages/npm npm package
packages/local Local testing

Running locally

$ git clone https://github.com/andresmarpz/favicons.git
$ cd favicons
$ npm i

Dependents (0)

Package Sidebar

Install

npm i @andresmarpz/favicons

Weekly Downloads

26

Version

1.1.3

License

GPL-3.0-or-later

Unpacked Size

47.4 kB

Total Files

9

Last publish

Collaborators

  • andresmarpz