Zum Hauptinhalt springen
Version: latest
Universell einsetzbar

PostWidget funktioniert sowohl auf dem Server als auch im Browser. Nutze immer den Standard-Import (z. B. @prokodo/ui/post-widget) — die Library erkennt die Umgebung automatisch.

PostWidget

PostWidget rendert ein kompaktes Sidebar-Widget mit aktuellen oder verwandten Beiträgen inklusive Thumbnail und Datum.


Übersicht

import { PostWidget } from "@prokodo/ui/post-widget"
;<PostWidget title="Recent posts" posts={latestPosts} />

Import

import { PostWidget } from "@prokodo/ui/post-widget"

CSS:

import "@prokodo/ui/post-widget.css"

Props

PropTypStandardPflichtBeschreibung
itemsPostWidgetItem[]Array von Post-Items.
titlePostWidgetHeadlineWidget-Überschrift: { content: string } & HeadlineProps.
fullWidthbooleanfalseKarte auf volle Containerbreite ausdehnen.
colorVariantsAkzentfarbe (erweitert CardProps).
structuredDatabooleanfalseJSON-LD-Strukturdaten ausgeben.
classNamestringCSS-Klasse am Root-Element.

Siehe src/components/post-widget/PostWidget.model.ts für den vollständigen PostWidgetProps-Typ.


Farbe

Das color-Prop überträgt eine einheitliche Akzentfarbe auf alle visuellen Ebenen des Widgets:

WertKarten-Rahmen / SchattenWidget-TitelEintrags-Headlines
"primary"Marken-Blau (30 % Tönung + Glow)Marken-BlauMarken-Blau
"secondary"Akzent-Cyan (30 % Tönung + Glow)Akzent-CyanAkzent-Cyan
"success"Grün-IndikatorGrünGrün
"warning"Bernstein-IndikatorBernsteinBernstein
"error"Rot-IndikatorRotRot
"info"Neutraler VordergrundtonGedämpftGedämpft
"white"Standard-Weißkarte, kein Schatteninherit (automatischer Kontrast)inherit

Wenn kein color übergeben wird, verwenden Widget-Titel und Eintrags-Headlines "inherit" (Standard-Textfarbe).


Design-Tokens

PostWidget definiert keine eigenen CSS Custom Properties. Passe das Erscheinungsbild an, indem du folgende globale Design-System-Tokens auf :root oder einem übergeordneten Element überschreibst:

TokenBeschreibung
--pk-space-lgOberer Abstand der Listenelemente
--pk-space-mdRechter Abstand des Thumbnail-Bilds
--pk-color-mutedTextfarbe des Datums
--pk-radius-mdEckenradius des Thumbnail-Bilds

AIC-Hinweis

Verwende im Anwendungscode immer den Standard-Importpfad:

import { PostWidget } from "@prokodo/ui/post-widget"

Eine separate Auswahl von /client oder /lazy ist im Consumer-Code nicht erforderlich.

AIC-Komponenten unterstützen außerdem ein priority-Flag für kritische Above-the-fold-Elemente. Am sichtbarsten ist das bei Image (natives Preloading via <link rel="preload"> für Above-the-fold-Inhalte).


WCAG-2.2-Status

KriteriumBezeichnungStatusHinweis
1.3.1Info und Beziehungen (A)✅ ErfülltSemantische Struktur (Überschriften, Listen, Labels, Landmarks) muss programmatisch via HTML oder ARIA vermittelt werden.
1.3.2Bedeutungsvolle Reihenfolge (A)🔍 Manuell prüfenDie Lesereihenfolge im DOM muss der beabsichtigten visuellen Darstellungsreihenfolge entsprechen.
1.4.3Kontrast (Minimum) (AA)🔍 Manuell prüfenText benötigt ein Kontrastverhältnis von mindestens 4,5:1 (3:1 für großen Text). Prüfung im finalen Produkt-Theme erforderlich.
2.4.6Überschriften und Bezeichnungen (AA)🔍 Manuell prüfenÜberschriften und Labels müssen das Thema oder den Zweck des zugehörigen Inhalts beschreiben.
4.1.2Name, Rolle, Wert (A)✅ ErfülltName, Rolle und Zustand aller interaktiven UI-Komponenten müssen via nativer HTML-Semantik oder ARIA programmatisch bestimmbar sein.

Testabdeckung: 2 jest-axe-Assertion(s) in 4 Testdatei(en) · 3 ARIA-Attribut-Vorkommen im Quellcode-Scan. Kriterien mit 🔍 erfordern manuelle Prüfung im finalen Integrations- und Theme-Kontext.

Storybook

👉 PostWidget in Storybook öffnen


Quellcode

src/components/post-widget/PostWidget.model.ts