Aller au contenu

Builder.io & Astro

Builder.io est un CMS visuel qui prend en charge l’édition de contenu par glisser-déposer pour la construction de sites Web.

Cette recette vous montrera comment connecter votre espace Builder à Astro avec zéro JavaScript côté client.

Pour commencer, vous devez disposer des éléments suivants :

  • Un compte et un espace Builder - Si vous n’avez pas encore de compte, inscrivez-vous gratuitement et créez un nouvel espace. Si vous avez déjà un espace avec Builder, n’hésitez pas à l’utiliser, mais vous devrez modifier le code pour qu’il corresponde au nom du modèle (blogpost) et aux champs de données personnalisées.
  • Une clé API Builder - Cette clé publique sera utilisée pour récupérer votre contenu depuis Builder. Lire le guide de Builder sur la façon de trouver votre clé.

Configuration des informations d’identification

Titre de la section Configuration des informations d’identification

Pour ajouter votre clé API Builder et votre nom de modèle Builder à Astro, créez un fichier .env à la racine de votre projet (s’il n’existe pas déjà) et ajoutez les variables suivantes :

.env
BUILDER_API_PUBLIC_KEY=VOTRE_VLE_API
BUILDER_BLOGPOST_MODEL='blogpost'

Maintenant, vous devriez pouvoir utiliser cette clé API dans votre projet.

Si vous voulez avoir IntelliSense pour vos variables d’environnement, vous pouvez créer un fichier env.d.ts dans le répertoire src/ et configurer ImportMetaEnv comme ceci :

src/env.d.ts
interface ImportMetaEnv {
readonly BUILDER_API_PUBLIC_KEY: string;
}

Votre projet doit maintenant inclure ces fichiers :

  • Directorysrc/
    • env.d.ts
  • .env
  • astro.config.mjs
  • package.json

Création d’un modèle pour un billet de blog

Titre de la section Création d’un modèle pour un billet de blog

Les instructions ci-dessous créent un blog Astro en utilisant un modèle Builder (Type : “Section”) appelé blogpost qui contient deux champs texte obligatoires : title et slug.

Dans l’application Builder, créez le modèle qui représentera un article de blog : allez dans l’onglet Models et cliquez sur le bouton + Create Model pour créer un modèle avec les champs et valeurs suivants :

  • Type: Section
  • Name: “blogpost”
  • Description: “Ce modèle est destiné à un article de blog”

Dans votre nouveau modèle, utilisez le bouton + New Custom Field pour créer deux nouveaux champs :

  1. Champ texte

    • Name: “title”
    • Requis: Yes
    • Valeur par défaut : “J’ai oublié de donner un titre à ce champ”.

    (laisser les autres paramètres par défaut)

  2. Champ texte

    • Nom:** “slug”
    • Obligatoire:** Yes
    • Default value “certaines-limaces-prennent-leur-temps”

    (laisser les autres paramètres par défaut)

Cliquez ensuite sur le bouton Save en haut à droite.

Pour utiliser l’éditeur visuel de Builder, créez la page src/pages/builder-preview.astro qui rendra le composant spécial <builder-component> :

  • Directorysrc/
    • Directorypages/
      • builder-preview.astro
    • env.d.ts
  • .env
  • astro.config.mjs
  • package.json

Ajoutez ensuite le contenu suivant :

src/pages/builder-preview.astro
---
const builderAPIpublicKey = import.meta.env.BUILDER_API_PUBLIC_KEY;
const builderModel = import.meta.env.BUILDER_BLOGPOST_MODEL;
---
<html lang="fr">
<head>
<title>Aperçu pour builder.io</title>
</head>
<body>
<header>Ceci est votre header</header>
<builder-component model={builderModel} api-key={builderAPIpublicKey}
></builder-component>
<script async src="https://cdn.builder.io/js/webcomponents"></script>
<footer>Ceci est votre footer</footer>
</body>
</html>

Dans l’exemple ci-dessus, <builder-component> indique à Builder où insérer le contenu de son CMS.

Définir la nouvelle route comme URL de prévisualisation

Titre de la section Définir la nouvelle route comme URL de prévisualisation
  1. Copiez l’URL complète de votre aperçu, y compris le protocole, dans votre presse-papiers (par exemple https://{votre_hôte}/builder-preview).

  2. Allez dans l’onglet Models de votre espace Builder, sélectionnez le modèle que vous avez créé et collez l’URL de l’étape 1 dans le champ Preview URL. Assurez-vous que l’URL est complète et inclut le protocole, par exemple https://.

  3. Cliquez sur le bouton Save en haut à droite.

Test de la configuration de l’URL de prévisualisation

Titre de la section Test de la configuration de l’URL de prévisualisation
  1. Assurez-vous que votre site est actif (c’est-à-dire que votre serveur de développement fonctionne) et que la route /builder-preview fonctionne.

  2. Dans votre espace Builder, sous l’onglet Content, cliquez sur New pour créer une nouvelle entrée de contenu pour votre modèle blogpost.

  3. Dans l’éditeur Builder qui vient de s’ouvrir, vous devriez pouvoir voir la page builder-preview.astro avec un gros Add Block au milieu.

  1. Dans l’éditeur visuel de Builder, créez une nouvelle entrée de contenu avec les valeurs suivantes :
    • title: ‘premier article, woohoo !
    • slug: ‘premier-article-woohoo’
  2. Complétez votre article à l’aide du bouton Add Block et ajoutez un champ de texte avec le contenu de l’article.
  3. Dans le champ de texte situé au-dessus de l’éditeur, donnez un nom à votre article. C’est ainsi qu’il sera listé dans l’application Builder.
  4. Lorsque vous êtes prêt, cliquez sur le bouton Publish dans le coin supérieur droit.
  5. Créez autant d’articles que vous le souhaitez en vous assurant que toutes les entrées de contenu contiennent un titre et un slug ainsi que le contenu de l’article.

Affichage d’une liste d’articles de blog

Titre de la section Affichage d’une liste d’articles de blog

Ajoutez le contenu suivant à src/pages/index.astro afin de récupérer et d’afficher une liste de tous les titres d’articles, chacun renvoyant à sa propre page :

src/pages/index.astro
---
const builderAPIpublicKey = import.meta.env.BUILDER_API_PUBLIC_KEY;
const builderModel = import.meta.env.BUILDER_BLOGPOST_MODEL;
const { results: posts } = await fetch(
`https://cdn.builder.io/api/v3/content/${builderModel}?${new URLSearchParams({
apiKey: builderAPIpublicKey,
fields: ["data.slug", "data.title"].join(","),
cachebust: "true",
}).toString()}`
)
.then((res) => res.json())
.catch();
---
<html lang="fr">
<head>
<title>Index du Blog</title>
</head>
<body>
<ul>
{
posts.map(({ data: { slug, title } }) => (
<li>
<a href={`/posts/${slug}`}>{title}</a>
</li>
))
}
</ul>
</body>
</html>

La récupération via l’API de contenu renvoie un tableau d’objets contenant les données de chaque article. Le paramètre de requête fields indique à Builder quelles données sont incluses (voir le code surligné). Les paramètres slug et title doivent correspondre aux noms des champs de données personnalisés que vous avez ajoutés à votre modèle Builder.

Le tableau posts retourné par la recherche affiche une liste de titres d’articles de blog sur la page d’accueil. Les routes des pages individuelles seront créées dans l’étape suivante.

Allez sur votre route d’index et vous devriez pouvoir voir une liste de liens, chacun avec le titre d’un article de blog !

Créez la page src/pages/posts/[slug].astro qui générera dynamiquement une page pour chaque article.

  • Directorysrc/
    • Directorypages/
      • index.astro
      • Directoryposts/
        • [slug].astro
    • env.d.ts
  • .env
  • astro.config.mjs
  • package.json

Ce fichier doit contenir :

  • Une fonction getStaticPaths() pour récupérer les informations slug de Builder et créer une route statique pour chaque article de blog.
  • Un fetch() vers l’API de Builder utilisant l’identifiant slug pour retourner le contenu de l’article et les métadonnées (par exemple un title).
  • Un <Fragment /> dans le template pour rendre le contenu de l’article en HTML.

Chacun de ces éléments est mis en évidence dans l’extrait de code suivant.

src/pages/posts/[slug].astro
---
export async function getStaticPaths() {
const builderModel = import.meta.env.BUILDER_BLOGPOST_MODEL;
const builderAPIpublicKey = import.meta.env.BUILDER_API_PUBLIC_KEY;
const { results: posts } = await fetch(
`https://cdn.builder.io/api/v3/content/${builderModel}?${new URLSearchParams(
{
apiKey: builderAPIpublicKey,
fields: ["data.slug", "data.title"].join(","),
cachebust: "true",
}
).toString()}`
)
.then((res) => res.json())
.catch
// ...catch some errors...);
();
return [
...posts.map(({ data: { slug, title } }) => [
{
params: { slug },
props: { title },
},
]),
];
}
const { slug } = Astro.params;
const { title } = Astro.props;
const builderModel = import.meta.env.BUILDER_BLOGPOST_MODEL;
const builderAPIpublicKey = import.meta.env.BUILDER_API_PUBLIC_KEY;
// L'API de Builder requiert ce champ, mais pour ce cas d'utilisation,
// l'URL ne semble pas avoir d'importance - l'API renvoie le même HTML.
const encodedUrl = encodeURIComponent("moot");
const { html: postHTML } = await fetch(
`https://cdn.builder.io/api/v1/qwik/${builderModel}?${new URLSearchParams({
apiKey: builderAPIpublicKey,
url: encodedUrl,
"query.data.slug": slug,
cachebust: "true",
}).toString()}`
)
.then((res) => res.json())
.catch();
---
<html lang="fr">
<head>
<title>{title}</title>
</head>
<body>
<header>Ceci est votre header</header>
<article>
<Fragment set:html={postHTML} />
</article>
<footer>Ceci est votre footer</footer>
</body>
</html>

Désormais, lorsque vous cliquez sur un lien de votre route d’indexation, vous êtes redirigé vers la page de l’article de blog concerné.

Pour déployer votre site web, visitez nos guides de déploiement et suivez les instructions de votre hébergeur préféré.

Reconstruire sur les changements du Builder

Titre de la section Reconstruire sur les changements du Builder

Si votre projet utilise le mode statique par défaut d’Astro, vous devrez configurer un webhook pour déclencher une nouvelle construction lorsque votre contenu change. Si vous utilisez Netlify ou Vercel comme fournisseur d’hébergement, vous pouvez utiliser sa fonctionnalité webhook pour déclencher une nouvelle construction chaque fois que vous cliquez sur Publish dans l’éditeur Builder.

  1. Allez dans le tableau de bord de votre site, puis Site Settings et cliquez sur Build & deploy.
  2. Sous l’onglet Continuous Deployment, trouvez la section Build hooks et cliquez sur Add build hook.
  3. Donnez un nom à votre webhook et sélectionnez la branche sur laquelle vous souhaitez déclencher la construction. Cliquez sur Save et copiez l’URL générée.
  1. Allez sur le tableau de bord de votre projet et cliquez sur Settings.
  2. Sous l’onglet Git, trouvez la section Deploy Hooks.
  3. Donnez un nom à votre webhook et indiquez la branche sur laquelle vous souhaitez déclencher la construction. Cliquez sur Add et copiez l’URL générée.
  1. Dans votre tableau de bord Builder, allez dans votre modèle blogpost. Sous Show More Options, sélectionnez Edit Webhooks en bas.
  2. Ajoutez un nouveau webhook en cliquant sur Webhook. Collez l’URL générée par votre hébergeur dans le champ Url.
  3. Cliquez sur Show Advanced sous le champ URL et basculez l’option pour sélectionner Disable Payload. Lorsque la charge utile est désactivée, Builder envoie une requête POST plus simple à votre hébergeur, ce qui peut s’avérer utile au fur et à mesure de la croissance de votre site. Cliquez sur Done pour enregistrer cette sélection.

Avec ce webhook en place, chaque fois que vous cliquez sur le bouton Publish dans l’éditeur de Builder, votre hébergeur reconstruit votre site - et Astro récupère les données nouvellement publiées pour vous. Il ne vous reste plus qu’à vous détendre et à publier votre contenu !

Plus de guides sur les CMS