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
- Adicione um campo
selecttemplateà sua coleçãopages - Crie componentes de layout para cada opção
- 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.