forked from lodash/lodash
-
Notifications
You must be signed in to change notification settings - Fork 0
/
flatMapDepth.js
29 lines (27 loc) · 898 Bytes
/
flatMapDepth.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
import baseFlatten from './.internal/baseFlatten.js'
import map from './map.js'
/**
* This method is like `flatMap` except that it recursively flattens the
* mapped results up to `depth` times.
*
* @since 4.7.0
* @category Collection
* @param {Array|Object} collection The collection to iterate over.
* @param {Function} iteratee The function invoked per iteration.
* @param {number} [depth=1] The maximum recursion depth.
* @returns {Array} Returns the new flattened array.
* @see flatMap, flatMapDeep, flatten, flattenDeep, flattenDepth, map, mapKeys, mapValues
* @example
*
* function duplicate(n) {
* return [[[n, n]]]
* }
*
* flatMapDepth([1, 2], duplicate, 2)
* // => [[1, 1], [2, 2]]
*/
function flatMapDepth(collection, iteratee, depth) {
depth = depth === undefined ? 1 : +depth
return baseFlatten(map(collection, iteratee), depth)
}
export default flatMapDepth