bigbuffet-rw/app/soapbox/features/ui/components/who-to-follow-panel.tsx

66 lines
2.1 KiB
TypeScript
Raw Normal View History

import React from 'react';
import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
2022-09-26 12:22:00 -07:00
import { Link } from 'react-router-dom';
2022-03-21 11:09:01 -07:00
2022-09-26 12:22:00 -07:00
import { Text, Widget } from 'soapbox/components/ui';
2022-11-15 08:13:54 -08:00
import AccountContainer from 'soapbox/containers/account-container';
2022-09-26 12:22:00 -07:00
import PlaceholderSidebarSuggestions from 'soapbox/features/placeholder/components/placeholder-sidebar-suggestions';
import { useDismissSuggestion, useSuggestions } from 'soapbox/queries/suggestions';
2022-03-21 11:09:01 -07:00
import type { Account as AccountEntity } from 'soapbox/types/entities';
2022-03-21 11:09:01 -07:00
const messages = defineMessages({
dismissSuggestion: { id: 'suggestions.dismiss', defaultMessage: 'Dismiss suggestion' },
});
interface IWhoToFollowPanel {
limit: number
}
const WhoToFollowPanel = ({ limit }: IWhoToFollowPanel) => {
const intl = useIntl();
2022-09-26 12:22:00 -07:00
const { data: suggestions, isFetching } = useSuggestions();
const dismissSuggestion = useDismissSuggestion();
2022-03-21 11:09:01 -07:00
const suggestionsToRender = suggestions.slice(0, limit);
const handleDismiss = (account: AccountEntity) => {
2022-09-26 12:22:00 -07:00
dismissSuggestion.mutate(account.id);
2022-03-21 11:09:01 -07:00
};
if (!isFetching && !suggestions.length) {
return null;
}
2022-03-21 11:09:01 -07:00
return (
2022-04-18 20:49:17 -07:00
<Widget
title={<FormattedMessage id='who_to_follow.title' defaultMessage='People To Follow' />}
2022-09-26 12:22:00 -07:00
action={
<Link className='text-right' to='/suggestions'>
<Text tag='span' theme='primary' size='sm' className='hover:underline'>
<FormattedMessage id='feed_suggestions.view_all' defaultMessage='View all' />
</Text>
2022-09-26 12:22:00 -07:00
</Link>
}
2022-04-18 20:49:17 -07:00
>
2022-09-26 12:22:00 -07:00
{isFetching ? (
<PlaceholderSidebarSuggestions limit={limit} />
) : (
suggestionsToRender.map((suggestion: any) => (
<AccountContainer
key={suggestion.account}
// @ts-ignore: TS thinks `id` is passed to <Account>, but it isn't
id={suggestion.account}
actionIcon={require('@tabler/icons/x.svg')}
actionTitle={intl.formatMessage(messages.dismissSuggestion)}
onActionClick={handleDismiss}
/>
))
)}
</Widget>
2022-03-21 11:09:01 -07:00
);
};
export default WhoToFollowPanel;