pleroma/app/soapbox/features/onboarding/steps/suggested-accounts-step.tsx

110 lines
3.4 KiB
TypeScript
Raw Normal View History

import debounce from 'lodash/debounce';
import React from 'react';
2022-04-12 11:25:53 -07:00
import { FormattedMessage } from 'react-intl';
2022-04-12 06:52:04 -07:00
2022-11-15 08:00:49 -08:00
import ScrollableList from 'soapbox/components/scrollable-list';
2022-04-12 06:52:04 -07:00
import { Button, Card, CardBody, Stack, Text } from 'soapbox/components/ui';
2022-11-15 08:13:54 -08:00
import AccountContainer from 'soapbox/containers/account-container';
2022-09-27 06:58:49 -07:00
import { useOnboardingSuggestions } from 'soapbox/queries/suggestions';
2022-04-12 06:52:04 -07:00
const SuggestedAccountsStep = ({ onNext }: { onNext: () => void }) => {
const { data, fetchNextPage, hasNextPage, isFetching } = useOnboardingSuggestions();
2022-04-12 06:52:04 -07:00
const handleLoadMore = debounce(() => {
if (isFetching) {
return null;
}
return fetchNextPage();
}, 300);
2022-04-12 06:52:04 -07:00
const renderSuggestions = () => {
if (!data) {
return null;
}
return (
2023-02-01 14:13:42 -08:00
<div className='flex flex-col sm:pt-4 sm:pb-10'>
<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}
2022-07-01 13:07:01 -07:00
withLinkToProfile={false}
/>
</div>
))}
</ScrollableList>
</div>
);
};
const renderEmpty = () => {
return (
2023-02-01 14:13:42 -08:00
<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();
}
};
2022-04-12 06:52:04 -07:00
return (
<Card variant='rounded' size='xl'>
<CardBody>
<div>
2023-02-01 14:13:42 -08:00
<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'>
2022-04-12 06:52:04 -07:00
<Stack space={2}>
<Text size='2xl' align='center' weight='bold'>
2022-04-12 11:25:53 -07:00
<FormattedMessage id='onboarding.suggestions.title' defaultMessage='Suggested accounts' />
2022-04-12 06:52:04 -07:00
</Text>
<Text theme='muted' align='center'>
2022-04-12 11:25:53 -07:00
<FormattedMessage id='onboarding.suggestions.subtitle' defaultMessage='Here are a few of the most popular accounts you might like.' />
2022-04-12 06:52:04 -07:00
</Text>
</Stack>
</div>
{renderBody()}
2022-04-12 06:52:04 -07:00
2023-02-01 14:13:42 -08:00
<div className='mx-auto sm:w-2/3 md:w-1/2'>
2022-04-12 06:52:04 -07:00
<Stack>
<Stack justifyContent='center' space={2}>
<Button
block
theme='primary'
onClick={onNext}
>
<FormattedMessage id='onboarding.done' defaultMessage='Done' />
2022-04-12 06:52:04 -07:00
</Button>
<Button block theme='tertiary' type='button' onClick={onNext}>
2022-04-12 11:25:53 -07:00
<FormattedMessage id='onboarding.skip' defaultMessage='Skip for now' />
</Button>
2022-04-12 06:52:04 -07:00
</Stack>
</Stack>
</div>
</div>
</CardBody>
</Card>
);
};
export default SuggestedAccountsStep;