import { OrderedSet as ImmutableOrderedSet, is } from 'immutable'; import React, { useState } from 'react'; import { useEffect } from 'react'; import { defineMessages, useIntl } from 'react-intl'; import { Link } from 'react-router-dom'; import { fetchUsers } from 'soapbox/actions/admin'; import compareId from 'soapbox/compare_id'; import { Text, Widget } from 'soapbox/components/ui'; import AccountContainer from 'soapbox/containers/account_container'; import { useAppSelector } from 'soapbox/hooks'; import { useAppDispatch } from 'soapbox/hooks'; const messages = defineMessages({ title: { id: 'admin.latest_accounts_panel.title', defaultMessage: 'Latest Accounts' }, expand: { id: 'admin.latest_accounts_panel.expand_message', defaultMessage: 'Click to see {count} more {count, plural, one {account} other {accounts}}' }, }); interface ILatestAccountsPanel { limit?: number, } const LatestAccountsPanel: React.FC = ({ limit = 5 }) => { const dispatch = useAppDispatch(); const intl = useIntl(); const accountIds = useAppSelector>((state) => state.admin.get('latestUsers').take(limit)); const hasDates = useAppSelector((state) => accountIds.every(id => !!state.accounts.getIn([id, 'created_at']))); const [total, setTotal] = useState(accountIds.size); useEffect(() => { dispatch(fetchUsers(['local', 'active'], 1, null, limit)) .then((value) => { setTotal((value as { count: number }).count); }) .catch(() => {}); }, []); const sortedIds = accountIds.sort(compareId).reverse(); const isSorted = hasDates && is(accountIds, sortedIds); if (!isSorted || !accountIds || accountIds.isEmpty()) { return null; } const expandCount = total - accountIds.size; return ( {accountIds.take(limit).map((account) => ( ))} {!!expandCount && ( {intl.formatMessage(messages.expand, { count: expandCount })} )} ); }; export default LatestAccountsPanel;