Layouts de página

Nesta página

O WordPress tem «Page Templates» — um menu suspenso no editor para escolher um layout por página (por exemplo, Default, Full Width, Landing Page). O EmDash suporta o mesmo padrão com um campo select.

Como funciona

  1. Adicione um campo select template à sua coleção pages
  2. Crie componentes de layout para cada opção
  3. Mapeie o valor do campo para um layout na rota da página

Não é preciso um sistema especial — usa o campo select existente do EmDash e o modelo de componentes do Astro.

Adicionar o campo

Na interface de administração, adicione um campo select à coleção pages com o slug template e as opções de layout (por exemplo, «Default», «Full Width»). Ou inclua nos dados de seed:

{
  "slug": "template",
  "label": "Template",
  "type": "select",
  "validation": {
    "options": ["Default", "Full Width"]
  },
  "defaultValue": "Default"
}

Criar componentes de layout

Cada layout envolve o conteúdo no seu layout base com estilos diferentes:

---
import type { ContentEntry } from "emdash";
import { PortableText } from "emdash/ui";
import Base from "./Base.astro";

interface Props {
  page: ContentEntry<any>;
}

const { page } = Astro.props;
---

<Base title={page.data.title}>
  <article class="page-default">
    <h1>{page.data.title}</h1>
    <PortableText value={page.data.content} />
  </article>
</Base>

<style>
  .page-default {
    max-width: var(--content-width);
    margin: 0 auto;
    padding: 2rem 1rem;
  }
</style>
---
import type { ContentEntry } from "emdash";
import { PortableText } from "emdash/ui";
import Base from "./Base.astro";

interface Props {
  page: ContentEntry<any>;
}

const { page } = Astro.props;
---

<Base title={page.data.title}>
  <article class="page-wide">
    <h1>{page.data.title}</h1>
    <PortableText value={page.data.content} />
  </article>
</Base>

<style>
  .page-wide {
    max-width: var(--wide-width);
    margin: 0 auto;
    padding: 2rem 1rem;
  }
</style>

Ligar a rota

Na rota da página, importe cada layout e mapeie o valor do template:

---
import { getEmDashEntry } from "emdash";
import PageDefault from "../../layouts/PageDefault.astro";
import PageFullWidth from "../../layouts/PageFullWidth.astro";

const { slug } = Astro.params;

if (!slug) {
  return Astro.redirect("/404");
}

const { entry: page } = await getEmDashEntry("pages", slug);

if (!page) {
  return Astro.redirect("/404");
}

const layouts = {
  "Default": PageDefault,
  "Full Width": PageFullWidth,
};

const Layout = layouts[page.data.template as keyof typeof layouts] ?? PageDefault;
---

<Layout page={page} />

A rota permanece pequena. Cada componente de layout tem a sua própria marcação e estilos. Adicionar um layout é: criar o componente, adicionar a opção ao select, adicionar uma linha ao mapa.

Adicionar mais layouts

Escolhas comuns em temas WordPress:

  • Default — coluna de conteúdo estreita, boa para leitura
  • Full Width — área de conteúdo mais larga, sem barra lateral
  • Landing Page — sem cabeçalho/rodapé, secções hero
  • Sidebar — conteúdo com área de widgets na barra lateral

Cada um é apenas outro componente Astro em src/layouts/ e outra entrada no mapa de layouts da rota.