bigbuffet-rw/app/soapbox/queries/suggestions.ts

58 lines
1.6 KiB
TypeScript
Raw Normal View History

import { useInfiniteQuery } from '@tanstack/react-query';
import { fetchRelationships } from 'soapbox/actions/accounts';
import { importFetchedAccounts } from 'soapbox/actions/importer';
import { getLinks } from 'soapbox/api';
import { useApi, useAppDispatch } from 'soapbox/hooks';
2022-09-08 09:47:19 -07:00
import type { IAccount } from './accounts';
type Suggestion = {
source: 'staff'
2022-09-08 09:47:19 -07:00
account: IAccount
}
export default function useOnboardingSuggestions() {
const api = useApi();
const dispatch = useAppDispatch();
const getV2Suggestions = async(pageParam: any): Promise<{ data: Suggestion[], link: string | undefined, hasMore: boolean }> => {
const link = pageParam?.link || '/api/v2/suggestions';
const response = await api.get<Suggestion[]>(link);
const hasMore = !!response.headers.link;
const nextLink = getLinks(response).refs.find(link => link.rel === 'next')?.uri;
const accounts = response.data.map(({ account }) => account);
const accountIds = accounts.map((account) => account.id);
dispatch(importFetchedAccounts(accounts));
dispatch(fetchRelationships(accountIds));
return {
data: response.data,
link: nextLink,
hasMore,
};
};
const result = useInfiniteQuery(['suggestions', 'v2'], ({ pageParam }) => getV2Suggestions(pageParam), {
keepPreviousData: true,
getNextPageParam: (config) => {
if (config.hasMore) {
return { link: config.link };
}
return undefined;
},
});
const data = result.data?.pages.reduce<Suggestion[]>(
(prev: Suggestion[], curr) => [...prev, ...curr.data],
[],
);
return {
...result,
data,
};
}