109 lines
3.4 KiB
TypeScript
109 lines
3.4 KiB
TypeScript
import debounce from 'lodash/debounce';
|
|
import React from 'react';
|
|
import { FormattedMessage } from 'react-intl';
|
|
|
|
import ScrollableList from 'soapbox/components/scrollable-list';
|
|
import { Button, Card, CardBody, Stack, Text } from 'soapbox/components/ui';
|
|
import AccountContainer from 'soapbox/containers/account-container';
|
|
import { useOnboardingSuggestions } from 'soapbox/queries/suggestions';
|
|
|
|
const SuggestedAccountsStep = ({ onNext }: { onNext: () => void }) => {
|
|
const { data, fetchNextPage, hasNextPage, isFetching } = useOnboardingSuggestions();
|
|
|
|
const handleLoadMore = debounce(() => {
|
|
if (isFetching) {
|
|
return null;
|
|
}
|
|
|
|
return fetchNextPage();
|
|
}, 300);
|
|
|
|
const renderSuggestions = () => {
|
|
if (!data) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<div className='flex flex-col sm:pb-10 sm:pt-4'>
|
|
<ScrollableList
|
|
isLoading={isFetching}
|
|
scrollKey='suggestions'
|
|
onLoadMore={handleLoadMore}
|
|
hasMore={hasNextPage}
|
|
useWindowScroll={false}
|
|
style={{ height: 320 }}
|
|
>
|
|
{data.map((suggestion) => (
|
|
<div key={suggestion.account.id} className='py-2'>
|
|
<AccountContainer
|
|
id={suggestion.account.id}
|
|
showProfileHoverCard={false}
|
|
withLinkToProfile={false}
|
|
/>
|
|
</div>
|
|
))}
|
|
</ScrollableList>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
const renderEmpty = () => {
|
|
return (
|
|
<div className='my-2 rounded-lg bg-primary-50 p-8 text-center dark:bg-gray-800'>
|
|
<Text>
|
|
<FormattedMessage id='empty_column.follow_recommendations' defaultMessage='Looks like no suggestions could be generated for you. You can try using search to look for people you might know or explore trending hashtags.' />
|
|
</Text>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
const renderBody = () => {
|
|
if (!data || data.length === 0) {
|
|
return renderEmpty();
|
|
} else {
|
|
return renderSuggestions();
|
|
}
|
|
};
|
|
|
|
return (
|
|
<Card variant='rounded' size='xl'>
|
|
<CardBody>
|
|
<div>
|
|
<div className='-mx-4 mb-4 border-b border-solid border-gray-200 pb-4 dark:border-gray-800 sm:-mx-10 sm:pb-10'>
|
|
<Stack space={2}>
|
|
<Text size='2xl' align='center' weight='bold'>
|
|
<FormattedMessage id='onboarding.suggestions.title' defaultMessage='Suggested accounts' />
|
|
</Text>
|
|
|
|
<Text theme='muted' align='center'>
|
|
<FormattedMessage id='onboarding.suggestions.subtitle' defaultMessage='Here are a few of the most popular accounts you might like.' />
|
|
</Text>
|
|
</Stack>
|
|
</div>
|
|
|
|
{renderBody()}
|
|
|
|
<div className='mx-auto sm:w-2/3 md:w-1/2'>
|
|
<Stack>
|
|
<Stack justifyContent='center' space={2}>
|
|
<Button
|
|
block
|
|
theme='primary'
|
|
onClick={onNext}
|
|
>
|
|
<FormattedMessage id='onboarding.done' defaultMessage='Done' />
|
|
</Button>
|
|
|
|
<Button block theme='tertiary' type='button' onClick={onNext}>
|
|
<FormattedMessage id='onboarding.skip' defaultMessage='Skip for now' />
|
|
</Button>
|
|
</Stack>
|
|
</Stack>
|
|
</div>
|
|
</div>
|
|
</CardBody>
|
|
</Card>
|
|
);
|
|
};
|
|
|
|
export default SuggestedAccountsStep;
|