Docs

IntroductionUsageTroubleshooting

Examples

Chatbotv0 cloneWorkflow

Components

Attachments

A flexible, composable attachment component for displaying files, images, videos, audio, and source documents.

The Attachment component provides a unified way to display file attachments and source documents with multiple layout variants.

mountain-landscape.jpg
ocean-sunset.jpg

Installation

npx ai-elements@latest add attachments

Usage with AI SDK

Display user-uploaded files in chat messages or input areas.

app/page.tsx
'use client';

import {
  Attachments,
  Attachment,
  AttachmentPreview,
  AttachmentInfo,
  AttachmentRemove,
} from '@/components/ai-elements/attachments';
import type { FileUIPart } from 'ai';

interface MessageProps {
  attachments: (FileUIPart & { id: string })[];
  onRemove?: (id: string) => void;
}

const MessageAttachments = ({ attachments, onRemove }: MessageProps) => (
  <Attachments variant="grid">
    {attachments.map((file) => (
      <Attachment
        key={file.id}
        data={file}
        onRemove={onRemove ? () => onRemove(file.id) : undefined}
      >
        <AttachmentPreview />
        <AttachmentRemove />
      </Attachment>
    ))}
  </Attachments>
);

export default MessageAttachments;

Features

  • Three display variants: grid (thumbnails), inline (badges), and list (rows)
  • Supports both FileUIPart and SourceDocumentUIPart from the AI SDK
  • Automatic media type detection (image, video, audio, document, source)
  • Hover card support for inline previews
  • Remove button with customizable callback
  • Composable architecture for maximum flexibility
  • Accessible with proper ARIA labels
  • TypeScript support with exported utility functions

Examples

Grid Variant

Best for displaying attachments in messages with visual thumbnails.

mountain-landscape.jpg
ocean-sunset.jpg

Inline Variant

Best for compact badge-style display in input areas with hover previews.

mountain-landscape.jpg
mountain-landscape.jpg
quarterly-report.pdf
React Documentation
podcast-episode.mp3

List Variant

Best for file lists with full metadata display.

mountain-landscape.jpg
mountain-landscape.jpgimage/jpeg
quarterly-report-2024.pdfapplication/pdf
product-demo.mp4video/mp4
API Documentationtext/html
meeting-recording.mp3audio/mpeg

Props

<Attachments />

Container component that sets the layout variant.

Prop

Type

<Attachment />

Individual attachment item wrapper.

Prop

Type

<AttachmentPreview />

Displays the media preview (image, video, or icon).

Prop

Type

<AttachmentInfo />

Displays the filename and optional media type.

Prop

Type

<AttachmentRemove />

Remove button that appears on hover.

Prop

Type

<AttachmentHoverCard />

Wrapper for hover preview functionality.

Prop

Type

<AttachmentHoverCardTrigger />

Trigger element for the hover card.

Prop

Type

<AttachmentHoverCardContent />

Content displayed in the hover card.

Prop

Type

<AttachmentEmpty />

Empty state component when no attachments are present.

Prop

Type

Utility Functions

getMediaCategory(data)

Returns the media category for an attachment.

import { getMediaCategory } from '@/components/ai-elements/attachments';

const category = getMediaCategory(attachment);
// Returns: "image" | "video" | "audio" | "document" | "source" | "unknown"

getAttachmentLabel(data)

Returns the display label for an attachment.

import { getAttachmentLabel } from '@/components/ai-elements/attachments';

const label = getAttachmentLabel(attachment);
// Returns filename or fallback like "Image" or "Attachment"