import classNames from 'classnames';
import { t } from '@vegaprotocol/i18n';
import {
ExternalLink,
Intent,
TradingAnchorButton,
TradingButton,
VegaIcon,
VegaIconNames,
} from '@vegaprotocol/ui-toolkit';
import { useVegaWallet, useVegaWalletDialogStore } from '@vegaprotocol/wallet';
import { Networks, useEnvironment } from '@vegaprotocol/environment';
import {
OnboardingStep,
useGetOnboardingStep,
useOnboardingStore,
} from './use-get-onboarding-step';
import { Links, Routes } from '../../lib/links';
import { useGlobalStore } from '../../stores';
import { useSidebar, ViewType } from '../sidebar';
interface Props {
lead?: string;
}
const GetStartedButton = ({ step }: { step: OnboardingStep }) => {
const dismiss = useOnboardingStore((store) => store.dismiss);
const setDialogOpen = useOnboardingStore((store) => store.setDialogOpen);
const marketId = useGlobalStore((store) => store.marketId);
const setWalletDialogOpen = useOnboardingStore(
(store) => store.setWalletDialogOpen
);
const setViews = useSidebar((store) => store.setViews);
const buttonProps = {
size: 'small' as const,
'data-testid': 'get-started-button',
intent: Intent.Info,
};
if (step <= OnboardingStep.ONBOARDING_CONNECT_STEP) {
return (
setWalletDialogOpen(true)}>
{t('Connect')}
);
} else if (step === OnboardingStep.ONBOARDING_DEPOSIT_STEP) {
return (
setDialogOpen(false)}
>
{t('Deposit')}
);
} else if (step >= OnboardingStep.ONBOARDING_ORDER_STEP) {
const link = marketId ? Links.MARKET(marketId) : Links.HOME();
return (
{
setViews({ type: ViewType.Order }, Routes.MARKET);
dismiss();
}}
>
{t('Ready to trade')}
);
}
return (
setWalletDialogOpen(true)}>
{t('Get started')}
);
};
export const GetStartedCheckList = () => {
const { pubKey } = useVegaWallet();
const currentStep = useGetOnboardingStep();
return (
OnboardingStep.ONBOARDING_CONNECT_STEP || pubKey
)}
/>
OnboardingStep.ONBOARDING_DEPOSIT_STEP}
/>
OnboardingStep.ONBOARDING_ORDER_STEP}
/>
);
};
export const GetStarted = ({ lead }: Props) => {
const { pubKey } = useVegaWallet();
const { VEGA_ENV, VEGA_NETWORKS } = useEnvironment();
const openVegaWalletDialog = useVegaWalletDialogStore(
(store) => store.openVegaWalletDialog
);
const currentStep = useGetOnboardingStep();
const dismissed = useOnboardingStore((store) => store.dismissed);
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 }
);
if (!dismissed) {
return (
{lead &&
{lead}
}
{t('Get started')}
{VEGA_ENV === Networks.MAINNET && (
{t('Experiment for free with virtual assets on')}{' '}
{t('Fairground Testnet')}
)}
{VEGA_ENV === Networks.TESTNET && (
{t('Ready to trade with real funds?')}{' '}
{t('Switch to Mainnet')}
)}
);
}
if (!pubKey) {
return (
You need a{' '}
Vega wallet
{' '}
to start trading in this market.
{t('Connect wallet')}
);
}
return null;
};
const Step = ({
step,
text,
complete,
}: {
step: number;
text: string;
complete: boolean;
}) => {
return (
{complete ? : {step}.}
{text}
);
};
const Tick = () => {
return (
);
};