|                                            |  | var compareAscending = require('./_compareAscending');
/** * Used by `_.orderBy` to compare multiple properties of a value to another * and stable sort them. * * If `orders` is unspecified, all values are sorted in ascending order. Otherwise, * specify an order of "desc" for descending or "asc" for ascending sort order * of corresponding values. * * @private * @param {Object} object The object to compare. * @param {Object} other The other object to compare. * @param {boolean[]|string[]} orders The order to sort by for each property. * @returns {number} Returns the sort order indicator for `object`. */function compareMultiple(object, other, orders) {  var index = -1,      objCriteria = object.criteria,      othCriteria = other.criteria,      length = objCriteria.length,      ordersLength = orders.length;
  while (++index < length) {    var result = compareAscending(objCriteria[index], othCriteria[index]);    if (result) {      if (index >= ordersLength) {        return result;      }      var order = orders[index];      return result * (order == 'desc' ? -1 : 1);    }  }  // Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications
  // that causes it, under certain circumstances, to provide the same value for
  // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247
  // for more details.
  //
  // This also ensures a stable sort in V8 and other engines.
  // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details.
  return object.index - other.index;}
module.exports = compareMultiple;
 |