// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React, { useRef, useState } from 'react'; import type { LocalizerType } from '../types/Util'; import { Button, ButtonVariant } from './Button'; import { Modal } from './Modal'; import { Spinner } from './Spinner'; export type PropsType = Readonly<{ i18n: LocalizerType; isPending: boolean; onContinue: () => void; onSkip: () => void; }>; export function CaptchaDialog({ i18n, isPending, onSkip, onContinue, }: PropsType): JSX.Element { const [isClosing, setIsClosing] = useState(false); const buttonRef = useRef(null); const onCancelClick = (event: React.MouseEvent) => { event.preventDefault(); setIsClosing(false); }; const onSkipClick = (event: React.MouseEvent) => { event.preventDefault(); onSkip(); }; if (isClosing && !isPending) { const footer = ( <> ); return ( setIsClosing(false)} key="skip" modalFooter={footer} >

{i18n('icu:CaptchaDialog--can-close__body')}

); } const onContinueClick = (event: React.MouseEvent) => { event.preventDefault(); onContinue(); }; const updateButtonRef = (button: HTMLButtonElement): void => { buttonRef.current = button; if (button) { button.focus(); } }; const footer = ( ); return ( setIsClosing(true)} key="primary" modalFooter={footer} >

{i18n('icu:CaptchaDialog__first-paragraph')}

{i18n('icu:CaptchaDialog__second-paragraph')}

); }