68 lines
2.3 KiB
TypeScript
68 lines
2.3 KiB
TypeScript
import React, { useEffect } from 'react';
|
|
import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
|
|
|
|
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';
|
|
|
|
const messages = defineMessages({
|
|
title: { id: 'column.events', defaultMessage: 'Events' },
|
|
});
|
|
|
|
const Events = () => {
|
|
const intl = useIntl();
|
|
|
|
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());
|
|
}, []);
|
|
|
|
return (
|
|
<Column label={intl.formatMessage(messages.title)}>
|
|
<HStack className='mb-4' space={2} justifyContent='between'>
|
|
<CardTitle title='Recent events' />
|
|
<Button
|
|
className='ml-auto'
|
|
theme='primary'
|
|
size='sm'
|
|
onClick={onComposeEvent}
|
|
>
|
|
Create event
|
|
</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>
|
|
<CardHeader>
|
|
<CardTitle title='Joined events' />
|
|
</CardHeader>
|
|
<CardBody>
|
|
<EventCarousel
|
|
statusIds={joinedEvents}
|
|
isLoading={joinedEventsLoading}
|
|
emptyMessage={<FormattedMessage id='events.joined_events.empty' defaultMessage="You haven't joined any event yet." />}
|
|
/>
|
|
</CardBody>
|
|
</Column>
|
|
);
|
|
};
|
|
|
|
export default Events;
|