2025-12-10 23:48:19 +05:30
|
|
|
"use client";
|
|
|
|
|
|
|
|
|
|
import { Button } from "@/components/ui/button";
|
|
|
|
|
import { Separator } from "@/components/ui/separator";
|
|
|
|
|
import {
|
|
|
|
|
Tooltip,
|
|
|
|
|
TooltipContent,
|
|
|
|
|
TooltipTrigger,
|
|
|
|
|
} from "@/components/ui/tooltip";
|
|
|
|
|
import { cn } from "@/lib/utils";
|
|
|
|
|
import { BookmarkIcon, type LucideProps } from "lucide-react";
|
|
|
|
|
import type { ComponentProps, HTMLAttributes } from "react";
|
|
|
|
|
|
|
|
|
|
export type CheckpointProps = HTMLAttributes<HTMLDivElement>;
|
|
|
|
|
|
|
|
|
|
export const Checkpoint = ({
|
|
|
|
|
className,
|
|
|
|
|
children,
|
|
|
|
|
...props
|
|
|
|
|
}: CheckpointProps) => (
|
|
|
|
|
<div
|
|
|
|
|
className={cn("flex items-center gap-0.5 text-muted-foreground overflow-hidden", className)}
|
|
|
|
|
{...props}
|
|
|
|
|
>
|
|
|
|
|
{children}
|
|
|
|
|
<Separator />
|
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
export type CheckpointIconProps = LucideProps;
|
|
|
|
|
|
|
|
|
|
export const CheckpointIcon = ({
|
|
|
|
|
className,
|
|
|
|
|
children,
|
|
|
|
|
...props
|
|
|
|
|
}: CheckpointIconProps) =>
|
|
|
|
|
children ?? (
|
|
|
|
|
<BookmarkIcon className={cn("size-4 shrink-0", className)} {...props} />
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
export type CheckpointTriggerProps = ComponentProps<typeof Button> & {
|
|
|
|
|
tooltip?: string;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export const CheckpointTrigger = ({
|
|
|
|
|
children,
|
|
|
|
|
className,
|
|
|
|
|
variant = "ghost",
|
|
|
|
|
size = "sm",
|
|
|
|
|
tooltip,
|
|
|
|
|
...props
|
|
|
|
|
}: CheckpointTriggerProps) =>
|
|
|
|
|
tooltip ? (
|
|
|
|
|
<Tooltip>
|
|
|
|
|
<TooltipTrigger asChild>
|
2025-12-22 09:14:09 +05:30
|
|
|
<Button
|
|
|
|
|
className={cn(className)}
|
|
|
|
|
size={size}
|
|
|
|
|
type="button"
|
|
|
|
|
variant={variant}
|
|
|
|
|
{...props}
|
|
|
|
|
>
|
2025-12-10 23:48:19 +05:30
|
|
|
{children}
|
|
|
|
|
</Button>
|
|
|
|
|
</TooltipTrigger>
|
|
|
|
|
<TooltipContent align="start" side="bottom">
|
|
|
|
|
{tooltip}
|
|
|
|
|
</TooltipContent>
|
|
|
|
|
</Tooltip>
|
|
|
|
|
) : (
|
2025-12-22 09:14:09 +05:30
|
|
|
<Button
|
|
|
|
|
className={cn(className)}
|
|
|
|
|
size={size}
|
|
|
|
|
type="button"
|
|
|
|
|
variant={variant}
|
|
|
|
|
{...props}
|
|
|
|
|
>
|
2025-12-10 23:48:19 +05:30
|
|
|
{children}
|
|
|
|
|
</Button>
|
|
|
|
|
);
|