"use client"; import type { Variants } from "motion/react"; import { motion, useAnimation } from "motion/react"; import type { HTMLAttributes } from "react"; import { forwardRef, useCallback, useImperativeHandle, useRef } from "react"; import { cn } from "@/lib/utils"; export interface BadgeAlertIconHandle { startAnimation: () => void; stopAnimation: () => void; } interface BadgeAlertIconProps extends HTMLAttributes { size?: number; } const ICON_VARIANTS: Variants = { normal: { scale: 1, rotate: 0 }, animate: { scale: [1, 1.1, 1.1, 1.1, 1], rotate: [0, -3, 3, -2, 2, 0], transition: { duration: 0.5, times: [0, 0.2, 0.4, 0.6, 1], ease: "easeInOut", }, }, }; const BadgeAlertIcon = forwardRef(({ onMouseEnter, onMouseLeave, className, size = 28, ...props }, ref) => { const controls = useAnimation(); const isControlledRef = useRef(false); useImperativeHandle(ref, () => { isControlledRef.current = true; return { startAnimation: () => controls.start("animate"), stopAnimation: () => controls.start("normal"), }; }); const handleMouseEnter = useCallback((e: React.MouseEvent) => { if (isControlledRef.current) { onMouseEnter?.(e); } else { controls.start("animate"); } }, [controls, onMouseEnter]); const handleMouseLeave = useCallback((e: React.MouseEvent) => { if (isControlledRef.current) { onMouseLeave?.(e); } else { controls.start("normal"); } }, [controls, onMouseLeave]); return (
); }); BadgeAlertIcon.displayName = "BadgeAlertIcon"; export { BadgeAlertIcon };