| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 1 | import * as ResizablePrimitive from "react-resizable-panels"; |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 2 | |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 3 | import { cn } from "@/lib/utils"; |
| 4 | import { DragHandleDots2Icon } from "@radix-ui/react-icons"; |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 5 | |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 6 | const ResizablePanelGroup = ({ className, ...props }: React.ComponentProps<typeof ResizablePrimitive.PanelGroup>) => ( |
| 7 | <ResizablePrimitive.PanelGroup |
| 8 | className={cn("flex h-full w-full data-[panel-group-direction=vertical]:flex-col", className)} |
| 9 | {...props} |
| 10 | /> |
| 11 | ); |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 12 | |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 13 | const ResizablePanel = ResizablePrimitive.Panel; |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 14 | |
| 15 | const ResizableHandle = ({ |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 16 | withHandle, |
| 17 | className, |
| 18 | ...props |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 19 | }: React.ComponentProps<typeof ResizablePrimitive.PanelResizeHandle> & { |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 20 | withHandle?: boolean; |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 21 | }) => ( |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 22 | <ResizablePrimitive.PanelResizeHandle |
| 23 | className={cn( |
| 24 | "relative flex w-px items-center justify-center bg-border after:absolute after:inset-y-0 after:left-1/2 after:w-1 after:-translate-x-1/2 focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring focus-visible:ring-offset-1 data-[panel-group-direction=vertical]:h-px data-[panel-group-direction=vertical]:w-full data-[panel-group-direction=vertical]:after:left-0 data-[panel-group-direction=vertical]:after:h-1 data-[panel-group-direction=vertical]:after:w-full data-[panel-group-direction=vertical]:after:-translate-y-1/2 data-[panel-group-direction=vertical]:after:translate-x-0 [&[data-panel-group-direction=vertical]>div]:rotate-90", |
| 25 | className, |
| 26 | )} |
| 27 | {...props} |
| 28 | > |
| 29 | {withHandle && ( |
| 30 | <div className="z-10 flex h-4 w-3 items-center justify-center rounded-sm border bg-border"> |
| 31 | <DragHandleDots2Icon className="h-2.5 w-2.5" /> |
| 32 | </div> |
| 33 | )} |
| 34 | </ResizablePrimitive.PanelResizeHandle> |
| 35 | ); |
| gio | 5f2f100 | 2025-03-20 18:38:48 +0400 | [diff] [blame] | 36 | |
| gio | d002661 | 2025-05-08 13:00:36 +0000 | [diff] [blame] | 37 | export { ResizablePanelGroup, ResizablePanel, ResizableHandle }; |