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 | ||
|  |   }); | ||
|  | } |