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.
		
		
		
		
		
			
		
			
				
					53 lines
				
				2.0 KiB
			
		
		
			
		
	
	
					53 lines
				
				2.0 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								import isValid from '../isValid/index.js';
							 | 
						||
| 
								 | 
							
								import isWeekend from '../isWeekend/index.js';
							 | 
						||
| 
								 | 
							
								import toDate from '../toDate/index.js';
							 | 
						||
| 
								 | 
							
								import differenceInCalendarDays from '../differenceInCalendarDays/index.js';
							 | 
						||
| 
								 | 
							
								import addDays from '../addDays/index.js';
							 | 
						||
| 
								 | 
							
								import isSameDay from '../isSameDay/index.js';
							 | 
						||
| 
								 | 
							
								import toInteger from '../_lib/toInteger/index.js';
							 | 
						||
| 
								 | 
							
								import requiredArgs from '../_lib/requiredArgs/index.js';
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * @name differenceInBusinessDays
							 | 
						||
| 
								 | 
							
								 * @category Day Helpers
							 | 
						||
| 
								 | 
							
								 * @summary Get the number of business days between the given dates.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @description
							 | 
						||
| 
								 | 
							
								 * Get the number of business day periods between the given dates.
							 | 
						||
| 
								 | 
							
								 * Business days being days that arent in the weekend.
							 | 
						||
| 
								 | 
							
								 * Like `differenceInCalendarDays`, the function removes the times from
							 | 
						||
| 
								 | 
							
								 * the dates before calculating the difference.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @param {Date|Number} dateLeft - the later date
							 | 
						||
| 
								 | 
							
								 * @param {Date|Number} dateRight - the earlier date
							 | 
						||
| 
								 | 
							
								 * @returns {Number} the number of business days
							 | 
						||
| 
								 | 
							
								 * @throws {TypeError} 2 arguments required
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @example
							 | 
						||
| 
								 | 
							
								 * // How many business days are between
							 | 
						||
| 
								 | 
							
								 * // 10 January 2014 and 20 July 2014?
							 | 
						||
| 
								 | 
							
								 * var result = differenceInBusinessDays(
							 | 
						||
| 
								 | 
							
								 *   new Date(2014, 6, 20),
							 | 
						||
| 
								 | 
							
								 *   new Date(2014, 0, 10)
							 | 
						||
| 
								 | 
							
								 * )
							 | 
						||
| 
								 | 
							
								 * //=> 136
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								export default function differenceInBusinessDays(dirtyDateLeft, dirtyDateRight) {
							 | 
						||
| 
								 | 
							
								  requiredArgs(2, arguments);
							 | 
						||
| 
								 | 
							
								  var dateLeft = toDate(dirtyDateLeft);
							 | 
						||
| 
								 | 
							
								  var dateRight = toDate(dirtyDateRight);
							 | 
						||
| 
								 | 
							
								  if (!isValid(dateLeft) || !isValid(dateRight)) return new Date(NaN);
							 | 
						||
| 
								 | 
							
								  var calendarDifference = differenceInCalendarDays(dateLeft, dateRight);
							 | 
						||
| 
								 | 
							
								  var sign = calendarDifference < 0 ? -1 : 1;
							 | 
						||
| 
								 | 
							
								  var weeks = toInteger(calendarDifference / 7);
							 | 
						||
| 
								 | 
							
								  var result = weeks * 5;
							 | 
						||
| 
								 | 
							
								  dateRight = addDays(dateRight, weeks * 7); // the loop below will run at most 6 times to account for the remaining days that don't makeup a full week
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  while (!isSameDay(dateLeft, dateRight)) {
							 | 
						||
| 
								 | 
							
								    // sign is used to account for both negative and positive differences
							 | 
						||
| 
								 | 
							
								    result += isWeekend(dateRight) ? 0 : sign;
							 | 
						||
| 
								 | 
							
								    dateRight = addDays(dateRight, sign);
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  return result === 0 ? 0 : result;
							 | 
						||
| 
								 | 
							
								}
							 |