import clsx from "clsx"; import type { ComponentPropsWithoutRef } from "react"; import styles from "./Loading.module.css"; export type LoadingProps = ComponentPropsWithoutRef<"div"> & { width: number; // of entire container, in pixels boxes?: number; // total number of boxes (default: 3) timing?: number; // staggered timing between each box's pulse, in seconds (default: 0.1s) }; const Loading = ({ width, boxes = 3, timing = 0.1, className, style, ...rest }: LoadingProps) => { // each box is just an empty div const divs = []; // allow a custom number of pulsing boxes (defaults to 3) for (let i = 0; i < boxes; i++) { // width of each box correlates with number of boxes (with a little padding) // each individual box's animation has a staggered start in corresponding order divs.push(
); } return (
{divs}
); }; export default Loading;