71 lines
No EOL
1.8 KiB
TypeScript
71 lines
No EOL
1.8 KiB
TypeScript
import React from 'react';
|
|
import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
|
|
|
|
import { useAccountLookup } from 'soapbox/api/hooks';
|
|
import { useFollowing } from 'soapbox/api/hooks/accounts/useFollowing';
|
|
import Account from 'soapbox/components/account';
|
|
import MissingIndicator from 'soapbox/components/missing-indicator';
|
|
import ScrollableList from 'soapbox/components/scrollable-list';
|
|
import { Column, Spinner } from 'soapbox/components/ui';
|
|
|
|
const messages = defineMessages({
|
|
heading: { id: 'column.following', defaultMessage: 'Following' },
|
|
});
|
|
|
|
interface IFollowing {
|
|
params?: {
|
|
username?: string
|
|
}
|
|
}
|
|
|
|
/** Displays a list of accounts the given user is following. */
|
|
const Following: React.FC<IFollowing> = ({ params }) => {
|
|
const intl = useIntl();
|
|
|
|
const { account, isUnavailable } = useAccountLookup(params?.username);
|
|
|
|
const {
|
|
accounts,
|
|
hasNextPage,
|
|
fetchNextPage,
|
|
isLoading,
|
|
} = useFollowing(account?.id);
|
|
|
|
if (isLoading) {
|
|
return (
|
|
<Spinner />
|
|
);
|
|
}
|
|
|
|
if (!account) {
|
|
return (
|
|
<MissingIndicator />
|
|
);
|
|
}
|
|
|
|
if (isUnavailable) {
|
|
return (
|
|
<div className='empty-column-indicator'>
|
|
<FormattedMessage id='empty_column.account_unavailable' defaultMessage='Profile unavailable' />
|
|
</div>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<Column label={intl.formatMessage(messages.heading)} transparent>
|
|
<ScrollableList
|
|
scrollKey='following'
|
|
hasMore={hasNextPage}
|
|
onLoadMore={fetchNextPage}
|
|
emptyMessage={<FormattedMessage id='account.follows.empty' defaultMessage="This user doesn't follow anyone yet." />}
|
|
itemClassName='pb-4'
|
|
>
|
|
{accounts.map((account) => (
|
|
<Account key={account.id} account={account} />
|
|
))}
|
|
</ScrollableList>
|
|
</Column>
|
|
);
|
|
};
|
|
|
|
export default Following; |