Skip to content
This repository has been archived by the owner on Jan 16, 2024. It is now read-only.

Commit

Permalink
feat(components:charts): add Recharts custom tooltip component
Browse files Browse the repository at this point in the history
  ## what
  - add Recharts custom tooltip component

  ## how
  - obtained from
    - https://github.com/tremorlabs/tremor/blob/main/src/components/chart-elements/common/ChartTooltip.tsx
  - note
    - this tooltip is from `tremor.so` , and it uses tailwindcss custom
      configs, which means `tailwind.config.ts` needs to be updated
      - done in commit 1e5b14f

  ## why
  - this will be used in charts
  - this is will make chart tooltips more pleasing to look at compared
    to the default tooltips

  ## where
  - ./src/components/charts/Tooltip.tsx

  ## usage
  • Loading branch information
Clumsy-Coder committed Jan 16, 2024
1 parent cd293e1 commit 73b0f7b
Showing 1 changed file with 155 additions and 0 deletions.
155 changes: 155 additions & 0 deletions src/components/charts/Tooltip.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,155 @@
/*
* Custom Recharts tooltip component.
* Used in Rechart charts
*
* Code obtained from `tremor.so`
* https://github.com/tremorlabs/tremor/blob/main/src/components/chart-elements/common/ChartTooltip.tsx
*/

import { cn } from "@/lib/utils";

export const ChartTooltipFrame = ({ children }: { children: React.ReactNode }) => (
<div
className={cn(
// common
"rounded-tremor-default text-tremor-default",
// light
"bg-tremor-background shadow-tremor-dropdown border-tremor-border",
// dark
"dark:bg-dark-tremor-background dark:shadow-dark-tremor-dropdown border dark:border-dark-tremor-border",
"rounded"
)}
>
{children}
</div>
);

export interface ChartTooltipRowProps {
value: string;
name: string;
color: string;
}

export const ChartTooltipRow = ({ value, name, color }: ChartTooltipRowProps) => {
return (
<div className="flex items-center justify-between space-x-8">
<div className="flex items-center space-x-2">
<span
className={cn(
// common
"shrink-0 rounded-tremor-full",
// light
"border-tremor-background shadow-tremor-card",
// dark
"dark:border-dark-tremor-background dark:shadow-dark-tremor-card",
// getColorClassNames(color, colorPalette.background).bgColor,
// color in hex code
`bg-[${color}]`,
"h-3",
"w-3",
"rounded-md",
)}
/>
<p
className={cn(
// common
"text-right whitespace-nowrap",
// light
"text-tremor-content",
// dark
"dark:text-dark-tremor-content",
)}
>
{name}
</p>
</div>
<p
className={cn(
// common
"font-medium tabular-nums text-right whitespace-nowrap",
// light
"text-tremor-content-emphasis",
// dark
"dark:text-dark-tremor-content-emphasis",
)}
>
{value}
</p>
</div>
) };

export interface ChartTooltipProps {
active: boolean | undefined;
payload: any;
label: string;
// categoryColors: Map<string, Color | string>;
valueFormatter: {
(value: number): string;
}
labelFormatter?: {
(payload:any ) : string;
}
}

const ChartTooltip = ({
active,
payload,
label,
// categoryColors,
valueFormatter,
labelFormatter
}: ChartTooltipProps) => {
if (active && payload) {
const filteredPayload: any[] = payload.filter((item: any) => item.type !== "none");

return (
<ChartTooltipFrame>
<div
className={cn(
// light
"border-tremor-border",
// dark
"dark:border-dark-tremor-border",
"px-4",
"py-2",
"border-b",
)}
>
<p
className={cn(
// common
"font-medium",
// light
"text-tremor-content-emphasis",
// dark
"dark:text-dark-tremor-content-emphasis",
)}
>
{labelFormatter ? labelFormatter(payload) : label}
</p>
</div>

<div className={
cn(
"px-4",
"py-2",
"space-y-1"
)
}>
{filteredPayload.map(({ value, name, payload }: { value: number; name: string, payload: any }, idx: number) => (
<ChartTooltipRow
key={`id-${idx}`}
value={valueFormatter(value)}
name={name}
// color={categoryColors.get(name) ?? BaseColors.Blue}
color={payload.fill}
/>
))}
</div>
</ChartTooltipFrame>
);
}
return null;
};

export default ChartTooltip;

0 comments on commit 73b0f7b

Please sign in to comment.