import { ListIterator } from '../_internal/ListIterator.js'; import { ListOfRecursiveArraysOrValues } from '../_internal/ListOfRecursiveArraysOrValues.js'; import { ObjectIterator } from '../_internal/ObjectIterator.js'; /** * Creates a flattened array of values by running each element through iteratee and flattening the mapped results up to depth times. * * @template T * @param {Record | T> | Record | T> | null | undefined} collection - The collection to iterate over. * @returns {T[]} Returns the new flattened array. * * @example * const obj = { a: [[1, 2]], b: [[[3]]] }; * flatMapDepth(obj); * // => [1, 2, [3]] */ declare function flatMapDepth(collection: Record | T> | Record | T> | null | undefined): T[]; /** * Creates a flattened array of values by running each element through iteratee and flattening the mapped results up to depth times. * * @template T, R * @param {ArrayLike | null | undefined} collection - The collection to iterate over. * @param {ListIterator | R>} iteratee - The function invoked per iteration. * @param {number} [depth=1] - The maximum recursion depth. * @returns {R[]} Returns the new flattened array. * * @example * function duplicate(n) { * return [[n, n]]; * } * * flatMapDepth([1, 2], duplicate, 2); * // => [1, 1, 2, 2] */ declare function flatMapDepth(collection: ArrayLike | null | undefined, iteratee: ListIterator | R>, depth?: number): R[]; /** * Creates a flattened array of values by running each element through iteratee and flattening the mapped results up to depth times. * * @template T, R * @param {T | null | undefined} collection - The object to iterate over. * @param {ObjectIterator | R>} iteratee - The function invoked per iteration. * @param {number} [depth=1] - The maximum recursion depth. * @returns {R[]} Returns the new flattened array. * * @example * const obj = { a: 1, b: 2 }; * flatMapDepth(obj, (value, key) => [[key, value]], 2); * // => ['a', 1, 'b', 2] */ declare function flatMapDepth(collection: T | null | undefined, iteratee: ObjectIterator | R>, depth?: number): R[]; /** * Creates a flattened array of values by running each element through iteratee and flattening the mapped results up to depth times. * * @param {object | null | undefined} collection - The collection to iterate over. * @param {string} iteratee - The property name to use as iteratee. * @param {number} [depth=1] - The maximum recursion depth. * @returns {any[]} Returns the new flattened array. * * @example * const users = [ * { user: 'barney', hobbies: [['hiking'], ['coding']] }, * { user: 'fred', hobbies: [['reading']] } * ]; * flatMapDepth(users, 'hobbies', 2); * // => ['hiking', 'coding', 'reading'] */ declare function flatMapDepth(collection: object | null | undefined, iteratee: string, depth?: number): any[]; /** * Creates a flattened array of values by running each element through iteratee and flattening the mapped results up to depth times. * * @param {object | null | undefined} collection - The collection to iterate over. * @param {object} iteratee - The object properties to match. * @param {number} [depth=1] - The maximum recursion depth. * @returns {boolean[]} Returns the new flattened array. * * @example * const users = [ * { user: 'barney', active: [[true], [false]] }, * { user: 'fred', active: [[false]] } * ]; * flatMapDepth(users, { active: [[false]] }); * // => [false] */ declare function flatMapDepth(collection: object | null | undefined, iteratee: object, depth?: number): boolean[]; export { flatMapDepth };