2023-10-23 14:57:18 +00:00
|
|
|
import {
|
|
|
|
CopyWithTooltip,
|
|
|
|
Tooltip,
|
|
|
|
VegaIcon,
|
|
|
|
VegaIconNames,
|
|
|
|
} from '@vegaprotocol/ui-toolkit';
|
2023-09-21 13:25:19 +00:00
|
|
|
import classNames from 'classnames';
|
2023-10-23 14:57:18 +00:00
|
|
|
import type { HTMLAttributes, ReactNode } from 'react';
|
|
|
|
import { Button } from './buttons';
|
2023-10-31 01:12:59 +00:00
|
|
|
import { t } from '@vegaprotocol/i18n';
|
2023-09-21 13:25:19 +00:00
|
|
|
|
|
|
|
export const Tile = ({
|
|
|
|
className,
|
|
|
|
children,
|
2023-10-23 14:57:18 +00:00
|
|
|
}: HTMLAttributes<HTMLDivElement>) => {
|
2023-09-21 13:25:19 +00:00
|
|
|
return (
|
|
|
|
<div
|
|
|
|
className={classNames(
|
2023-10-23 14:57:18 +00:00
|
|
|
'rounded-lg overflow-hidden relative',
|
|
|
|
'bg-vega-clight-800 dark:bg-vega-cdark-800 text-black dark:text-white',
|
|
|
|
'p-6',
|
|
|
|
className
|
2023-09-21 13:25:19 +00:00
|
|
|
)}
|
|
|
|
>
|
2023-10-23 14:57:18 +00:00
|
|
|
{children}
|
2023-09-21 13:25:19 +00:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
2023-10-23 14:57:18 +00:00
|
|
|
|
|
|
|
type StatTileProps = {
|
|
|
|
title: string;
|
2023-11-01 10:06:36 +00:00
|
|
|
description?: ReactNode;
|
2023-10-23 14:57:18 +00:00
|
|
|
children?: ReactNode;
|
|
|
|
};
|
|
|
|
export const StatTile = ({ title, description, children }: StatTileProps) => {
|
|
|
|
return (
|
|
|
|
<Tile>
|
|
|
|
<h3 className="mb-1 text-sm text-vega-clight-100 dark:text-vega-cdark-100 calt">
|
|
|
|
{title}
|
|
|
|
</h3>
|
|
|
|
<div className="text-5xl text-left">{children}</div>
|
|
|
|
{description && (
|
|
|
|
<div className="text-sm text-left text-vega-clight-100 dark:text-vega-cdark-100">
|
|
|
|
{description}
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</Tile>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const FADE_OUT_STYLE = classNames(
|
|
|
|
'after:w-5 after:h-full after:absolute after:top-0 after:right-0',
|
|
|
|
'after:bg-gradient-to-l after:from-vega-clight-800 after:dark:from-vega-cdark-800 after:to-transparent'
|
|
|
|
);
|
|
|
|
|
|
|
|
export const CodeTile = ({
|
|
|
|
code,
|
2023-10-31 01:12:59 +00:00
|
|
|
createdAt,
|
2023-10-23 14:57:18 +00:00
|
|
|
className,
|
|
|
|
}: {
|
|
|
|
code: string;
|
2023-10-31 01:12:59 +00:00
|
|
|
createdAt?: string;
|
2023-10-23 14:57:18 +00:00
|
|
|
className?: string;
|
|
|
|
}) => {
|
|
|
|
return (
|
2023-10-31 01:12:59 +00:00
|
|
|
<StatTile
|
|
|
|
title={t('Your referral code')}
|
|
|
|
description={createdAt ? t('(Created at: %s)', createdAt) : undefined}
|
|
|
|
>
|
2023-11-01 10:06:36 +00:00
|
|
|
<div className="flex items-center justify-between gap-2">
|
2023-10-23 14:57:18 +00:00
|
|
|
<Tooltip
|
|
|
|
description={
|
|
|
|
<div className="break-all">
|
2023-11-01 10:06:36 +00:00
|
|
|
<span className="text-xl text-transparent bg-rainbow bg-clip-text">
|
2023-10-23 14:57:18 +00:00
|
|
|
{code}
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
>
|
|
|
|
<div
|
|
|
|
className={classNames(
|
|
|
|
'relative bg-rainbow bg-clip-text text-transparent text-5xl overflow-hidden',
|
|
|
|
FADE_OUT_STYLE
|
|
|
|
)}
|
|
|
|
>
|
|
|
|
{code}
|
|
|
|
</div>
|
|
|
|
</Tooltip>
|
|
|
|
<CopyWithTooltip text={code}>
|
|
|
|
<Button className="text-sm no-underline !py-0 !px-0 h-fit !bg-transparent">
|
2023-10-31 01:12:59 +00:00
|
|
|
<span className="sr-only">{t('Copy')}</span>
|
2023-10-23 14:57:18 +00:00
|
|
|
<VegaIcon size={24} name={VegaIconNames.COPY} />
|
|
|
|
</Button>
|
|
|
|
</CopyWithTooltip>
|
|
|
|
</div>
|
|
|
|
</StatTile>
|
|
|
|
);
|
|
|
|
};
|