Ícone 3D do Copilot Trader
Pilha de dólares 3D
Pilha de dólares 3D
COPILOT TRADER
You are given a task to integrate an existing React component in the codebase The codebase should support: - shadcn project structure - Tailwind CSS - Typescript If it doesn't, provide instructions on how to setup project via shadcn CLI, install Tailwind or Typescript. Determine the default path for components and styles. If default path for components is not /components/ui, provide instructions on why it's important to create this folder Copy-paste this component to /components/ui folder: ```tsx splite.tsx 'use client' import { Suspense, lazy } from 'react' const Spline = lazy(() => import('@splinetool/react-spline')) interface SplineSceneProps { scene: string className?: string } export function SplineScene({ scene, className }: SplineSceneProps) { return (
} > ) } demo.tsx 'use client' import { SplineScene } from "@/components/ui/splite"; import { Card } from "@/components/ui/card" import { Spotlight } from "@/components/ui/spotlight" export function SplineSceneBasic() { return (
{/* Left content */}

Interactive 3D

Bring your UI to life with beautiful 3D scenes. Create immersive experiences that capture attention and enhance your design.

{/* Right content */}
) } ``` Copy-paste these files for dependencies: ```tsx aceternity/spotlight import React from "react"; import { cn } from "@/lib/utils"; type SpotlightProps = { className?: string; fill?: string; }; export const Spotlight = ({ className, fill }: SpotlightProps) => { return ( ); }; ``` ```tsx ibelick/spotlight 'use client'; import React, { useRef, useState, useCallback, useEffect } from 'react'; import { motion, useSpring, useTransform, SpringOptions } from 'framer-motion'; import { cn } from '@/lib/utils'; type SpotlightProps = { className?: string; size?: number; springOptions?: SpringOptions; }; export function Spotlight({ className, size = 200, springOptions = { bounce: 0 }, }: SpotlightProps) { const containerRef = useRef(null); const [isHovered, setIsHovered] = useState(false); const [parentElement, setParentElement] = useState(null); const mouseX = useSpring(0, springOptions); const mouseY = useSpring(0, springOptions); const spotlightLeft = useTransform(mouseX, (x) => `${x - size / 2}px`); const spotlightTop = useTransform(mouseY, (y) => `${y - size / 2}px`); useEffect(() => { if (containerRef.current) { const parent = containerRef.current.parentElement; if (parent) { parent.style.position = 'relative'; parent.style.overflow = 'hidden'; setParentElement(parent); } } }, []); const handleMouseMove = useCallback( (event: MouseEvent) => { if (!parentElement) return; const { left, top } = parentElement.getBoundingClientRect(); mouseX.set(event.clientX - left); mouseY.set(event.clientY - top); }, [mouseX, mouseY, parentElement] ); useEffect(() => { if (!parentElement) return; parentElement.addEventListener('mousemove', handleMouseMove); parentElement.addEventListener('mouseenter', () => setIsHovered(true)); parentElement.addEventListener('mouseleave', () => setIsHovered(false)); return () => { parentElement.removeEventListener('mousemove', handleMouseMove); parentElement.removeEventListener('mouseenter', () => setIsHovered(true)); parentElement.removeEventListener('mouseleave', () => setIsHovered(false) ); }; }, [parentElement, handleMouseMove]); return ( ); } ``` ```tsx shadcn/card import * as React from "react" import { cn } from "@/lib/utils" const Card = React.forwardRef< HTMLDivElement, React.HTMLAttributes >(({ className, ...props }, ref) => (
)) Card.displayName = "Card" const CardHeader = React.forwardRef< HTMLDivElement, React.HTMLAttributes >(({ className, ...props }, ref) => (
)) CardHeader.displayName = "CardHeader" const CardTitle = React.forwardRef< HTMLParagraphElement, React.HTMLAttributes >(({ className, ...props }, ref) => (

)) CardTitle.displayName = "CardTitle" const CardDescription = React.forwardRef< HTMLParagraphElement, React.HTMLAttributes >(({ className, ...props }, ref) => (

)) CardDescription.displayName = "CardDescription" const CardContent = React.forwardRef< HTMLDivElement, React.HTMLAttributes >(({ className, ...props }, ref) => (

)) CardContent.displayName = "CardContent" const CardFooter = React.forwardRef< HTMLDivElement, React.HTMLAttributes >(({ className, ...props }, ref) => (
)) CardFooter.displayName = "CardFooter" export { Card, CardHeader, CardFooter, CardTitle, CardDescription, CardContent } ``` Install NPM dependencies: ```bash @splinetool/runtime, @splinetool/react-spline, framer-motion ``` Implementation Guidelines 1. Analyze the component structure and identify all required dependencies 2. Review the component's argumens and state 3. Identify any required context providers or hooks and install them 4. Questions to Ask - What data/props will be passed to this component? - Are there any specific state management requirements? - Are there any required assets (images, icons, etc.)? - What is the expected responsive behavior? - What is the best place to use this component in the app? Steps to integrate 0. Copy paste all the code above in the correct directories 1. Install external dependencies 2. Fill image assets with Unsplash stock images you know exist 3. Use lucide-react icons for svgs or logos if component requires them