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
			| 
								 
											3 years ago
										 
									 | 
							
								import eachWeekendOfInterval from '../eachWeekendOfInterval/index.js';
							 | 
						||
| 
								 | 
							
								import startOfMonth from '../startOfMonth/index.js';
							 | 
						||
| 
								 | 
							
								import endOfMonth from '../endOfMonth/index.js';
							 | 
						||
| 
								 | 
							
								import requiredArgs from '../_lib/requiredArgs/index.js';
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * @name eachWeekendOfMonth
							 | 
						||
| 
								 | 
							
								 * @category Month Helpers
							 | 
						||
| 
								 | 
							
								 * @summary List all the Saturdays and Sundays in the given month.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @description
							 | 
						||
| 
								 | 
							
								 * Get all the Saturdays and Sundays in the given month.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @param {Date|Number} date - the given month
							 | 
						||
| 
								 | 
							
								 * @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 given month
							 | 
						||
| 
								 | 
							
								 * var result = eachWeekendOfMonth(new Date(2022, 1, 1))
							 | 
						||
| 
								 | 
							
								 * //=> [
							 | 
						||
| 
								 | 
							
								 * //   Sat Feb 05 2022 00:00:00,
							 | 
						||
| 
								 | 
							
								 * //   Sun Feb 06 2022 00:00:00,
							 | 
						||
| 
								 | 
							
								 * //   Sat Feb 12 2022 00:00:00,
							 | 
						||
| 
								 | 
							
								 * //   Sun Feb 13 2022 00:00:00,
							 | 
						||
| 
								 | 
							
								 * //   Sat Feb 19 2022 00:00:00,
							 | 
						||
| 
								 | 
							
								 * //   Sun Feb 20 2022 00:00:00,
							 | 
						||
| 
								 | 
							
								 * //   Sat Feb 26 2022 00:00:00,
							 | 
						||
| 
								 | 
							
								 * //   Sun Feb 27 2022 00:00:00
							 | 
						||
| 
								 | 
							
								 * // ]
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								export default function eachWeekendOfMonth(dirtyDate) {
							 | 
						||
| 
								 | 
							
								  requiredArgs(1, arguments);
							 | 
						||
| 
								 | 
							
								  var startDate = startOfMonth(dirtyDate);
							 | 
						||
| 
								 | 
							
								  if (isNaN(startDate)) throw new RangeError('The passed date is invalid');
							 | 
						||
| 
								 | 
							
								  var endDate = endOfMonth(dirtyDate);
							 | 
						||
| 
								 | 
							
								  return eachWeekendOfInterval({
							 | 
						||
| 
								 | 
							
								    start: startDate,
							 | 
						||
| 
								 | 
							
								    end: endDate
							 | 
						||
| 
								 | 
							
								  });
							 | 
						||
| 
								 | 
							
								}
							 |