Coder Social home page Coder Social logo

create-favicons's Introduction

Create favicons

Crea i file favicons come descritto in How to Favicon in 2024.

I file da elaborare devono essere in formato SVG, mentre quelli generati sono in formato SVG (favicon), PNG (apple-touch-icon e altri file per android), e ICO (altro favicon per compatibilità con i browser meno recenti). Vengono inoltre genrati i file manifest.webmanifest e uno snippet html, opzionale, con i tag link per l'inserimento degli elementi generati.

Le immagini sono generate con Sharp, SVGO e sharp-ico.

Creazione template file di config (vedi più avanti)

npx create-favicons init

Utilizzo

npx create-favicons [--dir=./path/to/dir]

Lo script agisce normalmente nella directory corrente, ma, utilizzando il parametro opzionale --dir, è possibile specificare una directory alternativa (percorso relativo alla dir di esecuzione).

Lo script in prima battuta cerca nella dir di lavoro il file create-favicons-cfg.mjs che contiene un oggetto con tutti i parametri necessari (vedi di seguito).

In sua assenza, cerca il file favicon-src.svg da utilizzare come sorgente per tutte le immagini, e assumendo i valori di default (vedi dopo) per tutti gli altri parametri.

Tra gli altri, è possibile spcificare il parametro small_src_img nel caso sia necessario specificare un'immagine ottimizzata per le piccole dimensioni (32px).

Il formato migliore per i file sorgenti è SVG, o in alternativa PNG.

In assenza di entrambi i file viene restituito un errore.

I parametri di default sono elencati in dettaglio nel file src/create-favicons/src/default-params.mjs, e possono essere personalizzati nel file di configurazione, che deve avere questa forma:

// file create-favicons-cfg.mjs
const params = [{ /* ... */ }];

export default params;

params può essere un oggetto o un array. In quest'ultimo caso, ogni elemento dell'array corrisponde ad un diverso set di favicons.

Per creare un file di cfg di esempio nella directory corrente (con tutti i valori di default e la loro descrizione), utilizzare il comando:

npx create-favicons init

Utilizzo da remoto

I comandi possono essere eseguiti anche senza installare preventivamente il package:

npx --package=@massimo-cassandro/dev-utilities create-favicons init
npx --package=@massimo-cassandro/dev-utilities create-favicons [--dir=...]

Esecuzione

Lo script produce le varie immagini png ed svg, il file manifest.webmanifest e uno snippet html (o nel linguaggio indicato nel parametro snippet_language). Tutte le immagini vengono ottimizzate con SVGO e imagemin.

Tutti file vengono salvati nella dir indicata in output_dir (default: directory corrente).

Opzionalmente il file snippet può essere salvato in una directory differente (snippet_path) o si può decidere di non crearlo, impostando il valore snippet_name a null.

Nel file di configurazione è anche possibile impostare il parametro webmanifest_extra, che permette di aggiungere voci aggiuntive al file manifest. Per ulteriori info: https://developer.mozilla.org/en-US/docs/Web/Manifest

File generati:

<link rel="icon" href="/favicon.ico" sizes="any"> <!-- 32×32 + 16x16 -->
<link rel="icon" href="/icon.svg" type="image/svg+xml">
<link rel="apple-touch-icon" href="/apple-touch-icon.png"> <!-- 180×180 -->
<link rel="manifest" href="/manifest.webmanifest">
// manifest.webmanifest
{
  "icons": [
    { "src": "/icon-192.png", "type": "image/png", "sizes": "192x192" },
    { "src": "/icon-512.png", "type": "image/png", "sizes": "512x512" }
  ]
}

Vedi anche esempio in https://github.com/massimo-cassandro/dev-utilities/tree/main/test/test/create-favicons-test.

create-favicons's People

Contributors

massimo-cassandro avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.