Hugo Shortcodes personnalisés
Cette page explique les shortcodes Hugo personnalisés pouvant être utilisés dans la documentation de Kubernetes Markdown.
En savoir plus sur shortcodes dans la documentation Hugo.
Etat de la fonctionnalité
Dans une page de Markdown (fichier .md
) de ce site, vous pouvez ajouter un code court pour afficher la version et l'état de la fonction documentée.
Feature state demo
Ci-dessous se trouve une démo de l'extrait d'état de la fonctionnalité, qui affiche la fonctionnalité comme stable dans Kubernetes version 1.10.
{{< feature-state for_k8s_version="v1.10" state="stable" >}}
Rend à :
Kubernetes v1.10 [stable]
Les valeurs valides pour state
sont :
- alpha
- beta
- deprecated
- stable
Feature state code
La version de Kubernetes affichée par défaut est celle de la page ou du site.
Ceci peut être modifié en passant le paramètre for_k8s_version
shortcode.
{{< feature-state for_k8s_version="v1.10" state="stable" >}}
Rend à :
Kubernetes v1.10 [stable]
Alpha feature
{{< feature-state feature-state state="alpha" >}}
Rend à :
Kubernetes v1.23 [alpha]
Beta feature
{{< feature-state feature-state state="beta" >}}
Rend à :
Kubernetes v1.23 [beta]
Stable feature
{{< feature-state feature-state state="stable" >}}
Rend à :
Kubernetes v1.23 [stable]
Deprecated feature
{{< feature-state feature-state state="deprecated" >}}
Rend à :
Kubernetes v1.23 [deprecated]
Glossaire
Vous pouvez faire référence à des termes du glossaire avec une inclusion qui met à jour et remplace automatiquement le contenu avec les liens pertinents de notre glossaire. When the term is moused-over by someone using the online documentation, the glossary entry displays a tooltip.
The raw data for glossary terms is stored at https://github.com/kubernetes/website/tree/master/content/en/docs/reference/glossary, with a content file for each glossary term.
Démonstration du glossaire
Par exemple, le snippet suivant est rendu à cluster avec une infobulle :
{{< glossary_tooltip text="cluster" term_id="cluster" >}}
Tabs
Dans une page de démarque (fichier .md
) de ce site, vous pouvez ajouter un jeu d'onglets pour afficher plusieurs saveurs d'une solution donnée.
The tabs
shortcode takes these parameters:
name
: Le nom tel qu'il apparaît sur l'onglet.codelang
: Si vous fournissez un contenu interne au shortcodetab
, vous pouvez indiquer à Hugo quel langage de code utiliser pour activer la coloration syntaxique.include
: Le fichier à inclure dans l'onglet. Si l'onglet vit dans un Hugo leaf bundle, le fichier -- qui peut être n'importe quel type MIME supporté par Hugo -- est recherché dans le bundle lui-même. Si ce n'est pas le cas, la page de contenu qui doit être incluse est recherchée par rapport à la page en cours. Notez qu'avec leinclude
, vous n'avez pas de contenu interne de shortcode et devez utiliser la syntaxe de fermeture automatique. Par exemple,{{< tab name="Content File #1" include="example1" />}}
. La langue doit être spécifiée souscodelang
ou la langue est prise en compte en fonction du nom du fichier. Les fichiers non contenus sont mis en surbrillance par défaut.- Si votre contenu interne est Markdown, vous devez utiliser le délimiteur
%
pour entourer l'onglet. Par exemple,{{% tab name="Tab 1" %}}This is **markdown**{{% /tab %}}
- Vous pouvez combiner les variations mentionnées ci-dessus dans un ensemble d'onglets.
Ci-dessous se trouve une démo du raccourci des onglets.
tabs
doit être unique dans une page de contenu.
Tabs demo: Code highlighting
{{< tabs name="tab_with_code" >}}
{{{< tab name="Tab 1" codelang="bash" >}}
echo "This is tab 1."
{{< /tab >}}
{{< tab name="Tab 2" codelang="go" >}}
println "This is tab 2."
{{< /tab >}}}
{{< /tabs >}}
Rend à:
echo "This is tab 1."
println "This is tab 2."
Tabs demo: Inline Markdown and HTML
{{< tabs name="tab_with_md" >}}
{{% tab name="Markdown" %}}
This is **some markdown.**
{{< note >}}
It can even contain shortcodes.
{{< /note >}}
{{% /tab %}}
{{< tab name="HTML" >}}
<div>
<h3>Plain HTML</h3>
<p>This is some <i>plain</i> HTML.</p>
</div>
{{< /tab >}}
{{< /tabs >}}
Rend à:
This is some markdown.
Plain HTML
This is some plain HTML.
Tabs demo: File include
{{< tabs name="tab_with_file_include" >}}
{{< tab name="Content File #1" include="example1" />}}
{{< tab name="Content File #2" include="example2" />}}
{{< tab name="JSON File" include="podtemplate" />}}
{{< /tabs >}}
Rend à:
Ceci est un fichier de contenu exemple à l'intérieur du paquet de feuilles includes.
Ceci est un autre exemple fichier de contenu à l'intérieur du paquet de feuilles includes.
{
"apiVersion": "v1",
"kind": "PodTemplate",
"metadata": {
"name": "nginx"
},
"template": {
"metadata": {
"labels": {
"name": "nginx"
},
"generateName": "nginx-"
},
"spec": {
"containers": [{
"name": "nginx",
"image": "dockerfile/nginx",
"ports": [{"containerPort": 80}]
}]
}
}
}
A suivre
- En savoir plus sur Hugo.
- En savoir plus sur écrire un nouveau sujet.
- En savoir plus sur l'utilisation des page templates.
- En savoir plus sur staging your changes
- En savoir plus sur créer une pull request.