import { List as ImmutableList } from 'immutable'; import React, { useEffect, useState } from 'react'; import { FormattedMessage, defineMessages, useIntl } from 'react-intl'; import { fetchFavourites, fetchReactions } from 'soapbox/actions/interactions'; import ScrollableList from 'soapbox/components/scrollable-list'; import { Emoji, Modal, Spinner, Tabs } from 'soapbox/components/ui'; import AccountContainer from 'soapbox/containers/account-container'; import { useAppDispatch, useAppSelector } from 'soapbox/hooks'; import { ReactionRecord } from 'soapbox/reducers/user_lists'; import type { Item } from 'soapbox/components/ui/tabs/tabs'; const messages = defineMessages({ close: { id: 'lightbox.close', defaultMessage: 'Close' }, all: { id: 'reactions.all', defaultMessage: 'All' }, }); interface IReactionsModal { onClose: (string: string) => void, statusId: string, reaction?: string, } const ReactionsModal: React.FC = ({ onClose, statusId, reaction: initialReaction }) => { const dispatch = useAppDispatch(); const intl = useIntl(); const [reaction, setReaction] = useState(initialReaction); const reactions = useAppSelector> | undefined>((state) => { const favourites = state.user_lists.favourited_by.get(statusId)?.items; const reactions = state.user_lists.reactions.get(statusId)?.items; return favourites && reactions && ImmutableList(favourites?.size ? [ReactionRecord({ accounts: favourites, count: favourites.size, name: '👍' })] : []).concat(reactions || []); }); const fetchData = () => { dispatch(fetchFavourites(statusId)); dispatch(fetchReactions(statusId)); }; const onClickClose = () => { onClose('REACTIONS'); }; const renderFilterBar = () => { const items: Array = [ { text: intl.formatMessage(messages.all), action: () => setReaction(''), name: 'all', }, ]; reactions!.forEach(reaction => items.push( { text:
{reaction.count}
, action: () => setReaction(reaction.name), name: reaction.name, }, )); return ; }; useEffect(() => { fetchData(); }, []); const accounts = reactions && (reaction ? reactions.find(({ name }) => name === reaction)?.accounts.map(account => ({ id: account, reaction: reaction })) : reactions.map(({ accounts, name }) => accounts.map(account => ({ id: account, reaction: name }))).flatten()) as ImmutableList<{ id: string, reaction: string }>; let body; if (!accounts) { body = ; } else { const emptyMessage = ; body = (<> {reactions.size > 0 && renderFilterBar()} {accounts.map((account) => , )} ); } return ( } onClose={onClickClose} > {body} ); }; export default ReactionsModal;