import React, { useEffect } from 'react'; import { FormattedMessage } from 'react-intl'; import { fetchReblogs } from 'soapbox/actions/interactions'; import { fetchStatus } from 'soapbox/actions/statuses'; import ScrollableList from 'soapbox/components/scrollable_list'; import { Modal, Spinner } from 'soapbox/components/ui'; import AccountContainer from 'soapbox/containers/account_container'; import { useAppDispatch, useAppSelector } from 'soapbox/hooks'; interface IReblogsModal { onClose: (string: string) => void, statusId: string, } const ReblogsModal: React.FC = ({ onClose, statusId }) => { const dispatch = useAppDispatch(); const accountIds = useAppSelector((state) => state.user_lists.getIn(['reblogged_by', statusId])); const fetchData = () => { dispatch(fetchReblogs(statusId)); dispatch(fetchStatus(statusId)); }; useEffect(() => { fetchData(); }, []); const onClickClose = () => { onClose('REBLOGS'); }; let body; if (!accountIds) { body = ; } else { const emptyMessage = ; body = ( {accountIds.map((id: string) => , )} ); } return ( } onClose={onClickClose} > {body} ); }; export default ReblogsModal;