react-magma-dom 4.10.0-next.20 → 4.10.0-next.21
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/components/DatePicker/CalendarContext.d.ts +2 -0
- package/dist/components/DatePicker/CalendarHeader.d.ts +1 -1
- package/dist/components/DatePicker/MonthPicker.d.ts +6 -0
- package/dist/components/DatePicker/StyledSelect.d.ts +9 -0
- package/dist/components/DatePicker/YearPicker.d.ts +7 -0
- package/dist/components/DatePicker/utils.d.ts +6 -0
- package/dist/esm/index.js +189 -75
- package/dist/esm/index.js.map +1 -1
- package/dist/i18n/interface.d.ts +2 -0
- package/dist/properties.json +98 -24
- package/dist/react-magma-dom.cjs.development.js +188 -74
- 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
|
@@ -1741,6 +1741,8 @@ var defaultI18n = {
|
|
|
1741
1741
|
today: 'Today',
|
|
1742
1742
|
navigateToCurrentDateAriaLabel: 'Navigate to current month and year',
|
|
1743
1743
|
backToCalendarAriaLabel: 'Back to Calendar',
|
|
1744
|
+
selectMonth: 'Select a month',
|
|
1745
|
+
selectYear: 'Select a year',
|
|
1744
1746
|
helpModal: {
|
|
1745
1747
|
header: 'Keyboard Shortcuts',
|
|
1746
1748
|
helpButtonAriaLabel: 'Calendar Widget Help',
|
|
@@ -6596,7 +6598,9 @@ var CalendarContext = /*#__PURE__*/React.createContext({
|
|
|
6596
6598
|
onNextMonthClick: function onNextMonthClick() {},
|
|
6597
6599
|
setDateFocused: function setDateFocused(value) {},
|
|
6598
6600
|
setFocusedDate: function setFocusedDate(day) {},
|
|
6599
|
-
setFocusedTodayDate: function setFocusedTodayDate(event) {}
|
|
6601
|
+
setFocusedTodayDate: function setFocusedTodayDate(event) {},
|
|
6602
|
+
setMonthFocusedDate: function setMonthFocusedDate(monthNumber) {},
|
|
6603
|
+
setYearFocusedDate: function setYearFocusedDate(yearNumber) {}
|
|
6600
6604
|
});
|
|
6601
6605
|
|
|
6602
6606
|
var _excluded$G = ["arrowStyle", "children", "content", "containerStyle", "id", "position", "testId", "tooltipStyle"];
|
|
@@ -6856,6 +6860,23 @@ function i18nFormat(date, formatStr, locale$1) {
|
|
|
6856
6860
|
function getDateFromString(date) {
|
|
6857
6861
|
return date ? date instanceof Date ? date : new Date(date) : null;
|
|
6858
6862
|
}
|
|
6863
|
+
function getCurrentMonthAndYear(date, locale) {
|
|
6864
|
+
var currentDate = i18nFormat(date, 'MMMM yyyy', locale);
|
|
6865
|
+
var capitalizeCurrentMonth = currentDate && currentDate.charAt(0).toUpperCase() + currentDate.slice(1);
|
|
6866
|
+
var _ref = capitalizeCurrentMonth ? capitalizeCurrentMonth.split(' ') : ['', ''],
|
|
6867
|
+
month = _ref[0],
|
|
6868
|
+
year = _ref[1];
|
|
6869
|
+
return {
|
|
6870
|
+
month: month,
|
|
6871
|
+
year: year
|
|
6872
|
+
};
|
|
6873
|
+
}
|
|
6874
|
+
function setMonthForDate(prevDate, numberMonth) {
|
|
6875
|
+
return dateFns.startOfMonth(dateFns.setMonth(prevDate, numberMonth));
|
|
6876
|
+
}
|
|
6877
|
+
function setYearForDate(prevDate, numberYear) {
|
|
6878
|
+
return dateFns.setYear(prevDate, numberYear);
|
|
6879
|
+
}
|
|
6859
6880
|
|
|
6860
6881
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$g() { 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)."; }
|
|
6861
6882
|
function getCalendarDayBackground(isInverse, isChosen, theme) {
|
|
@@ -6917,7 +6938,7 @@ var CalendarDayCell = /*#__PURE__*/_styled("td", {
|
|
|
6917
6938
|
return props.theme.typeScale.size03.lineHeight;
|
|
6918
6939
|
}, ";height:", function (props) {
|
|
6919
6940
|
return props.theme.spaceScale.spacing09;
|
|
6920
|
-
}, ";padding:0;position:relative;text-align:center;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AAgEkC","file":"CalendarDay.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { isAfter, isBefore, isSameDay, isSameMonth } from 'date-fns';\r\nimport { enUS } from 'date-fns/locale';\r\nimport { transparentize } from 'polished';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { i18nFormat as format } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nfunction getCalendarDayBackground(isInverse, isChosen, theme) {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.tertiary : theme.colors.primary;\r\n    }\r\n    return isChosen ? theme.colors.primary : theme.colors.neutral100;\r\n}\r\nconst getTodayColor = (isChosen, isInverse, theme) => {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.primary600 : theme.colors.secondary500;\r\n    }\r\n    return isChosen ? theme.colors.neutral100 : theme.colors.primary500;\r\n};\r\nconst getChosenDayColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n};\r\nconst getDisabledColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.6, theme.colors.neutral100)\r\n        : transparentize(0.4, theme.colors.neutral500);\r\n};\r\nconst getNotCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.3, theme.colors.neutral100)\r\n        : theme.colors.neutral500;\r\n};\r\nconst getCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.neutral100 : theme.colors.neutral700;\r\n};\r\nconst getCalendarDayColor = (state, isInverse, theme) => {\r\n    if (state.isToday)\r\n        return getTodayColor(state.isChosen, isInverse, theme);\r\n    if (state.disabled)\r\n        return getDisabledColor(isInverse, theme);\r\n    if (state.isChosen)\r\n        return getChosenDayColor(isInverse, theme);\r\n    if (!state.isDayInCurrentMonth && !state.disabled)\r\n        return getNotCurrentMonthColor(isInverse, theme);\r\n    return getCurrentMonthColor(isInverse, theme);\r\n};\r\nfunction getChosenDayBorder(isInverse, isChosen, theme) {\r\n    if (isChosen) {\r\n        return `1px solid ${isInverse ? theme.colors.primary600 : theme.colors.neutral100}`;\r\n    }\r\n}\r\nfunction getChosenDayHover(isChosen, isInverse, theme) {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.neutral200 : theme.colors.primary600;\r\n    }\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral200;\r\n}\r\nconst getCalendarDayFontSize = (state) => {\r\n    if (state.isToday)\r\n        return 700;\r\n    return !state.isDayInCurrentMonth || state.disabled ? 400 : 500;\r\n};\r\nconst CalendarDayCell = styled.td `\n  color: ${props => props.isInverse ? props.theme.colors.danger : props.theme.colors.neutral};\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  height: ${props => props.theme.spaceScale.spacing09};\n  padding: 0;\n  position: relative;\n  text-align: center;\n`;\r\nconst CalendarDayInner = styled.button `\n  align-items: center;\n  background: ${props => getCalendarDayBackground(props.isInverse, props.state.isChosen, props.theme)};\n  border: 2px solid transparent;\n  color: ${props => getCalendarDayColor(props.state, props.isInverse, props.theme)};\n  font-weight: ${props => getCalendarDayFontSize(props.state)};\n  cursor: ${props => (props.state.disabled ? 'not-allowed' : 'pointer')};\n  display: flex;\n  height: ${props => props.theme.spaceScale.spacing09};\n  justify-content: center;\n  overflow: hidden;\n  outline-offset: 0;\n  position: relative;\n  transition: background 0.5s ease-in-out 0s;\n  width: 43px;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    border: ${props => getChosenDayBorder(props.isInverse, props.state.isChosen, props.theme)};\n    width: ${props => props.theme.spaceScale.spacing09};\n    height: 36px;\n    margin: 1px;\n  }\n\n  &:before {\n    background: ${props => props.isInverse\r\n    ? props.theme.colors.danger200\r\n    : props.theme.colors.neutral};\n    content: '';\n    height: 200%;\n    left: 0;\n    opacity: 0;\n    position: absolute;\n    top: -50%;\n    transition: 0.2s;\n    width: 200%;\n  }\n\n  &:hover {\n    &:before {\n      opacity: ${props => (props.state.disabled ? 0 : 0.1)};\n    }\n    border: none;\n    background: ${props => getChosenDayHover(props.state.isChosen, props.isInverse, props.theme)};\n  }\n`;\r\nconst EmptyCell = styled.td `\n  border: 0;\n  padding: 0;\n`;\r\nconst TodayIndicator = styled.span `\n  position: absolute;\n  bottom: 5px;\n  left: 19px;\n  width: 5px;\n  height: 5px;\n  border-radius: 50%;\n  background: ${props => getTodayColor(props.isChosen, props.isInverse, props.theme)};\n`;\r\nexport const CalendarDay = (props) => {\r\n    const dayRef = React.useRef();\r\n    const { dateFocused, focusedDate, chosenDate, maxDate, minDate, onDateChange, setDateFocused, setFocusedDate, isInverse, } = React.useContext(CalendarContext);\r\n    const [focused, setFocused] = React.useState(false);\r\n    const { day } = props;\r\n    React.useEffect(() => {\r\n        if (dateFocused && isSameDay(day, focusedDate)) {\r\n            dayRef.current.focus();\r\n            setFocused(true);\r\n        }\r\n        else {\r\n            if (focused) {\r\n                setFocused(false);\r\n            }\r\n        }\r\n    }, [focusedDate, dateFocused]);\r\n    function onCalendarDayFocus() {\r\n        setDateFocused(true);\r\n    }\r\n    function onDayClick(event) {\r\n        if (disabled) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        onDateChange(day, event);\r\n    }\r\n    function onFocusDay(event) {\r\n        if (disabled || !isSameMonth(day, focusedDate)) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        setFocusedDate(day);\r\n    }\r\n    const disabled = (maxDate ? isAfter(props.day, maxDate) : false) ||\r\n        (minDate ? isBefore(props.day, minDate) : false);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    if (day) {\r\n        const sameDateAsFocusedDate = isSameDay(day, focusedDate);\r\n        const sameDateAsChosenDate = isSameDay(day, chosenDate);\r\n        const sameDateAsToday = isSameDay(day, new Date());\r\n        const isDayInCurrentMonth = isSameMonth(day, focusedDate);\r\n        const locale = i18n.locale || enUS;\r\n        const ariaLabel = `${disabled ? i18n.datePicker.disabledDayAriaLabel : ''} ${format(day, 'EEEE, MMMM do yyyy', locale)} ${sameDateAsToday ? i18n.datePicker.todayAriaLabel : ''} ${sameDateAsChosenDate ? i18n.datePicker.selectedDayAriaLabel : ''}`;\r\n        const dayState = {\r\n            isChosen: sameDateAsChosenDate,\r\n            disabled,\r\n            isDayInCurrentMonth,\r\n            isToday: sameDateAsToday,\r\n        };\r\n        return (React.createElement(CalendarDayCell, { onFocus: onCalendarDayFocus, isInverse: isInverse, theme: theme },\r\n            React.createElement(CalendarDayInner, { \"aria-disabled\": disabled, \"aria-label\": ariaLabel, \"aria-current\": sameDateAsToday ? 'date' : undefined, \"aria-selected\": sameDateAsChosenDate, \"data-testid\": \"calendar-day\", state: dayState, isInverse: isInverse, onClick: onDayClick, onMouseDown: onFocusDay, ref: dayRef, tabIndex: sameDateAsFocusedDate ? 0 : -1, type: \"button\", theme: theme }, format(day, 'd', locale)),\r\n            sameDateAsToday && (React.createElement(TodayIndicator, { \"data-testid\": \"todayIndicator\", isInverse: isInverse, isChosen: sameDateAsChosenDate, theme: theme }))));\r\n    }\r\n    else {\r\n        return React.createElement(EmptyCell, null);\r\n    }\r\n};\r\n//# sourceMappingURL=CalendarDay.js.map"]} */"));
|
|
6941
|
+
}, ";padding:0;position:relative;text-align:center;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AAgEkC","file":"CalendarDay.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { isAfter, isBefore, isSameDay, isSameMonth } from 'date-fns';\r\nimport { enUS } from 'date-fns/locale';\r\nimport { transparentize } from 'polished';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { i18nFormat as format } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nfunction getCalendarDayBackground(isInverse, isChosen, theme) {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.tertiary : theme.colors.primary;\r\n    }\r\n    return isChosen ? theme.colors.primary : theme.colors.neutral100;\r\n}\r\nconst getTodayColor = (isChosen, isInverse, theme) => {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.primary600 : theme.colors.secondary500;\r\n    }\r\n    return isChosen ? theme.colors.neutral100 : theme.colors.primary500;\r\n};\r\nconst getChosenDayColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n};\r\nconst getDisabledColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.6, theme.colors.neutral100)\r\n        : transparentize(0.4, theme.colors.neutral500);\r\n};\r\nconst getNotCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.3, theme.colors.neutral100)\r\n        : theme.colors.neutral500;\r\n};\r\nconst getCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.neutral100 : theme.colors.neutral700;\r\n};\r\nconst getCalendarDayColor = (state, isInverse, theme) => {\r\n    if (state.isToday)\r\n        return getTodayColor(state.isChosen, isInverse, theme);\r\n    if (state.disabled)\r\n        return getDisabledColor(isInverse, theme);\r\n    if (state.isChosen)\r\n        return getChosenDayColor(isInverse, theme);\r\n    if (!state.isDayInCurrentMonth && !state.disabled)\r\n        return getNotCurrentMonthColor(isInverse, theme);\r\n    return getCurrentMonthColor(isInverse, theme);\r\n};\r\nfunction getChosenDayBorder(isInverse, isChosen, theme) {\r\n    if (isChosen) {\r\n        return `1px solid ${isInverse ? theme.colors.primary600 : theme.colors.neutral100}`;\r\n    }\r\n}\r\nfunction getChosenDayHover(isChosen, isInverse, theme) {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.neutral200 : theme.colors.primary600;\r\n    }\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral200;\r\n}\r\nconst getCalendarDayFontSize = (state) => {\r\n    if (state.isToday)\r\n        return 700;\r\n    return !state.isDayInCurrentMonth || state.disabled ? 400 : 500;\r\n};\r\nconst CalendarDayCell = styled.td `\n  color: ${props => props.isInverse ? props.theme.colors.danger : props.theme.colors.neutral};\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  height: ${props => props.theme.spaceScale.spacing09};\n  padding: 0;\n  position: relative;\n  text-align: center;\n`;\r\nconst CalendarDayInner = styled.button `\n  align-items: center;\n  background: ${props => getCalendarDayBackground(props.isInverse, props.state.isChosen, props.theme)};\n  border: 2px solid transparent;\n  color: ${props => getCalendarDayColor(props.state, props.isInverse, props.theme)};\n  font-weight: ${props => getCalendarDayFontSize(props.state)};\n  cursor: ${props => (props.state.disabled ? 'not-allowed' : 'pointer')};\n  display: flex;\n  height: ${props => props.theme.spaceScale.spacing09};\n  justify-content: center;\n  overflow: hidden;\n  outline-offset: 0;\n  position: relative;\n  transition: background 0.5s ease-in-out 0s;\n  width: 43px;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    border: ${props => getChosenDayBorder(props.isInverse, props.state.isChosen, props.theme)};\n    width: ${props => props.theme.spaceScale.spacing09};\n    height: 36px;\n    margin: 1px;\n  }\n\n  &:before {\n    background: ${props => props.isInverse\r\n    ? props.theme.colors.danger200\r\n    : props.theme.colors.neutral};\n    content: '';\n    height: 200%;\n    left: 0;\n    opacity: 0;\n    position: absolute;\n    top: -50%;\n    transition: 0.2s;\n    width: 200%;\n  }\n\n  &:hover {\n    &:before {\n      opacity: ${props => (props.state.disabled ? 0 : 0.1)};\n    }\n    border: none;\n    background: ${props => getChosenDayHover(props.state.isChosen, props.isInverse, props.theme)};\n  }\n`;\r\nconst EmptyCell = styled.td `\n  border: 0;\n  padding: 0;\n`;\r\nconst TodayIndicator = styled.span `\n  position: absolute;\n  bottom: 5px;\n  left: 19px;\n  width: 5px;\n  height: 5px;\n  border-radius: 50%;\n  background: ${props => getTodayColor(props.isChosen, props.isInverse, props.theme)};\n`;\r\nexport const CalendarDay = (props) => {\r\n    const dayRef = React.useRef();\r\n    const { dateFocused, focusedDate, chosenDate, maxDate, minDate, onDateChange, setDateFocused, setFocusedDate, isInverse, } = React.useContext(CalendarContext);\r\n    const [focused, setFocused] = React.useState(false);\r\n    const { day } = props;\r\n    React.useEffect(() => {\r\n        if (dateFocused && isSameDay(day, focusedDate)) {\r\n            dayRef.current.focus();\r\n            setFocused(true);\r\n        }\r\n        else {\r\n            if (focused) {\r\n                setFocused(false);\r\n            }\r\n        }\r\n    }, [focusedDate, dateFocused]);\r\n    function onCalendarDayFocus() {\r\n        setDateFocused(true);\r\n    }\r\n    function onDayClick(event) {\r\n        if (disabled) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        onDateChange(day, event);\r\n    }\r\n    function onFocusDay(event) {\r\n        if (disabled || !isSameMonth(day, focusedDate)) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        setFocusedDate(day);\r\n    }\r\n    const disabled = (maxDate ? isAfter(props.day, maxDate) : false) ||\r\n        (minDate ? isBefore(props.day, minDate) : false);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    if (day) {\r\n        const sameDateAsFocusedDate = isSameDay(day, focusedDate);\r\n        const sameDateAsChosenDate = isSameDay(day, chosenDate);\r\n        const sameDateAsToday = isSameDay(day, new Date());\r\n        const isDayInCurrentMonth = isSameMonth(day, focusedDate);\r\n        const locale = i18n.locale || enUS;\r\n        const ariaLabel = `${disabled ? i18n.datePicker.disabledDayAriaLabel : ''} ${format(day, 'EEEE, MMMM do yyyy', locale)} ${sameDateAsToday ? i18n.datePicker.todayAriaLabel : ''} ${sameDateAsChosenDate ? i18n.datePicker.selectedDayAriaLabel : ''}`;\r\n        const dayState = {\r\n            isChosen: sameDateAsChosenDate,\r\n            disabled,\r\n            isDayInCurrentMonth,\r\n            isToday: sameDateAsToday,\r\n        };\r\n        return (React.createElement(CalendarDayCell, { onFocus: onCalendarDayFocus, isInverse: isInverse, theme: theme },\r\n            React.createElement(CalendarDayInner, { \"aria-disabled\": disabled, \"aria-label\": ariaLabel, \"aria-current\": sameDateAsToday ? 'date' : undefined, \"aria-selected\": sameDateAsChosenDate, \"data-testid\": \"calendar-day\", 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"]} */"));
|
|
6921
6942
|
var CalendarDayInner = /*#__PURE__*/_styled("button", {
|
|
6922
6943
|
target: "eviokpi2",
|
|
6923
6944
|
label: "CalendarDayInner"
|
|
@@ -6943,13 +6964,13 @@ var CalendarDayInner = /*#__PURE__*/_styled("button", {
|
|
|
6943
6964
|
return getChosenDayHover(props.state.isChosen, props.isInverse, props.theme);
|
|
6944
6965
|
}, ";&:before{opacity:", function (props) {
|
|
6945
6966
|
return props.state.disabled ? 0 : 0.1;
|
|
6946
|
-
}, ";}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AA0EuC","file":"CalendarDay.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { isAfter, isBefore, isSameDay, isSameMonth } from 'date-fns';\r\nimport { enUS } from 'date-fns/locale';\r\nimport { transparentize } from 'polished';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { i18nFormat as format } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nfunction getCalendarDayBackground(isInverse, isChosen, theme) {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.tertiary : theme.colors.primary;\r\n    }\r\n    return isChosen ? theme.colors.primary : theme.colors.neutral100;\r\n}\r\nconst getTodayColor = (isChosen, isInverse, theme) => {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.primary600 : theme.colors.secondary500;\r\n    }\r\n    return isChosen ? theme.colors.neutral100 : theme.colors.primary500;\r\n};\r\nconst getChosenDayColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n};\r\nconst getDisabledColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.6, theme.colors.neutral100)\r\n        : transparentize(0.4, theme.colors.neutral500);\r\n};\r\nconst getNotCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.3, theme.colors.neutral100)\r\n        : theme.colors.neutral500;\r\n};\r\nconst getCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.neutral100 : theme.colors.neutral700;\r\n};\r\nconst getCalendarDayColor = (state, isInverse, theme) => {\r\n    if (state.isToday)\r\n        return getTodayColor(state.isChosen, isInverse, theme);\r\n    if (state.disabled)\r\n        return getDisabledColor(isInverse, theme);\r\n    if (state.isChosen)\r\n        return getChosenDayColor(isInverse, theme);\r\n    if (!state.isDayInCurrentMonth && !state.disabled)\r\n        return getNotCurrentMonthColor(isInverse, theme);\r\n    return getCurrentMonthColor(isInverse, theme);\r\n};\r\nfunction getChosenDayBorder(isInverse, isChosen, theme) {\r\n    if (isChosen) {\r\n        return `1px solid ${isInverse ? theme.colors.primary600 : theme.colors.neutral100}`;\r\n    }\r\n}\r\nfunction getChosenDayHover(isChosen, isInverse, theme) {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.neutral200 : theme.colors.primary600;\r\n    }\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral200;\r\n}\r\nconst getCalendarDayFontSize = (state) => {\r\n    if (state.isToday)\r\n        return 700;\r\n    return !state.isDayInCurrentMonth || state.disabled ? 400 : 500;\r\n};\r\nconst CalendarDayCell = styled.td `\n  color: ${props => props.isInverse ? props.theme.colors.danger : props.theme.colors.neutral};\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  height: ${props => props.theme.spaceScale.spacing09};\n  padding: 0;\n  position: relative;\n  text-align: center;\n`;\r\nconst CalendarDayInner = styled.button `\n  align-items: center;\n  background: ${props => getCalendarDayBackground(props.isInverse, props.state.isChosen, props.theme)};\n  border: 2px solid transparent;\n  color: ${props => getCalendarDayColor(props.state, props.isInverse, props.theme)};\n  font-weight: ${props => getCalendarDayFontSize(props.state)};\n  cursor: ${props => (props.state.disabled ? 'not-allowed' : 'pointer')};\n  display: flex;\n  height: ${props => props.theme.spaceScale.spacing09};\n  justify-content: center;\n  overflow: hidden;\n  outline-offset: 0;\n  position: relative;\n  transition: background 0.5s ease-in-out 0s;\n  width: 43px;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    border: ${props => getChosenDayBorder(props.isInverse, props.state.isChosen, props.theme)};\n    width: ${props => props.theme.spaceScale.spacing09};\n    height: 36px;\n    margin: 1px;\n  }\n\n  &:before {\n    background: ${props => props.isInverse\r\n    ? props.theme.colors.danger200\r\n    : props.theme.colors.neutral};\n    content: '';\n    height: 200%;\n    left: 0;\n    opacity: 0;\n    position: absolute;\n    top: -50%;\n    transition: 0.2s;\n    width: 200%;\n  }\n\n  &:hover {\n    &:before {\n      opacity: ${props => (props.state.disabled ? 0 : 0.1)};\n    }\n    border: none;\n    background: ${props => getChosenDayHover(props.state.isChosen, props.isInverse, props.theme)};\n  }\n`;\r\nconst EmptyCell = styled.td `\n  border: 0;\n  padding: 0;\n`;\r\nconst TodayIndicator = styled.span `\n  position: absolute;\n  bottom: 5px;\n  left: 19px;\n  width: 5px;\n  height: 5px;\n  border-radius: 50%;\n  background: ${props => getTodayColor(props.isChosen, props.isInverse, props.theme)};\n`;\r\nexport const CalendarDay = (props) => {\r\n    const dayRef = React.useRef();\r\n    const { dateFocused, focusedDate, chosenDate, maxDate, minDate, onDateChange, setDateFocused, setFocusedDate, isInverse, } = React.useContext(CalendarContext);\r\n    const [focused, setFocused] = React.useState(false);\r\n    const { day } = props;\r\n    React.useEffect(() => {\r\n        if (dateFocused && isSameDay(day, focusedDate)) {\r\n            dayRef.current.focus();\r\n            setFocused(true);\r\n        }\r\n        else {\r\n            if (focused) {\r\n                setFocused(false);\r\n            }\r\n        }\r\n    }, [focusedDate, dateFocused]);\r\n    function onCalendarDayFocus() {\r\n        setDateFocused(true);\r\n    }\r\n    function onDayClick(event) {\r\n        if (disabled) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        onDateChange(day, event);\r\n    }\r\n    function onFocusDay(event) {\r\n        if (disabled || !isSameMonth(day, focusedDate)) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        setFocusedDate(day);\r\n    }\r\n    const disabled = (maxDate ? isAfter(props.day, maxDate) : false) ||\r\n        (minDate ? isBefore(props.day, minDate) : false);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    if (day) {\r\n        const sameDateAsFocusedDate = isSameDay(day, focusedDate);\r\n        const sameDateAsChosenDate = isSameDay(day, chosenDate);\r\n        const sameDateAsToday = isSameDay(day, new Date());\r\n        const isDayInCurrentMonth = isSameMonth(day, focusedDate);\r\n        const locale = i18n.locale || enUS;\r\n        const ariaLabel = `${disabled ? i18n.datePicker.disabledDayAriaLabel : ''} ${format(day, 'EEEE, MMMM do yyyy', locale)} ${sameDateAsToday ? i18n.datePicker.todayAriaLabel : ''} ${sameDateAsChosenDate ? i18n.datePicker.selectedDayAriaLabel : ''}`;\r\n        const dayState = {\r\n            isChosen: sameDateAsChosenDate,\r\n            disabled,\r\n            isDayInCurrentMonth,\r\n            isToday: sameDateAsToday,\r\n        };\r\n        return (React.createElement(CalendarDayCell, { onFocus: onCalendarDayFocus, isInverse: isInverse, theme: theme },\r\n            React.createElement(CalendarDayInner, { \"aria-disabled\": disabled, \"aria-label\": ariaLabel, \"aria-current\": sameDateAsToday ? 'date' : undefined, \"aria-selected\": sameDateAsChosenDate, \"data-testid\": \"calendar-day\", state: dayState, isInverse: isInverse, onClick: onDayClick, onMouseDown: onFocusDay, ref: dayRef, tabIndex: sameDateAsFocusedDate ? 0 : -1, type: \"button\", theme: theme }, format(day, 'd', locale)),\r\n            sameDateAsToday && (React.createElement(TodayIndicator, { \"data-testid\": \"todayIndicator\", isInverse: isInverse, isChosen: sameDateAsChosenDate, theme: theme }))));\r\n    }\r\n    else {\r\n        return React.createElement(EmptyCell, null);\r\n    }\r\n};\r\n//# sourceMappingURL=CalendarDay.js.map"]} */"));
|
|
6967
|
+
}, ";}}" + ( "/*# 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"]} */"));
|
|
6947
6968
|
var EmptyCell = /*#__PURE__*/_styled("td", {
|
|
6948
6969
|
target: "eviokpi1",
|
|
6949
6970
|
label: "EmptyCell"
|
|
6950
6971
|
})( {
|
|
6951
6972
|
name: "1njmmm4",
|
|
6952
|
-
styles: "border:0;padding:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AA2H4B","file":"CalendarDay.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { isAfter, isBefore, isSameDay, isSameMonth } from 'date-fns';\r\nimport { enUS } from 'date-fns/locale';\r\nimport { transparentize } from 'polished';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { i18nFormat as format } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nfunction getCalendarDayBackground(isInverse, isChosen, theme) {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.tertiary : theme.colors.primary;\r\n    }\r\n    return isChosen ? theme.colors.primary : theme.colors.neutral100;\r\n}\r\nconst getTodayColor = (isChosen, isInverse, theme) => {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.primary600 : theme.colors.secondary500;\r\n    }\r\n    return isChosen ? theme.colors.neutral100 : theme.colors.primary500;\r\n};\r\nconst getChosenDayColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n};\r\nconst getDisabledColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.6, theme.colors.neutral100)\r\n        : transparentize(0.4, theme.colors.neutral500);\r\n};\r\nconst getNotCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.3, theme.colors.neutral100)\r\n        : theme.colors.neutral500;\r\n};\r\nconst getCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.neutral100 : theme.colors.neutral700;\r\n};\r\nconst getCalendarDayColor = (state, isInverse, theme) => {\r\n    if (state.isToday)\r\n        return getTodayColor(state.isChosen, isInverse, theme);\r\n    if (state.disabled)\r\n        return getDisabledColor(isInverse, theme);\r\n    if (state.isChosen)\r\n        return getChosenDayColor(isInverse, theme);\r\n    if (!state.isDayInCurrentMonth && !state.disabled)\r\n        return getNotCurrentMonthColor(isInverse, theme);\r\n    return getCurrentMonthColor(isInverse, theme);\r\n};\r\nfunction getChosenDayBorder(isInverse, isChosen, theme) {\r\n    if (isChosen) {\r\n        return `1px solid ${isInverse ? theme.colors.primary600 : theme.colors.neutral100}`;\r\n    }\r\n}\r\nfunction getChosenDayHover(isChosen, isInverse, theme) {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.neutral200 : theme.colors.primary600;\r\n    }\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral200;\r\n}\r\nconst getCalendarDayFontSize = (state) => {\r\n    if (state.isToday)\r\n        return 700;\r\n    return !state.isDayInCurrentMonth || state.disabled ? 400 : 500;\r\n};\r\nconst CalendarDayCell = styled.td `\n  color: ${props => props.isInverse ? props.theme.colors.danger : props.theme.colors.neutral};\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  height: ${props => props.theme.spaceScale.spacing09};\n  padding: 0;\n  position: relative;\n  text-align: center;\n`;\r\nconst CalendarDayInner = styled.button `\n  align-items: center;\n  background: ${props => getCalendarDayBackground(props.isInverse, props.state.isChosen, props.theme)};\n  border: 2px solid transparent;\n  color: ${props => getCalendarDayColor(props.state, props.isInverse, props.theme)};\n  font-weight: ${props => getCalendarDayFontSize(props.state)};\n  cursor: ${props => (props.state.disabled ? 'not-allowed' : 'pointer')};\n  display: flex;\n  height: ${props => props.theme.spaceScale.spacing09};\n  justify-content: center;\n  overflow: hidden;\n  outline-offset: 0;\n  position: relative;\n  transition: background 0.5s ease-in-out 0s;\n  width: 43px;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    border: ${props => getChosenDayBorder(props.isInverse, props.state.isChosen, props.theme)};\n    width: ${props => props.theme.spaceScale.spacing09};\n    height: 36px;\n    margin: 1px;\n  }\n\n  &:before {\n    background: ${props => props.isInverse\r\n    ? props.theme.colors.danger200\r\n    : props.theme.colors.neutral};\n    content: '';\n    height: 200%;\n    left: 0;\n    opacity: 0;\n    position: absolute;\n    top: -50%;\n    transition: 0.2s;\n    width: 200%;\n  }\n\n  &:hover {\n    &:before {\n      opacity: ${props => (props.state.disabled ? 0 : 0.1)};\n    }\n    border: none;\n    background: ${props => getChosenDayHover(props.state.isChosen, props.isInverse, props.theme)};\n  }\n`;\r\nconst EmptyCell = styled.td `\n  border: 0;\n  padding: 0;\n`;\r\nconst TodayIndicator = styled.span `\n  position: absolute;\n  bottom: 5px;\n  left: 19px;\n  width: 5px;\n  height: 5px;\n  border-radius: 50%;\n  background: ${props => getTodayColor(props.isChosen, props.isInverse, props.theme)};\n`;\r\nexport const CalendarDay = (props) => {\r\n    const dayRef = React.useRef();\r\n    const { dateFocused, focusedDate, chosenDate, maxDate, minDate, onDateChange, setDateFocused, setFocusedDate, isInverse, } = React.useContext(CalendarContext);\r\n    const [focused, setFocused] = React.useState(false);\r\n    const { day } = props;\r\n    React.useEffect(() => {\r\n        if (dateFocused && isSameDay(day, focusedDate)) {\r\n            dayRef.current.focus();\r\n            setFocused(true);\r\n        }\r\n        else {\r\n            if (focused) {\r\n                setFocused(false);\r\n            }\r\n        }\r\n    }, [focusedDate, dateFocused]);\r\n    function onCalendarDayFocus() {\r\n        setDateFocused(true);\r\n    }\r\n    function onDayClick(event) {\r\n        if (disabled) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        onDateChange(day, event);\r\n    }\r\n    function onFocusDay(event) {\r\n        if (disabled || !isSameMonth(day, focusedDate)) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        setFocusedDate(day);\r\n    }\r\n    const disabled = (maxDate ? isAfter(props.day, maxDate) : false) ||\r\n        (minDate ? isBefore(props.day, minDate) : false);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    if (day) {\r\n        const sameDateAsFocusedDate = isSameDay(day, focusedDate);\r\n        const sameDateAsChosenDate = isSameDay(day, chosenDate);\r\n        const sameDateAsToday = isSameDay(day, new Date());\r\n        const isDayInCurrentMonth = isSameMonth(day, focusedDate);\r\n        const locale = i18n.locale || enUS;\r\n        const ariaLabel = `${disabled ? i18n.datePicker.disabledDayAriaLabel : ''} ${format(day, 'EEEE, MMMM do yyyy', locale)} ${sameDateAsToday ? i18n.datePicker.todayAriaLabel : ''} ${sameDateAsChosenDate ? i18n.datePicker.selectedDayAriaLabel : ''}`;\r\n        const dayState = {\r\n            isChosen: sameDateAsChosenDate,\r\n            disabled,\r\n            isDayInCurrentMonth,\r\n            isToday: sameDateAsToday,\r\n        };\r\n        return (React.createElement(CalendarDayCell, { onFocus: onCalendarDayFocus, isInverse: isInverse, theme: theme },\r\n            React.createElement(CalendarDayInner, { \"aria-disabled\": disabled, \"aria-label\": ariaLabel, \"aria-current\": sameDateAsToday ? 'date' : undefined, \"aria-selected\": sameDateAsChosenDate, \"data-testid\": \"calendar-day\", state: dayState, isInverse: isInverse, onClick: onDayClick, onMouseDown: onFocusDay, ref: dayRef, tabIndex: sameDateAsFocusedDate ? 0 : -1, type: \"button\", theme: theme }, format(day, 'd', locale)),\r\n            sameDateAsToday && (React.createElement(TodayIndicator, { \"data-testid\": \"todayIndicator\", isInverse: isInverse, isChosen: sameDateAsChosenDate, theme: theme }))));\r\n    }\r\n    else {\r\n        return React.createElement(EmptyCell, null);\r\n    }\r\n};\r\n//# sourceMappingURL=CalendarDay.js.map"]} */",
|
|
6973
|
+
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"]} */",
|
|
6953
6974
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$g
|
|
6954
6975
|
});
|
|
6955
6976
|
var TodayIndicator = /*#__PURE__*/_styled("span", {
|
|
@@ -6957,7 +6978,7 @@ var TodayIndicator = /*#__PURE__*/_styled("span", {
|
|
|
6957
6978
|
label: "TodayIndicator"
|
|
6958
6979
|
})("position:absolute;bottom:5px;left:19px;width:5px;height:5px;border-radius:50%;background:", function (props) {
|
|
6959
6980
|
return getTodayColor(props.isChosen, props.isInverse, props.theme);
|
|
6960
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarDay.tsx"],"names":[],"mappings":"AA+HmC","file":"CalendarDay.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { isAfter, isBefore, isSameDay, isSameMonth } from 'date-fns';\r\nimport { enUS } from 'date-fns/locale';\r\nimport { transparentize } from 'polished';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { i18nFormat as format } from './utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nfunction getCalendarDayBackground(isInverse, isChosen, theme) {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.tertiary : theme.colors.primary;\r\n    }\r\n    return isChosen ? theme.colors.primary : theme.colors.neutral100;\r\n}\r\nconst getTodayColor = (isChosen, isInverse, theme) => {\r\n    if (isInverse) {\r\n        return isChosen ? theme.colors.primary600 : theme.colors.secondary500;\r\n    }\r\n    return isChosen ? theme.colors.neutral100 : theme.colors.primary500;\r\n};\r\nconst getChosenDayColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral100;\r\n};\r\nconst getDisabledColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.6, theme.colors.neutral100)\r\n        : transparentize(0.4, theme.colors.neutral500);\r\n};\r\nconst getNotCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse\r\n        ? transparentize(0.3, theme.colors.neutral100)\r\n        : theme.colors.neutral500;\r\n};\r\nconst getCurrentMonthColor = (isInverse, theme) => {\r\n    return isInverse ? theme.colors.neutral100 : theme.colors.neutral700;\r\n};\r\nconst getCalendarDayColor = (state, isInverse, theme) => {\r\n    if (state.isToday)\r\n        return getTodayColor(state.isChosen, isInverse, theme);\r\n    if (state.disabled)\r\n        return getDisabledColor(isInverse, theme);\r\n    if (state.isChosen)\r\n        return getChosenDayColor(isInverse, theme);\r\n    if (!state.isDayInCurrentMonth && !state.disabled)\r\n        return getNotCurrentMonthColor(isInverse, theme);\r\n    return getCurrentMonthColor(isInverse, theme);\r\n};\r\nfunction getChosenDayBorder(isInverse, isChosen, theme) {\r\n    if (isChosen) {\r\n        return `1px solid ${isInverse ? theme.colors.primary600 : theme.colors.neutral100}`;\r\n    }\r\n}\r\nfunction getChosenDayHover(isChosen, isInverse, theme) {\r\n    if (isChosen) {\r\n        return isInverse ? theme.colors.neutral200 : theme.colors.primary600;\r\n    }\r\n    return isInverse ? theme.colors.primary600 : theme.colors.neutral200;\r\n}\r\nconst getCalendarDayFontSize = (state) => {\r\n    if (state.isToday)\r\n        return 700;\r\n    return !state.isDayInCurrentMonth || state.disabled ? 400 : 500;\r\n};\r\nconst CalendarDayCell = styled.td `\n  color: ${props => props.isInverse ? props.theme.colors.danger : props.theme.colors.neutral};\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  height: ${props => props.theme.spaceScale.spacing09};\n  padding: 0;\n  position: relative;\n  text-align: center;\n`;\r\nconst CalendarDayInner = styled.button `\n  align-items: center;\n  background: ${props => getCalendarDayBackground(props.isInverse, props.state.isChosen, props.theme)};\n  border: 2px solid transparent;\n  color: ${props => getCalendarDayColor(props.state, props.isInverse, props.theme)};\n  font-weight: ${props => getCalendarDayFontSize(props.state)};\n  cursor: ${props => (props.state.disabled ? 'not-allowed' : 'pointer')};\n  display: flex;\n  height: ${props => props.theme.spaceScale.spacing09};\n  justify-content: center;\n  overflow: hidden;\n  outline-offset: 0;\n  position: relative;\n  transition: background 0.5s ease-in-out 0s;\n  width: 43px;\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    border: ${props => getChosenDayBorder(props.isInverse, props.state.isChosen, props.theme)};\n    width: ${props => props.theme.spaceScale.spacing09};\n    height: 36px;\n    margin: 1px;\n  }\n\n  &:before {\n    background: ${props => props.isInverse\r\n    ? props.theme.colors.danger200\r\n    : props.theme.colors.neutral};\n    content: '';\n    height: 200%;\n    left: 0;\n    opacity: 0;\n    position: absolute;\n    top: -50%;\n    transition: 0.2s;\n    width: 200%;\n  }\n\n  &:hover {\n    &:before {\n      opacity: ${props => (props.state.disabled ? 0 : 0.1)};\n    }\n    border: none;\n    background: ${props => getChosenDayHover(props.state.isChosen, props.isInverse, props.theme)};\n  }\n`;\r\nconst EmptyCell = styled.td `\n  border: 0;\n  padding: 0;\n`;\r\nconst TodayIndicator = styled.span `\n  position: absolute;\n  bottom: 5px;\n  left: 19px;\n  width: 5px;\n  height: 5px;\n  border-radius: 50%;\n  background: ${props => getTodayColor(props.isChosen, props.isInverse, props.theme)};\n`;\r\nexport const CalendarDay = (props) => {\r\n    const dayRef = React.useRef();\r\n    const { dateFocused, focusedDate, chosenDate, maxDate, minDate, onDateChange, setDateFocused, setFocusedDate, isInverse, } = React.useContext(CalendarContext);\r\n    const [focused, setFocused] = React.useState(false);\r\n    const { day } = props;\r\n    React.useEffect(() => {\r\n        if (dateFocused && isSameDay(day, focusedDate)) {\r\n            dayRef.current.focus();\r\n            setFocused(true);\r\n        }\r\n        else {\r\n            if (focused) {\r\n                setFocused(false);\r\n            }\r\n        }\r\n    }, [focusedDate, dateFocused]);\r\n    function onCalendarDayFocus() {\r\n        setDateFocused(true);\r\n    }\r\n    function onDayClick(event) {\r\n        if (disabled) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        onDateChange(day, event);\r\n    }\r\n    function onFocusDay(event) {\r\n        if (disabled || !isSameMonth(day, focusedDate)) {\r\n            event.preventDefault();\r\n            return;\r\n        }\r\n        setFocusedDate(day);\r\n    }\r\n    const disabled = (maxDate ? isAfter(props.day, maxDate) : false) ||\r\n        (minDate ? isBefore(props.day, minDate) : false);\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    if (day) {\r\n        const sameDateAsFocusedDate = isSameDay(day, focusedDate);\r\n        const sameDateAsChosenDate = isSameDay(day, chosenDate);\r\n        const sameDateAsToday = isSameDay(day, new Date());\r\n        const isDayInCurrentMonth = isSameMonth(day, focusedDate);\r\n        const locale = i18n.locale || enUS;\r\n        const ariaLabel = `${disabled ? i18n.datePicker.disabledDayAriaLabel : ''} ${format(day, 'EEEE, MMMM do yyyy', locale)} ${sameDateAsToday ? i18n.datePicker.todayAriaLabel : ''} ${sameDateAsChosenDate ? i18n.datePicker.selectedDayAriaLabel : ''}`;\r\n        const dayState = {\r\n            isChosen: sameDateAsChosenDate,\r\n            disabled,\r\n            isDayInCurrentMonth,\r\n            isToday: sameDateAsToday,\r\n        };\r\n        return (React.createElement(CalendarDayCell, { onFocus: onCalendarDayFocus, isInverse: isInverse, theme: theme },\r\n            React.createElement(CalendarDayInner, { \"aria-disabled\": disabled, \"aria-label\": ariaLabel, \"aria-current\": sameDateAsToday ? 'date' : undefined, \"aria-selected\": sameDateAsChosenDate, \"data-testid\": \"calendar-day\", state: dayState, isInverse: isInverse, onClick: onDayClick, onMouseDown: onFocusDay, ref: dayRef, tabIndex: sameDateAsFocusedDate ? 0 : -1, type: \"button\", theme: theme }, format(day, 'd', locale)),\r\n            sameDateAsToday && (React.createElement(TodayIndicator, { \"data-testid\": \"todayIndicator\", isInverse: isInverse, isChosen: sameDateAsChosenDate, theme: theme }))));\r\n    }\r\n    else {\r\n        return React.createElement(EmptyCell, null);\r\n    }\r\n};\r\n//# sourceMappingURL=CalendarDay.js.map"]} */"));
|
|
6981
|
+
}, ";" + ( "/*# 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"]} */"));
|
|
6961
6982
|
var CalendarDay = function CalendarDay(props) {
|
|
6962
6983
|
var dayRef = React.useRef();
|
|
6963
6984
|
var _React$useContext = React.useContext(CalendarContext),
|
|
@@ -7027,6 +7048,7 @@ var CalendarDay = function CalendarDay(props) {
|
|
|
7027
7048
|
"aria-current": sameDateAsToday ? 'date' : undefined,
|
|
7028
7049
|
"aria-selected": sameDateAsChosenDate,
|
|
7029
7050
|
"data-testid": "calendar-day",
|
|
7051
|
+
disabled: disabled,
|
|
7030
7052
|
state: dayState,
|
|
7031
7053
|
isInverse: isInverse,
|
|
7032
7054
|
onClick: onDayClick,
|
|
@@ -7046,6 +7068,108 @@ var CalendarDay = function CalendarDay(props) {
|
|
|
7046
7068
|
}
|
|
7047
7069
|
};
|
|
7048
7070
|
|
|
7071
|
+
var StyledSelect = /*#__PURE__*/_styled("div", {
|
|
7072
|
+
target: "e184pa9z0",
|
|
7073
|
+
label: "StyledSelect"
|
|
7074
|
+
})("div>div{border:none;background:", function (props) {
|
|
7075
|
+
return props.isInverse ? props.theme.colors.primary500 : props.theme.colors.neutral100;
|
|
7076
|
+
}, ";&:focus-within{outline:2px solid ", function (props) {
|
|
7077
|
+
return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
|
|
7078
|
+
}, ";outline-offset:", function (props) {
|
|
7079
|
+
return props.theme.spaceScale.spacing01;
|
|
7080
|
+
}, ";}select{padding:", function (props) {
|
|
7081
|
+
return props.theme.spaceScale.spacing03;
|
|
7082
|
+
}, ";&:hover,&:focus{background:", function (props) {
|
|
7083
|
+
return props.isInverse ? polished.transparentize(0.3, props.theme.colors.primary700) : polished.transparentize(0.95, props.theme.colors.neutral900);
|
|
7084
|
+
}, ";cursor:pointer!important;}}svg{display:none;}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN0eWxlZFNlbGVjdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRXVDIiwiZmlsZSI6IlN0eWxlZFNlbGVjdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IHRyYW5zcGFyZW50aXplIH0gZnJvbSAncG9saXNoZWQnO1xyXG5leHBvcnQgY29uc3QgU3R5bGVkU2VsZWN0ID0gc3R5bGVkLmRpdiBgXG4gIGRpdiA+IGRpdiB7XG4gICAgYm9yZGVyOiBub25lO1xuICAgIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5NTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgICAmOmZvY3VzLXdpdGhpbiB7XG4gICAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICAgJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuICAgICAgb3V0bGluZS1vZmZzZXQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDF9O1xuICAgIH1cblxuICAgIHNlbGVjdCB7XG4gICAgICBwYWRkaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfTtcbiAgICAgICY6aG92ZXIsXG4gICAgICAmOmZvY3VzIHtcbiAgICAgICAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gdHJhbnNwYXJlbnRpemUoMC4zLCBwcm9wcy50aGVtZS5jb2xvcnMucHJpbWFyeTcwMClcclxuICAgIDogdHJhbnNwYXJlbnRpemUoMC45NSwgcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw5MDApfTtcbiAgICAgICAgY3Vyc29yOiBwb2ludGVyICFpbXBvcnRhbnQ7XG4gICAgICB9XG4gICAgfVxuXG4gICAgc3ZnIHtcbiAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxuICB9XG5gO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1TdHlsZWRTZWxlY3QuanMubWFwIl19 */"));
|
|
7085
|
+
|
|
7086
|
+
var MonthPicker = function MonthPicker(props) {
|
|
7087
|
+
var currentMonth = props.currentMonth,
|
|
7088
|
+
isInverse = props.isInverse;
|
|
7089
|
+
var _React$useContext = React.useContext(CalendarContext),
|
|
7090
|
+
setMonthFocusedDate = _React$useContext.setMonthFocusedDate;
|
|
7091
|
+
var i18n = React.useContext(I18nContext);
|
|
7092
|
+
var monthsLabels = i18n.months["long"];
|
|
7093
|
+
var theme = React.useContext(ThemeContext);
|
|
7094
|
+
var months = Object.values(monthsLabels).map(function (label, value) {
|
|
7095
|
+
return {
|
|
7096
|
+
label: label,
|
|
7097
|
+
value: value
|
|
7098
|
+
};
|
|
7099
|
+
});
|
|
7100
|
+
var getNumberMonthByLabel = function getNumberMonthByLabel(label) {
|
|
7101
|
+
var _months$find;
|
|
7102
|
+
return (_months$find = months.find(function (month) {
|
|
7103
|
+
return month.label === label;
|
|
7104
|
+
})) == null ? void 0 : _months$find.value;
|
|
7105
|
+
};
|
|
7106
|
+
function onMonthChange(month) {
|
|
7107
|
+
setMonthFocusedDate(month);
|
|
7108
|
+
}
|
|
7109
|
+
return React.createElement(StyledSelect, {
|
|
7110
|
+
isInverse: isInverse,
|
|
7111
|
+
theme: theme
|
|
7112
|
+
}, React.createElement(NativeSelect, {
|
|
7113
|
+
"aria-label": currentMonth + ". " + i18n.datePicker.selectMonth,
|
|
7114
|
+
"data-testid": "month-picker",
|
|
7115
|
+
fieldId: '',
|
|
7116
|
+
onChange: function onChange(e) {
|
|
7117
|
+
return onMonthChange(Number(e.target.value));
|
|
7118
|
+
},
|
|
7119
|
+
value: getNumberMonthByLabel(currentMonth)
|
|
7120
|
+
}, months.map(function (month) {
|
|
7121
|
+
return React.createElement("option", {
|
|
7122
|
+
key: month.value,
|
|
7123
|
+
value: month.value
|
|
7124
|
+
}, month.label);
|
|
7125
|
+
})));
|
|
7126
|
+
};
|
|
7127
|
+
|
|
7128
|
+
var YearPicker = function YearPicker(props) {
|
|
7129
|
+
var currentYear = props.currentYear,
|
|
7130
|
+
isInverse = props.isInverse;
|
|
7131
|
+
var _React$useContext = React__default.useContext(CalendarContext),
|
|
7132
|
+
minDate = _React$useContext.minDate,
|
|
7133
|
+
maxDate = _React$useContext.maxDate;
|
|
7134
|
+
var minYear = minDate ? dateFns.getYear(minDate) : 1900;
|
|
7135
|
+
var maxYear = maxDate ? dateFns.getYear(maxDate) : 2099;
|
|
7136
|
+
var theme = React__default.useContext(ThemeContext);
|
|
7137
|
+
var _React$useContext2 = React__default.useContext(CalendarContext),
|
|
7138
|
+
setYearFocusedDate = _React$useContext2.setYearFocusedDate;
|
|
7139
|
+
var i18n = React__default.useContext(I18nContext);
|
|
7140
|
+
var visibleYears = Array.from({
|
|
7141
|
+
length: maxYear - minYear + 1
|
|
7142
|
+
}, function (_, i) {
|
|
7143
|
+
return minYear + i;
|
|
7144
|
+
});
|
|
7145
|
+
var years = visibleYears.map(function (year) {
|
|
7146
|
+
return {
|
|
7147
|
+
label: String(year),
|
|
7148
|
+
value: year
|
|
7149
|
+
};
|
|
7150
|
+
});
|
|
7151
|
+
function onYearChange(year) {
|
|
7152
|
+
setYearFocusedDate(year);
|
|
7153
|
+
}
|
|
7154
|
+
return React__default.createElement(StyledSelect, {
|
|
7155
|
+
isInverse: isInverse,
|
|
7156
|
+
theme: theme
|
|
7157
|
+
}, React__default.createElement(NativeSelect, {
|
|
7158
|
+
"aria-label": currentYear + ". " + i18n.datePicker.selectYear,
|
|
7159
|
+
"data-testid": "year-picker",
|
|
7160
|
+
fieldId: '',
|
|
7161
|
+
onChange: function onChange(e) {
|
|
7162
|
+
return onYearChange(Number(e.target.value));
|
|
7163
|
+
},
|
|
7164
|
+
value: currentYear
|
|
7165
|
+
}, years.map(function (year) {
|
|
7166
|
+
return React__default.createElement("option", {
|
|
7167
|
+
key: year.value,
|
|
7168
|
+
value: year.value
|
|
7169
|
+
}, year.label);
|
|
7170
|
+
})));
|
|
7171
|
+
};
|
|
7172
|
+
|
|
7049
7173
|
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)."; }
|
|
7050
7174
|
var CalendarHeaderContainer = /*#__PURE__*/_styled("div", {
|
|
7051
7175
|
target: "eg9fn2d3",
|
|
@@ -7054,9 +7178,7 @@ var CalendarHeaderContainer = /*#__PURE__*/_styled("div", {
|
|
|
7054
7178
|
return props.theme.spaceScale.spacing03;
|
|
7055
7179
|
}, " 0 ", function (props) {
|
|
7056
7180
|
return props.theme.spaceScale.spacing03;
|
|
7057
|
-
}, " "
|
|
7058
|
-
return props.theme.spaceScale.spacing03;
|
|
7059
|
-
}, ";justify-content:space-between;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFySGVhZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFhMkMiLCJmaWxlIjoiQ2FsZW5kYXJIZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IGFkZE1vbnRocywgc3ViTW9udGhzIH0gZnJvbSAnZGF0ZS1mbnMnO1xyXG5pbXBvcnQgeyBlblVTIH0gZnJvbSAnZGF0ZS1mbnMvbG9jYWxlJztcclxuaW1wb3J0IHsgS2V5Ym9hcmRBcnJvd0xlZnRJY29uLCBLZXlib2FyZEFycm93UmlnaHRJY29uLCB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHsgQW5ub3VuY2UgfSBmcm9tICcuLi9Bbm5vdW5jZSc7XHJcbmltcG9ydCB7IENhbGVuZGFyQ29udGV4dCB9IGZyb20gJy4vQ2FsZW5kYXJDb250ZXh0JztcclxuaW1wb3J0IHsgaTE4bkZvcm1hdCBhcyBmb3JtYXQgfSBmcm9tICcuL3V0aWxzJztcclxuaW1wb3J0IHsgSTE4bkNvbnRleHQgfSBmcm9tICcuLi8uLi9pMThuJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlRm9ya2VkUmVmLCB1c2VQcmV2aW91cyB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuaW1wb3J0IHsgQnV0dG9uQ29sb3IsIEJ1dHRvblR5cGUsIEJ1dHRvblZhcmlhbnQgfSBmcm9tICcuLi9CdXR0b24nO1xyXG5pbXBvcnQgeyBJY29uQnV0dG9uIH0gZnJvbSAnLi4vSWNvbkJ1dHRvbic7XHJcbmNvbnN0IENhbGVuZGFySGVhZGVyQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHBhZGRpbmc6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDBcbiAgICAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfVxuICAgICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5gO1xyXG5jb25zdCBDYWxlbmRhckhlYWRlclRleHQgPSBzdHlsZWQuZGl2IGBcbiAgY2FwdGlvbi1zaWRlOiBpbml0aWFsO1xuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw3MDB9O1xuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5mb250U2l6ZX07XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMubGluZUhlaWdodH07XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7IFxuICBmb250LXdlaWdodDogNjAwOyBcbiAgXG4gICY6Zm9jdXMge1xuICAgIG91dGxpbmU6IDJweCBzb2xpZFxuICAgICAgJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzSW52ZXJzZVxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMuZm9jdXN9O1xuYDtcclxuY29uc3QgTW9udGhZZWFyV3JhcHBlciA9IHN0eWxlZC5zcGFuIGBcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGdhcDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG5gO1xyXG5jb25zdCBOYXZpZ2F0aW9uV3JhcHBlciA9IHN0eWxlZC5zcGFuIGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IHJvdztcbmA7XHJcbmV4cG9ydCBjb25zdCBDYWxlbmRhckhlYWRlciA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCBmb3J3YXJkZWRSZWYpID0+IHtcclxuICAgIGNvbnN0IGNhbGVuZGFySGVhZGVyID0gUmVhY3QudXNlUmVmKCk7XHJcbiAgICBjb25zdCB7IGZvY3VzZWREYXRlLCBvblByZXZNb250aENsaWNrLCBvbk5leHRNb250aENsaWNrIH0gPSBSZWFjdC51c2VDb250ZXh0KENhbGVuZGFyQ29udGV4dCk7XHJcbiAgICBjb25zdCBwcmV2Rm9jdXNIZWFkZXIgPSB1c2VQcmV2aW91cyhwcm9wcy5mb2N1c0hlYWRlcik7XHJcbiAgICBjb25zdCByZWYgPSB1c2VGb3JrZWRSZWYoZm9yd2FyZGVkUmVmLCBjYWxlbmRhckhlYWRlcik7XHJcbiAgICBSZWFjdC51c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIGlmICghcHJldkZvY3VzSGVhZGVyICYmIHByb3BzLmZvY3VzSGVhZGVyKSB7XHJcbiAgICAgICAgICAgIGNhbGVuZGFySGVhZGVyLmN1cnJlbnQuZm9jdXMoKTtcclxuICAgICAgICB9XHJcbiAgICB9LCBbcHJvcHMuZm9jdXNIZWFkZXJdKTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgaTE4biA9IFJlYWN0LnVzZUNvbnRleHQoSTE4bkNvbnRleHQpO1xyXG4gICAgY29uc3QgbG9jYWxlID0gaTE4bi5sb2NhbGUgfHwgZW5VUztcclxuICAgIGNvbnN0IGN1cnJlbnRNb250aCA9IGZvcm1hdChmb2N1c2VkRGF0ZSwgJ01NTU0geXl5eScsIGxvY2FsZSk7XHJcbiAgICBjb25zdCBjYXBpdGFsaXplQ3VycmVudE1vbnRoID0gY3VycmVudE1vbnRoICYmXHJcbiAgICAgICAgY3VycmVudE1vbnRoLmNoYXJBdCgwKS50b1VwcGVyQ2FzZSgpICsgY3VycmVudE1vbnRoLnNsaWNlKDEpO1xyXG4gICAgY29uc3QgW21vbnRoLCB5ZWFyXSA9IGNhcGl0YWxpemVDdXJyZW50TW9udGhcclxuICAgICAgICA/IGNhcGl0YWxpemVDdXJyZW50TW9udGguc3BsaXQoJyAnKVxyXG4gICAgICAgIDogWycnLCAnJ107XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2FsZW5kYXJIZWFkZXJDb250YWluZXIsIHsgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChDYWxlbmRhckhlYWRlclRleHQsIHsgXCJkYXRhLXRlc3RpZFwiOiBcImNhbGVuZGFyLWhlYWRlclwiLCB0YWJJbmRleDogLTEsIHRoZW1lOiB0aGVtZSwgcmVmOiByZWYsIGlzSW52ZXJzZTogcHJvcHMuaXNJbnZlcnNlIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQW5ub3VuY2UsIG51bGwsXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KE1vbnRoWWVhcldyYXBwZXIsIHsgdGhlbWU6IHRoZW1lIH0sXHJcbiAgICAgICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChcInNwYW5cIiwgbnVsbCwgbW9udGgpLFxyXG4gICAgICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJzcGFuXCIsIG51bGwsIHllYXIpKSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTmF2aWdhdGlvbldyYXBwZXIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSWNvbkJ1dHRvbiwgeyBcImFyaWEtbGFiZWxcIjogYCR7aTE4bi5kYXRlUGlja2VyLnByZXZpb3VzTW9udGhBcmlhTGFiZWx9ICR7Zm9ybWF0KHN1Yk1vbnRocyhuZXcgRGF0ZShmb2N1c2VkRGF0ZSksIDEpLCAnTU1NTSB5eXl5JywgbG9jYWxlKX1gLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBpY29uOiBSZWFjdC5jcmVhdGVFbGVtZW50KEtleWJvYXJkQXJyb3dMZWZ0SWNvbiwgbnVsbCksIHR5cGU6IEJ1dHRvblR5cGUuYnV0dG9uLCB2YXJpYW50OiBCdXR0b25WYXJpYW50LmxpbmssIG9uQ2xpY2s6IG9uUHJldk1vbnRoQ2xpY2ssIHN0eWxlOiB7IG1hcmdpblJpZ2h0OiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMiB9IH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb25CdXR0b24sIHsgXCJhcmlhLWxhYmVsXCI6IGAke2kxOG4uZGF0ZVBpY2tlci5uZXh0TW9udGhBcmlhTGFiZWx9ICR7Zm9ybWF0KGFkZE1vbnRocyhuZXcgRGF0ZShmb2N1c2VkRGF0ZSksIDEpLCAnTU1NTSB5eXl5JywgbG9jYWxlKX1gLCBpY29uOiBSZWFjdC5jcmVhdGVFbGVtZW50KEtleWJvYXJkQXJyb3dSaWdodEljb24sIG51bGwpLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCB0eXBlOiBCdXR0b25UeXBlLmJ1dHRvbiwgdmFyaWFudDogQnV0dG9uVmFyaWFudC5saW5rLCBvbkNsaWNrOiBvbk5leHRNb250aENsaWNrLCBzdHlsZTogeyBtYXJnaW5MZWZ0OiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMiB9IH0pKSkpO1xyXG59KTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q2FsZW5kYXJIZWFkZXIuanMubWFwIl19 */"));
|
|
7181
|
+
}, " 0;justify-content:space-between;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFySGVhZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjMkMiLCJmaWxlIjoiQ2FsZW5kYXJIZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IGFkZE1vbnRocywgc3ViTW9udGhzIH0gZnJvbSAnZGF0ZS1mbnMnO1xyXG5pbXBvcnQgeyBlblVTIH0gZnJvbSAnZGF0ZS1mbnMvbG9jYWxlJztcclxuaW1wb3J0IHsgS2V5Ym9hcmRBcnJvd0xlZnRJY29uLCBLZXlib2FyZEFycm93UmlnaHRJY29uLCB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHsgQW5ub3VuY2UgfSBmcm9tICcuLi9Bbm5vdW5jZSc7XHJcbmltcG9ydCB7IENhbGVuZGFyQ29udGV4dCB9IGZyb20gJy4vQ2FsZW5kYXJDb250ZXh0JztcclxuaW1wb3J0IHsgaTE4bkZvcm1hdCBhcyBmb3JtYXQsIGdldEN1cnJlbnRNb250aEFuZFllYXIgfSBmcm9tICcuL3V0aWxzJztcclxuaW1wb3J0IHsgSTE4bkNvbnRleHQgfSBmcm9tICcuLi8uLi9pMThuJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgQnV0dG9uQ29sb3IsIEJ1dHRvblR5cGUsIEJ1dHRvblZhcmlhbnQgfSBmcm9tICcuLi9CdXR0b24nO1xyXG5pbXBvcnQgeyBJY29uQnV0dG9uIH0gZnJvbSAnLi4vSWNvbkJ1dHRvbic7XHJcbmltcG9ydCB7IE1vbnRoUGlja2VyIH0gZnJvbSAnLi9Nb250aFBpY2tlcic7XHJcbmltcG9ydCB7IFllYXJQaWNrZXIgfSBmcm9tICcuL1llYXJQaWNrZXInO1xyXG5jb25zdCBDYWxlbmRhckhlYWRlckNvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwXG4gICAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMDtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuYDtcclxuY29uc3QgQ2FsZW5kYXJIZWFkZXJUZXh0ID0gc3R5bGVkLmRpdiBgXG4gIGNhcHRpb24tc2lkZTogaW5pdGlhbDtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMuZm9udFNpemV9O1xuICBsaW5lLWhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmxpbmVIZWlnaHR9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBmb250LXdlaWdodDogNjAwO1xuXG4gICY6Zm9jdXMge1xuICAgIG91dGxpbmU6IG5vbmU7XG4gIH1cbmA7XHJcbmNvbnN0IE1vbnRoWWVhcldyYXBwZXIgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZ2FwOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfTtcbmA7XHJcbmNvbnN0IE5hdmlnYXRpb25XcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiByb3c7XG5gO1xyXG5leHBvcnQgY29uc3QgQ2FsZW5kYXJIZWFkZXIgPSBwcm9wcyA9PiB7XHJcbiAgICBjb25zdCB7IGZvY3VzZWREYXRlLCBvblByZXZNb250aENsaWNrLCBvbk5leHRNb250aENsaWNrIH0gPSBSZWFjdC51c2VDb250ZXh0KENhbGVuZGFyQ29udGV4dCk7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGkxOG4gPSBSZWFjdC51c2VDb250ZXh0KEkxOG5Db250ZXh0KTtcclxuICAgIGNvbnN0IGxvY2FsZSA9IGkxOG4ubG9jYWxlIHx8IGVuVVM7XHJcbiAgICBjb25zdCBtb250aEFuZFllYXIgPSBnZXRDdXJyZW50TW9udGhBbmRZZWFyKGZvY3VzZWREYXRlLCBsb2NhbGUpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KENhbGVuZGFySGVhZGVyQ29udGFpbmVyLCB7IHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2FsZW5kYXJIZWFkZXJUZXh0LCB7IHRhYkluZGV4OiAtMSwgdGhlbWU6IHRoZW1lLCBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEFubm91bmNlLCBudWxsLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChNb250aFllYXJXcmFwcGVyLCB7IHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTW9udGhQaWNrZXIsIHsgY3VycmVudE1vbnRoOiBtb250aEFuZFllYXIubW9udGgsIGlzSW52ZXJzZTogcHJvcHMuaXNJbnZlcnNlIH0pLFxyXG4gICAgICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoWWVhclBpY2tlciwgeyBjdXJyZW50WWVhcjogTnVtYmVyKG1vbnRoQW5kWWVhci55ZWFyKSwgaXNJbnZlcnNlOiBwcm9wcy5pc0ludmVyc2UgfSkpKSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChOYXZpZ2F0aW9uV3JhcHBlciwgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJY29uQnV0dG9uLCB7IFwiYXJpYS1sYWJlbFwiOiBgJHtpMThuLmRhdGVQaWNrZXIucHJldmlvdXNNb250aEFyaWFMYWJlbH0gJHtmb3JtYXQoc3ViTW9udGhzKG5ldyBEYXRlKGZvY3VzZWREYXRlKSwgMSksICdNTU1NIHl5eXknLCBsb2NhbGUpfWAsIGNvbG9yOiBCdXR0b25Db2xvci5zdWJ0bGUsIGljb246IFJlYWN0LmNyZWF0ZUVsZW1lbnQoS2V5Ym9hcmRBcnJvd0xlZnRJY29uLCBudWxsKSwgdHlwZTogQnV0dG9uVHlwZS5idXR0b24sIHZhcmlhbnQ6IEJ1dHRvblZhcmlhbnQubGluaywgb25DbGljazogb25QcmV2TW9udGhDbGljaywgc3R5bGU6IHsgbWFyZ2luUmlnaHQ6IHRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAyIH0gfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSWNvbkJ1dHRvbiwgeyBcImFyaWEtbGFiZWxcIjogYCR7aTE4bi5kYXRlUGlja2VyLm5leHRNb250aEFyaWFMYWJlbH0gJHtmb3JtYXQoYWRkTW9udGhzKG5ldyBEYXRlKGZvY3VzZWREYXRlKSwgMSksICdNTU1NIHl5eXknLCBsb2NhbGUpfWAsIGljb246IFJlYWN0LmNyZWF0ZUVsZW1lbnQoS2V5Ym9hcmRBcnJvd1JpZ2h0SWNvbiwgbnVsbCksIGNvbG9yOiBCdXR0b25Db2xvci5zdWJ0bGUsIHR5cGU6IEJ1dHRvblR5cGUuYnV0dG9uLCB2YXJpYW50OiBCdXR0b25WYXJpYW50LmxpbmssIG9uQ2xpY2s6IG9uTmV4dE1vbnRoQ2xpY2ssIHN0eWxlOiB7IG1hcmdpbkxlZnQ6IHRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAyIH0gfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNhbGVuZGFySGVhZGVyLmpzLm1hcCJdfQ== */"));
|
|
7060
7182
|
var CalendarHeaderText = /*#__PURE__*/_styled("div", {
|
|
7061
7183
|
target: "eg9fn2d2",
|
|
7062
7184
|
label: "CalendarHeaderText"
|
|
@@ -7066,55 +7188,45 @@ var CalendarHeaderText = /*#__PURE__*/_styled("div", {
|
|
|
7066
7188
|
return props.theme.typeScale.size03.fontSize;
|
|
7067
7189
|
}, ";line-height:", function (props) {
|
|
7068
7190
|
return props.theme.typeScale.size03.lineHeight;
|
|
7069
|
-
}, ";text-align:center;justify-content:center;align-items:center;font-weight:600;&:focus{outline:
|
|
7070
|
-
|
|
7071
|
-
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFySGVhZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQnNDIiwiZmlsZSI6IkNhbGVuZGFySGVhZGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBhZGRNb250aHMsIHN1Yk1vbnRocyB9IGZyb20gJ2RhdGUtZm5zJztcclxuaW1wb3J0IHsgZW5VUyB9IGZyb20gJ2RhdGUtZm5zL2xvY2FsZSc7XHJcbmltcG9ydCB7IEtleWJvYXJkQXJyb3dMZWZ0SWNvbiwgS2V5Ym9hcmRBcnJvd1JpZ2h0SWNvbiwgfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBDYWxlbmRhckNvbnRleHQgfSBmcm9tICcuL0NhbGVuZGFyQ29udGV4dCc7XHJcbmltcG9ydCB7IGkxOG5Gb3JtYXQgYXMgZm9ybWF0IH0gZnJvbSAnLi91dGlscyc7XHJcbmltcG9ydCB7IEkxOG5Db250ZXh0IH0gZnJvbSAnLi4vLi4vaTE4bic7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IHVzZUZvcmtlZFJlZiwgdXNlUHJldmlvdXMgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IEJ1dHRvbkNvbG9yLCBCdXR0b25UeXBlLCBCdXR0b25WYXJpYW50IH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5jb25zdCBDYWxlbmRhckhlYWRlckNvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBkaXNwbGF5OiBmbGV4O1xuICBwYWRkaW5nOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfSAwXG4gICAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM31cbiAgICAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfTtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuYDtcclxuY29uc3QgQ2FsZW5kYXJIZWFkZXJUZXh0ID0gc3R5bGVkLmRpdiBgXG4gIGNhcHRpb24tc2lkZTogaW5pdGlhbDtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDMuZm9udFNpemV9O1xuICBsaW5lLWhlaWdodDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmxpbmVIZWlnaHR9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyOyBcbiAgZm9udC13ZWlnaHQ6IDYwMDsgXG4gIFxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c0ludmVyc2VcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzfTtcbmA7XHJcbmNvbnN0IE1vbnRoWWVhcldyYXBwZXIgPSBzdHlsZWQuc3BhbiBgXG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBnYXA6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuYDtcclxuY29uc3QgTmF2aWdhdGlvbldyYXBwZXIgPSBzdHlsZWQuc3BhbiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiByb3c7XG5gO1xyXG5leHBvcnQgY29uc3QgQ2FsZW5kYXJIZWFkZXIgPSBSZWFjdC5mb3J3YXJkUmVmKChwcm9wcywgZm9yd2FyZGVkUmVmKSA9PiB7XHJcbiAgICBjb25zdCBjYWxlbmRhckhlYWRlciA9IFJlYWN0LnVzZVJlZigpO1xyXG4gICAgY29uc3QgeyBmb2N1c2VkRGF0ZSwgb25QcmV2TW9udGhDbGljaywgb25OZXh0TW9udGhDbGljayB9ID0gUmVhY3QudXNlQ29udGV4dChDYWxlbmRhckNvbnRleHQpO1xyXG4gICAgY29uc3QgcHJldkZvY3VzSGVhZGVyID0gdXNlUHJldmlvdXMocHJvcHMuZm9jdXNIZWFkZXIpO1xyXG4gICAgY29uc3QgcmVmID0gdXNlRm9ya2VkUmVmKGZvcndhcmRlZFJlZiwgY2FsZW5kYXJIZWFkZXIpO1xyXG4gICAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBpZiAoIXByZXZGb2N1c0hlYWRlciAmJiBwcm9wcy5mb2N1c0hlYWRlcikge1xyXG4gICAgICAgICAgICBjYWxlbmRhckhlYWRlci5jdXJyZW50LmZvY3VzKCk7XHJcbiAgICAgICAgfVxyXG4gICAgfSwgW3Byb3BzLmZvY3VzSGVhZGVyXSk7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGkxOG4gPSBSZWFjdC51c2VDb250ZXh0KEkxOG5Db250ZXh0KTtcclxuICAgIGNvbnN0IGxvY2FsZSA9IGkxOG4ubG9jYWxlIHx8IGVuVVM7XHJcbiAgICBjb25zdCBjdXJyZW50TW9udGggPSBmb3JtYXQoZm9jdXNlZERhdGUsICdNTU1NIHl5eXknLCBsb2NhbGUpO1xyXG4gICAgY29uc3QgY2FwaXRhbGl6ZUN1cnJlbnRNb250aCA9IGN1cnJlbnRNb250aCAmJlxyXG4gICAgICAgIGN1cnJlbnRNb250aC5jaGFyQXQoMCkudG9VcHBlckNhc2UoKSArIGN1cnJlbnRNb250aC5zbGljZSgxKTtcclxuICAgIGNvbnN0IFttb250aCwgeWVhcl0gPSBjYXBpdGFsaXplQ3VycmVudE1vbnRoXHJcbiAgICAgICAgPyBjYXBpdGFsaXplQ3VycmVudE1vbnRoLnNwbGl0KCcgJylcclxuICAgICAgICA6IFsnJywgJyddO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KENhbGVuZGFySGVhZGVyQ29udGFpbmVyLCB7IHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2FsZW5kYXJIZWFkZXJUZXh0LCB7IFwiZGF0YS10ZXN0aWRcIjogXCJjYWxlbmRhci1oZWFkZXJcIiwgdGFiSW5kZXg6IC0xLCB0aGVtZTogdGhlbWUsIHJlZjogcmVmLCBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEFubm91bmNlLCBudWxsLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChNb250aFllYXJXcmFwcGVyLCB7IHRoZW1lOiB0aGVtZSB9LFxyXG4gICAgICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJzcGFuXCIsIG51bGwsIG1vbnRoKSxcclxuICAgICAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFwic3BhblwiLCBudWxsLCB5ZWFyKSkpKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KE5hdmlnYXRpb25XcmFwcGVyLCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb25CdXR0b24sIHsgXCJhcmlhLWxhYmVsXCI6IGAke2kxOG4uZGF0ZVBpY2tlci5wcmV2aW91c01vbnRoQXJpYUxhYmVsfSAke2Zvcm1hdChzdWJNb250aHMobmV3IERhdGUoZm9jdXNlZERhdGUpLCAxKSwgJ01NTU0geXl5eScsIGxvY2FsZSl9YCwgY29sb3I6IEJ1dHRvbkNvbG9yLnN1YnRsZSwgaWNvbjogUmVhY3QuY3JlYXRlRWxlbWVudChLZXlib2FyZEFycm93TGVmdEljb24sIG51bGwpLCB0eXBlOiBCdXR0b25UeXBlLmJ1dHRvbiwgdmFyaWFudDogQnV0dG9uVmFyaWFudC5saW5rLCBvbkNsaWNrOiBvblByZXZNb250aENsaWNrLCBzdHlsZTogeyBtYXJnaW5SaWdodDogdGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDIgfSB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJY29uQnV0dG9uLCB7IFwiYXJpYS1sYWJlbFwiOiBgJHtpMThuLmRhdGVQaWNrZXIubmV4dE1vbnRoQXJpYUxhYmVsfSAke2Zvcm1hdChhZGRNb250aHMobmV3IERhdGUoZm9jdXNlZERhdGUpLCAxKSwgJ01NTU0geXl5eScsIGxvY2FsZSl9YCwgaWNvbjogUmVhY3QuY3JlYXRlRWxlbWVudChLZXlib2FyZEFycm93UmlnaHRJY29uLCBudWxsKSwgY29sb3I6IEJ1dHRvbkNvbG9yLnN1YnRsZSwgdHlwZTogQnV0dG9uVHlwZS5idXR0b24sIHZhcmlhbnQ6IEJ1dHRvblZhcmlhbnQubGluaywgb25DbGljazogb25OZXh0TW9udGhDbGljaywgc3R5bGU6IHsgbWFyZ2luTGVmdDogdGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDIgfSB9KSkpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNhbGVuZGFySGVhZGVyLmpzLm1hcCJdfQ== */"));
|
|
7072
|
-
var MonthYearWrapper = /*#__PURE__*/_styled("span", {
|
|
7191
|
+
}, ";text-align:center;justify-content:center;align-items:center;font-weight:600;&:focus{outline:none;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFySGVhZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQnNDIiwiZmlsZSI6IkNhbGVuZGFySGVhZGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBhZGRNb250aHMsIHN1Yk1vbnRocyB9IGZyb20gJ2RhdGUtZm5zJztcclxuaW1wb3J0IHsgZW5VUyB9IGZyb20gJ2RhdGUtZm5zL2xvY2FsZSc7XHJcbmltcG9ydCB7IEtleWJvYXJkQXJyb3dMZWZ0SWNvbiwgS2V5Ym9hcmRBcnJvd1JpZ2h0SWNvbiwgfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBDYWxlbmRhckNvbnRleHQgfSBmcm9tICcuL0NhbGVuZGFyQ29udGV4dCc7XHJcbmltcG9ydCB7IGkxOG5Gb3JtYXQgYXMgZm9ybWF0LCBnZXRDdXJyZW50TW9udGhBbmRZZWFyIH0gZnJvbSAnLi91dGlscyc7XHJcbmltcG9ydCB7IEkxOG5Db250ZXh0IH0gZnJvbSAnLi4vLi4vaTE4bic7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEJ1dHRvbkNvbG9yLCBCdXR0b25UeXBlLCBCdXR0b25WYXJpYW50IH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBNb250aFBpY2tlciB9IGZyb20gJy4vTW9udGhQaWNrZXInO1xyXG5pbXBvcnQgeyBZZWFyUGlja2VyIH0gZnJvbSAnLi9ZZWFyUGlja2VyJztcclxuY29uc3QgQ2FsZW5kYXJIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMFxuICAgICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDA7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XHJcbmNvbnN0IENhbGVuZGFySGVhZGVyVGV4dCA9IHN0eWxlZC5kaXYgYFxuICBjYXB0aW9uLXNpZGU6IGluaXRpYWw7XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMH07XG4gIGZvbnQtc2l6ZTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmZvbnRTaXplfTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcblxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiBub25lO1xuICB9XG5gO1xyXG5jb25zdCBNb250aFllYXJXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG5gO1xyXG5jb25zdCBOYXZpZ2F0aW9uV3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogcm93O1xuYDtcclxuZXhwb3J0IGNvbnN0IENhbGVuZGFySGVhZGVyID0gcHJvcHMgPT4ge1xyXG4gICAgY29uc3QgeyBmb2N1c2VkRGF0ZSwgb25QcmV2TW9udGhDbGljaywgb25OZXh0TW9udGhDbGljayB9ID0gUmVhY3QudXNlQ29udGV4dChDYWxlbmRhckNvbnRleHQpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpMThuID0gUmVhY3QudXNlQ29udGV4dChJMThuQ29udGV4dCk7XHJcbiAgICBjb25zdCBsb2NhbGUgPSBpMThuLmxvY2FsZSB8fCBlblVTO1xyXG4gICAgY29uc3QgbW9udGhBbmRZZWFyID0gZ2V0Q3VycmVudE1vbnRoQW5kWWVhcihmb2N1c2VkRGF0ZSwgbG9jYWxlKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChDYWxlbmRhckhlYWRlckNvbnRhaW5lciwgeyB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KENhbGVuZGFySGVhZGVyVGV4dCwgeyB0YWJJbmRleDogLTEsIHRoZW1lOiB0aGVtZSwgaXNJbnZlcnNlOiBwcm9wcy5pc0ludmVyc2UgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChBbm5vdW5jZSwgbnVsbCxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTW9udGhZZWFyV3JhcHBlciwgeyB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KE1vbnRoUGlja2VyLCB7IGN1cnJlbnRNb250aDogbW9udGhBbmRZZWFyLm1vbnRoLCBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSB9KSxcclxuICAgICAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFllYXJQaWNrZXIsIHsgY3VycmVudFllYXI6IE51bWJlcihtb250aEFuZFllYXIueWVhciksIGlzSW52ZXJzZTogcHJvcHMuaXNJbnZlcnNlIH0pKSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTmF2aWdhdGlvbldyYXBwZXIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSWNvbkJ1dHRvbiwgeyBcImFyaWEtbGFiZWxcIjogYCR7aTE4bi5kYXRlUGlja2VyLnByZXZpb3VzTW9udGhBcmlhTGFiZWx9ICR7Zm9ybWF0KHN1Yk1vbnRocyhuZXcgRGF0ZShmb2N1c2VkRGF0ZSksIDEpLCAnTU1NTSB5eXl5JywgbG9jYWxlKX1gLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBpY29uOiBSZWFjdC5jcmVhdGVFbGVtZW50KEtleWJvYXJkQXJyb3dMZWZ0SWNvbiwgbnVsbCksIHR5cGU6IEJ1dHRvblR5cGUuYnV0dG9uLCB2YXJpYW50OiBCdXR0b25WYXJpYW50LmxpbmssIG9uQ2xpY2s6IG9uUHJldk1vbnRoQ2xpY2ssIHN0eWxlOiB7IG1hcmdpblJpZ2h0OiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMiB9IH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb25CdXR0b24sIHsgXCJhcmlhLWxhYmVsXCI6IGAke2kxOG4uZGF0ZVBpY2tlci5uZXh0TW9udGhBcmlhTGFiZWx9ICR7Zm9ybWF0KGFkZE1vbnRocyhuZXcgRGF0ZShmb2N1c2VkRGF0ZSksIDEpLCAnTU1NTSB5eXl5JywgbG9jYWxlKX1gLCBpY29uOiBSZWFjdC5jcmVhdGVFbGVtZW50KEtleWJvYXJkQXJyb3dSaWdodEljb24sIG51bGwpLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCB0eXBlOiBCdXR0b25UeXBlLmJ1dHRvbiwgdmFyaWFudDogQnV0dG9uVmFyaWFudC5saW5rLCBvbkNsaWNrOiBvbk5leHRNb250aENsaWNrLCBzdHlsZTogeyBtYXJnaW5MZWZ0OiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMiB9IH0pKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1DYWxlbmRhckhlYWRlci5qcy5tYXAiXX0= */"));
|
|
7192
|
+
var MonthYearWrapper = /*#__PURE__*/_styled("div", {
|
|
7073
7193
|
target: "eg9fn2d1",
|
|
7074
7194
|
label: "MonthYearWrapper"
|
|
7075
|
-
})("display:
|
|
7195
|
+
})("display:flex;gap:", function (props) {
|
|
7076
7196
|
return props.theme.spaceScale.spacing03;
|
|
7077
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
7078
|
-
var NavigationWrapper = /*#__PURE__*/_styled("
|
|
7197
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFySGVhZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQ29DIiwiZmlsZSI6IkNhbGVuZGFySGVhZGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBhZGRNb250aHMsIHN1Yk1vbnRocyB9IGZyb20gJ2RhdGUtZm5zJztcclxuaW1wb3J0IHsgZW5VUyB9IGZyb20gJ2RhdGUtZm5zL2xvY2FsZSc7XHJcbmltcG9ydCB7IEtleWJvYXJkQXJyb3dMZWZ0SWNvbiwgS2V5Ym9hcmRBcnJvd1JpZ2h0SWNvbiwgfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBDYWxlbmRhckNvbnRleHQgfSBmcm9tICcuL0NhbGVuZGFyQ29udGV4dCc7XHJcbmltcG9ydCB7IGkxOG5Gb3JtYXQgYXMgZm9ybWF0LCBnZXRDdXJyZW50TW9udGhBbmRZZWFyIH0gZnJvbSAnLi91dGlscyc7XHJcbmltcG9ydCB7IEkxOG5Db250ZXh0IH0gZnJvbSAnLi4vLi4vaTE4bic7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEJ1dHRvbkNvbG9yLCBCdXR0b25UeXBlLCBCdXR0b25WYXJpYW50IH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBNb250aFBpY2tlciB9IGZyb20gJy4vTW9udGhQaWNrZXInO1xyXG5pbXBvcnQgeyBZZWFyUGlja2VyIH0gZnJvbSAnLi9ZZWFyUGlja2VyJztcclxuY29uc3QgQ2FsZW5kYXJIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMFxuICAgICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDA7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XHJcbmNvbnN0IENhbGVuZGFySGVhZGVyVGV4dCA9IHN0eWxlZC5kaXYgYFxuICBjYXB0aW9uLXNpZGU6IGluaXRpYWw7XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMH07XG4gIGZvbnQtc2l6ZTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmZvbnRTaXplfTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcblxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiBub25lO1xuICB9XG5gO1xyXG5jb25zdCBNb250aFllYXJXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG5gO1xyXG5jb25zdCBOYXZpZ2F0aW9uV3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogcm93O1xuYDtcclxuZXhwb3J0IGNvbnN0IENhbGVuZGFySGVhZGVyID0gcHJvcHMgPT4ge1xyXG4gICAgY29uc3QgeyBmb2N1c2VkRGF0ZSwgb25QcmV2TW9udGhDbGljaywgb25OZXh0TW9udGhDbGljayB9ID0gUmVhY3QudXNlQ29udGV4dChDYWxlbmRhckNvbnRleHQpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpMThuID0gUmVhY3QudXNlQ29udGV4dChJMThuQ29udGV4dCk7XHJcbiAgICBjb25zdCBsb2NhbGUgPSBpMThuLmxvY2FsZSB8fCBlblVTO1xyXG4gICAgY29uc3QgbW9udGhBbmRZZWFyID0gZ2V0Q3VycmVudE1vbnRoQW5kWWVhcihmb2N1c2VkRGF0ZSwgbG9jYWxlKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChDYWxlbmRhckhlYWRlckNvbnRhaW5lciwgeyB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KENhbGVuZGFySGVhZGVyVGV4dCwgeyB0YWJJbmRleDogLTEsIHRoZW1lOiB0aGVtZSwgaXNJbnZlcnNlOiBwcm9wcy5pc0ludmVyc2UgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChBbm5vdW5jZSwgbnVsbCxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTW9udGhZZWFyV3JhcHBlciwgeyB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KE1vbnRoUGlja2VyLCB7IGN1cnJlbnRNb250aDogbW9udGhBbmRZZWFyLm1vbnRoLCBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSB9KSxcclxuICAgICAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFllYXJQaWNrZXIsIHsgY3VycmVudFllYXI6IE51bWJlcihtb250aEFuZFllYXIueWVhciksIGlzSW52ZXJzZTogcHJvcHMuaXNJbnZlcnNlIH0pKSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTmF2aWdhdGlvbldyYXBwZXIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSWNvbkJ1dHRvbiwgeyBcImFyaWEtbGFiZWxcIjogYCR7aTE4bi5kYXRlUGlja2VyLnByZXZpb3VzTW9udGhBcmlhTGFiZWx9ICR7Zm9ybWF0KHN1Yk1vbnRocyhuZXcgRGF0ZShmb2N1c2VkRGF0ZSksIDEpLCAnTU1NTSB5eXl5JywgbG9jYWxlKX1gLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBpY29uOiBSZWFjdC5jcmVhdGVFbGVtZW50KEtleWJvYXJkQXJyb3dMZWZ0SWNvbiwgbnVsbCksIHR5cGU6IEJ1dHRvblR5cGUuYnV0dG9uLCB2YXJpYW50OiBCdXR0b25WYXJpYW50LmxpbmssIG9uQ2xpY2s6IG9uUHJldk1vbnRoQ2xpY2ssIHN0eWxlOiB7IG1hcmdpblJpZ2h0OiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMiB9IH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb25CdXR0b24sIHsgXCJhcmlhLWxhYmVsXCI6IGAke2kxOG4uZGF0ZVBpY2tlci5uZXh0TW9udGhBcmlhTGFiZWx9ICR7Zm9ybWF0KGFkZE1vbnRocyhuZXcgRGF0ZShmb2N1c2VkRGF0ZSksIDEpLCAnTU1NTSB5eXl5JywgbG9jYWxlKX1gLCBpY29uOiBSZWFjdC5jcmVhdGVFbGVtZW50KEtleWJvYXJkQXJyb3dSaWdodEljb24sIG51bGwpLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCB0eXBlOiBCdXR0b25UeXBlLmJ1dHRvbiwgdmFyaWFudDogQnV0dG9uVmFyaWFudC5saW5rLCBvbkNsaWNrOiBvbk5leHRNb250aENsaWNrLCBzdHlsZTogeyBtYXJnaW5MZWZ0OiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMiB9IH0pKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1DYWxlbmRhckhlYWRlci5qcy5tYXAiXX0= */"));
|
|
7198
|
+
var NavigationWrapper = /*#__PURE__*/_styled("div", {
|
|
7079
7199
|
target: "eg9fn2d0",
|
|
7080
7200
|
label: "NavigationWrapper"
|
|
7081
7201
|
})( {
|
|
7082
7202
|
name: "ho1qnd",
|
|
7083
|
-
styles: "display:flex;flex-direction:row/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
7203
|
+
styles: "display:flex;flex-direction:row/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFySGVhZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5Q3FDIiwiZmlsZSI6IkNhbGVuZGFySGVhZGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBhZGRNb250aHMsIHN1Yk1vbnRocyB9IGZyb20gJ2RhdGUtZm5zJztcclxuaW1wb3J0IHsgZW5VUyB9IGZyb20gJ2RhdGUtZm5zL2xvY2FsZSc7XHJcbmltcG9ydCB7IEtleWJvYXJkQXJyb3dMZWZ0SWNvbiwgS2V5Ym9hcmRBcnJvd1JpZ2h0SWNvbiwgfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IEFubm91bmNlIH0gZnJvbSAnLi4vQW5ub3VuY2UnO1xyXG5pbXBvcnQgeyBDYWxlbmRhckNvbnRleHQgfSBmcm9tICcuL0NhbGVuZGFyQ29udGV4dCc7XHJcbmltcG9ydCB7IGkxOG5Gb3JtYXQgYXMgZm9ybWF0LCBnZXRDdXJyZW50TW9udGhBbmRZZWFyIH0gZnJvbSAnLi91dGlscyc7XHJcbmltcG9ydCB7IEkxOG5Db250ZXh0IH0gZnJvbSAnLi4vLi4vaTE4bic7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEJ1dHRvbkNvbG9yLCBCdXR0b25UeXBlLCBCdXR0b25WYXJpYW50IH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBNb250aFBpY2tlciB9IGZyb20gJy4vTW9udGhQaWNrZXInO1xyXG5pbXBvcnQgeyBZZWFyUGlja2VyIH0gZnJvbSAnLi9ZZWFyUGlja2VyJztcclxuY29uc3QgQ2FsZW5kYXJIZWFkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZGlzcGxheTogZmxleDtcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMFxuICAgICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9IDA7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XHJcbmNvbnN0IENhbGVuZGFySGVhZGVyVGV4dCA9IHN0eWxlZC5kaXYgYFxuICBjYXB0aW9uLXNpZGU6IGluaXRpYWw7XG4gIGNvbG9yOiAke3Byb3BzID0+IHByb3BzLmlzSW52ZXJzZVxyXG4gICAgPyBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDEwMFxyXG4gICAgOiBwcm9wcy50aGVtZS5jb2xvcnMubmV1dHJhbDcwMH07XG4gIGZvbnQtc2l6ZTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS50eXBlU2NhbGUuc2l6ZTAzLmZvbnRTaXplfTtcbiAgbGluZS1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMy5saW5lSGVpZ2h0fTtcbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcblxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiBub25lO1xuICB9XG5gO1xyXG5jb25zdCBNb250aFllYXJXcmFwcGVyID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG5gO1xyXG5jb25zdCBOYXZpZ2F0aW9uV3JhcHBlciA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogcm93O1xuYDtcclxuZXhwb3J0IGNvbnN0IENhbGVuZGFySGVhZGVyID0gcHJvcHMgPT4ge1xyXG4gICAgY29uc3QgeyBmb2N1c2VkRGF0ZSwgb25QcmV2TW9udGhDbGljaywgb25OZXh0TW9udGhDbGljayB9ID0gUmVhY3QudXNlQ29udGV4dChDYWxlbmRhckNvbnRleHQpO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpMThuID0gUmVhY3QudXNlQ29udGV4dChJMThuQ29udGV4dCk7XHJcbiAgICBjb25zdCBsb2NhbGUgPSBpMThuLmxvY2FsZSB8fCBlblVTO1xyXG4gICAgY29uc3QgbW9udGhBbmRZZWFyID0gZ2V0Q3VycmVudE1vbnRoQW5kWWVhcihmb2N1c2VkRGF0ZSwgbG9jYWxlKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChDYWxlbmRhckhlYWRlckNvbnRhaW5lciwgeyB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KENhbGVuZGFySGVhZGVyVGV4dCwgeyB0YWJJbmRleDogLTEsIHRoZW1lOiB0aGVtZSwgaXNJbnZlcnNlOiBwcm9wcy5pc0ludmVyc2UgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChBbm5vdW5jZSwgbnVsbCxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTW9udGhZZWFyV3JhcHBlciwgeyB0aGVtZTogdGhlbWUgfSxcclxuICAgICAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KE1vbnRoUGlja2VyLCB7IGN1cnJlbnRNb250aDogbW9udGhBbmRZZWFyLm1vbnRoLCBpc0ludmVyc2U6IHByb3BzLmlzSW52ZXJzZSB9KSxcclxuICAgICAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFllYXJQaWNrZXIsIHsgY3VycmVudFllYXI6IE51bWJlcihtb250aEFuZFllYXIueWVhciksIGlzSW52ZXJzZTogcHJvcHMuaXNJbnZlcnNlIH0pKSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTmF2aWdhdGlvbldyYXBwZXIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSWNvbkJ1dHRvbiwgeyBcImFyaWEtbGFiZWxcIjogYCR7aTE4bi5kYXRlUGlja2VyLnByZXZpb3VzTW9udGhBcmlhTGFiZWx9ICR7Zm9ybWF0KHN1Yk1vbnRocyhuZXcgRGF0ZShmb2N1c2VkRGF0ZSksIDEpLCAnTU1NTSB5eXl5JywgbG9jYWxlKX1gLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCBpY29uOiBSZWFjdC5jcmVhdGVFbGVtZW50KEtleWJvYXJkQXJyb3dMZWZ0SWNvbiwgbnVsbCksIHR5cGU6IEJ1dHRvblR5cGUuYnV0dG9uLCB2YXJpYW50OiBCdXR0b25WYXJpYW50LmxpbmssIG9uQ2xpY2s6IG9uUHJldk1vbnRoQ2xpY2ssIHN0eWxlOiB7IG1hcmdpblJpZ2h0OiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMiB9IH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb25CdXR0b24sIHsgXCJhcmlhLWxhYmVsXCI6IGAke2kxOG4uZGF0ZVBpY2tlci5uZXh0TW9udGhBcmlhTGFiZWx9ICR7Zm9ybWF0KGFkZE1vbnRocyhuZXcgRGF0ZShmb2N1c2VkRGF0ZSksIDEpLCAnTU1NTSB5eXl5JywgbG9jYWxlKX1gLCBpY29uOiBSZWFjdC5jcmVhdGVFbGVtZW50KEtleWJvYXJkQXJyb3dSaWdodEljb24sIG51bGwpLCBjb2xvcjogQnV0dG9uQ29sb3Iuc3VidGxlLCB0eXBlOiBCdXR0b25UeXBlLmJ1dHRvbiwgdmFyaWFudDogQnV0dG9uVmFyaWFudC5saW5rLCBvbkNsaWNrOiBvbk5leHRNb250aENsaWNrLCBzdHlsZTogeyBtYXJnaW5MZWZ0OiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMiB9IH0pKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1DYWxlbmRhckhlYWRlci5qcy5tYXAiXX0= */",
|
|
7084
7204
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$h
|
|
7085
7205
|
});
|
|
7086
|
-
var CalendarHeader =
|
|
7087
|
-
var calendarHeader = React.useRef();
|
|
7206
|
+
var CalendarHeader = function CalendarHeader(props) {
|
|
7088
7207
|
var _React$useContext = React.useContext(CalendarContext),
|
|
7089
7208
|
focusedDate = _React$useContext.focusedDate,
|
|
7090
7209
|
onPrevMonthClick = _React$useContext.onPrevMonthClick,
|
|
7091
7210
|
onNextMonthClick = _React$useContext.onNextMonthClick;
|
|
7092
|
-
var prevFocusHeader = usePrevious(props.focusHeader);
|
|
7093
|
-
var ref = useForkedRef(forwardedRef, calendarHeader);
|
|
7094
|
-
React.useEffect(function () {
|
|
7095
|
-
if (!prevFocusHeader && props.focusHeader) {
|
|
7096
|
-
calendarHeader.current.focus();
|
|
7097
|
-
}
|
|
7098
|
-
}, [props.focusHeader]);
|
|
7099
7211
|
var theme = React.useContext(ThemeContext);
|
|
7100
7212
|
var i18n = React.useContext(I18nContext);
|
|
7101
7213
|
var locale$1 = i18n.locale || locale.enUS;
|
|
7102
|
-
var
|
|
7103
|
-
var capitalizeCurrentMonth = currentMonth && currentMonth.charAt(0).toUpperCase() + currentMonth.slice(1);
|
|
7104
|
-
var _ref = capitalizeCurrentMonth ? capitalizeCurrentMonth.split(' ') : ['', ''],
|
|
7105
|
-
month = _ref[0],
|
|
7106
|
-
year = _ref[1];
|
|
7214
|
+
var monthAndYear = getCurrentMonthAndYear(focusedDate, locale$1);
|
|
7107
7215
|
return React.createElement(CalendarHeaderContainer, {
|
|
7108
7216
|
theme: theme
|
|
7109
7217
|
}, React.createElement(CalendarHeaderText, {
|
|
7110
|
-
"data-testid": "calendar-header",
|
|
7111
7218
|
tabIndex: -1,
|
|
7112
7219
|
theme: theme,
|
|
7113
|
-
ref: ref,
|
|
7114
7220
|
isInverse: props.isInverse
|
|
7115
7221
|
}, React.createElement(Announce, null, React.createElement(MonthYearWrapper, {
|
|
7116
7222
|
theme: theme
|
|
7117
|
-
}, React.createElement(
|
|
7223
|
+
}, React.createElement(MonthPicker, {
|
|
7224
|
+
currentMonth: monthAndYear.month,
|
|
7225
|
+
isInverse: props.isInverse
|
|
7226
|
+
}), React.createElement(YearPicker, {
|
|
7227
|
+
currentYear: Number(monthAndYear.year),
|
|
7228
|
+
isInverse: props.isInverse
|
|
7229
|
+
})))), React.createElement(NavigationWrapper, null, React.createElement(IconButton, {
|
|
7118
7230
|
"aria-label": i18n.datePicker.previousMonthAriaLabel + " " + i18nFormat(dateFns.subMonths(new Date(focusedDate), 1), 'MMMM yyyy', locale$1),
|
|
7119
7231
|
color: exports.ButtonColor.subtle,
|
|
7120
7232
|
icon: React.createElement(reactMagmaIcons.KeyboardArrowLeftIcon, null),
|
|
@@ -7135,7 +7247,7 @@ var CalendarHeader = /*#__PURE__*/React.forwardRef(function (props, forwardedRef
|
|
|
7135
7247
|
marginLeft: theme.spaceScale.spacing02
|
|
7136
7248
|
}
|
|
7137
7249
|
})));
|
|
7138
|
-
}
|
|
7250
|
+
};
|
|
7139
7251
|
|
|
7140
7252
|
function useFocusLock(active, header, body) {
|
|
7141
7253
|
var rootNode = React.useRef(null);
|
|
@@ -7225,7 +7337,7 @@ var List = /*#__PURE__*/_styled("ul", {
|
|
|
7225
7337
|
label: "List"
|
|
7226
7338
|
})( {
|
|
7227
7339
|
name: "1s0dwnn",
|
|
7228
|
-
styles: "list-style:none;margin:0;padding:0;text-align:left/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAYuB","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: props.onReturnBack }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */",
|
|
7340
|
+
styles: "list-style:none;margin:0;padding:0;text-align:left/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAYuB","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: e => {\r\n                        // Avoid scrolling to the top of the page\r\n                        e.preventDefault();\r\n                        props.onReturnBack();\r\n                    } }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */",
|
|
7229
7341
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$i
|
|
7230
7342
|
});
|
|
7231
7343
|
var Item = /*#__PURE__*/_styled("li", {
|
|
@@ -7235,7 +7347,7 @@ var Item = /*#__PURE__*/_styled("li", {
|
|
|
7235
7347
|
return props.theme.typeScale.size02.fontSize;
|
|
7236
7348
|
}, ";line-height:", function (props) {
|
|
7237
7349
|
return props.theme.typeScale.size02.lineHeight;
|
|
7238
|
-
}, ";align-items:center;span{flex:0 0 100px;overflow:hidden;line-height:28px;min-height:36px;height:max-content;text-align:center;}div{flex:1;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAkBuB","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: props.onReturnBack }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
|
|
7350
|
+
}, ";align-items:center;span{flex:0 0 100px;overflow:hidden;line-height:28px;min-height:36px;height:max-content;text-align:center;}div{flex:1;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAkBuB","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: e => {\r\n                        // Avoid scrolling to the top of the page\r\n                        e.preventDefault();\r\n                        props.onReturnBack();\r\n                    } }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
|
|
7239
7351
|
var KeyboardShortcutButtonWrapper = /*#__PURE__*/_styled("span", {
|
|
7240
7352
|
target: "egx42px6",
|
|
7241
7353
|
label: "KeyboardShortcutButtonWrapper"
|
|
@@ -7253,13 +7365,13 @@ var KeyboardShortcutButtonWrapper = /*#__PURE__*/_styled("span", {
|
|
|
7253
7365
|
return props.theme.spaceScale.spacing02;
|
|
7254
7366
|
}, " ", function (props) {
|
|
7255
7367
|
return props.theme.spaceScale.spacing04;
|
|
7256
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAqCkD","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: props.onReturnBack }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
|
|
7368
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAqCkD","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: e => {\r\n                        // Avoid scrolling to the top of the page\r\n                        e.preventDefault();\r\n                        props.onReturnBack();\r\n                    } }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
|
|
7257
7369
|
var StyledPopup = /*#__PURE__*/_styled("div", {
|
|
7258
7370
|
target: "egx42px5",
|
|
7259
7371
|
label: "StyledPopup"
|
|
7260
7372
|
})( {
|
|
7261
7373
|
name: "bjn8wh",
|
|
7262
|
-
styles: "position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAkD+B","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: props.onReturnBack }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */",
|
|
7374
|
+
styles: "position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAkD+B","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: e => {\r\n                        // Avoid scrolling to the top of the page\r\n                        e.preventDefault();\r\n                        props.onReturnBack();\r\n                    } }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */",
|
|
7263
7375
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$i
|
|
7264
7376
|
});
|
|
7265
7377
|
var StyledNavContainer = /*#__PURE__*/_styled("div", {
|
|
@@ -7271,7 +7383,7 @@ var StyledNavContainer = /*#__PURE__*/_styled("div", {
|
|
|
7271
7383
|
return props.isInverse ? props.theme.colors.primary400 : props.theme.colors.neutral300;
|
|
7272
7384
|
}, ";background:", function (props) {
|
|
7273
7385
|
return props.isInverse ? props.theme.colors.primary600 : props.theme.colors.neutral200;
|
|
7274
|
-
}, ";height:44px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAqDsC","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: props.onReturnBack }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
|
|
7386
|
+
}, ";height:44px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAqDsC","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: e => {\r\n                        // Avoid scrolling to the top of the page\r\n                        e.preventDefault();\r\n                        props.onReturnBack();\r\n                    } }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
|
|
7275
7387
|
var StyledContent = /*#__PURE__*/_styled("div", {
|
|
7276
7388
|
target: "egx42px3",
|
|
7277
7389
|
label: "StyledContent"
|
|
@@ -7290,19 +7402,19 @@ var StyledContent = /*#__PURE__*/_styled("div", {
|
|
|
7290
7402
|
}, " ", function (props) {
|
|
7291
7403
|
var _props$theme6;
|
|
7292
7404
|
return (_props$theme6 = props.theme) == null ? void 0 : _props$theme6.spaceScale.spacing02;
|
|
7293
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAmEiC","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: props.onReturnBack }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
|
|
7405
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAmEiC","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: e => {\r\n                        // Avoid scrolling to the top of the page\r\n                        e.preventDefault();\r\n                        props.onReturnBack();\r\n                    } }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
|
|
7294
7406
|
var StyledDescription = /*#__PURE__*/_styled("p", {
|
|
7295
7407
|
target: "egx42px2",
|
|
7296
7408
|
label: "StyledDescription"
|
|
7297
7409
|
})("font-family:", function (props) {
|
|
7298
7410
|
return props.theme.bodyFont;
|
|
7299
|
-
}, ";margin:0;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAiFmC","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: props.onReturnBack }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
|
|
7411
|
+
}, ";margin:0;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAiFmC","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: e => {\r\n                        // Avoid scrolling to the top of the page\r\n                        e.preventDefault();\r\n                        props.onReturnBack();\r\n                    } }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
|
|
7300
7412
|
var CloseButton = /*#__PURE__*/_styled("span", {
|
|
7301
7413
|
target: "egx42px1",
|
|
7302
7414
|
label: "CloseButton"
|
|
7303
7415
|
})( {
|
|
7304
7416
|
name: "130ebu3",
|
|
7305
|
-
styles: "position:absolute;right:3px;top:3px;z-index:1/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAqFgC","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: props.onReturnBack }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */",
|
|
7417
|
+
styles: "position:absolute;right:3px;top:3px;z-index:1/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAqFgC","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: e => {\r\n                        // Avoid scrolling to the top of the page\r\n                        e.preventDefault();\r\n                        props.onReturnBack();\r\n                    } }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */",
|
|
7306
7418
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$i
|
|
7307
7419
|
});
|
|
7308
7420
|
var BackToCalendarWrapper = /*#__PURE__*/_styled("span", {
|
|
@@ -7318,7 +7430,7 @@ var BackToCalendarWrapper = /*#__PURE__*/_styled("span", {
|
|
|
7318
7430
|
return props.isInverse ? props.theme.colors.tertiary500 : props.theme.colors.primary500;
|
|
7319
7431
|
}, ";&:hover{color:", function (props) {
|
|
7320
7432
|
return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.primary600;
|
|
7321
|
-
}, ";}svg{height:20px;width:20px;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AA2F0C","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: props.onReturnBack }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
|
|
7433
|
+
}, ";}svg{height:20px;width:20px;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AA2F0C","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { Heading } from '../Heading';\r\nimport { Hyperlink, HyperlinkIconPosition } from '../Hyperlink';\r\nimport { IconButton } from '../IconButton';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nconst List = styled.ul `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  text-align: left;\n`;\r\nconst Item = styled.li `\n  display: flex;\n  list-style: none;\n  margin-bottom: 12px;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  align-items: center;\n  span {\n    flex: 0 0 100px;\n    overflow: hidden;\n    line-height: 28px;\n    min-height: 36px;\n    height: max-content;\n    text-align: center;\n  }\n  div {\n    flex: 1;\n  }\n`;\r\nconst KeyboardShortcutButtonWrapper = styled.span `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral200};\n  font-family: monospace;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  text-transform: uppercase;\n  padding: ${props => props.theme.spaceScale.spacing02}\n    ${props => props.theme.spaceScale.spacing04};\n`;\r\nconst StyledPopup = styled.div `\n  position: relative;\n`;\r\nconst StyledNavContainer = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  padding: ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  height: 44px;\n`;\r\nconst StyledContent = styled.div `\n  z-index: 9999;\n  position: relative;\n  color: ${props => props.isInverse\r\n    ? props?.theme?.colors?.neutral100\r\n    : props?.theme?.colors?.neutral700};\n\n  h2 {\n    margin: ${props => props.theme?.spaceScale.spacing05} 0\n      ${props => props.theme?.spaceScale.spacing04} 0;\n  }\n  padding: 0 ${props => props.theme?.spaceScale.spacing05}\n    ${props => props.theme?.spaceScale.spacing02};\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst BackToCalendarWrapper = styled.span `\n  margin-top: ${props => props.theme.spaceScale.spacing03};\n  font-weight: 600;\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n  svg {\n    height: 20px;\n    width: 20px;\n  }\n`;\r\nexport const HelperInformation = (props) => {\r\n    const i18n = React.useContext(I18nContext);\r\n    const theme = React.useContext(ThemeContext);\r\n    const helperInformationRef = useFocusLock(true);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, { ref: helperInformationRef },\r\n        React.createElement(StyledNavContainer, { \"data-testid\": \"helper-navigation-container\", isInverse: isInverse, theme: theme },\r\n            React.createElement(BackToCalendarWrapper, { isInverse: isInverse, theme: theme },\r\n                React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.backToCalendarAriaLabel, target: \"_self\", to: \"#\", icon: React.createElement(ArrowBackIcon, null), iconPosition: HyperlinkIconPosition.left, hasUnderline: false, isInverse: isInverse, onClick: e => {\r\n                        // Avoid scrolling to the top of the page\r\n                        e.preventDefault();\r\n                        props.onReturnBack();\r\n                    } }, \"Back to Calendar\")),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link, style: {\r\n                        color: isInverse\r\n                            ? theme.colors.neutral100\r\n                            : theme.colors.neutral900,\r\n                    } }))),\r\n        React.createElement(StyledContent, { isInverse: isInverse, theme: theme },\r\n            React.createElement(Heading, { level: 2, visualStyle: TypographyVisualStyle.headingXSmall, isInverse: isInverse }, i18n.datePicker.helpModal.header),\r\n            React.createElement(List, { id: \"DayPickerKeyboardShortcuts_description\" },\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { \"aria-label\": i18n.datePicker.helpModal.enter.ariaLabel, isInverse: isInverse, role: \"img\", theme: theme }, \"\\u21B5\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.enter.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.rightAndLeftArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2190/\\u2192\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.rightAndLeftArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.upAndDownArrowKeys.ariaLabel, isInverse: isInverse }, \"\\u2191/\\u2193\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.upAndDownArrowKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.pageUpAndPageDownKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.pageUpAndPageDownKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.homeAndEndKeys.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.homeAndEndKeys.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.homeAndEndKeys.explanation)),\r\n                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.escape.ariaLabel, isInverse: isInverse }, i18n.datePicker.helpModal.escape.displayValue),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.escape.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
|
|
7322
7434
|
var HelperInformation = function HelperInformation(props) {
|
|
7323
7435
|
var i18n = React.useContext(I18nContext);
|
|
7324
7436
|
var theme = React.useContext(ThemeContext);
|
|
@@ -7341,7 +7453,11 @@ var HelperInformation = function HelperInformation(props) {
|
|
|
7341
7453
|
iconPosition: exports.HyperlinkIconPosition.left,
|
|
7342
7454
|
hasUnderline: false,
|
|
7343
7455
|
isInverse: isInverse,
|
|
7344
|
-
onClick:
|
|
7456
|
+
onClick: function onClick(e) {
|
|
7457
|
+
// Avoid scrolling to the top of the page
|
|
7458
|
+
e.preventDefault();
|
|
7459
|
+
props.onReturnBack();
|
|
7460
|
+
}
|
|
7345
7461
|
}, "Back to Calendar")), React.createElement(CloseButton, {
|
|
7346
7462
|
theme: theme
|
|
7347
7463
|
}, React.createElement(IconButton, {
|
|
@@ -7430,7 +7546,7 @@ var CalendarContainer = /*#__PURE__*/_styled("div", {
|
|
|
7430
7546
|
return props.isInverse ? props.theme.colors.primary500 : props.theme.colors.neutral100;
|
|
7431
7547
|
}, ";overflow:visible;&:focus{border-radius:", function (props) {
|
|
7432
7548
|
return props.theme.borderRadius;
|
|
7433
|
-
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAeqC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: ${props => props.theme.spaceScale.spacing09}\n    ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const [focusHeader, setFocusHeader] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened, headingRef);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n        if (props.calendarOpened && !props.focusOnOpen && !focusHeader) {\r\n            setFocusHeader(true);\r\n        }\r\n        if (prevCalendarOpened && !props.calendarOpened) {\r\n            setFocusHeader(false);\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme },\r\n            React.createElement(CalendarHeader, { ref: headingRef, focusHeader: focusHeader, isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
7549
|
+
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAgBqC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: 45px ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened);\r\n    const monthContainerRef = React.useRef(null);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme, ref: monthContainerRef },\r\n            React.createElement(CalendarHeader, { isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
7434
7550
|
var MonthContainer = /*#__PURE__*/_styled("div", {
|
|
7435
7551
|
target: "eeao89h7",
|
|
7436
7552
|
label: "MonthContainer"
|
|
@@ -7438,45 +7554,43 @@ var MonthContainer = /*#__PURE__*/_styled("div", {
|
|
|
7438
7554
|
return props.isInverse ? props.theme.colors.primary500 : props.theme.colors.neutral100;
|
|
7439
7555
|
}, ";font-family:", function (props) {
|
|
7440
7556
|
return props.theme.bodyFont;
|
|
7441
|
-
}, ";text-align:center;user-select:none;vertical-align:top;padding:", function (props) {
|
|
7442
|
-
return props.theme.spaceScale.spacing09;
|
|
7443
|
-
}, " ", function (props) {
|
|
7557
|
+
}, ";text-align:center;user-select:none;vertical-align:top;padding:45px ", function (props) {
|
|
7444
7558
|
return props.theme.spaceScale.spacing03;
|
|
7445
7559
|
}, " ", function (props) {
|
|
7446
7560
|
return props.theme.spaceScale.spacing03;
|
|
7447
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAyBkC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: ${props => props.theme.spaceScale.spacing09}\n    ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const [focusHeader, setFocusHeader] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened, headingRef);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n        if (props.calendarOpened && !props.focusOnOpen && !focusHeader) {\r\n            setFocusHeader(true);\r\n        }\r\n        if (prevCalendarOpened && !props.calendarOpened) {\r\n            setFocusHeader(false);\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme },\r\n            React.createElement(CalendarHeader, { ref: headingRef, focusHeader: focusHeader, isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
7561
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AA0BkC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: 45px ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened);\r\n    const monthContainerRef = React.useRef(null);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme, ref: monthContainerRef },\r\n            React.createElement(CalendarHeader, { isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
7448
7562
|
var Table$1 = /*#__PURE__*/_styled("table", {
|
|
7449
7563
|
target: "eeao89h6",
|
|
7450
7564
|
label: "Table"
|
|
7451
7565
|
})( {
|
|
7452
7566
|
name: "pq92j3",
|
|
7453
|
-
styles: "border-collapse:collapse;border-spacing:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAsC2B","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: ${props => props.theme.spaceScale.spacing09}\n    ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const [focusHeader, setFocusHeader] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened, headingRef);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n        if (props.calendarOpened && !props.focusOnOpen && !focusHeader) {\r\n            setFocusHeader(true);\r\n        }\r\n        if (prevCalendarOpened && !props.calendarOpened) {\r\n            setFocusHeader(false);\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme },\r\n            React.createElement(CalendarHeader, { ref: headingRef, focusHeader: focusHeader, isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */",
|
|
7567
|
+
styles: "border-collapse:collapse;border-spacing:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAsC2B","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: 45px ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened);\r\n    const monthContainerRef = React.useRef(null);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme, ref: monthContainerRef },\r\n            React.createElement(CalendarHeader, { isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */",
|
|
7454
7568
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$j
|
|
7455
7569
|
});
|
|
7456
7570
|
var Th = /*#__PURE__*/_styled("th", {
|
|
7457
7571
|
target: "eeao89h5",
|
|
7458
7572
|
label: "Th"
|
|
7459
7573
|
})("border:0;color:", function (props) {
|
|
7460
|
-
return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral500;
|
|
7574
|
+
return props.isInverse ? polished.transparentize(0.3, props.theme.colors.neutral100) : props.theme.colors.neutral500;
|
|
7461
7575
|
}, ";font-size:", function (props) {
|
|
7462
7576
|
return props.theme.typeScale.size01.fontSize;
|
|
7463
7577
|
}, ";line-height:", function (props) {
|
|
7464
7578
|
return props.theme.typeScale.size01.lineHeight;
|
|
7465
7579
|
}, ";padding:0;text-align:center;font-weight:600;text-transform:uppercase;padding-bottom:", function (props) {
|
|
7466
7580
|
return props.theme.spaceScale.spacing03;
|
|
7467
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AA0CqB","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: ${props => props.theme.spaceScale.spacing09}\n    ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const [focusHeader, setFocusHeader] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened, headingRef);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n        if (props.calendarOpened && !props.focusOnOpen && !focusHeader) {\r\n            setFocusHeader(true);\r\n        }\r\n        if (prevCalendarOpened && !props.calendarOpened) {\r\n            setFocusHeader(false);\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme },\r\n            React.createElement(CalendarHeader, { ref: headingRef, focusHeader: focusHeader, isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
7581
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AA0CqB","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: 45px ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened);\r\n    const monthContainerRef = React.useRef(null);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme, ref: monthContainerRef },\r\n            React.createElement(CalendarHeader, { isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
7468
7582
|
var HelperButton = /*#__PURE__*/_styled("span", {
|
|
7469
7583
|
target: "eeao89h4",
|
|
7470
7584
|
label: "HelperButton"
|
|
7471
7585
|
})("margin:", function (props) {
|
|
7472
7586
|
return props.theme.spaceScale.spacing02;
|
|
7473
|
-
}, ";top:-1px;position:absolute;left:0;z-index:2;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAuDiC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: ${props => props.theme.spaceScale.spacing09}\n    ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const [focusHeader, setFocusHeader] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened, headingRef);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n        if (props.calendarOpened && !props.focusOnOpen && !focusHeader) {\r\n            setFocusHeader(true);\r\n        }\r\n        if (prevCalendarOpened && !props.calendarOpened) {\r\n            setFocusHeader(false);\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme },\r\n            React.createElement(CalendarHeader, { ref: headingRef, focusHeader: focusHeader, isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
7587
|
+
}, ";top:-1px;position:absolute;left:0;z-index:2;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAuDiC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: 45px ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened);\r\n    const monthContainerRef = React.useRef(null);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme, ref: monthContainerRef },\r\n            React.createElement(CalendarHeader, { isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
7474
7588
|
var CloseButton$1 = /*#__PURE__*/_styled("span", {
|
|
7475
7589
|
target: "eeao89h3",
|
|
7476
7590
|
label: "CloseButton"
|
|
7477
7591
|
})( {
|
|
7478
7592
|
name: "130ebu3",
|
|
7479
|
-
styles: "position:absolute;right:3px;top:3px;z-index:1/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AA8DgC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: ${props => props.theme.spaceScale.spacing09}\n    ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const [focusHeader, setFocusHeader] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened, headingRef);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n        if (props.calendarOpened && !props.focusOnOpen && !focusHeader) {\r\n            setFocusHeader(true);\r\n        }\r\n        if (prevCalendarOpened && !props.calendarOpened) {\r\n            setFocusHeader(false);\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme },\r\n            React.createElement(CalendarHeader, { ref: headingRef, focusHeader: focusHeader, isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */",
|
|
7593
|
+
styles: "position:absolute;right:3px;top:3px;z-index:1/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AA8DgC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: 45px ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened);\r\n    const monthContainerRef = React.useRef(null);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme, ref: monthContainerRef },\r\n            React.createElement(CalendarHeader, { isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */",
|
|
7480
7594
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$j
|
|
7481
7595
|
});
|
|
7482
7596
|
var HeaderWrapper = /*#__PURE__*/_styled("div", {
|
|
@@ -7488,7 +7602,7 @@ var HeaderWrapper = /*#__PURE__*/_styled("div", {
|
|
|
7488
7602
|
return props.theme.spaceScale.spacing03;
|
|
7489
7603
|
}, ";border-bottom:1px solid ", function (props) {
|
|
7490
7604
|
return props.isInverse ? props.theme.colors.primary400 : props.theme.colors.neutral300;
|
|
7491
|
-
}, ";width:100%;height:44px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAoEiC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: ${props => props.theme.spaceScale.spacing09}\n    ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const [focusHeader, setFocusHeader] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened, headingRef);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n        if (props.calendarOpened && !props.focusOnOpen && !focusHeader) {\r\n            setFocusHeader(true);\r\n        }\r\n        if (prevCalendarOpened && !props.calendarOpened) {\r\n            setFocusHeader(false);\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme },\r\n            React.createElement(CalendarHeader, { ref: headingRef, focusHeader: focusHeader, isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
7605
|
+
}, ";width:100%;height:44px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAoEiC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: 45px ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened);\r\n    const monthContainerRef = React.useRef(null);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme, ref: monthContainerRef },\r\n            React.createElement(CalendarHeader, { isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
7492
7606
|
var Divider = /*#__PURE__*/_styled("span", {
|
|
7493
7607
|
target: "eeao89h1",
|
|
7494
7608
|
label: "Divider"
|
|
@@ -7500,7 +7614,7 @@ var Divider = /*#__PURE__*/_styled("span", {
|
|
|
7500
7614
|
return props.theme.spaceScale.spacing02;
|
|
7501
7615
|
}, ";border-radius:50%;background:", function (props) {
|
|
7502
7616
|
return props.isInverse ? props.theme.colors.neutral300 : props.theme.colors.neutral400;
|
|
7503
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAoF4B","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: ${props => props.theme.spaceScale.spacing09}\n    ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const [focusHeader, setFocusHeader] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened, headingRef);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n        if (props.calendarOpened && !props.focusOnOpen && !focusHeader) {\r\n            setFocusHeader(true);\r\n        }\r\n        if (prevCalendarOpened && !props.calendarOpened) {\r\n            setFocusHeader(false);\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme },\r\n            React.createElement(CalendarHeader, { ref: headingRef, focusHeader: focusHeader, isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
7617
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAoF4B","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: 45px ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened);\r\n    const monthContainerRef = React.useRef(null);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme, ref: monthContainerRef },\r\n            React.createElement(CalendarHeader, { isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
7504
7618
|
var TodayWrapper = /*#__PURE__*/_styled("div", {
|
|
7505
7619
|
target: "eeao89h0",
|
|
7506
7620
|
label: "TodayWrapper"
|
|
@@ -7516,20 +7630,17 @@ var TodayWrapper = /*#__PURE__*/_styled("div", {
|
|
|
7516
7630
|
return props.isInverse ? props.theme.colors.tertiary500 : props.theme.colors.primary500;
|
|
7517
7631
|
}, ";&:hover{color:", function (props) {
|
|
7518
7632
|
return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.primary600;
|
|
7519
|
-
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AA6FgC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: ${props => props.theme.spaceScale.spacing09}\n    ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const headingRef = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const [focusHeader, setFocusHeader] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened, headingRef);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n        if (props.calendarOpened && !props.focusOnOpen && !focusHeader) {\r\n            setFocusHeader(true);\r\n        }\r\n        if (prevCalendarOpened && !props.calendarOpened) {\r\n            setFocusHeader(false);\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme },\r\n            React.createElement(CalendarHeader, { ref: headingRef, focusHeader: focusHeader, isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
7633
|
+
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AA6FgC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { usePrevious } from '../../utils';\r\nimport { Hyperlink } from '../Hyperlink';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  overflow: visible;\n\n  &:focus {\n    border-radius: ${props => props.theme.borderRadius};\n  }\n`;\r\nconst MonthContainer = styled.div `\n  position: relative;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  font-family: ${props => props.theme.bodyFont};\n  text-align: center;\n  user-select: none;\n  vertical-align: top;\n  padding: 45px ${props => props.theme.spaceScale.spacing03}\n    ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n`;\r\nconst Th = styled.th `\n  border: 0;\n  color: ${props => props.isInverse\r\n    ? transparentize(0.3, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral500};\n  font-size: ${props => props.theme.typeScale.size01.fontSize};\n  line-height: ${props => props.theme.typeScale.size01.lineHeight};\n  padding: 0;\n  text-align: center;\n  font-weight: 600;\n  text-transform: uppercase;\n  padding-bottom: ${props => props.theme.spaceScale.spacing03};\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: -1px;\n  position: absolute;\n  left: 0;\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: 3px;\n  top: 3px;\n  z-index: 1;\n`;\r\nconst HeaderWrapper = styled.div `\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: flex;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary600\r\n    : props.theme.colors.neutral200};\n  padding: 11px ${props => props.theme.spaceScale.spacing03};\n  border-bottom: 1px solid\n    ${props => props.isInverse\r\n    ? props.theme.colors.primary400\r\n    : props.theme.colors.neutral300};\n  width: 100%;\n  height: 44px;\n`;\r\nconst Divider = styled.span `\n  margin-right: ${props => props.theme.spaceScale.spacing04};\n  width: ${props => props.theme.spaceScale.spacing02};\n  height: ${props => props.theme.spaceScale.spacing02};\n  border-radius: 50%;\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.neutral300\r\n    : props.theme.colors.neutral400};\n`;\r\nconst TodayWrapper = styled.div `\n  display: flex;\n  align-items: center;\n  margin-top: ${props => props.theme.spaceScale.spacing01};\n  margin-left: ${props => props.theme.spaceScale.spacing09};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: 600;\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.tertiary500\r\n    : props.theme.colors.primary500};\n\n  &:hover {\n    color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.primary600};\n  }\n`;\r\nexport const CalendarMonth = (props) => {\r\n    const lastFocus = React.useRef();\r\n    const helperButtonRef = React.useRef();\r\n    const context = React.useContext(CalendarContext);\r\n    const [dayFocusable, setDayFocusable] = React.useState(false);\r\n    const prevCalendarOpened = usePrevious(props.calendarOpened);\r\n    const focusTrapElement = useFocusLock(props.calendarOpened);\r\n    const monthContainerRef = React.useRef(null);\r\n    React.useEffect(() => {\r\n        if (!prevCalendarOpened && props.calendarOpened) {\r\n            lastFocus.current = document.activeElement;\r\n            if (props.focusOnOpen) {\r\n                setDayFocusable(true);\r\n                context.setDateFocused(true);\r\n            }\r\n        }\r\n    }, [props.calendarOpened, props.focusOnOpen]);\r\n    React.useEffect(() => {\r\n        if (prevCalendarOpened && !context.helperInformationShown) {\r\n            helperButtonRef.current.focus();\r\n        }\r\n    }, [context.helperInformationShown]);\r\n    function onCalendarTableFocus() {\r\n        setDayFocusable(true);\r\n    }\r\n    function onCalendarTableBlur() {\r\n        setDayFocusable(false);\r\n        context.setDateFocused(false);\r\n    }\r\n    function turnOffDateFocused() {\r\n        context.setDateFocused(false);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\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 = days.indexOf(i18n.datePicker.startOfWeek);\r\n    const sortedDays = days.slice(startOfWeek).concat(days.slice(0, startOfWeek));\r\n    const tableDaysHeaders = sortedDays.map((day, index) => (React.createElement(Th, { key: index, theme: theme, isInverse: context.isInverse, \"aria-label\": i18n.days.long[day] }, i18n.days.short[day])));\r\n    return (React.createElement(React.Fragment, null,\r\n        React.createElement(CalendarContainer, { \"data-testid\": \"calendarMonthContainer\", tabIndex: -1, theme: theme, onKeyDown: context.onKeyDown, isInverse: context.isInverse, ref: focusTrapElement }, context.helperInformationShown ? (React.createElement(HelperInformation, { isOpen: context.helperInformationShown, isInverse: context.isInverse, onReturnBack: context.hideHelperInformation, onClose: context.onClose })) : (React.createElement(MonthContainer, { \"data-testid\": \"monthContainer\", \"data-visible\": \"true\", isInverse: context.isInverse, theme: theme, ref: monthContainerRef },\r\n            React.createElement(CalendarHeader, { isInverse: context.isInverse }),\r\n            React.createElement(Table, { onBlur: onCalendarTableBlur, onFocus: onCalendarTableFocus, theme: theme, role: \"application\" },\r\n                React.createElement(\"tbody\", null,\r\n                    React.createElement(\"tr\", null, tableDaysHeaders),\r\n                    context\r\n                        .buildCalendarMonth(context.focusedDate, true)\r\n                        .map((week, i) => (React.createElement(\"tr\", { key: i }, week.map((day, dayOfWeek) => (React.createElement(CalendarDay, { key: dayOfWeek, isInverse: context.isInverse, day: day, dayFocusable: dayFocusable, onDateChange: context.onDateChange })))))))),\r\n            React.createElement(HeaderWrapper, { theme: theme, isInverse: context.isInverse },\r\n                React.createElement(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                    React.createElement(HelperButton, { theme: theme },\r\n                        React.createElement(IconButton, { color: ButtonColor.subtle, ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                                color: context.isInverse\r\n                                    ? theme.colors.neutral100\r\n                                    : theme.colors.neutral900,\r\n                            } }))),\r\n                React.createElement(TodayWrapper, { \"data-testid\": \"todayWrapper\", isInverse: context.isInverse, theme: theme, onClick: e => context.setFocusedTodayDate(e), onKeyDown: e => context.setFocusedTodayDate(e) },\r\n                    React.createElement(Divider, { \"data-testid\": \"divider\", theme: theme, isInverse: context.isInverse }),\r\n                    React.createElement(Hyperlink, { \"aria-label\": i18n.datePicker.navigateToCurrentDateAriaLabel, target: \"_self\", to: \"#\", hasUnderline: false }, i18n.datePicker.today)),\r\n                React.createElement(CloseButton, { theme: theme },\r\n                    React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.subtle, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link, style: {\r\n                            color: context.isInverse\r\n                                ? theme.colors.neutral100\r\n                                : theme.colors.neutral900,\r\n                        } }))))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
7520
7634
|
var CalendarMonth = function CalendarMonth(props) {
|
|
7521
7635
|
var lastFocus = React.useRef();
|
|
7522
|
-
var headingRef = React.useRef();
|
|
7523
7636
|
var helperButtonRef = React.useRef();
|
|
7524
7637
|
var context = React.useContext(CalendarContext);
|
|
7525
7638
|
var _React$useState = React.useState(false),
|
|
7526
7639
|
dayFocusable = _React$useState[0],
|
|
7527
7640
|
setDayFocusable = _React$useState[1];
|
|
7528
|
-
var _React$useState2 = React.useState(false),
|
|
7529
|
-
focusHeader = _React$useState2[0],
|
|
7530
|
-
setFocusHeader = _React$useState2[1];
|
|
7531
7641
|
var prevCalendarOpened = usePrevious(props.calendarOpened);
|
|
7532
|
-
var focusTrapElement = useFocusLock(props.calendarOpened
|
|
7642
|
+
var focusTrapElement = useFocusLock(props.calendarOpened);
|
|
7643
|
+
var monthContainerRef = React.useRef(null);
|
|
7533
7644
|
React.useEffect(function () {
|
|
7534
7645
|
if (!prevCalendarOpened && props.calendarOpened) {
|
|
7535
7646
|
lastFocus.current = document.activeElement;
|
|
@@ -7538,12 +7649,6 @@ var CalendarMonth = function CalendarMonth(props) {
|
|
|
7538
7649
|
context.setDateFocused(true);
|
|
7539
7650
|
}
|
|
7540
7651
|
}
|
|
7541
|
-
if (props.calendarOpened && !props.focusOnOpen && !focusHeader) {
|
|
7542
|
-
setFocusHeader(true);
|
|
7543
|
-
}
|
|
7544
|
-
if (prevCalendarOpened && !props.calendarOpened) {
|
|
7545
|
-
setFocusHeader(false);
|
|
7546
|
-
}
|
|
7547
7652
|
}, [props.calendarOpened, props.focusOnOpen]);
|
|
7548
7653
|
React.useEffect(function () {
|
|
7549
7654
|
if (prevCalendarOpened && !context.helperInformationShown) {
|
|
@@ -7589,10 +7694,9 @@ var CalendarMonth = function CalendarMonth(props) {
|
|
|
7589
7694
|
"data-testid": "monthContainer",
|
|
7590
7695
|
"data-visible": "true",
|
|
7591
7696
|
isInverse: context.isInverse,
|
|
7592
|
-
theme: theme
|
|
7697
|
+
theme: theme,
|
|
7698
|
+
ref: monthContainerRef
|
|
7593
7699
|
}, React.createElement(CalendarHeader, {
|
|
7594
|
-
ref: headingRef,
|
|
7595
|
-
focusHeader: focusHeader,
|
|
7596
7700
|
isInverse: context.isInverse
|
|
7597
7701
|
}), React.createElement(Table$1, {
|
|
7598
7702
|
onBlur: onCalendarTableBlur,
|
|
@@ -7805,7 +7909,7 @@ var DatePickerContainer = /*#__PURE__*/_styled("div", {
|
|
|
7805
7909
|
label: "DatePickerContainer"
|
|
7806
7910
|
})( {
|
|
7807
7911
|
name: "bjn8wh",
|
|
7808
|
-
styles: "position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAkBuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate } from '@floating-ui/react-dom';\r\nimport { addDays, endOfDay, isAfter, isBefore, isMatch, isSameMonth, isValid, parse, setHours, startOfDay, } from 'date-fns';\r\nimport { transparentize } from 'polished';\r\nimport { EventIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarMonth } from './CalendarMonth';\r\nimport { useMagmaFloating } from '../../hooks/useMagmaFloating';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Announce } from '../Announce';\r\nimport { Input } from '../Input';\r\nimport { InputType } from '../InputBase';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nimport { getCalendarMonthWeeks, getDateFromString, getNextMonthFromDate, getPrevMonthFromDate, handleKeyPress, i18nFormat as format, inDateRange, } from './utils';\r\nimport { omit, useForkedRef, useGenerateId } from '../../utils';\r\nconst DatePickerContainer = styled.div `\n  position: relative;\n`;\r\nconst DatePickerCalendar = styled.div `\n  border: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.15);\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: ${props => (props.opened ? 'block' : 'none')};\n  margin: ${props => props.theme.spaceScale.spacing01} 0px;\n  opacity: ${props => (props.opened ? '1' : '0')};\n  overflow: hidden;\n  transition: opacity 0.2s ease-in-out 0s;\n  width: 320px;\n`;\r\nexport const DatePicker = React.forwardRef((props, forwardedRef) => {\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const iconRef = React.useRef();\r\n    const inputRef = React.useRef();\r\n    const lastFocus = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const [helperInformationShown, setHelperInformationShown] = React.useState(false);\r\n    const [calendarOpened, setCalendarOpened] = React.useState(false);\r\n    const [dateFocused, setDateFocused] = React.useState(false);\r\n    const [focusedDate, setFocusedDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate) ||\r\n        setDefaultFocusedDate());\r\n    const [chosenDate, setChosenDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate));\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    React.useEffect(() => {\r\n        if (!calendarOpened) {\r\n            setDateFocused(false);\r\n        }\r\n    }, [calendarOpened]);\r\n    React.useEffect(() => {\r\n        if (props.value) {\r\n            setFocusedDate(setDateFromConsumer(props.value) || setDefaultFocusedDate());\r\n            setChosenDate(setDateFromConsumer(props.value));\r\n        }\r\n        if (props.value === null)\r\n            setChosenDate(undefined);\r\n    }, [props.value]);\r\n    function showHelperInformation() {\r\n        lastFocus.current = document.activeElement;\r\n        setHelperInformationShown(true);\r\n    }\r\n    function hideHelperInformation() {\r\n        lastFocus.current.focus();\r\n        setHelperInformationShown(false);\r\n    }\r\n    function closeHelperInformation() {\r\n        setHelperInformationShown(false);\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    const setFocusedTodayDate = (event) => {\r\n        const isKeyboardEvent = event.type === 'keydown';\r\n        if ((isKeyboardEvent &&\r\n            (event.key === ' ' ||\r\n                event.key === 'Enter')) ||\r\n            event.type === 'click') {\r\n            event.preventDefault();\r\n            setFocusedDate(setDefaultFocusedDate());\r\n        }\r\n    };\r\n    function setDateFromConsumer(date) {\r\n        const convertedDate = getDateFromString(date);\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        return date &&\r\n            inDateRange(convertedDate, convertedMinDate, convertedMaxDate)\r\n            ? convertedDate\r\n            : null;\r\n    }\r\n    function setDefaultFocusedDate() {\r\n        const newDate = new Date();\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        if (inDateRange(newDate, convertedMinDate, convertedMaxDate)) {\r\n            if (isBefore(startOfDay(newDate), convertedMinDate)) {\r\n                return addDays(newDate, 1);\r\n            }\r\n            return newDate;\r\n        }\r\n        else if (convertedMaxDate || convertedMinDate) {\r\n            return convertedMinDate ? convertedMinDate : convertedMaxDate;\r\n        }\r\n    }\r\n    function buildCalendarMonth(date, enableOutsideDates) {\r\n        const days = [\r\n            'sunday',\r\n            'monday',\r\n            'tuesday',\r\n            'wednesday',\r\n            'thursday',\r\n            'friday',\r\n            'saturday',\r\n        ];\r\n        const { startOfWeek } = i18n.datePicker;\r\n        return getCalendarMonthWeeks(date, enableOutsideDates, days.indexOf(startOfWeek));\r\n    }\r\n    function onPrevMonthClick() {\r\n        const newDate = getPrevMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function onNextMonthClick() {\r\n        const newDate = getNextMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function onDateChange(day) {\r\n        setChosenDate(day);\r\n        setCalendarOpened(false);\r\n    }\r\n    function reset() {\r\n        setFocusedDate(setDefaultFocusedDate());\r\n        setChosenDate(null);\r\n        setDateFocused(false);\r\n    }\r\n    function isValidDateFromString(value, day) {\r\n        const isValidDateFormat = isMatch(value, i18n.dateFormat);\r\n        const parsedDate = parse(value, i18n.dateFormat, new Date());\r\n        const isValidDate = isValid(parsedDate);\r\n        return isValidDateFormat && isValidDate;\r\n    }\r\n    function handleInputChange(event) {\r\n        const { value } = event.target;\r\n        const day = new Date(value);\r\n        setCalendarOpened(false);\r\n        props.onInputChange &&\r\n            typeof props.onInputChange === 'function' &&\r\n            props.onInputChange(event);\r\n        const isValidDay = isValidDateFromString(value, day);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(isValidDay ? day.toISOString() : value, event);\r\n    }\r\n    function handleInputFocus(event) {\r\n        props.onInputFocus &&\r\n            typeof props.onInputFocus === 'function' &&\r\n            props.onInputFocus(event);\r\n    }\r\n    function handleInputBlur(event) {\r\n        const { value } = inputRef.current;\r\n        const day = parse(value, i18n.dateFormat, new Date());\r\n        if (isValidDateFromString(value, day)) {\r\n            handleDateChange(day, event);\r\n        }\r\n        else {\r\n            reset && typeof reset === 'function' && reset();\r\n        }\r\n        props.onInputBlur &&\r\n            typeof props.onInputBlur === 'function' &&\r\n            props.onInputBlur(event);\r\n    }\r\n    function handleInputKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            setCalendarOpened(false);\r\n            inputRef.current.focus();\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            setCalendarOpened(false);\r\n            iconRef.current.focus();\r\n        }\r\n        if (dateFocused && document.activeElement.closest('table')) {\r\n            const newChosenDate = handleKeyPress(event, focusedDate, setCalendarOpened, showHelperInformation, onDateChange, iconRef);\r\n            if (newChosenDate) {\r\n                if (minDate && maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate)) &&\r\n                        isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (minDate && !maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (maxDate && !minDate) {\r\n                    if (isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else {\r\n                    setFocusedDate(newChosenDate);\r\n                }\r\n            }\r\n        }\r\n    }\r\n    function handleDateChange(day, event) {\r\n        props.onDateChange &&\r\n            typeof props.onDateChange === 'function' &&\r\n            props.onDateChange(day, event);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(day?.toISOString(), event);\r\n        onDateChange(day);\r\n        setFocusedDate(isAfter(setHours(day, 12), minDate) ? day : setDefaultFocusedDate);\r\n    }\r\n    function handleDaySelection(day, event) {\r\n        handleDateChange(day, event);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleCalendarBlur(event) {\r\n        const { currentTarget } = event;\r\n        // timeout needed for active element to update. Browser behavior.\r\n        // https://bugzilla.mozilla.org/show_bug.cgi?id=452307\r\n        setTimeout(() => {\r\n            const isInCalendar = currentTarget.contains(document.activeElement);\r\n            if (!isInCalendar && !helperInformationShown) {\r\n                setCalendarOpened(false);\r\n            }\r\n        }, 0);\r\n    }\r\n    function handleCloseButtonClick(event) {\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    function toggleCalendarOpened() {\r\n        setCalendarOpened(opened => !opened);\r\n    }\r\n    const { placeholder, testId, ...rest } = props;\r\n    const other = omit(['onDateChange', 'onInputChange', 'onInputBlur', 'onInputFocus'], rest);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const minDate = getDateFromString(props.minDate);\r\n    const maxDate = getDateFromString(props.maxDate);\r\n    const dateFormat = i18n.dateFormat;\r\n    const inputValue = chosenDate ? format(chosenDate, dateFormat) : '';\r\n    const { floatingStyles, refs, elements, update } = useMagmaFloating();\r\n    React.useEffect(() => {\r\n        const referenceDateInput = elements.reference;\r\n        const floatingCalendar = elements.floating;\r\n        if (calendarOpened && referenceDateInput && floatingCalendar) {\r\n            return autoUpdate(referenceDateInput, floatingCalendar, update);\r\n        }\r\n    }, [calendarOpened, elements, update]);\r\n    return (React.createElement(CalendarContext.Provider, { value: {\r\n            chosenDate,\r\n            focusedDate,\r\n            dateFocused,\r\n            maxDate,\r\n            minDate,\r\n            helperInformationShown,\r\n            isInverse,\r\n            buildCalendarMonth,\r\n            showHelperInformation,\r\n            hideHelperInformation,\r\n            onKeyDown: handleKeyDown,\r\n            onPrevMonthClick,\r\n            onNextMonthClick,\r\n            onDateChange: handleDaySelection,\r\n            setDateFocused,\r\n            setFocusedTodayDate,\r\n            setFocusedDate,\r\n            onClose: closeHelperInformation,\r\n        } },\r\n        React.createElement(DatePickerContainer, { \"data-testid\": testId, onBlur: handleCalendarBlur },\r\n            React.createElement(Announce, null, calendarOpened && (React.createElement(VisuallyHidden, null, i18n.datePicker.calendarOpenAnnounce))),\r\n            React.createElement(Input, Object.assign({}, other, { icon: React.createElement(EventIcon, null), iconAriaLabel: i18n.datePicker.calendarIconAriaLabel, iconRef: iconRef, onIconClick: toggleCalendarOpened, onIconKeyDown: handleInputKeyDown, id: id, isInverse: isInverse, ref: ref, onChange: handleInputChange, onBlur: handleInputBlur, onFocus: handleInputFocus, onKeyDown: handleInputKeyDown, onDateChange: handleDateChange, placeholder: placeholder ? placeholder : dateFormat.toLowerCase(), type: InputType.text, value: inputValue, setReference: refs.setReference })),\r\n            React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n                React.createElement(\"div\", { ref: el => calendarOpened && refs.setFloating(el), style: { ...floatingStyles, zIndex: '998' } },\r\n                    React.createElement(DatePickerCalendar, { \"data-testid\": \"calendarContainer\", opened: calendarOpened, isInverse: isInverse, theme: theme },\r\n                        React.createElement(CalendarMonth, { focusOnOpen: calendarOpened &&\r\n                                Boolean(focusedDate) &&\r\n                                Boolean(chosenDate), isInverse: isInverse, handleCloseButtonClick: handleCloseButtonClick, calendarOpened: calendarOpened, setDateFocused: setDateFocused })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
7912
|
+
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 inputRef = React.useRef();\r\n    const lastFocus = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const [helperInformationShown, setHelperInformationShown] = React.useState(false);\r\n    const [calendarOpened, setCalendarOpened] = React.useState(false);\r\n    const [dateFocused, setDateFocused] = React.useState(false);\r\n    const [focusedDate, setFocusedDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate) ||\r\n        setDefaultFocusedDate());\r\n    const [chosenDate, setChosenDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate));\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    React.useEffect(() => {\r\n        if (!calendarOpened) {\r\n            setDateFocused(false);\r\n        }\r\n    }, [calendarOpened]);\r\n    React.useEffect(() => {\r\n        if (props.value) {\r\n            setFocusedDate(setDateFromConsumer(props.value) || setDefaultFocusedDate());\r\n            setChosenDate(setDateFromConsumer(props.value));\r\n        }\r\n        if (props.value === null)\r\n            setChosenDate(undefined);\r\n    }, [props.value]);\r\n    function showHelperInformation() {\r\n        lastFocus.current = document.activeElement;\r\n        setHelperInformationShown(true);\r\n    }\r\n    function hideHelperInformation() {\r\n        lastFocus.current.focus();\r\n        setHelperInformationShown(false);\r\n    }\r\n    function closeHelperInformation() {\r\n        setHelperInformationShown(false);\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    const setFocusedTodayDate = (event) => {\r\n        const isKeyboardEvent = event.type === 'keydown';\r\n        if ((isKeyboardEvent &&\r\n            (event.key === ' ' ||\r\n                event.key === 'Enter')) ||\r\n            event.type === 'click') {\r\n            event.preventDefault();\r\n            setFocusedDate(setDefaultFocusedDate());\r\n        }\r\n    };\r\n    function setDateFromConsumer(date) {\r\n        const convertedDate = getDateFromString(date);\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        return date &&\r\n            inDateRange(convertedDate, convertedMinDate, convertedMaxDate)\r\n            ? convertedDate\r\n            : null;\r\n    }\r\n    function setDefaultFocusedDate() {\r\n        const newDate = new Date();\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        if (inDateRange(newDate, convertedMinDate, convertedMaxDate)) {\r\n            if (isBefore(startOfDay(newDate), convertedMinDate)) {\r\n                return addDays(newDate, 1);\r\n            }\r\n            return newDate;\r\n        }\r\n        else if (convertedMaxDate || convertedMinDate) {\r\n            return convertedMinDate ? convertedMinDate : convertedMaxDate;\r\n        }\r\n    }\r\n    function buildCalendarMonth(date, enableOutsideDates) {\r\n        const days = [\r\n            'sunday',\r\n            'monday',\r\n            'tuesday',\r\n            'wednesday',\r\n            'thursday',\r\n            'friday',\r\n            'saturday',\r\n        ];\r\n        const { startOfWeek } = i18n.datePicker;\r\n        return getCalendarMonthWeeks(date, enableOutsideDates, days.indexOf(startOfWeek));\r\n    }\r\n    function onPrevMonthClick() {\r\n        const newDate = getPrevMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function onNextMonthClick() {\r\n        const newDate = getNextMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function 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        setCalendarOpened(false);\r\n    }\r\n    function reset() {\r\n        setFocusedDate(setDefaultFocusedDate());\r\n        setChosenDate(null);\r\n        setDateFocused(false);\r\n    }\r\n    function isValidDateFromString(value, day) {\r\n        const isValidDateFormat = isMatch(value, i18n.dateFormat);\r\n        const parsedDate = parse(value, i18n.dateFormat, new Date());\r\n        const isValidDate = isValid(parsedDate);\r\n        return isValidDateFormat && isValidDate;\r\n    }\r\n    function handleInputChange(event) {\r\n        const { value } = event.target;\r\n        const day = new Date(value);\r\n        setCalendarOpened(false);\r\n        props.onInputChange &&\r\n            typeof props.onInputChange === 'function' &&\r\n            props.onInputChange(event);\r\n        const isValidDay = isValidDateFromString(value, day);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(isValidDay ? day.toISOString() : value, event);\r\n    }\r\n    function handleInputFocus(event) {\r\n        props.onInputFocus &&\r\n            typeof props.onInputFocus === 'function' &&\r\n            props.onInputFocus(event);\r\n    }\r\n    function handleInputBlur(event) {\r\n        const { value } = inputRef.current;\r\n        const day = parse(value, i18n.dateFormat, new Date());\r\n        if (isValidDateFromString(value, day)) {\r\n            handleDateChange(day, event);\r\n        }\r\n        else {\r\n            reset && typeof reset === 'function' && reset();\r\n        }\r\n        props.onInputBlur &&\r\n            typeof props.onInputBlur === 'function' &&\r\n            props.onInputBlur(event);\r\n    }\r\n    function handleInputKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            setCalendarOpened(false);\r\n            inputRef.current.focus();\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            setCalendarOpened(false);\r\n            iconRef.current.focus();\r\n        }\r\n        if (dateFocused && document.activeElement.closest('table')) {\r\n            const newChosenDate = handleKeyPress(event, focusedDate, setCalendarOpened, showHelperInformation, onDateChange, iconRef);\r\n            if (newChosenDate) {\r\n                if (minDate && maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate)) &&\r\n                        isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (minDate && !maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (maxDate && !minDate) {\r\n                    if (isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else {\r\n                    setFocusedDate(newChosenDate);\r\n                }\r\n            }\r\n        }\r\n    }\r\n    function handleDateChange(day, event) {\r\n        props.onDateChange &&\r\n            typeof props.onDateChange === 'function' &&\r\n            props.onDateChange(day, event);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(day?.toISOString(), event);\r\n        onDateChange(day);\r\n        setFocusedDate(day);\r\n    }\r\n    function handleDaySelection(day, event) {\r\n        handleDateChange(day, event);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleCalendarBlur(event) {\r\n        const { currentTarget } = event;\r\n        // timeout needed for active element to update. Browser behavior.\r\n        // https://bugzilla.mozilla.org/show_bug.cgi?id=452307\r\n        setTimeout(() => {\r\n            const isInCalendar = currentTarget.contains(document.activeElement);\r\n            if (!isInCalendar && !helperInformationShown) {\r\n                setCalendarOpened(false);\r\n            }\r\n        }, 0);\r\n    }\r\n    function handleCloseButtonClick(event) {\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    function toggleCalendarOpened() {\r\n        setCalendarOpened(opened => !opened);\r\n    }\r\n    const { placeholder, testId, ...rest } = props;\r\n    const other = omit(['onDateChange', 'onInputChange', 'onInputBlur', 'onInputFocus'], rest);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const minDate = getDateFromString(props.minDate);\r\n    const maxDate = getDateFromString(props.maxDate);\r\n    const dateFormat = i18n.dateFormat;\r\n    const inputValue = chosenDate ? format(chosenDate, dateFormat) : '';\r\n    const { floatingStyles, refs, elements, update } = useMagmaFloating();\r\n    React.useEffect(() => {\r\n        const referenceDateInput = elements.reference;\r\n        const floatingCalendar = elements.floating;\r\n        if (calendarOpened && referenceDateInput && floatingCalendar) {\r\n            return autoUpdate(referenceDateInput, floatingCalendar, update);\r\n        }\r\n    }, [calendarOpened, elements, update]);\r\n    return (React.createElement(CalendarContext.Provider, { value: {\r\n            chosenDate,\r\n            focusedDate,\r\n            dateFocused,\r\n            maxDate,\r\n            minDate,\r\n            helperInformationShown,\r\n            isInverse,\r\n            buildCalendarMonth,\r\n            showHelperInformation,\r\n            hideHelperInformation,\r\n            onKeyDown: handleKeyDown,\r\n            onPrevMonthClick,\r\n            onNextMonthClick,\r\n            onDateChange: handleDaySelection,\r\n            setDateFocused,\r\n            setFocusedTodayDate,\r\n            setFocusedDate,\r\n            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 })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
7809
7913
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
|
|
7810
7914
|
});
|
|
7811
7915
|
var DatePickerCalendar = /*#__PURE__*/_styled("div", {
|
|
@@ -7823,7 +7927,7 @@ var DatePickerCalendar = /*#__PURE__*/_styled("div", {
|
|
|
7823
7927
|
return props.theme.spaceScale.spacing01;
|
|
7824
7928
|
}, " 0px;opacity:", function (props) {
|
|
7825
7929
|
return props.opened ? '1' : '0';
|
|
7826
|
-
}, ";overflow:hidden;transition:opacity 0.2s ease-in-out 0s;width:320px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqBsC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate } from '@floating-ui/react-dom';\r\nimport { addDays, endOfDay, isAfter, isBefore, isMatch, isSameMonth, isValid, parse, setHours, startOfDay, } from 'date-fns';\r\nimport { transparentize } from 'polished';\r\nimport { EventIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarMonth } from './CalendarMonth';\r\nimport { useMagmaFloating } from '../../hooks/useMagmaFloating';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Announce } from '../Announce';\r\nimport { Input } from '../Input';\r\nimport { InputType } from '../InputBase';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nimport { getCalendarMonthWeeks, getDateFromString, getNextMonthFromDate, getPrevMonthFromDate, handleKeyPress, i18nFormat as format, inDateRange, } from './utils';\r\nimport { omit, useForkedRef, useGenerateId } from '../../utils';\r\nconst DatePickerContainer = styled.div `\n  position: relative;\n`;\r\nconst DatePickerCalendar = styled.div `\n  border: 1px solid\n    ${props => props.isInverse\r\n    ? transparentize(0.5, props.theme.colors.neutral100)\r\n    : props.theme.colors.neutral300};\n  border-radius: ${props => props.theme.borderRadius};\n  box-shadow: 0 2px 6px 0 rgba(0, 0, 0, 0.15);\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  display: ${props => (props.opened ? 'block' : 'none')};\n  margin: ${props => props.theme.spaceScale.spacing01} 0px;\n  opacity: ${props => (props.opened ? '1' : '0')};\n  overflow: hidden;\n  transition: opacity 0.2s ease-in-out 0s;\n  width: 320px;\n`;\r\nexport const DatePicker = React.forwardRef((props, forwardedRef) => {\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    const iconRef = React.useRef();\r\n    const inputRef = React.useRef();\r\n    const lastFocus = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const [helperInformationShown, setHelperInformationShown] = React.useState(false);\r\n    const [calendarOpened, setCalendarOpened] = React.useState(false);\r\n    const [dateFocused, setDateFocused] = React.useState(false);\r\n    const [focusedDate, setFocusedDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate) ||\r\n        setDefaultFocusedDate());\r\n    const [chosenDate, setChosenDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate));\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    React.useEffect(() => {\r\n        if (!calendarOpened) {\r\n            setDateFocused(false);\r\n        }\r\n    }, [calendarOpened]);\r\n    React.useEffect(() => {\r\n        if (props.value) {\r\n            setFocusedDate(setDateFromConsumer(props.value) || setDefaultFocusedDate());\r\n            setChosenDate(setDateFromConsumer(props.value));\r\n        }\r\n        if (props.value === null)\r\n            setChosenDate(undefined);\r\n    }, [props.value]);\r\n    function showHelperInformation() {\r\n        lastFocus.current = document.activeElement;\r\n        setHelperInformationShown(true);\r\n    }\r\n    function hideHelperInformation() {\r\n        lastFocus.current.focus();\r\n        setHelperInformationShown(false);\r\n    }\r\n    function closeHelperInformation() {\r\n        setHelperInformationShown(false);\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    const setFocusedTodayDate = (event) => {\r\n        const isKeyboardEvent = event.type === 'keydown';\r\n        if ((isKeyboardEvent &&\r\n            (event.key === ' ' ||\r\n                event.key === 'Enter')) ||\r\n            event.type === 'click') {\r\n            event.preventDefault();\r\n            setFocusedDate(setDefaultFocusedDate());\r\n        }\r\n    };\r\n    function setDateFromConsumer(date) {\r\n        const convertedDate = getDateFromString(date);\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        return date &&\r\n            inDateRange(convertedDate, convertedMinDate, convertedMaxDate)\r\n            ? convertedDate\r\n            : null;\r\n    }\r\n    function setDefaultFocusedDate() {\r\n        const newDate = new Date();\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        if (inDateRange(newDate, convertedMinDate, convertedMaxDate)) {\r\n            if (isBefore(startOfDay(newDate), convertedMinDate)) {\r\n                return addDays(newDate, 1);\r\n            }\r\n            return newDate;\r\n        }\r\n        else if (convertedMaxDate || convertedMinDate) {\r\n            return convertedMinDate ? convertedMinDate : convertedMaxDate;\r\n        }\r\n    }\r\n    function buildCalendarMonth(date, enableOutsideDates) {\r\n        const days = [\r\n            'sunday',\r\n            'monday',\r\n            'tuesday',\r\n            'wednesday',\r\n            'thursday',\r\n            'friday',\r\n            'saturday',\r\n        ];\r\n        const { startOfWeek } = i18n.datePicker;\r\n        return getCalendarMonthWeeks(date, enableOutsideDates, days.indexOf(startOfWeek));\r\n    }\r\n    function onPrevMonthClick() {\r\n        const newDate = getPrevMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function onNextMonthClick() {\r\n        const newDate = getNextMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function onDateChange(day) {\r\n        setChosenDate(day);\r\n        setCalendarOpened(false);\r\n    }\r\n    function reset() {\r\n        setFocusedDate(setDefaultFocusedDate());\r\n        setChosenDate(null);\r\n        setDateFocused(false);\r\n    }\r\n    function isValidDateFromString(value, day) {\r\n        const isValidDateFormat = isMatch(value, i18n.dateFormat);\r\n        const parsedDate = parse(value, i18n.dateFormat, new Date());\r\n        const isValidDate = isValid(parsedDate);\r\n        return isValidDateFormat && isValidDate;\r\n    }\r\n    function handleInputChange(event) {\r\n        const { value } = event.target;\r\n        const day = new Date(value);\r\n        setCalendarOpened(false);\r\n        props.onInputChange &&\r\n            typeof props.onInputChange === 'function' &&\r\n            props.onInputChange(event);\r\n        const isValidDay = isValidDateFromString(value, day);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(isValidDay ? day.toISOString() : value, event);\r\n    }\r\n    function handleInputFocus(event) {\r\n        props.onInputFocus &&\r\n            typeof props.onInputFocus === 'function' &&\r\n            props.onInputFocus(event);\r\n    }\r\n    function handleInputBlur(event) {\r\n        const { value } = inputRef.current;\r\n        const day = parse(value, i18n.dateFormat, new Date());\r\n        if (isValidDateFromString(value, day)) {\r\n            handleDateChange(day, event);\r\n        }\r\n        else {\r\n            reset && typeof reset === 'function' && reset();\r\n        }\r\n        props.onInputBlur &&\r\n            typeof props.onInputBlur === 'function' &&\r\n            props.onInputBlur(event);\r\n    }\r\n    function handleInputKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            setCalendarOpened(false);\r\n            inputRef.current.focus();\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            setCalendarOpened(false);\r\n            iconRef.current.focus();\r\n        }\r\n        if (dateFocused && document.activeElement.closest('table')) {\r\n            const newChosenDate = handleKeyPress(event, focusedDate, setCalendarOpened, showHelperInformation, onDateChange, iconRef);\r\n            if (newChosenDate) {\r\n                if (minDate && maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate)) &&\r\n                        isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (minDate && !maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (maxDate && !minDate) {\r\n                    if (isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else {\r\n                    setFocusedDate(newChosenDate);\r\n                }\r\n            }\r\n        }\r\n    }\r\n    function handleDateChange(day, event) {\r\n        props.onDateChange &&\r\n            typeof props.onDateChange === 'function' &&\r\n            props.onDateChange(day, event);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(day?.toISOString(), event);\r\n        onDateChange(day);\r\n        setFocusedDate(isAfter(setHours(day, 12), minDate) ? day : setDefaultFocusedDate);\r\n    }\r\n    function handleDaySelection(day, event) {\r\n        handleDateChange(day, event);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleCalendarBlur(event) {\r\n        const { currentTarget } = event;\r\n        // timeout needed for active element to update. Browser behavior.\r\n        // https://bugzilla.mozilla.org/show_bug.cgi?id=452307\r\n        setTimeout(() => {\r\n            const isInCalendar = currentTarget.contains(document.activeElement);\r\n            if (!isInCalendar && !helperInformationShown) {\r\n                setCalendarOpened(false);\r\n            }\r\n        }, 0);\r\n    }\r\n    function handleCloseButtonClick(event) {\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    function toggleCalendarOpened() {\r\n        setCalendarOpened(opened => !opened);\r\n    }\r\n    const { placeholder, testId, ...rest } = props;\r\n    const other = omit(['onDateChange', 'onInputChange', 'onInputBlur', 'onInputFocus'], rest);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const minDate = getDateFromString(props.minDate);\r\n    const maxDate = getDateFromString(props.maxDate);\r\n    const dateFormat = i18n.dateFormat;\r\n    const inputValue = chosenDate ? format(chosenDate, dateFormat) : '';\r\n    const { floatingStyles, refs, elements, update } = useMagmaFloating();\r\n    React.useEffect(() => {\r\n        const referenceDateInput = elements.reference;\r\n        const floatingCalendar = elements.floating;\r\n        if (calendarOpened && referenceDateInput && floatingCalendar) {\r\n            return autoUpdate(referenceDateInput, floatingCalendar, update);\r\n        }\r\n    }, [calendarOpened, elements, update]);\r\n    return (React.createElement(CalendarContext.Provider, { value: {\r\n            chosenDate,\r\n            focusedDate,\r\n            dateFocused,\r\n            maxDate,\r\n            minDate,\r\n            helperInformationShown,\r\n            isInverse,\r\n            buildCalendarMonth,\r\n            showHelperInformation,\r\n            hideHelperInformation,\r\n            onKeyDown: handleKeyDown,\r\n            onPrevMonthClick,\r\n            onNextMonthClick,\r\n            onDateChange: handleDaySelection,\r\n            setDateFocused,\r\n            setFocusedTodayDate,\r\n            setFocusedDate,\r\n            onClose: closeHelperInformation,\r\n        } },\r\n        React.createElement(DatePickerContainer, { \"data-testid\": testId, onBlur: handleCalendarBlur },\r\n            React.createElement(Announce, null, calendarOpened && (React.createElement(VisuallyHidden, null, i18n.datePicker.calendarOpenAnnounce))),\r\n            React.createElement(Input, Object.assign({}, other, { icon: React.createElement(EventIcon, null), iconAriaLabel: i18n.datePicker.calendarIconAriaLabel, iconRef: iconRef, onIconClick: toggleCalendarOpened, onIconKeyDown: handleInputKeyDown, id: id, isInverse: isInverse, ref: ref, onChange: handleInputChange, onBlur: handleInputBlur, onFocus: handleInputFocus, onKeyDown: handleInputKeyDown, onDateChange: handleDateChange, placeholder: placeholder ? placeholder : dateFormat.toLowerCase(), type: InputType.text, value: inputValue, setReference: refs.setReference })),\r\n            React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n                React.createElement(\"div\", { ref: el => calendarOpened && refs.setFloating(el), style: { ...floatingStyles, zIndex: '998' } },\r\n                    React.createElement(DatePickerCalendar, { \"data-testid\": \"calendarContainer\", opened: calendarOpened, isInverse: isInverse, theme: theme },\r\n                        React.createElement(CalendarMonth, { focusOnOpen: calendarOpened &&\r\n                                Boolean(focusedDate) &&\r\n                                Boolean(chosenDate), isInverse: isInverse, handleCloseButtonClick: handleCloseButtonClick, calendarOpened: calendarOpened, setDateFocused: setDateFocused })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
7930
|
+
}, ";overflow:hidden;transition:opacity 0.2s ease-in-out 0s;width:320px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqBsC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate } from '@floating-ui/react-dom';\r\nimport { addDays, endOfDay, isAfter, isBefore, isMatch, isSameMonth, isValid, parse, setHours, startOfDay, } from 'date-fns';\r\nimport { transparentize } from 'polished';\r\nimport { EventIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarMonth } from './CalendarMonth';\r\nimport { useMagmaFloating } from '../../hooks/useMagmaFloating';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { Announce } from '../Announce';\r\nimport { Input } from '../Input';\r\nimport { InputType } from '../InputBase';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nimport { getCalendarMonthWeeks, getDateFromString, getNextMonthFromDate, getPrevMonthFromDate, handleKeyPress, 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 inputRef = React.useRef();\r\n    const lastFocus = React.useRef();\r\n    const id = useGenerateId(props.id);\r\n    const [helperInformationShown, setHelperInformationShown] = React.useState(false);\r\n    const [calendarOpened, setCalendarOpened] = React.useState(false);\r\n    const [dateFocused, setDateFocused] = React.useState(false);\r\n    const [focusedDate, setFocusedDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate) ||\r\n        setDefaultFocusedDate());\r\n    const [chosenDate, setChosenDate] = React.useState(setDateFromConsumer(props.value || props.defaultDate));\r\n    const ref = useForkedRef(forwardedRef, inputRef);\r\n    React.useEffect(() => {\r\n        if (!calendarOpened) {\r\n            setDateFocused(false);\r\n        }\r\n    }, [calendarOpened]);\r\n    React.useEffect(() => {\r\n        if (props.value) {\r\n            setFocusedDate(setDateFromConsumer(props.value) || setDefaultFocusedDate());\r\n            setChosenDate(setDateFromConsumer(props.value));\r\n        }\r\n        if (props.value === null)\r\n            setChosenDate(undefined);\r\n    }, [props.value]);\r\n    function showHelperInformation() {\r\n        lastFocus.current = document.activeElement;\r\n        setHelperInformationShown(true);\r\n    }\r\n    function hideHelperInformation() {\r\n        lastFocus.current.focus();\r\n        setHelperInformationShown(false);\r\n    }\r\n    function closeHelperInformation() {\r\n        setHelperInformationShown(false);\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    const setFocusedTodayDate = (event) => {\r\n        const isKeyboardEvent = event.type === 'keydown';\r\n        if ((isKeyboardEvent &&\r\n            (event.key === ' ' ||\r\n                event.key === 'Enter')) ||\r\n            event.type === 'click') {\r\n            event.preventDefault();\r\n            setFocusedDate(setDefaultFocusedDate());\r\n        }\r\n    };\r\n    function setDateFromConsumer(date) {\r\n        const convertedDate = getDateFromString(date);\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        return date &&\r\n            inDateRange(convertedDate, convertedMinDate, convertedMaxDate)\r\n            ? convertedDate\r\n            : null;\r\n    }\r\n    function setDefaultFocusedDate() {\r\n        const newDate = new Date();\r\n        const convertedMinDate = getDateFromString(props.minDate);\r\n        const convertedMaxDate = getDateFromString(props.maxDate);\r\n        if (inDateRange(newDate, convertedMinDate, convertedMaxDate)) {\r\n            if (isBefore(startOfDay(newDate), convertedMinDate)) {\r\n                return addDays(newDate, 1);\r\n            }\r\n            return newDate;\r\n        }\r\n        else if (convertedMaxDate || convertedMinDate) {\r\n            return convertedMinDate ? convertedMinDate : convertedMaxDate;\r\n        }\r\n    }\r\n    function buildCalendarMonth(date, enableOutsideDates) {\r\n        const days = [\r\n            'sunday',\r\n            'monday',\r\n            'tuesday',\r\n            'wednesday',\r\n            'thursday',\r\n            'friday',\r\n            'saturday',\r\n        ];\r\n        const { startOfWeek } = i18n.datePicker;\r\n        return getCalendarMonthWeeks(date, enableOutsideDates, days.indexOf(startOfWeek));\r\n    }\r\n    function onPrevMonthClick() {\r\n        const newDate = getPrevMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function onNextMonthClick() {\r\n        const newDate = getNextMonthFromDate(focusedDate);\r\n        setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);\r\n    }\r\n    function 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        setCalendarOpened(false);\r\n    }\r\n    function reset() {\r\n        setFocusedDate(setDefaultFocusedDate());\r\n        setChosenDate(null);\r\n        setDateFocused(false);\r\n    }\r\n    function isValidDateFromString(value, day) {\r\n        const isValidDateFormat = isMatch(value, i18n.dateFormat);\r\n        const parsedDate = parse(value, i18n.dateFormat, new Date());\r\n        const isValidDate = isValid(parsedDate);\r\n        return isValidDateFormat && isValidDate;\r\n    }\r\n    function handleInputChange(event) {\r\n        const { value } = event.target;\r\n        const day = new Date(value);\r\n        setCalendarOpened(false);\r\n        props.onInputChange &&\r\n            typeof props.onInputChange === 'function' &&\r\n            props.onInputChange(event);\r\n        const isValidDay = isValidDateFromString(value, day);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(isValidDay ? day.toISOString() : value, event);\r\n    }\r\n    function handleInputFocus(event) {\r\n        props.onInputFocus &&\r\n            typeof props.onInputFocus === 'function' &&\r\n            props.onInputFocus(event);\r\n    }\r\n    function handleInputBlur(event) {\r\n        const { value } = inputRef.current;\r\n        const day = parse(value, i18n.dateFormat, new Date());\r\n        if (isValidDateFromString(value, day)) {\r\n            handleDateChange(day, event);\r\n        }\r\n        else {\r\n            reset && typeof reset === 'function' && reset();\r\n        }\r\n        props.onInputBlur &&\r\n            typeof props.onInputBlur === 'function' &&\r\n            props.onInputBlur(event);\r\n    }\r\n    function handleInputKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.preventDefault();\r\n            setCalendarOpened(false);\r\n            inputRef.current.focus();\r\n        }\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            setCalendarOpened(false);\r\n            iconRef.current.focus();\r\n        }\r\n        if (dateFocused && document.activeElement.closest('table')) {\r\n            const newChosenDate = handleKeyPress(event, focusedDate, setCalendarOpened, showHelperInformation, onDateChange, iconRef);\r\n            if (newChosenDate) {\r\n                if (minDate && maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate)) &&\r\n                        isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (minDate && !maxDate) {\r\n                    if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else if (maxDate && !minDate) {\r\n                    if (isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {\r\n                        setFocusedDate(newChosenDate);\r\n                    }\r\n                }\r\n                else {\r\n                    setFocusedDate(newChosenDate);\r\n                }\r\n            }\r\n        }\r\n    }\r\n    function handleDateChange(day, event) {\r\n        props.onDateChange &&\r\n            typeof props.onDateChange === 'function' &&\r\n            props.onDateChange(day, event);\r\n        props.onChange &&\r\n            typeof props.onChange === 'function' &&\r\n            props.onChange(day?.toISOString(), event);\r\n        onDateChange(day);\r\n        setFocusedDate(day);\r\n    }\r\n    function handleDaySelection(day, event) {\r\n        handleDateChange(day, event);\r\n        inputRef.current.focus();\r\n    }\r\n    function handleCalendarBlur(event) {\r\n        const { currentTarget } = event;\r\n        // timeout needed for active element to update. Browser behavior.\r\n        // https://bugzilla.mozilla.org/show_bug.cgi?id=452307\r\n        setTimeout(() => {\r\n            const isInCalendar = currentTarget.contains(document.activeElement);\r\n            if (!isInCalendar && !helperInformationShown) {\r\n                setCalendarOpened(false);\r\n            }\r\n        }, 0);\r\n    }\r\n    function handleCloseButtonClick(event) {\r\n        iconRef.current.focus();\r\n        setCalendarOpened(false);\r\n    }\r\n    function toggleCalendarOpened() {\r\n        setCalendarOpened(opened => !opened);\r\n    }\r\n    const { placeholder, testId, ...rest } = props;\r\n    const other = omit(['onDateChange', 'onInputChange', 'onInputBlur', 'onInputFocus'], rest);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    const minDate = getDateFromString(props.minDate);\r\n    const maxDate = getDateFromString(props.maxDate);\r\n    const dateFormat = i18n.dateFormat;\r\n    const inputValue = chosenDate ? format(chosenDate, dateFormat) : '';\r\n    const { floatingStyles, refs, elements, update } = useMagmaFloating();\r\n    React.useEffect(() => {\r\n        const referenceDateInput = elements.reference;\r\n        const floatingCalendar = elements.floating;\r\n        if (calendarOpened && referenceDateInput && floatingCalendar) {\r\n            return autoUpdate(referenceDateInput, floatingCalendar, update);\r\n        }\r\n    }, [calendarOpened, elements, update]);\r\n    return (React.createElement(CalendarContext.Provider, { value: {\r\n            chosenDate,\r\n            focusedDate,\r\n            dateFocused,\r\n            maxDate,\r\n            minDate,\r\n            helperInformationShown,\r\n            isInverse,\r\n            buildCalendarMonth,\r\n            showHelperInformation,\r\n            hideHelperInformation,\r\n            onKeyDown: handleKeyDown,\r\n            onPrevMonthClick,\r\n            onNextMonthClick,\r\n            onDateChange: handleDaySelection,\r\n            setDateFocused,\r\n            setFocusedTodayDate,\r\n            setFocusedDate,\r\n            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 })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
7827
7931
|
var DatePicker = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
|
|
7828
7932
|
var theme = React.useContext(ThemeContext);
|
|
7829
7933
|
var i18n = React.useContext(I18nContext);
|
|
@@ -7911,6 +8015,14 @@ var DatePicker = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
|
|
|
7911
8015
|
var newDate = getNextMonthFromDate(focusedDate);
|
|
7912
8016
|
setFocusedDate(dateFns.isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);
|
|
7913
8017
|
}
|
|
8018
|
+
function setMonthFocusedDate(monthNumber) {
|
|
8019
|
+
var newDate = setMonthForDate(focusedDate, monthNumber);
|
|
8020
|
+
setFocusedDate(newDate);
|
|
8021
|
+
}
|
|
8022
|
+
function setYearFocusedDate(yearNumber) {
|
|
8023
|
+
var newDate = setYearForDate(focusedDate, yearNumber);
|
|
8024
|
+
setFocusedDate(newDate);
|
|
8025
|
+
}
|
|
7914
8026
|
function onDateChange(day) {
|
|
7915
8027
|
setChosenDate(day);
|
|
7916
8028
|
setCalendarOpened(false);
|
|
@@ -7985,7 +8097,7 @@ var DatePicker = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
|
|
|
7985
8097
|
props.onDateChange && typeof props.onDateChange === 'function' && props.onDateChange(day, event);
|
|
7986
8098
|
props.onChange && typeof props.onChange === 'function' && props.onChange(day == null ? void 0 : day.toISOString(), event);
|
|
7987
8099
|
onDateChange(day);
|
|
7988
|
-
setFocusedDate(
|
|
8100
|
+
setFocusedDate(day);
|
|
7989
8101
|
}
|
|
7990
8102
|
function handleDaySelection(day, event) {
|
|
7991
8103
|
handleDateChange(day, event);
|
|
@@ -8051,6 +8163,8 @@ var DatePicker = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
|
|
|
8051
8163
|
setDateFocused: setDateFocused,
|
|
8052
8164
|
setFocusedTodayDate: setFocusedTodayDate,
|
|
8053
8165
|
setFocusedDate: setFocusedDate,
|
|
8166
|
+
setMonthFocusedDate: setMonthFocusedDate,
|
|
8167
|
+
setYearFocusedDate: setYearFocusedDate,
|
|
8054
8168
|
onClose: closeHelperInformation
|
|
8055
8169
|
}
|
|
8056
8170
|
}, React.createElement(DatePickerContainer, {
|