UNPKG

es-toolkit

Version:

A state-of-the-art, high-performance JavaScript utility library with a small bundle size and strong type annotations.

44 lines (41 loc) 1.73 kB
import { ValueKeyIteratee } from '../_internal/ValueKeyIteratee.js'; /** * Creates a new object composed of the properties that do not satisfy the predicate function. * * @template T * @param {Record<string, T> | null | undefined} object - The source object. * @param {ValueKeyIteratee<T>} predicate - The function invoked per property. * @returns {Record<string, T>} Returns the new object. * * @example * omitBy({ 'a': 1, 'b': '2', 'c': 3 }, isString); * // => { 'a': 1, 'c': 3 } */ declare function omitBy<T>(object: Record<string, T> | null | undefined, predicate?: ValueKeyIteratee<T>): Record<string, T>; /** * Creates a new object composed of the properties that do not satisfy the predicate function. * * @template T * @param {Record<number, T> | null | undefined} object - The source object. * @param {ValueKeyIteratee<T>} predicate - The function invoked per property. * @returns {Record<number, T>} Returns the new object. * * @example * omitBy({ 0: 1, 1: '2', 2: 3 }, isString); * // => { 0: 1, 2: 3 } */ declare function omitBy<T>(object: Record<number, T> | null | undefined, predicate?: ValueKeyIteratee<T>): Record<number, T>; /** * Creates a new object composed of the properties that do not satisfy the predicate function. * * @template T * @param {T | null | undefined} object - The source object. * @param {ValueKeyIteratee<T[keyof T]>} predicate - The function invoked per property. * @returns {Partial<T>} Returns the new object. * * @example * omitBy({ 'a': 1, 'b': '2', 'c': 3 }, isString); * // => { 'a': 1, 'c': 3 } */ declare function omitBy<T extends object>(object: T | null | undefined, predicate: ValueKeyIteratee<T[keyof T]>): Partial<T>; export { omitBy };