Domina la configuració de tabi: guia completa

Aquesta és la guia completa sobre la configuració a tabi. Si tens alguna pregunta, pots obrir un issue a GitHub o iniciar una discussió.

Taula de continguts

Jerarquia de configuració

tabi té una jerarquia que permet personalitzar el teu lloc a diferents nivells. La jerarquia (de menor a major prioritat) és la següent:

  1. Configuracions globals: Aquestes són les configuracions que s’apliquen a tot el teu lloc. Es configuren a config.toml.
  2. Configuracions de secció: Aquestes són les configuracions que s’apliquen a una secció del teu lloc (per exemple, /blog o /projects). Es configuren a la metainformació de l’arxiu _index.md de la secció.
  3. Configuració de la pàgina «pare»: Per a pàgines anidades (pàgines dins de pàgines), aquestes són les configuracions de la pàgina que les conté.
  4. Configuracions de pàgina: Aquestes són les configuracions que s’apliquen a una sola pàgina. Es configuren a la metainformació de la pàgina.

En tots els casos, les opcions de tabi es configuren a la secció [extra].

Per a les configuracions que segueixen aquesta jerarquia, el valor establert a una pàgina reemplaça el valor d’una secció, que al seu torn reemplaça el valor global. En resum: com més específica sigui la configuració, més prioritat tindrà, o pàgina > pàgina pare/secció > config.toml.


Cerca

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

tabi permet cerca local accessible i multilingüe amb Elasticlunr. Per activar-la, necessites:

  1. Establir un default_language a config.toml.
  2. Establir build_search_index = true.
  3. Opcionalment, configurar la secció [search].

Per exemple:

base_url = "https://example.com"
default_language = "en"
build_search_index = true

[search]
index_format = "elasticlunr_json" # O el menys eficient "elasticlunr_javascript".
include_title = true
include_description = true
include_path = true
include_content = true

Nota: per suport de cerca en Xinès/Japonès, necessites utilitzar una build personalitzada de Zola. Addicionalment, actualment no hi ha suport per a la cerca en català.

Consideracions per a usuaris de Zola 0.17.X

Zola 0.17.X no proporciona accés a la variable search.index_format (informe del bug). En utilitzar tabi, s’assumeix l’ús de l’índex JSON, que és més eficient. No obstant això, a causa d’un altre bug solucionat en 0.18.0, l’índex JSON per a llocs multilingües no es genera correctament.

Els usuaris amb versions de Zola anteriors a 0.18.0 que vulguin utilitzar l’índex JavaScript necessiten establir la variable index_format a dos llocs:

[search]
index_format = "elasticlunr_javascript"

[extra]
index_format = "elasticlunr_javascript"

Això assegura que tabi carregui els arxius correctes. Recomanem actualitzar a Zola 0.18.0 o posterior per a una funcionalitat òptima.

Detalls d’implementació

Per a detalls tècnics sobre la implementació de la cerca, incloent quan es carrega l’índex, característiques d’accessibilitat i altres detalls, consulta el Pull Request #250.


Suport multilingüe

tabi ofereix suport multilingüe complet per al teu lloc Zola, des de configurar un idioma predeterminat fins a afegir tots els que vulguis. Consulta les preguntes freqüents sobre idiomes per a més informació.


Aparença

Pàgina principal

La pàgina principal d’aquesta demo té una capçalera amb una imatge, un títol i una descripció:

Capçalera de la pàgina principalCapçalera de la pàgina principal

Capçalera

Per configurar la imatge i el títol, pots utilitzar la variable header al front matter de l’arxiu _index.md de la secció. Per exemple:

[extra]
header = {title = "Hola! Soc tabi~", img = "img/main.webp", img_alt = "Óscar Fernández, l'autor del tema" }

La descripció és contingut Markdown normal, escrit fora del front matter.

Llistant publicacions recents

Per mostrar publicacions a la pàgina principal, primer has de decidir d’on es serviran: de la ruta arrel (/) o d’un subdirectori (per exemple, /blog).

Opció A: Servir publicacions des de la ruta arrel (/)

Configura paginate_by al front matter del teu arxiu content/_index.md:

title = "Últimes publicacions"
sort_by = "date"
paginate_by = 5  # Mostra 5 publicacions per pàgina.

[extra]
header = {title = "Hola! Soc tabi~", img = "img/main.webp", img_alt = "El teu nom" }
NOTE

La configuració paginate_by va al front matter principal, no a la secció [extra].

Opció B: Servir publicacions des d’un subdirectori (per exemple, /blog)

Utilitza section_path a la secció [extra] del teu arxiu content/_index.md:

title = "Últimes publicacions"
sort_by = "date"
# No configuris `paginate_by` aquí.

[extra]
header = {title = "Hola! Soc tabi~", img = "img/main.webp", img_alt = "El teu nom" }
section_path = "blog/_index.md"  # On trobar les teves publicacions.
max_posts = 5  # Mostra fins a 5 publicacions a la pàgina principal.
ALERTA

No configuris paginate_by i section_path alhora. Aquestes configuracions són mútuament excloents i usar ambdues pot fer que no es mostrin publicacions.

Notes addicionals:

  • El title al front matter estableix el títol que apareix sobre les publicacions.
  • Utilitza la ruta completa a l’arxiu _index.md de la secció per a section_path. Usar section_path = "blog/" no funcionarà.
Fixar entrades

Pots fixar entrades per mantenir-les a la part superior de la pàgina principal. En aquesta demo, aquesta entrada està fixada, així que apareix primera amb una icona i etiqueta de “fixada”:

Entrada fixadaEntrada fixada

Les entrades fixades es mostren primer, mantenint el seu ordre relatiu segons el sort_by de la secció, seguides per les entrades regulars.

Per fixar una entrada, afegeix el següent al seu front matter:

[extra]
pinned = true
INFO

Aquesta configuració només afecta les pàgines principals del lloc (com /, /es/, /fr/). Altres seccions com blog/, tags/ o archive/ mostren les publicacions en el seu ordre habitual.

{{ admonition(type=“warning”, text=‘Quan s’utilitza la paginació (paginate_by), les entrades fixades poden aparèixer dues vegades: una vegada a la part superior de la primera pàgina, i una altra en la seva posició cronològica normal en pàgines posteriors.’) }}

Mostrar la data dels articles al llistat

Per defecte, quan es llisten els articles, es mostra la data de creació. Pots configurar quina(es) data(es) mostrar utilitzant l’opció post_listing_date. Configuracions disponibles:

  • date: Mostra només la data de publicació original de l’article (opció per defecte).
  • updated: Mostra només la data de l’última actualització de l’article. Si no hi ha data d’actualització, es mostra la data de publicació original.
  • both: Mostra tant la data de publicació original com la data de l’última actualització.

Llistat de Projectes

Pots mostrar una selecció de projectes a la teva pàgina principal. Per fer això, primer necessitaràs configurar el directori projects.

Un cop fet això, configura la ruta als projectes a la secció [extra] del teu fitxer _index.md:

[extra]
projects_path = "projects/_index.md"

Això mostrarà els 3 projectes de major prioritat (amb menor pes; el mateix ordre que a Projectes). Per mostrar més o menys projectes, configura max_projects a [extra].

Per defecte, la secció de projectes es mostrarà a la part inferior de la pàgina principal, sota les publicacions. Si prefereixes mostrar-la a la part superior, configura show_projects_first = true.

Commutador de mode clar i fosc

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

El commutador de mode clar i fosc (la icona de lluna/sol a la cantonada superior dreta) es pot habilitar configurant theme_switcher = true a config.toml.

Mode predeterminat (clar/fosc)

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

El mode predeterminat es pot especificar amb la variable default_theme, que accepta "dark" o "light". Si no s’especifica, el mode predeterminat és el mode del sistema.

Skin personalitzada

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Les skins («pells») de tabi canvien el color principal del lloc web. Pots configurar la skin a config.toml amb skin = "nom_de_la_skin. Per exemple, skin = "lavender" es veu així (clica per canviar entre mode clar i fosc):

Explora les skins disponibles i aprèn com crear la teva pròpia consultant la documentació.

Font sans serif (pal sec)

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

tabi utilitza una font serif per als paràgrafs dels articles (la que estàs veient ara). Pots canviar a una font sans-serif (la que veus als encapçalaments/menú) a tot el teu lloc configurant override_serif_with_sans = true a config.toml.

Fes clic a la imatge a continuació per comparar les fonts:

Estils CSS personalitzats

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Pots carregar estils CSS personalitzats per a tot el lloc web o en pàgines específiques utilitzant stylesheets, que accepta una llista de rutes cap a arxius CSS. Per exemple:

stylesheets = ["css/custom.css", "css/another.css"]

Color del tema del navegador

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

El color del tema del navegador és el color que apareix a la barra de pestanyes del navegador:

pestanyes amb un tema de navegador de colorpestanyes amb un tema de navegador de color

Pots establir-ho a config.toml com a browser_theme_color = "#087e96". Si vols diferents colors per als modes clar/obscur, pots establir un conjunt de colors amb browser_theme_color = ["#ffffff", "#000000"]. El primer color és per al mode clar, el segon per al fosc.

Aquesta variable accepta qualsevol color CSS vàlid, així que pots utilitzar paraules clau (per exemple, blue), codis hexadecimals (per exemple, #087e96) o valors RGB/HSL (per exemple, rgb(8, 126, 150)).

Etiquetes compactes

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Per defecte, la pàgina d’etiquetes mostra les etiquetes com:

NomEtiqueta — n entrada[es]

Establir compact_tags = true les mostrarà com:

NomEtiqueta n

Ordre de les etiquetes

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Per defecte, la pàgina d’etiquetes ordena les etiquetes alfabèticament, donada la configuració predeterminada de tag_sorting = "name". Si configures tag_sorting = "frequency", s’ordenaran segons el nombre de publicacions (de més a menys).


Sèries

Per a una explicació detallada, consulta la documentació de sèries.

Enllaç per saltar a les publicacions

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Per defecte, apareix automàticament un enllaç “Salta a les publicacions” al costat del títol de la sèrie quan una sèrie té un contingut de més de 2000 caràcters:

enllaç per saltar a les publicacions de la sèrieenllaç per saltar a les publicacions de la sèrie

Estableix show_jump_to_posts = true per forçar l’activació de la funció i show_jump_to_posts = false per desactivar-la.

Indexació de pàgines de sèries

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Per defecte, les pàgines de sèries s’indexen (usant una indexació basada en 1) segons el sort_by de la secció de sèries.

Estableix post_listing_index_reversed = true per invertir aquest índex.


Integració amb repositoris Git

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

❓: show_remote_source sí que segueix la jerarquia i es pot configurar en una pàgina, secció o de manera global. La resta de les configuracions només es poden establir a config.toml.

Aquestes configuracions et permeten vincular el teu lloc web tabi amb un repositori públic de Git a GitHub, GitLab, Gitea o Codeberg. Exemples de configuració:

remote_repository_url = "https://github.com/welpo/tabi"
remote_repository_git_platform = "auto"
remote_repository_branch = "main"
show_remote_changes = true
show_remote_source = true

Això habilita dues funcions:

  1. show_remote_source = true afegeix un enllaç al codi font del teu lloc web (el teu remote_repository_url) que es mostrarà al peu de pàgina:
Peu de pàgina del lloc web, mostrant un enllaç 'Codi font del lloc'Peu de pàgina del lloc web, mostrant un enllaç 'Codi font del lloc'
  1. show_remote_changes = true afegeix un enllaç “Veure canvis ↗” a l’historial de commits de l’article actualitzat, al costat de la data de l’última actualització [1]:
Títol de l'article i metadades, mostrant un enllaç 'Veure canvis'Títol de l'article i metadades, mostrant un enllaç 'Veure canvis'

En clicar aquest enllaç, seràs dirigit a l’historial de commits de l’article, on podràs veure els canvis realitzats en ell:

Historial de commits d'un articleHistorial de commits d'un article

Pàgines

Projectes

tabi té una plantilla integrada per a projectes. Per habilitar-la, pots crear un directori a content/projects/. Allà, pots crear un fitxer _index.md amb el següent contingut al bloc de metadades:

title = "Projectes"
sort_by = "weight"
template = "cards.html"
insert_anchor_links = "left"

[extra]
show_reading_time = false
quick_navigation_buttons = true
  • title és el títol de la pàgina.
  • sort_by determina com s’ordenen els projectes. Pots ordenar per “date”, “update_date”, “title”, “title_bytes”, “weight”, “slug” o “none”.
  • template = "cards.html" estableix la plantilla per renderitzar la pàgina de projectes.
  • insert_anchor_links = "left" afegeix enllaços àncora als encapçalaments.
  • show_reading_time = false amaga el temps estimat de lectura.
  • quick_navigation_buttons = true mostra els botons de navegació ràpida.

Al costat del fitxer _index.md, pots crear un fitxer per a cada projecte. Per exemple, aquest és el bloc de metadades per a la pàgina del projecte tabi:

title = "tabi"
description = "Un tema de Zola ràpid, lleuger i modern amb suport multilingüe."
weight = 1

[extra]
local_image = "img/tabi.webp"
  • title és el títol del projecte.
  • description és la descripció del projecte.
  • weight determina l’ordre en què es mostren els projectes. Com menor sigui el pes, més amunt apareixerà el projecte.
  • local_image és la ruta de la imatge del projecte. Aquesta imatge es mostra a la pàgina de projectes.

Quan un usuari faci clic a la imatge o al títol d’un projecte, serà portat a la pàgina del projecte. Si prefereixes que els usuaris vagin a un enllaç extern, pots establir link_to = "https://example.com" a la secció [extra] del fitxer .md del projecte.

La pàgina del projecte individual es renderitza amb la plantilla predeterminada, tret que estableixis una altra, per exemple, template = "info-page.html".

Filtrar projectes

Si afegeixes etiquetes als teus projectes, veuràs un filtre d’etiquetes:

Pàgina de projectes amb filtre d'etiquetesPàgina de projectes amb filtre d'etiquetes

El sistema de filtratge d’etiquetes utilitza millora progressiva:

  • Sense JavaScript: Les etiquetes enllacen directament a pàgines d’etiquetes dedicades (per exemple, /tags/nom-de-l-etiqueta).
  • Amb JavaScript: Filtratge instantani, sincronització d’URL (#nom-etiqueta) i navegació amb el teclat.

Per desactivar aquesta funció, estableix enable_cards_tag_filtering = false a la secció [extra] del fitxer projects/_index.md o a config.toml.

TIP

Per filtrar projectes per etiquetes, necessites establir etiquetes a la front matter de cada projecte. Per exemple:

title = "nom del projecte"
weight = 40

[taxonomies]
tags = ["etiqueta", "etiqueta 2", "tercera etiqueta"]

Arxiu

Afegir una pàgina d’arxiu és similar a afegir una pàgina de projectes. Pots crear un directori a content/archive/. Allà, pots crear un fitxer _index.md amb el següent encapçalament:

title = "Arxiu"
template = "archive.html"

Per defecte, l’arxiu llistarà les publicacions situades a blog/. Per personalitzar això, pots modificar la secció [extra] de l’arxiu _index.md:

  • Per a un sol directori: Estableix section_path = "directori/" per llistar publicacions d’un directori específic. Assegura’t d’incloure la barra inclinada al final.

  • Per a múltiples directoris: Si vols agregar publicacions de diversos directoris, especifica la llista a section_path. Per exemple:

    [extra]
    section_path = ["blog/", "notes/", "camí-tres/"]
    

Nota:

  • La pàgina d’arxiu només llistarà publicacions amb data.
  • L’ordre de les publicacions ve determinada per la variable sort_by de les seccions arxivades. Aquesta demo utilitza sort_by = "date" en blog/_index.md.

Etiquetes

tabi té suport integrat per a etiquetes. Per habilitar-les, simplement afegeix la taxonomia al teu config.toml:

taxonomies = [{name = "tags", feed = true}]

Després, pots afegir etiquetes a les teves publicacions afegint-les a l’array tags en el bloc de metadades de la teva publicació. Per exemple:

title = "Els molins de vent de la meva vida: reflexions d'un escuder"
date = 1605-01-16
description = "El meu viatge al costat de Don Quixot, enfrontant-me a gegants imaginats i descobrint les veritables batalles de la vida."

[taxonomies]
tags = ["personal", "reflexions"]

Pàgina sobre

Si vols tenir una pàgina que no sigui un article, per exemple per a una secció “Sobre”, “Contacte” o “Drets d’autor”, pots utilitzar la plantilla info-page.html.

Primer, crea un directori dins de content/ amb el nom que prefereixis. Per exemple, content/pages/. Després, crea un fitxer _index.md dins d’aquest directori. El fitxer hauria de ser així:

+++
render = false
insert_anchor_links = "left"
+++
  • render = false indica a Zola que no renderitzi la secció.
  • insert_anchor_links = "left" afegeix enllaços àncora als encapçalaments. Això és opcional.

Dins del directori, pots crear qualsevol quantitat de fitxers .md.

En aquesta demo, la pàgina Sobre mi utilitza la plantilla info-page.html. El bloc de metadades és el següent:

title = "Sobre mi"
template = "info-page.html"
path = "about"

Fixa’t com s’estableix path = "about". Zola situarà la pàgina a $base_url/about/. Si vols que la pàgina estigui disponible a /contacte/, hauries d’establir path = "contacte".

La plantilla info-page.html també es pot utilitzar per crear landing pages a la ruta arrel ("/"). Per fer-ho, l’arxiu content/_index.md hauria de ser així:

+++
title = "Títol de la pàgina"
template = "info-page.html"
+++

Contingut amb Markdown.

SEO

tabi s’encarrega de la majoria de tasques de SEO per a tu (com ara les etiquetes del protocol Open Graph, descripció, paleta de colors…), però hi ha certes configuracions que pots personalitzar.

Favicon

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

El favicon és la petita imatge que es mostra a la pestanya del navegador. Pots establir-la a config.toml amb favicon = "img/favicon.png".

Favicon d’emoji

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

També pots establir un emoji com a favicon amb favicon_emoji. Per exemple, favicon_emoji = "👾".

Nota: Alguns navegadors no suporten favicons d’emoji. Consulta la taula de compatibilitat a caniuse.

URL canònica

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

L’URL canònica és una manera d’indicar als motors de cerca quina és l’URL preferida per al contingut del teu lloc web. Això és útil per al SEO i per evitar problemes de contingut duplicat.

Per defecte, l’URL canònica és l’URL de la pàgina on et trobes. No obstant això, pots canviar això configurant canonical_url al front matter de la teva pàgina o secció.

Si tens un lloc amb una estructura idèntica i contingut coincident, pots configurar base_canonical_url al teu config.toml. L’URL canònica es crearà substituint el $base_url de l’URL actual amb el $base_canonical_url que establisquis.

Per exemple, si configures base_canonical_url = "https://example.com", l’URL canònica de la pàgina $base_url/blog/post1 serà https://example.com/blog/post1. Això és útil si tens un lloc amb diversos dominis que comparteixen el mateix contingut.

Nota: per assegurar-te que l’URL canònica sigui correcta, probablement serà millor configurar canonical_url individualment per a cada pàgina.

Targetes per a xarxes socials

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Les targetes per a xarxes socials són les imatges que es mostren quan comparteixes un enllaç a les xarxes socials:

Una captura de pantalla de WhatsApp mostrant un enllaç amb una targeta per a xarxes socials

Pots establir la imatge per a xarxes socials amb social_media_card = "img/social_media_card.png".

Pots especificar rutes tant relatives com absolutes.

  • Ruta relativa: Posiciona la imatge a la mateixa carpeta que la teva entrada de blog i especifica el seu nom. Per exemple, social_media_card = "relative_image.png".

  • Ruta absoluta: Posiciona la imatge en una carpeta específica i especifica la ruta des de l’arrel. Per exemple, social_media_card = "/img/absolute_image.png".

Si ambdues rutes, relativa i absoluta, són vàlides, la ruta relativa tindrà prioritat.

Ja que segueix la jerarquia, si no està configurat en una pàgina, però sí ho està en una secció, s’utilitzarà la imatge de la secció. Si no està configurat en una pàgina o secció, però sí en config.toml, s’utilitzarà la imatge global.

CONSELL

Automatitza la seva creació amb un script: Automatitzant les vistes prèvies dels enllaços amb Zola.

Creador del fedivers

PàginaSeccióconfig.tomlSegueix jerarquiaRequereix JavaScript

Pots mostrar el perfil del fedivers de l’autor en les previsualitzacions d’enllaços de Mastodon configurant la variable fediverse_creator al teu config.toml. Per exemple, per a @username@example.com, fes servir:

fediverse_creator = { handle = "username", domain = "example.com" }

Barra de navegació

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

La barra de navegació és la franja a la part superior de la pàgina que conté el títol del lloc i el menú de navegació. Pots personalitzar els elements que apareixen configurant menu en config.toml. Per exemple:

menu = [
    { name = "blog", url = "blog", trailing_slash = true },
    { name = "arxiu", url = "archive", trailing_slash = true },
    { name = "etiquetes", url = "tags", trailing_slash = true },
    { name = "projectes", url = "projects", trailing_slash = true },
    { name = "sobre nosaltres", url = "about", trailing_slash = true },
]

Botons de navegació ràpida

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Els botons de navegació ràpida són els botons que apareixen a la part inferior dreta de la pantalla. Hauries de veure’ls en aquesta pàgina, si no estàs en un dispositiu mòbil. Es veuen així:

Botons de navegació ràpidaBotons de navegació ràpida

Per activar-los, estableix quick_navigation_buttons = true.

Taula de continguts

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Activa l’índex de continguts just sota del títol i metadades de l’article amb toc = true.

Per saber més sobre com personalitzar-ho, consulta la documentació sobre la Taula de continguts.

Enllaços als articles anterior i següent

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Mostra enllaços als articles anterior i següent a la part inferior dels posts. Es veu així:

Enllaços als articles anterior i següentEnllaços als articles anterior i següent

Per activar aquesta funció, estableix show_previous_next_article_links = true i assegura’t que la secció té un valor sort_by (per exemple sort_by = "date").

Per defecte, els articles següents estaran al costat esquerre de la pàgina i els articles anteriors al costat dret. Per invertir l’ordre (articles següents al costat dret i articles anteriors al costat esquerre), configura invert_previous_next_article_links = true.

Per defecte, aquesta secció de navegació tindrà l’amplada completa del lloc (igual que la barra de navegació de la part superior). Per fer-la més estreta, coincidint amb l’amplada de l’article, configura previous_next_article_links_full_width = false.

Totes aquestes configuracions segueixen la jerarquia.

Enllaços de retorn a les notes a peu de pàgina

ADVERTÈNCIA DE DEPRECACIÓ

Zola v0.19.0 i posterior pot fer això de forma nativa. Estableix bottom_footnotes = true a la secció [markdown] de la teva configuració.

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Establir footnote_backlinks = true afegirà enllaços de retorn a les notes a peu de pàgina de les teves publicacions, com aquest:

Enllaços de retorn a les notes a peu de pàginaEnllaços de retorn a les notes a peu de pàgina

Quan facis clic en un enllaç de retorn (la fletxa ↩), et portarà de tornada al punt del text on es va fer referència a la nota a peu de pàgina.


Usabilitat

Botó de copiar en blocs de codi

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Establir copy_button = true afegirà un petit botó de copiar a la part superior dreta dels blocs de codi, com aquest:

Botó de copiar en blocs de codiBotó de copiar en blocs de codi

Mostrar ruta/URL en blocs de codi

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Estableix add_src_to_code_block = true per habilitar l’ús del shortcode add_src_to_code_block.

Forçar blocs de codi d’esquerra a dreta

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Per defecte, els blocs de codi es renderitzen d’esquerra a dreta, independentment de la direcció general del text. Estableix force_codeblock_ltr = false per permetre que els blocs de codi segueixin la direcció del document. Útil per a idiomes de dreta a esquerra que necessiten blocs de codi de dreta a esquerra.

Suport per a KaTeX

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

KaTeX és una biblioteca JavaScript ràpida i fàcil d’usar per a la representació de matemàtiques TeX a la web. Pots habilitar-ho amb katex = true. Mira com es veu en tabi aquí.

Suport per a Mermaid

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Mermaid és una eina de diagramació i gràfics basada en JavaScript. Pots activar-la amb mermaid = true.

Per defecte, la biblioteca Mermaid es serveix localment. Si prefereixes utilitzar un CDN, estableix serve_local_mermaid = false a config.toml. L’ús d’un CDN servirà la versió més recent de Mermaid; l’opció local servirà la versió inclosa amb tabi.

Consulta la documentació de Mermaid per a instruccions d’ús i exemples.

Subconjunt de tipus de lletra personalitzat

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Les tipus de lletra personalitzades causen parpalleig del text en Firefox. Per resoldre això, tabi carrega un subconjunt de glifs per a la capçalera. Donat que això (lleugerament) augmenta el temps de càrrega inicial, és una bona idea intentar minimitzar la mida d’aquest subconjunt, o desactivar-lo completament si no estàs fent servir un tipus de lletra personalitzat al teu tema.

Pots crear un subconjunt personalitzat adaptat al teu lloc, guardar-lo com a static/custom_subset.css, i fer que es carregui amb custom_subset = true.

Per desactivar el subconjunt, utilitza enable_subset = false.

Per obtenir més informació, incloent instruccions sobre com crear un subconjunt personalitzat, consulta la documentació.

Contingut complet al feed

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Per defecte, el feed Atom només conté el resum o descripció de les teves publicacions. Pots incloure el contingut complet de les publicacions establint full_content_in_feed = true a config.toml.

Amagar contingut del feed

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Pots amagar pàgines específiques o seccions senceres del feed amb hide_from_feed = true.

Comentaris

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Per activar els comentaris en una pàgina, establert el nom del sistema com a true al front matter. Per exemple, utterances = true.

Si vols activar els comentaris de forma global, pots fer-ho establint enabled_for_all_posts = true a la secció apropiada del teu config.toml (per exemple, a [extra.giscus]).

Si has activat un sistema de forma global i vols desactivar-lo per a una pàgina específica, pots fer-ho establint el nom del sistema com a false al front matter. Per exemple, utterances = false.

Llegeix la documentació per a més informació sobre els sistemes disponibles i la seva configuració.

Anàlisi web

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

tabi ofereix suport per a 3 sistemes d’anàlisi web que respecten la privacitat: Plausible, GoatCounter i Umami.

Pots configurar-los en la secció [extra.analytics] del teu arxiu config.toml.

  • service: el servei a utilitzar. Les opcions disponibles són "goatcounter", "umami", i "plausible".

  • id: l’identificador únic per al teu servei d’anàlisi. Això varia segons el servei:

    • Per a GoatCounter, és el codi triat durant el registre. Instàncies auto-allotjades de GoatCounter no requereixen aquest camp.
    • Per a Umami, és l’ID del lloc web.
    • Per a Plausible, és el nom de domini.
  • self_hosted_url: Opcional. Utilitza aquest camp per especificar l’URL si tens una instància auto-allotjada. L’URL base variarà segons la teva configuració particular. Alguns exemples:

    • Per a GoatCounter: "https://stats.example.com"
    • Per a Umami: "https://umami.example.com"
    • Per a Plausible: "https://plausible.example.com"

Un exemple de configuració per a GoatCounter no auto-allotjada seria:

[extra.analytics]
service = "goatcounter"
id = "tabi"
self_hosted_url = ""

Icones al peu de pàgina

Icones de xarxes socials

PàginaSeccióconfig.tomlRespecta jerarquiaRequereix JavaScript

Pots afegir icones de xarxes socials al peu de pàgina amb socials, que accepta una llista d’objectes de xarxes socials. Per exemple:

socials = [
    { name = "github", url = "https://github.com/welpo/", icon = "github" },
    { name = "soundcloud", url = "https://soundcloud.com/oskerwyld", icon = "soundcloud" },
    { name = "instagram", url = "https://instagram.com/oskerwyld", icon = "instagram" },
    { name = "youtube", url = "https://youtube.com/@oskerwyld", icon = "youtube" },
    { name = "spotify", url = "https://open.spotify.com/artist/5Hv2bYBhMp1lUHFri06xkE", icon = "spotify" },
]

Per veure una llista de totes les icones integrades, fes un cop d’ull al directori static/social_icons a GitHub.

Trobes a faltar algun icona? Si creus que seria una bona addició a tabi, no dubtis en obrir un issue o enviar una pull request (exemple).

Per utilitzar una icona personalitzada, pots afegir-la al directori static/social_icons del teu lloc web. Per exemple, si afegeixes custom.svg, la pots referenciar així:

{ name = "custom", url = "https://example.com", icon = "custom" }
NOTA

Tots els enllaços a xarxes socials inclouen l’atribut rel='me'. Això ajuda els motors de cerca i serveis web a verificar que les comptes de xarxes socials et pertanyen.

Icona de feed

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Pots afegir un enllaç al teu feed RSS/Atom al peu de pàgina amb feed_icon = true.

Nota pels usuaris de Zola 0.19.X: quan hi ha dos noms de fitxer a feed_filenames, només s’enllaçarà el primer al peu de pàgina.

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Pots afegir un menú al peu de pàgina amb footer_menu, que accepta una llista d’elements de menú. Per exemple:

footer_menu = [
    {url = "about", name = "about", trailing_slash = true},
    {url = "privacy", name = "privacy", trailing_slash = true},
    {url = "sitemap.xml", name = "sitemap", trailing_slash = false},
    {url = "https://example.com", name = "external link", trailing_slash = true},
]
PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Per afegir una menció sobre els drets d’autor al teu lloc web, configura copyright:

copyright = "© $CURRENT_YEAR Your Name $SEPARATOR Unless otherwise noted, the content in this website is available under the [CC BY-SA 4.0](https://creativecommons.org/licenses/by-sa/4.0/) license."
  • $TITLE serà reemplaçat per la variable title configurada a config.toml
  • $CURRENT_YEAR serà reemplaçat per l’any actual
  • $AUTHOR serà reemplaçat per la variable author
  • $SEPARATOR serà reemplaçat per la variable separator.

El text es processarà en Markdown. Per exemple, la configuració d’adalt:

Secció de drets d'autorSecció de drets d'autor

Si tens un lloc multilingüe i vols establir diferents notificacions de drets d’autor per a diferents idiomes, afegeix la traducció corresponent a copyright_translations.{codi_d'idioma} per a cada idioma que vulguis donar suport. El codi de llengua ha de coincidir amb el codi de llengua de tabi. Per exemple, pel castellà:

copyright_translations.es = "© $CURRENT_YEAR $AUTHOR $SEPARATOR A menos que se indique lo contrario, el contenido de esta web está disponible bajo la licencia [CC BY-SA 4.0](https://creativecommons.org/licenses/by-sa/4.0/)."

Metadades

Mostrar autoria

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Per mostrar l’autoria d’un article, estableix show_author = true.

Això mostrarà els autors establerts a la variable authors = [] al front matter del post. Si aquest camp no està configurat, mostrarà l’autor de config.toml (author = "").

Temps de lectura

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Pots activar o desactivar el temps estimat de lectura d’un article amb show_reading_time. Si el configures com a true, apareixerà a les metadades de l’article, com això:

Títol de l'article i metadades, mostrant un enllaç «Veure canvis»Títol de l'article i metadades, mostrant un enllaç «Veure canvis»

Com que segueix la jerarquia, pots activar-lo o desactivar-lo per a pàgines o seccions específiques. Per exemple, aquesta demo desactiva show_reading_time = false a la secció projectes a l’arxiu _index.md, de manera que les seves publicacions individuals no mostren el temps de lectura.

Mostrar la data

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Per defecte, la data es mostra sota el títol de la publicació. Pots amagar-la amb show_date = false. Aquest ajust segueix la jerarquia.

Format de data

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

tabi té dos formats de data: long_date_format i short_date_format. El format curt s’utilitza a les metadades d’una publicació, mentre que el format llarg s’utilitza al llistar les publicacions (és a dir, a la secció de blog o a la pàgina principal).

Per defecte és “6th July 2049” per a ambdós formats en anglès. Per a altres idiomes, el predeterminat és "%d %B %Y" per al format llarg i "%-d %b %Y" per al format curt.

A Zola, la sintaxi per al format de temps està inspirada en strftime. Una referència completa està disponible a la documentació de chrono.

Separador personalitzat

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

El separador apareix en diversos llocs: al títol del navegador, entre les metadades d’una publicació…

El separador per defecte és un punt de llista (), però pots canviar-lo configurant alguna cosa com separator = "|".

Ordre del títol

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Per defecte, el títol a la pestanya del navegador és el nom del lloc seguit del títol de la pàgina. Per exemple, el títol de la secció del blog és «~/tabi • Blog».

Configurant invert_title_order = true, pots invertir l’ordre del títol del lloc i el títol de la pàgina a la pestanya del navegador. Per exemple, l’etiqueta del títol de la secció del blog es convertiria en «Blog • ~/tabi».


Certainly, here is a high-quality, non-literal translation of the provided text into Catalan. I’ve adhered to your specifications, keeping the variables and English terms unchanged.

Seguretat

Correu electrònic codificat

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

Per tal de protegir la teva adreça de correu electrònic contra els spambots, pots codificar-la al peu de pàgina. Pots fer això establint email a una versió codificada en base64 de la teva adreça de correu electrònic[2]. Per exemple, email = "bWFpbEBleGFtcGxlLmNvbQ==" és la versió codificada en base64 de “mail@example.com”.

Si no vols codificar el teu correu electrònic tu mateix, tabi pot fer-ho per tu si configures encode_plaintext_email = true. Això et permet establir un correu electrònic en text pla en la configuració. Tingues en compte que això només protegeix la teva adreça de correu electrònic al teu lloc web, no en repositoris públics.

Si el correu electrònic està codificat (ja sigui per tu o per tabi), els usuaris amb JavaScript desactivat no veuran la icona de correu electrònic.

CSP (Content Security Policy)

PàginaSeccióconfig.tomlSegueix la jerarquiaRequereix JavaScript

La Content Security Policy (CSP) és una capa addicional de seguretat que ajuda a detectar i mitigar certs tipus d’atacs, inclosos atacs de Cross Site Scripting (XSS) i injecció de dades. Aquests atacs s’utilitzen per a tot, des del robatori de dades fins a la desfiguració de llocs web i la distribució de programari maliciós.

tabi té una CSP predeterminada que permet imatges i vídeos remots, així com incrustacions de YouTube i Vimeo. Pots personalitzar-la amb allowed_domains, que accepta una llista de directrius de CSP. Aquesta és la CSP predeterminada:

allowed_domains = [
    { directive = "font-src", domains = ["'self'", "data:"] },
    { directive = "img-src", domains = ["'self'", "https://*", "data:"] },
    { directive = "script-src", domains = ["'self'"] },
    { directive = "style-src", domains = ["'self'"] },
    { directive = "frame-src", domains = ["player.vimeo.com", "https://www.youtube-nocookie.com"] },
]

Aquesta opció està habilitada per defecte. Per desactivar-la per una pàgina, secció o globalment, estableix enable_csp = false. La configuració de enable_csp segueix la jerarquia.

Per a més informació, consulta la pàgina de documentació de CSP.


  1. Si estàs utilitzant un repositori Git remot, potser voldràs automatitzar el procés d’actualització del camp updated. Aquí tens una guia per a això: Zola Git Hook: actualitzant les dates de les publicacions.

  2. Per a codificar el teu correu electrònic en base64 pots utilitzar eines en línia o, al teu terminal, executar: printf 'mail@example.com' | base64