react-magma-dom 4.10.0-next.19 → 4.10.0-next.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -6595,6 +6595,7 @@ var CalendarContext = /*#__PURE__*/React.createContext({
6595
6595
  onPrevMonthClick: function onPrevMonthClick() {},
6596
6596
  onNextMonthClick: function onNextMonthClick() {},
6597
6597
  setDateFocused: function setDateFocused(value) {},
6598
+ setFocusedDate: function setFocusedDate(day) {},
6598
6599
  setFocusedTodayDate: function setFocusedTodayDate(event) {}
6599
6600
  });
6600
6601
 
@@ -6916,7 +6917,7 @@ var CalendarDayCell = /*#__PURE__*/_styled("td", {
6916
6917
  return props.theme.typeScale.size03.lineHeight;
6917
6918
  }, ";height:", function (props) {
6918
6919
  return props.theme.spaceScale.spacing09;
6919
- }, ";padding:0;position:relative;text-align:center;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AAgEkC","file":"CalendarDay.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { isAfter, isBefore, isSameDay, isSameMonth } from 'date-fns';\r\nimport { enUS } from 'date-fns/locale';\r\nimport { transparentize } from 'polished';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { i18nFormat as format } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nfunction getCalendarDayBackground(isInverse, isChosen, theme) {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.tertiary : theme.colors.primary;\r\n    }\r\n    return isChosen ? theme.colors.primary : theme.colors.neutral100;\r\n}\r\nconst getTodayColor = (isChosen, isInverse, theme) => {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.primary600 : theme.colors.secondary500;\r\n    }\r\n    return isChosen ? theme.colors.neutral100 : theme.colors.primary500;\r\n};\r\nconst getChosenDayColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n};\r\nconst getDisabledColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.6, theme.colors.neutral100)\r\n        : transparentize(0.4, theme.colors.neutral500);\r\n};\r\nconst getNotCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.3, theme.colors.neutral100)\r\n        : theme.colors.neutral500;\r\n};\r\nconst getCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.neutral100 : theme.colors.neutral700;\r\n};\r\nconst getCalendarDayColor = (state, isInverse, theme) => {\r\n    if (state.isToday)\r\n        return getTodayColor(state.isChosen, isInverse, theme);\r\n    if (state.disabled)\r\n        return getDisabledColor(isInverse, theme);\r\n    if (state.isChosen)\r\n        return getChosenDayColor(isInverse, theme);\r\n    if (!state.isDayInCurrentMonth && !state.disabled)\r\n        return getNotCurrentMonthColor(isInverse, theme);\r\n    return getCurrentMonthColor(isInverse, theme);\r\n};\r\nfunction getChosenDayBorder(isInverse, isChosen, theme) {\r\n    if (isChosen) {\r\n        return `1px solid ${isInverse ? theme.colors.primary600 : theme.colors.neutral100}`;\r\n    }\r\n}\r\nfunction getChosenDayHover(isChosen, isInverse, theme) {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.neutral200 : theme.colors.primary600;\r\n    }\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral200;\r\n}\r\nconst getCalendarDayFontSize = (state) => {\r\n    if (state.isToday)\r\n        return 700;\r\n    return !state.isDayInCurrentMonth || state.disabled ? 400 : 500;\r\n};\r\nconst CalendarDayCell = styled.td `\n  color: ${props => props.isInverse ? props.theme.colors.danger : props.theme.colors.neutral};\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  height: ${props => props.theme.spaceScale.spacing09};\n  padding: 0;\n  position: relative;\n  text-align: center;\n`;\r\nconst CalendarDayInner = styled.button `\n  align-items: center;\n  background: ${props => getCalendarDayBackground(props.isInverse, props.state.isChosen, props.theme)};\n  border: 2px solid transparent;\n  color: ${props => getCalendarDayColor(props.state, props.isInverse, props.theme)};\n  font-weight: ${props => getCalendarDayFontSize(props.state)};\n  cursor: ${props => (props.state.disabled ? 'not-allowed' : 'pointer')};\n  display: flex;\n  height: ${props => props.theme.spaceScale.spacing09};\n  justify-content: center;\n  overflow: hidden;\n  outline-offset: 0;\n  position: relative;\n  transition: background 0.5s ease-in-out 0s;\n  width: 43px;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    border: ${props => getChosenDayBorder(props.isInverse, props.state.isChosen, props.theme)};\n    width: ${props => props.theme.spaceScale.spacing09};\n    height: 36px;\n    margin: 1px;\n  }\n\n  &:before {\n    background: ${props => props.isInverse\r\n    ? props.theme.colors.danger200\r\n    : props.theme.colors.neutral};\n    content: '';\n    height: 200%;\n    left: 0;\n    opacity: 0;\n    position: absolute;\n    top: -50%;\n    transition: 0.2s;\n    width: 200%;\n  }\n\n  &:hover {\n    &:before {\n      opacity: ${props => (props.state.disabled ? 0 : 0.1)};\n    }\n    border: none;\n    background: ${props => getChosenDayHover(props.state.isChosen, props.isInverse, props.theme)};\n  }\n`;\r\nconst EmptyCell = styled.td `\n  border: 0;\n  padding: 0;\n`;\r\nconst TodayIndicator = styled.span `\n  position: absolute;\n  bottom: 5px;\n  left: 19px;\n  width: 5px;\n  height: 5px;\n  border-radius: 50%;\n  background: ${props => getTodayColor(props.isChosen, props.isInverse, props.theme)};\n`;\r\nexport const CalendarDay = (props) => {\r\n    const dayRef = React.useRef();\r\n    const { dateFocused, focusedDate, chosenDate, maxDate, minDate, setDateFocused, onDateChange, isInverse, } = React.useContext(CalendarContext);\r\n    const [focused, setFocused] = React.useState(false);\r\n    const { day } = props;\r\n    React.useEffect(() => {\r\n        if (dateFocused && isSameDay(day, focusedDate)) {\r\n            dayRef.current.focus();\r\n            setFocused(true);\r\n        }\r\n        else {\r\n            if (focused) {\r\n                setFocused(false);\r\n            }\r\n        }\r\n    }, [focusedDate, dateFocused]);\r\n    function onCalendarDayFocus() {\r\n        setDateFocused(true);\r\n    }\r\n    function onDayClick(event) {\r\n        if (disabled) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        onDateChange(day, event);\r\n    }\r\n    const disabled = (maxDate ? isAfter(props.day, maxDate) : false) ||\r\n        (minDate ? isBefore(props.day, minDate) : false);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    if (day) {\r\n        const sameDateAsFocusedDate = isSameDay(day, focusedDate);\r\n        const sameDateAsChosenDate = isSameDay(day, chosenDate);\r\n        const sameDateAsToday = isSameDay(day, new Date());\r\n        const isDayInCurrentMonth = isSameMonth(day, focusedDate);\r\n        const locale = i18n.locale || enUS;\r\n        const ariaLabel = `${disabled ? i18n.datePicker.disabledDayAriaLabel : ''} ${format(day, 'EEEE, MMMM do yyyy', locale)} ${sameDateAsToday ? i18n.datePicker.todayAriaLabel : ''} ${sameDateAsChosenDate ? i18n.datePicker.selectedDayAriaLabel : ''}`;\r\n        const dayState = {\r\n            isChosen: sameDateAsChosenDate,\r\n            disabled,\r\n            isDayInCurrentMonth,\r\n            isToday: sameDateAsToday,\r\n        };\r\n        return (React.createElement(CalendarDayCell, { onFocus: onCalendarDayFocus, isInverse: isInverse, theme: theme },\r\n            React.createElement(CalendarDayInner, { \"aria-disabled\": disabled, \"aria-label\": ariaLabel, \"aria-current\": sameDateAsToday ? 'date' : undefined, \"aria-selected\": sameDateAsChosenDate, \"data-testid\": \"calendar-day\", state: dayState, isInverse: isInverse, onClick: onDayClick, ref: dayRef, tabIndex: sameDateAsFocusedDate ? 0 : -1, type: \"button\", theme: theme }, format(day, 'd', locale)),\r\n            sameDateAsToday && (React.createElement(TodayIndicator, { \"data-testid\": \"todayIndicator\", isInverse: isInverse, isChosen: sameDateAsChosenDate, theme: theme }))));\r\n    }\r\n    else {\r\n        return React.createElement(EmptyCell, null);\r\n    }\r\n};\r\n//# sourceMappingURL=CalendarDay.js.map"]} */"));
6920
+ }, ";padding:0;position:relative;text-align:center;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AAgEkC","file":"CalendarDay.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { isAfter, isBefore, isSameDay, isSameMonth } from 'date-fns';\r\nimport { enUS } from 'date-fns/locale';\r\nimport { transparentize } from 'polished';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { i18nFormat as format } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nfunction getCalendarDayBackground(isInverse, isChosen, theme) {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.tertiary : theme.colors.primary;\r\n    }\r\n    return isChosen ? theme.colors.primary : theme.colors.neutral100;\r\n}\r\nconst getTodayColor = (isChosen, isInverse, theme) => {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.primary600 : theme.colors.secondary500;\r\n    }\r\n    return isChosen ? theme.colors.neutral100 : theme.colors.primary500;\r\n};\r\nconst getChosenDayColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n};\r\nconst getDisabledColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.6, theme.colors.neutral100)\r\n        : transparentize(0.4, theme.colors.neutral500);\r\n};\r\nconst getNotCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.3, theme.colors.neutral100)\r\n        : theme.colors.neutral500;\r\n};\r\nconst getCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.neutral100 : theme.colors.neutral700;\r\n};\r\nconst getCalendarDayColor = (state, isInverse, theme) => {\r\n    if (state.isToday)\r\n        return getTodayColor(state.isChosen, isInverse, theme);\r\n    if (state.disabled)\r\n        return getDisabledColor(isInverse, theme);\r\n    if (state.isChosen)\r\n        return getChosenDayColor(isInverse, theme);\r\n    if (!state.isDayInCurrentMonth && !state.disabled)\r\n        return getNotCurrentMonthColor(isInverse, theme);\r\n    return getCurrentMonthColor(isInverse, theme);\r\n};\r\nfunction getChosenDayBorder(isInverse, isChosen, theme) {\r\n    if (isChosen) {\r\n        return `1px solid ${isInverse ? theme.colors.primary600 : theme.colors.neutral100}`;\r\n    }\r\n}\r\nfunction getChosenDayHover(isChosen, isInverse, theme) {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.neutral200 : theme.colors.primary600;\r\n    }\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral200;\r\n}\r\nconst getCalendarDayFontSize = (state) => {\r\n    if (state.isToday)\r\n        return 700;\r\n    return !state.isDayInCurrentMonth || state.disabled ? 400 : 500;\r\n};\r\nconst CalendarDayCell = styled.td `\n  color: ${props => props.isInverse ? props.theme.colors.danger : props.theme.colors.neutral};\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  height: ${props => props.theme.spaceScale.spacing09};\n  padding: 0;\n  position: relative;\n  text-align: center;\n`;\r\nconst CalendarDayInner = styled.button `\n  align-items: center;\n  background: ${props => getCalendarDayBackground(props.isInverse, props.state.isChosen, props.theme)};\n  border: 2px solid transparent;\n  color: ${props => getCalendarDayColor(props.state, props.isInverse, props.theme)};\n  font-weight: ${props => getCalendarDayFontSize(props.state)};\n  cursor: ${props => (props.state.disabled ? 'not-allowed' : 'pointer')};\n  display: flex;\n  height: ${props => props.theme.spaceScale.spacing09};\n  justify-content: center;\n  overflow: hidden;\n  outline-offset: 0;\n  position: relative;\n  transition: background 0.5s ease-in-out 0s;\n  width: 43px;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    border: ${props => getChosenDayBorder(props.isInverse, props.state.isChosen, props.theme)};\n    width: ${props => props.theme.spaceScale.spacing09};\n    height: 36px;\n    margin: 1px;\n  }\n\n  &:before {\n    background: ${props => props.isInverse\r\n    ? props.theme.colors.danger200\r\n    : props.theme.colors.neutral};\n    content: '';\n    height: 200%;\n    left: 0;\n    opacity: 0;\n    position: absolute;\n    top: -50%;\n    transition: 0.2s;\n    width: 200%;\n  }\n\n  &:hover {\n    &:before {\n      opacity: ${props => (props.state.disabled ? 0 : 0.1)};\n    }\n    border: none;\n    background: ${props => getChosenDayHover(props.state.isChosen, props.isInverse, props.theme)};\n  }\n`;\r\nconst EmptyCell = styled.td `\n  border: 0;\n  padding: 0;\n`;\r\nconst TodayIndicator = styled.span `\n  position: absolute;\n  bottom: 5px;\n  left: 19px;\n  width: 5px;\n  height: 5px;\n  border-radius: 50%;\n  background: ${props => getTodayColor(props.isChosen, props.isInverse, props.theme)};\n`;\r\nexport const CalendarDay = (props) => {\r\n    const dayRef = React.useRef();\r\n    const { dateFocused, focusedDate, chosenDate, maxDate, minDate, onDateChange, setDateFocused, setFocusedDate, isInverse, } = React.useContext(CalendarContext);\r\n    const [focused, setFocused] = React.useState(false);\r\n    const { day } = props;\r\n    React.useEffect(() => {\r\n        if (dateFocused && isSameDay(day, focusedDate)) {\r\n            dayRef.current.focus();\r\n            setFocused(true);\r\n        }\r\n        else {\r\n            if (focused) {\r\n                setFocused(false);\r\n            }\r\n        }\r\n    }, [focusedDate, dateFocused]);\r\n    function onCalendarDayFocus() {\r\n        setDateFocused(true);\r\n    }\r\n    function onDayClick(event) {\r\n        if (disabled) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        onDateChange(day, event);\r\n    }\r\n    function onFocusDay(event) {\r\n        if (disabled || !isSameMonth(day, focusedDate)) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        setFocusedDate(day);\r\n    }\r\n    const disabled = (maxDate ? isAfter(props.day, maxDate) : false) ||\r\n        (minDate ? isBefore(props.day, minDate) : false);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    if (day) {\r\n        const sameDateAsFocusedDate = isSameDay(day, focusedDate);\r\n        const sameDateAsChosenDate = isSameDay(day, chosenDate);\r\n        const sameDateAsToday = isSameDay(day, new Date());\r\n        const isDayInCurrentMonth = isSameMonth(day, focusedDate);\r\n        const locale = i18n.locale || enUS;\r\n        const ariaLabel = `${disabled ? i18n.datePicker.disabledDayAriaLabel : ''} ${format(day, 'EEEE, MMMM do yyyy', locale)} ${sameDateAsToday ? i18n.datePicker.todayAriaLabel : ''} ${sameDateAsChosenDate ? i18n.datePicker.selectedDayAriaLabel : ''}`;\r\n        const dayState = {\r\n            isChosen: sameDateAsChosenDate,\r\n            disabled,\r\n            isDayInCurrentMonth,\r\n            isToday: sameDateAsToday,\r\n        };\r\n        return (React.createElement(CalendarDayCell, { onFocus: onCalendarDayFocus, isInverse: isInverse, theme: theme },\r\n            React.createElement(CalendarDayInner, { \"aria-disabled\": disabled, \"aria-label\": ariaLabel, \"aria-current\": sameDateAsToday ? 'date' : undefined, \"aria-selected\": sameDateAsChosenDate, \"data-testid\": \"calendar-day\", state: dayState, isInverse: isInverse, onClick: onDayClick, onMouseDown: onFocusDay, ref: dayRef, tabIndex: sameDateAsFocusedDate ? 0 : -1, type: \"button\", theme: theme }, format(day, 'd', locale)),\r\n            sameDateAsToday && (React.createElement(TodayIndicator, { \"data-testid\": \"todayIndicator\", isInverse: isInverse, isChosen: sameDateAsChosenDate, theme: theme }))));\r\n    }\r\n    else {\r\n        return React.createElement(EmptyCell, null);\r\n    }\r\n};\r\n//# sourceMappingURL=CalendarDay.js.map"]} */"));
6920
6921
  var CalendarDayInner = /*#__PURE__*/_styled("button", {
6921
6922
  target: "eviokpi2",
6922
6923
  label: "CalendarDayInner"
@@ -6942,13 +6943,13 @@ var CalendarDayInner = /*#__PURE__*/_styled("button", {
6942
6943
  return getChosenDayHover(props.state.isChosen, props.isInverse, props.theme);
6943
6944
  }, ";&:before{opacity:", function (props) {
6944
6945
  return props.state.disabled ? 0 : 0.1;
6945
- }, ";}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AA0EuC","file":"CalendarDay.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { isAfter, isBefore, isSameDay, isSameMonth } from 'date-fns';\r\nimport { enUS } from 'date-fns/locale';\r\nimport { transparentize } from 'polished';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { i18nFormat as format } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nfunction getCalendarDayBackground(isInverse, isChosen, theme) {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.tertiary : theme.colors.primary;\r\n    }\r\n    return isChosen ? theme.colors.primary : theme.colors.neutral100;\r\n}\r\nconst getTodayColor = (isChosen, isInverse, theme) => {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.primary600 : theme.colors.secondary500;\r\n    }\r\n    return isChosen ? theme.colors.neutral100 : theme.colors.primary500;\r\n};\r\nconst getChosenDayColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n};\r\nconst getDisabledColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.6, theme.colors.neutral100)\r\n        : transparentize(0.4, theme.colors.neutral500);\r\n};\r\nconst getNotCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.3, theme.colors.neutral100)\r\n        : theme.colors.neutral500;\r\n};\r\nconst getCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.neutral100 : theme.colors.neutral700;\r\n};\r\nconst getCalendarDayColor = (state, isInverse, theme) => {\r\n    if (state.isToday)\r\n        return getTodayColor(state.isChosen, isInverse, theme);\r\n    if (state.disabled)\r\n        return getDisabledColor(isInverse, theme);\r\n    if (state.isChosen)\r\n        return getChosenDayColor(isInverse, theme);\r\n    if (!state.isDayInCurrentMonth && !state.disabled)\r\n        return getNotCurrentMonthColor(isInverse, theme);\r\n    return getCurrentMonthColor(isInverse, theme);\r\n};\r\nfunction getChosenDayBorder(isInverse, isChosen, theme) {\r\n    if (isChosen) {\r\n        return `1px solid ${isInverse ? theme.colors.primary600 : theme.colors.neutral100}`;\r\n    }\r\n}\r\nfunction getChosenDayHover(isChosen, isInverse, theme) {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.neutral200 : theme.colors.primary600;\r\n    }\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral200;\r\n}\r\nconst getCalendarDayFontSize = (state) => {\r\n    if (state.isToday)\r\n        return 700;\r\n    return !state.isDayInCurrentMonth || state.disabled ? 400 : 500;\r\n};\r\nconst CalendarDayCell = styled.td `\n  color: ${props => props.isInverse ? props.theme.colors.danger : props.theme.colors.neutral};\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  height: ${props => props.theme.spaceScale.spacing09};\n  padding: 0;\n  position: relative;\n  text-align: center;\n`;\r\nconst CalendarDayInner = styled.button `\n  align-items: center;\n  background: ${props => getCalendarDayBackground(props.isInverse, props.state.isChosen, props.theme)};\n  border: 2px solid transparent;\n  color: ${props => getCalendarDayColor(props.state, props.isInverse, props.theme)};\n  font-weight: ${props => getCalendarDayFontSize(props.state)};\n  cursor: ${props => (props.state.disabled ? 'not-allowed' : 'pointer')};\n  display: flex;\n  height: ${props => props.theme.spaceScale.spacing09};\n  justify-content: center;\n  overflow: hidden;\n  outline-offset: 0;\n  position: relative;\n  transition: background 0.5s ease-in-out 0s;\n  width: 43px;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    border: ${props => getChosenDayBorder(props.isInverse, props.state.isChosen, props.theme)};\n    width: ${props => props.theme.spaceScale.spacing09};\n    height: 36px;\n    margin: 1px;\n  }\n\n  &:before {\n    background: ${props => props.isInverse\r\n    ? props.theme.colors.danger200\r\n    : props.theme.colors.neutral};\n    content: '';\n    height: 200%;\n    left: 0;\n    opacity: 0;\n    position: absolute;\n    top: -50%;\n    transition: 0.2s;\n    width: 200%;\n  }\n\n  &:hover {\n    &:before {\n      opacity: ${props => (props.state.disabled ? 0 : 0.1)};\n    }\n    border: none;\n    background: ${props => getChosenDayHover(props.state.isChosen, props.isInverse, props.theme)};\n  }\n`;\r\nconst EmptyCell = styled.td `\n  border: 0;\n  padding: 0;\n`;\r\nconst TodayIndicator = styled.span `\n  position: absolute;\n  bottom: 5px;\n  left: 19px;\n  width: 5px;\n  height: 5px;\n  border-radius: 50%;\n  background: ${props => getTodayColor(props.isChosen, props.isInverse, props.theme)};\n`;\r\nexport const CalendarDay = (props) => {\r\n    const dayRef = React.useRef();\r\n    const { dateFocused, focusedDate, chosenDate, maxDate, minDate, setDateFocused, onDateChange, isInverse, } = React.useContext(CalendarContext);\r\n    const [focused, setFocused] = React.useState(false);\r\n    const { day } = props;\r\n    React.useEffect(() => {\r\n        if (dateFocused && isSameDay(day, focusedDate)) {\r\n            dayRef.current.focus();\r\n            setFocused(true);\r\n        }\r\n        else {\r\n            if (focused) {\r\n                setFocused(false);\r\n            }\r\n        }\r\n    }, [focusedDate, dateFocused]);\r\n    function onCalendarDayFocus() {\r\n        setDateFocused(true);\r\n    }\r\n    function onDayClick(event) {\r\n        if (disabled) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        onDateChange(day, event);\r\n    }\r\n    const disabled = (maxDate ? isAfter(props.day, maxDate) : false) ||\r\n        (minDate ? isBefore(props.day, minDate) : false);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    if (day) {\r\n        const sameDateAsFocusedDate = isSameDay(day, focusedDate);\r\n        const sameDateAsChosenDate = isSameDay(day, chosenDate);\r\n        const sameDateAsToday = isSameDay(day, new Date());\r\n        const isDayInCurrentMonth = isSameMonth(day, focusedDate);\r\n        const locale = i18n.locale || enUS;\r\n        const ariaLabel = `${disabled ? i18n.datePicker.disabledDayAriaLabel : ''} ${format(day, 'EEEE, MMMM do yyyy', locale)} ${sameDateAsToday ? i18n.datePicker.todayAriaLabel : ''} ${sameDateAsChosenDate ? i18n.datePicker.selectedDayAriaLabel : ''}`;\r\n        const dayState = {\r\n            isChosen: sameDateAsChosenDate,\r\n            disabled,\r\n            isDayInCurrentMonth,\r\n            isToday: sameDateAsToday,\r\n        };\r\n        return (React.createElement(CalendarDayCell, { onFocus: onCalendarDayFocus, isInverse: isInverse, theme: theme },\r\n            React.createElement(CalendarDayInner, { \"aria-disabled\": disabled, \"aria-label\": ariaLabel, \"aria-current\": sameDateAsToday ? 'date' : undefined, \"aria-selected\": sameDateAsChosenDate, \"data-testid\": \"calendar-day\", state: dayState, isInverse: isInverse, onClick: onDayClick, ref: dayRef, tabIndex: sameDateAsFocusedDate ? 0 : -1, type: \"button\", theme: theme }, format(day, 'd', locale)),\r\n            sameDateAsToday && (React.createElement(TodayIndicator, { \"data-testid\": \"todayIndicator\", isInverse: isInverse, isChosen: sameDateAsChosenDate, theme: theme }))));\r\n    }\r\n    else {\r\n        return React.createElement(EmptyCell, null);\r\n    }\r\n};\r\n//# sourceMappingURL=CalendarDay.js.map"]} */"));
6946
+ }, ";}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AA0EuC","file":"CalendarDay.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { isAfter, isBefore, isSameDay, isSameMonth } from 'date-fns';\r\nimport { enUS } from 'date-fns/locale';\r\nimport { transparentize } from 'polished';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { i18nFormat as format } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nfunction getCalendarDayBackground(isInverse, isChosen, theme) {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.tertiary : theme.colors.primary;\r\n    }\r\n    return isChosen ? theme.colors.primary : theme.colors.neutral100;\r\n}\r\nconst getTodayColor = (isChosen, isInverse, theme) => {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.primary600 : theme.colors.secondary500;\r\n    }\r\n    return isChosen ? theme.colors.neutral100 : theme.colors.primary500;\r\n};\r\nconst getChosenDayColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n};\r\nconst getDisabledColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.6, theme.colors.neutral100)\r\n        : transparentize(0.4, theme.colors.neutral500);\r\n};\r\nconst getNotCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.3, theme.colors.neutral100)\r\n        : theme.colors.neutral500;\r\n};\r\nconst getCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.neutral100 : theme.colors.neutral700;\r\n};\r\nconst getCalendarDayColor = (state, isInverse, theme) => {\r\n    if (state.isToday)\r\n        return getTodayColor(state.isChosen, isInverse, theme);\r\n    if (state.disabled)\r\n        return getDisabledColor(isInverse, theme);\r\n    if (state.isChosen)\r\n        return getChosenDayColor(isInverse, theme);\r\n    if (!state.isDayInCurrentMonth && !state.disabled)\r\n        return getNotCurrentMonthColor(isInverse, theme);\r\n    return getCurrentMonthColor(isInverse, theme);\r\n};\r\nfunction getChosenDayBorder(isInverse, isChosen, theme) {\r\n    if (isChosen) {\r\n        return `1px solid ${isInverse ? theme.colors.primary600 : theme.colors.neutral100}`;\r\n    }\r\n}\r\nfunction getChosenDayHover(isChosen, isInverse, theme) {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.neutral200 : theme.colors.primary600;\r\n    }\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral200;\r\n}\r\nconst getCalendarDayFontSize = (state) => {\r\n    if (state.isToday)\r\n        return 700;\r\n    return !state.isDayInCurrentMonth || state.disabled ? 400 : 500;\r\n};\r\nconst CalendarDayCell = styled.td `\n  color: ${props => props.isInverse ? props.theme.colors.danger : props.theme.colors.neutral};\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  height: ${props => props.theme.spaceScale.spacing09};\n  padding: 0;\n  position: relative;\n  text-align: center;\n`;\r\nconst CalendarDayInner = styled.button `\n  align-items: center;\n  background: ${props => getCalendarDayBackground(props.isInverse, props.state.isChosen, props.theme)};\n  border: 2px solid transparent;\n  color: ${props => getCalendarDayColor(props.state, props.isInverse, props.theme)};\n  font-weight: ${props => getCalendarDayFontSize(props.state)};\n  cursor: ${props => (props.state.disabled ? 'not-allowed' : 'pointer')};\n  display: flex;\n  height: ${props => props.theme.spaceScale.spacing09};\n  justify-content: center;\n  overflow: hidden;\n  outline-offset: 0;\n  position: relative;\n  transition: background 0.5s ease-in-out 0s;\n  width: 43px;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    border: ${props => getChosenDayBorder(props.isInverse, props.state.isChosen, props.theme)};\n    width: ${props => props.theme.spaceScale.spacing09};\n    height: 36px;\n    margin: 1px;\n  }\n\n  &:before {\n    background: ${props => props.isInverse\r\n    ? props.theme.colors.danger200\r\n    : props.theme.colors.neutral};\n    content: '';\n    height: 200%;\n    left: 0;\n    opacity: 0;\n    position: absolute;\n    top: -50%;\n    transition: 0.2s;\n    width: 200%;\n  }\n\n  &:hover {\n    &:before {\n      opacity: ${props => (props.state.disabled ? 0 : 0.1)};\n    }\n    border: none;\n    background: ${props => getChosenDayHover(props.state.isChosen, props.isInverse, props.theme)};\n  }\n`;\r\nconst EmptyCell = styled.td `\n  border: 0;\n  padding: 0;\n`;\r\nconst TodayIndicator = styled.span `\n  position: absolute;\n  bottom: 5px;\n  left: 19px;\n  width: 5px;\n  height: 5px;\n  border-radius: 50%;\n  background: ${props => getTodayColor(props.isChosen, props.isInverse, props.theme)};\n`;\r\nexport const CalendarDay = (props) => {\r\n    const dayRef = React.useRef();\r\n    const { dateFocused, focusedDate, chosenDate, maxDate, minDate, onDateChange, setDateFocused, setFocusedDate, isInverse, } = React.useContext(CalendarContext);\r\n    const [focused, setFocused] = React.useState(false);\r\n    const { day } = props;\r\n    React.useEffect(() => {\r\n        if (dateFocused && isSameDay(day, focusedDate)) {\r\n            dayRef.current.focus();\r\n            setFocused(true);\r\n        }\r\n        else {\r\n            if (focused) {\r\n                setFocused(false);\r\n            }\r\n        }\r\n    }, [focusedDate, dateFocused]);\r\n    function onCalendarDayFocus() {\r\n        setDateFocused(true);\r\n    }\r\n    function onDayClick(event) {\r\n        if (disabled) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        onDateChange(day, event);\r\n    }\r\n    function onFocusDay(event) {\r\n        if (disabled || !isSameMonth(day, focusedDate)) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        setFocusedDate(day);\r\n    }\r\n    const disabled = (maxDate ? isAfter(props.day, maxDate) : false) ||\r\n        (minDate ? isBefore(props.day, minDate) : false);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    if (day) {\r\n        const sameDateAsFocusedDate = isSameDay(day, focusedDate);\r\n        const sameDateAsChosenDate = isSameDay(day, chosenDate);\r\n        const sameDateAsToday = isSameDay(day, new Date());\r\n        const isDayInCurrentMonth = isSameMonth(day, focusedDate);\r\n        const locale = i18n.locale || enUS;\r\n        const ariaLabel = `${disabled ? i18n.datePicker.disabledDayAriaLabel : ''} ${format(day, 'EEEE, MMMM do yyyy', locale)} ${sameDateAsToday ? i18n.datePicker.todayAriaLabel : ''} ${sameDateAsChosenDate ? i18n.datePicker.selectedDayAriaLabel : ''}`;\r\n        const dayState = {\r\n            isChosen: sameDateAsChosenDate,\r\n            disabled,\r\n            isDayInCurrentMonth,\r\n            isToday: sameDateAsToday,\r\n        };\r\n        return (React.createElement(CalendarDayCell, { onFocus: onCalendarDayFocus, isInverse: isInverse, theme: theme },\r\n            React.createElement(CalendarDayInner, { \"aria-disabled\": disabled, \"aria-label\": ariaLabel, \"aria-current\": sameDateAsToday ? 'date' : undefined, \"aria-selected\": sameDateAsChosenDate, \"data-testid\": \"calendar-day\", state: dayState, isInverse: isInverse, onClick: onDayClick, onMouseDown: onFocusDay, ref: dayRef, tabIndex: sameDateAsFocusedDate ? 0 : -1, type: \"button\", theme: theme }, format(day, 'd', locale)),\r\n            sameDateAsToday && (React.createElement(TodayIndicator, { \"data-testid\": \"todayIndicator\", isInverse: isInverse, isChosen: sameDateAsChosenDate, theme: theme }))));\r\n    }\r\n    else {\r\n        return React.createElement(EmptyCell, null);\r\n    }\r\n};\r\n//# sourceMappingURL=CalendarDay.js.map"]} */"));
6946
6947
  var EmptyCell = /*#__PURE__*/_styled("td", {
6947
6948
  target: "eviokpi1",
6948
6949
  label: "EmptyCell"
6949
6950
  })( {
6950
6951
  name: "1njmmm4",
6951
- styles: "border:0;padding:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AA2H4B","file":"CalendarDay.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { isAfter, isBefore, isSameDay, isSameMonth } from 'date-fns';\r\nimport { enUS } from 'date-fns/locale';\r\nimport { transparentize } from 'polished';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { i18nFormat as format } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nfunction getCalendarDayBackground(isInverse, isChosen, theme) {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.tertiary : theme.colors.primary;\r\n    }\r\n    return isChosen ? theme.colors.primary : theme.colors.neutral100;\r\n}\r\nconst getTodayColor = (isChosen, isInverse, theme) => {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.primary600 : theme.colors.secondary500;\r\n    }\r\n    return isChosen ? theme.colors.neutral100 : theme.colors.primary500;\r\n};\r\nconst getChosenDayColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n};\r\nconst getDisabledColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.6, theme.colors.neutral100)\r\n        : transparentize(0.4, theme.colors.neutral500);\r\n};\r\nconst getNotCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.3, theme.colors.neutral100)\r\n        : theme.colors.neutral500;\r\n};\r\nconst getCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.neutral100 : theme.colors.neutral700;\r\n};\r\nconst getCalendarDayColor = (state, isInverse, theme) => {\r\n    if (state.isToday)\r\n        return getTodayColor(state.isChosen, isInverse, theme);\r\n    if (state.disabled)\r\n        return getDisabledColor(isInverse, theme);\r\n    if (state.isChosen)\r\n        return getChosenDayColor(isInverse, theme);\r\n    if (!state.isDayInCurrentMonth && !state.disabled)\r\n        return getNotCurrentMonthColor(isInverse, theme);\r\n    return getCurrentMonthColor(isInverse, theme);\r\n};\r\nfunction getChosenDayBorder(isInverse, isChosen, theme) {\r\n    if (isChosen) {\r\n        return `1px solid ${isInverse ? theme.colors.primary600 : theme.colors.neutral100}`;\r\n    }\r\n}\r\nfunction getChosenDayHover(isChosen, isInverse, theme) {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.neutral200 : theme.colors.primary600;\r\n    }\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral200;\r\n}\r\nconst getCalendarDayFontSize = (state) => {\r\n    if (state.isToday)\r\n        return 700;\r\n    return !state.isDayInCurrentMonth || state.disabled ? 400 : 500;\r\n};\r\nconst CalendarDayCell = styled.td `\n  color: ${props => props.isInverse ? props.theme.colors.danger : props.theme.colors.neutral};\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  height: ${props => props.theme.spaceScale.spacing09};\n  padding: 0;\n  position: relative;\n  text-align: center;\n`;\r\nconst CalendarDayInner = styled.button `\n  align-items: center;\n  background: ${props => getCalendarDayBackground(props.isInverse, props.state.isChosen, props.theme)};\n  border: 2px solid transparent;\n  color: ${props => getCalendarDayColor(props.state, props.isInverse, props.theme)};\n  font-weight: ${props => getCalendarDayFontSize(props.state)};\n  cursor: ${props => (props.state.disabled ? 'not-allowed' : 'pointer')};\n  display: flex;\n  height: ${props => props.theme.spaceScale.spacing09};\n  justify-content: center;\n  overflow: hidden;\n  outline-offset: 0;\n  position: relative;\n  transition: background 0.5s ease-in-out 0s;\n  width: 43px;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    border: ${props => getChosenDayBorder(props.isInverse, props.state.isChosen, props.theme)};\n    width: ${props => props.theme.spaceScale.spacing09};\n    height: 36px;\n    margin: 1px;\n  }\n\n  &:before {\n    background: ${props => props.isInverse\r\n    ? props.theme.colors.danger200\r\n    : props.theme.colors.neutral};\n    content: '';\n    height: 200%;\n    left: 0;\n    opacity: 0;\n    position: absolute;\n    top: -50%;\n    transition: 0.2s;\n    width: 200%;\n  }\n\n  &:hover {\n    &:before {\n      opacity: ${props => (props.state.disabled ? 0 : 0.1)};\n    }\n    border: none;\n    background: ${props => getChosenDayHover(props.state.isChosen, props.isInverse, props.theme)};\n  }\n`;\r\nconst EmptyCell = styled.td `\n  border: 0;\n  padding: 0;\n`;\r\nconst TodayIndicator = styled.span `\n  position: absolute;\n  bottom: 5px;\n  left: 19px;\n  width: 5px;\n  height: 5px;\n  border-radius: 50%;\n  background: ${props => getTodayColor(props.isChosen, props.isInverse, props.theme)};\n`;\r\nexport const CalendarDay = (props) => {\r\n    const dayRef = React.useRef();\r\n    const { dateFocused, focusedDate, chosenDate, maxDate, minDate, setDateFocused, onDateChange, isInverse, } = React.useContext(CalendarContext);\r\n    const [focused, setFocused] = React.useState(false);\r\n    const { day } = props;\r\n    React.useEffect(() => {\r\n        if (dateFocused && isSameDay(day, focusedDate)) {\r\n            dayRef.current.focus();\r\n            setFocused(true);\r\n        }\r\n        else {\r\n            if (focused) {\r\n                setFocused(false);\r\n            }\r\n        }\r\n    }, [focusedDate, dateFocused]);\r\n    function onCalendarDayFocus() {\r\n        setDateFocused(true);\r\n    }\r\n    function onDayClick(event) {\r\n        if (disabled) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        onDateChange(day, event);\r\n    }\r\n    const disabled = (maxDate ? isAfter(props.day, maxDate) : false) ||\r\n        (minDate ? isBefore(props.day, minDate) : false);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    if (day) {\r\n        const sameDateAsFocusedDate = isSameDay(day, focusedDate);\r\n        const sameDateAsChosenDate = isSameDay(day, chosenDate);\r\n        const sameDateAsToday = isSameDay(day, new Date());\r\n        const isDayInCurrentMonth = isSameMonth(day, focusedDate);\r\n        const locale = i18n.locale || enUS;\r\n        const ariaLabel = `${disabled ? i18n.datePicker.disabledDayAriaLabel : ''} ${format(day, 'EEEE, MMMM do yyyy', locale)} ${sameDateAsToday ? i18n.datePicker.todayAriaLabel : ''} ${sameDateAsChosenDate ? i18n.datePicker.selectedDayAriaLabel : ''}`;\r\n        const dayState = {\r\n            isChosen: sameDateAsChosenDate,\r\n            disabled,\r\n            isDayInCurrentMonth,\r\n            isToday: sameDateAsToday,\r\n        };\r\n        return (React.createElement(CalendarDayCell, { onFocus: onCalendarDayFocus, isInverse: isInverse, theme: theme },\r\n            React.createElement(CalendarDayInner, { \"aria-disabled\": disabled, \"aria-label\": ariaLabel, \"aria-current\": sameDateAsToday ? 'date' : undefined, \"aria-selected\": sameDateAsChosenDate, \"data-testid\": \"calendar-day\", state: dayState, isInverse: isInverse, onClick: onDayClick, ref: dayRef, tabIndex: sameDateAsFocusedDate ? 0 : -1, type: \"button\", theme: theme }, format(day, 'd', locale)),\r\n            sameDateAsToday && (React.createElement(TodayIndicator, { \"data-testid\": \"todayIndicator\", isInverse: isInverse, isChosen: sameDateAsChosenDate, theme: theme }))));\r\n    }\r\n    else {\r\n        return React.createElement(EmptyCell, null);\r\n    }\r\n};\r\n//# sourceMappingURL=CalendarDay.js.map"]} */",
6952
+ styles: "border:0;padding:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AA2H4B","file":"CalendarDay.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { isAfter, isBefore, isSameDay, isSameMonth } from 'date-fns';\r\nimport { enUS } from 'date-fns/locale';\r\nimport { transparentize } from 'polished';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { i18nFormat as format } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nfunction getCalendarDayBackground(isInverse, isChosen, theme) {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.tertiary : theme.colors.primary;\r\n    }\r\n    return isChosen ? theme.colors.primary : theme.colors.neutral100;\r\n}\r\nconst getTodayColor = (isChosen, isInverse, theme) => {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.primary600 : theme.colors.secondary500;\r\n    }\r\n    return isChosen ? theme.colors.neutral100 : theme.colors.primary500;\r\n};\r\nconst getChosenDayColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n};\r\nconst getDisabledColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.6, theme.colors.neutral100)\r\n        : transparentize(0.4, theme.colors.neutral500);\r\n};\r\nconst getNotCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.3, theme.colors.neutral100)\r\n        : theme.colors.neutral500;\r\n};\r\nconst getCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.neutral100 : theme.colors.neutral700;\r\n};\r\nconst getCalendarDayColor = (state, isInverse, theme) => {\r\n    if (state.isToday)\r\n        return getTodayColor(state.isChosen, isInverse, theme);\r\n    if (state.disabled)\r\n        return getDisabledColor(isInverse, theme);\r\n    if (state.isChosen)\r\n        return getChosenDayColor(isInverse, theme);\r\n    if (!state.isDayInCurrentMonth && !state.disabled)\r\n        return getNotCurrentMonthColor(isInverse, theme);\r\n    return getCurrentMonthColor(isInverse, theme);\r\n};\r\nfunction getChosenDayBorder(isInverse, isChosen, theme) {\r\n    if (isChosen) {\r\n        return `1px solid ${isInverse ? theme.colors.primary600 : theme.colors.neutral100}`;\r\n    }\r\n}\r\nfunction getChosenDayHover(isChosen, isInverse, theme) {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.neutral200 : theme.colors.primary600;\r\n    }\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral200;\r\n}\r\nconst getCalendarDayFontSize = (state) => {\r\n    if (state.isToday)\r\n        return 700;\r\n    return !state.isDayInCurrentMonth || state.disabled ? 400 : 500;\r\n};\r\nconst CalendarDayCell = styled.td `\n  color: ${props => props.isInverse ? props.theme.colors.danger : props.theme.colors.neutral};\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  height: ${props => props.theme.spaceScale.spacing09};\n  padding: 0;\n  position: relative;\n  text-align: center;\n`;\r\nconst CalendarDayInner = styled.button `\n  align-items: center;\n  background: ${props => getCalendarDayBackground(props.isInverse, props.state.isChosen, props.theme)};\n  border: 2px solid transparent;\n  color: ${props => getCalendarDayColor(props.state, props.isInverse, props.theme)};\n  font-weight: ${props => getCalendarDayFontSize(props.state)};\n  cursor: ${props => (props.state.disabled ? 'not-allowed' : 'pointer')};\n  display: flex;\n  height: ${props => props.theme.spaceScale.spacing09};\n  justify-content: center;\n  overflow: hidden;\n  outline-offset: 0;\n  position: relative;\n  transition: background 0.5s ease-in-out 0s;\n  width: 43px;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    border: ${props => getChosenDayBorder(props.isInverse, props.state.isChosen, props.theme)};\n    width: ${props => props.theme.spaceScale.spacing09};\n    height: 36px;\n    margin: 1px;\n  }\n\n  &:before {\n    background: ${props => props.isInverse\r\n    ? props.theme.colors.danger200\r\n    : props.theme.colors.neutral};\n    content: '';\n    height: 200%;\n    left: 0;\n    opacity: 0;\n    position: absolute;\n    top: -50%;\n    transition: 0.2s;\n    width: 200%;\n  }\n\n  &:hover {\n    &:before {\n      opacity: ${props => (props.state.disabled ? 0 : 0.1)};\n    }\n    border: none;\n    background: ${props => getChosenDayHover(props.state.isChosen, props.isInverse, props.theme)};\n  }\n`;\r\nconst EmptyCell = styled.td `\n  border: 0;\n  padding: 0;\n`;\r\nconst TodayIndicator = styled.span `\n  position: absolute;\n  bottom: 5px;\n  left: 19px;\n  width: 5px;\n  height: 5px;\n  border-radius: 50%;\n  background: ${props => getTodayColor(props.isChosen, props.isInverse, props.theme)};\n`;\r\nexport const CalendarDay = (props) => {\r\n    const dayRef = React.useRef();\r\n    const { dateFocused, focusedDate, chosenDate, maxDate, minDate, onDateChange, setDateFocused, setFocusedDate, isInverse, } = React.useContext(CalendarContext);\r\n    const [focused, setFocused] = React.useState(false);\r\n    const { day } = props;\r\n    React.useEffect(() => {\r\n        if (dateFocused && isSameDay(day, focusedDate)) {\r\n            dayRef.current.focus();\r\n            setFocused(true);\r\n        }\r\n        else {\r\n            if (focused) {\r\n                setFocused(false);\r\n            }\r\n        }\r\n    }, [focusedDate, dateFocused]);\r\n    function onCalendarDayFocus() {\r\n        setDateFocused(true);\r\n    }\r\n    function onDayClick(event) {\r\n        if (disabled) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        onDateChange(day, event);\r\n    }\r\n    function onFocusDay(event) {\r\n        if (disabled || !isSameMonth(day, focusedDate)) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        setFocusedDate(day);\r\n    }\r\n    const disabled = (maxDate ? isAfter(props.day, maxDate) : false) ||\r\n        (minDate ? isBefore(props.day, minDate) : false);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    if (day) {\r\n        const sameDateAsFocusedDate = isSameDay(day, focusedDate);\r\n        const sameDateAsChosenDate = isSameDay(day, chosenDate);\r\n        const sameDateAsToday = isSameDay(day, new Date());\r\n        const isDayInCurrentMonth = isSameMonth(day, focusedDate);\r\n        const locale = i18n.locale || enUS;\r\n        const ariaLabel = `${disabled ? i18n.datePicker.disabledDayAriaLabel : ''} ${format(day, 'EEEE, MMMM do yyyy', locale)} ${sameDateAsToday ? i18n.datePicker.todayAriaLabel : ''} ${sameDateAsChosenDate ? i18n.datePicker.selectedDayAriaLabel : ''}`;\r\n        const dayState = {\r\n            isChosen: sameDateAsChosenDate,\r\n            disabled,\r\n            isDayInCurrentMonth,\r\n            isToday: sameDateAsToday,\r\n        };\r\n        return (React.createElement(CalendarDayCell, { onFocus: onCalendarDayFocus, isInverse: isInverse, theme: theme },\r\n            React.createElement(CalendarDayInner, { \"aria-disabled\": disabled, \"aria-label\": ariaLabel, \"aria-current\": sameDateAsToday ? 'date' : undefined, \"aria-selected\": sameDateAsChosenDate, \"data-testid\": \"calendar-day\", state: dayState, isInverse: isInverse, onClick: onDayClick, onMouseDown: onFocusDay, ref: dayRef, tabIndex: sameDateAsFocusedDate ? 0 : -1, type: \"button\", theme: theme }, format(day, 'd', locale)),\r\n            sameDateAsToday && (React.createElement(TodayIndicator, { \"data-testid\": \"todayIndicator\", isInverse: isInverse, isChosen: sameDateAsChosenDate, theme: theme }))));\r\n    }\r\n    else {\r\n        return React.createElement(EmptyCell, null);\r\n    }\r\n};\r\n//# sourceMappingURL=CalendarDay.js.map"]} */",
6952
6953
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$g
6953
6954
  });
6954
6955
  var TodayIndicator = /*#__PURE__*/_styled("span", {
@@ -6956,7 +6957,7 @@ var TodayIndicator = /*#__PURE__*/_styled("span", {
6956
6957
  label: "TodayIndicator"
6957
6958
  })("position:absolute;bottom:5px;left:19px;width:5px;height:5px;border-radius:50%;background:", function (props) {
6958
6959
  return getTodayColor(props.isChosen, props.isInverse, props.theme);
6959
- }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AA+HmC","file":"CalendarDay.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { isAfter, isBefore, isSameDay, isSameMonth } from 'date-fns';\r\nimport { enUS } from 'date-fns/locale';\r\nimport { transparentize } from 'polished';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { i18nFormat as format } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nfunction getCalendarDayBackground(isInverse, isChosen, theme) {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.tertiary : theme.colors.primary;\r\n    }\r\n    return isChosen ? theme.colors.primary : theme.colors.neutral100;\r\n}\r\nconst getTodayColor = (isChosen, isInverse, theme) => {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.primary600 : theme.colors.secondary500;\r\n    }\r\n    return isChosen ? theme.colors.neutral100 : theme.colors.primary500;\r\n};\r\nconst getChosenDayColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n};\r\nconst getDisabledColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.6, theme.colors.neutral100)\r\n        : transparentize(0.4, theme.colors.neutral500);\r\n};\r\nconst getNotCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.3, theme.colors.neutral100)\r\n        : theme.colors.neutral500;\r\n};\r\nconst getCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.neutral100 : theme.colors.neutral700;\r\n};\r\nconst getCalendarDayColor = (state, isInverse, theme) => {\r\n    if (state.isToday)\r\n        return getTodayColor(state.isChosen, isInverse, theme);\r\n    if (state.disabled)\r\n        return getDisabledColor(isInverse, theme);\r\n    if (state.isChosen)\r\n        return getChosenDayColor(isInverse, theme);\r\n    if (!state.isDayInCurrentMonth && !state.disabled)\r\n        return getNotCurrentMonthColor(isInverse, theme);\r\n    return getCurrentMonthColor(isInverse, theme);\r\n};\r\nfunction getChosenDayBorder(isInverse, isChosen, theme) {\r\n    if (isChosen) {\r\n        return `1px solid ${isInverse ? theme.colors.primary600 : theme.colors.neutral100}`;\r\n    }\r\n}\r\nfunction getChosenDayHover(isChosen, isInverse, theme) {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.neutral200 : theme.colors.primary600;\r\n    }\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral200;\r\n}\r\nconst getCalendarDayFontSize = (state) => {\r\n    if (state.isToday)\r\n        return 700;\r\n    return !state.isDayInCurrentMonth || state.disabled ? 400 : 500;\r\n};\r\nconst CalendarDayCell = styled.td `\n  color: ${props => props.isInverse ? props.theme.colors.danger : props.theme.colors.neutral};\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  height: ${props => props.theme.spaceScale.spacing09};\n  padding: 0;\n  position: relative;\n  text-align: center;\n`;\r\nconst CalendarDayInner = styled.button `\n  align-items: center;\n  background: ${props => getCalendarDayBackground(props.isInverse, props.state.isChosen, props.theme)};\n  border: 2px solid transparent;\n  color: ${props => getCalendarDayColor(props.state, props.isInverse, props.theme)};\n  font-weight: ${props => getCalendarDayFontSize(props.state)};\n  cursor: ${props => (props.state.disabled ? 'not-allowed' : 'pointer')};\n  display: flex;\n  height: ${props => props.theme.spaceScale.spacing09};\n  justify-content: center;\n  overflow: hidden;\n  outline-offset: 0;\n  position: relative;\n  transition: background 0.5s ease-in-out 0s;\n  width: 43px;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    border: ${props => getChosenDayBorder(props.isInverse, props.state.isChosen, props.theme)};\n    width: ${props => props.theme.spaceScale.spacing09};\n    height: 36px;\n    margin: 1px;\n  }\n\n  &:before {\n    background: ${props => props.isInverse\r\n    ? props.theme.colors.danger200\r\n    : props.theme.colors.neutral};\n    content: '';\n    height: 200%;\n    left: 0;\n    opacity: 0;\n    position: absolute;\n    top: -50%;\n    transition: 0.2s;\n    width: 200%;\n  }\n\n  &:hover {\n    &:before {\n      opacity: ${props => (props.state.disabled ? 0 : 0.1)};\n    }\n    border: none;\n    background: ${props => getChosenDayHover(props.state.isChosen, props.isInverse, props.theme)};\n  }\n`;\r\nconst EmptyCell = styled.td `\n  border: 0;\n  padding: 0;\n`;\r\nconst TodayIndicator = styled.span `\n  position: absolute;\n  bottom: 5px;\n  left: 19px;\n  width: 5px;\n  height: 5px;\n  border-radius: 50%;\n  background: ${props => getTodayColor(props.isChosen, props.isInverse, props.theme)};\n`;\r\nexport const CalendarDay = (props) => {\r\n    const dayRef = React.useRef();\r\n    const { dateFocused, focusedDate, chosenDate, maxDate, minDate, setDateFocused, onDateChange, isInverse, } = React.useContext(CalendarContext);\r\n    const [focused, setFocused] = React.useState(false);\r\n    const { day } = props;\r\n    React.useEffect(() => {\r\n        if (dateFocused && isSameDay(day, focusedDate)) {\r\n            dayRef.current.focus();\r\n            setFocused(true);\r\n        }\r\n        else {\r\n            if (focused) {\r\n                setFocused(false);\r\n            }\r\n        }\r\n    }, [focusedDate, dateFocused]);\r\n    function onCalendarDayFocus() {\r\n        setDateFocused(true);\r\n    }\r\n    function onDayClick(event) {\r\n        if (disabled) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        onDateChange(day, event);\r\n    }\r\n    const disabled = (maxDate ? isAfter(props.day, maxDate) : false) ||\r\n        (minDate ? isBefore(props.day, minDate) : false);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    if (day) {\r\n        const sameDateAsFocusedDate = isSameDay(day, focusedDate);\r\n        const sameDateAsChosenDate = isSameDay(day, chosenDate);\r\n        const sameDateAsToday = isSameDay(day, new Date());\r\n        const isDayInCurrentMonth = isSameMonth(day, focusedDate);\r\n        const locale = i18n.locale || enUS;\r\n        const ariaLabel = `${disabled ? i18n.datePicker.disabledDayAriaLabel : ''} ${format(day, 'EEEE, MMMM do yyyy', locale)} ${sameDateAsToday ? i18n.datePicker.todayAriaLabel : ''} ${sameDateAsChosenDate ? i18n.datePicker.selectedDayAriaLabel : ''}`;\r\n        const dayState = {\r\n            isChosen: sameDateAsChosenDate,\r\n            disabled,\r\n            isDayInCurrentMonth,\r\n            isToday: sameDateAsToday,\r\n        };\r\n        return (React.createElement(CalendarDayCell, { onFocus: onCalendarDayFocus, isInverse: isInverse, theme: theme },\r\n            React.createElement(CalendarDayInner, { \"aria-disabled\": disabled, \"aria-label\": ariaLabel, \"aria-current\": sameDateAsToday ? 'date' : undefined, \"aria-selected\": sameDateAsChosenDate, \"data-testid\": \"calendar-day\", state: dayState, isInverse: isInverse, onClick: onDayClick, ref: dayRef, tabIndex: sameDateAsFocusedDate ? 0 : -1, type: \"button\", theme: theme }, format(day, 'd', locale)),\r\n            sameDateAsToday && (React.createElement(TodayIndicator, { \"data-testid\": \"todayIndicator\", isInverse: isInverse, isChosen: sameDateAsChosenDate, theme: theme }))));\r\n    }\r\n    else {\r\n        return React.createElement(EmptyCell, null);\r\n    }\r\n};\r\n//# sourceMappingURL=CalendarDay.js.map"]} */"));
6960
+ }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AA+HmC","file":"CalendarDay.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { isAfter, isBefore, isSameDay, isSameMonth } from 'date-fns';\r\nimport { enUS } from 'date-fns/locale';\r\nimport { transparentize } from 'polished';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { i18nFormat as format } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nfunction getCalendarDayBackground(isInverse, isChosen, theme) {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.tertiary : theme.colors.primary;\r\n    }\r\n    return isChosen ? theme.colors.primary : theme.colors.neutral100;\r\n}\r\nconst getTodayColor = (isChosen, isInverse, theme) => {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.primary600 : theme.colors.secondary500;\r\n    }\r\n    return isChosen ? theme.colors.neutral100 : theme.colors.primary500;\r\n};\r\nconst getChosenDayColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n};\r\nconst getDisabledColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.6, theme.colors.neutral100)\r\n        : transparentize(0.4, theme.colors.neutral500);\r\n};\r\nconst getNotCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.3, theme.colors.neutral100)\r\n        : theme.colors.neutral500;\r\n};\r\nconst getCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.neutral100 : theme.colors.neutral700;\r\n};\r\nconst getCalendarDayColor = (state, isInverse, theme) => {\r\n    if (state.isToday)\r\n        return getTodayColor(state.isChosen, isInverse, theme);\r\n    if (state.disabled)\r\n        return getDisabledColor(isInverse, theme);\r\n    if (state.isChosen)\r\n        return getChosenDayColor(isInverse, theme);\r\n    if (!state.isDayInCurrentMonth && !state.disabled)\r\n        return getNotCurrentMonthColor(isInverse, theme);\r\n    return getCurrentMonthColor(isInverse, theme);\r\n};\r\nfunction getChosenDayBorder(isInverse, isChosen, theme) {\r\n    if (isChosen) {\r\n        return `1px solid ${isInverse ? theme.colors.primary600 : theme.colors.neutral100}`;\r\n    }\r\n}\r\nfunction getChosenDayHover(isChosen, isInverse, theme) {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.neutral200 : theme.colors.primary600;\r\n    }\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral200;\r\n}\r\nconst getCalendarDayFontSize = (state) => {\r\n    if (state.isToday)\r\n        return 700;\r\n    return !state.isDayInCurrentMonth || state.disabled ? 400 : 500;\r\n};\r\nconst CalendarDayCell = styled.td `\n  color: ${props => props.isInverse ? props.theme.colors.danger : props.theme.colors.neutral};\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  height: ${props => props.theme.spaceScale.spacing09};\n  padding: 0;\n  position: relative;\n  text-align: center;\n`;\r\nconst CalendarDayInner = styled.button `\n  align-items: center;\n  background: ${props => getCalendarDayBackground(props.isInverse, props.state.isChosen, props.theme)};\n  border: 2px solid transparent;\n  color: ${props => getCalendarDayColor(props.state, props.isInverse, props.theme)};\n  font-weight: ${props => getCalendarDayFontSize(props.state)};\n  cursor: ${props => (props.state.disabled ? 'not-allowed' : 'pointer')};\n  display: flex;\n  height: ${props => props.theme.spaceScale.spacing09};\n  justify-content: center;\n  overflow: hidden;\n  outline-offset: 0;\n  position: relative;\n  transition: background 0.5s ease-in-out 0s;\n  width: 43px;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    border: ${props => getChosenDayBorder(props.isInverse, props.state.isChosen, props.theme)};\n    width: ${props => props.theme.spaceScale.spacing09};\n    height: 36px;\n    margin: 1px;\n  }\n\n  &:before {\n    background: ${props => props.isInverse\r\n    ? props.theme.colors.danger200\r\n    : props.theme.colors.neutral};\n    content: '';\n    height: 200%;\n    left: 0;\n    opacity: 0;\n    position: absolute;\n    top: -50%;\n    transition: 0.2s;\n    width: 200%;\n  }\n\n  &:hover {\n    &:before {\n      opacity: ${props => (props.state.disabled ? 0 : 0.1)};\n    }\n    border: none;\n    background: ${props => getChosenDayHover(props.state.isChosen, props.isInverse, props.theme)};\n  }\n`;\r\nconst EmptyCell = styled.td `\n  border: 0;\n  padding: 0;\n`;\r\nconst TodayIndicator = styled.span `\n  position: absolute;\n  bottom: 5px;\n  left: 19px;\n  width: 5px;\n  height: 5px;\n  border-radius: 50%;\n  background: ${props => getTodayColor(props.isChosen, props.isInverse, props.theme)};\n`;\r\nexport const CalendarDay = (props) => {\r\n    const dayRef = React.useRef();\r\n    const { dateFocused, focusedDate, chosenDate, maxDate, minDate, onDateChange, setDateFocused, setFocusedDate, isInverse, } = React.useContext(CalendarContext);\r\n    const [focused, setFocused] = React.useState(false);\r\n    const { day } = props;\r\n    React.useEffect(() => {\r\n        if (dateFocused && isSameDay(day, focusedDate)) {\r\n            dayRef.current.focus();\r\n            setFocused(true);\r\n        }\r\n        else {\r\n            if (focused) {\r\n                setFocused(false);\r\n            }\r\n        }\r\n    }, [focusedDate, dateFocused]);\r\n    function onCalendarDayFocus() {\r\n        setDateFocused(true);\r\n    }\r\n    function onDayClick(event) {\r\n        if (disabled) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        onDateChange(day, event);\r\n    }\r\n    function onFocusDay(event) {\r\n        if (disabled || !isSameMonth(day, focusedDate)) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        setFocusedDate(day);\r\n    }\r\n    const disabled = (maxDate ? isAfter(props.day, maxDate) : false) ||\r\n        (minDate ? isBefore(props.day, minDate) : false);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    if (day) {\r\n        const sameDateAsFocusedDate = isSameDay(day, focusedDate);\r\n        const sameDateAsChosenDate = isSameDay(day, chosenDate);\r\n        const sameDateAsToday = isSameDay(day, new Date());\r\n        const isDayInCurrentMonth = isSameMonth(day, focusedDate);\r\n        const locale = i18n.locale || enUS;\r\n        const ariaLabel = `${disabled ? i18n.datePicker.disabledDayAriaLabel : ''} ${format(day, 'EEEE, MMMM do yyyy', locale)} ${sameDateAsToday ? i18n.datePicker.todayAriaLabel : ''} ${sameDateAsChosenDate ? i18n.datePicker.selectedDayAriaLabel : ''}`;\r\n        const dayState = {\r\n            isChosen: sameDateAsChosenDate,\r\n            disabled,\r\n            isDayInCurrentMonth,\r\n            isToday: sameDateAsToday,\r\n        };\r\n        return (React.createElement(CalendarDayCell, { onFocus: onCalendarDayFocus, isInverse: isInverse, theme: theme },\r\n            React.createElement(CalendarDayInner, { \"aria-disabled\": disabled, \"aria-label\": ariaLabel, \"aria-current\": sameDateAsToday ? 'date' : undefined, \"aria-selected\": sameDateAsChosenDate, \"data-testid\": \"calendar-day\", state: dayState, isInverse: isInverse, onClick: onDayClick, onMouseDown: onFocusDay, ref: dayRef, tabIndex: sameDateAsFocusedDate ? 0 : -1, type: \"button\", theme: theme }, format(day, 'd', locale)),\r\n            sameDateAsToday && (React.createElement(TodayIndicator, { \"data-testid\": \"todayIndicator\", isInverse: isInverse, isChosen: sameDateAsChosenDate, theme: theme }))));\r\n    }\r\n    else {\r\n        return React.createElement(EmptyCell, null);\r\n    }\r\n};\r\n//# sourceMappingURL=CalendarDay.js.map"]} */"));
6960
6961
  var CalendarDay = function CalendarDay(props) {
6961
6962
  var dayRef = React.useRef();
6962
6963
  var _React$useContext = React.useContext(CalendarContext),
@@ -6965,8 +6966,9 @@ var CalendarDay = function CalendarDay(props) {
6965
6966
  chosenDate = _React$useContext.chosenDate,
6966
6967
  maxDate = _React$useContext.maxDate,
6967
6968
  minDate = _React$useContext.minDate,
6968
- setDateFocused = _React$useContext.setDateFocused,
6969
6969
  onDateChange = _React$useContext.onDateChange,
6970
+ setDateFocused = _React$useContext.setDateFocused,
6971
+ setFocusedDate = _React$useContext.setFocusedDate,
6970
6972
  isInverse = _React$useContext.isInverse;
6971
6973
  var _React$useState = React.useState(false),
6972
6974
  focused = _React$useState[0],
@@ -6992,6 +6994,13 @@ var CalendarDay = function CalendarDay(props) {
6992
6994
  }
6993
6995
  onDateChange(day, event);
6994
6996
  }
6997
+ function onFocusDay(event) {
6998
+ if (disabled || !dateFns.isSameMonth(day, focusedDate)) {
6999
+ event.preventDefault();
7000
+ return;
7001
+ }
7002
+ setFocusedDate(day);
7003
+ }
6995
7004
  var disabled = (maxDate ? dateFns.isAfter(props.day, maxDate) : false) || (minDate ? dateFns.isBefore(props.day, minDate) : false);
6996
7005
  var theme = React.useContext(ThemeContext);
6997
7006
  var i18n = React.useContext(I18nContext);
@@ -7021,6 +7030,7 @@ var CalendarDay = function CalendarDay(props) {
7021
7030
  state: dayState,
7022
7031
  isInverse: isInverse,
7023
7032
  onClick: onDayClick,
7033
+ onMouseDown: onFocusDay,
7024
7034
  ref: dayRef,
7025
7035
  tabIndex: sameDateAsFocusedDate ? 0 : -1,
7026
7036
  type: "button",
@@ -7795,7 +7805,7 @@ var DatePickerContainer = /*#__PURE__*/_styled("div", {
7795
7805
  label: "DatePickerContainer"
7796
7806
  })( {
7797
7807
  name: "bjn8wh",
7798
- styles: "position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAkBuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate } from '@floating-ui/react-dom';\r\nimport { addDays, endOfDay, isAfter, isBefore, isMatch, isSameMonth, isValid, parse, setHours, startOfDay, } from 'date-fns';\r\nimport { transparentize } from 'polished';\r\nimport { EventIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarMonth } from './CalendarMonth';\r\nimport { useMagmaFloating } from '../../hooks/useMagmaFloating';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Announce } from '../Announce';\r\nimport { Input } from '../Input';\r\nimport { InputType } from '../InputBase';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nimport { getCalendarMonthWeeks, getDateFromString, getNextMonthFromDate, getPrevMonthFromDate, handleKeyPress, i18nFormat as format, inDateRange, } from './utils';\r\nimport { omit, useForkedRef, useGenerateId } from '../../utils';\r\nconst DatePickerContainer = styled.div `\n  position: relative;\n`;\r\nconst DatePickerCalendar = styled.div `\n  border: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.15);\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: ${props => (props.opened ? 'block' : 'none')};\n  margin: ${props => props.theme.spaceScale.spacing01} 0px;\n  opacity: ${props => (props.opened ? '1' : '0')};\n  overflow: hidden;\n  transition: opacity 0.2s ease-in-out 0s;\n  width: 320px;\n`;\r\nexport const DatePicker = React.forwardRef((props, forwardedRef) => {\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const iconRef = React.useRef();\r\n    const inputRef = React.useRef();\r\n    const lastFocus = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const [helperInformationShown, setHelperInformationShown] = React.useState(false);\r\n    const [calendarOpened, setCalendarOpened] = React.useState(false);\r\n    const [dateFocused, setDateFocused] = React.useState(false);\r\n    const [focusedDate, setFocusedDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate) ||\r\n        setDefaultFocusedDate());\r\n    const [chosenDate, setChosenDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate));\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    React.useEffect(() => {\r\n        if (!calendarOpened) {\r\n            setDateFocused(false);\r\n        }\r\n    }, [calendarOpened]);\r\n    React.useEffect(() => {\r\n        if (props.value) {\r\n            setFocusedDate(setDateFromConsumer(props.value) || setDefaultFocusedDate());\r\n            setChosenDate(setDateFromConsumer(props.value));\r\n        }\r\n        if (props.value === null)\r\n            setChosenDate(undefined);\r\n    }, [props.value]);\r\n    function showHelperInformation() {\r\n        lastFocus.current = document.activeElement;\r\n        setHelperInformationShown(true);\r\n    }\r\n    function hideHelperInformation() {\r\n        lastFocus.current.focus();\r\n        setHelperInformationShown(false);\r\n    }\r\n    function closeHelperInformation() {\r\n        setHelperInformationShown(false);\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    const setFocusedCurrentDate = (event) => {\r\n        const isKeyboardEvent = event.type === 'keydown';\r\n        if ((isKeyboardEvent &&\r\n            (event.key === ' ' ||\r\n                event.key === 'Enter')) ||\r\n            event.type === 'click') {\r\n            event.preventDefault();\r\n            setFocusedDate(setDefaultFocusedDate());\r\n        }\r\n    };\r\n    function setDateFromConsumer(date) {\r\n        const convertedDate = getDateFromString(date);\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        return date &&\r\n            inDateRange(convertedDate, convertedMinDate, convertedMaxDate)\r\n            ? convertedDate\r\n            : null;\r\n    }\r\n    function setDefaultFocusedDate() {\r\n        const newDate = new Date();\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        if (inDateRange(newDate, convertedMinDate, convertedMaxDate)) {\r\n            if (isBefore(startOfDay(newDate), convertedMinDate)) {\r\n                return addDays(newDate, 1);\r\n            }\r\n            return newDate;\r\n        }\r\n        else if (convertedMaxDate || convertedMinDate) {\r\n            return convertedMinDate ? convertedMinDate : convertedMaxDate;\r\n        }\r\n    }\r\n    function buildCalendarMonth(date, enableOutsideDates) {\r\n        const days = [\r\n            'sunday',\r\n            'monday',\r\n            'tuesday',\r\n            'wednesday',\r\n            'thursday',\r\n            'friday',\r\n            'saturday',\r\n        ];\r\n        const { startOfWeek } = i18n.datePicker;\r\n        return getCalendarMonthWeeks(date, enableOutsideDates, days.indexOf(startOfWeek));\r\n    }\r\n    function onPrevMonthClick() {\r\n        const newDate = getPrevMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function onNextMonthClick() {\r\n        const newDate = getNextMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function onDateChange(day) {\r\n        setChosenDate(day);\r\n        setCalendarOpened(false);\r\n    }\r\n    function reset() {\r\n        setFocusedDate(setDefaultFocusedDate());\r\n        setChosenDate(null);\r\n        setDateFocused(false);\r\n    }\r\n    function isValidDateFromString(value, day) {\r\n        const isValidDateFormat = isMatch(value, i18n.dateFormat);\r\n        const parsedDate = parse(value, i18n.dateFormat, new Date());\r\n        const isValidDate = isValid(parsedDate);\r\n        return isValidDateFormat && isValidDate;\r\n    }\r\n    function handleInputChange(event) {\r\n        const { value } = event.target;\r\n        const day = new Date(value);\r\n        setCalendarOpened(false);\r\n        props.onInputChange &&\r\n            typeof props.onInputChange === 'function' &&\r\n            props.onInputChange(event);\r\n        const isValidDay = isValidDateFromString(value, day);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(isValidDay ? day.toISOString() : value, event);\r\n    }\r\n    function handleInputFocus(event) {\r\n        props.onInputFocus &&\r\n            typeof props.onInputFocus === 'function' &&\r\n            props.onInputFocus(event);\r\n    }\r\n    function handleInputBlur(event) {\r\n        const { value } = inputRef.current;\r\n        const day = parse(value, i18n.dateFormat, new Date());\r\n        if (isValidDateFromString(value, day)) {\r\n            handleDateChange(day, event);\r\n        }\r\n        else {\r\n            reset && typeof reset === 'function' && reset();\r\n        }\r\n        props.onInputBlur &&\r\n            typeof props.onInputBlur === 'function' &&\r\n            props.onInputBlur(event);\r\n    }\r\n    function handleInputKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            setCalendarOpened(false);\r\n            inputRef.current.focus();\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            setCalendarOpened(false);\r\n            iconRef.current.focus();\r\n        }\r\n        if (dateFocused && document.activeElement.closest('table')) {\r\n            const newChosenDate = handleKeyPress(event, focusedDate, setCalendarOpened, showHelperInformation, onDateChange, iconRef);\r\n            if (newChosenDate) {\r\n                if (minDate && maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate)) &&\r\n                        isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (minDate && !maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (maxDate && !minDate) {\r\n                    if (isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else {\r\n                    setFocusedDate(newChosenDate);\r\n                }\r\n            }\r\n        }\r\n    }\r\n    function handleDateChange(day, event) {\r\n        props.onDateChange &&\r\n            typeof props.onDateChange === 'function' &&\r\n            props.onDateChange(day, event);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(day?.toISOString(), event);\r\n        onDateChange(day);\r\n        setFocusedDate(isAfter(setHours(day, 12), minDate) ? day : setDefaultFocusedDate);\r\n    }\r\n    function handleDaySelection(day, event) {\r\n        handleDateChange(day, event);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleCalendarBlur(event) {\r\n        const { currentTarget } = event;\r\n        // timeout needed for active element to update. Browser behavior.\r\n        // https://bugzilla.mozilla.org/show_bug.cgi?id=452307\r\n        setTimeout(() => {\r\n            const isInCalendar = currentTarget.contains(document.activeElement);\r\n            if (!isInCalendar && !helperInformationShown) {\r\n                setCalendarOpened(false);\r\n            }\r\n        }, 0);\r\n    }\r\n    function handleCloseButtonClick(event) {\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    function toggleCalendarOpened() {\r\n        setCalendarOpened(opened => !opened);\r\n    }\r\n    const { placeholder, testId, ...rest } = props;\r\n    const other = omit(['onDateChange', 'onInputChange', 'onInputBlur', 'onInputFocus'], rest);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const minDate = getDateFromString(props.minDate);\r\n    const maxDate = getDateFromString(props.maxDate);\r\n    const dateFormat = i18n.dateFormat;\r\n    const inputValue = chosenDate ? format(chosenDate, dateFormat) : '';\r\n    const { floatingStyles, refs, elements, update } = useMagmaFloating();\r\n    React.useEffect(() => {\r\n        const referenceDateInput = elements.reference;\r\n        const floatingCalendar = elements.floating;\r\n        if (calendarOpened && referenceDateInput && floatingCalendar) {\r\n            return autoUpdate(referenceDateInput, floatingCalendar, update);\r\n        }\r\n    }, [calendarOpened, elements, update]);\r\n    return (React.createElement(CalendarContext.Provider, { value: {\r\n            chosenDate,\r\n            focusedDate,\r\n            dateFocused,\r\n            maxDate,\r\n            minDate,\r\n            helperInformationShown,\r\n            isInverse,\r\n            buildCalendarMonth,\r\n            showHelperInformation,\r\n            hideHelperInformation,\r\n            onKeyDown: handleKeyDown,\r\n            onPrevMonthClick,\r\n            onNextMonthClick,\r\n            onDateChange: handleDaySelection,\r\n            setDateFocused,\r\n            setFocusedTodayDate: setFocusedCurrentDate,\r\n            onClose: closeHelperInformation,\r\n        } },\r\n        React.createElement(DatePickerContainer, { \"data-testid\": testId, onBlur: handleCalendarBlur },\r\n            React.createElement(Announce, null, calendarOpened && (React.createElement(VisuallyHidden, null, i18n.datePicker.calendarOpenAnnounce))),\r\n            React.createElement(Input, Object.assign({}, other, { icon: React.createElement(EventIcon, null), iconAriaLabel: i18n.datePicker.calendarIconAriaLabel, iconRef: iconRef, onIconClick: toggleCalendarOpened, onIconKeyDown: handleInputKeyDown, id: id, isInverse: isInverse, ref: ref, onChange: handleInputChange, onBlur: handleInputBlur, onFocus: handleInputFocus, onKeyDown: handleInputKeyDown, onDateChange: handleDateChange, placeholder: placeholder ? placeholder : dateFormat.toLowerCase(), type: InputType.text, value: inputValue, setReference: refs.setReference })),\r\n            React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n                React.createElement(\"div\", { ref: el => calendarOpened && refs.setFloating(el), style: { ...floatingStyles, zIndex: '998' } },\r\n                    React.createElement(DatePickerCalendar, { \"data-testid\": \"calendarContainer\", opened: calendarOpened, isInverse: isInverse, theme: theme },\r\n                        React.createElement(CalendarMonth, { focusOnOpen: calendarOpened &&\r\n                                Boolean(focusedDate) &&\r\n                                Boolean(chosenDate), isInverse: isInverse, handleCloseButtonClick: handleCloseButtonClick, calendarOpened: calendarOpened, setDateFocused: setDateFocused })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
7808
+ styles: "position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAkBuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate } from '@floating-ui/react-dom';\r\nimport { addDays, endOfDay, isAfter, isBefore, isMatch, isSameMonth, isValid, parse, setHours, startOfDay, } from 'date-fns';\r\nimport { transparentize } from 'polished';\r\nimport { EventIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarMonth } from './CalendarMonth';\r\nimport { useMagmaFloating } from '../../hooks/useMagmaFloating';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Announce } from '../Announce';\r\nimport { Input } from '../Input';\r\nimport { InputType } from '../InputBase';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nimport { getCalendarMonthWeeks, getDateFromString, getNextMonthFromDate, getPrevMonthFromDate, handleKeyPress, i18nFormat as format, inDateRange, } from './utils';\r\nimport { omit, useForkedRef, useGenerateId } from '../../utils';\r\nconst DatePickerContainer = styled.div `\n  position: relative;\n`;\r\nconst DatePickerCalendar = styled.div `\n  border: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.15);\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: ${props => (props.opened ? 'block' : 'none')};\n  margin: ${props => props.theme.spaceScale.spacing01} 0px;\n  opacity: ${props => (props.opened ? '1' : '0')};\n  overflow: hidden;\n  transition: opacity 0.2s ease-in-out 0s;\n  width: 320px;\n`;\r\nexport const DatePicker = React.forwardRef((props, forwardedRef) => {\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const iconRef = React.useRef();\r\n    const inputRef = React.useRef();\r\n    const lastFocus = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const [helperInformationShown, setHelperInformationShown] = React.useState(false);\r\n    const [calendarOpened, setCalendarOpened] = React.useState(false);\r\n    const [dateFocused, setDateFocused] = React.useState(false);\r\n    const [focusedDate, setFocusedDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate) ||\r\n        setDefaultFocusedDate());\r\n    const [chosenDate, setChosenDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate));\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    React.useEffect(() => {\r\n        if (!calendarOpened) {\r\n            setDateFocused(false);\r\n        }\r\n    }, [calendarOpened]);\r\n    React.useEffect(() => {\r\n        if (props.value) {\r\n            setFocusedDate(setDateFromConsumer(props.value) || setDefaultFocusedDate());\r\n            setChosenDate(setDateFromConsumer(props.value));\r\n        }\r\n        if (props.value === null)\r\n            setChosenDate(undefined);\r\n    }, [props.value]);\r\n    function showHelperInformation() {\r\n        lastFocus.current = document.activeElement;\r\n        setHelperInformationShown(true);\r\n    }\r\n    function hideHelperInformation() {\r\n        lastFocus.current.focus();\r\n        setHelperInformationShown(false);\r\n    }\r\n    function closeHelperInformation() {\r\n        setHelperInformationShown(false);\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    const setFocusedTodayDate = (event) => {\r\n        const isKeyboardEvent = event.type === 'keydown';\r\n        if ((isKeyboardEvent &&\r\n            (event.key === ' ' ||\r\n                event.key === 'Enter')) ||\r\n            event.type === 'click') {\r\n            event.preventDefault();\r\n            setFocusedDate(setDefaultFocusedDate());\r\n        }\r\n    };\r\n    function setDateFromConsumer(date) {\r\n        const convertedDate = getDateFromString(date);\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        return date &&\r\n            inDateRange(convertedDate, convertedMinDate, convertedMaxDate)\r\n            ? convertedDate\r\n            : null;\r\n    }\r\n    function setDefaultFocusedDate() {\r\n        const newDate = new Date();\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        if (inDateRange(newDate, convertedMinDate, convertedMaxDate)) {\r\n            if (isBefore(startOfDay(newDate), convertedMinDate)) {\r\n                return addDays(newDate, 1);\r\n            }\r\n            return newDate;\r\n        }\r\n        else if (convertedMaxDate || convertedMinDate) {\r\n            return convertedMinDate ? convertedMinDate : convertedMaxDate;\r\n        }\r\n    }\r\n    function buildCalendarMonth(date, enableOutsideDates) {\r\n        const days = [\r\n            'sunday',\r\n            'monday',\r\n            'tuesday',\r\n            'wednesday',\r\n            'thursday',\r\n            'friday',\r\n            'saturday',\r\n        ];\r\n        const { startOfWeek } = i18n.datePicker;\r\n        return getCalendarMonthWeeks(date, enableOutsideDates, days.indexOf(startOfWeek));\r\n    }\r\n    function onPrevMonthClick() {\r\n        const newDate = getPrevMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function onNextMonthClick() {\r\n        const newDate = getNextMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function onDateChange(day) {\r\n        setChosenDate(day);\r\n        setCalendarOpened(false);\r\n    }\r\n    function reset() {\r\n        setFocusedDate(setDefaultFocusedDate());\r\n        setChosenDate(null);\r\n        setDateFocused(false);\r\n    }\r\n    function isValidDateFromString(value, day) {\r\n        const isValidDateFormat = isMatch(value, i18n.dateFormat);\r\n        const parsedDate = parse(value, i18n.dateFormat, new Date());\r\n        const isValidDate = isValid(parsedDate);\r\n        return isValidDateFormat && isValidDate;\r\n    }\r\n    function handleInputChange(event) {\r\n        const { value } = event.target;\r\n        const day = new Date(value);\r\n        setCalendarOpened(false);\r\n        props.onInputChange &&\r\n            typeof props.onInputChange === 'function' &&\r\n            props.onInputChange(event);\r\n        const isValidDay = isValidDateFromString(value, day);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(isValidDay ? day.toISOString() : value, event);\r\n    }\r\n    function handleInputFocus(event) {\r\n        props.onInputFocus &&\r\n            typeof props.onInputFocus === 'function' &&\r\n            props.onInputFocus(event);\r\n    }\r\n    function handleInputBlur(event) {\r\n        const { value } = inputRef.current;\r\n        const day = parse(value, i18n.dateFormat, new Date());\r\n        if (isValidDateFromString(value, day)) {\r\n            handleDateChange(day, event);\r\n        }\r\n        else {\r\n            reset && typeof reset === 'function' && reset();\r\n        }\r\n        props.onInputBlur &&\r\n            typeof props.onInputBlur === 'function' &&\r\n            props.onInputBlur(event);\r\n    }\r\n    function handleInputKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            setCalendarOpened(false);\r\n            inputRef.current.focus();\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            setCalendarOpened(false);\r\n            iconRef.current.focus();\r\n        }\r\n        if (dateFocused && document.activeElement.closest('table')) {\r\n            const newChosenDate = handleKeyPress(event, focusedDate, setCalendarOpened, showHelperInformation, onDateChange, iconRef);\r\n            if (newChosenDate) {\r\n                if (minDate && maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate)) &&\r\n                        isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (minDate && !maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (maxDate && !minDate) {\r\n                    if (isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else {\r\n                    setFocusedDate(newChosenDate);\r\n                }\r\n            }\r\n        }\r\n    }\r\n    function handleDateChange(day, event) {\r\n        props.onDateChange &&\r\n            typeof props.onDateChange === 'function' &&\r\n            props.onDateChange(day, event);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(day?.toISOString(), event);\r\n        onDateChange(day);\r\n        setFocusedDate(isAfter(setHours(day, 12), minDate) ? day : setDefaultFocusedDate);\r\n    }\r\n    function handleDaySelection(day, event) {\r\n        handleDateChange(day, event);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleCalendarBlur(event) {\r\n        const { currentTarget } = event;\r\n        // timeout needed for active element to update. Browser behavior.\r\n        // https://bugzilla.mozilla.org/show_bug.cgi?id=452307\r\n        setTimeout(() => {\r\n            const isInCalendar = currentTarget.contains(document.activeElement);\r\n            if (!isInCalendar && !helperInformationShown) {\r\n                setCalendarOpened(false);\r\n            }\r\n        }, 0);\r\n    }\r\n    function handleCloseButtonClick(event) {\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    function toggleCalendarOpened() {\r\n        setCalendarOpened(opened => !opened);\r\n    }\r\n    const { placeholder, testId, ...rest } = props;\r\n    const other = omit(['onDateChange', 'onInputChange', 'onInputBlur', 'onInputFocus'], rest);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const minDate = getDateFromString(props.minDate);\r\n    const maxDate = getDateFromString(props.maxDate);\r\n    const dateFormat = i18n.dateFormat;\r\n    const inputValue = chosenDate ? format(chosenDate, dateFormat) : '';\r\n    const { floatingStyles, refs, elements, update } = useMagmaFloating();\r\n    React.useEffect(() => {\r\n        const referenceDateInput = elements.reference;\r\n        const floatingCalendar = elements.floating;\r\n        if (calendarOpened && referenceDateInput && floatingCalendar) {\r\n            return autoUpdate(referenceDateInput, floatingCalendar, update);\r\n        }\r\n    }, [calendarOpened, elements, update]);\r\n    return (React.createElement(CalendarContext.Provider, { value: {\r\n            chosenDate,\r\n            focusedDate,\r\n            dateFocused,\r\n            maxDate,\r\n            minDate,\r\n            helperInformationShown,\r\n            isInverse,\r\n            buildCalendarMonth,\r\n            showHelperInformation,\r\n            hideHelperInformation,\r\n            onKeyDown: handleKeyDown,\r\n            onPrevMonthClick,\r\n            onNextMonthClick,\r\n            onDateChange: handleDaySelection,\r\n            setDateFocused,\r\n            setFocusedTodayDate,\r\n            setFocusedDate,\r\n            onClose: closeHelperInformation,\r\n        } },\r\n        React.createElement(DatePickerContainer, { \"data-testid\": testId, onBlur: handleCalendarBlur },\r\n            React.createElement(Announce, null, calendarOpened && (React.createElement(VisuallyHidden, null, i18n.datePicker.calendarOpenAnnounce))),\r\n            React.createElement(Input, Object.assign({}, other, { icon: React.createElement(EventIcon, null), iconAriaLabel: i18n.datePicker.calendarIconAriaLabel, iconRef: iconRef, onIconClick: toggleCalendarOpened, onIconKeyDown: handleInputKeyDown, id: id, isInverse: isInverse, ref: ref, onChange: handleInputChange, onBlur: handleInputBlur, onFocus: handleInputFocus, onKeyDown: handleInputKeyDown, onDateChange: handleDateChange, placeholder: placeholder ? placeholder : dateFormat.toLowerCase(), type: InputType.text, value: inputValue, setReference: refs.setReference })),\r\n            React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n                React.createElement(\"div\", { ref: el => calendarOpened && refs.setFloating(el), style: { ...floatingStyles, zIndex: '998' } },\r\n                    React.createElement(DatePickerCalendar, { \"data-testid\": \"calendarContainer\", opened: calendarOpened, isInverse: isInverse, theme: theme },\r\n                        React.createElement(CalendarMonth, { focusOnOpen: calendarOpened &&\r\n                                Boolean(focusedDate) &&\r\n                                Boolean(chosenDate), isInverse: isInverse, handleCloseButtonClick: handleCloseButtonClick, calendarOpened: calendarOpened, setDateFocused: setDateFocused })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
7799
7809
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
7800
7810
  });
7801
7811
  var DatePickerCalendar = /*#__PURE__*/_styled("div", {
@@ -7813,7 +7823,7 @@ var DatePickerCalendar = /*#__PURE__*/_styled("div", {
7813
7823
  return props.theme.spaceScale.spacing01;
7814
7824
  }, " 0px;opacity:", function (props) {
7815
7825
  return props.opened ? '1' : '0';
7816
- }, ";overflow:hidden;transition:opacity 0.2s ease-in-out 0s;width:320px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqBsC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate } from '@floating-ui/react-dom';\r\nimport { addDays, endOfDay, isAfter, isBefore, isMatch, isSameMonth, isValid, parse, setHours, startOfDay, } from 'date-fns';\r\nimport { transparentize } from 'polished';\r\nimport { EventIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarMonth } from './CalendarMonth';\r\nimport { useMagmaFloating } from '../../hooks/useMagmaFloating';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Announce } from '../Announce';\r\nimport { Input } from '../Input';\r\nimport { InputType } from '../InputBase';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nimport { getCalendarMonthWeeks, getDateFromString, getNextMonthFromDate, getPrevMonthFromDate, handleKeyPress, i18nFormat as format, inDateRange, } from './utils';\r\nimport { omit, useForkedRef, useGenerateId } from '../../utils';\r\nconst DatePickerContainer = styled.div `\n  position: relative;\n`;\r\nconst DatePickerCalendar = styled.div `\n  border: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.15);\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: ${props => (props.opened ? 'block' : 'none')};\n  margin: ${props => props.theme.spaceScale.spacing01} 0px;\n  opacity: ${props => (props.opened ? '1' : '0')};\n  overflow: hidden;\n  transition: opacity 0.2s ease-in-out 0s;\n  width: 320px;\n`;\r\nexport const DatePicker = React.forwardRef((props, forwardedRef) => {\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const iconRef = React.useRef();\r\n    const inputRef = React.useRef();\r\n    const lastFocus = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const [helperInformationShown, setHelperInformationShown] = React.useState(false);\r\n    const [calendarOpened, setCalendarOpened] = React.useState(false);\r\n    const [dateFocused, setDateFocused] = React.useState(false);\r\n    const [focusedDate, setFocusedDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate) ||\r\n        setDefaultFocusedDate());\r\n    const [chosenDate, setChosenDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate));\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    React.useEffect(() => {\r\n        if (!calendarOpened) {\r\n            setDateFocused(false);\r\n        }\r\n    }, [calendarOpened]);\r\n    React.useEffect(() => {\r\n        if (props.value) {\r\n            setFocusedDate(setDateFromConsumer(props.value) || setDefaultFocusedDate());\r\n            setChosenDate(setDateFromConsumer(props.value));\r\n        }\r\n        if (props.value === null)\r\n            setChosenDate(undefined);\r\n    }, [props.value]);\r\n    function showHelperInformation() {\r\n        lastFocus.current = document.activeElement;\r\n        setHelperInformationShown(true);\r\n    }\r\n    function hideHelperInformation() {\r\n        lastFocus.current.focus();\r\n        setHelperInformationShown(false);\r\n    }\r\n    function closeHelperInformation() {\r\n        setHelperInformationShown(false);\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    const setFocusedCurrentDate = (event) => {\r\n        const isKeyboardEvent = event.type === 'keydown';\r\n        if ((isKeyboardEvent &&\r\n            (event.key === ' ' ||\r\n                event.key === 'Enter')) ||\r\n            event.type === 'click') {\r\n            event.preventDefault();\r\n            setFocusedDate(setDefaultFocusedDate());\r\n        }\r\n    };\r\n    function setDateFromConsumer(date) {\r\n        const convertedDate = getDateFromString(date);\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        return date &&\r\n            inDateRange(convertedDate, convertedMinDate, convertedMaxDate)\r\n            ? convertedDate\r\n            : null;\r\n    }\r\n    function setDefaultFocusedDate() {\r\n        const newDate = new Date();\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        if (inDateRange(newDate, convertedMinDate, convertedMaxDate)) {\r\n            if (isBefore(startOfDay(newDate), convertedMinDate)) {\r\n                return addDays(newDate, 1);\r\n            }\r\n            return newDate;\r\n        }\r\n        else if (convertedMaxDate || convertedMinDate) {\r\n            return convertedMinDate ? convertedMinDate : convertedMaxDate;\r\n        }\r\n    }\r\n    function buildCalendarMonth(date, enableOutsideDates) {\r\n        const days = [\r\n            'sunday',\r\n            'monday',\r\n            'tuesday',\r\n            'wednesday',\r\n            'thursday',\r\n            'friday',\r\n            'saturday',\r\n        ];\r\n        const { startOfWeek } = i18n.datePicker;\r\n        return getCalendarMonthWeeks(date, enableOutsideDates, days.indexOf(startOfWeek));\r\n    }\r\n    function onPrevMonthClick() {\r\n        const newDate = getPrevMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function onNextMonthClick() {\r\n        const newDate = getNextMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function onDateChange(day) {\r\n        setChosenDate(day);\r\n        setCalendarOpened(false);\r\n    }\r\n    function reset() {\r\n        setFocusedDate(setDefaultFocusedDate());\r\n        setChosenDate(null);\r\n        setDateFocused(false);\r\n    }\r\n    function isValidDateFromString(value, day) {\r\n        const isValidDateFormat = isMatch(value, i18n.dateFormat);\r\n        const parsedDate = parse(value, i18n.dateFormat, new Date());\r\n        const isValidDate = isValid(parsedDate);\r\n        return isValidDateFormat && isValidDate;\r\n    }\r\n    function handleInputChange(event) {\r\n        const { value } = event.target;\r\n        const day = new Date(value);\r\n        setCalendarOpened(false);\r\n        props.onInputChange &&\r\n            typeof props.onInputChange === 'function' &&\r\n            props.onInputChange(event);\r\n        const isValidDay = isValidDateFromString(value, day);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(isValidDay ? day.toISOString() : value, event);\r\n    }\r\n    function handleInputFocus(event) {\r\n        props.onInputFocus &&\r\n            typeof props.onInputFocus === 'function' &&\r\n            props.onInputFocus(event);\r\n    }\r\n    function handleInputBlur(event) {\r\n        const { value } = inputRef.current;\r\n        const day = parse(value, i18n.dateFormat, new Date());\r\n        if (isValidDateFromString(value, day)) {\r\n            handleDateChange(day, event);\r\n        }\r\n        else {\r\n            reset && typeof reset === 'function' && reset();\r\n        }\r\n        props.onInputBlur &&\r\n            typeof props.onInputBlur === 'function' &&\r\n            props.onInputBlur(event);\r\n    }\r\n    function handleInputKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            setCalendarOpened(false);\r\n            inputRef.current.focus();\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            setCalendarOpened(false);\r\n            iconRef.current.focus();\r\n        }\r\n        if (dateFocused && document.activeElement.closest('table')) {\r\n            const newChosenDate = handleKeyPress(event, focusedDate, setCalendarOpened, showHelperInformation, onDateChange, iconRef);\r\n            if (newChosenDate) {\r\n                if (minDate && maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate)) &&\r\n                        isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (minDate && !maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (maxDate && !minDate) {\r\n                    if (isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else {\r\n                    setFocusedDate(newChosenDate);\r\n                }\r\n            }\r\n        }\r\n    }\r\n    function handleDateChange(day, event) {\r\n        props.onDateChange &&\r\n            typeof props.onDateChange === 'function' &&\r\n            props.onDateChange(day, event);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(day?.toISOString(), event);\r\n        onDateChange(day);\r\n        setFocusedDate(isAfter(setHours(day, 12), minDate) ? day : setDefaultFocusedDate);\r\n    }\r\n    function handleDaySelection(day, event) {\r\n        handleDateChange(day, event);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleCalendarBlur(event) {\r\n        const { currentTarget } = event;\r\n        // timeout needed for active element to update. Browser behavior.\r\n        // https://bugzilla.mozilla.org/show_bug.cgi?id=452307\r\n        setTimeout(() => {\r\n            const isInCalendar = currentTarget.contains(document.activeElement);\r\n            if (!isInCalendar && !helperInformationShown) {\r\n                setCalendarOpened(false);\r\n            }\r\n        }, 0);\r\n    }\r\n    function handleCloseButtonClick(event) {\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    function toggleCalendarOpened() {\r\n        setCalendarOpened(opened => !opened);\r\n    }\r\n    const { placeholder, testId, ...rest } = props;\r\n    const other = omit(['onDateChange', 'onInputChange', 'onInputBlur', 'onInputFocus'], rest);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const minDate = getDateFromString(props.minDate);\r\n    const maxDate = getDateFromString(props.maxDate);\r\n    const dateFormat = i18n.dateFormat;\r\n    const inputValue = chosenDate ? format(chosenDate, dateFormat) : '';\r\n    const { floatingStyles, refs, elements, update } = useMagmaFloating();\r\n    React.useEffect(() => {\r\n        const referenceDateInput = elements.reference;\r\n        const floatingCalendar = elements.floating;\r\n        if (calendarOpened && referenceDateInput && floatingCalendar) {\r\n            return autoUpdate(referenceDateInput, floatingCalendar, update);\r\n        }\r\n    }, [calendarOpened, elements, update]);\r\n    return (React.createElement(CalendarContext.Provider, { value: {\r\n            chosenDate,\r\n            focusedDate,\r\n            dateFocused,\r\n            maxDate,\r\n            minDate,\r\n            helperInformationShown,\r\n            isInverse,\r\n            buildCalendarMonth,\r\n            showHelperInformation,\r\n            hideHelperInformation,\r\n            onKeyDown: handleKeyDown,\r\n            onPrevMonthClick,\r\n            onNextMonthClick,\r\n            onDateChange: handleDaySelection,\r\n            setDateFocused,\r\n            setFocusedTodayDate: setFocusedCurrentDate,\r\n            onClose: closeHelperInformation,\r\n        } },\r\n        React.createElement(DatePickerContainer, { \"data-testid\": testId, onBlur: handleCalendarBlur },\r\n            React.createElement(Announce, null, calendarOpened && (React.createElement(VisuallyHidden, null, i18n.datePicker.calendarOpenAnnounce))),\r\n            React.createElement(Input, Object.assign({}, other, { icon: React.createElement(EventIcon, null), iconAriaLabel: i18n.datePicker.calendarIconAriaLabel, iconRef: iconRef, onIconClick: toggleCalendarOpened, onIconKeyDown: handleInputKeyDown, id: id, isInverse: isInverse, ref: ref, onChange: handleInputChange, onBlur: handleInputBlur, onFocus: handleInputFocus, onKeyDown: handleInputKeyDown, onDateChange: handleDateChange, placeholder: placeholder ? placeholder : dateFormat.toLowerCase(), type: InputType.text, value: inputValue, setReference: refs.setReference })),\r\n            React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n                React.createElement(\"div\", { ref: el => calendarOpened && refs.setFloating(el), style: { ...floatingStyles, zIndex: '998' } },\r\n                    React.createElement(DatePickerCalendar, { \"data-testid\": \"calendarContainer\", opened: calendarOpened, isInverse: isInverse, theme: theme },\r\n                        React.createElement(CalendarMonth, { focusOnOpen: calendarOpened &&\r\n                                Boolean(focusedDate) &&\r\n                                Boolean(chosenDate), isInverse: isInverse, handleCloseButtonClick: handleCloseButtonClick, calendarOpened: calendarOpened, setDateFocused: setDateFocused })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
7826
+ }, ";overflow:hidden;transition:opacity 0.2s ease-in-out 0s;width:320px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqBsC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate } from '@floating-ui/react-dom';\r\nimport { addDays, endOfDay, isAfter, isBefore, isMatch, isSameMonth, isValid, parse, setHours, startOfDay, } from 'date-fns';\r\nimport { transparentize } from 'polished';\r\nimport { EventIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarMonth } from './CalendarMonth';\r\nimport { useMagmaFloating } from '../../hooks/useMagmaFloating';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Announce } from '../Announce';\r\nimport { Input } from '../Input';\r\nimport { InputType } from '../InputBase';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nimport { getCalendarMonthWeeks, getDateFromString, getNextMonthFromDate, getPrevMonthFromDate, handleKeyPress, i18nFormat as format, inDateRange, } from './utils';\r\nimport { omit, useForkedRef, useGenerateId } from '../../utils';\r\nconst DatePickerContainer = styled.div `\n  position: relative;\n`;\r\nconst DatePickerCalendar = styled.div `\n  border: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.15);\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: ${props => (props.opened ? 'block' : 'none')};\n  margin: ${props => props.theme.spaceScale.spacing01} 0px;\n  opacity: ${props => (props.opened ? '1' : '0')};\n  overflow: hidden;\n  transition: opacity 0.2s ease-in-out 0s;\n  width: 320px;\n`;\r\nexport const DatePicker = React.forwardRef((props, forwardedRef) => {\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const iconRef = React.useRef();\r\n    const inputRef = React.useRef();\r\n    const lastFocus = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const [helperInformationShown, setHelperInformationShown] = React.useState(false);\r\n    const [calendarOpened, setCalendarOpened] = React.useState(false);\r\n    const [dateFocused, setDateFocused] = React.useState(false);\r\n    const [focusedDate, setFocusedDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate) ||\r\n        setDefaultFocusedDate());\r\n    const [chosenDate, setChosenDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate));\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    React.useEffect(() => {\r\n        if (!calendarOpened) {\r\n            setDateFocused(false);\r\n        }\r\n    }, [calendarOpened]);\r\n    React.useEffect(() => {\r\n        if (props.value) {\r\n            setFocusedDate(setDateFromConsumer(props.value) || setDefaultFocusedDate());\r\n            setChosenDate(setDateFromConsumer(props.value));\r\n        }\r\n        if (props.value === null)\r\n            setChosenDate(undefined);\r\n    }, [props.value]);\r\n    function showHelperInformation() {\r\n        lastFocus.current = document.activeElement;\r\n        setHelperInformationShown(true);\r\n    }\r\n    function hideHelperInformation() {\r\n        lastFocus.current.focus();\r\n        setHelperInformationShown(false);\r\n    }\r\n    function closeHelperInformation() {\r\n        setHelperInformationShown(false);\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    const setFocusedTodayDate = (event) => {\r\n        const isKeyboardEvent = event.type === 'keydown';\r\n        if ((isKeyboardEvent &&\r\n            (event.key === ' ' ||\r\n                event.key === 'Enter')) ||\r\n            event.type === 'click') {\r\n            event.preventDefault();\r\n            setFocusedDate(setDefaultFocusedDate());\r\n        }\r\n    };\r\n    function setDateFromConsumer(date) {\r\n        const convertedDate = getDateFromString(date);\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        return date &&\r\n            inDateRange(convertedDate, convertedMinDate, convertedMaxDate)\r\n            ? convertedDate\r\n            : null;\r\n    }\r\n    function setDefaultFocusedDate() {\r\n        const newDate = new Date();\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        if (inDateRange(newDate, convertedMinDate, convertedMaxDate)) {\r\n            if (isBefore(startOfDay(newDate), convertedMinDate)) {\r\n                return addDays(newDate, 1);\r\n            }\r\n            return newDate;\r\n        }\r\n        else if (convertedMaxDate || convertedMinDate) {\r\n            return convertedMinDate ? convertedMinDate : convertedMaxDate;\r\n        }\r\n    }\r\n    function buildCalendarMonth(date, enableOutsideDates) {\r\n        const days = [\r\n            'sunday',\r\n            'monday',\r\n            'tuesday',\r\n            'wednesday',\r\n            'thursday',\r\n            'friday',\r\n            'saturday',\r\n        ];\r\n        const { startOfWeek } = i18n.datePicker;\r\n        return getCalendarMonthWeeks(date, enableOutsideDates, days.indexOf(startOfWeek));\r\n    }\r\n    function onPrevMonthClick() {\r\n        const newDate = getPrevMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function onNextMonthClick() {\r\n        const newDate = getNextMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function onDateChange(day) {\r\n        setChosenDate(day);\r\n        setCalendarOpened(false);\r\n    }\r\n    function reset() {\r\n        setFocusedDate(setDefaultFocusedDate());\r\n        setChosenDate(null);\r\n        setDateFocused(false);\r\n    }\r\n    function isValidDateFromString(value, day) {\r\n        const isValidDateFormat = isMatch(value, i18n.dateFormat);\r\n        const parsedDate = parse(value, i18n.dateFormat, new Date());\r\n        const isValidDate = isValid(parsedDate);\r\n        return isValidDateFormat && isValidDate;\r\n    }\r\n    function handleInputChange(event) {\r\n        const { value } = event.target;\r\n        const day = new Date(value);\r\n        setCalendarOpened(false);\r\n        props.onInputChange &&\r\n            typeof props.onInputChange === 'function' &&\r\n            props.onInputChange(event);\r\n        const isValidDay = isValidDateFromString(value, day);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(isValidDay ? day.toISOString() : value, event);\r\n    }\r\n    function handleInputFocus(event) {\r\n        props.onInputFocus &&\r\n            typeof props.onInputFocus === 'function' &&\r\n            props.onInputFocus(event);\r\n    }\r\n    function handleInputBlur(event) {\r\n        const { value } = inputRef.current;\r\n        const day = parse(value, i18n.dateFormat, new Date());\r\n        if (isValidDateFromString(value, day)) {\r\n            handleDateChange(day, event);\r\n        }\r\n        else {\r\n            reset && typeof reset === 'function' && reset();\r\n        }\r\n        props.onInputBlur &&\r\n            typeof props.onInputBlur === 'function' &&\r\n            props.onInputBlur(event);\r\n    }\r\n    function handleInputKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            setCalendarOpened(false);\r\n            inputRef.current.focus();\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            setCalendarOpened(false);\r\n            iconRef.current.focus();\r\n        }\r\n        if (dateFocused && document.activeElement.closest('table')) {\r\n            const newChosenDate = handleKeyPress(event, focusedDate, setCalendarOpened, showHelperInformation, onDateChange, iconRef);\r\n            if (newChosenDate) {\r\n                if (minDate && maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate)) &&\r\n                        isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (minDate && !maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (maxDate && !minDate) {\r\n                    if (isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else {\r\n                    setFocusedDate(newChosenDate);\r\n                }\r\n            }\r\n        }\r\n    }\r\n    function handleDateChange(day, event) {\r\n        props.onDateChange &&\r\n            typeof props.onDateChange === 'function' &&\r\n            props.onDateChange(day, event);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(day?.toISOString(), event);\r\n        onDateChange(day);\r\n        setFocusedDate(isAfter(setHours(day, 12), minDate) ? day : setDefaultFocusedDate);\r\n    }\r\n    function handleDaySelection(day, event) {\r\n        handleDateChange(day, event);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleCalendarBlur(event) {\r\n        const { currentTarget } = event;\r\n        // timeout needed for active element to update. Browser behavior.\r\n        // https://bugzilla.mozilla.org/show_bug.cgi?id=452307\r\n        setTimeout(() => {\r\n            const isInCalendar = currentTarget.contains(document.activeElement);\r\n            if (!isInCalendar && !helperInformationShown) {\r\n                setCalendarOpened(false);\r\n            }\r\n        }, 0);\r\n    }\r\n    function handleCloseButtonClick(event) {\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    function toggleCalendarOpened() {\r\n        setCalendarOpened(opened => !opened);\r\n    }\r\n    const { placeholder, testId, ...rest } = props;\r\n    const other = omit(['onDateChange', 'onInputChange', 'onInputBlur', 'onInputFocus'], rest);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const minDate = getDateFromString(props.minDate);\r\n    const maxDate = getDateFromString(props.maxDate);\r\n    const dateFormat = i18n.dateFormat;\r\n    const inputValue = chosenDate ? format(chosenDate, dateFormat) : '';\r\n    const { floatingStyles, refs, elements, update } = useMagmaFloating();\r\n    React.useEffect(() => {\r\n        const referenceDateInput = elements.reference;\r\n        const floatingCalendar = elements.floating;\r\n        if (calendarOpened && referenceDateInput && floatingCalendar) {\r\n            return autoUpdate(referenceDateInput, floatingCalendar, update);\r\n        }\r\n    }, [calendarOpened, elements, update]);\r\n    return (React.createElement(CalendarContext.Provider, { value: {\r\n            chosenDate,\r\n            focusedDate,\r\n            dateFocused,\r\n            maxDate,\r\n            minDate,\r\n            helperInformationShown,\r\n            isInverse,\r\n            buildCalendarMonth,\r\n            showHelperInformation,\r\n            hideHelperInformation,\r\n            onKeyDown: handleKeyDown,\r\n            onPrevMonthClick,\r\n            onNextMonthClick,\r\n            onDateChange: handleDaySelection,\r\n            setDateFocused,\r\n            setFocusedTodayDate,\r\n            setFocusedDate,\r\n            onClose: closeHelperInformation,\r\n        } },\r\n        React.createElement(DatePickerContainer, { \"data-testid\": testId, onBlur: handleCalendarBlur },\r\n            React.createElement(Announce, null, calendarOpened && (React.createElement(VisuallyHidden, null, i18n.datePicker.calendarOpenAnnounce))),\r\n            React.createElement(Input, Object.assign({}, other, { icon: React.createElement(EventIcon, null), iconAriaLabel: i18n.datePicker.calendarIconAriaLabel, iconRef: iconRef, onIconClick: toggleCalendarOpened, onIconKeyDown: handleInputKeyDown, id: id, isInverse: isInverse, ref: ref, onChange: handleInputChange, onBlur: handleInputBlur, onFocus: handleInputFocus, onKeyDown: handleInputKeyDown, onDateChange: handleDateChange, placeholder: placeholder ? placeholder : dateFormat.toLowerCase(), type: InputType.text, value: inputValue, setReference: refs.setReference })),\r\n            React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n                React.createElement(\"div\", { ref: el => calendarOpened && refs.setFloating(el), style: { ...floatingStyles, zIndex: '998' } },\r\n                    React.createElement(DatePickerCalendar, { \"data-testid\": \"calendarContainer\", opened: calendarOpened, isInverse: isInverse, theme: theme },\r\n                        React.createElement(CalendarMonth, { focusOnOpen: calendarOpened &&\r\n                                Boolean(focusedDate) &&\r\n                                Boolean(chosenDate), isInverse: isInverse, handleCloseButtonClick: handleCloseButtonClick, calendarOpened: calendarOpened, setDateFocused: setDateFocused })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
7817
7827
  var DatePicker = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
7818
7828
  var theme = React.useContext(ThemeContext);
7819
7829
  var i18n = React.useContext(I18nContext);
@@ -7862,7 +7872,7 @@ var DatePicker = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
7862
7872
  iconRef.current.focus();
7863
7873
  setCalendarOpened(false);
7864
7874
  }
7865
- var setFocusedCurrentDate = function setFocusedCurrentDate(event) {
7875
+ var setFocusedTodayDate = function setFocusedTodayDate(event) {
7866
7876
  var isKeyboardEvent = event.type === 'keydown';
7867
7877
  if (isKeyboardEvent && (event.key === ' ' || event.key === 'Enter') || event.type === 'click') {
7868
7878
  event.preventDefault();
@@ -8039,7 +8049,8 @@ var DatePicker = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
8039
8049
  onNextMonthClick: onNextMonthClick,
8040
8050
  onDateChange: handleDaySelection,
8041
8051
  setDateFocused: setDateFocused,
8042
- setFocusedTodayDate: setFocusedCurrentDate,
8052
+ setFocusedTodayDate: setFocusedTodayDate,
8053
+ setFocusedDate: setFocusedDate,
8043
8054
  onClose: closeHelperInformation
8044
8055
  }
8045
8056
  }, React.createElement(DatePickerContainer, {
@@ -16238,7 +16249,7 @@ function useMediaQuery(queryInput) {
16238
16249
  return match;
16239
16250
  }
16240
16251
 
16241
- var _excluded$1G = ["style", "containerStyle", "position"];
16252
+ var _excluded$1G = ["style", "containerStyle", "position", "isAnimated"];
16242
16253
  (function (DrawerPosition) {
16243
16254
  DrawerPosition["top"] = "top";
16244
16255
  DrawerPosition["bottom"] = "bottom";
@@ -16259,19 +16270,26 @@ var transitionPreset = {
16259
16270
  slideRight: true
16260
16271
  }
16261
16272
  };
16262
- var Drawer = /*#__PURE__*/React.forwardRef(function (props, ref) {
16273
+ var Drawer = /*#__PURE__*/React.forwardRef(function (props, _ref) {
16263
16274
  var style = props.style,
16264
16275
  containerStyle = props.containerStyle,
16265
16276
  position = props.position,
16277
+ _props$isAnimated = props.isAnimated,
16278
+ isAnimated = _props$isAnimated === void 0 ? false : _props$isAnimated,
16266
16279
  rest = _objectWithoutPropertiesLoose(props, _excluded$1G);
16267
16280
  var theme = React.useContext(ThemeContext);
16268
- var drawerStyle = _extends({}, theme.drawer["default"], theme.drawer[exports.DrawerPosition[position]]);
16281
+ var drawerPosition = position != null ? position : exports.DrawerPosition.top;
16282
+ var drawerStyle = _extends({}, theme.drawer["default"], theme.drawer[drawerPosition]);
16283
+ var containerTransition;
16284
+ if (isAnimated) {
16285
+ containerTransition = position ? transitionPreset[exports.DrawerPosition[position]] : transitionPreset[exports.DrawerPosition[exports.DrawerPosition.top]];
16286
+ }
16269
16287
  return React.createElement(Modal, Object.assign({
16270
16288
  containerStyle: _extends({
16271
16289
  padding: '0'
16272
16290
  }, containerStyle),
16273
- containerTransition: position ? transitionPreset[exports.DrawerPosition[position]] : transitionPreset[exports.DrawerPosition[exports.DrawerPosition.top]],
16274
- hasDrawerAnimation: true,
16291
+ containerTransition: containerTransition,
16292
+ hasDrawerAnimation: isAnimated,
16275
16293
  style: _extends({}, drawerStyle, style)
16276
16294
  }, rest));
16277
16295
  });