- Accordion
- Alert
- Alert Dialog
- Aspect Ratio
- Attachment
- Avatar
- Badge
- Breadcrumb
- Bubble
- Button
- Button Group
- Calendar
- Card
- Carousel
- Chart
- Checkbox
- Collapsible
- Combobox
- Command
- Context Menu
- Data Table
- Date Picker
- Dialog
- Direction
- Drawer
- Dropdown Menu
- Empty
- Field
- Hover Card
- Input
- Input Group
- Input OTP
- Item
- Kbd
- Label
- Marker
- Menubar
- Message
- Message Scroller
- Native Select
- Navigation Menu
- Pagination
- Popover
- Progress
- Radio Group
- Resizable
- Scroll Area
- Select
- Separator
- Sheet
- Sidebar
- Skeleton
- Slider
- Sonner
- Spinner
- Switch
- Table
- Tabs
- Textarea
- Toast
- Toggle
- Toggle Group
- Tooltip
- Typography
import { GitBranchIcon, SearchIcon } from "lucide-react"
import {The Marker component displays inline conversation markers such as status updates, system notes, bordered rows, and labeled separators. Compose it with Message in a conversation thread.
Installation#
pnpm dlx shadcn@latest add marker
Usage#
import { Marker, MarkerContent, MarkerIcon } from "@/components/ui/marker"<Marker>
<MarkerIcon>
<CheckIcon />
</MarkerIcon>
<MarkerContent>Explored 4 files</MarkerContent>
</Marker>Composition#
Use the following composition to build a marker:
Marker
├── MarkerIcon
└── MarkerContentFeatures#
- Inline marker, bordered row, and labeled separator variants
- Decorative icon slot that is hidden from assistive tech
- Polymorphic root via
asChildfor link and button markers - Pairs with the
shimmerutility for streaming status text - Customizable styling through the
classNameprop on every part
Examples#
Variants#
Use variant to switch between an inline marker, bordered row, and labeled separator.
import { Marker, MarkerContent } from "@/components/ui/marker"
export function MarkerVariantsDemo() {| Variant | Description |
|---|---|
default | An inline marker for status, notes, and actions. |
border | A default marker with a bottom border under the row. |
separator | A centered label with divider lines on each side. |
Status#
Set role="status" and include a Spinner for streaming or in-progress markers so updates are announced.
import {
Marker,
MarkerContent,Shimmer#
Add the shimmer utility class to MarkerContent for an animated streaming-text effect. The utility ships with the shadcn package — see the shimmer docs for installation.
import { Marker, MarkerContent } from "@/components/ui/marker"
export function MarkerShimmerDemo() {Separator#
Use the separator variant for labeled dividers, such as dates or section breaks, in a conversation.
import { Marker, MarkerContent } from "@/components/ui/marker"
export function MarkerSeparatorDemo() {Border#
Use the border variant for status rows that should keep the default marker alignment while separating the next row.
import { FileTextIcon, GitBranchIcon, SearchIcon } from "lucide-react"
import {With Icon#
Use MarkerIcon to render an icon alongside the content. Use flex-col to stack the icon above the content.
import { BookOpenCheck, GitBranchIcon, SearchIcon } from "lucide-react"
import {Links and Buttons#
Turn a marker into a link or button with the asChild prop on Marker.
"use client"
import { GitBranchIcon, RotateCcwIcon } from "lucide-react"import { Marker, MarkerContent } from "@/components/ui/marker"
export function MarkerLinkDemo() {
return (
<Marker asChild>
<a href="#">
<MarkerContent>View the pull request</MarkerContent>
</a>
</Marker>
)
}Accessibility#
Marker is presentational by default. The correct semantics depend on how you use it, so choose the role based on intent rather than relying on a single default.
Status and Progress#
For streaming or progress markers such as "Thinking..." or a running tool, set role="status" so assistive tech announces the update as it appears. Marker forwards role to the underlying element.
<Marker role="status">
<MarkerIcon>
<Spinner />
</MarkerIcon>
<MarkerContent>Compacting conversation</MarkerContent>
</Marker>Labeled Separators#
A separator that carries text, such as a date or a section label, needs no role. The divider lines are decorative CSS pseudo-elements, and the text is announced as ordinary content.
<Marker variant="separator">
<MarkerContent>Today</MarkerContent>
</Marker>Note: Do not add role="separator" to a labeled divider. A separator
takes its accessible name from aria-label, not from its text, and its
contents are treated as presentational, so the visible label would not be
announced. Reserve role="separator" for a divider with no meaningful text.
Bordered Markers#
A bordered marker keeps the same semantics as the default marker. The bottom border is decorative, so choose role="status", asChild, or no role based on the marker's purpose.
<Marker variant="border">
<MarkerIcon>
<FileTextIcon />
</MarkerIcon>
<MarkerContent>Opened implementation notes</MarkerContent>
</Marker>Decorative Icons#
MarkerIcon is decorative and hidden from assistive tech with aria-hidden, so the adjacent MarkerContent carries the meaning. For an icon-only marker, provide an aria-label or visible text so it is not announced as empty.
<Marker aria-label="Synced">
<MarkerIcon>
<CheckIcon />
</MarkerIcon>
</Marker>Interactive Markers#
When a marker links or triggers an action, render it as a real <button> or <a> with the asChild prop so it is focusable and exposes the correct role. The accessible name comes from the marker text.
<Marker asChild>
<a href="/files">
<MarkerIcon>
<FileTextIcon />
</MarkerIcon>
<MarkerContent>Explored 4 files</MarkerContent>
</a>
</Marker>API Reference#
Marker#
The root marker element. The file also exports markerVariants for composing the marker styles into custom components.
| Prop | Type | Default | Description |
|---|---|---|---|
variant | "default" | "border" | "separator" | "default" | The marker layout. |
asChild | boolean | false | Render as the child element, such as a link. |
className | string | - | Additional classes to apply to the root element. |
MarkerIcon#
A decorative icon slot. Hidden from assistive tech with aria-hidden.
| Prop | Type | Default | Description |
|---|---|---|---|
className | string | - | Additional classes to apply to the icon slot. |
MarkerContent#
The marker text content.
| Prop | Type | Default | Description |
|---|---|---|---|
className | string | - | Additional classes to apply to the content slot. |