Saltearse al contenido

Builder.io y Astro

Builder.io es un CMS visual que admite la edición de contenido mediante arrastrar y soltar para la construcción de sitios web.

Esta receta te mostrará cómo conectar tu espacio de Builder a Astro sin necesidad de JavaScript del lado del cliente.

Para empezar, necesitarás lo siguiente:

  • Una cuenta y un espacio en Builder - Si aún no tienes una cuenta, regístrate gratis y crea un nuevo espacio. Si ya tienes un espacio con Builder, siéntete libre de usarlo, pero tendrás que modificar el código para que coincida con el nombre del modelo (blogpost) y los campos de datos personalizados.
  • Una llave de API de Builder - Esta llave pública se usará para obtener tu contenido de Builder. Lee la guía de Builder sobre cómo encontrar tu llave.

Para agregar tu llave de API de Builder y el nombre de tu modelo de Builder a Astro, crea un archivo .env en la raíz de tu proyecto (si no existe ya) y agrega las siguientes variables:

.env
BUILDER_API_PUBLIC_KEY=YOUR_API_KEY
BUILDER_BLOGPOST_MODEL='blogpost'

Ahora, deberías poder usar esta llave de API en tu proyecto.

Si deseas tener IntelliSense para tus variables de entorno, puedes crear un archivo env.d.ts en el directorio src/ y configurar ImportMetaEnv de la siguiente manera:

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

Tu proyecto hasta este momento debería incluir estos archivos:

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

Creación de un modelo para una entrada de blog

Sección titulada Creación de un modelo para una entrada de blog

Las instrucciones a continuación crean un blog de Astro usando un modelo de Builder (Tipo: “Sección”) llamado blogpost que contiene dos campos de texto requeridos: title y slug.

Para tipos visuales

Puedes encontrar videos que muestran este procedimiento en uno de los tutoriales oficiales de Builder.

En la aplicación de Builder crea el modelo que representará una entrada de blog: ve a la pestaña Models y haz clic en el botón + Create Model para crear un modelo con los siguientes campos y valores:

  • Type: Section
  • Name: “blogpost”
  • Description: “Este modelo es para una entrada de blog”

En tu nuevo modelo, usa el botón + New Custom Field para crear 2 nuevos campos:

  1. Text field

    • Name: “title”
    • Required: Yes
    • Default value “Olvidé ponerle un título”

    (dejar los otros parámetros como sus valores predeterminados)

  2. Text field

    • Name: “slug”
    • Required: Yes
    • Default value “algunos-slugs-toman-su-tiempo”

    (dejar los otros parámetros como sus valores predeterminados)

Luego haz clic en el botón Save en la esquina superior derecha.

Para usar el editor visual de Builder, crea la página src/pages/builder-preview.astro que renderizará el componente especial <builder-component>:

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

Luego agrega el siguiente contenido:

src/pages/builder-preview.astro
---
const builderAPIpublicKey = import.meta.env.BUILDER_API_PUBLIC_KEY;
const builderModel = import.meta.env.BUILDER_BLOGPOST_MODEL;
---
<html lang="es">
<head>
<title>Vista previa para builder.io</title>
</head>
<body>
<header>Este es tu encabezado</header>
<builder-component model={builderModel} api-key={builderAPIpublicKey}
></builder-component>
<script async src="https://cdn.builder.io/js/webcomponents"></script>
<footer>Este es tu pie de página</footer>
</body>
</html>

En el ejemplo anterior, <builder-component> le dice a Builder dónde insertar el contenido de tu CMS.

Configuración de la nueva ruta como la URL de vista previa

Sección titulada Configuración de la nueva ruta como la URL de vista previa
  1. Copia la URL completa de tu vista previa, incluyendo el protocolo, en tu portapapeles (por ejemplo, https://{tu host}/builder-preview).

  2. Ve a la pestaña Models en tu espacio de Builder, selecciona el modelo que has creado y pega la URL del paso 1 en el campo Preview URL. Asegúrate de que la URL esté completa e incluya el protocolo, por ejemplo https://.

  3. Haz clic en el botón Save en la esquina superior derecha.

Prueba de la configuración de la URL de vista previa

Sección titulada Prueba de la configuración de la URL de vista previa
  1. Asegúrate de que tu sitio esté en línea (por ejemplo, tu servidor de desarrollo está en ejecución) y que la ruta /builder-preview esté funcionando.

  2. En tu espacio de Builder bajo la pestaña Content, haz clic en New para crear una nueva entrada de contenido para tu modelo blogpost.

  3. En el editor de Builder que acabas de abrir, deberías poder ver la página builder-preview.astro con un gran botón Add Block en el medio.

  1. En el editor visual de Builder, crea una nueva entrada de contenido con los siguientes valores:

    • title: ‘¡Primer articulo, woohoo!’
    • slug: ‘primer-articulo-woohoo’
  2. Completa tu entrada usando el botón Add Block y agrega un campo de texto con algo de contenido para la entrada.

  3. En el campo de texto sobre el editor, dale un nombre a tu entrada. Así es como se listará en la aplicación de Builder.

  4. Cuando estés listo, haz clic en el botón Publish en la esquina superior derecha.

  5. Crea tantas entradas como desees, asegurándote de que todas las entradas de contenido contengan un title y un slug así como algo de contenido para la entrada.

Mostrar una lista de entradas de blog

Sección titulada Mostrar una lista de entradas de blog

Agrega la siguiente información a src/pages/index.astro para poder obtener y mostrar una lista de todos los títulos de las entradas, cada uno enlazando a su propia página:

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="es">
<head>
<title>Índice de Blog</title>
</head>
<body>
<ul>
{
posts.flatMap(({ data: { slug, title } }) => (
<li>
<a href={`/posts/${slug}`}>{title}</a>
</li>
))
}
</ul>
</body>
</html>

Obteniendo datos a través de la API de contenido devuelve un array de objetos que contienen datos para cada entrada. El parámetro de consulta fields le dice a Builder qué datos se incluyen (ver código resaltado). slug y title deben coincidir con los nombres de los campos de datos personalizados que has agregado a tu modelo de Builder.

El array posts devuelto por la solicitud de recuperación muestra una lista de títulos de entradas de blog en la página de inicio. Las rutas de página individuales se crearán en el siguiente paso.

¡Ve a tu ruta de índice y deberías poder ver una lista de enlaces, cada uno con el título de una entrada de blog!

Mostrar una entrada de blog individual

Sección titulada Mostrar una entrada de blog individual

Crea la página src/pages/posts/[slug].astro que generará dinámicamente una página para cada entrada.

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

Este archivo debe contener:

  • Una función getStaticPaths() para obtener información de slug de Builder y crear una ruta estática para cada entrada de blog.
  • Una función fetch() a la API de Builder usando el identificador slug para devolver el contenido de la entrada y los metadatos (por ejemplo, un title).
  • Un componente <Fragment /> en la plantilla para renderizar el contenido de la entrada como HTML.

Cada uno de estos se destaca en el siguiente fragmento de código.

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
// ...atrapa algunos errores...);
();
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;
// La API de Builder requiere este campo, pero para este caso de uso, la URL no parece importar - la API devuelve el mismo 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="es">
<head>
<title>{title}</title>
</head>
<body>
<header>Este es tu encabezado</header>
<article>
<Fragment set:html={postHTML} />
</article>
<footer>Este es tu pie de página</footer>
</body>
</html>

Ahora cuando hagas clic en un enlace en tu ruta de índice, serás llevado a la página de entrada de blog individual.

Para desplegar tu sitio, visita nuestras guías de despliegue y sigue las instrucciones para tu proveedor de alojamiento preferido.

Reconstrucción en cambios de Builder

Sección titulada Reconstrucción en cambios de Builder

Si tu proyecto está usando el modo estático predeterminado de Astro, necesitarás configurar un webhook para desencadenar una nueva compilación cuando tu contenido cambie. Si estás usando Netlify o Vercel como tu proveedor de alojamiento, puedes usar su función de webhook para desencadenar una nueva compilación cada vez que hagas clic en Publish en el editor de Builder.

  1. Ve a tu panel de control del sitio, luego Site Settings y haz clic en Build & deploy.

  2. Bajo la pestaña Continuous Deployment, encuentra la sección Build hooks y haz clic en Add build hook.

  3. Proporciona un nombre para tu webhook y selecciona la rama en la que deseas desencadenar la compilación. Haz clic en Save y copia la URL generada.

  1. Ve a tu panel de control del proyecto y haz clic en Settings.

  2. Bajo la pestaña Git, encuentra la sección Deploy Hooks y haz clic en Add deploy hook.

  3. Proporciona un nombre para tu webhook y selecciona la rama en la que deseas desencadenar la compilación. Haz clic en Add y copia la URL generada.

  1. En el panel de control de Builder, ve a tu modelo blogpost. Bajo Show More Options, selecciona Edit Webhooks en la parte inferior.

  2. Agrega un nuevo webhook haciendo clic en Webhook. Pega la URL generada por tu proveedor de alojamiento en el campo Url.

  3. Haz clic en Show Advanced debajo del campo de URL y activa la opción para seleccionar Disable Payload. Con el payload deshabilitado, Builder envía una solicitud POST más simple a tu proveedor de alojamiento, lo que puede ser útil a medida que tu sitio crece. Haz clic en Done para guardar esta selección.

Con este webhook en su lugar, cada vez que hagas clic en el botón Publish en el editor de Builder, tu proveedor de alojamiento reconstruirá tu sitio - y Astro recuperará los datos recién publicados para ti. ¡No hay nada que hacer más que relajarse y publicar ese dulce contenido!

Más guías de CMS