TelegramPWA/src/components/main/SafeLinkModal.tsx

46 lines
1.3 KiB
TypeScript

import type { FC } from '../../lib/teact/teact';
import React, { memo, useCallback } from '../../lib/teact/teact';
import { getActions } from '../../global';
import { ensureProtocol } from '../../util/ensureProtocol';
import renderText from '../common/helpers/renderText';
import useCurrentOrPrev from '../../hooks/useCurrentOrPrev';
import useOldLang from '../../hooks/useOldLang';
import ConfirmDialog from '../ui/ConfirmDialog';
export type OwnProps = {
url?: string;
};
const SafeLinkModal: FC<OwnProps> = ({ url }) => {
const { toggleSafeLinkModal } = getActions();
const lang = useOldLang();
const handleOpen = useCallback(() => {
window.open(ensureProtocol(url), '_blank', 'noopener');
toggleSafeLinkModal({ url: undefined });
}, [toggleSafeLinkModal, url]);
const handleDismiss = useCallback(() => {
toggleSafeLinkModal({ url: undefined });
}, [toggleSafeLinkModal]);
const renderingUrl = useCurrentOrPrev(url);
return (
<ConfirmDialog
isOpen={Boolean(url)}
onClose={handleDismiss}
title={lang('OpenUrlTitle')}
textParts={renderText(lang('OpenUrlAlert2', renderingUrl), ['links'])}
confirmLabel={lang('OpenUrlTitle')}
confirmHandler={handleOpen}
/>
);
};
export default memo(SafeLinkModal);