All components
Grid Pattern
backgroundsA background grid pattern made with SVGs, fully customizable using Tailwind CSS.
responsive · 600px
Install
Same command in any shadcn project — React (Vite/CRA), Next.js, Remix, Astro, and more:
$
npx shadcn@latest add https://your-domain/r/grid-pattern.jsonUsage
import { GridPattern } from "@/registry/magic-ui/grid-pattern";
export default function Demo() {
return (
<div className="relative h-[600px] w-full overflow-hidden">
<GridPattern
squares={[
[4, 4], [5, 1], [8, 2], [5, 3], [5, 5],
[10, 10], [12, 15], [15, 10], [10, 15],
[2, 12], [14, 6], [7, 9], [11, 3],
]}
className="[mask-image:radial-gradient(600px_circle_at_center,white,transparent)]"
/>
</div>
);
}Component source
import { useId } from "react"
import { cn } from "@/lib/utils"
interface GridPatternProps extends React.SVGProps<SVGSVGElement> {
width?: number
height?: number
x?: number
y?: number
squares?: Array<[x: number, y: number]>
strokeDasharray?: string
className?: string
[key: string]: unknown
}
export function GridPattern({
width = 40,
height = 40,
x = -1,
y = -1,
strokeDasharray = "0",
squares,
className,
...props
}: GridPatternProps) {
const id = useId()
return (
<svg
aria-hidden="true"
className={cn(
"pointer-events-none absolute inset-0 h-full w-full fill-gray-400/30 stroke-gray-400/30",
className
)}
{...props}
>
<defs>
<pattern
id={id}
width={width}
height={height}
patternUnits="userSpaceOnUse"
x={x}
y={y}
>
<path
d={`M.5 ${height}V.5H${width}`}
fill="none"
strokeDasharray={strokeDasharray}
/>
</pattern>
</defs>
<rect width="100%" height="100%" strokeWidth={0} fill={`url(#${id})`} />
{squares && (
<svg x={x} y={y} className="overflow-visible">
{squares.map(([x, y]) => (
<rect
strokeWidth="0"
key={`${x}-${y}`}
width={width - 1}
height={height - 1}
x={x * width + 1}
y={y * height + 1}
/>
))}
</svg>
)}
</svg>
)
}Source: Magic UI