UNPKG

1.6 kBJavaScriptView Raw
1var compareAscending = require('./_compareAscending');
2
3/**
4 * Used by `_.orderBy` to compare multiple properties of a value to another
5 * and stable sort them.
6 *
7 * If `orders` is unspecified, all values are sorted in ascending order. Otherwise,
8 * specify an order of "desc" for descending or "asc" for ascending sort order
9 * of corresponding values.
10 *
11 * @private
12 * @param {Object} object The object to compare.
13 * @param {Object} other The other object to compare.
14 * @param {boolean[]|string[]} orders The order to sort by for each property.
15 * @returns {number} Returns the sort order indicator for `object`.
16 */
17function compareMultiple(object, other, orders) {
18 var index = -1,
19 objCriteria = object.criteria,
20 othCriteria = other.criteria,
21 length = objCriteria.length,
22 ordersLength = orders.length;
23
24 while (++index < length) {
25 var result = compareAscending(objCriteria[index], othCriteria[index]);
26 if (result) {
27 if (index >= ordersLength) {
28 return result;
29 }
30 var order = orders[index];
31 return result * (order == 'desc' ? -1 : 1);
32 }
33 }
34 // Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications
35 // that causes it, under certain circumstances, to provide the same value for
36 // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247
37 // for more details.
38 //
39 // This also ensures a stable sort in V8 and other engines.
40 // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details.
41 return object.index - other.index;
42}
43
44module.exports = compareMultiple;