Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/anolilab/unplugin-favicons

Generate favicons for your project with caching for blazing fast rebuilds.
https://github.com/anolilab/unplugin-favicons

anolilab astro esbuild favicon favicons favicons-generator generate generating-favicons image nuxt plugin pwa rollup rspack svelte sveltekit vite vite-plugin webpack

Last synced: 3 months ago
JSON representation

Generate favicons for your project with caching for blazing fast rebuilds.

Awesome Lists containing this project

README

        

A Favicons Plugin

Create and manage favicons with Vite, Rollup, Webpack, Rspack, Nuxt, Vue CLI, Svelte, esbuild and Astro on top of
[itgalaxy/favicons](https://github.com/itgalaxy/favicons)

[![typescript-image]][typescript-url] [![npm-image]][npm-url] [![license-image]][license-url]

---




Daniel Bannert's open source work is supported by the community on GitHub Sponsors


---

## Install

```bash
npm install --dev-save @anolilab/unplugin-favicons favicons
```

```sh
yarn add -D @anolilab/unplugin-favicons favicons
```

```sh
pnpm add -D @anolilab/unplugin-favicons favicons
```

## Zero Config Usage

Add your base logo as `logo.png` file to your assets folder.

## Only declared icons generation

```ts
unpluginFavicons({
/**
* Specify each icon type to render. Unlike `favicons`, this plugin is
* opt-in, meaning only the icon types you declare here will be rendered.
*
* For each icon type, all `favicons` options are supported. An
* additional `source` property is required to indicate the asset to be
* used for that icon type.
*/
icons: {
favicons: {
source: "./assets/favicon.png",
},
android: {
source: "./assets/android.png",
},
appleStartup: {
source: "./assets/apple-startup.png",
},
},
});
```

### Add the plugin to your bundler as follow:

Vite

```ts
// vite.config.ts
import unpluginFavicons from "@anolilab/unplugin-favicons/vite";

export default defineConfig({
plugins: [
unpluginFavicons({
/* options */
}),
],
});
```


Rollup

```ts
// rollup.config.js
import unpluginFavicons from "@anolilab/unplugin-favicons/rollup";
// To use the auto inject
import html from "@rollup/plugin-html";

export default {
plugins: [
// html(), // optional
unpluginFavicons({
/* options */
}),
],
};
```


esbuild (Only generates the favicons)

```ts
// esbuild.config.js
import { build } from "esbuild";

build({
plugins: [
require("@anolilab/unplugin-favicons/esbuild")({
/* options */
}),
],
});
```


Webpack

```ts
// webpack.config.js
module.exports = {
/* ... */
plugins: [
require("@anolilab/unplugin-favicons/webpack")({
/* options */
}),
],
};
```


Vue CLI (Untested)

```ts
// vue.config.js
module.exports = {
configureWebpack: {
plugins: [
require("@anolilab/unplugin-favicons/webpack")({
/* options */
}),
],
},
};
```


Nuxt

Nuxt 2 and [Nuxt Bridge](https://github.com/nuxt/bridge)

```ts
// nuxt.config.js
export default {
buildModules: [
[
"@anolilab/unplugin-favicons/nuxt",
{
/* options */
},
],
],
};
```

Nuxt 3

```ts
// nuxt.config.js
export default defineNuxtConfig({
modules: [
[
"@anolilab/unplugin-favicons/nuxt",
{
/* options */
},
],
],
});
```

See [the Nuxt example](examples/nuxt) for a working example project.


SvelteKit (No Supported for now, see Vite Plugin)

The `@anolilab/unplugin-favicons` plugin should be configured in the `vite.config.js` configuration file:

```ts
// vite.config.js
import { defineConfig } from "vite";
import { sveltekit } from "@sveltejs/kit/vite";
import unpluginFavicons from "@anolilab/unplugin-favicons/vite";

export default defineConfig({
plugins: [
sveltekit(),
unpluginFavicons({
/* options */
}),
],
});
```

Check instructions in the `Frameworks -> Svelte` section below if you faced module import errors.

See [the SvelteKit example](examples/sveltekit) for a working example project.


Svelte + Vite

Svelte support requires the `@sveltejs/vite-plugin-svelte` plugin:

```shell
npm i -D @sveltejs/vite-plugin-svelte
```

The `@anolilab/unplugin-favicons` plugin should be configured in the `vite.config.js` configuration file:

```ts
// vite.config.js
import { defineConfig } from "vite";
import { svelte } from "@sveltejs/vite-plugin-svelte";
import unpluginFavicons from "@anolilab/unplugin-favicons/vite";

export default defineConfig({
plugins: [
svelte(),
unpluginFavicons({
/* options */
}),
],
});
```

Check instructions in the `Frameworks -> Svelte` section below if you faced module import errors.

See [the Svelte + Vite example](examples/vite-svelte) for a working example project.


Next.js (Not Supported for now)

The `@anolilab/unplugin-favicons` plugin should be configured on `next.config.js` configuration file:

```js
/** @type {import('next').NextConfig} */
module.exports = {
reactStrictMode: true,
webpack(config) {
config.plugins.push(
require("@anolilab/unplugin-favicons/webpack")({
/* options */
}),
);

return config;
},
};
```

Check instructions in the `Frameworks -> React` section below if you faced module import errors.

See [the Next.js example](examples/next) for a working example project.


Astro

```ts
// astro.config.mjs
import { defineConfig } from "astro/config";
import unpluginFavicons from "@anolilab/unplugin-favicons/vite";

// https://astro.build/config
export default defineConfig({
vite: {
plugins: [
unpluginFavicons({
/* options */
}),
],
},
});
```

See [the Astro example](examples/astro) for a working example project.


The default configuration will automatically generate webapp manifest files along with 44 different icon formats as appropriate for iOS devices, Android devices, Windows Phone and various desktop browsers out of your single `logo.png`.

> **Tip:** You might want to [fine tune](#advanced-usage) what vendors to support.

### A Note on Path Resolution

Under the hood, Vite/Rollup resolve the paths to the logo and favicons according to the following
rules:

- If `/path/to/logo` is absolute, there is nothing to resolve and the path
specified is used as is.

- If `./path/to/logo` is relative, it’s resolved with respect to `process.cwd()`.

### HTML Injection

In combination with [Vite’s html plugin hooks](https://vitejs.dev/guide/api-plugin.html#transformindexhtml) it will also inject the necessary html for you:

```html

```

## Advanced Usage

```javascript
unpluginFavicons({
/** Your source logo (Will default to ) */
logo?: "assets/logo.png",
/** Inject html links/metadata. */
inject?: true,
/** `Favicons` configuration options
* - [See `favicons` documentation](https://github.com/itgalaxy/favicons) */
favicons?: FaviconsConfig,
/** The root of the project from which you want to load metadata */
projectRoot?: process.cwd(),
})
```

To fine tune what icons/metadata is generated, refer to
[favicons’ documentation](https://github.com/itgalaxy/favicons#usage).

The options specified under `favicons:` are handed over as is to [favicons],
except that if `appName`, `appDescription`, `version`, `developerName` or
`developerURL` are left `undefined`, they will be automatically inferred
respectively from `name`, `description`, `version`, `author.name` and
`author.url` as defined in the nearest `package.json` if available.
And if there’s no `author` it will use the first in the `contributors`.
To disable automatically retrieving metadata from `package.json`, set
to `null` the properties you want to omit.

### Examples

#### Basic

```javascript
unpluginFavicons({
logo: "./src/logo.png", // svg works too!
favicons: {
appName: "my-app",
appDescription: "My awesome App",
developerName: "Me",
developerURL: null, // prevent retrieving from the nearest package.json
background: "#ddd",
theme_color: "#333",
icons: {
coast: false,
yandex: false,
},
},
});
```

To fine tune what icons/metadata is generated, refer to
[favicons’ documentation](https://github.com/itgalaxy/favicons#usage).

#### Handling Multiple HTML Files

Vite calls the HTML transform hook for each HTML file template file you have configured in Vite, so this works automatically.

## Changelog

Take a look at the [CHANGELOG.md](https://github.com/anolilab/unplugin-favicons/blob/main/CHANGELOG.md).

## Contribution

You’re free to contribute to this project by submitting [issues](https://github.com/anolilab/unplugin-favicons/issues) and/or [pull requests](https://github.com/anolilab/unplugin-favicons/pulls).

Please keep in mind that every change and feature should be covered by
tests.

## License

This project is licensed under [MIT](https://github.com/anolilab/unplugin-favicons/blob/main/LICENSE.md).

## Supported Node.js Versions

Libraries in this ecosystem make the best effort to track
[Node.js’ release schedule](https://nodejs.org/en/about/releases/). Here’s [a
post on why we think this is important](https://medium.com/the-node-js-collection/maintainers-should-consider-following-node-js-release-schedule-ab08ed4de71a).

## Contributing

If you would like to help take a look at the [list of issues](https://github.com/anolilab/vite-plugin-favicon/issues) and check our [Contributing](.github/CONTRIBUTING.md) guild.

> **Note:** please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.

## Credits

- [Daniel Bannert](https://github.com/prisis)
- [All Contributors](https://github.com/anolilab/vite-plugin-favicon/graphs/contributors)

## License

The anolilab vite-plugin-favicon is open-sourced software licensed under the [MIT license](https://opensource.org/license/mit/)

[typescript-image]: https://img.shields.io/badge/Typescript-294E80.svg?style=for-the-badge&logo=typescript
[typescript-url]: "typescript"
[license-image]: https://img.shields.io/npm/l/@anolilab/unplugin-favicons?color=blueviolet&style=for-the-badge
[license-url]: LICENSE.md "license"
[npm-image]: https://img.shields.io/npm/v/@anolilab/unplugin-favicons/latest.svg?style=for-the-badge&logo=npm
[npm-url]: https://www.npmjs.com/login?next=%2Fpackage%2F%40anolilab%2Funplugin-favicons%2Fv%2Flatest "npm"