Files
sprint/packages/frontend/src/components/ui/colour-picker.tsx
Oliver Bryan e53bba06d0 added "asChild" for trigger and type="button", not submit
prevents dialogs being closed by accident
2026-01-12 00:55:47 +00:00

35 lines
1.3 KiB
TypeScript

import { HexColorPicker } from "react-colorful";
import { Button } from "@/components/ui/button";
import { Input } from "@/components/ui/input";
import { Popover, PopoverContent, PopoverTrigger } from "@/components/ui/popover";
export default function ColourPicker({
colour,
onChange,
}: {
colour: string;
onChange: (value: string) => void;
}) {
return (
<Popover>
<PopoverTrigger asChild>
<Button type="button" className="w-8 h-8" style={{ backgroundColor: colour }} />
</PopoverTrigger>
<PopoverContent className="w-fit grid gap-2 p-2" align="start" side={"top"}>
<HexColorPicker color={colour} onChange={onChange} className="p-0 m-0" />
<div className="border w-[92px] inline-flex items-center">
<Input
value={colour.slice(1).toUpperCase()}
onChange={(e) => onChange(`#${e.target.value}`)}
spellCheck={false}
className="flex-1 border-transparent h-fit pl-0 mx-0"
maxLength={6}
showCounter={false}
showHashPrefix
/>
</div>
</PopoverContent>
</Popover>
);
}