react-magma-dom 4.10.0-next.31 → 4.10.0-next.33
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.
- package/dist/esm/index.js +124 -34
- package/dist/esm/index.js.map +1 -1
- package/dist/properties.json +15 -15
- package/dist/react-magma-dom.cjs.development.js +124 -34
- package/dist/react-magma-dom.cjs.development.js.map +1 -1
- package/dist/react-magma-dom.cjs.production.min.js +1 -1
- package/dist/react-magma-dom.cjs.production.min.js.map +1 -1
- package/package.json +1 -1
package/dist/esm/index.js
CHANGED
|
@@ -10530,7 +10530,10 @@ var getTodayColor = function getTodayColor(isChosen, isInverse, theme) {
|
|
|
10530
10530
|
var getChosenDayColor = function getChosenDayColor(isInverse, theme) {
|
|
10531
10531
|
return isInverse ? theme.colors.primary600 : theme.colors.neutral100;
|
|
10532
10532
|
};
|
|
10533
|
-
var getDisabledColor = function getDisabledColor(isInverse, theme) {
|
|
10533
|
+
var getDisabledColor = function getDisabledColor(isChosen, isInverse, theme) {
|
|
10534
|
+
if (isChosen) {
|
|
10535
|
+
return isInverse ? theme.colors.primary600 : theme.colors.neutral100;
|
|
10536
|
+
}
|
|
10534
10537
|
return isInverse ? curriedTransparentize(0.6, theme.colors.neutral100) : curriedTransparentize(0.4, theme.colors.neutral500);
|
|
10535
10538
|
};
|
|
10536
10539
|
var getNotCurrentMonthColor = function getNotCurrentMonthColor(isInverse, theme) {
|
|
@@ -10541,7 +10544,7 @@ var getCurrentMonthColor = function getCurrentMonthColor(isInverse, theme) {
|
|
|
10541
10544
|
};
|
|
10542
10545
|
var getCalendarDayColor = function getCalendarDayColor(state, isInverse, theme) {
|
|
10543
10546
|
if (state.isToday) return getTodayColor(state.isChosen, isInverse, theme);
|
|
10544
|
-
if (state.disabled) return getDisabledColor(isInverse, theme);
|
|
10547
|
+
if (state.disabled) return getDisabledColor(state.isChosen, isInverse, theme);
|
|
10545
10548
|
if (state.isChosen) return getChosenDayColor(isInverse, theme);
|
|
10546
10549
|
if (!state.isDayInCurrentMonth && !state.disabled) return getNotCurrentMonthColor(isInverse, theme);
|
|
10547
10550
|
return getCurrentMonthColor(isInverse, theme);
|
|
@@ -10574,7 +10577,7 @@ var CalendarDayCell = /*#__PURE__*/_styled("td", {
|
|
|
10574
10577
|
return props.theme.typeScale.size03.lineHeight;
|
|
10575
10578
|
}, ";height:", function (props) {
|
|
10576
10579
|
return props.theme.spaceScale.spacing09;
|
|
10577
|
-
}, ";padding:0;position:relative;text-align:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# 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\", disabled: disabled, 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"]} */"));
|
|
10580
|
+
}, ";padding:0;position:relative;text-align:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AAmEkC","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 = (isChosen, isInverse, theme) => {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n    }\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(state.isChosen, 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\", disabled: disabled, 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"]} */"));
|
|
10578
10581
|
var CalendarDayInner = /*#__PURE__*/_styled("button", {
|
|
10579
10582
|
target: "eviokpi2",
|
|
10580
10583
|
label: "CalendarDayInner"
|
|
@@ -10600,7 +10603,7 @@ var CalendarDayInner = /*#__PURE__*/_styled("button", {
|
|
|
10600
10603
|
return getChosenDayHover(props.state.isChosen, props.isInverse, props.theme);
|
|
10601
10604
|
}, ";&:before{opacity:", function (props) {
|
|
10602
10605
|
return props.state.disabled ? 0 : 0.1;
|
|
10603
|
-
}, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# 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\", disabled: disabled, 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"]} */"));
|
|
10606
|
+
}, ";}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AA6EuC","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 = (isChosen, isInverse, theme) => {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n    }\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(state.isChosen, 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\", disabled: disabled, 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"]} */"));
|
|
10604
10607
|
var EmptyCell = /*#__PURE__*/_styled("td", {
|
|
10605
10608
|
target: "eviokpi1",
|
|
10606
10609
|
label: "EmptyCell"
|
|
@@ -10609,7 +10612,7 @@ var EmptyCell = /*#__PURE__*/_styled("td", {
|
|
|
10609
10612
|
styles: "border:0;padding:0"
|
|
10610
10613
|
} : {
|
|
10611
10614
|
name: "1njmmm4",
|
|
10612
|
-
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\", disabled: disabled, 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"]} */",
|
|
10615
|
+
styles: "border:0;padding:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AA8H4B","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 = (isChosen, isInverse, theme) => {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n    }\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(state.isChosen, 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\", disabled: disabled, 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"]} */",
|
|
10613
10616
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$g
|
|
10614
10617
|
});
|
|
10615
10618
|
var TodayIndicator = /*#__PURE__*/_styled("span", {
|
|
@@ -10617,7 +10620,7 @@ var TodayIndicator = /*#__PURE__*/_styled("span", {
|
|
|
10617
10620
|
label: "TodayIndicator"
|
|
10618
10621
|
})("position:absolute;bottom:5px;left:19px;width:5px;height:5px;border-radius:50%;background:", function (props) {
|
|
10619
10622
|
return getTodayColor(props.isChosen, props.isInverse, props.theme);
|
|
10620
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# 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\", disabled: disabled, 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"]} */"));
|
|
10623
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AAkImC","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 = (isChosen, isInverse, theme) => {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n    }\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(state.isChosen, 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\", disabled: disabled, 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"]} */"));
|
|
10621
10624
|
var CalendarDay = function CalendarDay(props) {
|
|
10622
10625
|
var dayRef = useRef();
|
|
10623
10626
|
var _React$useContext = useContext(CalendarContext),
|
|
@@ -10724,7 +10727,10 @@ var MonthPicker = function MonthPicker(props) {
|
|
|
10724
10727
|
var currentMonth = props.currentMonth,
|
|
10725
10728
|
isInverse = props.isInverse;
|
|
10726
10729
|
var _React$useContext = useContext(CalendarContext),
|
|
10727
|
-
setMonthFocusedDate = _React$useContext.setMonthFocusedDate
|
|
10730
|
+
setMonthFocusedDate = _React$useContext.setMonthFocusedDate,
|
|
10731
|
+
minDate = _React$useContext.minDate,
|
|
10732
|
+
maxDate = _React$useContext.maxDate,
|
|
10733
|
+
focusedDate = _React$useContext.focusedDate;
|
|
10728
10734
|
var i18n = useContext(I18nContext);
|
|
10729
10735
|
var monthsLabels = i18n.months["long"];
|
|
10730
10736
|
var theme = useContext(ThemeContext);
|
|
@@ -10740,6 +10746,24 @@ var MonthPicker = function MonthPicker(props) {
|
|
|
10740
10746
|
return month.label === label;
|
|
10741
10747
|
})) == null ? void 0 : _months$find.value;
|
|
10742
10748
|
};
|
|
10749
|
+
var isMonthDisabled = function isMonthDisabled(monthValue) {
|
|
10750
|
+
var currentYear = new Date(focusedDate).getFullYear();
|
|
10751
|
+
if (minDate) {
|
|
10752
|
+
var minYear = minDate.getFullYear();
|
|
10753
|
+
var minMonth = minDate.getMonth();
|
|
10754
|
+
if (currentYear === minYear && monthValue < minMonth) {
|
|
10755
|
+
return true;
|
|
10756
|
+
}
|
|
10757
|
+
}
|
|
10758
|
+
if (maxDate) {
|
|
10759
|
+
var maxYear = maxDate.getFullYear();
|
|
10760
|
+
var maxMonth = maxDate.getMonth();
|
|
10761
|
+
if (currentYear === maxYear && monthValue > maxMonth) {
|
|
10762
|
+
return true;
|
|
10763
|
+
}
|
|
10764
|
+
}
|
|
10765
|
+
return false;
|
|
10766
|
+
};
|
|
10743
10767
|
function onMonthChange(month) {
|
|
10744
10768
|
setMonthFocusedDate(month);
|
|
10745
10769
|
}
|
|
@@ -10749,19 +10773,19 @@ var MonthPicker = function MonthPicker(props) {
|
|
|
10749
10773
|
context.font = font;
|
|
10750
10774
|
return context.measureText(text).width;
|
|
10751
10775
|
};
|
|
10752
|
-
var
|
|
10753
|
-
var currentLabel = currentMonth;
|
|
10776
|
+
var getMonthWidth = function getMonthWidth(month) {
|
|
10754
10777
|
var font = theme.typeScale.size03.fontSize + " " + theme.bodyFont;
|
|
10755
10778
|
var padding = parseInt(theme.spaceScale.spacing03, 10) * 2;
|
|
10756
|
-
return Math.ceil(getTextWidth(
|
|
10757
|
-
}
|
|
10779
|
+
return Math.ceil(getTextWidth(month, font) + padding);
|
|
10780
|
+
};
|
|
10781
|
+
var width = getMonthWidth(currentMonth);
|
|
10758
10782
|
return createElement(StyledSelect, {
|
|
10759
10783
|
isInverse: isInverse,
|
|
10760
10784
|
theme: theme
|
|
10761
10785
|
}, createElement(NativeSelect, {
|
|
10762
10786
|
"aria-label": i18n.datePicker.selectMonth,
|
|
10763
10787
|
"data-testid": "month-picker",
|
|
10764
|
-
fieldId: '',
|
|
10788
|
+
fieldId: 'month-picker-id',
|
|
10765
10789
|
onChange: function onChange(e) {
|
|
10766
10790
|
return onMonthChange(Number(e.target.value));
|
|
10767
10791
|
},
|
|
@@ -10772,7 +10796,8 @@ var MonthPicker = function MonthPicker(props) {
|
|
|
10772
10796
|
}, months.map(function (month) {
|
|
10773
10797
|
return createElement("option", {
|
|
10774
10798
|
key: month.value,
|
|
10775
|
-
value: month.value
|
|
10799
|
+
value: month.value,
|
|
10800
|
+
disabled: isMonthDisabled(month.value)
|
|
10776
10801
|
}, month.label);
|
|
10777
10802
|
})));
|
|
10778
10803
|
};
|
|
@@ -10800,6 +10825,12 @@ var YearPicker = function YearPicker(props) {
|
|
|
10800
10825
|
value: year
|
|
10801
10826
|
};
|
|
10802
10827
|
});
|
|
10828
|
+
// Show the current year as a disabled option if it's not in the range between minDate and maxDate
|
|
10829
|
+
var showCurrentYearOption = !years.some(function (year) {
|
|
10830
|
+
return year.value === currentYear;
|
|
10831
|
+
});
|
|
10832
|
+
var isCurrentYearBeforeRange = currentYear < minYear;
|
|
10833
|
+
var isCurrentYearAfterRange = currentYear > maxYear;
|
|
10803
10834
|
function onYearChange(year) {
|
|
10804
10835
|
setYearFocusedDate(year);
|
|
10805
10836
|
}
|
|
@@ -10809,17 +10840,23 @@ var YearPicker = function YearPicker(props) {
|
|
|
10809
10840
|
}, React__default.createElement(NativeSelect, {
|
|
10810
10841
|
"aria-label": i18n.datePicker.selectYear,
|
|
10811
10842
|
"data-testid": "year-picker",
|
|
10812
|
-
fieldId: '',
|
|
10843
|
+
fieldId: 'year-picker-id',
|
|
10813
10844
|
onChange: function onChange(e) {
|
|
10814
10845
|
return onYearChange(Number(e.target.value));
|
|
10815
10846
|
},
|
|
10816
10847
|
value: currentYear
|
|
10817
|
-
},
|
|
10848
|
+
}, showCurrentYearOption && isCurrentYearBeforeRange && React__default.createElement("option", {
|
|
10849
|
+
value: currentYear,
|
|
10850
|
+
disabled: true
|
|
10851
|
+
}, currentYear), years.map(function (year) {
|
|
10818
10852
|
return React__default.createElement("option", {
|
|
10819
10853
|
key: year.value,
|
|
10820
10854
|
value: year.value
|
|
10821
10855
|
}, year.label);
|
|
10822
|
-
})
|
|
10856
|
+
}), showCurrentYearOption && isCurrentYearAfterRange && React__default.createElement("option", {
|
|
10857
|
+
value: currentYear,
|
|
10858
|
+
disabled: true
|
|
10859
|
+
}, currentYear)));
|
|
10823
10860
|
};
|
|
10824
10861
|
|
|
10825
10862
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$h() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
@@ -10830,7 +10867,7 @@ var CalendarHeaderContainer = /*#__PURE__*/_styled("div", {
|
|
|
10830
10867
|
return props.theme.spaceScale.spacing03;
|
|
10831
10868
|
}, " 0 ", function (props) {
|
|
10832
10869
|
return props.theme.spaceScale.spacing05;
|
|
10833
|
-
}, ";justify-content:space-between;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
10870
|
+
}, ";justify-content:space-between;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFySGVhZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlMkMiLCJmaWxlIjoiQ2FsZW5kYXJIZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IGFkZE1vbnRocywgc3ViTW9udGhzLCBzdGFydE9mTW9udGggfSBmcm9tICdkYXRlLWZucyc7XHJcbmltcG9ydCB7IGVuVVMgfSBmcm9tICdkYXRlLWZucy9sb2NhbGUnO1xyXG5pbXBvcnQgeyBLZXlib2FyZEFycm93TGVmdEljb24sIEtleWJvYXJkQXJyb3dSaWdodEljb24sIH0gZnJvbSAncmVhY3QtbWFnbWEtaWNvbnMnO1xyXG5pbXBvcnQgeyBDYWxlbmRhckNvbnRleHQgfSBmcm9tICcuL0NhbGVuZGFyQ29udGV4dCc7XHJcbmltcG9ydCB7IGkxOG5Gb3JtYXQgYXMgZm9ybWF0LCBnZXRDdXJyZW50TW9udGhBbmRZZWFyIH0gZnJvbSAnLi91dGlscyc7XHJcbmltcG9ydCB7IEkxOG5Db250ZXh0IH0gZnJvbSAnLi4vLi4vaTE4bic7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEJ1dHRvbkNvbG9yLCBCdXR0b25UeXBlLCBCdXR0b25WYXJpYW50IH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBNb250aFBpY2tlciB9IGZyb20gJy4vTW9udGhQaWNrZXInO1xyXG5pbXBvcnQgeyBZZWFyUGlja2VyIH0gZnJvbSAnLi9ZZWFyUGlja2VyJztcclxuaW1wb3J0IHsgQW5ub3VuY2UgfSBmcm9tICcuLi9Bbm5vdW5jZSc7XHJcbmltcG9ydCB7IFZpc3VhbGx5SGlkZGVuIH0gZnJvbSAnLi4vVmlzdWFsbHlIaWRkZW4nO1xyXG5jb25zdCBDYWxlbmRhckhlYWRlckNvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwXG4gICAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNX07XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XHJcbmNvbnN0IENhbGVuZGFySGVhZGVyVGV4dCA9IHN0eWxlZC5kaXYgYFxuICBjYXB0aW9uLXNpZGU6IGluaXRpYWw7XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMH07XG4gIGZvbnQtc2l6ZTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmZvbnRTaXplfTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcblxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiBub25lO1xuICB9XG5gO1xyXG5jb25zdCBNb250aFllYXJXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMX07XG5gO1xyXG5jb25zdCBOYXZpZ2F0aW9uV3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogcm93O1xuYDtcclxuZXhwb3J0IGNvbnN0IENhbGVuZGFySGVhZGVyID0gcHJvcHMgPT4ge1xyXG4gICAgY29uc3QgeyBmb2N1c2VkRGF0ZSwgb25QcmV2TW9udGhDbGljaywgb25OZXh0TW9udGhDbGljaywgbWluRGF0ZSwgbWF4RGF0ZSwgc2V0Rm9jdXNlZERhdGUsIH0gPSBSZWFjdC51c2VDb250ZXh0KENhbGVuZGFyQ29udGV4dCk7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGkxOG4gPSBSZWFjdC51c2VDb250ZXh0KEkxOG5Db250ZXh0KTtcclxuICAgIGNvbnN0IGxvY2FsZSA9IGkxOG4ubG9jYWxlIHx8IGVuVVM7XHJcbiAgICBjb25zdCBtb250aEFuZFllYXIgPSBnZXRDdXJyZW50TW9udGhBbmRZZWFyKGZvY3VzZWREYXRlLCBsb2NhbGUpO1xyXG4gICAgY29uc3QgbWluRGF0ZU9yRGVmYXVsdCA9IG1pbkRhdGUgPz8gbmV3IERhdGUoMTkwMCwgMCwgMSk7XHJcbiAgICBjb25zdCBtYXhEYXRlT3JEZWZhdWx0ID0gbWF4RGF0ZSA/PyBuZXcgRGF0ZSgyMDk5LCAxMSwgMzEpO1xyXG4gICAgY29uc3QgcHJldmlvdXNNb250aFJlZiA9IFJlYWN0LnVzZVJlZigpO1xyXG4gICAgY29uc3QgbmV4dE1vbnRoUmVmID0gUmVhY3QudXNlUmVmKCk7XHJcbiAgICBjb25zdCBpc0RhdGVFYXJsaWVyVGhhbk1pbkRhdGUgPSAobnVtYmVyTW9udGhzKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIChzdGFydE9mTW9udGgoc3ViTW9udGhzKGZvY3VzZWREYXRlLCBudW1iZXJNb250aHMpKSA8XHJcbiAgICAgICAgICAgIHN0YXJ0T2ZNb250aChtaW5EYXRlT3JEZWZhdWx0KSk7XHJcbiAgICB9O1xyXG4gICAgY29uc3QgaXNEYXRlTGF0ZXJUaGFuTWF4RGF0ZSA9IChudW1iZXJNb250aHMpID0+IHtcclxuICAgICAgICByZXR1cm4gKHN0YXJ0T2ZNb250aChhZGRNb250aHMoZm9jdXNlZERhdGUsIG51bWJlck1vbnRocykpID5cclxuICAgICAgICAgICAgc3RhcnRPZk1vbnRoKG1heERhdGVPckRlZmF1bHQpKTtcclxuICAgIH07XHJcbiAgICBjb25zdCBpc0Rpc2FibGVkUHJldk1vbnRoID0gaXNEYXRlRWFybGllclRoYW5NaW5EYXRlKDEpO1xyXG4gICAgY29uc3QgaXNEaXNhYmxlZE5leHRNb250aCA9IGlzRGF0ZUxhdGVyVGhhbk1heERhdGUoMSk7XHJcbiAgICBjb25zdCBvbkNsaWNrUHJldk1vbnRoID0gKCkgPT4ge1xyXG4gICAgICAgIGlmIChpc0RhdGVFYXJsaWVyVGhhbk1pbkRhdGUoMikpIHtcclxuICAgICAgICAgICAgbmV4dE1vbnRoUmVmLmN1cnJlbnQ/LmZvY3VzKCk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChzdGFydE9mTW9udGgobWF4RGF0ZU9yRGVmYXVsdCkgPj0gc3RhcnRPZk1vbnRoKGZvY3VzZWREYXRlKSkge1xyXG4gICAgICAgICAgICBvblByZXZNb250aENsaWNrKCk7XHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICB9XHJcbiAgICAgICAgaWYgKCFpc0Rpc2FibGVkUHJldk1vbnRoICYmIGlzRGlzYWJsZWROZXh0TW9udGgpIHtcclxuICAgICAgICAgICAgc2V0Rm9jdXNlZERhdGUobWF4RGF0ZU9yRGVmYXVsdCk7XHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICB9XHJcbiAgICAgICAgb25QcmV2TW9udGhDbGljaygpO1xyXG4gICAgfTtcclxuICAgIGNvbnN0IG9uQ2xpY2tOZXh0TW9udGggPSAoKSA9PiB7XHJcbiAgICAgICAgaWYgKGlzRGF0ZUxhdGVyVGhhbk1heERhdGUoMikpIHtcclxuICAgICAgICAgICAgcHJldmlvdXNNb250aFJlZi5jdXJyZW50Py5mb2N1cygpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAoc3RhcnRPZk1vbnRoKG1pbkRhdGVPckRlZmF1bHQpIDw9IHN0YXJ0T2ZNb250aChmb2N1c2VkRGF0ZSkpIHtcclxuICAgICAgICAgICAgb25OZXh0TW9udGhDbGljaygpO1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChpc0Rpc2FibGVkUHJldk1vbnRoICYmICFpc0Rpc2FibGVkTmV4dE1vbnRoKSB7XHJcbiAgICAgICAgICAgIHNldEZvY3VzZWREYXRlKG1pbkRhdGVPckRlZmF1bHQpO1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIG9uTmV4dE1vbnRoQ2xpY2soKTtcclxuICAgIH07XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2FsZW5kYXJIZWFkZXJDb250YWluZXIsIHsgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChDYWxlbmRhckhlYWRlclRleHQsIHsgdGFiSW5kZXg6IC0xLCB0aGVtZTogdGhlbWUsIGlzSW52ZXJzZTogcHJvcHMuaXNJbnZlcnNlIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTW9udGhZZWFyV3JhcHBlciwgeyB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTW9udGhQaWNrZXIsIHsgY3VycmVudE1vbnRoOiBtb250aEFuZFllYXIubW9udGgsIGlzSW52ZXJzZTogcHJvcHMuaXNJbnZlcnNlIH0pLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChZZWFyUGlja2VyLCB7IGN1cnJlbnRZZWFyOiBOdW1iZXIobW9udGhBbmRZZWFyLnllYXIpLCBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSB9KSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVmlzdWFsbHlIaWRkZW4sIG51bGwsXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEFubm91bmNlLCB7IFwiYXJpYS1hdG9taWNcIjogXCJ0cnVlXCIgfSxcclxuICAgICAgICAgICAgICAgICAgICBtb250aEFuZFllYXIubW9udGgsXHJcbiAgICAgICAgICAgICAgICAgICAgXCIgXCIsXHJcbiAgICAgICAgICAgICAgICAgICAgbW9udGhBbmRZZWFyLnllYXIpKSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChOYXZpZ2F0aW9uV3JhcHBlciwgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJY29uQnV0dG9uLCB7IFwiYXJpYS1sYWJlbFwiOiBgJHtpMThuLmRhdGVQaWNrZXIucHJldmlvdXNNb250aEFyaWFMYWJlbH0gJHtmb3JtYXQoc3ViTW9udGhzKG5ldyBEYXRlKGZvY3VzZWREYXRlKSwgMSksICdNTU1NIHl5eXknLCBsb2NhbGUpfWAsIGNvbG9yOiBCdXR0b25Db2xvci5zdWJ0bGUsIGRpc2FibGVkOiBpc0Rpc2FibGVkUHJldk1vbnRoLCBpY29uOiBSZWFjdC5jcmVhdGVFbGVtZW50KEtleWJvYXJkQXJyb3dMZWZ0SWNvbiwgbnVsbCksIHR5cGU6IEJ1dHRvblR5cGUuYnV0dG9uLCB2YXJpYW50OiBCdXR0b25WYXJpYW50LmxpbmssIG9uQ2xpY2s6IG9uQ2xpY2tQcmV2TW9udGgsIHJlZjogcHJldmlvdXNNb250aFJlZiwgc3R5bGU6IHsgbWFyZ2luUmlnaHQ6IHRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAyIH0gfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSWNvbkJ1dHRvbiwgeyBcImFyaWEtbGFiZWxcIjogYCR7aTE4bi5kYXRlUGlja2VyLm5leHRNb250aEFyaWFMYWJlbH0gJHtmb3JtYXQoYWRkTW9udGhzKG5ldyBEYXRlKGZvY3VzZWREYXRlKSwgMSksICdNTU1NIHl5eXknLCBsb2NhbGUpfWAsIGljb246IFJlYWN0LmNyZWF0ZUVsZW1lbnQoS2V5Ym9hcmRBcnJvd1JpZ2h0SWNvbiwgbnVsbCksIGNvbG9yOiBCdXR0b25Db2xvci5zdWJ0bGUsIGRpc2FibGVkOiBpc0Rpc2FibGVkTmV4dE1vbnRoLCB0eXBlOiBCdXR0b25UeXBlLmJ1dHRvbiwgdmFyaWFudDogQnV0dG9uVmFyaWFudC5saW5rLCBvbkNsaWNrOiBvbkNsaWNrTmV4dE1vbnRoLCByZWY6IG5leHRNb250aFJlZiwgc3R5bGU6IHsgbWFyZ2luTGVmdDogdGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDIgfSB9KSkpKTtcclxufTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q2FsZW5kYXJIZWFkZXIuanMubWFwIl19 */"));
|
|
10834
10871
|
var CalendarHeaderText = /*#__PURE__*/_styled("div", {
|
|
10835
10872
|
target: "eg9fn2d2",
|
|
10836
10873
|
label: "CalendarHeaderText"
|
|
@@ -10840,13 +10877,13 @@ var CalendarHeaderText = /*#__PURE__*/_styled("div", {
|
|
|
10840
10877
|
return props.theme.typeScale.size03.fontSize;
|
|
10841
10878
|
}, ";line-height:", function (props) {
|
|
10842
10879
|
return props.theme.typeScale.size03.lineHeight;
|
|
10843
|
-
}, ";text-align:center;justify-content:center;align-items:center;font-weight:600;&:focus{outline:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
10880
|
+
}, ";text-align:center;justify-content:center;align-items:center;font-weight:600;&:focus{outline:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFySGVhZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQnNDIiwiZmlsZSI6IkNhbGVuZGFySGVhZGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBhZGRNb250aHMsIHN1Yk1vbnRocywgc3RhcnRPZk1vbnRoIH0gZnJvbSAnZGF0ZS1mbnMnO1xyXG5pbXBvcnQgeyBlblVTIH0gZnJvbSAnZGF0ZS1mbnMvbG9jYWxlJztcclxuaW1wb3J0IHsgS2V5Ym9hcmRBcnJvd0xlZnRJY29uLCBLZXlib2FyZEFycm93UmlnaHRJY29uLCB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHsgQ2FsZW5kYXJDb250ZXh0IH0gZnJvbSAnLi9DYWxlbmRhckNvbnRleHQnO1xyXG5pbXBvcnQgeyBpMThuRm9ybWF0IGFzIGZvcm1hdCwgZ2V0Q3VycmVudE1vbnRoQW5kWWVhciB9IGZyb20gJy4vdXRpbHMnO1xyXG5pbXBvcnQgeyBJMThuQ29udGV4dCB9IGZyb20gJy4uLy4uL2kxOG4nO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBCdXR0b25Db2xvciwgQnV0dG9uVHlwZSwgQnV0dG9uVmFyaWFudCB9IGZyb20gJy4uL0J1dHRvbic7XHJcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICcuLi9JY29uQnV0dG9uJztcclxuaW1wb3J0IHsgTW9udGhQaWNrZXIgfSBmcm9tICcuL01vbnRoUGlja2VyJztcclxuaW1wb3J0IHsgWWVhclBpY2tlciB9IGZyb20gJy4vWWVhclBpY2tlcic7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBWaXN1YWxseUhpZGRlbiB9IGZyb20gJy4uL1Zpc3VhbGx5SGlkZGVuJztcclxuY29uc3QgQ2FsZW5kYXJIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMFxuICAgICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDV9O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5gO1xyXG5jb25zdCBDYWxlbmRhckhlYWRlclRleHQgPSBzdHlsZWQuZGl2IGBcbiAgY2FwdGlvbi1zaWRlOiBpbml0aWFsO1xuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw3MDB9O1xuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMubGluZUhlaWdodH07XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZvbnQtd2VpZ2h0OiA2MDA7XG5cbiAgJjpmb2N1cyB7XG4gICAgb3V0bGluZTogbm9uZTtcbiAgfVxuYDtcclxuY29uc3QgTW9udGhZZWFyV3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDF9O1xuYDtcclxuY29uc3QgTmF2aWdhdGlvbldyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbmA7XHJcbmV4cG9ydCBjb25zdCBDYWxlbmRhckhlYWRlciA9IHByb3BzID0+IHtcclxuICAgIGNvbnN0IHsgZm9jdXNlZERhdGUsIG9uUHJldk1vbnRoQ2xpY2ssIG9uTmV4dE1vbnRoQ2xpY2ssIG1pbkRhdGUsIG1heERhdGUsIHNldEZvY3VzZWREYXRlLCB9ID0gUmVhY3QudXNlQ29udGV4dChDYWxlbmRhckNvbnRleHQpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpMThuID0gUmVhY3QudXNlQ29udGV4dChJMThuQ29udGV4dCk7XHJcbiAgICBjb25zdCBsb2NhbGUgPSBpMThuLmxvY2FsZSB8fCBlblVTO1xyXG4gICAgY29uc3QgbW9udGhBbmRZZWFyID0gZ2V0Q3VycmVudE1vbnRoQW5kWWVhcihmb2N1c2VkRGF0ZSwgbG9jYWxlKTtcclxuICAgIGNvbnN0IG1pbkRhdGVPckRlZmF1bHQgPSBtaW5EYXRlID8/IG5ldyBEYXRlKDE5MDAsIDAsIDEpO1xyXG4gICAgY29uc3QgbWF4RGF0ZU9yRGVmYXVsdCA9IG1heERhdGUgPz8gbmV3IERhdGUoMjA5OSwgMTEsIDMxKTtcclxuICAgIGNvbnN0IHByZXZpb3VzTW9udGhSZWYgPSBSZWFjdC51c2VSZWYoKTtcclxuICAgIGNvbnN0IG5leHRNb250aFJlZiA9IFJlYWN0LnVzZVJlZigpO1xyXG4gICAgY29uc3QgaXNEYXRlRWFybGllclRoYW5NaW5EYXRlID0gKG51bWJlck1vbnRocykgPT4ge1xyXG4gICAgICAgIHJldHVybiAoc3RhcnRPZk1vbnRoKHN1Yk1vbnRocyhmb2N1c2VkRGF0ZSwgbnVtYmVyTW9udGhzKSkgPFxyXG4gICAgICAgICAgICBzdGFydE9mTW9udGgobWluRGF0ZU9yRGVmYXVsdCkpO1xyXG4gICAgfTtcclxuICAgIGNvbnN0IGlzRGF0ZUxhdGVyVGhhbk1heERhdGUgPSAobnVtYmVyTW9udGhzKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIChzdGFydE9mTW9udGgoYWRkTW9udGhzKGZvY3VzZWREYXRlLCBudW1iZXJNb250aHMpKSA+XHJcbiAgICAgICAgICAgIHN0YXJ0T2ZNb250aChtYXhEYXRlT3JEZWZhdWx0KSk7XHJcbiAgICB9O1xyXG4gICAgY29uc3QgaXNEaXNhYmxlZFByZXZNb250aCA9IGlzRGF0ZUVhcmxpZXJUaGFuTWluRGF0ZSgxKTtcclxuICAgIGNvbnN0IGlzRGlzYWJsZWROZXh0TW9udGggPSBpc0RhdGVMYXRlclRoYW5NYXhEYXRlKDEpO1xyXG4gICAgY29uc3Qgb25DbGlja1ByZXZNb250aCA9ICgpID0+IHtcclxuICAgICAgICBpZiAoaXNEYXRlRWFybGllclRoYW5NaW5EYXRlKDIpKSB7XHJcbiAgICAgICAgICAgIG5leHRNb250aFJlZi5jdXJyZW50Py5mb2N1cygpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAoc3RhcnRPZk1vbnRoKG1heERhdGVPckRlZmF1bHQpID49IHN0YXJ0T2ZNb250aChmb2N1c2VkRGF0ZSkpIHtcclxuICAgICAgICAgICAgb25QcmV2TW9udGhDbGljaygpO1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmICghaXNEaXNhYmxlZFByZXZNb250aCAmJiBpc0Rpc2FibGVkTmV4dE1vbnRoKSB7XHJcbiAgICAgICAgICAgIHNldEZvY3VzZWREYXRlKG1heERhdGVPckRlZmF1bHQpO1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIG9uUHJldk1vbnRoQ2xpY2soKTtcclxuICAgIH07XHJcbiAgICBjb25zdCBvbkNsaWNrTmV4dE1vbnRoID0gKCkgPT4ge1xyXG4gICAgICAgIGlmIChpc0RhdGVMYXRlclRoYW5NYXhEYXRlKDIpKSB7XHJcbiAgICAgICAgICAgIHByZXZpb3VzTW9udGhSZWYuY3VycmVudD8uZm9jdXMoKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgaWYgKHN0YXJ0T2ZNb250aChtaW5EYXRlT3JEZWZhdWx0KSA8PSBzdGFydE9mTW9udGgoZm9jdXNlZERhdGUpKSB7XHJcbiAgICAgICAgICAgIG9uTmV4dE1vbnRoQ2xpY2soKTtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAoaXNEaXNhYmxlZFByZXZNb250aCAmJiAhaXNEaXNhYmxlZE5leHRNb250aCkge1xyXG4gICAgICAgICAgICBzZXRGb2N1c2VkRGF0ZShtaW5EYXRlT3JEZWZhdWx0KTtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICBvbk5leHRNb250aENsaWNrKCk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KENhbGVuZGFySGVhZGVyQ29udGFpbmVyLCB7IHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2FsZW5kYXJIZWFkZXJUZXh0LCB7IHRhYkluZGV4OiAtMSwgdGhlbWU6IHRoZW1lLCBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KE1vbnRoWWVhcldyYXBwZXIsIHsgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KE1vbnRoUGlja2VyLCB7IGN1cnJlbnRNb250aDogbW9udGhBbmRZZWFyLm1vbnRoLCBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSB9KSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoWWVhclBpY2tlciwgeyBjdXJyZW50WWVhcjogTnVtYmVyKG1vbnRoQW5kWWVhci55ZWFyKSwgaXNJbnZlcnNlOiBwcm9wcy5pc0ludmVyc2UgfSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFZpc3VhbGx5SGlkZGVuLCBudWxsLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChBbm5vdW5jZSwgeyBcImFyaWEtYXRvbWljXCI6IFwidHJ1ZVwiIH0sXHJcbiAgICAgICAgICAgICAgICAgICAgbW9udGhBbmRZZWFyLm1vbnRoLFxyXG4gICAgICAgICAgICAgICAgICAgIFwiIFwiLFxyXG4gICAgICAgICAgICAgICAgICAgIG1vbnRoQW5kWWVhci55ZWFyKSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTmF2aWdhdGlvbldyYXBwZXIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSWNvbkJ1dHRvbiwgeyBcImFyaWEtbGFiZWxcIjogYCR7aTE4bi5kYXRlUGlja2VyLnByZXZpb3VzTW9udGhBcmlhTGFiZWx9ICR7Zm9ybWF0KHN1Yk1vbnRocyhuZXcgRGF0ZShmb2N1c2VkRGF0ZSksIDEpLCAnTU1NTSB5eXl5JywgbG9jYWxlKX1gLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBkaXNhYmxlZDogaXNEaXNhYmxlZFByZXZNb250aCwgaWNvbjogUmVhY3QuY3JlYXRlRWxlbWVudChLZXlib2FyZEFycm93TGVmdEljb24sIG51bGwpLCB0eXBlOiBCdXR0b25UeXBlLmJ1dHRvbiwgdmFyaWFudDogQnV0dG9uVmFyaWFudC5saW5rLCBvbkNsaWNrOiBvbkNsaWNrUHJldk1vbnRoLCByZWY6IHByZXZpb3VzTW9udGhSZWYsIHN0eWxlOiB7IG1hcmdpblJpZ2h0OiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMiB9IH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb25CdXR0b24sIHsgXCJhcmlhLWxhYmVsXCI6IGAke2kxOG4uZGF0ZVBpY2tlci5uZXh0TW9udGhBcmlhTGFiZWx9ICR7Zm9ybWF0KGFkZE1vbnRocyhuZXcgRGF0ZShmb2N1c2VkRGF0ZSksIDEpLCAnTU1NTSB5eXl5JywgbG9jYWxlKX1gLCBpY29uOiBSZWFjdC5jcmVhdGVFbGVtZW50KEtleWJvYXJkQXJyb3dSaWdodEljb24sIG51bGwpLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBkaXNhYmxlZDogaXNEaXNhYmxlZE5leHRNb250aCwgdHlwZTogQnV0dG9uVHlwZS5idXR0b24sIHZhcmlhbnQ6IEJ1dHRvblZhcmlhbnQubGluaywgb25DbGljazogb25DbGlja05leHRNb250aCwgcmVmOiBuZXh0TW9udGhSZWYsIHN0eWxlOiB7IG1hcmdpbkxlZnQ6IHRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAyIH0gfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNhbGVuZGFySGVhZGVyLmpzLm1hcCJdfQ== */"));
|
|
10844
10881
|
var MonthYearWrapper = /*#__PURE__*/_styled("div", {
|
|
10845
10882
|
target: "eg9fn2d1",
|
|
10846
10883
|
label: "MonthYearWrapper"
|
|
10847
10884
|
})("display:flex;gap:", function (props) {
|
|
10848
10885
|
return props.theme.spaceScale.spacing01;
|
|
10849
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
10886
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFySGVhZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzQ29DIiwiZmlsZSI6IkNhbGVuZGFySGVhZGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBhZGRNb250aHMsIHN1Yk1vbnRocywgc3RhcnRPZk1vbnRoIH0gZnJvbSAnZGF0ZS1mbnMnO1xyXG5pbXBvcnQgeyBlblVTIH0gZnJvbSAnZGF0ZS1mbnMvbG9jYWxlJztcclxuaW1wb3J0IHsgS2V5Ym9hcmRBcnJvd0xlZnRJY29uLCBLZXlib2FyZEFycm93UmlnaHRJY29uLCB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHsgQ2FsZW5kYXJDb250ZXh0IH0gZnJvbSAnLi9DYWxlbmRhckNvbnRleHQnO1xyXG5pbXBvcnQgeyBpMThuRm9ybWF0IGFzIGZvcm1hdCwgZ2V0Q3VycmVudE1vbnRoQW5kWWVhciB9IGZyb20gJy4vdXRpbHMnO1xyXG5pbXBvcnQgeyBJMThuQ29udGV4dCB9IGZyb20gJy4uLy4uL2kxOG4nO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBCdXR0b25Db2xvciwgQnV0dG9uVHlwZSwgQnV0dG9uVmFyaWFudCB9IGZyb20gJy4uL0J1dHRvbic7XHJcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICcuLi9JY29uQnV0dG9uJztcclxuaW1wb3J0IHsgTW9udGhQaWNrZXIgfSBmcm9tICcuL01vbnRoUGlja2VyJztcclxuaW1wb3J0IHsgWWVhclBpY2tlciB9IGZyb20gJy4vWWVhclBpY2tlcic7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBWaXN1YWxseUhpZGRlbiB9IGZyb20gJy4uL1Zpc3VhbGx5SGlkZGVuJztcclxuY29uc3QgQ2FsZW5kYXJIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMFxuICAgICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDV9O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5gO1xyXG5jb25zdCBDYWxlbmRhckhlYWRlclRleHQgPSBzdHlsZWQuZGl2IGBcbiAgY2FwdGlvbi1zaWRlOiBpbml0aWFsO1xuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw3MDB9O1xuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMubGluZUhlaWdodH07XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZvbnQtd2VpZ2h0OiA2MDA7XG5cbiAgJjpmb2N1cyB7XG4gICAgb3V0bGluZTogbm9uZTtcbiAgfVxuYDtcclxuY29uc3QgTW9udGhZZWFyV3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDF9O1xuYDtcclxuY29uc3QgTmF2aWdhdGlvbldyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbmA7XHJcbmV4cG9ydCBjb25zdCBDYWxlbmRhckhlYWRlciA9IHByb3BzID0+IHtcclxuICAgIGNvbnN0IHsgZm9jdXNlZERhdGUsIG9uUHJldk1vbnRoQ2xpY2ssIG9uTmV4dE1vbnRoQ2xpY2ssIG1pbkRhdGUsIG1heERhdGUsIHNldEZvY3VzZWREYXRlLCB9ID0gUmVhY3QudXNlQ29udGV4dChDYWxlbmRhckNvbnRleHQpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpMThuID0gUmVhY3QudXNlQ29udGV4dChJMThuQ29udGV4dCk7XHJcbiAgICBjb25zdCBsb2NhbGUgPSBpMThuLmxvY2FsZSB8fCBlblVTO1xyXG4gICAgY29uc3QgbW9udGhBbmRZZWFyID0gZ2V0Q3VycmVudE1vbnRoQW5kWWVhcihmb2N1c2VkRGF0ZSwgbG9jYWxlKTtcclxuICAgIGNvbnN0IG1pbkRhdGVPckRlZmF1bHQgPSBtaW5EYXRlID8/IG5ldyBEYXRlKDE5MDAsIDAsIDEpO1xyXG4gICAgY29uc3QgbWF4RGF0ZU9yRGVmYXVsdCA9IG1heERhdGUgPz8gbmV3IERhdGUoMjA5OSwgMTEsIDMxKTtcclxuICAgIGNvbnN0IHByZXZpb3VzTW9udGhSZWYgPSBSZWFjdC51c2VSZWYoKTtcclxuICAgIGNvbnN0IG5leHRNb250aFJlZiA9IFJlYWN0LnVzZVJlZigpO1xyXG4gICAgY29uc3QgaXNEYXRlRWFybGllclRoYW5NaW5EYXRlID0gKG51bWJlck1vbnRocykgPT4ge1xyXG4gICAgICAgIHJldHVybiAoc3RhcnRPZk1vbnRoKHN1Yk1vbnRocyhmb2N1c2VkRGF0ZSwgbnVtYmVyTW9udGhzKSkgPFxyXG4gICAgICAgICAgICBzdGFydE9mTW9udGgobWluRGF0ZU9yRGVmYXVsdCkpO1xyXG4gICAgfTtcclxuICAgIGNvbnN0IGlzRGF0ZUxhdGVyVGhhbk1heERhdGUgPSAobnVtYmVyTW9udGhzKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIChzdGFydE9mTW9udGgoYWRkTW9udGhzKGZvY3VzZWREYXRlLCBudW1iZXJNb250aHMpKSA+XHJcbiAgICAgICAgICAgIHN0YXJ0T2ZNb250aChtYXhEYXRlT3JEZWZhdWx0KSk7XHJcbiAgICB9O1xyXG4gICAgY29uc3QgaXNEaXNhYmxlZFByZXZNb250aCA9IGlzRGF0ZUVhcmxpZXJUaGFuTWluRGF0ZSgxKTtcclxuICAgIGNvbnN0IGlzRGlzYWJsZWROZXh0TW9udGggPSBpc0RhdGVMYXRlclRoYW5NYXhEYXRlKDEpO1xyXG4gICAgY29uc3Qgb25DbGlja1ByZXZNb250aCA9ICgpID0+IHtcclxuICAgICAgICBpZiAoaXNEYXRlRWFybGllclRoYW5NaW5EYXRlKDIpKSB7XHJcbiAgICAgICAgICAgIG5leHRNb250aFJlZi5jdXJyZW50Py5mb2N1cygpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAoc3RhcnRPZk1vbnRoKG1heERhdGVPckRlZmF1bHQpID49IHN0YXJ0T2ZNb250aChmb2N1c2VkRGF0ZSkpIHtcclxuICAgICAgICAgICAgb25QcmV2TW9udGhDbGljaygpO1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmICghaXNEaXNhYmxlZFByZXZNb250aCAmJiBpc0Rpc2FibGVkTmV4dE1vbnRoKSB7XHJcbiAgICAgICAgICAgIHNldEZvY3VzZWREYXRlKG1heERhdGVPckRlZmF1bHQpO1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIG9uUHJldk1vbnRoQ2xpY2soKTtcclxuICAgIH07XHJcbiAgICBjb25zdCBvbkNsaWNrTmV4dE1vbnRoID0gKCkgPT4ge1xyXG4gICAgICAgIGlmIChpc0RhdGVMYXRlclRoYW5NYXhEYXRlKDIpKSB7XHJcbiAgICAgICAgICAgIHByZXZpb3VzTW9udGhSZWYuY3VycmVudD8uZm9jdXMoKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgaWYgKHN0YXJ0T2ZNb250aChtaW5EYXRlT3JEZWZhdWx0KSA8PSBzdGFydE9mTW9udGgoZm9jdXNlZERhdGUpKSB7XHJcbiAgICAgICAgICAgIG9uTmV4dE1vbnRoQ2xpY2soKTtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAoaXNEaXNhYmxlZFByZXZNb250aCAmJiAhaXNEaXNhYmxlZE5leHRNb250aCkge1xyXG4gICAgICAgICAgICBzZXRGb2N1c2VkRGF0ZShtaW5EYXRlT3JEZWZhdWx0KTtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICBvbk5leHRNb250aENsaWNrKCk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KENhbGVuZGFySGVhZGVyQ29udGFpbmVyLCB7IHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2FsZW5kYXJIZWFkZXJUZXh0LCB7IHRhYkluZGV4OiAtMSwgdGhlbWU6IHRoZW1lLCBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KE1vbnRoWWVhcldyYXBwZXIsIHsgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KE1vbnRoUGlja2VyLCB7IGN1cnJlbnRNb250aDogbW9udGhBbmRZZWFyLm1vbnRoLCBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSB9KSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoWWVhclBpY2tlciwgeyBjdXJyZW50WWVhcjogTnVtYmVyKG1vbnRoQW5kWWVhci55ZWFyKSwgaXNJbnZlcnNlOiBwcm9wcy5pc0ludmVyc2UgfSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFZpc3VhbGx5SGlkZGVuLCBudWxsLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChBbm5vdW5jZSwgeyBcImFyaWEtYXRvbWljXCI6IFwidHJ1ZVwiIH0sXHJcbiAgICAgICAgICAgICAgICAgICAgbW9udGhBbmRZZWFyLm1vbnRoLFxyXG4gICAgICAgICAgICAgICAgICAgIFwiIFwiLFxyXG4gICAgICAgICAgICAgICAgICAgIG1vbnRoQW5kWWVhci55ZWFyKSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTmF2aWdhdGlvbldyYXBwZXIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSWNvbkJ1dHRvbiwgeyBcImFyaWEtbGFiZWxcIjogYCR7aTE4bi5kYXRlUGlja2VyLnByZXZpb3VzTW9udGhBcmlhTGFiZWx9ICR7Zm9ybWF0KHN1Yk1vbnRocyhuZXcgRGF0ZShmb2N1c2VkRGF0ZSksIDEpLCAnTU1NTSB5eXl5JywgbG9jYWxlKX1gLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBkaXNhYmxlZDogaXNEaXNhYmxlZFByZXZNb250aCwgaWNvbjogUmVhY3QuY3JlYXRlRWxlbWVudChLZXlib2FyZEFycm93TGVmdEljb24sIG51bGwpLCB0eXBlOiBCdXR0b25UeXBlLmJ1dHRvbiwgdmFyaWFudDogQnV0dG9uVmFyaWFudC5saW5rLCBvbkNsaWNrOiBvbkNsaWNrUHJldk1vbnRoLCByZWY6IHByZXZpb3VzTW9udGhSZWYsIHN0eWxlOiB7IG1hcmdpblJpZ2h0OiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMiB9IH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb25CdXR0b24sIHsgXCJhcmlhLWxhYmVsXCI6IGAke2kxOG4uZGF0ZVBpY2tlci5uZXh0TW9udGhBcmlhTGFiZWx9ICR7Zm9ybWF0KGFkZE1vbnRocyhuZXcgRGF0ZShmb2N1c2VkRGF0ZSksIDEpLCAnTU1NTSB5eXl5JywgbG9jYWxlKX1gLCBpY29uOiBSZWFjdC5jcmVhdGVFbGVtZW50KEtleWJvYXJkQXJyb3dSaWdodEljb24sIG51bGwpLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBkaXNhYmxlZDogaXNEaXNhYmxlZE5leHRNb250aCwgdHlwZTogQnV0dG9uVHlwZS5idXR0b24sIHZhcmlhbnQ6IEJ1dHRvblZhcmlhbnQubGluaywgb25DbGljazogb25DbGlja05leHRNb250aCwgcmVmOiBuZXh0TW9udGhSZWYsIHN0eWxlOiB7IG1hcmdpbkxlZnQ6IHRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAyIH0gfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNhbGVuZGFySGVhZGVyLmpzLm1hcCJdfQ== */"));
|
|
10850
10887
|
var NavigationWrapper = /*#__PURE__*/_styled("div", {
|
|
10851
10888
|
target: "eg9fn2d0",
|
|
10852
10889
|
label: "NavigationWrapper"
|
|
@@ -10855,18 +10892,63 @@ var NavigationWrapper = /*#__PURE__*/_styled("div", {
|
|
|
10855
10892
|
styles: "display:flex;flex-direction:row"
|
|
10856
10893
|
} : {
|
|
10857
10894
|
name: "ho1qnd",
|
|
10858
|
-
styles: "display:flex;flex-direction:row/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
10895
|
+
styles: "display:flex;flex-direction:row/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFySGVhZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwQ3FDIiwiZmlsZSI6IkNhbGVuZGFySGVhZGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBhZGRNb250aHMsIHN1Yk1vbnRocywgc3RhcnRPZk1vbnRoIH0gZnJvbSAnZGF0ZS1mbnMnO1xyXG5pbXBvcnQgeyBlblVTIH0gZnJvbSAnZGF0ZS1mbnMvbG9jYWxlJztcclxuaW1wb3J0IHsgS2V5Ym9hcmRBcnJvd0xlZnRJY29uLCBLZXlib2FyZEFycm93UmlnaHRJY29uLCB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHsgQ2FsZW5kYXJDb250ZXh0IH0gZnJvbSAnLi9DYWxlbmRhckNvbnRleHQnO1xyXG5pbXBvcnQgeyBpMThuRm9ybWF0IGFzIGZvcm1hdCwgZ2V0Q3VycmVudE1vbnRoQW5kWWVhciB9IGZyb20gJy4vdXRpbHMnO1xyXG5pbXBvcnQgeyBJMThuQ29udGV4dCB9IGZyb20gJy4uLy4uL2kxOG4nO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBCdXR0b25Db2xvciwgQnV0dG9uVHlwZSwgQnV0dG9uVmFyaWFudCB9IGZyb20gJy4uL0J1dHRvbic7XHJcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICcuLi9JY29uQnV0dG9uJztcclxuaW1wb3J0IHsgTW9udGhQaWNrZXIgfSBmcm9tICcuL01vbnRoUGlja2VyJztcclxuaW1wb3J0IHsgWWVhclBpY2tlciB9IGZyb20gJy4vWWVhclBpY2tlcic7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBWaXN1YWxseUhpZGRlbiB9IGZyb20gJy4uL1Zpc3VhbGx5SGlkZGVuJztcclxuY29uc3QgQ2FsZW5kYXJIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMFxuICAgICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDV9O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5gO1xyXG5jb25zdCBDYWxlbmRhckhlYWRlclRleHQgPSBzdHlsZWQuZGl2IGBcbiAgY2FwdGlvbi1zaWRlOiBpbml0aWFsO1xuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw3MDB9O1xuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMubGluZUhlaWdodH07XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGZvbnQtd2VpZ2h0OiA2MDA7XG5cbiAgJjpmb2N1cyB7XG4gICAgb3V0bGluZTogbm9uZTtcbiAgfVxuYDtcclxuY29uc3QgTW9udGhZZWFyV3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDF9O1xuYDtcclxuY29uc3QgTmF2aWdhdGlvbldyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbmA7XHJcbmV4cG9ydCBjb25zdCBDYWxlbmRhckhlYWRlciA9IHByb3BzID0+IHtcclxuICAgIGNvbnN0IHsgZm9jdXNlZERhdGUsIG9uUHJldk1vbnRoQ2xpY2ssIG9uTmV4dE1vbnRoQ2xpY2ssIG1pbkRhdGUsIG1heERhdGUsIHNldEZvY3VzZWREYXRlLCB9ID0gUmVhY3QudXNlQ29udGV4dChDYWxlbmRhckNvbnRleHQpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpMThuID0gUmVhY3QudXNlQ29udGV4dChJMThuQ29udGV4dCk7XHJcbiAgICBjb25zdCBsb2NhbGUgPSBpMThuLmxvY2FsZSB8fCBlblVTO1xyXG4gICAgY29uc3QgbW9udGhBbmRZZWFyID0gZ2V0Q3VycmVudE1vbnRoQW5kWWVhcihmb2N1c2VkRGF0ZSwgbG9jYWxlKTtcclxuICAgIGNvbnN0IG1pbkRhdGVPckRlZmF1bHQgPSBtaW5EYXRlID8/IG5ldyBEYXRlKDE5MDAsIDAsIDEpO1xyXG4gICAgY29uc3QgbWF4RGF0ZU9yRGVmYXVsdCA9IG1heERhdGUgPz8gbmV3IERhdGUoMjA5OSwgMTEsIDMxKTtcclxuICAgIGNvbnN0IHByZXZpb3VzTW9udGhSZWYgPSBSZWFjdC51c2VSZWYoKTtcclxuICAgIGNvbnN0IG5leHRNb250aFJlZiA9IFJlYWN0LnVzZVJlZigpO1xyXG4gICAgY29uc3QgaXNEYXRlRWFybGllclRoYW5NaW5EYXRlID0gKG51bWJlck1vbnRocykgPT4ge1xyXG4gICAgICAgIHJldHVybiAoc3RhcnRPZk1vbnRoKHN1Yk1vbnRocyhmb2N1c2VkRGF0ZSwgbnVtYmVyTW9udGhzKSkgPFxyXG4gICAgICAgICAgICBzdGFydE9mTW9udGgobWluRGF0ZU9yRGVmYXVsdCkpO1xyXG4gICAgfTtcclxuICAgIGNvbnN0IGlzRGF0ZUxhdGVyVGhhbk1heERhdGUgPSAobnVtYmVyTW9udGhzKSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIChzdGFydE9mTW9udGgoYWRkTW9udGhzKGZvY3VzZWREYXRlLCBudW1iZXJNb250aHMpKSA+XHJcbiAgICAgICAgICAgIHN0YXJ0T2ZNb250aChtYXhEYXRlT3JEZWZhdWx0KSk7XHJcbiAgICB9O1xyXG4gICAgY29uc3QgaXNEaXNhYmxlZFByZXZNb250aCA9IGlzRGF0ZUVhcmxpZXJUaGFuTWluRGF0ZSgxKTtcclxuICAgIGNvbnN0IGlzRGlzYWJsZWROZXh0TW9udGggPSBpc0RhdGVMYXRlclRoYW5NYXhEYXRlKDEpO1xyXG4gICAgY29uc3Qgb25DbGlja1ByZXZNb250aCA9ICgpID0+IHtcclxuICAgICAgICBpZiAoaXNEYXRlRWFybGllclRoYW5NaW5EYXRlKDIpKSB7XHJcbiAgICAgICAgICAgIG5leHRNb250aFJlZi5jdXJyZW50Py5mb2N1cygpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAoc3RhcnRPZk1vbnRoKG1heERhdGVPckRlZmF1bHQpID49IHN0YXJ0T2ZNb250aChmb2N1c2VkRGF0ZSkpIHtcclxuICAgICAgICAgICAgb25QcmV2TW9udGhDbGljaygpO1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmICghaXNEaXNhYmxlZFByZXZNb250aCAmJiBpc0Rpc2FibGVkTmV4dE1vbnRoKSB7XHJcbiAgICAgICAgICAgIHNldEZvY3VzZWREYXRlKG1heERhdGVPckRlZmF1bHQpO1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIG9uUHJldk1vbnRoQ2xpY2soKTtcclxuICAgIH07XHJcbiAgICBjb25zdCBvbkNsaWNrTmV4dE1vbnRoID0gKCkgPT4ge1xyXG4gICAgICAgIGlmIChpc0RhdGVMYXRlclRoYW5NYXhEYXRlKDIpKSB7XHJcbiAgICAgICAgICAgIHByZXZpb3VzTW9udGhSZWYuY3VycmVudD8uZm9jdXMoKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgaWYgKHN0YXJ0T2ZNb250aChtaW5EYXRlT3JEZWZhdWx0KSA8PSBzdGFydE9mTW9udGgoZm9jdXNlZERhdGUpKSB7XHJcbiAgICAgICAgICAgIG9uTmV4dE1vbnRoQ2xpY2soKTtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAoaXNEaXNhYmxlZFByZXZNb250aCAmJiAhaXNEaXNhYmxlZE5leHRNb250aCkge1xyXG4gICAgICAgICAgICBzZXRGb2N1c2VkRGF0ZShtaW5EYXRlT3JEZWZhdWx0KTtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICBvbk5leHRNb250aENsaWNrKCk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KENhbGVuZGFySGVhZGVyQ29udGFpbmVyLCB7IHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2FsZW5kYXJIZWFkZXJUZXh0LCB7IHRhYkluZGV4OiAtMSwgdGhlbWU6IHRoZW1lLCBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KE1vbnRoWWVhcldyYXBwZXIsIHsgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KE1vbnRoUGlja2VyLCB7IGN1cnJlbnRNb250aDogbW9udGhBbmRZZWFyLm1vbnRoLCBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSB9KSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoWWVhclBpY2tlciwgeyBjdXJyZW50WWVhcjogTnVtYmVyKG1vbnRoQW5kWWVhci55ZWFyKSwgaXNJbnZlcnNlOiBwcm9wcy5pc0ludmVyc2UgfSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFZpc3VhbGx5SGlkZGVuLCBudWxsLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChBbm5vdW5jZSwgeyBcImFyaWEtYXRvbWljXCI6IFwidHJ1ZVwiIH0sXHJcbiAgICAgICAgICAgICAgICAgICAgbW9udGhBbmRZZWFyLm1vbnRoLFxyXG4gICAgICAgICAgICAgICAgICAgIFwiIFwiLFxyXG4gICAgICAgICAgICAgICAgICAgIG1vbnRoQW5kWWVhci55ZWFyKSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTmF2aWdhdGlvbldyYXBwZXIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSWNvbkJ1dHRvbiwgeyBcImFyaWEtbGFiZWxcIjogYCR7aTE4bi5kYXRlUGlja2VyLnByZXZpb3VzTW9udGhBcmlhTGFiZWx9ICR7Zm9ybWF0KHN1Yk1vbnRocyhuZXcgRGF0ZShmb2N1c2VkRGF0ZSksIDEpLCAnTU1NTSB5eXl5JywgbG9jYWxlKX1gLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBkaXNhYmxlZDogaXNEaXNhYmxlZFByZXZNb250aCwgaWNvbjogUmVhY3QuY3JlYXRlRWxlbWVudChLZXlib2FyZEFycm93TGVmdEljb24sIG51bGwpLCB0eXBlOiBCdXR0b25UeXBlLmJ1dHRvbiwgdmFyaWFudDogQnV0dG9uVmFyaWFudC5saW5rLCBvbkNsaWNrOiBvbkNsaWNrUHJldk1vbnRoLCByZWY6IHByZXZpb3VzTW9udGhSZWYsIHN0eWxlOiB7IG1hcmdpblJpZ2h0OiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMiB9IH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb25CdXR0b24sIHsgXCJhcmlhLWxhYmVsXCI6IGAke2kxOG4uZGF0ZVBpY2tlci5uZXh0TW9udGhBcmlhTGFiZWx9ICR7Zm9ybWF0KGFkZE1vbnRocyhuZXcgRGF0ZShmb2N1c2VkRGF0ZSksIDEpLCAnTU1NTSB5eXl5JywgbG9jYWxlKX1gLCBpY29uOiBSZWFjdC5jcmVhdGVFbGVtZW50KEtleWJvYXJkQXJyb3dSaWdodEljb24sIG51bGwpLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBkaXNhYmxlZDogaXNEaXNhYmxlZE5leHRNb250aCwgdHlwZTogQnV0dG9uVHlwZS5idXR0b24sIHZhcmlhbnQ6IEJ1dHRvblZhcmlhbnQubGluaywgb25DbGljazogb25DbGlja05leHRNb250aCwgcmVmOiBuZXh0TW9udGhSZWYsIHN0eWxlOiB7IG1hcmdpbkxlZnQ6IHRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAyIH0gfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNhbGVuZGFySGVhZGVyLmpzLm1hcCJdfQ== */",
|
|
10859
10896
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$h
|
|
10860
10897
|
});
|
|
10861
10898
|
var CalendarHeader = function CalendarHeader(props) {
|
|
10862
10899
|
var _React$useContext = useContext(CalendarContext),
|
|
10863
10900
|
focusedDate = _React$useContext.focusedDate,
|
|
10864
10901
|
onPrevMonthClick = _React$useContext.onPrevMonthClick,
|
|
10865
|
-
onNextMonthClick = _React$useContext.onNextMonthClick
|
|
10902
|
+
onNextMonthClick = _React$useContext.onNextMonthClick,
|
|
10903
|
+
minDate = _React$useContext.minDate,
|
|
10904
|
+
maxDate = _React$useContext.maxDate,
|
|
10905
|
+
setFocusedDate = _React$useContext.setFocusedDate;
|
|
10866
10906
|
var theme = useContext(ThemeContext);
|
|
10867
10907
|
var i18n = useContext(I18nContext);
|
|
10868
10908
|
var locale = i18n.locale || enUS;
|
|
10869
10909
|
var monthAndYear = getCurrentMonthAndYear(focusedDate, locale);
|
|
10910
|
+
var minDateOrDefault = minDate != null ? minDate : new Date(1900, 0, 1);
|
|
10911
|
+
var maxDateOrDefault = maxDate != null ? maxDate : new Date(2099, 11, 31);
|
|
10912
|
+
var previousMonthRef = useRef();
|
|
10913
|
+
var nextMonthRef = useRef();
|
|
10914
|
+
var isDateEarlierThanMinDate = function isDateEarlierThanMinDate(numberMonths) {
|
|
10915
|
+
return startOfMonth(subMonths(focusedDate, numberMonths)) < startOfMonth(minDateOrDefault);
|
|
10916
|
+
};
|
|
10917
|
+
var isDateLaterThanMaxDate = function isDateLaterThanMaxDate(numberMonths) {
|
|
10918
|
+
return startOfMonth(addMonths(focusedDate, numberMonths)) > startOfMonth(maxDateOrDefault);
|
|
10919
|
+
};
|
|
10920
|
+
var isDisabledPrevMonth = isDateEarlierThanMinDate(1);
|
|
10921
|
+
var isDisabledNextMonth = isDateLaterThanMaxDate(1);
|
|
10922
|
+
var onClickPrevMonth = function onClickPrevMonth() {
|
|
10923
|
+
if (isDateEarlierThanMinDate(2)) {
|
|
10924
|
+
var _nextMonthRef$current;
|
|
10925
|
+
(_nextMonthRef$current = nextMonthRef.current) == null || _nextMonthRef$current.focus();
|
|
10926
|
+
}
|
|
10927
|
+
if (startOfMonth(maxDateOrDefault) >= startOfMonth(focusedDate)) {
|
|
10928
|
+
onPrevMonthClick();
|
|
10929
|
+
return;
|
|
10930
|
+
}
|
|
10931
|
+
if (!isDisabledPrevMonth && isDisabledNextMonth) {
|
|
10932
|
+
setFocusedDate(maxDateOrDefault);
|
|
10933
|
+
return;
|
|
10934
|
+
}
|
|
10935
|
+
onPrevMonthClick();
|
|
10936
|
+
};
|
|
10937
|
+
var onClickNextMonth = function onClickNextMonth() {
|
|
10938
|
+
if (isDateLaterThanMaxDate(2)) {
|
|
10939
|
+
var _previousMonthRef$cur;
|
|
10940
|
+
(_previousMonthRef$cur = previousMonthRef.current) == null || _previousMonthRef$cur.focus();
|
|
10941
|
+
}
|
|
10942
|
+
if (startOfMonth(minDateOrDefault) <= startOfMonth(focusedDate)) {
|
|
10943
|
+
onNextMonthClick();
|
|
10944
|
+
return;
|
|
10945
|
+
}
|
|
10946
|
+
if (isDisabledPrevMonth && !isDisabledNextMonth) {
|
|
10947
|
+
setFocusedDate(minDateOrDefault);
|
|
10948
|
+
return;
|
|
10949
|
+
}
|
|
10950
|
+
onNextMonthClick();
|
|
10951
|
+
};
|
|
10870
10952
|
return createElement(CalendarHeaderContainer, {
|
|
10871
10953
|
theme: theme
|
|
10872
10954
|
}, createElement(CalendarHeaderText, {
|
|
@@ -10881,13 +10963,17 @@ var CalendarHeader = function CalendarHeader(props) {
|
|
|
10881
10963
|
}), createElement(YearPicker, {
|
|
10882
10964
|
currentYear: Number(monthAndYear.year),
|
|
10883
10965
|
isInverse: props.isInverse
|
|
10884
|
-
}))
|
|
10966
|
+
})), createElement(VisuallyHidden, null, createElement(Announce, {
|
|
10967
|
+
"aria-atomic": "true"
|
|
10968
|
+
}, monthAndYear.month, " ", monthAndYear.year))), createElement(NavigationWrapper, null, createElement(IconButton, {
|
|
10885
10969
|
"aria-label": i18n.datePicker.previousMonthAriaLabel + " " + i18nFormat(subMonths(new Date(focusedDate), 1), 'MMMM yyyy', locale),
|
|
10886
10970
|
color: ButtonColor.subtle,
|
|
10971
|
+
disabled: isDisabledPrevMonth,
|
|
10887
10972
|
icon: createElement(KeyboardArrowLeftIcon, null),
|
|
10888
10973
|
type: ButtonType.button,
|
|
10889
10974
|
variant: ButtonVariant.link,
|
|
10890
|
-
onClick:
|
|
10975
|
+
onClick: onClickPrevMonth,
|
|
10976
|
+
ref: previousMonthRef,
|
|
10891
10977
|
style: {
|
|
10892
10978
|
marginRight: theme.spaceScale.spacing02
|
|
10893
10979
|
}
|
|
@@ -10895,9 +10981,11 @@ var CalendarHeader = function CalendarHeader(props) {
|
|
|
10895
10981
|
"aria-label": i18n.datePicker.nextMonthAriaLabel + " " + i18nFormat(addMonths(new Date(focusedDate), 1), 'MMMM yyyy', locale),
|
|
10896
10982
|
icon: createElement(KeyboardArrowRightIcon, null),
|
|
10897
10983
|
color: ButtonColor.subtle,
|
|
10984
|
+
disabled: isDisabledNextMonth,
|
|
10898
10985
|
type: ButtonType.button,
|
|
10899
10986
|
variant: ButtonVariant.link,
|
|
10900
|
-
onClick:
|
|
10987
|
+
onClick: onClickNextMonth,
|
|
10988
|
+
ref: nextMonthRef,
|
|
10901
10989
|
style: {
|
|
10902
10990
|
marginLeft: theme.spaceScale.spacing02
|
|
10903
10991
|
}
|
|
@@ -11578,7 +11666,7 @@ var DatePickerContainer = /*#__PURE__*/_styled("div", {
|
|
|
11578
11666
|
styles: "position:relative"
|
|
11579
11667
|
} : {
|
|
11580
11668
|
name: "bjn8wh",
|
|
11581
|
-
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, setMonthForDate, setYearForDate, 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 previousIconRef = 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 (props.apiRef) {\r\n            props.apiRef.current = {\r\n                closeDatePickerManually(event) {\r\n                    handleCloseButtonClick(event);\r\n                },\r\n                openDatePickerManually(event) {\r\n                    toggleCalendarOpened();\r\n                    inputRef.current.focus();\r\n                },\r\n            };\r\n        }\r\n    }, []);\r\n    React.useEffect(() => {\r\n        if (dateTimePickerContent &&\r\n            chosenDate &&\r\n            inputRef.current !== document.activeElement) {\r\n            if (!props.additionalInputContent && props.setAdditionalInputContent) {\r\n                props.setAdditionalInputContent('12:00 AM');\r\n            }\r\n            setFocusedDate(chosenDate);\r\n        }\r\n    }, [chosenDate]);\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    React.useEffect(() => {\r\n        previousIconRef.current = iconRef.current;\r\n    }, []);\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 setMonthFocusedDate(monthNumber) {\r\n        const newDate = setMonthForDate(focusedDate, monthNumber);\r\n        setFocusedDate(newDate);\r\n    }\r\n    function setYearFocusedDate(yearNumber) {\r\n        const newDate = setYearForDate(focusedDate, yearNumber);\r\n        setFocusedDate(newDate);\r\n    }\r\n    function onDateChange(day) {\r\n        setChosenDate(day);\r\n        if (dateTimePickerContent)\r\n            return;\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        let isValidDay;\r\n        if (dateTimePickerContent) {\r\n            const splitValue = value.split(' ')[0];\r\n            isValidDay = isValidDateFromString(splitValue, day);\r\n            const validDay = new Date(splitValue);\r\n            const pattern = /^\\d{2}\\/\\d{2}\\/\\d{4}$/;\r\n            if (pattern.test(splitValue)) {\r\n                setChosenDate(validDay);\r\n            }\r\n            props.onChange &&\r\n                typeof props.onChange === 'function' &&\r\n                props.onChange(isValidDay ? validDay.toISOString() : splitValue, event);\r\n        }\r\n        else {\r\n            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    }\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(dateTimePickerContent ? value.split(' ')[0] : value, i18n.dateFormat, new Date());\r\n        let isValidDay;\r\n        if (dateTimePickerContent) {\r\n            const splitValue = value.split(' ')[0];\r\n            isValidDay = isValidDateFromString(splitValue, day);\r\n            const validDay = new Date(splitValue);\r\n            if (isValidDay) {\r\n                handleDateChange(validDay, event);\r\n            }\r\n        }\r\n        else {\r\n            isValidDay = isValidDateFromString(value, day);\r\n            if (isValidDay) {\r\n                handleDateChange(day, event);\r\n            }\r\n            else {\r\n                reset && typeof reset === 'function' && reset();\r\n            }\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        if (dateTimePickerContent)\r\n            return;\r\n        setFocusedDate(day);\r\n    }\r\n    function handleDaySelection(day, event) {\r\n        handleDateChange(day, event);\r\n        if (dateTimePickerContent)\r\n            return;\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        if (!iconRef.current && previousIconRef.current) {\r\n            iconRef.current = previousIconRef.current;\r\n        }\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, dateTimePickerContent, ...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    let inputValue = chosenDate ? format(chosenDate, dateFormat) : '';\r\n    if (inputValue && props.additionalInputContent) {\r\n        inputValue = `${inputValue} ${props.additionalInputContent}`;\r\n    }\r\n    else if (props.additionalInputContent) {\r\n        setChosenDate(new Date());\r\n    }\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            setMonthFocusedDate,\r\n            setYearFocusedDate,\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, dateTimePickerContent: dateTimePickerContent })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
11669
|
+
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, 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, setMonthForDate, setYearForDate, 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 previousIconRef = 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 (props.apiRef) {\r\n            props.apiRef.current = {\r\n                closeDatePickerManually(event) {\r\n                    handleCloseButtonClick(event);\r\n                },\r\n                openDatePickerManually(event) {\r\n                    toggleCalendarOpened();\r\n                    inputRef.current.focus();\r\n                },\r\n            };\r\n        }\r\n    }, []);\r\n    React.useEffect(() => {\r\n        if (dateTimePickerContent &&\r\n            chosenDate &&\r\n            inputRef.current !== document.activeElement) {\r\n            if (!props.additionalInputContent && props.setAdditionalInputContent) {\r\n                props.setAdditionalInputContent('12:00 AM');\r\n            }\r\n            setFocusedDate(chosenDate);\r\n        }\r\n    }, [chosenDate]);\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    React.useEffect(() => {\r\n        previousIconRef.current = iconRef.current;\r\n    }, []);\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(newDate);\r\n    }\r\n    function onNextMonthClick() {\r\n        const newDate = getNextMonthFromDate(focusedDate);\r\n        setFocusedDate(newDate);\r\n    }\r\n    function setMonthFocusedDate(monthNumber) {\r\n        const newDate = setMonthForDate(focusedDate, monthNumber);\r\n        setFocusedDate(newDate);\r\n    }\r\n    function setYearFocusedDate(yearNumber) {\r\n        const newDate = setYearForDate(focusedDate, yearNumber);\r\n        setFocusedDate(newDate);\r\n    }\r\n    function onDateChange(day) {\r\n        setChosenDate(day);\r\n        if (dateTimePickerContent)\r\n            return;\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        let isValidDay;\r\n        if (dateTimePickerContent) {\r\n            const splitValue = value.split(' ')[0];\r\n            isValidDay = isValidDateFromString(splitValue, day);\r\n            const validDay = new Date(splitValue);\r\n            const pattern = /^\\d{2}\\/\\d{2}\\/\\d{4}$/;\r\n            if (pattern.test(splitValue)) {\r\n                setChosenDate(validDay);\r\n            }\r\n            props.onChange &&\r\n                typeof props.onChange === 'function' &&\r\n                props.onChange(isValidDay ? validDay.toISOString() : splitValue, event);\r\n        }\r\n        else {\r\n            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    }\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(dateTimePickerContent ? value.split(' ')[0] : value, i18n.dateFormat, new Date());\r\n        let isValidDay;\r\n        if (dateTimePickerContent) {\r\n            const splitValue = value.split(' ')[0];\r\n            isValidDay = isValidDateFromString(splitValue, day);\r\n            const validDay = new Date(splitValue);\r\n            if (isValidDay) {\r\n                handleDateChange(validDay, event);\r\n            }\r\n        }\r\n        else {\r\n            isValidDay = isValidDateFromString(value, day);\r\n            if (isValidDay) {\r\n                handleDateChange(day, event);\r\n            }\r\n            else {\r\n                reset && typeof reset === 'function' && reset();\r\n            }\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        if (dateTimePickerContent)\r\n            return;\r\n        setFocusedDate(day);\r\n    }\r\n    function handleDaySelection(day, event) {\r\n        handleDateChange(day, event);\r\n        if (dateTimePickerContent)\r\n            return;\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        if (!iconRef.current && previousIconRef.current) {\r\n            iconRef.current = previousIconRef.current;\r\n        }\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, dateTimePickerContent, ...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    let inputValue = chosenDate ? format(chosenDate, dateFormat) : '';\r\n    if (inputValue && props.additionalInputContent) {\r\n        inputValue = `${inputValue} ${props.additionalInputContent}`;\r\n    }\r\n    else if (props.additionalInputContent) {\r\n        setChosenDate(new Date());\r\n    }\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            setMonthFocusedDate,\r\n            setYearFocusedDate,\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, dateTimePickerContent: dateTimePickerContent })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
11582
11670
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
|
|
11583
11671
|
});
|
|
11584
11672
|
var DatePickerCalendar = /*#__PURE__*/_styled("div", {
|
|
@@ -11596,7 +11684,7 @@ var DatePickerCalendar = /*#__PURE__*/_styled("div", {
|
|
|
11596
11684
|
return props.theme.spaceScale.spacing01;
|
|
11597
11685
|
}, " 0px;opacity:", function (props) {
|
|
11598
11686
|
return props.opened ? '1' : '0';
|
|
11599
|
-
}, ";overflow:hidden;transition:opacity 0.2s ease-in-out 0s;width:320px;" + (process.env.NODE_ENV === "production" ? "" : "/*# 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, setMonthForDate, setYearForDate, 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 previousIconRef = 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 (props.apiRef) {\r\n            props.apiRef.current = {\r\n                closeDatePickerManually(event) {\r\n                    handleCloseButtonClick(event);\r\n                },\r\n                openDatePickerManually(event) {\r\n                    toggleCalendarOpened();\r\n                    inputRef.current.focus();\r\n                },\r\n            };\r\n        }\r\n    }, []);\r\n    React.useEffect(() => {\r\n        if (dateTimePickerContent &&\r\n            chosenDate &&\r\n            inputRef.current !== document.activeElement) {\r\n            if (!props.additionalInputContent && props.setAdditionalInputContent) {\r\n                props.setAdditionalInputContent('12:00 AM');\r\n            }\r\n            setFocusedDate(chosenDate);\r\n        }\r\n    }, [chosenDate]);\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    React.useEffect(() => {\r\n        previousIconRef.current = iconRef.current;\r\n    }, []);\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 setMonthFocusedDate(monthNumber) {\r\n        const newDate = setMonthForDate(focusedDate, monthNumber);\r\n        setFocusedDate(newDate);\r\n    }\r\n    function setYearFocusedDate(yearNumber) {\r\n        const newDate = setYearForDate(focusedDate, yearNumber);\r\n        setFocusedDate(newDate);\r\n    }\r\n    function onDateChange(day) {\r\n        setChosenDate(day);\r\n        if (dateTimePickerContent)\r\n            return;\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        let isValidDay;\r\n        if (dateTimePickerContent) {\r\n            const splitValue = value.split(' ')[0];\r\n            isValidDay = isValidDateFromString(splitValue, day);\r\n            const validDay = new Date(splitValue);\r\n            const pattern = /^\\d{2}\\/\\d{2}\\/\\d{4}$/;\r\n            if (pattern.test(splitValue)) {\r\n                setChosenDate(validDay);\r\n            }\r\n            props.onChange &&\r\n                typeof props.onChange === 'function' &&\r\n                props.onChange(isValidDay ? validDay.toISOString() : splitValue, event);\r\n        }\r\n        else {\r\n            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    }\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(dateTimePickerContent ? value.split(' ')[0] : value, i18n.dateFormat, new Date());\r\n        let isValidDay;\r\n        if (dateTimePickerContent) {\r\n            const splitValue = value.split(' ')[0];\r\n            isValidDay = isValidDateFromString(splitValue, day);\r\n            const validDay = new Date(splitValue);\r\n            if (isValidDay) {\r\n                handleDateChange(validDay, event);\r\n            }\r\n        }\r\n        else {\r\n            isValidDay = isValidDateFromString(value, day);\r\n            if (isValidDay) {\r\n                handleDateChange(day, event);\r\n            }\r\n            else {\r\n                reset && typeof reset === 'function' && reset();\r\n            }\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        if (dateTimePickerContent)\r\n            return;\r\n        setFocusedDate(day);\r\n    }\r\n    function handleDaySelection(day, event) {\r\n        handleDateChange(day, event);\r\n        if (dateTimePickerContent)\r\n            return;\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        if (!iconRef.current && previousIconRef.current) {\r\n            iconRef.current = previousIconRef.current;\r\n        }\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, dateTimePickerContent, ...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    let inputValue = chosenDate ? format(chosenDate, dateFormat) : '';\r\n    if (inputValue && props.additionalInputContent) {\r\n        inputValue = `${inputValue} ${props.additionalInputContent}`;\r\n    }\r\n    else if (props.additionalInputContent) {\r\n        setChosenDate(new Date());\r\n    }\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            setMonthFocusedDate,\r\n            setYearFocusedDate,\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, dateTimePickerContent: dateTimePickerContent })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
11687
|
+
}, ";overflow:hidden;transition:opacity 0.2s ease-in-out 0s;width:320px;" + (process.env.NODE_ENV === "production" ? "" : "/*# 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, 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, setMonthForDate, setYearForDate, 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 previousIconRef = 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 (props.apiRef) {\r\n            props.apiRef.current = {\r\n                closeDatePickerManually(event) {\r\n                    handleCloseButtonClick(event);\r\n                },\r\n                openDatePickerManually(event) {\r\n                    toggleCalendarOpened();\r\n                    inputRef.current.focus();\r\n                },\r\n            };\r\n        }\r\n    }, []);\r\n    React.useEffect(() => {\r\n        if (dateTimePickerContent &&\r\n            chosenDate &&\r\n            inputRef.current !== document.activeElement) {\r\n            if (!props.additionalInputContent && props.setAdditionalInputContent) {\r\n                props.setAdditionalInputContent('12:00 AM');\r\n            }\r\n            setFocusedDate(chosenDate);\r\n        }\r\n    }, [chosenDate]);\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    React.useEffect(() => {\r\n        previousIconRef.current = iconRef.current;\r\n    }, []);\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(newDate);\r\n    }\r\n    function onNextMonthClick() {\r\n        const newDate = getNextMonthFromDate(focusedDate);\r\n        setFocusedDate(newDate);\r\n    }\r\n    function setMonthFocusedDate(monthNumber) {\r\n        const newDate = setMonthForDate(focusedDate, monthNumber);\r\n        setFocusedDate(newDate);\r\n    }\r\n    function setYearFocusedDate(yearNumber) {\r\n        const newDate = setYearForDate(focusedDate, yearNumber);\r\n        setFocusedDate(newDate);\r\n    }\r\n    function onDateChange(day) {\r\n        setChosenDate(day);\r\n        if (dateTimePickerContent)\r\n            return;\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        let isValidDay;\r\n        if (dateTimePickerContent) {\r\n            const splitValue = value.split(' ')[0];\r\n            isValidDay = isValidDateFromString(splitValue, day);\r\n            const validDay = new Date(splitValue);\r\n            const pattern = /^\\d{2}\\/\\d{2}\\/\\d{4}$/;\r\n            if (pattern.test(splitValue)) {\r\n                setChosenDate(validDay);\r\n            }\r\n            props.onChange &&\r\n                typeof props.onChange === 'function' &&\r\n                props.onChange(isValidDay ? validDay.toISOString() : splitValue, event);\r\n        }\r\n        else {\r\n            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    }\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(dateTimePickerContent ? value.split(' ')[0] : value, i18n.dateFormat, new Date());\r\n        let isValidDay;\r\n        if (dateTimePickerContent) {\r\n            const splitValue = value.split(' ')[0];\r\n            isValidDay = isValidDateFromString(splitValue, day);\r\n            const validDay = new Date(splitValue);\r\n            if (isValidDay) {\r\n                handleDateChange(validDay, event);\r\n            }\r\n        }\r\n        else {\r\n            isValidDay = isValidDateFromString(value, day);\r\n            if (isValidDay) {\r\n                handleDateChange(day, event);\r\n            }\r\n            else {\r\n                reset && typeof reset === 'function' && reset();\r\n            }\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        if (dateTimePickerContent)\r\n            return;\r\n        setFocusedDate(day);\r\n    }\r\n    function handleDaySelection(day, event) {\r\n        handleDateChange(day, event);\r\n        if (dateTimePickerContent)\r\n            return;\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        if (!iconRef.current && previousIconRef.current) {\r\n            iconRef.current = previousIconRef.current;\r\n        }\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, dateTimePickerContent, ...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    let inputValue = chosenDate ? format(chosenDate, dateFormat) : '';\r\n    if (inputValue && props.additionalInputContent) {\r\n        inputValue = `${inputValue} ${props.additionalInputContent}`;\r\n    }\r\n    else if (props.additionalInputContent) {\r\n        setChosenDate(new Date());\r\n    }\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            setMonthFocusedDate,\r\n            setYearFocusedDate,\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, dateTimePickerContent: dateTimePickerContent })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
11600
11688
|
var DatePicker = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
11601
11689
|
var theme = useContext(ThemeContext);
|
|
11602
11690
|
var i18n = useContext(I18nContext);
|
|
@@ -11703,11 +11791,11 @@ var DatePicker = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
|
11703
11791
|
}
|
|
11704
11792
|
function onPrevMonthClick() {
|
|
11705
11793
|
var newDate = getPrevMonthFromDate(focusedDate);
|
|
11706
|
-
setFocusedDate(
|
|
11794
|
+
setFocusedDate(newDate);
|
|
11707
11795
|
}
|
|
11708
11796
|
function onNextMonthClick() {
|
|
11709
11797
|
var newDate = getNextMonthFromDate(focusedDate);
|
|
11710
|
-
setFocusedDate(
|
|
11798
|
+
setFocusedDate(newDate);
|
|
11711
11799
|
}
|
|
11712
11800
|
function setMonthFocusedDate(monthNumber) {
|
|
11713
11801
|
var newDate = setMonthForDate(focusedDate, monthNumber);
|
|
@@ -12300,7 +12388,7 @@ var TimePicker = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
12300
12388
|
}));
|
|
12301
12389
|
});
|
|
12302
12390
|
|
|
12303
|
-
var _excluded$L = ["onTimeChange", "onDone", "placeholder", "value", "defaultValue", "labelText", "timePickerLabelText", "buttonLabelText"];
|
|
12391
|
+
var _excluded$L = ["onTimeChange", "onInputChange", "onDone", "placeholder", "value", "defaultValue", "labelText", "timePickerLabelText", "buttonLabelText"];
|
|
12304
12392
|
var DoneButtonWrapper = /*#__PURE__*/_styled("div", {
|
|
12305
12393
|
target: "e19df3bi0",
|
|
12306
12394
|
label: "DoneButtonWrapper"
|
|
@@ -12310,9 +12398,10 @@ var DoneButtonWrapper = /*#__PURE__*/_styled("div", {
|
|
|
12310
12398
|
return props.theme.spaceScale.spacing05;
|
|
12311
12399
|
}, ";margin:", function (props) {
|
|
12312
12400
|
return "0 -" + props.theme.spaceScale.spacing03 + " -" + props.theme.spaceScale.spacing03;
|
|
12313
|
-
}, ";display:flex;justify-content:flex-end;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNcUMiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBCdXR0b24sIEJ1dHRvbkNvbG9yLCBCdXR0b25TaXplLCBJMThuQ29udGV4dCwgVGhlbWVDb250ZXh0LCB9IGZyb20gJy4uLy4uJztcclxuaW1wb3J0IHsgRGF0ZVBpY2tlciB9IGZyb20gJy4uL0RhdGVQaWNrZXInO1xyXG5pbXBvcnQgeyBMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi4vTGFiZWwnO1xyXG5pbXBvcnQgeyBUaW1lUGlja2VyIH0gZnJvbSAnLi4vVGltZVBpY2tlcic7XHJcbmNvbnN0IERvbmVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQtY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/
|
|
12401
|
+
}, ";display:flex;justify-content:flex-end;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNcUMiLCJmaWxlIjoiaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBCdXR0b24sIEJ1dHRvbkNvbG9yLCBCdXR0b25TaXplLCBJMThuQ29udGV4dCwgVGhlbWVDb250ZXh0LCB9IGZyb20gJy4uLy4uJztcclxuaW1wb3J0IHsgRGF0ZVBpY2tlciB9IGZyb20gJy4uL0RhdGVQaWNrZXInO1xyXG5pbXBvcnQgeyBMYWJlbFBvc2l0aW9uIH0gZnJvbSAnLi4vTGFiZWwnO1xyXG5pbXBvcnQgeyBUaW1lUGlja2VyIH0gZnJvbSAnLi4vVGltZVBpY2tlcic7XHJcbmNvbnN0IERvbmVCdXR0b25XcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQtY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5NjAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMjAwfTtcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNX07XG4gIG1hcmdpbjogJHtwcm9wcyA9PiBgMCAtJHtwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gLSR7cHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9YH07XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG5gO1xyXG5leHBvcnQgY29uc3QgRGF0ZVRpbWVQaWNrZXIgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgZm9yd2FyZGVkUmVmKSA9PiB7XHJcbiAgICBjb25zdCB7IG9uVGltZUNoYW5nZSwgb25JbnB1dENoYW5nZSwgb25Eb25lLCBwbGFjZWhvbGRlciwgdmFsdWUsIGRlZmF1bHRWYWx1ZSwgbGFiZWxUZXh0LCB0aW1lUGlja2VyTGFiZWxUZXh0LCBidXR0b25MYWJlbFRleHQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGNvbnN0IGkxOG4gPSBSZWFjdC51c2VDb250ZXh0KEkxOG5Db250ZXh0KTtcclxuICAgIGNvbnN0IGdldFRpbWVGcm9tRGF0ZSA9IChkYXRlKSA9PiB7XHJcbiAgICAgICAgaWYgKCFkYXRlKVxyXG4gICAgICAgICAgICByZXR1cm4gJyc7XHJcbiAgICAgICAgY29uc3QgZGF0ZU9iaiA9IG5ldyBEYXRlKGRhdGUpO1xyXG4gICAgICAgIHJldHVybiBkYXRlT2JqLnRvTG9jYWxlVGltZVN0cmluZygnZW4tVVMnLCB7XHJcbiAgICAgICAgICAgIGhvdXIxMjogdHJ1ZSxcclxuICAgICAgICAgICAgaG91cjogJ251bWVyaWMnLFxyXG4gICAgICAgICAgICBtaW51dGU6ICcyLWRpZ2l0JyxcclxuICAgICAgICB9KTtcclxuICAgIH07XHJcbiAgICBjb25zdCBpbml0aWFsVGltZSA9IGdldFRpbWVGcm9tRGF0ZSh2YWx1ZSA/PyBkZWZhdWx0VmFsdWUpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBkYXRlUGlja2VyQXBpUmVmID0gUmVhY3QudXNlUmVmKG51bGwpO1xyXG4gICAgY29uc3QgcHJldmlvdXNUaW1lID0gUmVhY3QudXNlUmVmKCcnKTtcclxuICAgIGNvbnN0IFthZGRpdGlvbmFsSW5wdXRDb250ZW50LCBzZXRBZGRpdGlvbmFsSW5wdXRDb250ZW50XSA9IFJlYWN0LnVzZVN0YXRlKGluaXRpYWxUaW1lIHx8ICcnKTtcclxuICAgIGNvbnN0IGhhbmRsZURvbmVDbGljayA9IChldmVudCkgPT4ge1xyXG4gICAgICAgIGRhdGVQaWNrZXJBcGlSZWYuY3VycmVudD8uY2xvc2VEYXRlUGlja2VyTWFudWFsbHkoKTtcclxuICAgICAgICBvbkRvbmUgJiYgb25Eb25lKGV2ZW50KTtcclxuICAgIH07XHJcbiAgICBjb25zdCBoYW5kbGVDbGVhciA9ICgpID0+IHtcclxuICAgICAgICBzZXRBZGRpdGlvbmFsSW5wdXRDb250ZW50KCcnKTtcclxuICAgICAgICBwcmV2aW91c1RpbWUuY3VycmVudCA9ICcnO1xyXG4gICAgfTtcclxuICAgIGNvbnN0IGhhbmRsZUlucHV0Q2hhbmdlID0gKGV2ZW50KSA9PiB7XHJcbiAgICAgICAgY29uc3QgeyB2YWx1ZSB9ID0gZXZlbnQudGFyZ2V0O1xyXG4gICAgICAgIGlmICghdmFsdWUpIHtcclxuICAgICAgICAgICAgc2V0QWRkaXRpb25hbElucHV0Q29udGVudCgnJyk7XHJcbiAgICAgICAgICAgIHByZXZpb3VzVGltZS5jdXJyZW50ID0gJyc7XHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICB9XHJcbiAgICAgICAgY29uc3QgdGltZU1hdGNoID0gdmFsdWUubWF0Y2goL1xcYihcXGR7MSwyfTpcXGR7Mn1cXHM/W0FQXU0pXFxiL2kpO1xyXG4gICAgICAgIGlmICh0aW1lTWF0Y2gpIHtcclxuICAgICAgICAgICAgY29uc3QgdGltZVZhbHVlID0gdGltZU1hdGNoWzFdO1xyXG4gICAgICAgICAgICBzZXRBZGRpdGlvbmFsSW5wdXRDb250ZW50KHRpbWVWYWx1ZSk7XHJcbiAgICAgICAgICAgIHByZXZpb3VzVGltZS5jdXJyZW50ID0gdGltZVZhbHVlO1xyXG4gICAgICAgIH1cclxuICAgICAgICBlbHNlIHtcclxuICAgICAgICAgICAgY29uc3QgY3V0dGVkVmFsdWUgPSB2YWx1ZS5zcGxpdCgnICcpO1xyXG4gICAgICAgICAgICBpZiAoY3V0dGVkVmFsdWVbMF0gJiYgY3V0dGVkVmFsdWVbMF0gIT09ICcnKSB7XHJcbiAgICAgICAgICAgICAgICBzZXRBZGRpdGlvbmFsSW5wdXRDb250ZW50KHByZXZpb3VzVGltZS5jdXJyZW50KTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICBlbHNlIHtcclxuICAgICAgICAgICAgICAgIHNldEFkZGl0aW9uYWxJbnB1dENvbnRlbnQoJycpO1xyXG4gICAgICAgICAgICAgICAgcHJldmlvdXNUaW1lLmN1cnJlbnQgPSAnJztcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuICAgICAgICBvbklucHV0Q2hhbmdlICYmIG9uSW5wdXRDaGFuZ2UoZXZlbnQpO1xyXG4gICAgfTtcclxuICAgIGNvbnN0IG9uVGltZUhhbmRsZUNoYW5nZSA9ICh2YWx1ZSkgPT4ge1xyXG4gICAgICAgIHNldEFkZGl0aW9uYWxJbnB1dENvbnRlbnQodmFsdWUpO1xyXG4gICAgICAgIHByZXZpb3VzVGltZS5jdXJyZW50ID0gdmFsdWU7XHJcbiAgICAgICAgb25UaW1lQ2hhbmdlICYmIG9uVGltZUNoYW5nZSh2YWx1ZSk7XHJcbiAgICB9O1xyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBpZiAoIXZhbHVlICYmICFkZWZhdWx0VmFsdWUpIHtcclxuICAgICAgICAgICAgaGFuZGxlQ2xlYXIoKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSBpZiAodmFsdWUpIHtcclxuICAgICAgICAgICAgY29uc3QgbmV3VGltZSA9IGdldFRpbWVGcm9tRGF0ZSh2YWx1ZSk7XHJcbiAgICAgICAgICAgIHNldEFkZGl0aW9uYWxJbnB1dENvbnRlbnQobmV3VGltZSk7XHJcbiAgICAgICAgICAgIHByZXZpb3VzVGltZS5jdXJyZW50ID0gbmV3VGltZTtcclxuICAgICAgICB9XHJcbiAgICB9LCBbdmFsdWUsIGRlZmF1bHRWYWx1ZV0pO1xyXG4gICAgY29uc3QgZGF0ZUZvcm1hdCA9IGkxOG4uZGF0ZUZvcm1hdDtcclxuICAgIGNvbnN0IHVwZGF0ZWRQbGFjZWhvbGRlciA9IHBsYWNlaG9sZGVyXHJcbiAgICAgICAgPyBwbGFjZWhvbGRlclxyXG4gICAgICAgIDogYCR7ZGF0ZUZvcm1hdC50b0xvd2VyQ2FzZSgpfSBoaDptbSBBTWA7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoRGF0ZVBpY2tlciwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgbGFiZWxUZXh0OiBsYWJlbFRleHQgPz8gaTE4bi5kYXRlVGltZVBpY2tlckxhYmVsLCBhcGlSZWY6IGRhdGVQaWNrZXJBcGlSZWYsIGFkZGl0aW9uYWxJbnB1dENvbnRlbnQ6IGFkZGl0aW9uYWxJbnB1dENvbnRlbnQsIHBsYWNlaG9sZGVyOiB1cGRhdGVkUGxhY2Vob2xkZXIsIG9uSW5wdXRDaGFuZ2U6IGhhbmRsZUlucHV0Q2hhbmdlLCBzZXRBZGRpdGlvbmFsSW5wdXRDb250ZW50OiBzZXRBZGRpdGlvbmFsSW5wdXRDb250ZW50LCBpc0NsZWFyYWJsZTogdHJ1ZSwgb25DbGVhcjogaGFuZGxlQ2xlYXIsIHJlZjogZm9yd2FyZGVkUmVmLCB2YWx1ZTogdmFsdWUsIGRlZmF1bHREYXRlOiBkZWZhdWx0VmFsdWUsIGRhdGVUaW1lUGlja2VyQ29udGVudDogUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUaW1lUGlja2VyLCB7IHZhbHVlOiAhYWRkaXRpb25hbElucHV0Q29udGVudCA/IHVuZGVmaW5lZCA6IGFkZGl0aW9uYWxJbnB1dENvbnRlbnQsIG9uQ2hhbmdlOiBvblRpbWVIYW5kbGVDaGFuZ2UsIGxhYmVsUG9zaXRpb246IExhYmVsUG9zaXRpb24ubGVmdCwgaW5wdXRTdHlsZTogeyB3aWR0aDogJzEwMCUnIH0sIGxhYmVsVGV4dDogdGltZVBpY2tlckxhYmVsVGV4dCA/PyAnVGltZScsIGNvbnRhaW5lclN0eWxlOiB7XHJcbiAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogdGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDUsXHJcbiAgICAgICAgICAgICAgICAgICAgbWFyZ2luOiBgMCAtJHt0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31gLFxyXG4gICAgICAgICAgICAgICAgICAgIGJvcmRlckJsb2NrOiBgMXB4IHNvbGlkICR7cHJvcHMuaXNJbnZlcnNlID8gdGhlbWUuY29sb3JzLnByaW1hcnk0MDAgOiB0aGVtZS5jb2xvcnMubmV1dHJhbDMwMH1gLFxyXG4gICAgICAgICAgICAgICAgfSB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChEb25lQnV0dG9uV3JhcHBlciwgeyB0aGVtZTogdGhlbWUsIGlzSW52ZXJzZTogcHJvcHMuaXNJbnZlcnNlIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEJ1dHRvbiwgeyBvbkNsaWNrOiBoYW5kbGVEb25lQ2xpY2ssIHNpemU6IEJ1dHRvblNpemUuc21hbGwsIGNvbG9yOiBCdXR0b25Db2xvci5zdWJ0bGUgfSwgYnV0dG9uTGFiZWxUZXh0ID8/ICdEb25lJykpKSB9KSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9aW5kZXguanMubWFwIl19 */"));
|
|
12314
12402
|
var DateTimePicker = /*#__PURE__*/React__default.forwardRef(function (props, forwardedRef) {
|
|
12315
12403
|
var onTimeChange = props.onTimeChange,
|
|
12404
|
+
onInputChange = props.onInputChange,
|
|
12316
12405
|
onDone = props.onDone,
|
|
12317
12406
|
placeholder = props.placeholder,
|
|
12318
12407
|
value = props.value,
|
|
@@ -12347,7 +12436,7 @@ var DateTimePicker = /*#__PURE__*/React__default.forwardRef(function (props, for
|
|
|
12347
12436
|
setAdditionalInputContent('');
|
|
12348
12437
|
previousTime.current = '';
|
|
12349
12438
|
};
|
|
12350
|
-
var
|
|
12439
|
+
var handleInputChange = function handleInputChange(event) {
|
|
12351
12440
|
var value = event.target.value;
|
|
12352
12441
|
if (!value) {
|
|
12353
12442
|
setAdditionalInputContent('');
|
|
@@ -12368,6 +12457,7 @@ var DateTimePicker = /*#__PURE__*/React__default.forwardRef(function (props, for
|
|
|
12368
12457
|
previousTime.current = '';
|
|
12369
12458
|
}
|
|
12370
12459
|
}
|
|
12460
|
+
onInputChange && onInputChange(event);
|
|
12371
12461
|
};
|
|
12372
12462
|
var onTimeHandleChange = function onTimeHandleChange(value) {
|
|
12373
12463
|
setAdditionalInputContent(value);
|
|
@@ -12385,12 +12475,12 @@ var DateTimePicker = /*#__PURE__*/React__default.forwardRef(function (props, for
|
|
|
12385
12475
|
}, [value, defaultValue]);
|
|
12386
12476
|
var dateFormat = i18n.dateFormat;
|
|
12387
12477
|
var updatedPlaceholder = placeholder ? placeholder : dateFormat.toLowerCase() + " hh:mm AM";
|
|
12388
|
-
return React__default.createElement(DatePicker, Object.assign({
|
|
12478
|
+
return React__default.createElement(DatePicker, Object.assign({}, other, {
|
|
12389
12479
|
labelText: labelText != null ? labelText : i18n.dateTimePickerLabel,
|
|
12390
12480
|
apiRef: datePickerApiRef,
|
|
12391
12481
|
additionalInputContent: additionalInputContent,
|
|
12392
12482
|
placeholder: updatedPlaceholder,
|
|
12393
|
-
onInputChange:
|
|
12483
|
+
onInputChange: handleInputChange,
|
|
12394
12484
|
setAdditionalInputContent: setAdditionalInputContent,
|
|
12395
12485
|
isClearable: true,
|
|
12396
12486
|
onClear: handleClear,
|
|
@@ -12418,7 +12508,7 @@ var DateTimePicker = /*#__PURE__*/React__default.forwardRef(function (props, for
|
|
|
12418
12508
|
size: ButtonSize.small,
|
|
12419
12509
|
color: ButtonColor.subtle
|
|
12420
12510
|
}, buttonLabelText != null ? buttonLabelText : 'Done')))
|
|
12421
|
-
}
|
|
12511
|
+
}));
|
|
12422
12512
|
});
|
|
12423
12513
|
|
|
12424
12514
|
function registerDescendant(itemRefArray, itemRef) {
|