initial commit

This commit is contained in:
Harivansh Rathi 2024-11-24 20:56:03 -05:00
commit ef9ccf22d3
133 changed files with 20802 additions and 0 deletions

View file

@ -0,0 +1,84 @@
'use client'
import { TrendingUp } from 'lucide-react'
import { Bar, BarChart, XAxis, YAxis } from 'recharts'
import {
Card,
CardContent,
CardDescription,
CardFooter,
CardHeader,
CardTitle
} from '@/components/ui/card'
import {
ChartConfig,
ChartContainer,
ChartTooltip,
ChartTooltipContent
} from '@/components/ui/chart'
const chartData = [
{ browser: 'chrome', visitors: 275, fill: 'var(--color-chrome)' },
{ browser: 'safari', visitors: 200, fill: 'var(--color-safari)' },
{ browser: 'firefox', visitors: 187, fill: 'var(--color-firefox)' },
{ browser: 'edge', visitors: 173, fill: 'var(--color-edge)' },
{ browser: 'other', visitors: 90, fill: 'var(--color-other)' }
]
const chartConfig = {
visitors: {
label: 'Visitors'
},
chrome: {
label: 'Chrome',
color: 'hsl(var(--chart-1))'
},
safari: {
label: 'Safari',
color: 'hsl(var(--chart-2))'
},
firefox: {
label: 'Firefox',
color: 'hsl(var(--chart-3))'
},
edge: {
label: 'Edge',
color: 'hsl(var(--chart-4))'
},
other: {
label: 'Other',
color: 'hsl(var(--chart-5))'
}
} satisfies ChartConfig
export function BarChartMixed() {
return (
<ChartContainer config={chartConfig} className="w-full h-[200px]">
<BarChart
accessibilityLayer
data={chartData}
layout="vertical"
margin={{
left: 0
}}
>
<YAxis
dataKey="browser"
type="category"
tickLine={false}
tickMargin={10}
axisLine={false}
tickFormatter={(value) =>
chartConfig[value as keyof typeof chartConfig]?.label
}
/>
<XAxis dataKey="visitors" type="number" hide />
<ChartTooltip
cursor={false}
content={<ChartTooltipContent hideLabel />}
/>
<Bar dataKey="visitors" layout="vertical" radius={5} />
</BarChart>
</ChartContainer>
)
}

View file

@ -0,0 +1,61 @@
'use client'
import { TrendingUp } from 'lucide-react'
import { Bar, BarChart, CartesianGrid, XAxis } from 'recharts'
import {
Card,
CardContent,
CardDescription,
CardFooter,
CardHeader,
CardTitle
} from '@/components/ui/card'
import {
ChartConfig,
ChartContainer,
ChartTooltip,
ChartTooltipContent
} from '@/components/ui/chart'
const chartData = [
{ month: 'January', desktop: 186, mobile: 80 },
{ month: 'February', desktop: 305, mobile: 200 },
{ month: 'March', desktop: 237, mobile: 120 },
{ month: 'April', desktop: 73, mobile: 190 },
{ month: 'May', desktop: 209, mobile: 130 },
{ month: 'June', desktop: 214, mobile: 140 }
]
const chartConfig = {
desktop: {
label: 'Desktop',
color: 'hsl(var(--chart-1))'
},
mobile: {
label: 'Mobile',
color: 'hsl(var(--chart-2))'
}
} satisfies ChartConfig
export function BarChartMultiple() {
return (
<ChartContainer config={chartConfig} className="w-full h-[200px]">
<BarChart accessibilityLayer data={chartData}>
<CartesianGrid vertical={false} />
<XAxis
dataKey="month"
tickLine={false}
tickMargin={10}
axisLine={false}
tickFormatter={(value) => value.slice(0, 3)}
/>
<ChartTooltip
cursor={false}
content={<ChartTooltipContent indicator="dashed" />}
/>
<Bar dataKey="desktop" fill="var(--color-desktop)" radius={4} />
<Bar dataKey="mobile" fill="var(--color-mobile)" radius={4} />
</BarChart>
</ChartContainer>
)
}

View file

@ -0,0 +1,6 @@
export { BarChartMixed } from './bar-chart-mixed'
export { BarChartMultiple } from './bar-chart-multiple'
export { LineChartMultiple } from './line-chart-multiple'
export { PieChartDonut } from './pie-chart-donut'
export { RadarChartLines } from './radar-chart-lines'
export { RadialChartGrid } from './radial-chart-grid'

View file

@ -0,0 +1,77 @@
'use client'
import { TrendingUp } from 'lucide-react'
import { CartesianGrid, Line, LineChart, XAxis } from 'recharts'
import {
Card,
CardContent,
CardDescription,
CardFooter,
CardHeader,
CardTitle
} from '@/components/ui/card'
import {
ChartConfig,
ChartContainer,
ChartTooltip,
ChartTooltipContent
} from '@/components/ui/chart'
const chartData = [
{ month: 'January', desktop: 186, mobile: 80 },
{ month: 'February', desktop: 305, mobile: 200 },
{ month: 'March', desktop: 237, mobile: 120 },
{ month: 'April', desktop: 73, mobile: 190 },
{ month: 'May', desktop: 209, mobile: 130 },
{ month: 'June', desktop: 214, mobile: 140 }
]
const chartConfig = {
desktop: {
label: 'Desktop',
color: 'hsl(var(--chart-1))'
},
mobile: {
label: 'Mobile',
color: 'hsl(var(--chart-2))'
}
} satisfies ChartConfig
export function LineChartMultiple() {
return (
<ChartContainer config={chartConfig} className="w-full h-[200px]">
<LineChart
accessibilityLayer
data={chartData}
margin={{
left: 12,
right: 12
}}
>
<CartesianGrid vertical={false} />
<XAxis
dataKey="month"
tickLine={false}
axisLine={false}
tickMargin={8}
tickFormatter={(value) => value.slice(0, 3)}
/>
<ChartTooltip cursor={false} content={<ChartTooltipContent />} />
<Line
dataKey="desktop"
type="monotone"
stroke="var(--color-desktop)"
strokeWidth={2}
dot={false}
/>
<Line
dataKey="mobile"
type="monotone"
stroke="var(--color-mobile)"
strokeWidth={2}
dot={false}
/>
</LineChart>
</ChartContainer>
)
}

View file

@ -0,0 +1,110 @@
'use client'
import * as React from 'react'
import { TrendingUp } from 'lucide-react'
import { Label, Pie, PieChart } from 'recharts'
import {
Card,
CardContent,
CardDescription,
CardFooter,
CardHeader,
CardTitle
} from '@/components/ui/card'
import {
ChartConfig,
ChartContainer,
ChartTooltip,
ChartTooltipContent
} from '@/components/ui/chart'
const chartData = [
{ browser: 'chrome', visitors: 275, fill: 'var(--color-chrome)' },
{ browser: 'safari', visitors: 200, fill: 'var(--color-safari)' },
{ browser: 'firefox', visitors: 287, fill: 'var(--color-firefox)' },
{ browser: 'edge', visitors: 173, fill: 'var(--color-edge)' },
{ browser: 'other', visitors: 190, fill: 'var(--color-other)' }
]
const chartConfig = {
visitors: {
label: 'Visitors'
},
chrome: {
label: 'Chrome',
color: 'hsl(var(--chart-1))'
},
safari: {
label: 'Safari',
color: 'hsl(var(--chart-2))'
},
firefox: {
label: 'Firefox',
color: 'hsl(var(--chart-3))'
},
edge: {
label: 'Edge',
color: 'hsl(var(--chart-4))'
},
other: {
label: 'Other',
color: 'hsl(var(--chart-5))'
}
} satisfies ChartConfig
export function PieChartDonut() {
const totalVisitors = React.useMemo(() => {
return chartData.reduce((acc, curr) => acc + curr.visitors, 0)
}, [])
return (
<ChartContainer
config={chartConfig}
className="aspect-square w-full h-[200px]"
>
<PieChart>
<ChartTooltip
cursor={false}
content={<ChartTooltipContent hideLabel />}
/>
<Pie
data={chartData}
dataKey="visitors"
nameKey="browser"
innerRadius={60}
strokeWidth={5}
>
<Label
content={({ viewBox }) => {
if (viewBox && 'cx' in viewBox && 'cy' in viewBox) {
return (
<text
x={viewBox.cx}
y={viewBox.cy}
textAnchor="middle"
dominantBaseline="middle"
>
<tspan
x={viewBox.cx}
y={viewBox.cy}
className="fill-foreground text-3xl font-bold"
>
{totalVisitors.toLocaleString()}
</tspan>
<tspan
x={viewBox.cx}
y={(viewBox.cy || 0) + 24}
className="fill-muted-foreground"
>
Visitors
</tspan>
</text>
)
}
}}
/>
</Pie>
</PieChart>
</ChartContainer>
)
}

View file

@ -0,0 +1,47 @@
'use client'
import { PolarAngleAxis, PolarGrid, Radar, RadarChart } from 'recharts'
import {
ChartConfig,
ChartContainer,
ChartTooltip,
ChartTooltipContent
} from '@/components/ui/chart'
const chartData = [
{ month: 'January', desktop: 186 },
{ month: 'February', desktop: 285 },
{ month: 'March', desktop: 237 },
{ month: 'April', desktop: 203 },
{ month: 'May', desktop: 209 },
{ month: 'June', desktop: 264 }
]
const chartConfig = {
desktop: {
label: 'Desktop',
color: 'hsl(var(--chart-1))'
}
} satisfies ChartConfig
export function RadarChartLines() {
return (
<ChartContainer
config={chartConfig}
className="w-full aspect-square h-[200px]"
>
<RadarChart data={chartData}>
<ChartTooltip cursor={false} content={<ChartTooltipContent />} />
<PolarGrid
className="fill-[--color-desktop] opacity-20"
gridType="circle"
/>
<PolarAngleAxis dataKey="month" />
<Radar
dataKey="desktop"
fill="var(--color-desktop)"
fillOpacity={0.5}
/>
</RadarChart>
</ChartContainer>
)
}

View file

@ -0,0 +1,70 @@
'use client'
import { TrendingUp } from 'lucide-react'
import { PolarGrid, RadialBar, RadialBarChart } from 'recharts'
import {
Card,
CardContent,
CardDescription,
CardFooter,
CardHeader,
CardTitle
} from '@/components/ui/card'
import {
ChartConfig,
ChartContainer,
ChartTooltip,
ChartTooltipContent
} from '@/components/ui/chart'
const chartData = [
{ browser: 'chrome', visitors: 275, fill: 'var(--color-chrome)' },
{ browser: 'safari', visitors: 200, fill: 'var(--color-safari)' },
{ browser: 'firefox', visitors: 187, fill: 'var(--color-firefox)' },
{ browser: 'edge', visitors: 173, fill: 'var(--color-edge)' },
{ browser: 'other', visitors: 90, fill: 'var(--color-other)' }
]
const chartConfig = {
visitors: {
label: 'Visitors'
},
chrome: {
label: 'Chrome',
color: 'hsl(var(--chart-1))'
},
safari: {
label: 'Safari',
color: 'hsl(var(--chart-2))'
},
firefox: {
label: 'Firefox',
color: 'hsl(var(--chart-3))'
},
edge: {
label: 'Edge',
color: 'hsl(var(--chart-4))'
},
other: {
label: 'Other',
color: 'hsl(var(--chart-5))'
}
} satisfies ChartConfig
export function RadialChartGrid() {
return (
<ChartContainer
config={chartConfig}
className="aspect-square w-full h-[200px]"
>
<RadialBarChart data={chartData} innerRadius={30} outerRadius={100}>
<ChartTooltip
cursor={false}
content={<ChartTooltipContent hideLabel nameKey="browser" />}
/>
<PolarGrid gridType="circle" />
<RadialBar dataKey="visitors" />
</RadialBarChart>
</ChartContainer>
)
}

View file

@ -0,0 +1,89 @@
'use client'
import { TrendingUp } from 'lucide-react'
import {
Label,
PolarGrid,
PolarRadiusAxis,
RadialBar,
RadialBarChart
} from 'recharts'
import {
Card,
CardContent,
CardDescription,
CardFooter,
CardHeader,
CardTitle
} from '@/components/ui/card'
import { ChartConfig, ChartContainer } from '@/components/ui/chart'
const chartData = [
{ browser: 'safari', visitors: 1260, fill: 'var(--color-safari)' }
]
const chartConfig = {
visitors: {
label: 'Visitors'
},
safari: {
label: 'Safari',
color: 'hsl(var(--chart-2))'
}
} satisfies ChartConfig
export function RadialChartShape() {
return (
<ChartContainer
config={chartConfig}
className="aspect-square w-full h-[200px]"
>
<RadialBarChart
data={chartData}
endAngle={100}
innerRadius={80}
outerRadius={140}
>
<PolarGrid
gridType="circle"
radialLines={false}
stroke="none"
className="first:fill-muted last:fill-background"
polarRadius={[86, 74]}
/>
<RadialBar dataKey="visitors" background />
<PolarRadiusAxis tick={false} tickLine={false} axisLine={false}>
<Label
content={({ viewBox }) => {
if (viewBox && 'cx' in viewBox && 'cy' in viewBox) {
return (
<text
x={viewBox.cx}
y={viewBox.cy}
textAnchor="middle"
dominantBaseline="middle"
>
<tspan
x={viewBox.cx}
y={viewBox.cy}
className="fill-foreground text-4xl font-bold"
>
{chartData[0].visitors.toLocaleString()}
</tspan>
<tspan
x={viewBox.cx}
y={(viewBox.cy || 0) + 24}
className="fill-muted-foreground"
>
Visitors
</tspan>
</text>
)
}
}}
/>
</PolarRadiusAxis>
</RadialBarChart>
</ChartContainer>
)
}

View file

@ -0,0 +1,188 @@
'use client'
import { ColorPicker } from '@/components/color-picker'
import { Button } from '@/components/ui/button'
import { Checkbox } from '@/components/ui/checkbox'
import { Slider } from '@/components/ui/slider'
import { TriangleAlert } from 'lucide-react'
import React, { useEffect, useState, useTransition } from 'react'
import {
BarChartMixed,
BarChartMultiple,
PieChartDonut,
LineChartMultiple,
RadialChartGrid,
RadarChartLines
} from './_components'
import { Calendar } from '@/components/ui/calendar'
import { DateRange } from 'react-day-picker'
import { RadialChartShape } from './_components/radial-chart-shape'
import { Progress } from '@/components/ui/progress'
import { Switch } from '@/components/ui/switch'
import {
Card,
CardContent,
CardDescription,
CardFooter,
CardHeader,
CardTitle
} from '@/components/ui/card'
import { Input } from '@/components/ui/input'
import { Label } from '@/components/ui/label'
import { toast } from 'react-hot-toast'
export default function () {
const [progress, setProgress] = useState(0)
const [email, setEmail] = useState('')
useEffect(() => {
const interval = setInterval(() => {
setProgress((prevProgress) => {
const newProgress = (prevProgress + 10) % 101
return newProgress
})
}, 1000)
return () => clearInterval(interval)
}, [])
const handleSubmit = async (e: any) => {
e.preventDefault()
const email = e.target.email.value
try {
const response = await fetch('/api/emails', {
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify({ email })
})
const data = await response.json()
if (data.message) {
toast.success(data.message)
setEmail('')
} else {
console.error(data, 'ha')
}
} catch (error) {
console.error('Error:', error)
}
}
return (
<main className="w-full max-w-6xl flex flex-col gap-16 p-6">
<div className="flex flex-col sm:flex-row w-fit mx-auto md:max-w-md gap-2 rounded-lg bg-yellow-300/50 border-2 border-yellow-500/75 p-4 text-foreground">
<TriangleAlert className="w-8 h-8 sm:w-6 sm:h-6 mx-auto sm:mx-0" />
<span className="w-fit">
If you refresh the page, it will reset the colors. Update{' '}
<code className="rounded-lg p-1 bg-foreground/10">globals.css</code>{' '}
with your new colors.
</span>
</div>
<div className="flex flex-col w-fit mx-auto max-w-xs xs:max-w-xl lg:max-w-full lg:mx-0 lg:flex-row lg:w-full justify-between gap-8">
<div className="grid grid-cols-1 xs:grid-cols-2 w-fit xs:w-full mx-auto sm:mx-0 gap-8">
<div className="w-min sm:w-max flex flex-col items-center mx-auto gap-2 text-lg md:text-xl sm:whitespace-nowrap">
<span>Primary color</span>
<ColorPicker variable="--primary" />
</div>
<div className="w-min sm:w-max flex flex-col items-center mx-auto gap-2 text-lg md:text-xl sm:whitespace-nowrap">
<span>Primary text color</span>
<ColorPicker variable="--primary-foreground" />
</div>
</div>
<div className="w-full h-fit flex flex-col gap-6 text-lg md:text-xl sm:whitespace-nowrap">
<span>Components</span>
<div className="flex flex-wrap justify-center items-center sm:justify-start w-full h-fit gap-6">
<Button variant="default">Default</Button>
<Button variant="ghost">Ghost</Button>
<Checkbox defaultChecked={true} className="w-5 h-5" />
<Slider
defaultValue={[50]}
max={100}
step={1}
className="max-w-36"
/>
<Switch defaultChecked />
<Progress value={progress} />
<Card className="w-full bg-transparent relative">
<CardHeader>
<CardTitle>Get the Starter Kit</CardTitle>
<CardDescription>
Receive the Starter Kit for free in your mailbox.
</CardDescription>
</CardHeader>
<form onSubmit={handleSubmit}>
<CardContent>
<div className="grid w-full items-center gap-4">
<div className="flex flex-col space-y-1.5">
<Label htmlFor="name">Email</Label>
<Input
name="email"
id="email"
type="email"
placeholder="example@gmail.com"
value={email}
onChange={(e) => setEmail(e.target.value)}
required
/>
</div>
</div>
</CardContent>
<CardFooter className="flex justify-between">
<Button
type="button"
variant="outline"
onClick={() => setEmail('')}
>
Cancel
</Button>
<Button type="submit">Continue</Button>
</CardFooter>
</form>
</Card>
</div>
</div>
</div>
<div className="flex flex-col w-fit mx-auto max-w-xs xs:max-w-xl lg:max-w-full lg:mx-0 lg:flex-row lg:w-full justify-between gap-8">
<div className="grid grid-cols-1 xs:grid-cols-2 w-fit xs:w-full mx-auto sm:mx-0 gap-8">
<div className="w-min flex flex-col items-center mx-auto gap-2 text-lg md:text-xl sm:whitespace-nowrap">
<span>Chart Color 1</span>
<ColorPicker variable="--chart-1" />
</div>
<div className="w-min flex flex-col items-center mx-auto gap-2 text-lg md:text-xl sm:whitespace-nowrap">
<span>Chart Color 2</span>
<ColorPicker variable="--chart-2" />
</div>
<div className="w-min flex flex-col items-center mx-auto gap-2 text-lg md:text-xl sm:whitespace-nowrap">
<span>Chart Color 3</span>
<ColorPicker variable="--chart-3" />
</div>
<div className="w-min flex flex-col items-center mx-auto gap-2 text-lg md:text-xl sm:whitespace-nowrap">
<span>Chart Color 4</span>
<ColorPicker variable="--chart-4" />
</div>
<div className="w-min col-span-2 flex flex-col items-center mx-auto gap-2 text-lg md:text-xl sm:whitespace-nowrap">
<span>Chart Color 5</span>
<ColorPicker variable="--chart-5" />
</div>
</div>
<div className="w-full h-fit flex flex-col gap-6 text-lg md:text-xl sm:whitespace-nowrap">
<span>Charts</span>
<div className="flex flex-wrap max-w-[250px] xs:max-w-full mx-auto justify-center items-center sm:justify-start w-full h-fit gap-6">
<BarChartMultiple />
<BarChartMixed />
<LineChartMultiple />
<div className="flex flex-col sm:flex-row w-full">
<PieChartDonut />
<RadialChartGrid />
</div>
<div className="flex flex-col sm:flex-row w-full">
<RadarChartLines />
<RadialChartShape />
</div>
</div>
</div>
</div>
</main>
)
}