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.
		
		
		
		
		
			
		
			
				
					39 lines
				
				1.2 KiB
			
		
		
			
		
	
	
					39 lines
				
				1.2 KiB
			| 
								 
											3 years ago
										 
									 | 
							
								import eachWeekendOfInterval from '../eachWeekendOfInterval/index.js';
							 | 
						||
| 
								 | 
							
								import startOfYear from '../startOfYear/index.js';
							 | 
						||
| 
								 | 
							
								import endOfYear from '../endOfYear/index.js';
							 | 
						||
| 
								 | 
							
								import requiredArgs from '../_lib/requiredArgs/index.js';
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * @name eachWeekendOfYear
							 | 
						||
| 
								 | 
							
								 * @category Year Helpers
							 | 
						||
| 
								 | 
							
								 * @summary List all the Saturdays and Sundays in the year.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @description
							 | 
						||
| 
								 | 
							
								 * Get all the Saturdays and Sundays in the year.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @param {Date|Number} date - the given year
							 | 
						||
| 
								 | 
							
								 * @returns {Date[]} an array containing all the Saturdays and Sundays
							 | 
						||
| 
								 | 
							
								 * @throws {TypeError} 1 argument required
							 | 
						||
| 
								 | 
							
								 * @throws {RangeError} The passed date is invalid
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @example
							 | 
						||
| 
								 | 
							
								 * // Lists all Saturdays and Sundays in the year
							 | 
						||
| 
								 | 
							
								 * var result = eachWeekendOfYear(new Date(2020, 1, 1))
							 | 
						||
| 
								 | 
							
								 * //=> [
							 | 
						||
| 
								 | 
							
								 * //   Sat Jan 03 2020 00:00:00,
							 | 
						||
| 
								 | 
							
								 * //   Sun Jan 04 2020 00:00:00,
							 | 
						||
| 
								 | 
							
								 * //   ...
							 | 
						||
| 
								 | 
							
								 * //   Sun Dec 27 2020 00:00:00
							 | 
						||
| 
								 | 
							
								 * // ]
							 | 
						||
| 
								 | 
							
								 * ]
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								export default function eachWeekendOfYear(dirtyDate) {
							 | 
						||
| 
								 | 
							
								  requiredArgs(1, arguments);
							 | 
						||
| 
								 | 
							
								  var startDate = startOfYear(dirtyDate);
							 | 
						||
| 
								 | 
							
								  if (isNaN(startDate)) throw new RangeError('The passed date is invalid');
							 | 
						||
| 
								 | 
							
								  var endDate = endOfYear(dirtyDate);
							 | 
						||
| 
								 | 
							
								  return eachWeekendOfInterval({
							 | 
						||
| 
								 | 
							
								    start: startDate,
							 | 
						||
| 
								 | 
							
								    end: endDate
							 | 
						||
| 
								 | 
							
								  });
							 | 
						||
| 
								 | 
							
								}
							 |