// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import type { ReactElement } from 'react'; import React, { useCallback, useState } from 'react'; import type { LocalizerType } from '../../types/Util'; import { Button, ButtonSize, ButtonVariant } from '../Button'; import { SystemMessage } from './SystemMessage'; import { ChatSessionRefreshedDialog } from './ChatSessionRefreshedDialog'; import { openLinkInWebBrowser } from '../../util/openLinkInWebBrowser'; import { mapToSupportLocale } from '../../util/mapToSupportLocale'; type PropsHousekeepingType = { i18n: LocalizerType; }; export type PropsType = PropsHousekeepingType; export function ChatSessionRefreshedNotification( props: PropsType ): ReactElement { const { i18n } = props; const [isDialogOpen, setIsDialogOpen] = useState(false); const openDialog = useCallback(() => { setIsDialogOpen(true); }, [setIsDialogOpen]); const closeDialog = useCallback(() => { setIsDialogOpen(false); }, [setIsDialogOpen]); const wrappedContactSupport = useCallback(() => { setIsDialogOpen(false); const baseUrl = 'https://support.signal.org/hc/LOCALE/requests/new?desktop&chat_refreshed'; const locale = window.SignalContext.getResolvedMessagesLocale(); const supportLocale = mapToSupportLocale(locale); const url = baseUrl.replace('LOCALE', supportLocale); openLinkInWebBrowser(url); }, [setIsDialogOpen]); return ( <> {i18n('icu:ChatRefresh--learnMore')} } icon="session-refresh" /> {isDialogOpen ? ( ) : null} ); }