Cursor
A custom cursor component with optional spring animations. It can be globally applied to the page or attached specifically to a parent element.
Examples
Cursor with image and spring
data:image/s3,"s3://crabby-images/29f04/29f04f448f5988b1d06fc586c52a9c94efc224f1" alt="Olympic logo Paris 2024"
Cursor with custom component
data:image/s3,"s3://crabby-images/022cd/022cd2b633bdfd80d09b4ef51f17ec3a1501c895" alt="Green herbs"
Cursor with image and spring
Christian Church, Eastern Europe
Installation
npx shadcn add "https://motion-primitives.com/c/cursor.json"
Component API
Prop | Type | Default | Description |
---|---|---|---|
children | ReactNode | required | Children to be rendered within the custom cursor. Mandatory. |
className | string | Optional CSS class for styling the custom cursor container. | |
springConfig | SpringOptions | Configuration for the spring physics used in the cursor's movement. | |
attachToParent | boolean | false | If true , the cursor will only be visible when hovering over its parent component. |
transition | Transition | Transition settings from motion for animation effects. | |
variants | Object (with initial, animated, exit properties) | Variants for controlling the animation states with specific properties for initial, animate, and exit states. | |
onPositionChange | (position: { x: number, y: number }) => void | Callback function that is called when the cursor position changes. |