@arolariu/components
Version:
🎨 70+ beautiful, accessible React components built on Radix UI. TypeScript-first, tree-shakeable, SSR-ready. Perfect for modern web apps, design systems & rapid prototyping. Zero config, maximum flexibility! ⚡
66 lines (65 loc) • 2.52 kB
JavaScript
"use client";
import { jsx, jsxs } from "react/jsx-runtime";
import { motion } from "motion/react";
import { forwardRef } from "react";
import { cn } from "../../lib/utilities.js";
const defaultSpanClassName = "absolute inset-0 flex items-center justify-center rounded-lg";
const FlipButton = /*#__PURE__*/ forwardRef(({ frontText, backText, transition = {
type: "spring",
stiffness: 280,
damping: 20
}, className, frontClassName, backClassName, from = "top", ...props }, ref)=>{
const isVertical = "top" === from || "bottom" === from;
const rotateAxis = isVertical ? "rotateX" : "rotateY";
const frontOffset = "top" === from || "left" === from ? "50%" : "-50%";
const backOffset = "top" === from || "left" === from ? "-50%" : "50%";
const buildVariant = (opacity, rotation, offset = null)=>({
opacity,
[rotateAxis]: rotation,
...isVertical && null !== offset ? {
y: offset
} : {},
...!isVertical && null !== offset ? {
x: offset
} : {}
});
const frontVariants = {
initial: buildVariant(1, 0, "0%"),
hover: buildVariant(0, 90, frontOffset)
};
const backVariants = {
initial: buildVariant(0, 90, backOffset),
hover: buildVariant(1, 0, "0%")
};
return /*#__PURE__*/ jsxs(motion.button, {
ref: ref,
initial: "initial",
whileHover: "hover",
whileTap: {
scale: 0.95
},
className: cn("relative inline-block h-10 cursor-pointer px-4 py-2 text-sm font-medium perspective-[1000px] focus:outline-none", className),
...props,
children: [
/*#__PURE__*/ jsx(motion.span, {
variants: frontVariants,
transition: transition,
className: cn(defaultSpanClassName, "bg-muted text-black dark:text-white", frontClassName),
children: frontText
}),
/*#__PURE__*/ jsx(motion.span, {
variants: backVariants,
transition: transition,
className: cn(defaultSpanClassName, "bg-primary text-primary-foreground", backClassName),
children: backText
}),
/*#__PURE__*/ jsx("span", {
className: "invisible",
children: frontText
})
]
});
});
FlipButton.displayName = "FlipButton";
export { FlipButton };
//# sourceMappingURL=flip-button.js.map