Docs
Cloud Orbit
Cloud Orbit
This component creates a dynamic and interactive experience, where each icon orbits in a fluid motion. Fully customizable, it's ideal for showcasing your tech stack or the tools your product uses.
data:image/s3,"s3://crabby-images/3e3a1/3e3a1c990335a6d768ba8ecb227fa41b80a84dbb" alt="Charlie Avatar"
data:image/s3,"s3://crabby-images/91066/91066801bcb74dbdd589ba1a5f72034e4ec02d20" alt="Deepseek Logo"
data:image/s3,"s3://crabby-images/e4490/e44902088d9b61ece4bb8578112bffa477c7cd47" alt="Motion Logo"
data:image/s3,"s3://crabby-images/d2576/d2576637be05849b7628e536ad22f15b4488502e" alt="Tailwind Logo"
data:image/s3,"s3://crabby-images/bcc9c/bcc9c0793e32b84f1c573ccd66202a3b9a366bf4" alt="Edge Logo"
data:image/s3,"s3://crabby-images/28792/287922d8b4c42e528d82d129947d0739721326d4" alt="Linear Logo"
data:image/s3,"s3://crabby-images/bd751/bd751540c891b79727a7251abc9f0952202c32e4" alt="React Logo"
data:image/s3,"s3://crabby-images/469ab/469abab13843794ea66965807e5b760edc8b0c0d" alt="Drizzle ORM Logo"
Installation
pnpm dlx shadcn@latest add to-setup
Usage
import { CloudOrbit, OrbitingImage } from "@/registry/components/cloud-orbit";
const orbitingImagesData = [
{
speed: 20,
radius: 119,
size: 53,
startAt: 0.15625,
images: [
{
name: "Deepseek Logo",
url: "/images/components/cloud-orbit/deepseek-logo.webp",
},
{
name: "Drizzle ORM Logo",
url: "/images/components/cloud-orbit/drizzle-orm-logo.webp",
},
],
},
...
];
<CloudOrbit
duration={3}
size={160}
images={[
{
name: "Charlie Avatar",
url: "/images/components/cloud-orbit/avatar-1.webp",
},
{
name: "Tommy Avatar",
url: "/images/components/cloud-orbit/avatar-2.webp",
},
]}
className=""
>
{orbitingImagesData.map((orbit, index) => (
<OrbitingImage
key={index}
speed={orbit.speed}
radius={orbit.radius}
size={orbit.size}
startAt={orbit.startAt}
images={orbit.images}
/>
))}
</CloudOrbit>
Note
Placing the icons at the correct angle can be a bit tricky. For easier setup, use the positions from the demo and adjust them visually. If you need help, just reach out!
Props
cloud-orbit
props.
Prop | Type | Description | Default |
---|---|---|---|
duration | number | Duration of the animation cycle in seconds. | 3 |
children | React.ReactNode | Child elements to be rendered inside the component. | - |
size | number | Size of the main orbit container in pixels. | 160 |
className | string | Additional custom classes for styling. | - |
images | Array<Object> | Array of image objects, each containing a url and name . | [] |
props | Record<string, any> | Additional HTML attributes for the component’s wrapper div. | - |
orbiting-image
props.
Prop | Type | Description | Default |
---|---|---|---|
speed | number | Speed of the orbiting motion (lower is slower). | 20 |
radius | number | Radius of the orbit path in pixels. | 100 |
startAt | number | Delay before animation starts, in seconds. | 0 |
size | number | Size of each orbiting image in pixels. | 80 |
className | string | Additional custom classes for styling. | - |
images | Array<Object> | Array of image objects, each containing a url and name . | [] |
duration | number | Duration of the animation cycle for each orbiting image. | 3 |
props | Record<string, any> | Additional HTML attributes for the component’s wrapper div. | - |
Disclaimer
We are not affiliated with any of the brands whose logos are used in this component. These logos are displayed for demonstration purposes only.
Credits
This component is inspired by Icloud
The avatar images are from
Spline.One
For SVGs, I recommend using SVGL