mirror of
https://github.com/documenso/documenso.git
synced 2025-11-23 13:11:32 +10:00
60 lines
1.7 KiB
TypeScript
60 lines
1.7 KiB
TypeScript
'use client';
|
|
|
|
import { HTMLAttributes } from 'react';
|
|
|
|
import { Bar, BarChart, ResponsiveContainer, Tooltip, XAxis, YAxis } from 'recharts';
|
|
|
|
import { formatMonth } from '@documenso/lib/client-only/format-month';
|
|
import { cn } from '@documenso/ui/lib/utils';
|
|
|
|
import { StargazersType } from './page';
|
|
|
|
export type MetricsDataKey = 'stars' | 'forks' | 'mergedPRs' | 'openIssues';
|
|
export type GithubMetricProps = HTMLAttributes<HTMLDivElement> & {
|
|
data: StargazersType;
|
|
metricKey: MetricsDataKey;
|
|
title: string;
|
|
label: string;
|
|
chartHeight?: number;
|
|
};
|
|
|
|
export const GithubMetric = ({
|
|
className,
|
|
data,
|
|
metricKey,
|
|
title,
|
|
label,
|
|
chartHeight = 400,
|
|
...props
|
|
}: GithubMetricProps) => {
|
|
const formattedData = Object.keys(data)
|
|
.map((key) => ({
|
|
month: formatMonth(key),
|
|
[metricKey]: data[key][metricKey],
|
|
}))
|
|
.reverse();
|
|
|
|
return (
|
|
<div className={cn('flex flex-col', className)} {...props}>
|
|
<h3 className="px-4 text-lg font-semibold">{title}</h3>
|
|
|
|
<div className="border-border mt-2.5 flex flex-1 items-center justify-center rounded-2xl border pr-2 shadow-sm hover:shadow">
|
|
<ResponsiveContainer width="100%" height={chartHeight}>
|
|
<BarChart data={formattedData} margin={{ top: 30, right: 20 }}>
|
|
<XAxis dataKey="month" />
|
|
<YAxis />
|
|
<Tooltip
|
|
itemStyle={{
|
|
color: 'hsl(var(--primary-foreground))',
|
|
}}
|
|
formatter={(value) => [Number(value), label]}
|
|
cursor={{ fill: 'hsl(var(--primary) / 10%)' }}
|
|
/>
|
|
<Bar dataKey={metricKey} fill="hsl(var(--primary))" label={label} />
|
|
</BarChart>
|
|
</ResponsiveContainer>
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|