UNPKG

@replit/connectors

Version:

The official TypeScript library for the Replit API

60 lines 2.49 kB
import { FinalRequestOptions } from "../internal/request-options.mjs"; import { type Replit } from "../client.mjs"; import { APIPromise } from "./api-promise.mjs"; import { type APIResponseProps } from "../internal/parse.mjs"; export type PageRequestOptions = Pick<FinalRequestOptions, 'query' | 'headers' | 'body' | 'path' | 'method'>; export declare abstract class AbstractPage<Item> implements AsyncIterable<Item> { #private; protected options: FinalRequestOptions; protected response: Response; protected body: unknown; constructor(client: Replit, response: Response, body: unknown, options: FinalRequestOptions); abstract nextPageRequestOptions(): PageRequestOptions | null; abstract getPaginatedItems(): Item[]; hasNextPage(): boolean; getNextPage(): Promise<this>; iterPages(): AsyncGenerator<this>; [Symbol.asyncIterator](): AsyncGenerator<Item>; } /** * This subclass of Promise will resolve to an instantiated Page once the request completes. * * It also implements AsyncIterable to allow auto-paginating iteration on an unawaited list call, eg: * * for await (const item of client.items.list()) { * console.log(item) * } */ export declare class PagePromise<PageClass extends AbstractPage<Item>, Item = ReturnType<PageClass['getPaginatedItems']>[number]> extends APIPromise<PageClass> implements AsyncIterable<Item> { constructor(client: Replit, request: Promise<APIResponseProps>, Page: new (...args: ConstructorParameters<typeof AbstractPage>) => PageClass); /** * Allow auto-paginating iteration on an unawaited list call, eg: * * for await (const item of client.items.list()) { * console.log(item) * } */ [Symbol.asyncIterator](): AsyncGenerator<Item>; } export interface OffsetPaginationResponse<Item> { items: Array<Item>; total: number; offset: number; limit: number; } export interface OffsetPaginationParams { /** * The number of elements to skip. */ offset?: number; } export declare class OffsetPagination<Item> extends AbstractPage<Item> implements OffsetPaginationResponse<Item> { items: Array<Item>; total: number; offset: number; limit: number; constructor(client: Replit, response: Response, body: OffsetPaginationResponse<Item>, options: FinalRequestOptions); getPaginatedItems(): Item[]; nextPageRequestOptions(): PageRequestOptions | null; } //# sourceMappingURL=pagination.d.mts.map