ts-prime
Version:
A utility library for JavaScript and Typescript.
34 lines • 1.79 kB
TypeScript
import { LazyResult } from './_reduceLazy';
import { Pred, PredIndexedOptional, PredIndexed } from './_types';
/**
* Filter the elements of an array that meet the condition specified in a callback function.
* @param array The array to filter.
* @param fn the callback function.
* @signature
* P.filter(array, fn)
* @signature
* P.filter(fn)(array)
* @example
* P.filter([1, 2, 3], x => x % 2 === 1) // => [1, 3]
*
* P.pipe([1, 2, 3], P.filter(x => x % 2 === 1)) // => [1, 3]
* @category Array, Pipe
*/
export declare function filter<T, S extends T>(array: readonly T[], fn: (value: T) => value is S): S[];
export declare function filter<T>(array: readonly T[], fn: Pred<T, boolean>): T[];
export declare function filter<T, S extends T>(fn: (input: T) => input is S): (array: readonly T[]) => S[];
export declare function filter<T>(fn: Pred<T, boolean>): (array: readonly T[]) => T[];
export declare namespace filter {
function indexed<T, S extends T>(array: readonly T[], fn: (input: T, index: number, array: readonly T[]) => input is S): S[];
function indexed<T>(array: readonly T[], fn: PredIndexed<T, boolean>): T[];
/**
* @data_last
*/
function indexed<T, S extends T>(fn: (input: T, index: number, array: readonly T[]) => input is S): (array: readonly T[]) => S[];
function indexed<T>(fn: PredIndexed<T, boolean>): (array: readonly T[]) => T[];
const lazy: <T>(fn: PredIndexedOptional<T, boolean>) => (value: T, index?: number | undefined, array?: readonly T[] | undefined) => LazyResult<T>;
const lazyIndexed: (<T>(fn: PredIndexedOptional<T, boolean>) => (value: T, index?: number | undefined, array?: readonly T[] | undefined) => LazyResult<T>) & {
indexed: true;
};
}
//# sourceMappingURL=filter.d.ts.map