import type { Toast } from '@vegaprotocol/ui-toolkit'; import { Intent, useToasts } from '@vegaprotocol/ui-toolkit'; import { useTelemetryApproval } from '../../lib/hooks/use-telemetry-approval'; import { useCallback, useEffect } from 'react'; import { TelemetryApproval } from './telemetry-approval'; import { useOnboardingStore } from '../../stores/onboarding'; import { useT } from '../../lib/use-t'; const TELEMETRY_APPROVAL_TOAST_ID = 'telemetry_toast_id'; export const Telemetry = () => { const t = useT(); const onboardingDissmissed = useOnboardingStore((store) => store.dismissed); const [telemetryValue, setTelemetryValue, isTelemetryNeeded, closeTelemetry] = useTelemetryApproval(); const [setToast, hasToast, removeToast] = useToasts((store) => [ store.setToast, store.hasToast, store.remove, ]); const onApprovalClose = useCallback(() => { closeTelemetry(); removeToast(TELEMETRY_APPROVAL_TOAST_ID); }, [closeTelemetry, removeToast]); const setTelemetryApprovalAndClose = useCallback( (value: string) => { setTelemetryValue(value); onApprovalClose(); }, [onApprovalClose, setTelemetryValue] ); useEffect(() => { if (isTelemetryNeeded && onboardingDissmissed) { const toast: Toast = { id: TELEMETRY_APPROVAL_TOAST_ID, intent: Intent.Primary, content: ( <>

{t('Improve vega console')}

), onClose: onApprovalClose, }; if (!hasToast(TELEMETRY_APPROVAL_TOAST_ID)) { setToast(toast); } return; } }, [ telemetryValue, isTelemetryNeeded, onboardingDissmissed, setToast, hasToast, onApprovalClose, setTelemetryApprovalAndClose, t, ]); return null; };