aboutsummaryrefslogtreecommitdiff
path: root/src/components/ui/wooble-card.tsx
blob: 70a561540b2395294d35343d9ff58e469d0d2c73 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
// "use client";
// import { cn } from "@/lib/utils";
// import { motion } from "motion/react";
// import React, { useState } from "react";

// export const WobbleCard = ({
//   children,
//   containerClassName,
//   className,
// }: {
//   children: React.ReactNode;
//   containerClassName?: string;
//   className?: string;
// }) => {
//   const [mousePosition, setMousePosition] = useState({ x: 0, y: 0 });
//   const [isHovering, setIsHovering] = useState(false);

//   const handleMouseMove = (event: React.MouseEvent<HTMLElement>) => {
//     const { clientX, clientY } = event;
//     const rect = event.currentTarget.getBoundingClientRect();
//     const x = (clientX - (rect.left + rect.width / 2)) / 20;
//     const y = (clientY - (rect.top + rect.height / 2)) / 20;
//     setMousePosition({ x, y });
//   };
//   return (
//     <motion.section
//       onMouseMove={handleMouseMove}
//       onMouseEnter={() => setIsHovering(true)}
//       onMouseLeave={() => {
//         setIsHovering(false);
//         setMousePosition({ x: 0, y: 0 });
//       }}
//       style={{
//         transform: isHovering
//           ? `translate3d(${mousePosition.x}px, ${mousePosition.y}px, 0) scale3d(1, 1, 1)`
//           : "translate3d(0px, 0px, 0) scale3d(1, 1, 1)",
//         transition: "transform 0.1s ease-out",
//       }}
//       className={cn(
//         "mx-auto w-full bg-indigo-800  relative rounded-2xl overflow-hidden",
//         containerClassName
//       )}
//     >
//       <div
//         className="relative  h-full [background-image:radial-gradient(88%_100%_at_top,rgba(255,255,255,0.5),rgba(255,255,255,0))]  sm:mx-0 sm:rounded-2xl overflow-hidden"
//         style={{
//           boxShadow:
//             "0 10px 32px rgba(34, 42, 53, 0.12), 0 1px 1px rgba(0, 0, 0, 0.05), 0 0 0 1px rgba(34, 42, 53, 0.05), 0 4px 6px rgba(34, 42, 53, 0.08), 0 24px 108px rgba(47, 48, 55, 0.10)",
//         }}
//       >
//         <motion.div
//           style={{
//             transform: isHovering
//               ? `translate3d(${-mousePosition.x}px, ${-mousePosition.y}px, 0) scale3d(1.03, 1.03, 1)`
//               : "translate3d(0px, 0px, 0) scale3d(1, 1, 1)",
//             transition: "transform 0.1s ease-out",
//           }}
//           className={cn("h-full px-4 py-20 sm:px-10", className)}
//         >
//           <Noise />
//           {children}
//         </motion.div>
//       </div>
//     </motion.section>
//   );
// };

// const Noise = () => {
//   return (
//     <div
//       className="absolute inset-0 w-full h-full scale-[1.2] transform opacity-10 [mask-image:radial-gradient(#fff,transparent,75%)]"
//       style={{
//         backgroundImage: "url(/noise.webp)",
//         backgroundSize: "30%",
//       }}
//     ></div>
//   );
// };