2022-11-27 14:29:45 -08:00
|
|
|
import React, { useEffect } from 'react';
|
2022-11-26 13:15:58 -08:00
|
|
|
import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
|
2022-11-26 11:13:14 -08:00
|
|
|
|
2022-11-26 13:15:58 -08:00
|
|
|
import { fetchJoinedEvents, fetchRecentEvents } from 'soapbox/actions/events';
|
|
|
|
import { openModal } from 'soapbox/actions/modals';
|
|
|
|
import { Button, CardBody, CardHeader, CardTitle, Column, HStack } from 'soapbox/components/ui';
|
|
|
|
import { useAppDispatch, useAppSelector } from 'soapbox/hooks';
|
|
|
|
|
|
|
|
import EventCarousel from './components/event-carousel';
|
2022-11-26 11:13:14 -08:00
|
|
|
|
|
|
|
const messages = defineMessages({
|
|
|
|
title: { id: 'column.events', defaultMessage: 'Events' },
|
|
|
|
});
|
|
|
|
|
|
|
|
const Events = () => {
|
|
|
|
const intl = useIntl();
|
|
|
|
|
2022-11-26 13:15:58 -08:00
|
|
|
const dispatch = useAppDispatch();
|
|
|
|
|
|
|
|
const recentEvents = useAppSelector((state) => state.status_lists.get('recent_events')!.items);
|
|
|
|
const recentEventsLoading = useAppSelector((state) => state.status_lists.get('recent_events')!.isLoading);
|
|
|
|
const joinedEvents = useAppSelector((state) => state.status_lists.get('joined_events')!.items);
|
|
|
|
const joinedEventsLoading = useAppSelector((state) => state.status_lists.get('joined_events')!.isLoading);
|
|
|
|
|
|
|
|
const onComposeEvent = () => {
|
|
|
|
dispatch(openModal('COMPOSE_EVENT'));
|
|
|
|
};
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
dispatch(fetchRecentEvents());
|
|
|
|
dispatch(fetchJoinedEvents());
|
|
|
|
}, []);
|
|
|
|
|
2022-11-26 11:13:14 -08:00
|
|
|
return (
|
2022-11-26 13:15:58 -08:00
|
|
|
<Column label={intl.formatMessage(messages.title)}>
|
2023-08-14 13:37:42 -07:00
|
|
|
<HStack className='mb-2' space={2} justifyContent='between'>
|
2022-12-14 15:35:40 -08:00
|
|
|
<CardTitle title={<FormattedMessage id='events.recent_events' defaultMessage='Recent events' />} />
|
2022-11-26 13:15:58 -08:00
|
|
|
<Button
|
2023-02-05 14:14:21 -08:00
|
|
|
className='ml-auto xl:hidden'
|
2022-11-26 13:15:58 -08:00
|
|
|
theme='primary'
|
|
|
|
size='sm'
|
|
|
|
onClick={onComposeEvent}
|
|
|
|
>
|
2022-12-14 15:35:40 -08:00
|
|
|
<FormattedMessage id='events.create_event' defaultMessage='Create event' />
|
2022-11-26 13:15:58 -08:00
|
|
|
</Button>
|
|
|
|
</HStack>
|
|
|
|
<CardBody className='mb-2'>
|
|
|
|
<EventCarousel
|
|
|
|
statusIds={recentEvents}
|
|
|
|
isLoading={recentEventsLoading}
|
|
|
|
emptyMessage={<FormattedMessage id='events.recent_events.empty' defaultMessage='There are no public events yet.' />}
|
|
|
|
/>
|
|
|
|
</CardBody>
|
2023-08-14 13:37:42 -07:00
|
|
|
<CardHeader className='mb-2'>
|
2022-12-14 15:35:40 -08:00
|
|
|
<CardTitle title={<FormattedMessage id='events.joined_events' defaultMessage='Joined events' />} />
|
2022-11-26 13:15:58 -08:00
|
|
|
</CardHeader>
|
|
|
|
<CardBody>
|
|
|
|
<EventCarousel
|
|
|
|
statusIds={joinedEvents}
|
|
|
|
isLoading={joinedEventsLoading}
|
|
|
|
emptyMessage={<FormattedMessage id='events.joined_events.empty' defaultMessage="You haven't joined any event yet." />}
|
|
|
|
/>
|
|
|
|
</CardBody>
|
|
|
|
</Column>
|
2022-11-26 11:13:14 -08:00
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default Events;
|