GT2/GT2-iOS/node_modules/fbjs/lib/minBy.js.flow

35 lines
803 B
Plaintext
Raw Normal View History

2018-02-12 17:26:06 +00:00
/**
* 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;