UNPKG

@augment-vir/common

Version:

A collection of augments, helpers types, functions, and classes for any JavaScript environment.

34 lines (33 loc) 1.26 kB
/** * Performs * [`[].map()`](https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Array/map) * on an array but supports an async callback. The async callback is blocking. Meaning, * `awaitedForEach` will wait for a callback on array element 1 to finish before moving on to array * element 2. Compare to `await Promise.all([].map(async () => {}))` which is _not_ blocking (all * callbacks are called in parallel). * * @category Array * @category Package : @augment-vir/common * @example * * ```ts * import {awaitedBlockingMap} from '@augment-vir/common'; * * const result = await awaitedBlockingMap( * [ * 1, * 2, * 3, * 4, * 5, * ], * async (value) => { * return await Promise.resolve(value); * }, * ); * ``` * * @returns A new array (does not mutate). * @package [`@augment-vir/common`](https://www.npmjs.com/package/@augment-vir/common) */ export declare function awaitedBlockingMap<OriginalGeneric, MappedGeneric>(input: ReadonlyArray<OriginalGeneric>, callback: (arrayElement: OriginalGeneric, index: number, wholeArray: ReadonlyArray<OriginalGeneric>) => MappedGeneric | PromiseLike<MappedGeneric>): Promise<Awaited<MappedGeneric>[]>;