mirror of
https://github.com/hex248/sprint.git
synced 2026-02-09 02:33:02 +00:00
colour picker component
This commit is contained in:
34
packages/frontend/src/components/ui/colour-picker.tsx
Normal file
34
packages/frontend/src/components/ui/colour-picker.tsx
Normal file
@@ -0,0 +1,34 @@
|
||||
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>
|
||||
<Button className="w-8 h-8" style={{ backgroundColor: colour }}></Button>
|
||||
</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>
|
||||
);
|
||||
}
|
||||
Reference in New Issue
Block a user