2024-02-08 14:07:48 +00:00
|
|
|
import { Link, useSearchParams } from 'react-router-dom';
|
|
|
|
import {
|
|
|
|
Intent,
|
|
|
|
TradingAnchorButton,
|
|
|
|
VegaIcon,
|
|
|
|
VegaIconNames,
|
|
|
|
} from '@vegaprotocol/ui-toolkit';
|
2024-03-01 14:25:56 +00:00
|
|
|
import { useVegaWallet, useDialogStore } from '@vegaprotocol/wallet-react';
|
2024-01-31 14:21:29 +00:00
|
|
|
import { addDecimalsFormatNumber } from '@vegaprotocol/utils';
|
|
|
|
import { useT } from '../../lib/use-t';
|
|
|
|
import { useReferralSetTransaction } from '../../lib/hooks/use-referral-set-transaction';
|
|
|
|
import { DApp, TokenStaticLinks, useLinks } from '@vegaprotocol/environment';
|
|
|
|
import { RainbowButton } from '../../components/rainbow-button';
|
|
|
|
import { usePageTitle } from '../../lib/hooks/use-page-title';
|
|
|
|
import { ErrorBoundary } from '../../components/error-boundary';
|
|
|
|
import { Box } from '../../components/competitions/box';
|
|
|
|
import { LayoutWithGradient } from '../../components/layouts-inner';
|
|
|
|
import { Links } from '../../lib/links';
|
|
|
|
import { TeamForm, TransactionType } from './team-form';
|
|
|
|
|
|
|
|
export const CompetitionsCreateTeam = () => {
|
|
|
|
const [searchParams] = useSearchParams();
|
|
|
|
const isSolo = Boolean(searchParams.get('solo'));
|
|
|
|
const t = useT();
|
|
|
|
|
|
|
|
usePageTitle(t('Create a team'));
|
|
|
|
|
|
|
|
const { isReadOnly, pubKey } = useVegaWallet();
|
2024-03-01 14:25:56 +00:00
|
|
|
const openWalletDialog = useDialogStore((store) => store.open);
|
2024-01-31 14:21:29 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<ErrorBoundary feature="create-team">
|
|
|
|
<LayoutWithGradient>
|
|
|
|
<div className="mx-auto md:w-2/3 max-w-xl">
|
|
|
|
<Box className="flex flex-col gap-4">
|
2024-02-08 14:07:48 +00:00
|
|
|
<Link
|
|
|
|
to={Links.COMPETITIONS()}
|
|
|
|
className="text-xs inline-flex items-center gap-1 group"
|
|
|
|
>
|
|
|
|
<VegaIcon
|
|
|
|
name={VegaIconNames.CHEVRON_LEFT}
|
|
|
|
size={12}
|
|
|
|
className="text-vega-clight-100 dark:text-vega-cdark-100"
|
|
|
|
/>{' '}
|
|
|
|
<span className="group-hover:underline">
|
|
|
|
{t('Go back to the competitions')}
|
|
|
|
</span>
|
|
|
|
</Link>
|
2024-01-31 14:21:29 +00:00
|
|
|
<h1 className="calt text-2xl lg:text-3xl xl:text-4xl">
|
2024-02-01 10:38:57 +00:00
|
|
|
{isSolo ? t('Create solo team') : t('Create a team')}
|
2024-01-31 14:21:29 +00:00
|
|
|
</h1>
|
|
|
|
{pubKey && !isReadOnly ? (
|
|
|
|
<CreateTeamFormContainer isSolo={isSolo} />
|
|
|
|
) : (
|
|
|
|
<>
|
|
|
|
<p>
|
|
|
|
{t(
|
|
|
|
'Create a team to participate in team based rewards as well as access the discount benefits of the current referral program.'
|
|
|
|
)}
|
|
|
|
</p>
|
|
|
|
<RainbowButton variant="border" onClick={openWalletDialog}>
|
|
|
|
{t('Connect wallet')}
|
|
|
|
</RainbowButton>
|
|
|
|
</>
|
|
|
|
)}
|
|
|
|
</Box>
|
|
|
|
</div>
|
|
|
|
</LayoutWithGradient>
|
|
|
|
</ErrorBoundary>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const CreateTeamFormContainer = ({ isSolo }: { isSolo: boolean }) => {
|
|
|
|
const t = useT();
|
|
|
|
const createLink = useLinks(DApp.Governance);
|
|
|
|
|
|
|
|
const { err, status, code, isEligible, requiredStake, onSubmit } =
|
|
|
|
useReferralSetTransaction({
|
|
|
|
onSuccess: (code) => {
|
|
|
|
// For some reason team creation takes a long time, too long even to make
|
|
|
|
// polling viable, so its not feasible to navigate to the team page
|
|
|
|
// after creation
|
|
|
|
//
|
|
|
|
// navigate(Links.COMPETITIONS_TEAM(code));
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
if (status === 'confirmed') {
|
|
|
|
return (
|
2024-02-01 19:33:25 +00:00
|
|
|
<div
|
|
|
|
className="flex flex-col items-start gap-2"
|
|
|
|
data-testid="team-creation-success-message"
|
|
|
|
>
|
2024-01-31 14:21:29 +00:00
|
|
|
<p className="text-sm">{t('Team creation transaction successful')}</p>
|
|
|
|
{code && (
|
|
|
|
<>
|
2024-02-08 14:07:48 +00:00
|
|
|
<dl>
|
|
|
|
<dt className="text-sm">{t('Your team ID:')}</dt>
|
|
|
|
<dl>
|
|
|
|
<span
|
|
|
|
className="font-mono break-all bg-rainbow bg-clip-text text-transparent text-2xl"
|
|
|
|
data-testid="team-id-display"
|
|
|
|
>
|
|
|
|
{code}
|
|
|
|
</span>
|
|
|
|
</dl>
|
|
|
|
</dl>
|
2024-01-31 14:21:29 +00:00
|
|
|
<TradingAnchorButton
|
|
|
|
href={Links.COMPETITIONS_TEAM(code)}
|
|
|
|
intent={Intent.Info}
|
|
|
|
size="small"
|
2024-02-01 19:33:25 +00:00
|
|
|
data-testid="view-team-button"
|
2024-01-31 14:21:29 +00:00
|
|
|
>
|
|
|
|
{t('View team')}
|
|
|
|
</TradingAnchorButton>
|
|
|
|
</>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!isEligible) {
|
|
|
|
return (
|
|
|
|
<div className="flex flex-col gap-4">
|
|
|
|
{requiredStake !== undefined && (
|
|
|
|
<p>
|
|
|
|
{t(
|
|
|
|
'You need at least {{requiredStake}} VEGA staked to generate a referral code and participate in the referral program.',
|
|
|
|
{
|
|
|
|
requiredStake: addDecimalsFormatNumber(
|
|
|
|
requiredStake.toString(),
|
|
|
|
18
|
|
|
|
),
|
|
|
|
}
|
|
|
|
)}
|
|
|
|
</p>
|
|
|
|
)}
|
|
|
|
<TradingAnchorButton
|
|
|
|
href={createLink(TokenStaticLinks.ASSOCIATE)}
|
|
|
|
intent={Intent.Primary}
|
|
|
|
target="_blank"
|
|
|
|
>
|
|
|
|
{t('Stake some $VEGA now')}
|
|
|
|
</TradingAnchorButton>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<TeamForm
|
|
|
|
type={TransactionType.CreateReferralSet}
|
|
|
|
onSubmit={onSubmit}
|
|
|
|
status={status}
|
|
|
|
err={err}
|
2024-02-01 10:38:57 +00:00
|
|
|
isCreatingSoloTeam={isSolo}
|
2024-01-31 14:21:29 +00:00
|
|
|
/>
|
|
|
|
);
|
|
|
|
};
|