You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							45 lines
						
					
					
						
							1.4 KiB
						
					
					
				
			
		
		
	
	
							45 lines
						
					
					
						
							1.4 KiB
						
					
					
				var arrayMap = require('./_arrayMap'), | 
						|
    baseIntersection = require('./_baseIntersection'), | 
						|
    baseIteratee = require('./_baseIteratee'), | 
						|
    baseRest = require('./_baseRest'), | 
						|
    castArrayLikeObject = require('./_castArrayLikeObject'), | 
						|
    last = require('./last'); | 
						|
 | 
						|
/** | 
						|
 * This method is like `_.intersection` except that it accepts `iteratee` | 
						|
 * which is invoked for each element of each `arrays` to generate the criterion | 
						|
 * by which they're compared. The order and references of result values are | 
						|
 * determined by the first array. The iteratee is invoked with one argument: | 
						|
 * (value). | 
						|
 * | 
						|
 * @static | 
						|
 * @memberOf _ | 
						|
 * @since 4.0.0 | 
						|
 * @category Array | 
						|
 * @param {...Array} [arrays] The arrays to inspect. | 
						|
 * @param {Function} [iteratee=_.identity] The iteratee invoked per element. | 
						|
 * @returns {Array} Returns the new array of intersecting values. | 
						|
 * @example | 
						|
 * | 
						|
 * _.intersectionBy([2.1, 1.2], [2.3, 3.4], Math.floor); | 
						|
 * // => [2.1] | 
						|
 * | 
						|
 * // The `_.property` iteratee shorthand. | 
						|
 * _.intersectionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x'); | 
						|
 * // => [{ 'x': 1 }] | 
						|
 */ | 
						|
var intersectionBy = baseRest(function(arrays) { | 
						|
  var iteratee = last(arrays), | 
						|
      mapped = arrayMap(arrays, castArrayLikeObject); | 
						|
 | 
						|
  if (iteratee === last(mapped)) { | 
						|
    iteratee = undefined; | 
						|
  } else { | 
						|
    mapped.pop(); | 
						|
  } | 
						|
  return (mapped.length && mapped[0] === arrays[0]) | 
						|
    ? baseIntersection(mapped, baseIteratee(iteratee, 2)) | 
						|
    : []; | 
						|
}); | 
						|
 | 
						|
module.exports = intersectionBy;
 | 
						|
 |