WordPress hat „Page Templates“ — ein Dropdown im Editor, mit dem Sie pro Seite ein Layout wählen (z. B. Default, Full Width, Landing Page). EmDash unterstützt dasselbe Muster mit einem select-Feld.
Funktionsweise
- Fügen Sie der Collection
pageseinselect-Feldtemplatehinzu - Erstellen Sie Layout-Komponenten für jede Option
- Ordnen Sie den Feldwert in Ihrer Seitenroute einem Layout zu
Es ist kein spezielles System nötig — das nutzt das vorhandene Select-Feld von EmDash und das Komponentenmodell von Astro.
Feld hinzufügen
Fügen Sie in der Admin-Oberfläche der Collection pages ein Select-Feld mit dem Slug template und Ihren Layout-Optionen hinzu (z. B. „Default“, „Full Width“). Oder nehmen Sie es in Ihre Seed-Daten auf:
{
"slug": "template",
"label": "Template",
"type": "select",
"validation": {
"options": ["Default", "Full Width"]
},
"defaultValue": "Default"
}
Layout-Komponenten erstellen
Jedes Layout packt den Inhalt in Ihr Basislayout mit unterschiedlichem Styling:
---
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>
Route einbinden
Importieren Sie in Ihrer Seitenroute jedes Layout und mappen Sie den Template-Wert:
---
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} />
Die Route bleibt übersichtlich. Jede Layout-Komponente besitzt eigenes Markup und Styling. Ein weiteres Layout heißt: Komponente anlegen, Option zum Select-Feld hinzufügen, eine Zeile in die Map aufnehmen.
Weitere Layouts
Häufige Varianten aus WordPress-Themes:
- Default — schmale Inhaltsspalte, gut zum Lesen
- Full Width — breiter Inhaltsbereich, keine Sidebar
- Landing Page — ohne Header/Footer, Hero-Bereiche
- Sidebar — Inhalt mit Sidebar-Widget-Bereich
Jeweils nur eine weitere Astro-Komponente in Ihrem Verzeichnis src/layouts/ und ein weiterer Eintrag in der Layout-Map der Route.