@arolariu/components
Version:
🎨 70+ beautiful, accessible React components built on Base UI. TypeScript-first, CSS Modules styling, tree-shakeable, SSR-ready. Perfect for modern web apps, design systems & rapid prototyping. Zero config, maximum flexibility! ⚡
76 lines (75 loc) • 2.78 kB
JavaScript
"use client";
import { jsx, jsxs } from "react/jsx-runtime";
import { motion } from "motion/react";
import { cn } from "../../lib/utilities.js";
import flip_button_module from "./flip-button.module.js";
import * as __rspack_external_react from "react";
const FlipButton = /*#__PURE__*/ __rspack_external_react.forwardRef(({ frontText, backText, transition = {
type: "spring",
stiffness: 280,
damping: 20
}, className, frontClassName, backClassName, from = "top", ...props }, ref)=>{
const { key: _ignoredKey, ...restProps } = props;
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 = __rspack_external_react.useCallback((opacity, rotation, offset = null)=>({
opacity,
[rotateAxis]: rotation,
...isVertical && null !== offset ? {
y: offset
} : {},
...!isVertical && null !== offset ? {
x: offset
} : {}
}), [
isVertical,
rotateAxis
]);
const frontVariants = __rspack_external_react.useMemo(()=>({
initial: buildVariant(1, 0, "0%"),
hover: buildVariant(0, 90, frontOffset)
}), [
buildVariant,
frontOffset
]);
const backVariants = __rspack_external_react.useMemo(()=>({
initial: buildVariant(0, 90, backOffset),
hover: buildVariant(1, 0, "0%")
}), [
backOffset,
buildVariant
]);
return /*#__PURE__*/ jsxs(motion.button, {
ref: ref,
initial: "initial",
whileHover: "hover",
whileTap: {
scale: 0.95
},
className: cn(flip_button_module.button, className),
...restProps,
children: [
/*#__PURE__*/ jsx(motion.span, {
variants: frontVariants,
transition: transition,
className: cn(flip_button_module.face, flip_button_module.front, frontClassName),
children: frontText
}),
/*#__PURE__*/ jsx(motion.span, {
variants: backVariants,
transition: transition,
className: cn(flip_button_module.face, flip_button_module.back, backClassName),
children: backText
}),
/*#__PURE__*/ jsx("span", {
className: flip_button_module.measure,
children: frontText
})
]
});
});
FlipButton.displayName = "FlipButton";
export { FlipButton };
//# sourceMappingURL=flip-button.js.map