"use client";
import { useState } from "react";
import { CheckIcon, CopyIcon, InfoIcon, StarIcon } from "lucide-react";
import {
InputGroup,
InputGroupAddon,
InputGroupButton,
InputGroupInput,
} from "@/registry/pure-ui/ui/input-group";
import {
Popover,
PopoverPopup,
PopoverTrigger,
} from "@/registry/pure-ui/ui/popover";
export function InputGroupButtonDemo() {
const { isCopied, copyToClipboard } = useCopyToClipboard();
const [isFavorite, setIsFavorite] = useState(false);
return (
<div className="grid w-full max-w-sm gap-6">
<InputGroup>
<InputGroupInput placeholder="https://x.com/_MusKRii" readOnly />
<InputGroupAddon align="inline-end">
<InputGroupButton
aria-label="Copy"
title="Copy"
size="icon-xs"
onClick={() => {
copyToClipboard("https://x.com/_MusKRii");
}}
>
{isCopied ? <CheckIcon /> : <CopyIcon />}
</InputGroupButton>
</InputGroupAddon>
</InputGroup>
<InputGroup className="[--radius:9999px]">
<Popover>
<PopoverTrigger nativeButton={false} render={<InputGroupAddon />}>
<InputGroupButton variant="secondary" size="icon-xs">
<InfoIcon />
</InputGroupButton>
</PopoverTrigger>
<PopoverPopup
align="start"
className="flex flex-col gap-1 rounded-xl text-sm w-72"
>
<p className="font-medium">Your connection is not secure.</p>
<p className="text-muted-foreground text-sm">
You should not enter any sensitive information on this site.
</p>
</PopoverPopup>
</Popover>
<InputGroupAddon className="text-muted-foreground pl-1.5">
https://
</InputGroupAddon>
<InputGroupInput id="input-secure-19" />
<InputGroupAddon align="inline-end">
<InputGroupButton
aria-label="Favorite"
title="Favorite"
onClick={() => setIsFavorite(!isFavorite)}
size="icon-xs"
>
<StarIcon
data-favorite={isFavorite}
className="data-[favorite=true]:fill-blue-600 data-[favorite=true]:stroke-blue-600"
/>
</InputGroupButton>
</InputGroupAddon>
</InputGroup>
<InputGroup>
<InputGroupInput placeholder="Type to search..." />
<InputGroupAddon align="inline-end">
<InputGroupButton variant="secondary">Search</InputGroupButton>
</InputGroupAddon>
</InputGroup>
</div>
);
}
export function useCopyToClipboard({
timeout = 2000,
onCopy,
}: {
timeout?: number;
onCopy?: () => void;
} = {}) {
const [isCopied, setIsCopied] = useState(false);
const copyToClipboard = (value: string) => {
if (typeof window === "undefined" || !navigator.clipboard.writeText) {
return;
}
if (!value) return;
navigator.clipboard.writeText(value).then(() => {
setIsCopied(true);
if (onCopy) {
onCopy();
}
if (timeout !== 0) {
setTimeout(() => {
setIsCopied(false);
}, timeout);
}
}, console.error);
};
return { isCopied, copyToClipboard };
}