2023-08-02 15:34:04 +00:00
|
|
|
import classNames from 'classnames';
|
|
|
|
import {
|
2023-08-24 08:03:56 +00:00
|
|
|
ExternalLink,
|
|
|
|
Intent,
|
2023-09-15 14:10:38 +00:00
|
|
|
TradingAnchorButton,
|
2023-08-24 08:03:56 +00:00
|
|
|
TradingButton,
|
|
|
|
VegaIcon,
|
|
|
|
VegaIconNames,
|
|
|
|
} from '@vegaprotocol/ui-toolkit';
|
2024-03-01 14:25:56 +00:00
|
|
|
import { useVegaWallet, useDialogStore } from '@vegaprotocol/wallet-react';
|
2023-08-02 15:34:04 +00:00
|
|
|
import { Networks, useEnvironment } from '@vegaprotocol/environment';
|
2024-03-01 14:25:56 +00:00
|
|
|
import { useOnboardingStore } from '../../stores/onboarding';
|
2023-08-24 08:03:56 +00:00
|
|
|
import {
|
|
|
|
OnboardingStep,
|
|
|
|
useGetOnboardingStep,
|
2024-03-01 14:25:56 +00:00
|
|
|
} from '../../lib/hooks/use-get-onboarding-step';
|
2023-09-20 20:28:34 +00:00
|
|
|
import { Links, Routes } from '../../lib/links';
|
2023-08-24 08:03:56 +00:00
|
|
|
import { useGlobalStore } from '../../stores';
|
|
|
|
import { useSidebar, ViewType } from '../sidebar';
|
2023-11-16 03:10:39 +00:00
|
|
|
import { useT } from '../../lib/use-t';
|
|
|
|
import { Trans } from 'react-i18next';
|
2023-08-02 15:34:04 +00:00
|
|
|
|
|
|
|
interface Props {
|
|
|
|
lead?: string;
|
|
|
|
}
|
|
|
|
|
2023-08-24 08:03:56 +00:00
|
|
|
const GetStartedButton = ({ step }: { step: OnboardingStep }) => {
|
2023-11-16 03:10:39 +00:00
|
|
|
const t = useT();
|
2024-03-01 14:25:56 +00:00
|
|
|
const { VEGA_ENV } = useEnvironment();
|
2023-09-01 09:00:20 +00:00
|
|
|
const dismiss = useOnboardingStore((store) => store.dismiss);
|
2024-03-01 14:25:56 +00:00
|
|
|
const setDialog = useOnboardingStore((store) => store.setDialog);
|
|
|
|
const risk = useOnboardingStore((store) => store.risk);
|
2023-08-24 08:03:56 +00:00
|
|
|
const marketId = useGlobalStore((store) => store.marketId);
|
2023-09-15 12:36:08 +00:00
|
|
|
const setViews = useSidebar((store) => store.setViews);
|
2023-09-15 14:10:38 +00:00
|
|
|
|
|
|
|
const buttonProps = {
|
|
|
|
size: 'small' as const,
|
|
|
|
'data-testid': 'get-started-button',
|
|
|
|
intent: Intent.Info,
|
2023-08-02 15:34:04 +00:00
|
|
|
};
|
2023-09-15 14:10:38 +00:00
|
|
|
|
2023-09-12 15:07:37 +00:00
|
|
|
if (step <= OnboardingStep.ONBOARDING_CONNECT_STEP) {
|
2023-09-15 14:10:38 +00:00
|
|
|
return (
|
2024-03-01 14:25:56 +00:00
|
|
|
<TradingButton
|
|
|
|
{...buttonProps}
|
|
|
|
onClick={() => {
|
|
|
|
if (VEGA_ENV === Networks.MAINNET && risk !== 'accepted') {
|
|
|
|
setDialog('risk');
|
|
|
|
} else {
|
|
|
|
setDialog('connect');
|
|
|
|
}
|
|
|
|
}}
|
|
|
|
>
|
2023-09-15 14:10:38 +00:00
|
|
|
{t('Connect')}
|
|
|
|
</TradingButton>
|
|
|
|
);
|
2023-08-24 08:03:56 +00:00
|
|
|
} else if (step === OnboardingStep.ONBOARDING_DEPOSIT_STEP) {
|
2023-09-15 14:10:38 +00:00
|
|
|
return (
|
|
|
|
<TradingAnchorButton
|
|
|
|
{...buttonProps}
|
2023-09-20 20:28:34 +00:00
|
|
|
href={Links.DEPOSIT()}
|
2024-03-01 14:25:56 +00:00
|
|
|
onClick={() => setDialog('inactive')}
|
2023-09-15 14:10:38 +00:00
|
|
|
>
|
|
|
|
{t('Deposit')}
|
|
|
|
</TradingAnchorButton>
|
|
|
|
);
|
2023-09-14 19:10:33 +00:00
|
|
|
} else if (step >= OnboardingStep.ONBOARDING_ORDER_STEP) {
|
2023-09-20 20:28:34 +00:00
|
|
|
const link = marketId ? Links.MARKET(marketId) : Links.HOME();
|
2023-09-15 14:10:38 +00:00
|
|
|
return (
|
|
|
|
<TradingAnchorButton
|
|
|
|
{...buttonProps}
|
2023-09-20 20:28:34 +00:00
|
|
|
href={link}
|
2023-09-15 14:10:38 +00:00
|
|
|
onClick={() => {
|
|
|
|
setViews({ type: ViewType.Order }, Routes.MARKET);
|
|
|
|
dismiss();
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
{t('Ready to trade')}
|
|
|
|
</TradingAnchorButton>
|
|
|
|
);
|
2023-08-24 08:03:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
2024-03-01 14:25:56 +00:00
|
|
|
<TradingButton {...buttonProps} onClick={() => setDialog('connect')}>
|
2023-09-15 14:10:38 +00:00
|
|
|
{t('Get started')}
|
2023-08-24 08:03:56 +00:00
|
|
|
</TradingButton>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2023-09-15 14:10:38 +00:00
|
|
|
export const GetStartedCheckList = () => {
|
2023-11-16 03:10:39 +00:00
|
|
|
const t = useT();
|
2023-09-15 14:10:38 +00:00
|
|
|
const { pubKey } = useVegaWallet();
|
|
|
|
const currentStep = useGetOnboardingStep();
|
|
|
|
return (
|
|
|
|
<ul className="list-none">
|
|
|
|
<Step
|
|
|
|
step={1}
|
|
|
|
text={t('Connect')}
|
|
|
|
complete={Boolean(
|
|
|
|
currentStep > OnboardingStep.ONBOARDING_CONNECT_STEP || pubKey
|
|
|
|
)}
|
|
|
|
/>
|
|
|
|
<Step
|
|
|
|
step={2}
|
|
|
|
text={t('Deposit funds')}
|
|
|
|
complete={currentStep > OnboardingStep.ONBOARDING_DEPOSIT_STEP}
|
|
|
|
/>
|
|
|
|
<Step
|
|
|
|
step={3}
|
|
|
|
text={t('Open a position')}
|
|
|
|
complete={currentStep > OnboardingStep.ONBOARDING_ORDER_STEP}
|
|
|
|
/>
|
|
|
|
</ul>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2023-08-24 08:03:56 +00:00
|
|
|
export const GetStarted = ({ lead }: Props) => {
|
2023-11-16 03:10:39 +00:00
|
|
|
const t = useT();
|
2023-08-24 08:03:56 +00:00
|
|
|
const { pubKey } = useVegaWallet();
|
|
|
|
const { VEGA_ENV, VEGA_NETWORKS } = useEnvironment();
|
2024-03-01 14:25:56 +00:00
|
|
|
const openVegaWalletDialog = useDialogStore((store) => store.open);
|
2023-09-14 19:10:33 +00:00
|
|
|
const currentStep = useGetOnboardingStep();
|
|
|
|
const dismissed = useOnboardingStore((store) => store.dismissed);
|
2023-08-02 15:34:04 +00:00
|
|
|
|
2023-08-04 10:09:43 +00:00
|
|
|
const wrapperClasses = classNames(
|
|
|
|
'flex flex-col py-4 px-6 gap-4 rounded',
|
|
|
|
'bg-vega-blue-300 dark:bg-vega-blue-700',
|
|
|
|
'border border-vega-blue-350 dark:border-vega-blue-650',
|
|
|
|
{ 'mt-8': !lead }
|
|
|
|
);
|
|
|
|
|
2023-09-14 19:10:33 +00:00
|
|
|
if (!dismissed) {
|
2023-08-02 15:34:04 +00:00
|
|
|
return (
|
2023-08-04 10:09:43 +00:00
|
|
|
<div className={wrapperClasses} data-testid="get-started-banner">
|
2023-08-02 15:34:04 +00:00
|
|
|
{lead && <h2>{lead}</h2>}
|
2023-08-04 10:09:43 +00:00
|
|
|
<h3 className="text-lg">{t('Get started')}</h3>
|
2023-08-02 15:34:04 +00:00
|
|
|
<div>
|
2023-09-15 14:10:38 +00:00
|
|
|
<GetStartedCheckList />
|
2023-08-02 15:34:04 +00:00
|
|
|
</div>
|
|
|
|
<div>
|
2023-08-24 08:03:56 +00:00
|
|
|
<GetStartedButton step={currentStep} />
|
2023-08-02 15:34:04 +00:00
|
|
|
</div>
|
|
|
|
{VEGA_ENV === Networks.MAINNET && (
|
|
|
|
<p className="text-sm">
|
2023-11-16 03:10:39 +00:00
|
|
|
<Trans
|
|
|
|
defaults="Experiment for free with virtual assets on <0>Fairground Testnet</0>"
|
|
|
|
components={[
|
|
|
|
<ExternalLink href={VEGA_NETWORKS.TESTNET} key="link">
|
|
|
|
Fairground Testnet
|
|
|
|
</ExternalLink>,
|
|
|
|
]}
|
|
|
|
/>
|
2023-08-02 15:34:04 +00:00
|
|
|
</p>
|
|
|
|
)}
|
|
|
|
{VEGA_ENV === Networks.TESTNET && (
|
|
|
|
<p className="text-sm">
|
2023-11-16 03:10:39 +00:00
|
|
|
<Trans
|
|
|
|
defaults="Ready to trade with real funds? <0>Switch to Mainnet</0>"
|
|
|
|
components={[
|
2024-03-01 14:25:56 +00:00
|
|
|
<ExternalLink
|
|
|
|
href={VEGA_NETWORKS.MAINNET}
|
|
|
|
key="link"
|
|
|
|
className="underline"
|
|
|
|
>
|
2023-11-16 03:10:39 +00:00
|
|
|
Switch to Mainnet
|
|
|
|
</ExternalLink>,
|
|
|
|
]}
|
|
|
|
/>
|
2023-08-02 15:34:04 +00:00
|
|
|
</p>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
2023-08-04 10:09:43 +00:00
|
|
|
|
|
|
|
if (!pubKey) {
|
|
|
|
return (
|
|
|
|
<div className={wrapperClasses}>
|
2023-08-25 17:52:52 +00:00
|
|
|
<p className="mb-1 text-sm">
|
2023-11-16 03:10:39 +00:00
|
|
|
<Trans
|
|
|
|
defaults="You need a <0>Vega wallet</0> to start trading in this market."
|
|
|
|
components={[
|
|
|
|
<ExternalLink href="https://vega.xyz/wallet" key="link">
|
|
|
|
Vega wallet
|
|
|
|
</ExternalLink>,
|
|
|
|
]}
|
|
|
|
/>
|
2023-08-04 10:09:43 +00:00
|
|
|
</p>
|
|
|
|
<TradingButton
|
|
|
|
onClick={openVegaWalletDialog}
|
|
|
|
size="small"
|
|
|
|
data-testid="order-connect-wallet"
|
|
|
|
intent={Intent.Info}
|
|
|
|
>
|
|
|
|
{t('Connect wallet')}
|
|
|
|
</TradingButton>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2023-08-02 15:34:04 +00:00
|
|
|
return null;
|
|
|
|
};
|
2023-08-25 17:52:52 +00:00
|
|
|
|
|
|
|
const Step = ({
|
|
|
|
step,
|
|
|
|
text,
|
|
|
|
complete,
|
|
|
|
}: {
|
|
|
|
step: number;
|
|
|
|
text: string;
|
|
|
|
complete: boolean;
|
|
|
|
}) => {
|
|
|
|
return (
|
|
|
|
<li
|
|
|
|
className={classNames('flex', {
|
|
|
|
'text-vega-clight-200 dark:text-vega-cdark-200': complete,
|
|
|
|
})}
|
|
|
|
>
|
|
|
|
<div className="flex justify-center w-5">
|
|
|
|
{complete ? <Tick /> : <span>{step}.</span>}
|
|
|
|
</div>
|
|
|
|
<div className="ml-1">{text}</div>
|
|
|
|
</li>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const Tick = () => {
|
|
|
|
return (
|
|
|
|
<span className="relative right-[2px]">
|
|
|
|
<VegaIcon name={VegaIconNames.TICK} size={18} />
|
|
|
|
</span>
|
|
|
|
);
|
|
|
|
};
|