Docs
Tweet Grid
Tweet Grid
A masonry grid full of tweets
Join the club
Installation
Copy and paste the following code into your project.
"use client"
import * as React from "react"
import { cva, type VariantProps } from "class-variance-authority"
import { Tweet } from "react-tweet"
import { cn } from "@/lib/utils"
const tweetGridVariants = cva("max-w-4xl md:max-w-6xl px-2", {
variants: {
columns: {
1: "columns-1",
2: "sm:columns-2",
3: "md:columns-3",
4: "lg:columns-4",
5: "xl:columns-5",
},
},
defaultVariants: {
columns: 3,
},
})
const tweetItemVariants = cva("break-inside-avoid", {
variants: {
spacing: {
sm: "mb-2",
md: "mb-4",
lg: "mb-6",
},
},
defaultVariants: {
spacing: "md",
},
})
export interface TweetGridProps
extends VariantProps<typeof tweetGridVariants>,
VariantProps<typeof tweetItemVariants> {
tweets: string[]
className?: string
}
export const TweetGrid: React.FC<TweetGridProps> = ({
tweets,
columns,
spacing,
className,
}) => {
return (
<div className={cn(tweetGridVariants({ columns }), className)}>
{tweets.map((tweetId, i) => (
<div
key={`${tweetId}-${i}`}
className={cn(tweetItemVariants({ spacing }))}
>
<Tweet id={tweetId} />
</div>
))}
</div>
)
}
Update the import paths to match your project setup.
Usage
import { TweetGrid } from "@/components/ui/tweet-grid"
// Grab tweet ids
const exampleTweets = [
"1742983975340327184",
"1743049700583116812",
"1754067409366073443",
"1753968111059861648",
"1754174981897118136",
"1743632296802988387",
"1754110885168021921",
"1760248682828419497",
"1760230134601122153",
"1760184980356088267",
]
export default function TweetGridDemo() {
return <TweetGrid tweets={exampleTweets} />
}