Spinner

SVG-based loading spinner with size and color variants for inline or standalone usage.

Preview

Basic spinner

import { Spinner } from '@/registry/ui-kit/tailwind-spinner/react'

function Example() {
  return <Spinner size="md" variant="primary" />
}

Component API

PropDefaultDescription
SpinnerAnimated loading spinner with size (sm/md/lg) and variant (default/primary).

Source Code

"use client";

import React from "react";

interface SpinnerProps {
  size?: "sm" | "md" | "lg";
  variant?: "default" | "primary";
  className?: string;
}

const sizeMap: Record<string, string> = {
  sm: "h-4 w-4",
  md: "h-6 w-6",
  lg: "h-8 w-8",
};

const variantMap: Record<string, string> = {
  default: "text-zinc-600 dark:text-zinc-400",
  primary: "text-indigo-600 dark:text-indigo-400",
};

export function Spinner({
  size = "md",
  variant = "default",
  className = "",
}: SpinnerProps) {
  return (
    <span role="status">
      <svg
        className={`animate-spin ${sizeMap[size]} ${variantMap[variant]} ${className}`}
        xmlns="http://www.w3.org/2000/svg"
        fill="none"
        viewBox="0 0 24 24"
      >
        <circle
          className="opacity-25"
          cx="12"
          cy="12"
          r="10"
          stroke="currentColor"
          strokeWidth="4"
        />
        <path
          className="opacity-75"
          fill="currentColor"
          d="M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
        />
      </svg>
      <span className="sr-only">Loading...</span>
    </span>
  );
}