import { useEffect, useMemo, useCallback } from 'react'; import { defineMessages, useIntl, FormattedMessage } from 'react-intl'; import { Helmet } from 'react-helmet'; import { Link } from 'react-router-dom'; import AddIcon from '@/material-icons/400-24px/add.svg?react'; import ListAltIcon from '@/material-icons/400-24px/list_alt.svg?react'; import MoreHorizIcon from '@/material-icons/400-24px/more_horiz.svg?react'; import SquigglyArrow from '@/svg-icons/squiggly_arrow.svg?react'; import { fetchLists } from 'mastodon/actions/lists'; import { openModal } from 'mastodon/actions/modal'; import { Column } from 'mastodon/components/column'; import { ColumnHeader } from 'mastodon/components/column_header'; import { Icon } from 'mastodon/components/icon'; import ScrollableList from 'mastodon/components/scrollable_list'; import DropdownMenuContainer from 'mastodon/containers/dropdown_menu_container'; import { getOrderedLists } from 'mastodon/selectors/lists'; import { useAppSelector, useAppDispatch } from 'mastodon/store'; const messages = defineMessages({ heading: { id: 'column.lists', defaultMessage: 'Lists' }, create: { id: 'lists.create_list', defaultMessage: 'Create list' }, edit: { id: 'lists.edit', defaultMessage: 'Edit list' }, delete: { id: 'lists.delete', defaultMessage: 'Delete list' }, more: { id: 'status.more', defaultMessage: 'More' }, }); const ListItem: React.FC<{ id: string; title: string; }> = ({ id, title }) => { const dispatch = useAppDispatch(); const intl = useIntl(); const handleDeleteClick = useCallback(() => { dispatch( openModal({ modalType: 'CONFIRM_DELETE_LIST', modalProps: { listId: id, }, }), ); }, [dispatch, id]); const menu = useMemo( () => [ { text: intl.formatMessage(messages.edit), to: `/lists/${id}/edit` }, { text: intl.formatMessage(messages.delete), action: handleDeleteClick }, ], [intl, id, handleDeleteClick], ); return (
{title}
); }; const Lists: React.FC<{ multiColumn?: boolean; }> = ({ multiColumn }) => { const dispatch = useAppDispatch(); const intl = useIntl(); const lists = useAppSelector((state) => getOrderedLists(state)); useEffect(() => { dispatch(fetchLists()); }, [dispatch]); const emptyMessage = ( <>
); return ( } /> {lists.map((list) => ( ))} {intl.formatMessage(messages.heading)} ); }; // eslint-disable-next-line import/no-default-export export default Lists;