UNPKG

tasuku

Version:

タスク — The minimal task runner

84 lines (74 loc) 2.72 kB
interface Options { /** Number of concurrently pending promises returned by `mapper`. Must be an integer from 1 and up or `Infinity`. @default Infinity */ readonly concurrency?: number; /** When `true`, the first mapper rejection will be rejected back to the consumer. When `false`, instead of stopping when a promise rejects, it will wait for all the promises to settle and then reject with an [aggregated error](https://github.com/sindresorhus/aggregate-error) containing all the errors from the rejected promises. Caveat: When `true`, any already-started async mappers will continue to run until they resolve or reject. In the case of infinite concurrency with sync iterables, *all* mappers are invoked on startup and will continue after the first rejection. [Issue #51](https://github.com/sindresorhus/p-map/issues/51) can be implemented for abort control. @default true */ readonly stopOnError?: boolean; } type State = 'pending' | 'loading' | 'error' | 'warning' | 'success'; type TaskObject = { title: string; state: State; children: TaskObject[]; status?: string; output?: string; }; type TaskInnerAPI = { task: Task; setTitle(title: string): void; setStatus(status?: string): void; setWarning(warning?: Error | string): void; setError(error?: Error | string): void; setOutput(output: string | { message: string; }): void; }; type TaskFunction<T> = (innerApi: TaskInnerAPI) => Promise<T>; declare const runSymbol: unique symbol; type RegisteredTask<T = any> = { [runSymbol]: () => Promise<T>; task: TaskObject; clear: () => void; }; type TaskAPI<Result = any> = { result: Result; state: State; clear: () => void; }; type Task = (<TaskReturnType>( /** * The task title */ title: string, /** * The task function */ taskFunction: TaskFunction<TaskReturnType>) => Promise<TaskAPI<TaskReturnType>>) & { group: TaskGroup; }; type TaskGroupResults<RegisteredTasks extends RegisteredTask[]> = { [Key in keyof RegisteredTasks]: (RegisteredTasks[Key] extends RegisteredTask<infer ReturnType> ? TaskAPI<ReturnType> : unknown); }; type TaskGroupAPI<Results = any[]> = Results & { clear(): void; }; type CreateTask = <ReturnType>( /** * The task title */ title: string, /** * The task function */ taskFunction: TaskFunction<ReturnType>) => RegisteredTask<ReturnType>; type TaskGroup = <RegisteredTasks extends RegisteredTask[]>(createTasks: (taskCreator: CreateTask) => readonly [...RegisteredTasks], options?: Options) => Promise<TaskGroupAPI<TaskGroupResults<RegisteredTasks>>>; declare const _default: Task; export { Task, TaskAPI, TaskFunction, TaskGroupAPI, TaskInnerAPI, _default as default };