1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
import { fetchJSON } from "https://esm.town/v/mgruel/fetchJSON";
type PaginatedData<T> = {
data: T[];
links: {
prev?: string;
self: string;
next?: string;
};
};
export const paginateAPI = async <T extends any = any>(
url: string,
options?: RequestInit,
) => {
let result: T[] = [];
let nextUrl = url;
while (nextUrl) {
const { data, links } = await fetchJSON<PaginatedData<T>>(
nextUrl,
options,
);
result = result.concat(data ?? []);
nextUrl = links?.next;
}
return result;
};
Val Town is a social website to write and deploy JavaScript.
Build APIs and schedule functions from your browser.
Comments
Nobody has commented on this val yet: be the first!
October 23, 2023