pl-fe: rewrites

Signed-off-by: mkljczk <git@mkljczk.pl>
This commit is contained in:
mkljczk 2024-12-05 10:26:52 +01:00
parent 9f24429820
commit 50428184f1
4 changed files with 38 additions and 51 deletions

View file

@ -10,7 +10,7 @@ import { ChatWidgetScreens, useChatContext } from 'pl-fe/contexts/chat-context';
import { useDebounce } from 'pl-fe/hooks/use-debounce'; import { useDebounce } from 'pl-fe/hooks/use-debounce';
import { useChats } from 'pl-fe/queries/chats'; import { useChats } from 'pl-fe/queries/chats';
import { queryClient } from 'pl-fe/queries/client'; import { queryClient } from 'pl-fe/queries/client';
import useAccountSearch from 'pl-fe/queries/search'; import { useAccountSearch } from 'pl-fe/queries/search/use-search-accounts';
import toast from 'pl-fe/toast'; import toast from 'pl-fe/toast';
import Blankslate from './blankslate'; import Blankslate from './blankslate';

View file

@ -7,7 +7,9 @@ import HStack from 'pl-fe/components/ui/hstack';
import Stack from 'pl-fe/components/ui/stack'; import Stack from 'pl-fe/components/ui/stack';
import Text from 'pl-fe/components/ui/text'; import Text from 'pl-fe/components/ui/text';
import VerificationBadge from 'pl-fe/components/verification-badge'; import VerificationBadge from 'pl-fe/components/verification-badge';
import useAccountSearch from 'pl-fe/queries/search'; import { useAppSelector } from 'pl-fe/hooks/use-app-selector';
import { useAccountSearch } from 'pl-fe/queries/search/use-search-accounts';
import { selectAccounts } from 'pl-fe/selectors';
import type { Account } from 'pl-api'; import type { Account } from 'pl-api';
@ -18,7 +20,8 @@ interface IResults {
} }
const Results = ({ accountSearchResult, onSelect, parentRef }: IResults) => { const Results = ({ accountSearchResult, onSelect, parentRef }: IResults) => {
const { data: accounts, isFetching, hasNextPage, fetchNextPage } = accountSearchResult; const { data: accountIds = [], isFetching, hasNextPage, fetchNextPage } = accountSearchResult;
const accounts = useAppSelector((state) => selectAccounts(state, accountIds));
const [isNearBottom, setNearBottom] = useState<boolean>(false); const [isNearBottom, setNearBottom] = useState<boolean>(false);
const [isNearTop, setNearTop] = useState<boolean>(true); const [isNearTop, setNearTop] = useState<boolean>(true);

View file

@ -1,48 +0,0 @@
import { keepPreviousData, useInfiniteQuery } from '@tanstack/react-query';
import { useClient } from 'pl-fe/hooks/use-client';
import { flattenPages } from 'pl-fe/utils/queries';
import type { Account, PaginatedResponse } from 'pl-api';
const useAccountSearch = (q: string) => {
const client = useClient();
const getAccountSearch = async(q: string, pageParam?: Pick<PaginatedResponse<Account>, 'next'>): Promise<PaginatedResponse<Account>> => {
if (pageParam?.next) return pageParam.next();
const _getAccountSearch = async (offset = 0) => {
const response = await client.accounts.searchAccounts(q, {
limit: 10,
following: true,
offset: offset,
});
return {
previous: null,
next: response.length ? () => _getAccountSearch(offset + 10) : null,
items: response,
partial: false,
};
};
return _getAccountSearch(0);
};
const queryInfo = useInfiniteQuery({
queryKey: ['search', 'accounts', q],
queryFn: ({ pageParam }) => getAccountSearch(q, pageParam),
placeholderData: keepPreviousData,
initialPageParam: { next: null as (() => Promise<PaginatedResponse<Account>>) | null },
getNextPageParam: (config) => config.next ? config : undefined,
});
const data = flattenPages(queryInfo.data);
return {
...queryInfo,
data,
};
};
export { useAccountSearch as default };

View file

@ -0,0 +1,32 @@
import { useInfiniteQuery } from '@tanstack/react-query';
import { importEntities } from 'pl-fe/actions/importer';
import { useAppDispatch } from 'pl-fe/hooks/use-app-dispatch';
import { useClient } from 'pl-fe/hooks/use-client';
import type { SearchAccountParams } from 'pl-api';
const useAccountSearch = (
query: string,
params?: Omit<SearchAccountParams, 'limit' | 'offset'>,
) => {
const client = useClient();
const dispatch = useAppDispatch();
return useInfiniteQuery({
queryKey: ['search', 'accountSearch', query, params],
queryFn: ({ pageParam: offset, signal }) => client.accounts.searchAccounts(query, {
...params,
offset,
}, { signal }).then((accounts) => {
dispatch(importEntities({ accounts }));
return accounts.map(({ id }) => id);
}),
enabled: !!query?.trim(),
initialPageParam: 0,
getNextPageParam: (_, allPages) => allPages.flat().length,
select: (data) => data.pages.flat(),
});
};
export { useAccountSearch };