12345678910111213141516171819202122232425262728293031323334353637 |
- import { constructFrom } from "./constructFrom.js";
- import { toDate } from "./toDate.js";
- /**
- * The {@link getDaysInMonth} function options.
- */
- /**
- * @name getDaysInMonth
- * @category Month Helpers
- * @summary Get the number of days in a month of the given date.
- *
- * @description
- * Get the number of days in a month of the given date, considering the context if provided.
- *
- * @param date - The given date
- * @param options - An object with options
- *
- * @returns The number of days in a month
- *
- * @example
- * // How many days are in February 2000?
- * const result = getDaysInMonth(new Date(2000, 1))
- * //=> 29
- */
- export function getDaysInMonth(date, options) {
- const _date = toDate(date, options?.in);
- const year = _date.getFullYear();
- const monthIndex = _date.getMonth();
- const lastDayOfMonth = constructFrom(_date, 0);
- lastDayOfMonth.setFullYear(year, monthIndex + 1, 0);
- lastDayOfMonth.setHours(0, 0, 0, 0);
- return lastDayOfMonth.getDate();
- }
- // Fallback for modularized imports:
- export default getDaysInMonth;
|