Extend UI is a set of open-source components for document agents, user-facing document flows, and internal tools.
The library includes 14 components and examples for PDF, DOCX, and XLSX viewers, plus bounding box citations, file upload, file thumbnails, e-signature, document splitting, layout blocks, and Finder-style file browsing. Components are fully customizable, MIT licensed, and available through the shadcn component registry.
Extend UI started as the internal component layer for Extend. We built it after evaluating existing file viewer and document component libraries and needing more complete, polished building blocks for document-heavy products. The components are maintained in production at Extend and are used across workflows that process millions of pages, so fixes and improvements continue to flow back into the project.
Use Extend UI when you need document viewers, review surfaces, file-management interfaces, or agent-facing document tools without starting from a generic viewer library. Because each component is installed as source, it also works well with design-system agents and prototyping tools that need editable React and Tailwind code.
- Documentation: https://www.extend.ai/ui
- GitHub: extend-hq/ui
- Registry namespace:
@extend/*
Install a component with the shadcn CLI:
npx shadcn@latest add @extend/pdf-viewer
Then render the installed component from your app:
import { PDFViewer } from "@/components/ui/pdf-viewer" export default function Page() { return <PDFViewer file="/sample.pdf" className="h-[720px]" /> }
Extend UI components are copied into your project as source, so you can adapt
them to your app. Shared primitives such as Button, Select, Dialog,
ScrollArea, and Tooltip are expected to use the primitives your app already
has. If your project uses a different alias or design-system path, update the
generated imports to match, for example changing
@/components/ui/button or @/components/ui/select to your local primitive
paths. You can also set those aliases in components.json before installing so
new components are generated closer to your app structure.
Inspect OCR and layout output with selectable blocks, confidence, markdown text, and PDF overlays that stay connected to the rendered page.
npx shadcn@latest add @extend/layout-blocks-block
import type { ParsedOcrOutput } from "@/components/ui/layout-blocks" import { OcrBlocksBlock } from "@/components/blocks/layout-blocks-block" const output: ParsedOcrOutput = { chunks: [ { blocks: [ { id: "title", type: "heading", content: "Statement of Work", metadata: { page: { number: 1, width: 612, height: 792 }, avgOcrConfidence: 0.99, }, boundingBox: { left: 72, top: 96, right: 360, bottom: 124 }, }, ], }, ], } export default function Page() { return <OcrBlocksBlock file="/documents/statement.pdf" output={output} /> }
Review extracted values against the source PDF with field-level citations, editable form controls, JSON diffing, and page overlays.
Bounding Box Citations component
npx shadcn@latest add @extend/bounding-box-citations-block
import type { ReviewField } from "@/components/ui/bounding-box-citations" import { HumanReviewBlock } from "@/components/blocks/bounding-box-citations-block" const fields: ReviewField[] = [ { key: "invoice_total", schema: { type: "number", title: "Invoice total", description: "Total amount due on the invoice.", }, actual: 1280.5, expected: 1280.5, location: { page: 1, area: { left: 62, top: 82, width: 22, height: 4 }, }, }, ] export default function Page() { return ( <HumanReviewBlock file="/documents/invoice.pdf" fields={fields} className="h-[720px]" /> ) }
A Finder-style file browser for object-store manifests. It supports icon, list, column, and gallery views, and opens PDF, DOCX, XLSX, and image files in viewer dialogs.
npx shadcn@latest add @extend/file-system-block
import type { FileSystemItem } from "@/components/ui/file-system" import { FileSystemBlock } from "@/components/blocks/file-system-block" const items: FileSystemItem[] = [ { kind: "folder", path: "reports/", hasChildren: true, }, { kind: "file", path: "bank-statement.pdf", contentType: "application/pdf", url: "/documents/bank-statement.pdf", previewImageUrl: "/documents/bank-statement-preview.png", }, ] export default function Page() { return ( <FileSystemBlock items={items} title="Documents" defaultView="icons" className="h-[720px]" getFileUrl={(file) => `/api/files/sign?path=${encodeURIComponent(file.path)}` } loadChildren={async ({ path }) => { const response = await fetch( `/api/files?prefix=${encodeURIComponent(path)}` ) return response.json() }} /> ) }
npx shadcn@latest add @extend/pdf-viewer npx shadcn@latest add @extend/docx-viewer npx shadcn@latest add @extend/xlsx-viewer npx shadcn@latest add @extend/file-upload npx shadcn@latest add @extend/file-thumbnail npx shadcn@latest add @extend/e-signature
pnpm install pnpm v4:dev
The site runs at http://localhost:4000.
Extend UI is built and maintained by Extend for teams building modern document processing products.
Licensed under the MIT license.