2023-06-25 13:57:13 -07:00
|
|
|
import { Entities } from 'soapbox/entity-store/entities';
|
|
|
|
import { useEntities } from 'soapbox/entity-store/hooks';
|
|
|
|
import { useApi } from 'soapbox/hooks';
|
|
|
|
import { Account, accountSchema } from 'soapbox/schemas';
|
|
|
|
|
|
|
|
import { useRelationships } from './useRelationships';
|
|
|
|
|
2023-06-25 14:21:27 -07:00
|
|
|
function useFollowing(accountId: string | undefined, type: 'followers' | 'following') {
|
2023-06-25 13:57:13 -07:00
|
|
|
const api = useApi();
|
|
|
|
|
|
|
|
const { entities, ...rest } = useEntities(
|
2023-06-25 14:21:27 -07:00
|
|
|
[Entities.ACCOUNTS, accountId!, type],
|
|
|
|
() => api.get(`/api/v1/accounts/${accountId}/${type}`),
|
2023-06-25 13:57:13 -07:00
|
|
|
{ schema: accountSchema, enabled: !!accountId },
|
|
|
|
);
|
|
|
|
|
|
|
|
const { relationships } = useRelationships(
|
2023-06-25 14:21:27 -07:00
|
|
|
[accountId!, type],
|
2023-06-25 13:57:13 -07:00
|
|
|
entities.map(({ id }) => id),
|
|
|
|
);
|
|
|
|
|
|
|
|
const accounts: Account[] = entities.map((account) => ({
|
|
|
|
...account,
|
|
|
|
relationship: relationships[account.id],
|
|
|
|
}));
|
|
|
|
|
|
|
|
return { accounts, ...rest };
|
|
|
|
}
|
|
|
|
|
|
|
|
export { useFollowing };
|