import { TradingButton as Button, Dialog, Intent, Tooltip, VegaIcon, VegaIconNames, } from '@vegaprotocol/ui-toolkit'; import { useSimpleTransaction, useVegaWallet, } from '@vegaprotocol/wallet-react'; import { useT } from '../../lib/use-t'; import { type Team } from '../../lib/hooks/use-team'; import { useState } from 'react'; type JoinType = 'switch' | 'join'; export const JoinTeam = ({ team, partyTeam, refetch, }: { team: Team; partyTeam?: Team; refetch: () => void; }) => { const { pubKey, isReadOnly } = useVegaWallet(); const [confirmDialog, setConfirmDialog] = useState(); return ( <> setConfirmDialog(undefined)} > {confirmDialog !== undefined && ( setConfirmDialog(undefined)} refetch={refetch} /> )} ); }; export const JoinButton = ({ pubKey, isReadOnly, team, partyTeam, onJoin, }: { pubKey: string | undefined; isReadOnly: boolean; team: Team; partyTeam?: Team; onJoin: (type: JoinType) => void; }) => { const t = useT(); /** * A team cannot be joined (closed) when set as such * and the currently connected pubkey is not whitelisted. */ const isTeamClosed = team.closed && !team.allowList.includes(pubKey || ''); if (!pubKey || isReadOnly) { return ( ); } // Party is the creator of a team if (partyTeam && partyTeam.referrer === pubKey) { // Party is the creator of THIS team if (partyTeam.teamId === team.teamId) { return ( ); } else { // Not creator of the team, but still can't switch because // creators cannot leave their own team return ( ); } } // Party is in a team, but not this one if (partyTeam && partyTeam.teamId !== team.teamId) { // This team is closed. if (isTeamClosed) { return ( ); } // This team is open. return ( ); } // Joined. Current party is already in this team if (partyTeam && partyTeam.teamId === team.teamId) { return ( ); } // This team is closed. if (isTeamClosed) { return ( ); } // This team is open. return ( ); }; const DialogContent = ({ type, team, partyTeam, onCancel, refetch, }: { type: JoinType; team: Team; partyTeam?: Team; onCancel: () => void; refetch: () => void; }) => { const t = useT(); const { send, status, error } = useSimpleTransaction({ onSuccess: refetch, }); const joinTeam = () => { send({ joinTeam: { id: team.teamId, }, }); }; if (error) { return (

{error}

); } if (status === 'requested') { return

{t('Confirm in wallet...')}

; } if (status === 'pending') { return

{t('Confirming transaction...')}

; } if (status === 'confirmed') { if (type === 'switch') { return (

{t( 'Team switch successful. You will switch team at the end of the epoch.' )}

); } return

{t('Team joined')}

; } return (
{type === 'switch' && ( <>

{t('Switch team')}

{t( "Switching team will move you from '{{fromTeam}}' to '{{toTeam}}' at the end of the epoch. Are you sure?", { fromTeam: partyTeam?.name, toTeam: team.name, } )}

)} {type === 'join' && ( <>

{t('Join team')}

{t('Are you sure you want to join team: {{team}}', { team: team.name, })}

)}
); };