import { debounce } from 'lodash'; import React, { useEffect } from 'react'; import { defineMessages, FormattedMessage, useIntl } from 'react-intl'; import { fetchScheduledStatuses, expandScheduledStatuses } from 'soapbox/actions/scheduled_statuses'; import ScrollableList from 'soapbox/components/scrollable_list'; import { useAppSelector, useAppDispatch } from 'soapbox/hooks'; import Column from '../ui/components/column'; import ScheduledStatus from './components/scheduled_status'; const messages = defineMessages({ heading: { id: 'column.scheduled_statuses', defaultMessage: 'Scheduled Posts' }, }); const handleLoadMore = debounce((dispatch) => { dispatch(expandScheduledStatuses()); }, 300, { leading: true }); const ScheduledStatuses = () => { const intl = useIntl(); const dispatch = useAppDispatch(); const statusIds = useAppSelector((state) => state.status_lists.getIn(['scheduled_statuses', 'items'])); const isLoading = useAppSelector((state) => state.status_lists.getIn(['scheduled_statuses', 'isLoading'])); const hasMore = useAppSelector((state) => !!state.status_lists.getIn(['scheduled_statuses', 'next'])); useEffect(() => { dispatch(fetchScheduledStatuses()); }, []); const emptyMessage = ; return ( handleLoadMore(dispatch)} emptyMessage={emptyMessage} > {statusIds.map((id: string) => )} ); }; export default ScheduledStatuses;