continue re-design
This commit is contained in:
@@ -0,0 +1,57 @@
|
||||
import { AnimatePresence, motion } from "motion/react";
|
||||
|
||||
import { cn } from "@/utils/cn";
|
||||
|
||||
export default function Checkbox({
|
||||
checked,
|
||||
onChange,
|
||||
}: {
|
||||
checked: boolean;
|
||||
onChange?: (checked: boolean) => void;
|
||||
}) {
|
||||
return (
|
||||
<button
|
||||
className="size-20 p-3 relative"
|
||||
type="button"
|
||||
onClick={() => onChange?.(!checked)}
|
||||
>
|
||||
<div
|
||||
className={cn(
|
||||
"w-full h-full rounded-3 group inside-border relative transition-all",
|
||||
checked
|
||||
? "bg-heat-100 group-hover:bg-[#FA4500] before:border-transparent"
|
||||
: "bg-black-alpha-3 group-hover:bg-black-alpha-6 before:border-black-alpha-10 group-hover:before:border-black-alpha-40",
|
||||
)}
|
||||
style={{
|
||||
boxShadow: checked
|
||||
? "0px 2px 4px 0px rgba(255, 77, 0, 0.12), 0px 1px 1px 0px rgba(255, 77, 0, 0.12), 0px 0.5px 0.5px 0px rgba(255, 77, 0, 0.16), 0px 0.25px 0.25px 0px rgba(255, 77, 0, 0.20)"
|
||||
: "",
|
||||
}}
|
||||
>
|
||||
<AnimatePresence>
|
||||
{checked && (
|
||||
<motion.svg
|
||||
animate={{ opacity: 1, scale: 1, y: 0 }}
|
||||
className="absolute cs-10"
|
||||
exit={{ opacity: 0, scale: 0.9, y: 4 }}
|
||||
fill="none"
|
||||
height="10"
|
||||
initial={{ opacity: 0, scale: 0.9, y: 4 }}
|
||||
viewBox="0 0 10 10"
|
||||
width="10"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
>
|
||||
<path
|
||||
d="M2 5.98438L4.39062 8.375L8.375 2"
|
||||
stroke="white"
|
||||
strokeLinecap="round"
|
||||
strokeLinejoin="round"
|
||||
strokeWidth="1.25"
|
||||
/>
|
||||
</motion.svg>
|
||||
)}
|
||||
</AnimatePresence>
|
||||
</div>
|
||||
</button>
|
||||
);
|
||||
}
|
||||
Reference in New Issue
Block a user