3 min de lecture
259 vues

Rédiger les articles sur Laravel Cameroun Avec MarkdownX

Rédiger les articles sur Laravel Cameroun Avec MarkdownX

Dans cet article nous allons détailler pas à pas comment rédiger un article sur Laravel Cameroun. Il existe plusieurs éditeurs pour rédiger du contenu dans un site web. Chaque site selon ses besoins met en place un éditeur de text qui pourrait correspondre au profil des utilisateurs. Dans notre cas étant une communauté de développeurs, nous allons utiliser un éditeur de type Markdown

C'est quoi le Markdown ?

D'après Wikipédia, le Markdown est un langage de balisage léger permettant de créer du texte formaté à l'aide d'un éditeur de texte brut (notre bon vieux Textarea). Et de plus ne plus de nos jours beaucoup de plateformes utilisent cet éditeur comme langage de texte (WhatsApp, Telegram, Messenger, etc). On considère de plus en plus aussi cet éditeur comme étant un éditeur uniquement réservé aux développeurs ce qui n'est pas forcément le cas sachant que l'un des créateurs du Markdown en 2004 est John Gruber qui est un UI Designer. Les syntaxes pour écrire du Markdown sont listés sur ce lien

Mais pour rédiger nos articles (et la plus part des contenus sur ce site) nous allons utiliser un éditeur Markdown un peu plus puissant et qui est facile à prendre en main: MarkdownX

C'est quoi MarkdownX ?

MarkdownX est un éditeur markdown qui offre des fonctionnalités super interessantes pour faciliter la rédaction du contenu en utilisant du Markdown. L'éditeur a un dropdown qui vous permet de facilement uploader des images, ajouter des liens, coller du code, intégrer des vidéos et plusieurs autres choses.

photo_2021-12-02 14.33.31.jpeg

Complémentaires

Pour les articles qui vont contenir des codes sources, nous recommandons de consulter le site de Torchlight qui est l'outil qui nous permet de formater le code source. Torchlight is a VS Code-compatible syntax highlighter that requires no JavaScript, supports every language, every VS Code theme, line highlighting, git diffing, and more.

Attention à partir d'ici c'est vraiment pour les développeurs 😁

Le formatage du code est une partie importante pour présenter son code et pour ceci nous allons partager comment faire pour partager un code avec MarkdownX en utilisant Torchlight comme syntax highlighter. Nous allons présenter quelques exemples mais pour la suite nous vous redirigeons bien évidemment sur la documentation.

Pour écrire du code sur du Markdown vous devez rajouter les éléments suivants: "```{mon code}```" et pour avoir un meilleur rendu vous pouvez aussi préciser le langage utilisé "```php {mon code php ici} ```"

Si vous voulez vous concentrer sur une ligne spécifique, vous pouvez ajouter un commentaire de code avec la syntaxe magique [tl ! highglight] et cette ligne sera mise en évidence.

En utilisant Torchlight pour écrire le bloc de PHP suivant, en se concentrant sur les lignes 6 et 7, vous ajouterez deux commentaires à votre code.

return [
'extensions' => [
// Add attributes straight from markdown.
AttributesExtension::class,
// Add Torchlight syntax highlighting.
TorchlightExtension::class,
]
]

Torchlight permet aussi maintenant d'avoir une couleur syntaxique pour Blade, donc en écrivant du code blade on peut préciser pour avoir la couleur syntaxique qui s'applique a notre code

@if($article->nextArticle() || $article->previousArticle())
<div class="pt-6 space-y-6">
@if($next = $article->nextArticle())
<div>
<h2 class="text-xs leading-5 tracking-wide uppercase text-skin-base">Article suivant</h2>
<a href="{{ route('articles.show', $next) }}" class="mt-3 flex items-start space-x-2">
<img class="h-8 w-8 object-cover shadow-lg rounded-md" src="{{ $next->getFirstMediaUrl('media') }}" alt="{{ $next->slug }}">
<span class="text-sm font-medium leading-4 text-skin-inverted hover:text-skin-primary-hover line-clamp-2">{{ $next->title }}</span>
</a>
</div>
@endif
 
@if($previous = $article->previousArticle())
<div>
<h2 class="text-xs leading-5 tracking-wide uppercase text-skin-base">Article précédent</h2>
<a href="{{ route('articles.show', $previous) }}" class="mt-3 flex items-start space-x-2">
<img class="h-8 w-8 object-cover shadow-lg rounded-md" src="{{ $previous->getFirstMediaUrl('media') }}" alt="{{ $previous->slug }}">
<span class="text-sm font-medium leading-4 text-skin-inverted hover:text-skin-primary-hover line-clamp-2">{{ $previous->title }}</span>
</a>
</div>
@endif
</div>
@endif
<div class="pt-6">
<livewire:reactions :model="$article" />
</div>

Pour en savoir plus consulter la documentation