import React, { useEffect } from 'react'; import { defineMessages, FormattedMessage, useIntl } from 'react-intl'; import { setupListEditor, resetListEditor } from 'soapbox/actions/lists'; import { CardHeader, CardTitle, Modal } from 'soapbox/components/ui'; import { useAppSelector, useAppDispatch } from 'soapbox/hooks'; import Account from './components/account'; import EditListForm from './components/edit-list-form'; import Search from './components/search'; const messages = defineMessages({ close: { id: 'lightbox.close', defaultMessage: 'Close' }, changeTitle: { id: 'lists.edit.submit', defaultMessage: 'Change title' }, addToList: { id: 'lists.account.add', defaultMessage: 'Add to list' }, removeFromList: { id: 'lists.account.remove', defaultMessage: 'Remove from list' }, editList: { id: 'lists.edit', defaultMessage: 'Edit list' }, }); interface IListEditor { listId: string onClose: (type: string) => void } const ListEditor: React.FC = ({ listId, onClose }) => { const intl = useIntl(); const dispatch = useAppDispatch(); const accountIds = useAppSelector((state) => state.listEditor.accounts.items); const searchAccountIds = useAppSelector((state) => state.listEditor.suggestions.items); useEffect(() => { dispatch(setupListEditor(listId)); return () => { dispatch(resetListEditor()); }; }, []); const onClickClose = () => { onClose('LIST_ADDER'); }; return ( } onClose={onClickClose} >
{accountIds.size > 0 && (
{accountIds.map(accountId => )}
)}
{searchAccountIds.map(accountId => )}
); }; export default ListEditor;