76 lines
2.3 KiB
TypeScript
76 lines
2.3 KiB
TypeScript
import { Map as ImmutableMap } from 'immutable';
|
|
import * as React from 'react';
|
|
import { useDispatch } from 'react-redux';
|
|
|
|
import { Button, Card, CardBody, Stack, Text } from 'soapbox/components/ui';
|
|
import AccountContainer from 'soapbox/containers/account_container';
|
|
import { useAppSelector } from 'soapbox/hooks';
|
|
|
|
import { fetchSuggestions } from '../../../actions/suggestions';
|
|
|
|
const SuggestedAccountsStep = ({ onNext }: { onNext: () => void }) => {
|
|
const dispatch = useDispatch();
|
|
|
|
const suggestions = useAppSelector((state) => state.suggestions.get('items'));
|
|
const suggestionsToRender = suggestions.slice(0, 5);
|
|
|
|
React.useEffect(() => {
|
|
dispatch(fetchSuggestions());
|
|
}, []);
|
|
|
|
if (suggestionsToRender.isEmpty()) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<Card variant='rounded' size='xl'>
|
|
<CardBody>
|
|
<div>
|
|
<div className='pb-4 sm:pb-10 mb-4 border-b border-gray-200 border-solid -mx-4 sm:-mx-10'>
|
|
<Stack space={2}>
|
|
<Text size='2xl' align='center' weight='bold'>
|
|
Suggested accounts
|
|
</Text>
|
|
|
|
<Text theme='muted' align='center'>
|
|
Here are a few of the most popular accounts you might like.
|
|
</Text>
|
|
</Stack>
|
|
</div>
|
|
|
|
<div className='sm:pt-4 sm:pb-10 flex flex-col divide-y divide-solid divide-gray-200'>
|
|
{suggestionsToRender.map((suggestion: ImmutableMap<string, any>) => (
|
|
<div key={suggestion.get('account')} className='py-2'>
|
|
<AccountContainer
|
|
// @ts-ignore: TS thinks `id` is passed to <Account>, but it isn't
|
|
id={suggestion.get('account')}
|
|
showProfileHoverCard={false}
|
|
/>
|
|
</div>
|
|
))}
|
|
</div>
|
|
|
|
<div className='sm:w-2/3 md:w-1/2 mx-auto'>
|
|
<Stack>
|
|
|
|
|
|
<Stack justifyContent='center' space={2}>
|
|
<Button
|
|
block
|
|
theme='primary'
|
|
onClick={onNext}
|
|
>
|
|
Done
|
|
</Button>
|
|
|
|
<Button block theme='link' type='button' onClick={onNext}>Skip for now</Button>
|
|
</Stack>
|
|
</Stack>
|
|
</div>
|
|
</div>
|
|
</CardBody>
|
|
</Card>
|
|
);
|
|
};
|
|
|
|
export default SuggestedAccountsStep;
|