varapply=require('./_apply'),arrayMap=require('./_arrayMap'),unzip=require('./unzip');/** * This method is like `_.unzip` except that it accepts `iteratee` to specify * how regrouped values should be combined. The iteratee is invoked with the * elements of each group: (...group). * * @static * @memberOf _ * @since 3.8.0 * @category Array * @param {Array} array The array of grouped elements to process. * @param {Function} [iteratee=_.identity] The function to combine * regrouped values. * @returns {Array} Returns the new array of regrouped elements. * @example * * var zipped = _.zip([1, 2], [10, 20], [100, 200]); * // => [[1, 10, 100], [2, 20, 200]] * * _.unzipWith(zipped, _.add); * // => [3, 30, 300] */functionunzipWith(array,iteratee){if(!(array&&array.length)){return[];}varresult=unzip(array);if(iteratee==null){returnresult;}returnarrayMap(result,function(group){returnapply(iteratee,undefined,group);});}module.exports=unzipWith;