import React, { useState, useEffect, useRef } from 'react'; import { FormattedMessage } from 'react-intl'; import api from 'soapbox/api'; import { Modal, Stack, Text, Input } from 'soapbox/components/ui'; import { useAppDispatch } from 'soapbox/hooks'; import type { RootState } from 'soapbox/store'; const fetchEmbed = (url: string) => { return (dispatch: any, getState: () => RootState) => { return api(getState).get('/api/oembed', { params: { url } }); }; }; interface IEmbedModal { url: string, onError: (error: any) => void, } const EmbedModal: React.FC = ({ url, onError }) => { const dispatch = useAppDispatch(); const iframe = useRef(null); const [oembed, setOembed] = useState(null); useEffect(() => { dispatch(fetchEmbed(url)).then(({ data }) => { if (!iframe.current?.contentWindow) return; setOembed(data); const iframeDocument = iframe.current.contentWindow.document; iframeDocument.open(); iframeDocument.write(data.html); iframeDocument.close(); const innerFrame = iframeDocument.querySelector('iframe'); iframeDocument.body.style.margin = '0'; if (innerFrame) { innerFrame.width = '100%'; } }).catch(error => { onError(error); }); }, [!!iframe.current]); const handleInputClick: React.MouseEventHandler = (e) => { e.currentTarget.select(); }; return ( }>