mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-07-02 00:54:15 +00:00
- Update component API: PanelGroup → Group, PanelResizeHandle → Separator - Update prop: direction → orientation - Update size values: number → string with units (e.g., "50%") - Update CSS selectors: data-[panel-group-direction] → aria-[orientation] - Update controlled component: onLayout → onLayoutChange with Layout type Closes #9118, #9136, #9200
159 lines
4.7 KiB
TypeScript
159 lines
4.7 KiB
TypeScript
"use client"
|
|
|
|
import * as React from "react"
|
|
import type { Layout } from "react-resizable-panels"
|
|
|
|
import {
|
|
Example,
|
|
ExampleWrapper,
|
|
} from "@/registry/bases/base/components/example"
|
|
import {
|
|
ResizableHandle,
|
|
ResizablePanel,
|
|
ResizablePanelGroup,
|
|
} from "@/registry/bases/base/ui/resizable"
|
|
|
|
export default function ResizableExample() {
|
|
return (
|
|
<ExampleWrapper>
|
|
<ResizableHorizontal />
|
|
<ResizableVertical />
|
|
<ResizableWithHandle />
|
|
<ResizableNested />
|
|
<ResizableControlled />
|
|
</ExampleWrapper>
|
|
)
|
|
}
|
|
|
|
function ResizableHorizontal() {
|
|
return (
|
|
<Example title="Horizontal">
|
|
<ResizablePanelGroup
|
|
orientation="horizontal"
|
|
className="min-h-[200px] rounded-lg border"
|
|
>
|
|
<ResizablePanel defaultSize="25%">
|
|
<div className="flex h-full items-center justify-center p-6">
|
|
<span className="font-semibold">Sidebar</span>
|
|
</div>
|
|
</ResizablePanel>
|
|
<ResizableHandle />
|
|
<ResizablePanel defaultSize="75%">
|
|
<div className="flex h-full items-center justify-center p-6">
|
|
<span className="font-semibold">Content</span>
|
|
</div>
|
|
</ResizablePanel>
|
|
</ResizablePanelGroup>
|
|
</Example>
|
|
)
|
|
}
|
|
|
|
function ResizableVertical() {
|
|
return (
|
|
<Example title="Vertical">
|
|
<ResizablePanelGroup
|
|
orientation="vertical"
|
|
className="min-h-[200px] rounded-lg border"
|
|
>
|
|
<ResizablePanel defaultSize="25%">
|
|
<div className="flex h-full items-center justify-center p-6">
|
|
<span className="font-semibold">Header</span>
|
|
</div>
|
|
</ResizablePanel>
|
|
<ResizableHandle />
|
|
<ResizablePanel defaultSize="75%">
|
|
<div className="flex h-full items-center justify-center p-6">
|
|
<span className="font-semibold">Content</span>
|
|
</div>
|
|
</ResizablePanel>
|
|
</ResizablePanelGroup>
|
|
</Example>
|
|
)
|
|
}
|
|
|
|
function ResizableWithHandle() {
|
|
return (
|
|
<Example title="With Handle">
|
|
<ResizablePanelGroup
|
|
orientation="horizontal"
|
|
className="min-h-[200px] rounded-lg border"
|
|
>
|
|
<ResizablePanel defaultSize="25%">
|
|
<div className="flex h-full items-center justify-center p-6">
|
|
<span className="font-semibold">Sidebar</span>
|
|
</div>
|
|
</ResizablePanel>
|
|
<ResizableHandle withHandle />
|
|
<ResizablePanel defaultSize="75%">
|
|
<div className="flex h-full items-center justify-center p-6">
|
|
<span className="font-semibold">Content</span>
|
|
</div>
|
|
</ResizablePanel>
|
|
</ResizablePanelGroup>
|
|
</Example>
|
|
)
|
|
}
|
|
|
|
function ResizableNested() {
|
|
return (
|
|
<Example title="Nested">
|
|
<ResizablePanelGroup
|
|
orientation="horizontal"
|
|
className="rounded-lg border"
|
|
>
|
|
<ResizablePanel defaultSize="50%">
|
|
<div className="flex h-[200px] items-center justify-center p-6">
|
|
<span className="font-semibold">One</span>
|
|
</div>
|
|
</ResizablePanel>
|
|
<ResizableHandle />
|
|
<ResizablePanel defaultSize="50%">
|
|
<ResizablePanelGroup orientation="vertical">
|
|
<ResizablePanel defaultSize="25%">
|
|
<div className="flex h-full items-center justify-center p-6">
|
|
<span className="font-semibold">Two</span>
|
|
</div>
|
|
</ResizablePanel>
|
|
<ResizableHandle />
|
|
<ResizablePanel defaultSize="75%">
|
|
<div className="flex h-full items-center justify-center p-6">
|
|
<span className="font-semibold">Three</span>
|
|
</div>
|
|
</ResizablePanel>
|
|
</ResizablePanelGroup>
|
|
</ResizablePanel>
|
|
</ResizablePanelGroup>
|
|
</Example>
|
|
)
|
|
}
|
|
|
|
function ResizableControlled() {
|
|
const [layout, setLayout] = React.useState<Layout>({})
|
|
|
|
return (
|
|
<Example title="Controlled">
|
|
<ResizablePanelGroup
|
|
orientation="horizontal"
|
|
className="min-h-[200px] rounded-lg border"
|
|
onLayoutChange={setLayout}
|
|
>
|
|
<ResizablePanel defaultSize="30%" id="left" minSize="20%">
|
|
<div className="flex h-full flex-col items-center justify-center gap-2 p-6">
|
|
<span className="font-semibold">
|
|
{Math.round(layout.left ?? 30)}%
|
|
</span>
|
|
</div>
|
|
</ResizablePanel>
|
|
<ResizableHandle />
|
|
<ResizablePanel defaultSize="70%" id="right" minSize="30%">
|
|
<div className="flex h-full flex-col items-center justify-center gap-2 p-6">
|
|
<span className="font-semibold">
|
|
{Math.round(layout.right ?? 70)}%
|
|
</span>
|
|
</div>
|
|
</ResizablePanel>
|
|
</ResizablePanelGroup>
|
|
</Example>
|
|
)
|
|
}
|