mirror of
https://github.com/documenso/documenso.git
synced 2025-11-12 07:43:16 +10:00
**Description:** - Updated mobile header with respect to latest designs <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit - **New Features** - Added a new `showText` property to the `MenuSwitcher` component to control text visibility. - Added a `textSectionClassName` property to the `AvatarWithText` component for conditional text section styling. - Updated the `CommandDialog` and `DialogContent` components with new positioning and styling properties. - **Style Updates** - Adjusted text size responsiveness in the `Hero` component for various screen sizes. - Modified text truncation and input styling in the `Widget` component. - Changed the width of the `SheetContent` element in `MobileNavigation` and adjusted footer layout. - **Documentation** - Added instructions for certificate placement in `SIGNING.md`. - **Refactor** - Standardized type imports across various components and utilities for improved type checking. <!-- end of auto-generated comment: release notes by coderabbit.ai --> --------- Signed-off-by: Adithya Krishna <adithya@documenso.com> Signed-off-by: Adithya Krishna <aadithya794@gmail.com> Co-authored-by: David Nguyen <davidngu28@gmail.com>
69 lines
2.2 KiB
TypeScript
69 lines
2.2 KiB
TypeScript
'use client';
|
|
|
|
import type { HTMLAttributes } from 'react';
|
|
|
|
import { Bar, BarChart, ResponsiveContainer, Tooltip, XAxis, YAxis } from 'recharts';
|
|
|
|
import { formatMonth } from '@documenso/lib/client-only/format-month';
|
|
|
|
export type FundingRaisedProps = HTMLAttributes<HTMLDivElement> & {
|
|
data: Record<string, string | number>[];
|
|
};
|
|
|
|
export const FundingRaised = ({ className, data, ...props }: FundingRaisedProps) => {
|
|
const formattedData = data.map((item) => ({
|
|
amount: Number(item.amount),
|
|
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
|
|
date: formatMonth(item.date as string),
|
|
}));
|
|
|
|
return (
|
|
<div className={className} {...props}>
|
|
<div className="border-border flex flex-col justify-center rounded-2xl border p-6 pl-2 shadow-sm hover:shadow">
|
|
<div className="mb-6 flex px-4">
|
|
<h3 className="text-lg font-semibold">Total Funding Raised</h3>
|
|
</div>
|
|
|
|
<ResponsiveContainer width="100%" height={400}>
|
|
<BarChart data={formattedData} margin={{ top: 40, right: 40, bottom: 20, left: 40 }}>
|
|
<XAxis dataKey="date" />
|
|
<YAxis
|
|
tickFormatter={(value) =>
|
|
Number(value).toLocaleString('en-US', {
|
|
style: 'currency',
|
|
currency: 'USD',
|
|
maximumFractionDigits: 0,
|
|
})
|
|
}
|
|
/>
|
|
<Tooltip
|
|
labelStyle={{
|
|
color: 'hsl(var(--primary-foreground))',
|
|
}}
|
|
itemStyle={{
|
|
color: 'hsl(var(--primary-foreground))',
|
|
}}
|
|
formatter={(value) => [
|
|
Number(value).toLocaleString('en-US', {
|
|
style: 'currency',
|
|
currency: 'USD',
|
|
maximumFractionDigits: 0,
|
|
}),
|
|
'Amount Raised',
|
|
]}
|
|
cursor={{ fill: 'hsl(var(--primary) / 10%)' }}
|
|
/>
|
|
<Bar
|
|
dataKey="amount"
|
|
fill="hsl(var(--primary))"
|
|
label="Amount Raised"
|
|
maxBarSize={60}
|
|
radius={[4, 4, 0, 0]}
|
|
/>
|
|
</BarChart>
|
|
</ResponsiveContainer>
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|