/*! * All material copyright ESRI, All Rights Reserved, unless otherwise specified. * See https://github.com/Esri/calcite-components/blob/master/LICENSE.md for details. * v1.0.0-beta.97 */ 'use strict'; const index = require('./index-a0010f96.js'); const locale = require('./locale-678ce361.js'); /** * Check if date is within a min and max * * @param date * @param min * @param max */ function inRange(date, min, max) { const time = date.getTime(); const afterMin = !(min instanceof Date) || time >= min.getTime(); const beforeMax = !(max instanceof Date) || time <= max.getTime(); return afterMin && beforeMax; } /** * Ensures date is within range, * returns min or max if out of bounds * * @param date * @param min * @param max */ function dateFromRange(date, min, max) { if (!(date instanceof Date)) { return null; } const time = date.getTime(); const beforeMin = min instanceof Date && time < min.getTime(); const afterMax = max instanceof Date && time > max.getTime(); if (beforeMin) { return min; } if (afterMax) { return max; } return date; } /** * Parse an iso8601 string (YYYY-mm-dd) into a valid date. * TODO: handle time when time of day UI is added * * @param iso8601 * @param isEndDate */ function dateFromISO(iso8601, isEndDate = false) { if (iso8601 instanceof Date) { return iso8601; } if (!iso8601 || typeof iso8601 !== "string") { return null; } const d = iso8601.split(/[: T-]/).map(parseFloat); const date = new Date(d[0], (d[1] || 1) - 1, d[2] || 1); date.setFullYear(d[0]); if (isNaN(date.getTime())) { throw new Error(`Invalid ISO 8601 date: "${iso8601}"`); } if (isEndDate) { return setEndOfDay(date); } return date; } /** * Return first portion of ISO string (YYYY-mm-dd) * * @param date */ function dateToISO(date) { if (typeof date === "string") { return date; } if (date instanceof Date) { return new Date(date.getTime() - date.getTimezoneOffset() * 60000).toISOString().split("T")[0]; } return ""; } /** * Check if two dates are the same day, month, year * * @param d1 * @param d2 */ function sameDate(d1, d2) { return (d1 instanceof Date && d2 instanceof Date && d1.getDate() === d2.getDate() && d1.getMonth() === d2.getMonth() && d1.getFullYear() === d2.getFullYear()); } /** * Get a date one month in the past * * @param date */ function prevMonth(date) { const month = date.getMonth(); const nextDate = new Date(date); nextDate.setMonth(month - 1); // date doesn't exist in new month, use last day if (month === nextDate.getMonth()) { return new Date(date.getFullYear(), month, 0); } return nextDate; } /** * Get a date one month in the future * * @param date */ function nextMonth(date) { const month = date.getMonth(); const nextDate = new Date(date); nextDate.setMonth(month + 1); // date doesn't exist in new month, use last day if ((month + 2) % 7 === nextDate.getMonth() % 7) { return new Date(date.getFullYear(), month + 2, 0); } return nextDate; } /** * Parse numeric units for day, month, and year from a localized string * month starts at 0 (can pass to date constructor) * * @param str * @param localeData */ function parseDateString(str, localeData) { const { separator, unitOrder } = localeData; const order = getOrder(unitOrder); const values = str.split(separator).map((part) => locale.numberStringFormatter.delocalize(part)); return { day: parseInt(values[order.indexOf("d")]), month: parseInt(values[order.indexOf("m")]) - 1, year: parseInt(values[order.indexOf("y")]) }; } /** * Based on the unitOrder string, find order of month, day, and year for locale * * @param unitOrder */ function getOrder(unitOrder) { const signifiers = ["d", "m", "y"]; const order = unitOrder.toLowerCase(); return signifiers.sort((a, b) => order.indexOf(a) - order.indexOf(b)); } /** * Get number of days between two dates * * @param date1 * @param date2 */ function getDaysDiff(date1, date2) { const ts1 = date1.getTime(); const ts2 = date2.getTime(); return (ts1 - ts2) / (1000 * 3600 * 24); } /** * Set time of the day to the end. * * @param {Date} date Date. * @returns {Date} Date with time set to end of day . */ function setEndOfDay(date) { date.setHours(23, 59, 59, 999); return date; } /** * CLDR cache. * Exported for testing purposes. * * @private */ const translationCache = {}; /** * CLDR request cache. * Exported for testing purposes. * * @private */ const requestCache = {}; /** * Fetch calendar data for a given locale from list of supported languages * * @param lang * @public */ async function getLocaleData(lang) { const locale$1 = locale.getSupportedLocale(lang); if (translationCache[locale$1]) { return translationCache[locale$1]; } if (!requestCache[locale$1]) { requestCache[locale$1] = fetch(index.getAssetPath(`./assets/date-picker/nls/${locale$1}.json`)) .then((resp) => resp.json()) .catch(() => { console.error(`Translations for "${locale$1}" not found or invalid, falling back to english`); return getLocaleData("en"); }); } const data = await requestCache[locale$1]; translationCache[locale$1] = data; return data; } /** * Maps value to valueAsDate * * @param value */ function getValueAsDateRange(value) { return value.map((v, index) => dateFromISO(v, index === 1)); } const HEADING_LEVEL = 2; const TEXT = { nextMonth: "Next month", prevMonth: "Previous month", year: "Year" }; exports.HEADING_LEVEL = HEADING_LEVEL; exports.TEXT = TEXT; exports.dateFromISO = dateFromISO; exports.dateFromRange = dateFromRange; exports.dateToISO = dateToISO; exports.getDaysDiff = getDaysDiff; exports.getLocaleData = getLocaleData; exports.getOrder = getOrder; exports.getValueAsDateRange = getValueAsDateRange; exports.inRange = inRange; exports.nextMonth = nextMonth; exports.parseDateString = parseDateString; exports.prevMonth = prevMonth; exports.sameDate = sameDate; exports.setEndOfDay = setEndOfDay;