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 CircleIcon from '@/material-icons/400-24px/account_circle.svg?react'; import AddIcon from '@/material-icons/400-24px/add.svg?react'; import MoreHorizIcon from '@/material-icons/400-24px/more_horiz.svg?react'; import SquigglyArrow from '@/svg-icons/squiggly_arrow.svg?react'; import { fetchCircles } from 'mastodon/actions/circles'; import { openModal } from 'mastodon/actions/modal'; import { Column } from 'mastodon/components/column'; import { ColumnHeader } from 'mastodon/components/column_header'; import { Dropdown } from 'mastodon/components/dropdown_menu'; import { Icon } from 'mastodon/components/icon'; import ScrollableList from 'mastodon/components/scrollable_list'; import { getOrderedCircles } from 'mastodon/selectors/circles'; import { useAppSelector, useAppDispatch } from 'mastodon/store'; const messages = defineMessages({ heading: { id: 'column.circles', defaultMessage: 'Circles' }, create: { id: 'circles.create_circle', defaultMessage: 'Create circle' }, edit: { id: 'circles.edit', defaultMessage: 'Edit circle' }, delete: { id: 'circles.delete', defaultMessage: 'Delete circle' }, more: { id: 'status.more', defaultMessage: 'More' }, }); const CircleItem: React.FC<{ id: string; title: string; }> = ({ id, title }) => { const dispatch = useAppDispatch(); const intl = useIntl(); const handleDeleteClick = useCallback(() => { dispatch( openModal({ modalType: 'CONFIRM_DELETE_CIRCLE', modalProps: { circleId: id, }, }), ); }, [dispatch, id]); const menu = useMemo( () => [ { text: intl.formatMessage(messages.edit), to: `/circles/${id}/edit` }, { text: intl.formatMessage(messages.delete), action: handleDeleteClick }, ], [intl, id, handleDeleteClick], ); return (
{title}
); }; const Circles: React.FC<{ multiColumn?: boolean; }> = ({ multiColumn }) => { const dispatch = useAppDispatch(); const intl = useIntl(); const circles = useAppSelector((state) => getOrderedCircles(state)); useEffect(() => { dispatch(fetchCircles()); }, [dispatch]); const emptyMessage = ( <>
); return ( } /> {circles.map((circle) => ( ))} {intl.formatMessage(messages.heading)} ); }; // eslint-disable-next-line import/no-default-export export default Circles;