oxios 1.7.1

Oxios Agent OS — Agent Operating System powered by oxi-sdk
import { Skeleton } from '@/components/ui/skeleton'

export function LoadingCards({ count = 3 }: { count?: number }) {
  return (
    <div className="grid gap-4 animate-stagger">
      {Array.from({ length: count }, (_, i) => (
        <div key={i} className="rounded-xl border p-6">
          <Skeleton className="h-4 w-1/3 mb-4" />
          <Skeleton className="h-3 w-2/3 mb-2" />
          <Skeleton className="h-3 w-1/2" />
        </div>
      ))}
    </div>
  )
}

export function LoadingTable({ rows = 5 }: { rows?: number }) {
  return (
    <div className="rounded-xl border animate-fade-in-up">
      <div className="border-b p-4 bg-muted/30">
        <Skeleton className="h-4 w-1/4" />
      </div>
      {Array.from({ length: rows }, (_, i) => (
        <div key={i} className="flex items-center gap-4 border-b p-4 last:border-0">
          <Skeleton className="h-4 w-1/4" />
          <Skeleton className="h-4 w-1/3" />
          <Skeleton className="h-4 w-1/6" />
        </div>
      ))}
    </div>
  )
}

/** KPI stat card skeleton — big number + label + sparkline area */
export function LoadingStatCards({ count = 6 }: { count?: number }) {
  return (
    <div className="grid gap-3 grid-cols-2 sm:grid-cols-3 xl:grid-cols-6 animate-stagger">
      {Array.from({ length: count }, (_, i) => (
        <div key={i} className="rounded-xl border p-4 space-y-3">
          <Skeleton className="h-3 w-2/3" />
          <Skeleton className="h-7 w-1/3" />
          <div className="flex items-center justify-between">
            <Skeleton className="h-3 w-1/4" />
            <Skeleton className="h-10 w-20 rounded" />
          </div>
        </div>
      ))}
    </div>
  )
}

/** Agent list skeleton — icon + name + id */
export function LoadingAgentList({ count = 4 }: { count?: number }) {
  return (
    <div className="space-y-2 animate-stagger">
      {Array.from({ length: count }, (_, i) => (
        <div key={i} className="flex items-center gap-3 rounded-md border px-3 py-2">
          <Skeleton className="h-3.5 w-3.5 rounded-sm" />
          <Skeleton className="h-4 w-1/3" />
          <Skeleton className="h-3 w-12 ml-auto" />
        </div>
      ))}
    </div>
  )
}

/** Dashboard system health skeleton */
export function LoadingSystemHealth() {
  return (
    <div className="rounded-xl border p-4 space-y-3 animate-fade-in-up">
      <div className="flex items-center gap-2">
        <Skeleton className="h-4 w-4 rounded" />
        <Skeleton className="h-5 w-32" />
      </div>
      {Array.from({ length: 3 }, (_, i) => (
        <div key={i} className="flex items-center gap-2">
          <Skeleton className="h-2 w-2 rounded-full" />
          <Skeleton className="h-3 w-20" />
          <Skeleton className="h-3 w-12 ml-auto" />
        </div>
      ))}
    </div>
  )
}