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.
		
		
		
		
			
				
					42 lines
				
				1.4 KiB
			
		
		
			
		
	
	
					42 lines
				
				1.4 KiB
			| 
								 
											4 years ago
										 
									 | 
							
								var baseAssignValue = require('./_baseAssignValue'),
							 | 
						||
| 
								 | 
							
								    createAggregator = require('./_createAggregator');
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/** Used for built-in method references. */
							 | 
						||
| 
								 | 
							
								var objectProto = Object.prototype;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/** Used to check objects for own properties. */
							 | 
						||
| 
								 | 
							
								var hasOwnProperty = objectProto.hasOwnProperty;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Creates an object composed of keys generated from the results of running
							 | 
						||
| 
								 | 
							
								 * each element of `collection` thru `iteratee`. The order of grouped values
							 | 
						||
| 
								 | 
							
								 * is determined by the order they occur in `collection`. The corresponding
							 | 
						||
| 
								 | 
							
								 * value of each key is an array of elements responsible for generating the
							 | 
						||
| 
								 | 
							
								 * key. The iteratee is invoked with one argument: (value).
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @static
							 | 
						||
| 
								 | 
							
								 * @memberOf _
							 | 
						||
| 
								 | 
							
								 * @since 0.1.0
							 | 
						||
| 
								 | 
							
								 * @category Collection
							 | 
						||
| 
								 | 
							
								 * @param {Array|Object} collection The collection to iterate over.
							 | 
						||
| 
								 | 
							
								 * @param {Function} [iteratee=_.identity] The iteratee to transform keys.
							 | 
						||
| 
								 | 
							
								 * @returns {Object} Returns the composed aggregate object.
							 | 
						||
| 
								 | 
							
								 * @example
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * _.groupBy([6.1, 4.2, 6.3], Math.floor);
							 | 
						||
| 
								 | 
							
								 * // => { '4': [4.2], '6': [6.1, 6.3] }
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * // The `_.property` iteratee shorthand.
							 | 
						||
| 
								 | 
							
								 * _.groupBy(['one', 'two', 'three'], 'length');
							 | 
						||
| 
								 | 
							
								 * // => { '3': ['one', 'two'], '5': ['three'] }
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								var groupBy = createAggregator(function(result, value, key) {
							 | 
						||
| 
								 | 
							
								  if (hasOwnProperty.call(result, key)) {
							 | 
						||
| 
								 | 
							
								    result[key].push(value);
							 | 
						||
| 
								 | 
							
								  } else {
							 | 
						||
| 
								 | 
							
								    baseAssignValue(result, key, [value]);
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								});
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								module.exports = groupBy;
							 |