Crea e condividi un componente tema font

Discourse supporta l’importazione di temi contenenti asset da un repository remoto.

Questo consente agli autori di temi di condividere caratteri e immagini.

Crea un nuovo repository git con il font

mkdir discourse-roboto-theme
cd discourse-roboto-theme
git init .
vim about.json

Per about.json aggiungi un file di configurazione scheletro

{
  "name": "Roboto theme component",
  "about_url": "",
  "license_url": "",
  "assets": {
    "roboto": "assets/roboto.woff2"
  }
}

Aggiungi un file LICENSE, io uso solitamente MIT

vim LICENSE

Scarica il font

http://localfont.com/ è un sito utile per ottenere i font

mkdir assets
cp ~/Downloads/roboto.woff2 roboto.woff2

Aggiungi CSS che utilizza il tema

mkdir common
cd common

Crea un file chiamato common.scss con

@font-face {
  font-family: Roboto;
  src: url($roboto) format("woff2");
}

body {
  font-family: Roboto;
}

Esegui il push delle modifiche su GitHub

Esegui il commit di tutte le modifiche:

git add LICENSE
git add about.json
git add assets/roboto.woff2
git add common/common.scss
git commit -am "first commit"

Crea un account su GitHub.com e poi crea un nuovo repository.

(Opzionale) crea un topic su Discourse come sede per discutere i tuoi colori

Idealmente dovresti creare un topic nella categoria #plugin:theme con alcuni screenshot del tuo schema di colori. Lo userai come tuo about_url

Compila le informazioni mancanti nel tuo file about.json

  • Naviga alla tua pagina LICENSE su GitHub, inserisci quell’URL come tuo license_url

  • Usa l’URL del progetto GitHub o l’URL del topic di Discourse come tuo about_url

Alla fine del processo il tuo file about.json sarà simile a questo:

{
  "name": "Roboto theme component",
  "about_url": "https://github.com/SamSaffron/discourse-roboto-theme",
  "license_url": "https://github.com/SamSaffron/discourse-roboto-theme/blob/master/LICENSE",
  "assets": {
    "roboto": "assets/roboto.woff2"
  }
}

Esegui il commit della modifica ed esegui il push su GitHub

git commit -am "added more details"
git push

Prova il tuo componente font

  • Nella schermata admin/customize/theme importa il tuo tema da GitHub

:confetti_ball:
Ora puoi condividere facilmente i font!

Vedi anche:


Questo documento è controllato in versione - suggerisci modifiche su github.

19 Mi Piace

Great tutorial.

Worked like a charm except it looks like localfont.com is down or no more.

I used this Google webfonts helper site to download a .woff2 version of the font I was after.

See also Discourse Theme CLI (console app to help you build themes)

1 Mi Piace

Quando ho seguito i passaggi ho ricevuto un Errore: Variabile non definita: “$fontname”.

Quindi:
Ho dichiarato la variabile in $variables:
fontname: "assets/fontname.woff2";

Mi sembra che tu debba inserirla, ma quale percorso usare in $variables?

Quando lasci che Discourse carichi i file con

"assets": {
        "fontname": "assets/fontname.woff2"
   }

carica il file in un percorso diverso da assets/roboto.woff2, sembra
(/uploads/db0202/original/1X/...)

Modifica:
Non c’è bisogno di $variables, la magia avviene con i caricamenti. Ma avevo assets/font.svg#regular negli assets e l’hashtag ha creato il problema.

2 Mi Piace

Sto riscontrando lo stesso errore Errore: Variabile non definita. Inoltre, non vengono visualizzati asset in caricamenti o caricamento come intestazione.

Questo how-to necessita di un aggiornamento?

Grazie in anticipo

1 Mi Piace