Seitenlayouts

Auf dieser Seite

Lassen Sie Redakteure ein Layout pro Seite auswählen (z.B. Standard, Volle Breite, Landing Page) aus einem Dropdown im Editor, indem Sie ein select-Feld verwenden, das Layout-Komponenten in Ihrer Seitenroute zugeordnet ist.

Wie es funktioniert

  1. Fügen Sie Ihrer Pages-Collection ein template-Select-Feld hinzu
  2. Erstellen Sie Layout-Komponenten für jede Option
  3. Ordnen Sie den Feldwert einem Layout in Ihrer Seitenroute zu

Dies nutzt EmDashs Select-Feld und Astros Komponentenmodell.

Das Feld hinzufügen

Fügen Sie in der Admin-Oberfläche ein Select-Feld zu Ihrer Pages-Collection mit dem Slug template und Ihren Layout-Optionen hinzu (z.B. “Default”, “Full Width”). Oder fügen Sie es in Ihre Seed-Daten ein:

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

Layout-Komponenten erstellen

Jedes Layout umschließt Inhalte in Ihrem 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>

Die Route verbinden

Importieren Sie in Ihrer Seitenroute jedes Layout und ordnen Sie den Template-Wert zu:

---
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 klein. Jede Layout-Komponente besitzt ihr eigenes Markup und Styling. Ein Layout hinzuzufügen bedeutet: eine Komponente erstellen, die Option zum Select-Feld hinzufügen, eine Zeile zur Map hinzufügen.

Weitere Layouts hinzufügen

Gängige Layout-Optionen:

  • Default — schmale Inhaltsspalte, gut zum Lesen
  • Full Width — breiterer Inhaltsbereich, keine Sidebar
  • Landing Page — kein Header/Footer, Hero-Bereiche
  • Sidebar — Inhalt mit einem Sidebar-Widget-Bereich

Jedes ist einfach eine weitere Astro-Komponente in Ihrem src/layouts/-Verzeichnis und ein weiterer Eintrag in der Layout-Map der Route.