Contribuer au site

Tag :
  • cs
Auteurs :
  • François Brucker

Le site Do_It est un site constitué de fichiers écrit au format Markdown. Y contribuer est très simple, il suffit de suivre ce document.

Architecture d'un post

Un post Do_It est un dossier à mettre dans le code source du site. Par exemple, cette page est le dossier https://github.com/FrancoisBrucker/do-it/tree/main/src/cs/contribuer-au-site

Ce dossier contient :

Il y a 3 endroits où placer ses contributions :

Post cs

Votre dossier de post doit s'appeler comme l'intitulé du cours, en remplaçant les espace par des -.

Par exemple ce post s'appelle contribuer-au-site et est rangé dans le dossier cs :

src
└── cs
    ├── contribuer-au-site
    │   └── index.md
    └── index.njk

Post pok

Comme plusieurs groupes de personnes peuvent faire le même pok, on ajoute une indirection. Votre dossier de post doit s'appeler des initiales des personnes constituant le groupe (séparés par des -) et être placé dans le dossier du pok correspondant. Par exemple si j'avais avec Geo fait le pok "un site chez moi", le post aurait été nommé FB-GD, et aurait été de cette forme :

src
└── pok
    ├── un-site-chez-moi
    │   ├── FB-GD
    │   │   ├── index.njk
    │   │   └── sources.zip
    │   ├── RS
    │   └── index.njk
    └── index.njk

Il aurait en effet contenu, en plus du fichier index.md les sources du site compressées au format zip.

Post mon

De la même manière que le poste pok.

Le fichier index.md

Il est constitué de trois parties :

Exemple

Ce fichier est visible à cette adresse.

Entête

Ce sont les premières lignes du site. Elles contiennent les méta-données du post :

---
layout: layout/post.njk

title: "Contribuer au site"
authors:
  - François Brucker
résumé: "Comment contribuer au site Do_It."

tags:
  - 'cs'
---

Résumé

Dans l'entête.

corps du texte

Le reste du post, écrit en markdown. Le titre est déjà mis, vos différentes parties sont donc de niveau ##

les ressources

Placez les ressources dans le même dossier que votre post. Vos liens auront alors l'une des deux formes suivantes

Ressources à télécharger

[ressource à télécharger](./sources.zip)`{.fichier}

Images

![image à voir](./mon-image.webp)`{.fichier}

Si vous nommez votre fichier autrement que index.md, il faut mettre ../ devant le chargement de votre ressource (ex : ![image à voir](../mon-image.webp)).

En effet, si vous utilisez par exemple mon_fichier.md comme nom de post, eleventy va :

  1. créer un dossier nommer mon_fichier
  2. placer votre post dans ce dossier et le renommer index.md

Vos images ne se retrouvent du coup plus dans le bon dossier...

C'est pourquoi, il est recommandé de toujours créer un dossier avec le nom de votre post et d'y mettre vos données,fichier index.md et ressources.

Possibilités étendues en markdown

Plusieurs balises spéciales ont été ajoutées pour vous aider à écrire des parties spécifiques de votre post.

liens

Il existe plusieurs façons d'écrire les liens. On suppose que l'on a l'architecture suivante :

src
└── pok
    ├── un-site-chez-moi
    │   ├── FB-GD
    │   │   ├── index.njk
    │   │   └── sources.zip
    │   ├── RS
    │   └── index.njk
    ├── index.njk
    └── cs
       ├── contribuer-au-site
       │   └── index.md
       └── index.njk

Et que l'on veuille, depuis le post FB-GD, aller vers le post contribuer-au-site.

Il y a deux façons de faire :

Texte spécial

En plus des possibilités markdown, on ajoute deux distinctions de texte :

Shortcodes

Les shortcodes sont des aides markdown. Elles permettent de mettre en valeur un paragraphe. elles sont toutes de la même forme :

{% nom_shortcode "titre de la shortcode" %} le contenu de la shortcode. {% endnom_shortcode %}

Le titre de la shortcode est toujours optionnel. Mais s'il est présent il est obligatoirement entre " ".

Shortcode attention

faisez attention

Une grosse mise en garde.

Code :

{% attention "**faisez** attention" %} Une *grosse* mise en garde. {% endattention %}

Shortcode note

Nom de la shortcode : note

Une note à retenir.

Code :

{% note %} Une note à retenir. {% endnote %}

Shortcode info

Un truc marrant ou une information utile, mais pas indispensable.

Code :

{% info %} Un truc marrant ou une information utile, mais pas indispensable. {% endinfo %}

Shortcode faire

Quelque-chose à faire.

Code :

{% faire %} Quelque-chose à faire. {% endfaire %}

Shortcode details

titre de la shortcode

Quelque chose de caché. Que l'on peut écrire en Markdown

Le titre de la shortcode est automatiquement mis en gras.

Code :

{% details "titre de la shortcode" %} Quelque chose de caché. Que l'on peut *écrire* en `Markdown` {% enddetails %}

Shortcode exercice

Un exercice à faire.

On peut le combiner avec la shortcode details pour créer un exercice et son corrigé :

Sujet de l'exercice

corrigé

Le corrigé de l'exercice.

Code :

{% exercice %} Sujet de l'exercice {% endexercice %} {% details "corrigé" %} Le corrigé de l'exercice. {% enddetails %}

Shortcode chemin

Pour emmener vers un autre cours par exemple :

Code :

{% chemin %} [Cours do-it de FB](https://francoisbrucker.github.io/cours_informatique/enseignements/ecm/3A/do-it/) {% endchemin %}

Shortcode prerequis

  • un pré-requis à lire
  • un autre pré-requis à lire

Code :

{% prerequis %} - un pré-requis à lire - un autre pré-requis à lire {% endprerequis %}

Shortcode lien

Code :

{% lien %} - [un MON utile](/promos/2023-2024/Lucie-Le-Boursicaud/mon/temps-2.2/) - [un cours qui sert](https://francoisbrucker.github.io/cours_informatique/cours/web/) {% endlien %}

Shortcode lieninterne

Un POK traitant d'un sujet.
Gordon Zola
01/09/1970

Code avec un lien absolu :

{% lieninterne "/promos/20XX-20YY/Zola-Gordon/pok/temps-1" %}

Codes avec des liens relatifs (par exemple dans votre fichier /promos/20XX-20YY/Zola-Gordon/pok/index.md) :

{% lieninterne "./temps-1" %}
{% lieninterne "./temps-2/" %}

Écrire du code

Pour écrire du code, le thème prismjs se chargera de la coloration syntaxique.

Par exemple :

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8" />
        <link rel="icon" href="assets/favicon.webp" />
        ...
    </head>
    <body class="language-none">
    <header data-plugin-header="line-numbers"></header>
    <section class="language-markup">
      <h1>How to use</h1>
      ...
    </body>
</html>

Peut s'écrire avec le markdown suivant :

    
```html
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="utf-8" />
        <link rel="icon" href="assets/favicon.webp" />
        ...
    </head>
    <body class="language-none">
    <header data-plugin-header="line-numbers">
    <section class="language-markup">
      <h1>How to use
      ...
    </body>
</html>
```
    

Également, il est possible d'ajouter les numéros de ligne comme ceci :

print(42)
print(43)

Avec le code :

    
```python/
print(42)
print(43)
```
    

Tables

On utilise les possibilités de multimarkdown

Table avec titre

titre colonne 1 titre colonne 2
Content Cell Content Cell
Content Cell Content Cell

Code :

| titre colonne 1  | titre colonne 2 |
| ---------------- | --------------- |
| Content Cell     | Content Cell    |
| Content Cell     | Content Cell    |

Tables sans titre

Content Cell Content Cell
Content Cell Content Cell

Code :

| ------------- | ------------- |
| Content Cell  | Content Cell  |
| Content Cell  | Content Cell  |

Tables multi-colonnes

Je prends 2 colonnes
Content Cell Content Cell

Code :

| ------------- | ------------- |
| Je prends 2 colonnes ||
| Content Cell | Content Cell |

Tables multi-lignes

Je prends 2 lignes Content Cell
Content Cell
Content Cell Content Cell

Code :

| ------------- | ------------- |
| Je prends 2 lignes |Content Cell |
| ^^ |Content Cell |
| Content Cell | Content Cell |

plusieurs ligne dans une cellule

  1. ligne colonne 1
  2. ligne colonne 1
  1. ligne colonne 2
  2. ligne colonne 2
Content Cell Content Cell

Code :

| ------------- | ------------- |
| 1. ligne colonne 1 | 1. ligne colonne 2 | \
| 1. ligne colonne 1 | 2. ligne colonne 2 |
| Content Cell | Content Cell |

Alignement horizontal

Content Cell Content Cell Content Cell
Content Cell Content Cell Content Cell
Content Cell Content Cell Content Cell

Code :

| :- | :-: | -: |
| Content Cell | Content Cell | Content Cell |
| Content Cell | Content Cell |Content Cell |
| Content Cell | Content Cell |Content Cell |

Alignement vertical

On ajoute un style, mais il ne faut pas que ce soit la dernière colonne. Exemple sur une colonne multi-ligne :

Content Cell Content Cell
Content Cell
Content Cell Content Cell

Code :

| ------------- | ------------- |
| Content Cell {style="vertical-align:middle"}| Content Cell |
| ^^| Content Cell |
| Content Cell | Content Cell |

Si l'on veut avoir un alignement vertical de la dernière colonne, il faut ajouter une colonne vide (je ne sais pas trop pourquoi) :

Content Cell Content Cell
Content Cell
Content Cell Content Cell

Code :

| ------------- | ------------- | - |
| Content Cell | Content Cell {style="vertical-align:middle"}| |
| Content Cell | ^^ | |
| Content Cell | Content Cell | |

tbd

TBD

  • résumé :

    1. toujours pris en compte : dans l'entête
    2. dans les résumés si pas 1
      1. premier paragraphe
      2. entre balise
  • pok, mon, mon-index, pok-index, projet

  • entête, pas de [] que des listes