aboutsummaryrefslogtreecommitdiff
path: root/node_modules/fbjs/lib/minBy.js.flow
blob: 0417c793a88b22e7a2c36efe867a719e4273973d (plain)
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
30
31
32
33
34
35
/**
 * Copyright (c) 2013-present, Facebook, Inc.
 *
 * This source code is licensed under the MIT license found in the
 * LICENSE file in the root directory of this source tree.
 *
 * @providesModule minBy
 * @flow
 */

var compareNumber = (a, b) => a - b;

/**
 * Returns the minimum element as measured by a scoring function f. Returns the
 * first such element if there are ties.
 */
function minBy<A, B>(as: Iterable<A>, f: (a: A) => B, compare?: ?(u: B, v: B) => number): ?A {
  compare = compare || (compareNumber: any);

  var minA = undefined;
  var minB = undefined;
  var seenFirst = false;
  for (var a of as) {
    var b = f(a);
    if (!seenFirst || compare(b, (minB: any)) < 0) {
      minA = a;
      minB = b;
      seenFirst = true;
    }
  }

  return minA;
}

module.exports = minBy;