UNPKG

1.65 kBJavaScriptView Raw
1var _curry2 =
2/*#__PURE__*/
3require("./internal/_curry2");
4
5var _dispatchable =
6/*#__PURE__*/
7require("./internal/_dispatchable");
8
9var _filter =
10/*#__PURE__*/
11require("./internal/_filter");
12
13var _isObject =
14/*#__PURE__*/
15require("./internal/_isObject");
16
17var _reduce =
18/*#__PURE__*/
19require("./internal/_reduce");
20
21var _xfilter =
22/*#__PURE__*/
23require("./internal/_xfilter");
24
25var keys =
26/*#__PURE__*/
27require("./keys");
28/**
29 * Takes a predicate and a `Filterable`, and returns a new filterable of the
30 * same type containing the members of the given filterable which satisfy the
31 * given predicate. Filterable objects include plain objects or any object
32 * that has a filter method such as `Array`.
33 *
34 * Dispatches to the `filter` method of the second argument, if present.
35 *
36 * Acts as a transducer if a transformer is given in list position.
37 *
38 * @func
39 * @memberOf R
40 * @since v0.1.0
41 * @category List
42 * @sig Filterable f => (a -> Boolean) -> f a -> f a
43 * @param {Function} pred
44 * @param {Array} filterable
45 * @return {Array} Filterable
46 * @see R.reject, R.transduce, R.addIndex
47 * @example
48 *
49 * const isEven = n => n % 2 === 0;
50 *
51 * R.filter(isEven, [1, 2, 3, 4]); //=> [2, 4]
52 *
53 * R.filter(isEven, {a: 1, b: 2, c: 3, d: 4}); //=> {b: 2, d: 4}
54 */
55
56
57var filter =
58/*#__PURE__*/
59_curry2(
60/*#__PURE__*/
61_dispatchable(['filter'], _xfilter, function (pred, filterable) {
62 return _isObject(filterable) ? _reduce(function (acc, key) {
63 if (pred(filterable[key])) {
64 acc[key] = filterable[key];
65 }
66
67 return acc;
68 }, {}, keys(filterable)) : // else
69 _filter(pred, filterable);
70}));
71
72module.exports = filter;
\No newline at end of file