lifetracker/apps/web/components/dashboard/bookmarks/UpdatableBookmarksGrid.tsx

53 lines
1.4 KiB
TypeScript

"use client";
import UploadDropzone from "@/components/dashboard/UploadDropzone";
import { api } from "@/lib/trpc";
import type {
ZGetBookmarksRequest,
ZGetBookmarksResponse,
} from "@hoarder/shared/types/bookmarks";
import { BookmarkGridContextProvider } from "@hoarder/shared-react/hooks/bookmark-grid-context";
import BookmarksGrid from "./BookmarksGrid";
export default function UpdatableBookmarksGrid({
query,
bookmarks: initialBookmarks,
showEditorCard = false,
}: {
query: ZGetBookmarksRequest;
bookmarks: ZGetBookmarksResponse;
showEditorCard?: boolean;
itemsPerPage?: number;
}) {
const { data, fetchNextPage, hasNextPage, isFetchingNextPage } =
api.bookmarks.getBookmarks.useInfiniteQuery(
{ ...query, useCursorV2: true },
{
initialData: () => ({
pages: [initialBookmarks],
pageParams: [query.cursor],
}),
initialCursor: null,
getNextPageParam: (lastPage) => lastPage.nextCursor,
},
);
const grid = (
<BookmarksGrid
bookmarks={data!.pages.flatMap((b) => b.bookmarks)}
hasNextPage={hasNextPage}
fetchNextPage={() => fetchNextPage()}
isFetchingNextPage={isFetchingNextPage}
showEditorCard={showEditorCard}
/>
);
return (
<BookmarkGridContextProvider query={query}>
{showEditorCard ? <UploadDropzone>{grid}</UploadDropzone> : grid}
</BookmarkGridContextProvider>
);
}