ThreeD Loader

Loader with effect of rotating two connected rings

Usage

import { ThreeDLoader } from "react-awesome-loaders";
export const ThreeDLoaderComponent = () => {
return (
<>
<ThreeDLoader
colorRing1={"#DC2626"}
desktopSize={"100px"}
mobileSize={"64px"}
/>
</>
);
};

Parameters

Below are the parameters for ThreeDLoader that you can customize.

OptionDescriptionTypeDefault
classNameclass attribute for loaderStringthreedloader
colorRing1Color of first ringString#4F46E5
colorRing2Color of second ringString#4F46E5
colorLightColor of light dropping on ringsString#FFFFFF
colorAmbientLightColor of ambient lightString#cdd9ed
sizeSize of the logoString64px
desktopSizeSize of the logo on desktopString(empty)
mobileSizeSize of the logo on mobileString(empty)

Some of the color parameters like colorLight, colorAmbientLight are added for this loader since it is created in 3D using three.js and the resultant loader is the 3D model.

size, desktopSize and mobileSize attributes are defined relative to 64px for all loaders and it doesn't mean the actual size would be 64px. It means all the sizes defined will be w.r.t 64px. If you pass 128px then the size doubles. Also, note that if one of the desktopSize and mobileSize is not defined, then it will use the size attribute. Value defined in size attribute is assigned for mobile devices and loader automatically doubles the size on desktop device.

❤️ Inspired from codepen by Aaron Iker