From 0927f44026ccd35f685b7e7866d1fb856e145a52 Mon Sep 17 00:00:00 2001 From: Arghya Das Date: Fri, 27 Dec 2024 09:37:46 +0530 Subject: [PATCH 1/2] feat: added spotlight effect on border in magic card --- content/docs/components/magic-card.mdx | 16 +++++------ public/r/styles/default/magic-card.json | 2 +- registry/default/example/magic-card-demo.tsx | 6 +++-- registry/default/magicui/magic-card.tsx | 28 +++++++++++++++----- 4 files changed, 34 insertions(+), 18 deletions(-) diff --git a/content/docs/components/magic-card.mdx b/content/docs/components/magic-card.mdx index c6afc5f95..44b98747a 100644 --- a/content/docs/components/magic-card.mdx +++ b/content/docs/components/magic-card.mdx @@ -44,14 +44,14 @@ npx shadcn@latest add "https://magicui.design/r/magic-card" ### MagicCard -| Prop name | Type | Default | Description | -| -------------------- | --------------- | --------- | ------------------------------------------- | -| children | React.ReactNode | - | The content to be rendered inside the card | -| className | string | - | Additional CSS classes to apply to the card | -| gradientSize | number | 200 | Size of the gradient effect | -| gradientColor | string | "#262626" | Color of the gradient effect | -| gradientOpacity | number | - | Opacity of the gradient effect | -| gradientTransparency | number | 80 | Transparency level of the gradient effect | +| Prop name | Type | Default | Description | +| --------------- | --------------- | --------- | ------------------------------------------- | +| children | React.ReactNode | - | The content to be rendered inside the card | +| className | string | - | Additional CSS classes to apply to the card | +| gradientSize | number | 200 | Size of the gradient effect | +| gradientColor | string | "#262626" | Color of the gradient effect | +| gradientOpacity | number | - | Opacity of the gradient effect | +| gradientColors | string[] | - | Colors of the gradient effect | ## Credits diff --git a/public/r/styles/default/magic-card.json b/public/r/styles/default/magic-card.json index 8d93efa66..7fa1d6f96 100644 --- a/public/r/styles/default/magic-card.json +++ b/public/r/styles/default/magic-card.json @@ -7,7 +7,7 @@ "files": [ { "path": "magicui/magic-card.tsx", - "content": "\"use client\";\n\nimport React, { useCallback, useEffect, useRef } from \"react\";\nimport { motion, useMotionTemplate, useMotionValue } from \"framer-motion\";\n\nimport { cn } from \"@/lib/utils\";\n\nexport interface MagicCardProps extends React.HTMLAttributes {\n gradientSize?: number;\n gradientColor?: string;\n gradientOpacity?: number;\n}\n\nexport function MagicCard({\n children,\n className,\n gradientSize = 200,\n gradientColor = \"#262626\",\n gradientOpacity = 0.8,\n}: MagicCardProps) {\n const cardRef = useRef(null);\n const mouseX = useMotionValue(-gradientSize);\n const mouseY = useMotionValue(-gradientSize);\n\n const handleMouseMove = useCallback(\n (e: MouseEvent) => {\n if (cardRef.current) {\n const { left, top } = cardRef.current.getBoundingClientRect();\n const clientX = e.clientX;\n const clientY = e.clientY;\n mouseX.set(clientX - left);\n mouseY.set(clientY - top);\n }\n },\n [mouseX, mouseY],\n );\n\n const handleMouseOut = useCallback(\n (e: MouseEvent) => {\n if (!e.relatedTarget) {\n document.removeEventListener(\"mousemove\", handleMouseMove);\n mouseX.set(-gradientSize);\n mouseY.set(-gradientSize);\n }\n },\n [handleMouseMove, mouseX, gradientSize, mouseY],\n );\n\n const handleMouseEnter = useCallback(() => {\n document.addEventListener(\"mousemove\", handleMouseMove);\n mouseX.set(-gradientSize);\n mouseY.set(-gradientSize);\n }, [handleMouseMove, mouseX, gradientSize, mouseY]);\n\n useEffect(() => {\n document.addEventListener(\"mousemove\", handleMouseMove);\n document.addEventListener(\"mouseout\", handleMouseOut);\n document.addEventListener(\"mouseenter\", handleMouseEnter);\n\n return () => {\n document.removeEventListener(\"mousemove\", handleMouseMove);\n document.removeEventListener(\"mouseout\", handleMouseOut);\n document.removeEventListener(\"mouseenter\", handleMouseEnter);\n };\n }, [handleMouseEnter, handleMouseMove, handleMouseOut]);\n\n useEffect(() => {\n mouseX.set(-gradientSize);\n mouseY.set(-gradientSize);\n }, [gradientSize, mouseX, mouseY]);\n\n return (\n \n
{children}
\n \n \n );\n}\n", + "content": "\"use client\";\n\nimport React, { useCallback, useEffect, useRef } from \"react\";\nimport { motion, useMotionTemplate, useMotionValue } from \"framer-motion\";\n\nimport { cn } from \"@/lib/utils\";\n\nexport interface MagicCardProps extends React.HTMLAttributes {\n gradientSize?: number;\n gradientColor?: string;\n gradientOpacity?: number;\n gradientColors?: [string, string, string];\n}\n\nexport function MagicCard({\n children,\n className,\n gradientSize = 200,\n gradientColor = \"#262626\",\n gradientOpacity = 0.8,\n gradientColors = [\"#FF0080\", \"#4096FF\", \"#78FF78\"],\n}: MagicCardProps) {\n const cardRef = useRef(null);\n const mouseX = useMotionValue(-gradientSize);\n const mouseY = useMotionValue(-gradientSize);\n\n const handleMouseMove = useCallback(\n (e: MouseEvent) => {\n if (cardRef.current) {\n const { left, top } = cardRef.current.getBoundingClientRect();\n const clientX = e.clientX;\n const clientY = e.clientY;\n mouseX.set(clientX - left);\n mouseY.set(clientY - top);\n }\n },\n [mouseX, mouseY]\n );\n\n const handleMouseOut = useCallback(\n (e: MouseEvent) => {\n if (!e.relatedTarget) {\n document.removeEventListener(\"mousemove\", handleMouseMove);\n mouseX.set(-gradientSize);\n mouseY.set(-gradientSize);\n }\n },\n [handleMouseMove, mouseX, gradientSize, mouseY]\n );\n\n const handleMouseEnter = useCallback(() => {\n document.addEventListener(\"mousemove\", handleMouseMove);\n mouseX.set(-gradientSize);\n mouseY.set(-gradientSize);\n }, [handleMouseMove, mouseX, gradientSize, mouseY]);\n\n useEffect(() => {\n document.addEventListener(\"mousemove\", handleMouseMove);\n document.addEventListener(\"mouseout\", handleMouseOut);\n document.addEventListener(\"mouseenter\", handleMouseEnter);\n\n return () => {\n document.removeEventListener(\"mousemove\", handleMouseMove);\n document.removeEventListener(\"mouseout\", handleMouseOut);\n document.removeEventListener(\"mouseenter\", handleMouseEnter);\n };\n }, [handleMouseEnter, handleMouseMove, handleMouseOut]);\n\n useEffect(() => {\n mouseX.set(-gradientSize);\n mouseY.set(-gradientSize);\n }, [gradientSize, mouseX, mouseY]);\n\n return (\n \n
\n
{children}
\n \n \n
\n );\n}\n", "type": "registry:ui", "target": "" } diff --git a/registry/default/example/magic-card-demo.tsx b/registry/default/example/magic-card-demo.tsx index 7128bff3b..a87e53aa7 100644 --- a/registry/default/example/magic-card-demo.tsx +++ b/registry/default/example/magic-card-demo.tsx @@ -11,14 +11,16 @@ export default function MagicCardDemo() { } > Magic Card diff --git a/registry/default/magicui/magic-card.tsx b/registry/default/magicui/magic-card.tsx index bbd55d7c7..fd21b4342 100644 --- a/registry/default/magicui/magic-card.tsx +++ b/registry/default/magicui/magic-card.tsx @@ -1,7 +1,7 @@ "use client"; -import React, { useCallback, useEffect, useRef } from "react"; import { motion, useMotionTemplate, useMotionValue } from "framer-motion"; +import React, { useCallback, useEffect, useRef } from "react"; import { cn } from "@/lib/utils"; @@ -9,6 +9,7 @@ export interface MagicCardProps extends React.HTMLAttributes { gradientSize?: number; gradientColor?: string; gradientOpacity?: number; + gradientColors?: [string, string, string]; } export function MagicCard({ @@ -17,6 +18,7 @@ export function MagicCard({ gradientSize = 200, gradientColor = "#262626", gradientOpacity = 0.8, + gradientColors = ["#FF0080", "#4096FF", "#78FF78"], }: MagicCardProps) { const cardRef = useRef(null); const mouseX = useMotionValue(-gradientSize); @@ -72,14 +74,12 @@ export function MagicCard({ return (
-
{children}
+
+
{children}
+
); } From 88596debddb9e65a9df72a00643befb4f5a98d53 Mon Sep 17 00:00:00 2001 From: Dillion Verma Date: Fri, 27 Dec 2024 10:53:23 -0500 Subject: [PATCH 2/2] fix: update spotlight --- content/docs/components/magic-card.mdx | 5 +++-- registry/default/example/magic-card-demo.tsx | 2 -- registry/default/magicui/magic-card.tsx | 20 ++++++++++---------- 3 files changed, 13 insertions(+), 14 deletions(-) diff --git a/content/docs/components/magic-card.mdx b/content/docs/components/magic-card.mdx index 44b98747a..9071da77a 100644 --- a/content/docs/components/magic-card.mdx +++ b/content/docs/components/magic-card.mdx @@ -50,8 +50,9 @@ npx shadcn@latest add "https://magicui.design/r/magic-card" | className | string | - | Additional CSS classes to apply to the card | | gradientSize | number | 200 | Size of the gradient effect | | gradientColor | string | "#262626" | Color of the gradient effect | -| gradientOpacity | number | - | Opacity of the gradient effect | -| gradientColors | string[] | - | Colors of the gradient effect | +| gradientOpacity | number | 0.8 | Opacity of the gradient effect | +| gradientFrom | string | "#9E7AFF" | Start color of the gradient border | +| gradientTo | string | "#FE8BBB" | End color of the gradient border | ## Credits diff --git a/registry/default/example/magic-card-demo.tsx b/registry/default/example/magic-card-demo.tsx index a87e53aa7..5c3c77e15 100644 --- a/registry/default/example/magic-card-demo.tsx +++ b/registry/default/example/magic-card-demo.tsx @@ -13,14 +13,12 @@ export default function MagicCardDemo() { Magic Card diff --git a/registry/default/magicui/magic-card.tsx b/registry/default/magicui/magic-card.tsx index fd21b4342..cf5e90a95 100644 --- a/registry/default/magicui/magic-card.tsx +++ b/registry/default/magicui/magic-card.tsx @@ -1,15 +1,16 @@ "use client"; -import { motion, useMotionTemplate, useMotionValue } from "framer-motion"; +import { motion, useMotionTemplate, useMotionValue } from "motion/react"; import React, { useCallback, useEffect, useRef } from "react"; import { cn } from "@/lib/utils"; -export interface MagicCardProps extends React.HTMLAttributes { +interface MagicCardProps extends React.HTMLAttributes { gradientSize?: number; gradientColor?: string; gradientOpacity?: number; - gradientColors?: [string, string, string]; + gradientFrom?: string; + gradientTo?: string; } export function MagicCard({ @@ -18,7 +19,8 @@ export function MagicCard({ gradientSize = 200, gradientColor = "#262626", gradientOpacity = 0.8, - gradientColors = ["#FF0080", "#4096FF", "#78FF78"], + gradientFrom = "#9E7AFF", + gradientTo = "#FE8BBB", }: MagicCardProps) { const cardRef = useRef(null); const mouseX = useMotionValue(-gradientSize); @@ -76,7 +78,7 @@ export function MagicCard({ ref={cardRef} className={cn("group relative flex size-full rounded-xl", className)} > -
+
{children}