50 lines
1.5 KiB
JavaScript
50 lines
1.5 KiB
JavaScript
|
import arrayMap from './_arrayMap.js';
|
||
|
import baseGet from './_baseGet.js';
|
||
|
import baseIteratee from './_baseIteratee.js';
|
||
|
import baseMap from './_baseMap.js';
|
||
|
import baseSortBy from './_baseSortBy.js';
|
||
|
import baseUnary from './_baseUnary.js';
|
||
|
import compareMultiple from './_compareMultiple.js';
|
||
|
import identity from './identity.js';
|
||
|
import isArray from './isArray.js';
|
||
|
|
||
|
/**
|
||
|
* The base implementation of `_.orderBy` without param guards.
|
||
|
*
|
||
|
* @private
|
||
|
* @param {Array|Object} collection The collection to iterate over.
|
||
|
* @param {Function[]|Object[]|string[]} iteratees The iteratees to sort by.
|
||
|
* @param {string[]} orders The sort orders of `iteratees`.
|
||
|
* @returns {Array} Returns the new sorted array.
|
||
|
*/
|
||
|
function baseOrderBy(collection, iteratees, orders) {
|
||
|
if (iteratees.length) {
|
||
|
iteratees = arrayMap(iteratees, function(iteratee) {
|
||
|
if (isArray(iteratee)) {
|
||
|
return function(value) {
|
||
|
return baseGet(value, iteratee.length === 1 ? iteratee[0] : iteratee);
|
||
|
}
|
||
|
}
|
||
|
return iteratee;
|
||
|
});
|
||
|
} else {
|
||
|
iteratees = [identity];
|
||
|
}
|
||
|
|
||
|
var index = -1;
|
||
|
iteratees = arrayMap(iteratees, baseUnary(baseIteratee));
|
||
|
|
||
|
var result = baseMap(collection, function(value, key, collection) {
|
||
|
var criteria = arrayMap(iteratees, function(iteratee) {
|
||
|
return iteratee(value);
|
||
|
});
|
||
|
return { 'criteria': criteria, 'index': ++index, 'value': value };
|
||
|
});
|
||
|
|
||
|
return baseSortBy(result, function(object, other) {
|
||
|
return compareMultiple(object, other, orders);
|
||
|
});
|
||
|
}
|
||
|
|
||
|
export default baseOrderBy;
|