bigbuffet-rw/app/soapbox/features/following/index.tsx
2023-06-25 15:57:38 -05:00

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;