react-magma-dom 4.7.0-next.21 → 4.7.0-next.22
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 +1 -0
- package/dist/components/DatePicker/HelperInformation.d.ts +1 -0
- package/dist/esm/index.js +150 -112
- package/dist/esm/index.js.map +1 -1
- package/dist/properties.json +24 -8
- package/dist/react-magma-dom.cjs.development.js +149 -111
- package/dist/react-magma-dom.cjs.development.js.map +1 -1
- package/dist/react-magma-dom.cjs.production.min.js +1 -1
- package/dist/react-magma-dom.cjs.production.min.js.map +1 -1
- package/package.json +1 -1
package/dist/esm/index.js
CHANGED
|
@@ -5,7 +5,7 @@ import { CloseIcon, InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, ChevronRi
|
|
|
5
5
|
import ReactDOM__default, { flushSync as flushSync$1 } from 'react-dom';
|
|
6
6
|
import isEqual from 'react-fast-compare';
|
|
7
7
|
import 'warning';
|
|
8
|
-
import { isBefore, isSameDay, isAfter, format as format$1, addMonths, endOfWeek, addDays, addWeeks,
|
|
8
|
+
import { isBefore, isSameDay, isAfter, format as format$1, startOfMonth, subMonths, addMonths, endOfWeek, addDays, addWeeks, startOfWeek, subDays, subWeeks, endOfMonth, getDay, differenceInDays, startOfDay, isSameMonth, parse as parse$1, setHours, endOfDay, isMatch, isValid } from 'date-fns';
|
|
9
9
|
import { enUS } from 'date-fns/locale';
|
|
10
10
|
import { useSelect, useMultipleSelection, useCombobox } from 'downshift';
|
|
11
11
|
export { default as styled } from '@emotion/styled';
|
|
@@ -2506,7 +2506,7 @@ var defaultI18n = {
|
|
|
2506
2506
|
datePicker: {
|
|
2507
2507
|
startOfWeek: 'sunday',
|
|
2508
2508
|
calendarIconAriaLabel: 'Toggle Calendar Widget',
|
|
2509
|
-
calendarOpenAnnounce: 'Calendar Widget is now open.
|
|
2509
|
+
calendarOpenAnnounce: 'Calendar Widget is now open.',
|
|
2510
2510
|
calendarCloseAriaLabel: 'Close Calendar Widget',
|
|
2511
2511
|
previousMonthAriaLabel: 'Previous Month',
|
|
2512
2512
|
nextMonthAriaLabel: 'Next Month',
|
|
@@ -7139,6 +7139,7 @@ var CalendarContext = /*#__PURE__*/createContext({
|
|
|
7139
7139
|
},
|
|
7140
7140
|
showHelperInformation: function showHelperInformation() {},
|
|
7141
7141
|
hideHelperInformation: function hideHelperInformation() {},
|
|
7142
|
+
onClose: function onClose() {},
|
|
7142
7143
|
onDateChange: function onDateChange(newDate, event) {},
|
|
7143
7144
|
onKeyDown: function onKeyDown(event) {},
|
|
7144
7145
|
onPrevMonthClick: function onPrevMonthClick() {},
|
|
@@ -9359,6 +9360,88 @@ var CalendarDay = function CalendarDay(props) {
|
|
|
9359
9360
|
}
|
|
9360
9361
|
};
|
|
9361
9362
|
|
|
9363
|
+
function useFocusLock(active, header, body) {
|
|
9364
|
+
var rootNode = useRef(null);
|
|
9365
|
+
var focusableItems = useRef([]);
|
|
9366
|
+
// The filter is necessary for the proper functioning of focus in drawer-navigation or similar cases
|
|
9367
|
+
var updateFocusableItems = function updateFocusableItems() {
|
|
9368
|
+
var _rootNode$current;
|
|
9369
|
+
focusableItems.current = Array.from(((_rootNode$current = rootNode.current) == null ? void 0 : _rootNode$current.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"]), video')) || []).filter(function (element) {
|
|
9370
|
+
var style = window.getComputedStyle(element);
|
|
9371
|
+
return element instanceof HTMLElement && style.display !== 'none' && style.visibility !== 'hidden' && !element.hasAttribute('disabled');
|
|
9372
|
+
});
|
|
9373
|
+
};
|
|
9374
|
+
useEffect(function () {
|
|
9375
|
+
if (active) {
|
|
9376
|
+
updateFocusableItems();
|
|
9377
|
+
var observer = new MutationObserver(function () {
|
|
9378
|
+
updateFocusableItems();
|
|
9379
|
+
});
|
|
9380
|
+
if (rootNode.current) {
|
|
9381
|
+
observer.observe(rootNode.current, {
|
|
9382
|
+
childList: true,
|
|
9383
|
+
subtree: true
|
|
9384
|
+
});
|
|
9385
|
+
}
|
|
9386
|
+
if (header && header.current) {
|
|
9387
|
+
header.current.focus();
|
|
9388
|
+
} else if (focusableItems.current && focusableItems.current.length > 0) {
|
|
9389
|
+
var firstItem = focusableItems.current[0];
|
|
9390
|
+
firstItem.focus();
|
|
9391
|
+
} else if (body && body.current) {
|
|
9392
|
+
body.current.firstChild.setAttribute('tabIndex', '-1');
|
|
9393
|
+
body.current.firstChild.focus();
|
|
9394
|
+
}
|
|
9395
|
+
return function () {
|
|
9396
|
+
observer.disconnect();
|
|
9397
|
+
};
|
|
9398
|
+
}
|
|
9399
|
+
}, [active, header, body]);
|
|
9400
|
+
useEffect(function () {
|
|
9401
|
+
var handleKeyPress = function handleKeyPress(event) {
|
|
9402
|
+
if (!focusableItems.current) return;
|
|
9403
|
+
var key = event.key,
|
|
9404
|
+
shiftKey = event.shiftKey;
|
|
9405
|
+
var _focusableItems$curre = focusableItems.current,
|
|
9406
|
+
length = _focusableItems$curre.length,
|
|
9407
|
+
firstItem = _focusableItems$curre[0],
|
|
9408
|
+
lastItem = _focusableItems$curre[length - 1];
|
|
9409
|
+
if (active && key === 'Tab') {
|
|
9410
|
+
// If no focusable items are
|
|
9411
|
+
if (length === 0) {
|
|
9412
|
+
event.preventDefault();
|
|
9413
|
+
return;
|
|
9414
|
+
}
|
|
9415
|
+
// If only one item then prevent tabbing when locked
|
|
9416
|
+
if (length === 1) {
|
|
9417
|
+
event.preventDefault();
|
|
9418
|
+
if (firstItem !== document.activeElement) {
|
|
9419
|
+
firstItem.focus();
|
|
9420
|
+
}
|
|
9421
|
+
return;
|
|
9422
|
+
}
|
|
9423
|
+
// If focused on last item then focus on first item when tab is pressed
|
|
9424
|
+
if (!shiftKey && document.activeElement === lastItem) {
|
|
9425
|
+
event.preventDefault();
|
|
9426
|
+
firstItem.focus();
|
|
9427
|
+
return;
|
|
9428
|
+
}
|
|
9429
|
+
// If focused on first item then focus on last item when shift + tab is pressed
|
|
9430
|
+
if (shiftKey && (document.activeElement === firstItem || document.activeElement === (header == null ? void 0 : header.current))) {
|
|
9431
|
+
event.preventDefault();
|
|
9432
|
+
lastItem.focus();
|
|
9433
|
+
return;
|
|
9434
|
+
}
|
|
9435
|
+
}
|
|
9436
|
+
};
|
|
9437
|
+
window.addEventListener('keydown', handleKeyPress);
|
|
9438
|
+
return function () {
|
|
9439
|
+
window.removeEventListener('keydown', handleKeyPress);
|
|
9440
|
+
};
|
|
9441
|
+
}, [active, focusableItems, header]);
|
|
9442
|
+
return rootNode;
|
|
9443
|
+
}
|
|
9444
|
+
|
|
9362
9445
|
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)."; }
|
|
9363
9446
|
var List = /*#__PURE__*/_styled("ul", {
|
|
9364
9447
|
target: "egx42px6",
|
|
@@ -9369,7 +9452,7 @@ var List = /*#__PURE__*/_styled("ul", {
|
|
|
9369
9452
|
} : {
|
|
9370
9453
|
name: "1s0dwnn",
|
|
9371
9454
|
styles: "list-style:none;margin:0;padding:0;text-align:left",
|
|
9372
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
9455
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAWuB","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Heading } from '../Heading';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\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  justify-content: space-between;\n  padding: 2px;\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: 10px 0 12px 0;\n  }\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\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, null,\r\n            React.createElement(IconButton, { icon: React.createElement(ArrowBackIcon, null), isInverse: isInverse, size: ButtonSize.small, style: { top: '4px', left: '-12px' }, variant: ButtonVariant.link, onClick: props.onReturnBack }, \"Back to Calendar\"),\r\n            React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, style: { left: '16px', margin: '4px' }, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link })),\r\n        React.createElement(StyledContent, { isInverse: isInverse },\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"]} */",
|
|
9373
9456
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$h
|
|
9374
9457
|
});
|
|
9375
9458
|
var Item = /*#__PURE__*/_styled("li", {
|
|
@@ -9379,7 +9462,7 @@ var Item = /*#__PURE__*/_styled("li", {
|
|
|
9379
9462
|
return props.theme.typeScale.size02.fontSize;
|
|
9380
9463
|
}, ";line-height:", function (props) {
|
|
9381
9464
|
return props.theme.typeScale.size02.lineHeight;
|
|
9382
|
-
}, ";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;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
9465
|
+
}, ";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;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAiBuB","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Heading } from '../Heading';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\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  justify-content: space-between;\n  padding: 2px;\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: 10px 0 12px 0;\n  }\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\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, null,\r\n            React.createElement(IconButton, { icon: React.createElement(ArrowBackIcon, null), isInverse: isInverse, size: ButtonSize.small, style: { top: '4px', left: '-12px' }, variant: ButtonVariant.link, onClick: props.onReturnBack }, \"Back to Calendar\"),\r\n            React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, style: { left: '16px', margin: '4px' }, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link })),\r\n        React.createElement(StyledContent, { isInverse: isInverse },\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"]} */"));
|
|
9383
9466
|
var KeyboardShortcutButtonWrapper = /*#__PURE__*/_styled("span", {
|
|
9384
9467
|
target: "egx42px4",
|
|
9385
9468
|
label: "KeyboardShortcutButtonWrapper"
|
|
@@ -9397,7 +9480,7 @@ var KeyboardShortcutButtonWrapper = /*#__PURE__*/_styled("span", {
|
|
|
9397
9480
|
return props.theme.spaceScale.spacing02;
|
|
9398
9481
|
}, " ", function (props) {
|
|
9399
9482
|
return props.theme.spaceScale.spacing04;
|
|
9400
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
9483
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAoCkD","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Heading } from '../Heading';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\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  justify-content: space-between;\n  padding: 2px;\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: 10px 0 12px 0;\n  }\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\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, null,\r\n            React.createElement(IconButton, { icon: React.createElement(ArrowBackIcon, null), isInverse: isInverse, size: ButtonSize.small, style: { top: '4px', left: '-12px' }, variant: ButtonVariant.link, onClick: props.onReturnBack }, \"Back to Calendar\"),\r\n            React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, style: { left: '16px', margin: '4px' }, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link })),\r\n        React.createElement(StyledContent, { isInverse: isInverse },\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"]} */"));
|
|
9401
9484
|
var StyledPopup = /*#__PURE__*/_styled("div", {
|
|
9402
9485
|
target: "egx42px3",
|
|
9403
9486
|
label: "StyledPopup"
|
|
@@ -9407,7 +9490,7 @@ var StyledPopup = /*#__PURE__*/_styled("div", {
|
|
|
9407
9490
|
} : {
|
|
9408
9491
|
name: "bjn8wh",
|
|
9409
9492
|
styles: "position:relative",
|
|
9410
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
9493
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAiD+B","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Heading } from '../Heading';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\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  justify-content: space-between;\n  padding: 2px;\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: 10px 0 12px 0;\n  }\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\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, null,\r\n            React.createElement(IconButton, { icon: React.createElement(ArrowBackIcon, null), isInverse: isInverse, size: ButtonSize.small, style: { top: '4px', left: '-12px' }, variant: ButtonVariant.link, onClick: props.onReturnBack }, \"Back to Calendar\"),\r\n            React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, style: { left: '16px', margin: '4px' }, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link })),\r\n        React.createElement(StyledContent, { isInverse: isInverse },\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"]} */",
|
|
9411
9494
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$h
|
|
9412
9495
|
});
|
|
9413
9496
|
var StyledNavContainer = /*#__PURE__*/_styled("div", {
|
|
@@ -9419,7 +9502,7 @@ var StyledNavContainer = /*#__PURE__*/_styled("div", {
|
|
|
9419
9502
|
} : {
|
|
9420
9503
|
name: "l6h0c2",
|
|
9421
9504
|
styles: "display:flex;justify-content:space-between;padding:2px",
|
|
9422
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
9505
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAoDsC","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Heading } from '../Heading';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\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  justify-content: space-between;\n  padding: 2px;\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: 10px 0 12px 0;\n  }\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\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, null,\r\n            React.createElement(IconButton, { icon: React.createElement(ArrowBackIcon, null), isInverse: isInverse, size: ButtonSize.small, style: { top: '4px', left: '-12px' }, variant: ButtonVariant.link, onClick: props.onReturnBack }, \"Back to Calendar\"),\r\n            React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, style: { left: '16px', margin: '4px' }, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link })),\r\n        React.createElement(StyledContent, { isInverse: isInverse },\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"]} */",
|
|
9423
9506
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$h
|
|
9424
9507
|
});
|
|
9425
9508
|
var StyledContent = /*#__PURE__*/_styled("div", {
|
|
@@ -9428,18 +9511,21 @@ var StyledContent = /*#__PURE__*/_styled("div", {
|
|
|
9428
9511
|
})("z-index:9999;position:relative;color:", function (props) {
|
|
9429
9512
|
var _props$theme, _props$theme2;
|
|
9430
9513
|
return props.isInverse ? props == null || (_props$theme = props.theme) == null || (_props$theme = _props$theme.colors) == null ? void 0 : _props$theme.neutral100 : props == null || (_props$theme2 = props.theme) == null || (_props$theme2 = _props$theme2.colors) == null ? void 0 : _props$theme2.neutral700;
|
|
9431
|
-
}, ";h2{margin:10px 0 12px 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
9514
|
+
}, ";h2{margin:10px 0 12px 0;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAyDiC","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Heading } from '../Heading';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\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  justify-content: space-between;\n  padding: 2px;\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: 10px 0 12px 0;\n  }\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\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, null,\r\n            React.createElement(IconButton, { icon: React.createElement(ArrowBackIcon, null), isInverse: isInverse, size: ButtonSize.small, style: { top: '4px', left: '-12px' }, variant: ButtonVariant.link, onClick: props.onReturnBack }, \"Back to Calendar\"),\r\n            React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, style: { left: '16px', margin: '4px' }, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link })),\r\n        React.createElement(StyledContent, { isInverse: isInverse },\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"]} */"));
|
|
9432
9515
|
var StyledDescription = /*#__PURE__*/_styled("p", {
|
|
9433
9516
|
target: "egx42px0",
|
|
9434
9517
|
label: "StyledDescription"
|
|
9435
9518
|
})("font-family:", function (props) {
|
|
9436
9519
|
return props.theme.bodyFont;
|
|
9437
|
-
}, ";margin:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
9520
|
+
}, ";margin:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAoEmC","file":"HelperInformation.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Heading } from '../Heading';\r\nimport { ArrowBackIcon, CloseIcon } from 'react-magma-icons';\r\nimport { TypographyVisualStyle } from '../Typography';\r\nimport { I18nContext } from '../../i18n';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\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  justify-content: space-between;\n  padding: 2px;\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: 10px 0 12px 0;\n  }\n`;\r\nconst StyledDescription = styled.p `\n  font-family: ${props => props.theme.bodyFont};\n  margin: 0;\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, null,\r\n            React.createElement(IconButton, { icon: React.createElement(ArrowBackIcon, null), isInverse: isInverse, size: ButtonSize.small, style: { top: '4px', left: '-12px' }, variant: ButtonVariant.link, onClick: props.onReturnBack }, \"Back to Calendar\"),\r\n            React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), isInverse: isInverse, size: ButtonSize.medium, style: { left: '16px', margin: '4px' }, type: ButtonType.button, onClick: props.onClose, variant: ButtonVariant.link })),\r\n        React.createElement(StyledContent, { isInverse: isInverse },\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"]} */"));
|
|
9438
9521
|
var HelperInformation = function HelperInformation(props) {
|
|
9439
9522
|
var i18n = useContext(I18nContext);
|
|
9440
9523
|
var theme = useContext(ThemeContext);
|
|
9524
|
+
var helperInformationRef = useFocusLock(true);
|
|
9441
9525
|
var isInverse = useIsInverse(props.isInverse);
|
|
9442
|
-
return createElement(StyledPopup,
|
|
9526
|
+
return createElement(StyledPopup, {
|
|
9527
|
+
ref: helperInformationRef
|
|
9528
|
+
}, createElement(StyledNavContainer, null, createElement(IconButton, {
|
|
9443
9529
|
icon: createElement(ArrowBackIcon, null),
|
|
9444
9530
|
isInverse: isInverse,
|
|
9445
9531
|
size: ButtonSize.small,
|
|
@@ -9448,7 +9534,7 @@ var HelperInformation = function HelperInformation(props) {
|
|
|
9448
9534
|
left: '-12px'
|
|
9449
9535
|
},
|
|
9450
9536
|
variant: ButtonVariant.link,
|
|
9451
|
-
onClick: props.
|
|
9537
|
+
onClick: props.onReturnBack
|
|
9452
9538
|
}, "Back to Calendar"), createElement(IconButton, {
|
|
9453
9539
|
"aria-label": i18n.datePicker.calendarCloseAriaLabel,
|
|
9454
9540
|
color: ButtonColor.secondary,
|
|
@@ -9527,88 +9613,6 @@ var HelperInformation = function HelperInformation(props) {
|
|
|
9527
9613
|
}, i18n.datePicker.helpModal.escape.explanation)))));
|
|
9528
9614
|
};
|
|
9529
9615
|
|
|
9530
|
-
function useFocusLock(active, header, body) {
|
|
9531
|
-
var rootNode = useRef(null);
|
|
9532
|
-
var focusableItems = useRef([]);
|
|
9533
|
-
// The filter is necessary for the proper functioning of focus in drawer-navigation or similar cases
|
|
9534
|
-
var updateFocusableItems = function updateFocusableItems() {
|
|
9535
|
-
var _rootNode$current;
|
|
9536
|
-
focusableItems.current = Array.from(((_rootNode$current = rootNode.current) == null ? void 0 : _rootNode$current.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"]), video')) || []).filter(function (element) {
|
|
9537
|
-
var style = window.getComputedStyle(element);
|
|
9538
|
-
return element instanceof HTMLElement && style.display !== 'none' && style.visibility !== 'hidden' && !element.hasAttribute('disabled');
|
|
9539
|
-
});
|
|
9540
|
-
};
|
|
9541
|
-
useEffect(function () {
|
|
9542
|
-
if (active) {
|
|
9543
|
-
updateFocusableItems();
|
|
9544
|
-
var observer = new MutationObserver(function () {
|
|
9545
|
-
updateFocusableItems();
|
|
9546
|
-
});
|
|
9547
|
-
if (rootNode.current) {
|
|
9548
|
-
observer.observe(rootNode.current, {
|
|
9549
|
-
childList: true,
|
|
9550
|
-
subtree: true
|
|
9551
|
-
});
|
|
9552
|
-
}
|
|
9553
|
-
if (header && header.current) {
|
|
9554
|
-
header.current.focus();
|
|
9555
|
-
} else if (focusableItems.current && focusableItems.current.length > 0) {
|
|
9556
|
-
var firstItem = focusableItems.current[0];
|
|
9557
|
-
firstItem.focus();
|
|
9558
|
-
} else if (body && body.current) {
|
|
9559
|
-
body.current.firstChild.setAttribute('tabIndex', '-1');
|
|
9560
|
-
body.current.firstChild.focus();
|
|
9561
|
-
}
|
|
9562
|
-
return function () {
|
|
9563
|
-
observer.disconnect();
|
|
9564
|
-
};
|
|
9565
|
-
}
|
|
9566
|
-
}, [active, header, body]);
|
|
9567
|
-
useEffect(function () {
|
|
9568
|
-
var handleKeyPress = function handleKeyPress(event) {
|
|
9569
|
-
if (!focusableItems.current) return;
|
|
9570
|
-
var key = event.key,
|
|
9571
|
-
shiftKey = event.shiftKey;
|
|
9572
|
-
var _focusableItems$curre = focusableItems.current,
|
|
9573
|
-
length = _focusableItems$curre.length,
|
|
9574
|
-
firstItem = _focusableItems$curre[0],
|
|
9575
|
-
lastItem = _focusableItems$curre[length - 1];
|
|
9576
|
-
if (active && key === 'Tab') {
|
|
9577
|
-
// If no focusable items are
|
|
9578
|
-
if (length === 0) {
|
|
9579
|
-
event.preventDefault();
|
|
9580
|
-
return;
|
|
9581
|
-
}
|
|
9582
|
-
// If only one item then prevent tabbing when locked
|
|
9583
|
-
if (length === 1) {
|
|
9584
|
-
event.preventDefault();
|
|
9585
|
-
if (firstItem !== document.activeElement) {
|
|
9586
|
-
firstItem.focus();
|
|
9587
|
-
}
|
|
9588
|
-
return;
|
|
9589
|
-
}
|
|
9590
|
-
// If focused on last item then focus on first item when tab is pressed
|
|
9591
|
-
if (!shiftKey && document.activeElement === lastItem) {
|
|
9592
|
-
event.preventDefault();
|
|
9593
|
-
firstItem.focus();
|
|
9594
|
-
return;
|
|
9595
|
-
}
|
|
9596
|
-
// If focused on first item then focus on last item when shift + tab is pressed
|
|
9597
|
-
if (shiftKey && (document.activeElement === firstItem || document.activeElement === (header == null ? void 0 : header.current))) {
|
|
9598
|
-
event.preventDefault();
|
|
9599
|
-
lastItem.focus();
|
|
9600
|
-
return;
|
|
9601
|
-
}
|
|
9602
|
-
}
|
|
9603
|
-
};
|
|
9604
|
-
window.addEventListener('keydown', handleKeyPress);
|
|
9605
|
-
return function () {
|
|
9606
|
-
window.removeEventListener('keydown', handleKeyPress);
|
|
9607
|
-
};
|
|
9608
|
-
}, [active, focusableItems, header]);
|
|
9609
|
-
return rootNode;
|
|
9610
|
-
}
|
|
9611
|
-
|
|
9612
9616
|
var CalendarContainer = /*#__PURE__*/_styled("div", {
|
|
9613
9617
|
target: "eeao89h5",
|
|
9614
9618
|
label: "CalendarContainer"
|
|
@@ -9618,7 +9622,7 @@ var CalendarContainer = /*#__PURE__*/_styled("div", {
|
|
|
9618
9622
|
return props.theme.spaceScale.spacing05;
|
|
9619
9623
|
}, " ", function (props) {
|
|
9620
9624
|
return props.theme.spaceScale.spacing03;
|
|
9621
|
-
}, ";overflow:visible;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFyTW9udGgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWNxQyIsImZpbGUiOiJDYWxlbmRhck1vbnRoLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgQnV0dG9uQ29sb3IsIEJ1dHRvblNpemUsIEJ1dHRvblR5cGUsIEJ1dHRvblZhcmlhbnQgfSBmcm9tICcuLi9CdXR0b24nO1xyXG5pbXBvcnQgeyBJY29uQnV0dG9uIH0gZnJvbSAnLi4vSWNvbkJ1dHRvbic7XHJcbmltcG9ydCB7IFRvb2x0aXAgfSBmcm9tICcuLi9Ub29sdGlwJztcclxuaW1wb3J0IHsgQ2xvc2VJY29uLCBLZXlib2FyZEljb24gfSBmcm9tICdyZWFjdC1tYWdtYS1pY29ucyc7XHJcbmltcG9ydCB7IENhbGVuZGFyQ29udGV4dCB9IGZyb20gJy4vQ2FsZW5kYXJDb250ZXh0JztcclxuaW1wb3J0IHsgQ2FsZW5kYXJIZWFkZXIgfSBmcm9tICcuL0NhbGVuZGFySGVhZGVyJztcclxuaW1wb3J0IHsgQ2FsZW5kYXJEYXkgfSBmcm9tICcuL0NhbGVuZGFyRGF5JztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgSGVscGVySW5mb3JtYXRpb24gfSBmcm9tICcuL0hlbHBlckluZm9ybWF0aW9uJztcclxuaW1wb3J0IHsgdXNlUHJldmlvdXMgfSBmcm9tICcuLi8uLi91dGlscyc7XHJcbmltcG9ydCB7IEkxOG5Db250ZXh0IH0gZnJvbSAnLi4vLi4vaTE4bic7XHJcbmltcG9ydCB7IHVzZUZvY3VzTG9jayB9IGZyb20gJy4uLy4uL2hvb2tzL3VzZUZvY3VzTG9jayc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuY29uc3QgQ2FsZW5kYXJDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLnByaW1hcnk1MDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDB9O1xuICBwYWRkaW5nOiAwICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDV9XG4gICAgJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG4gIG92ZXJmbG93OiB2aXNpYmxlO1xuYDtcclxuY29uc3QgTW9udGhDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLnByaW1hcnk1MDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDB9O1xuICBmb250LWZhbWlseTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5ib2R5Rm9udH07XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgdXNlci1zZWxlY3Q6IG5vbmU7XG4gIHZlcnRpY2FsLWFsaWduOiB0b3A7XG5gO1xyXG5jb25zdCBUYWJsZSA9IHN0eWxlZC50YWJsZSBgXG4gIGJvcmRlci1jb2xsYXBzZTogY29sbGFwc2U7XG4gIGJvcmRlci1zcGFjaW5nOiAwO1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAzfTtcbmA7XHJcbmNvbnN0IFRoID0gc3R5bGVkLnRoIGBcbiAgYm9yZGVyOiAwO1xuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWw3MDB9O1xuICBmb250LXNpemU6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUudHlwZVNjYWxlLnNpemUwMi5mb250U2l6ZX07XG4gIGxpbmUtaGVpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnR5cGVTY2FsZS5zaXplMDIubGluZUhlaWdodH07XG4gIGZvbnQtd2VpZ2h0OiBub3JtYWw7XG4gIHBhZGRpbmc6IDA7XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbmA7XHJcbmNvbnN0IEhlbHBlckJ1dHRvbiA9IHN0eWxlZC5zcGFuIGBcbiAgbWFyZ2luOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAyfTtcbiAgdG9wOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAxfTtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBsZWZ0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAxfTtcbiAgei1pbmRleDogMjtcbmA7XHJcbmNvbnN0IENsb3NlQnV0dG9uID0gc3R5bGVkLnNwYW4gYFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHJpZ2h0OiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAxfTtcbiAgdG9wOiAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAxfTtcbiAgei1pbmRleDogMTtcbiAgbWFyZ2luOiAke3Byb3BzID0+
|
|
9625
|
+
}, ";overflow:visible;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAcqC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { usePrevious } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport styled from '@emotion/styled';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  padding: 0 ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing03};\n  overflow: visible;\n`;\r\nconst MonthContainer = styled.div `\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`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n  margin-bottom: ${props => props.theme.spaceScale.spacing03};\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.neutral700};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: normal;\n  padding: 0;\n  text-align: center;\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: ${props => props.theme.spaceScale.spacing01};\n  position: absolute;\n  left: ${props => props.theme.spaceScale.spacing01};\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: ${props => props.theme.spaceScale.spacing01};\n  top: ${props => props.theme.spaceScale.spacing01};\n  z-index: 1;\n  margin: ${props => props.theme.spaceScale.spacing02};\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 }, i18n.days.min[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)\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(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                React.createElement(HelperButton, { theme: theme },\r\n                    React.createElement(IconButton, { ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, size: ButtonSize.small, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link })))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
9622
9626
|
var MonthContainer = /*#__PURE__*/_styled("div", {
|
|
9623
9627
|
target: "eeao89h4",
|
|
9624
9628
|
label: "MonthContainer"
|
|
@@ -9626,13 +9630,13 @@ var MonthContainer = /*#__PURE__*/_styled("div", {
|
|
|
9626
9630
|
return props.isInverse ? props.theme.colors.primary500 : props.theme.colors.neutral100;
|
|
9627
9631
|
}, ";font-family:", function (props) {
|
|
9628
9632
|
return props.theme.bodyFont;
|
|
9629
|
-
}, ";text-align:center;user-select:none;vertical-align:top;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFyTW9udGgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNCa0MiLCJmaWxlIjoiQ2FsZW5kYXJNb250aC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IEJ1dHRvbkNvbG9yLCBCdXR0b25TaXplLCBCdXR0b25UeXBlLCBCdXR0b25WYXJpYW50IH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vVG9vbHRpcCc7XHJcbmltcG9ydCB7IENsb3NlSWNvbiwgS2V5Ym9hcmRJY29uIH0gZnJvbSAncmVhY3QtbWFnbWEtaWNvbnMnO1xyXG5pbXBvcnQgeyBDYWxlbmRhckNvbnRleHQgfSBmcm9tICcuL0NhbGVuZGFyQ29udGV4dCc7XHJcbmltcG9ydCB7IENhbGVuZGFySGVhZGVyIH0gZnJvbSAnLi9DYWxlbmRhckhlYWRlcic7XHJcbmltcG9ydCB7IENhbGVuZGFyRGF5IH0gZnJvbSAnLi9DYWxlbmRhckRheSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEhlbHBlckluZm9ybWF0aW9uIH0gZnJvbSAnLi9IZWxwZXJJbmZvcm1hdGlvbic7XHJcbmltcG9ydCB7IHVzZVByZXZpb3VzIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgeyBJMThuQ29udGV4dCB9IGZyb20gJy4uLy4uL2kxOG4nO1xyXG5pbXBvcnQgeyB1c2VGb2N1c0xvY2sgfSBmcm9tICcuLi8uLi9ob29rcy91c2VGb2N1c0xvY2snO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IENhbGVuZGFyQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5NTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA1fVxuICAgICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICBvdmVyZmxvdzogdmlzaWJsZTtcbmA7XHJcbmNvbnN0IE1vbnRoQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5NTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgZm9udC1mYW1pbHk6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9keUZvbnR9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIHVzZXItc2VsZWN0OiBub25lO1xuICB2ZXJ0aWNhbC1hbGlnbjogdG9wO1xuYDtcclxuY29uc3QgVGFibGUgPSBzdHlsZWQudGFibGUgYFxuICBib3JkZXItY29sbGFwc2U6IGNvbGxhcHNlO1xuICBib3JkZXItc3BhY2luZzogMDtcbiAgbWFyZ2luLWJvdHRvbTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG5gO1xyXG5jb25zdCBUaCA9IHN0eWxlZC50aCBgXG4gIGJvcmRlcjogMDtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+
|
|
9633
|
+
}, ";text-align:center;user-select:none;vertical-align:top;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAsBkC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { usePrevious } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport styled from '@emotion/styled';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  padding: 0 ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing03};\n  overflow: visible;\n`;\r\nconst MonthContainer = styled.div `\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`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n  margin-bottom: ${props => props.theme.spaceScale.spacing03};\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.neutral700};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: normal;\n  padding: 0;\n  text-align: center;\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: ${props => props.theme.spaceScale.spacing01};\n  position: absolute;\n  left: ${props => props.theme.spaceScale.spacing01};\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: ${props => props.theme.spaceScale.spacing01};\n  top: ${props => props.theme.spaceScale.spacing01};\n  z-index: 1;\n  margin: ${props => props.theme.spaceScale.spacing02};\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 }, i18n.days.min[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)\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(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                React.createElement(HelperButton, { theme: theme },\r\n                    React.createElement(IconButton, { ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, size: ButtonSize.small, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link })))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
9630
9634
|
var Table$1 = /*#__PURE__*/_styled("table", {
|
|
9631
9635
|
target: "eeao89h3",
|
|
9632
9636
|
label: "Table"
|
|
9633
9637
|
})("border-collapse:collapse;border-spacing:0;margin-bottom:", function (props) {
|
|
9634
9638
|
return props.theme.spaceScale.spacing03;
|
|
9635
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFyTW9udGgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStCMkIiLCJmaWxlIjoiQ2FsZW5kYXJNb250aC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IEJ1dHRvbkNvbG9yLCBCdXR0b25TaXplLCBCdXR0b25UeXBlLCBCdXR0b25WYXJpYW50IH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vVG9vbHRpcCc7XHJcbmltcG9ydCB7IENsb3NlSWNvbiwgS2V5Ym9hcmRJY29uIH0gZnJvbSAncmVhY3QtbWFnbWEtaWNvbnMnO1xyXG5pbXBvcnQgeyBDYWxlbmRhckNvbnRleHQgfSBmcm9tICcuL0NhbGVuZGFyQ29udGV4dCc7XHJcbmltcG9ydCB7IENhbGVuZGFySGVhZGVyIH0gZnJvbSAnLi9DYWxlbmRhckhlYWRlcic7XHJcbmltcG9ydCB7IENhbGVuZGFyRGF5IH0gZnJvbSAnLi9DYWxlbmRhckRheSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEhlbHBlckluZm9ybWF0aW9uIH0gZnJvbSAnLi9IZWxwZXJJbmZvcm1hdGlvbic7XHJcbmltcG9ydCB7IHVzZVByZXZpb3VzIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgeyBJMThuQ29udGV4dCB9IGZyb20gJy4uLy4uL2kxOG4nO1xyXG5pbXBvcnQgeyB1c2VGb2N1c0xvY2sgfSBmcm9tICcuLi8uLi9ob29rcy91c2VGb2N1c0xvY2snO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IENhbGVuZGFyQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5NTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA1fVxuICAgICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICBvdmVyZmxvdzogdmlzaWJsZTtcbmA7XHJcbmNvbnN0IE1vbnRoQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5NTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgZm9udC1mYW1pbHk6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9keUZvbnR9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIHVzZXItc2VsZWN0OiBub25lO1xuICB2ZXJ0aWNhbC1hbGlnbjogdG9wO1xuYDtcclxuY29uc3QgVGFibGUgPSBzdHlsZWQudGFibGUgYFxuICBib3JkZXItY29sbGFwc2U6IGNvbGxhcHNlO1xuICBib3JkZXItc3BhY2luZzogMDtcbiAgbWFyZ2luLWJvdHRvbTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG5gO1xyXG5jb25zdCBUaCA9IHN0eWxlZC50aCBgXG4gIGJvcmRlcjogMDtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+
|
|
9639
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AA+B2B","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { usePrevious } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport styled from '@emotion/styled';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  padding: 0 ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing03};\n  overflow: visible;\n`;\r\nconst MonthContainer = styled.div `\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`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n  margin-bottom: ${props => props.theme.spaceScale.spacing03};\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.neutral700};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: normal;\n  padding: 0;\n  text-align: center;\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: ${props => props.theme.spaceScale.spacing01};\n  position: absolute;\n  left: ${props => props.theme.spaceScale.spacing01};\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: ${props => props.theme.spaceScale.spacing01};\n  top: ${props => props.theme.spaceScale.spacing01};\n  z-index: 1;\n  margin: ${props => props.theme.spaceScale.spacing02};\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 }, i18n.days.min[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)\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(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                React.createElement(HelperButton, { theme: theme },\r\n                    React.createElement(IconButton, { ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, size: ButtonSize.small, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link })))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
9636
9640
|
var Th = /*#__PURE__*/_styled("th", {
|
|
9637
9641
|
target: "eeao89h2",
|
|
9638
9642
|
label: "Th"
|
|
@@ -9642,7 +9646,7 @@ var Th = /*#__PURE__*/_styled("th", {
|
|
|
9642
9646
|
return props.theme.typeScale.size02.fontSize;
|
|
9643
9647
|
}, ";line-height:", function (props) {
|
|
9644
9648
|
return props.theme.typeScale.size02.lineHeight;
|
|
9645
|
-
}, ";font-weight:normal;padding:0;text-align:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFyTW9udGgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9DcUIiLCJmaWxlIjoiQ2FsZW5kYXJNb250aC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IEJ1dHRvbkNvbG9yLCBCdXR0b25TaXplLCBCdXR0b25UeXBlLCBCdXR0b25WYXJpYW50IH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vVG9vbHRpcCc7XHJcbmltcG9ydCB7IENsb3NlSWNvbiwgS2V5Ym9hcmRJY29uIH0gZnJvbSAncmVhY3QtbWFnbWEtaWNvbnMnO1xyXG5pbXBvcnQgeyBDYWxlbmRhckNvbnRleHQgfSBmcm9tICcuL0NhbGVuZGFyQ29udGV4dCc7XHJcbmltcG9ydCB7IENhbGVuZGFySGVhZGVyIH0gZnJvbSAnLi9DYWxlbmRhckhlYWRlcic7XHJcbmltcG9ydCB7IENhbGVuZGFyRGF5IH0gZnJvbSAnLi9DYWxlbmRhckRheSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEhlbHBlckluZm9ybWF0aW9uIH0gZnJvbSAnLi9IZWxwZXJJbmZvcm1hdGlvbic7XHJcbmltcG9ydCB7IHVzZVByZXZpb3VzIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgeyBJMThuQ29udGV4dCB9IGZyb20gJy4uLy4uL2kxOG4nO1xyXG5pbXBvcnQgeyB1c2VGb2N1c0xvY2sgfSBmcm9tICcuLi8uLi9ob29rcy91c2VGb2N1c0xvY2snO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IENhbGVuZGFyQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5NTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA1fVxuICAgICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICBvdmVyZmxvdzogdmlzaWJsZTtcbmA7XHJcbmNvbnN0IE1vbnRoQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5NTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgZm9udC1mYW1pbHk6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9keUZvbnR9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIHVzZXItc2VsZWN0OiBub25lO1xuICB2ZXJ0aWNhbC1hbGlnbjogdG9wO1xuYDtcclxuY29uc3QgVGFibGUgPSBzdHlsZWQudGFibGUgYFxuICBib3JkZXItY29sbGFwc2U6IGNvbGxhcHNlO1xuICBib3JkZXItc3BhY2luZzogMDtcbiAgbWFyZ2luLWJvdHRvbTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG5gO1xyXG5jb25zdCBUaCA9IHN0eWxlZC50aCBgXG4gIGJvcmRlcjogMDtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+
|
|
9649
|
+
}, ";font-weight:normal;padding:0;text-align:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAoCqB","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { usePrevious } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport styled from '@emotion/styled';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  padding: 0 ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing03};\n  overflow: visible;\n`;\r\nconst MonthContainer = styled.div `\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`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n  margin-bottom: ${props => props.theme.spaceScale.spacing03};\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.neutral700};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: normal;\n  padding: 0;\n  text-align: center;\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: ${props => props.theme.spaceScale.spacing01};\n  position: absolute;\n  left: ${props => props.theme.spaceScale.spacing01};\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: ${props => props.theme.spaceScale.spacing01};\n  top: ${props => props.theme.spaceScale.spacing01};\n  z-index: 1;\n  margin: ${props => props.theme.spaceScale.spacing02};\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 }, i18n.days.min[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)\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(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                React.createElement(HelperButton, { theme: theme },\r\n                    React.createElement(IconButton, { ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, size: ButtonSize.small, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link })))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
9646
9650
|
var HelperButton = /*#__PURE__*/_styled("span", {
|
|
9647
9651
|
target: "eeao89h1",
|
|
9648
9652
|
label: "HelperButton"
|
|
@@ -9652,7 +9656,7 @@ var HelperButton = /*#__PURE__*/_styled("span", {
|
|
|
9652
9656
|
return props.theme.spaceScale.spacing01;
|
|
9653
9657
|
}, ";position:absolute;left:", function (props) {
|
|
9654
9658
|
return props.theme.spaceScale.spacing01;
|
|
9655
|
-
}, ";z-index:2;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFyTW9udGgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQStDaUMiLCJmaWxlIjoiQ2FsZW5kYXJNb250aC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IEJ1dHRvbkNvbG9yLCBCdXR0b25TaXplLCBCdXR0b25UeXBlLCBCdXR0b25WYXJpYW50IH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vVG9vbHRpcCc7XHJcbmltcG9ydCB7IENsb3NlSWNvbiwgS2V5Ym9hcmRJY29uIH0gZnJvbSAncmVhY3QtbWFnbWEtaWNvbnMnO1xyXG5pbXBvcnQgeyBDYWxlbmRhckNvbnRleHQgfSBmcm9tICcuL0NhbGVuZGFyQ29udGV4dCc7XHJcbmltcG9ydCB7IENhbGVuZGFySGVhZGVyIH0gZnJvbSAnLi9DYWxlbmRhckhlYWRlcic7XHJcbmltcG9ydCB7IENhbGVuZGFyRGF5IH0gZnJvbSAnLi9DYWxlbmRhckRheSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEhlbHBlckluZm9ybWF0aW9uIH0gZnJvbSAnLi9IZWxwZXJJbmZvcm1hdGlvbic7XHJcbmltcG9ydCB7IHVzZVByZXZpb3VzIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgeyBJMThuQ29udGV4dCB9IGZyb20gJy4uLy4uL2kxOG4nO1xyXG5pbXBvcnQgeyB1c2VGb2N1c0xvY2sgfSBmcm9tICcuLi8uLi9ob29rcy91c2VGb2N1c0xvY2snO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IENhbGVuZGFyQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5NTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA1fVxuICAgICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICBvdmVyZmxvdzogdmlzaWJsZTtcbmA7XHJcbmNvbnN0IE1vbnRoQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5NTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgZm9udC1mYW1pbHk6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9keUZvbnR9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIHVzZXItc2VsZWN0OiBub25lO1xuICB2ZXJ0aWNhbC1hbGlnbjogdG9wO1xuYDtcclxuY29uc3QgVGFibGUgPSBzdHlsZWQudGFibGUgYFxuICBib3JkZXItY29sbGFwc2U6IGNvbGxhcHNlO1xuICBib3JkZXItc3BhY2luZzogMDtcbiAgbWFyZ2luLWJvdHRvbTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG5gO1xyXG5jb25zdCBUaCA9IHN0eWxlZC50aCBgXG4gIGJvcmRlcjogMDtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+
|
|
9659
|
+
}, ";z-index:2;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AA+CiC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { usePrevious } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport styled from '@emotion/styled';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  padding: 0 ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing03};\n  overflow: visible;\n`;\r\nconst MonthContainer = styled.div `\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`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n  margin-bottom: ${props => props.theme.spaceScale.spacing03};\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.neutral700};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: normal;\n  padding: 0;\n  text-align: center;\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: ${props => props.theme.spaceScale.spacing01};\n  position: absolute;\n  left: ${props => props.theme.spaceScale.spacing01};\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: ${props => props.theme.spaceScale.spacing01};\n  top: ${props => props.theme.spaceScale.spacing01};\n  z-index: 1;\n  margin: ${props => props.theme.spaceScale.spacing02};\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 }, i18n.days.min[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)\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(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                React.createElement(HelperButton, { theme: theme },\r\n                    React.createElement(IconButton, { ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, size: ButtonSize.small, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link })))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
9656
9660
|
var CloseButton = /*#__PURE__*/_styled("span", {
|
|
9657
9661
|
target: "eeao89h0",
|
|
9658
9662
|
label: "CloseButton"
|
|
@@ -9662,10 +9666,11 @@ var CloseButton = /*#__PURE__*/_styled("span", {
|
|
|
9662
9666
|
return props.theme.spaceScale.spacing01;
|
|
9663
9667
|
}, ";z-index:1;margin:", function (props) {
|
|
9664
9668
|
return props.theme.spaceScale.spacing02;
|
|
9665
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNhbGVuZGFyTW9udGgudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNEZ0MiLCJmaWxlIjoiQ2FsZW5kYXJNb250aC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IEJ1dHRvbkNvbG9yLCBCdXR0b25TaXplLCBCdXR0b25UeXBlLCBCdXR0b25WYXJpYW50IH0gZnJvbSAnLi4vQnV0dG9uJztcclxuaW1wb3J0IHsgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL0ljb25CdXR0b24nO1xyXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vVG9vbHRpcCc7XHJcbmltcG9ydCB7IENsb3NlSWNvbiwgS2V5Ym9hcmRJY29uIH0gZnJvbSAncmVhY3QtbWFnbWEtaWNvbnMnO1xyXG5pbXBvcnQgeyBDYWxlbmRhckNvbnRleHQgfSBmcm9tICcuL0NhbGVuZGFyQ29udGV4dCc7XHJcbmltcG9ydCB7IENhbGVuZGFySGVhZGVyIH0gZnJvbSAnLi9DYWxlbmRhckhlYWRlcic7XHJcbmltcG9ydCB7IENhbGVuZGFyRGF5IH0gZnJvbSAnLi9DYWxlbmRhckRheSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEhlbHBlckluZm9ybWF0aW9uIH0gZnJvbSAnLi9IZWxwZXJJbmZvcm1hdGlvbic7XHJcbmltcG9ydCB7IHVzZVByZXZpb3VzIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5pbXBvcnQgeyBJMThuQ29udGV4dCB9IGZyb20gJy4uLy4uL2kxOG4nO1xyXG5pbXBvcnQgeyB1c2VGb2N1c0xvY2sgfSBmcm9tICcuLi8uLi9ob29rcy91c2VGb2N1c0xvY2snO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IENhbGVuZGFyQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5NTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgcGFkZGluZzogMCAke3Byb3BzID0+IHByb3BzLnRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA1fVxuICAgICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDN9O1xuICBvdmVyZmxvdzogdmlzaWJsZTtcbmA7XHJcbmNvbnN0IE1vbnRoQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIGJhY2tncm91bmQ6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5wcmltYXJ5NTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwfTtcbiAgZm9udC1mYW1pbHk6ICR7cHJvcHMgPT4gcHJvcHMudGhlbWUuYm9keUZvbnR9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG4gIHVzZXItc2VsZWN0OiBub25lO1xuICB2ZXJ0aWNhbC1hbGlnbjogdG9wO1xuYDtcclxuY29uc3QgVGFibGUgPSBzdHlsZWQudGFibGUgYFxuICBib3JkZXItY29sbGFwc2U6IGNvbGxhcHNlO1xuICBib3JkZXItc3BhY2luZzogMDtcbiAgbWFyZ2luLWJvdHRvbTogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM307XG5gO1xyXG5jb25zdCBUaCA9IHN0eWxlZC50aCBgXG4gIGJvcmRlcjogMDtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsNzAwfTtcbiAgZm9udC1zaXplOiAke3Byb3BzID0+
|
|
9669
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CalendarMonth.tsx"],"names":[],"mappings":"AAsDgC","file":"CalendarMonth.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ButtonColor, ButtonSize, ButtonType, ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { Tooltip } from '../Tooltip';\r\nimport { CloseIcon, KeyboardIcon } from 'react-magma-icons';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarHeader } from './CalendarHeader';\r\nimport { CalendarDay } from './CalendarDay';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { HelperInformation } from './HelperInformation';\r\nimport { usePrevious } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useFocusLock } from '../../hooks/useFocusLock';\r\nimport styled from '@emotion/styled';\r\nconst CalendarContainer = styled.div `\n  background: ${props => props.isInverse\r\n    ? props.theme.colors.primary500\r\n    : props.theme.colors.neutral100};\n  padding: 0 ${props => props.theme.spaceScale.spacing05}\n    ${props => props.theme.spaceScale.spacing03};\n  overflow: visible;\n`;\r\nconst MonthContainer = styled.div `\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`;\r\nconst Table = styled.table `\n  border-collapse: collapse;\n  border-spacing: 0;\n  margin-bottom: ${props => props.theme.spaceScale.spacing03};\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.neutral700};\n  font-size: ${props => props.theme.typeScale.size02.fontSize};\n  line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  font-weight: normal;\n  padding: 0;\n  text-align: center;\n`;\r\nconst HelperButton = styled.span `\n  margin: ${props => props.theme.spaceScale.spacing02};\n  top: ${props => props.theme.spaceScale.spacing01};\n  position: absolute;\n  left: ${props => props.theme.spaceScale.spacing01};\n  z-index: 2;\n`;\r\nconst CloseButton = styled.span `\n  position: absolute;\n  right: ${props => props.theme.spaceScale.spacing01};\n  top: ${props => props.theme.spaceScale.spacing01};\n  z-index: 1;\n  margin: ${props => props.theme.spaceScale.spacing02};\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 }, i18n.days.min[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)\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(Tooltip, { content: 'Keyboard instructions', tooltipStyle: { position: 'fixed' } },\r\n                React.createElement(HelperButton, { theme: theme },\r\n                    React.createElement(IconButton, { ref: helperButtonRef, \"aria-label\": i18n.datePicker.helpModal.helpButtonAriaLabel, icon: React.createElement(KeyboardIcon, null), onClick: context.showHelperInformation, size: ButtonSize.small, onFocus: turnOffDateFocused, type: ButtonType.button, variant: ButtonVariant.link }))),\r\n            React.createElement(CloseButton, { theme: theme },\r\n                React.createElement(IconButton, { \"aria-label\": i18n.datePicker.calendarCloseAriaLabel, color: ButtonColor.secondary, icon: React.createElement(CloseIcon, null), onClick: props.handleCloseButtonClick, size: ButtonSize.medium, type: ButtonType.button, variant: ButtonVariant.link })))))));\r\n};\r\n//# sourceMappingURL=CalendarMonth.js.map"]} */"));
|
|
9666
9670
|
var CalendarMonth = function CalendarMonth(props) {
|
|
9667
9671
|
var lastFocus = useRef();
|
|
9668
9672
|
var headingRef = useRef();
|
|
9673
|
+
var helperButtonRef = useRef();
|
|
9669
9674
|
var context = useContext(CalendarContext);
|
|
9670
9675
|
var _React$useState = useState(false),
|
|
9671
9676
|
dayFocusable = _React$useState[0],
|
|
@@ -9690,6 +9695,11 @@ var CalendarMonth = function CalendarMonth(props) {
|
|
|
9690
9695
|
setFocusHeader(false);
|
|
9691
9696
|
}
|
|
9692
9697
|
}, [props.calendarOpened, props.focusOnOpen]);
|
|
9698
|
+
useEffect(function () {
|
|
9699
|
+
if (prevCalendarOpened && !context.helperInformationShown) {
|
|
9700
|
+
helperButtonRef.current.focus();
|
|
9701
|
+
}
|
|
9702
|
+
}, [context.helperInformationShown]);
|
|
9693
9703
|
function onCalendarTableFocus() {
|
|
9694
9704
|
setDayFocusable(true);
|
|
9695
9705
|
}
|
|
@@ -9717,17 +9727,18 @@ var CalendarMonth = function CalendarMonth(props) {
|
|
|
9717
9727
|
tabIndex: -1,
|
|
9718
9728
|
theme: theme,
|
|
9719
9729
|
onKeyDown: context.onKeyDown,
|
|
9720
|
-
isInverse: context.isInverse
|
|
9730
|
+
isInverse: context.isInverse,
|
|
9731
|
+
ref: focusTrapElement
|
|
9721
9732
|
}, context.helperInformationShown ? createElement(HelperInformation, {
|
|
9722
9733
|
isOpen: context.helperInformationShown,
|
|
9723
9734
|
isInverse: context.isInverse,
|
|
9724
|
-
|
|
9735
|
+
onReturnBack: context.hideHelperInformation,
|
|
9736
|
+
onClose: context.onClose
|
|
9725
9737
|
}) : createElement(MonthContainer, {
|
|
9726
9738
|
"data-testid": "monthContainer",
|
|
9727
9739
|
"data-visible": "true",
|
|
9728
9740
|
isInverse: context.isInverse,
|
|
9729
|
-
theme: theme
|
|
9730
|
-
ref: focusTrapElement
|
|
9741
|
+
theme: theme
|
|
9731
9742
|
}, createElement(CalendarHeader, {
|
|
9732
9743
|
ref: headingRef,
|
|
9733
9744
|
focusHeader: focusHeader,
|
|
@@ -9735,7 +9746,8 @@ var CalendarMonth = function CalendarMonth(props) {
|
|
|
9735
9746
|
}), createElement(Table$1, {
|
|
9736
9747
|
onBlur: onCalendarTableBlur,
|
|
9737
9748
|
onFocus: onCalendarTableFocus,
|
|
9738
|
-
theme: theme
|
|
9749
|
+
theme: theme,
|
|
9750
|
+
role: "application"
|
|
9739
9751
|
}, createElement("tbody", null, createElement("tr", null, tableDaysHeaders), context.buildCalendarMonth(context.focusedDate).map(function (week, i) {
|
|
9740
9752
|
return createElement("tr", {
|
|
9741
9753
|
key: i
|
|
@@ -9756,6 +9768,7 @@ var CalendarMonth = function CalendarMonth(props) {
|
|
|
9756
9768
|
}, createElement(HelperButton, {
|
|
9757
9769
|
theme: theme
|
|
9758
9770
|
}, createElement(IconButton, {
|
|
9771
|
+
ref: helperButtonRef,
|
|
9759
9772
|
"aria-label": i18n.datePicker.helpModal.helpButtonAriaLabel,
|
|
9760
9773
|
icon: createElement(KeyboardIcon, null),
|
|
9761
9774
|
onClick: context.showHelperInformation,
|
|
@@ -11671,7 +11684,7 @@ var DatePickerContainer = /*#__PURE__*/_styled("div", {
|
|
|
11671
11684
|
} : {
|
|
11672
11685
|
name: "bjn8wh",
|
|
11673
11686
|
styles: "position:relative",
|
|
11674
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiBuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarMonth } from './CalendarMonth';\r\nimport { Announce } from '../Announce';\r\nimport { Input } from '../Input';\r\nimport { InputType } from '../InputBase';\r\nimport { isMatch, isValid, parse } from 'date-fns';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { EventIcon } from 'react-magma-icons';\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\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate, flip, useFloating, } from '@floating-ui/react-dom';\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        setHelperInformationShown(false);\r\n        lastFocus.current.focus();\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            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        setFocusedDate(getPrevMonthFromDate);\r\n    }\r\n    function onNextMonthClick() {\r\n        setFocusedDate(getNextMonthFromDate);\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                setFocusedDate(newChosenDate);\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 } = useFloating({\r\n        middleware: [flip()],\r\n        placement: 'bottom-start',\r\n        whileElementsMounted: autoUpdate,\r\n    });\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        } },\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: refs.setFloating, 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"]} */",
|
|
11687
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiBuC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarMonth } from './CalendarMonth';\r\nimport { Announce } from '../Announce';\r\nimport { Input } from '../Input';\r\nimport { InputType } from '../InputBase';\r\nimport { addDays, endOfDay, isAfter, isBefore, isMatch, isSameMonth, isValid, parse, setHours, startOfDay, } from 'date-fns';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { EventIcon } from 'react-magma-icons';\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\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate, flip, useFloating, } from '@floating-ui/react-dom';\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    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 } = useFloating({\r\n        middleware: [flip()],\r\n        placement: 'bottom-start',\r\n        whileElementsMounted: autoUpdate,\r\n    });\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            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: refs.setFloating, 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"]} */",
|
|
11675
11688
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$i
|
|
11676
11689
|
});
|
|
11677
11690
|
var DatePickerCalendar = /*#__PURE__*/_styled("div", {
|
|
@@ -11689,7 +11702,7 @@ var DatePickerCalendar = /*#__PURE__*/_styled("div", {
|
|
|
11689
11702
|
return props.theme.spaceScale.spacing01;
|
|
11690
11703
|
}, " 0px;opacity:", function (props) {
|
|
11691
11704
|
return props.opened ? '1' : '0';
|
|
11692
|
-
}, ";overflow:hidden;transition:opacity 0.2s ease-in-out 0s;width:320px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoBsC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarMonth } from './CalendarMonth';\r\nimport { Announce } from '../Announce';\r\nimport { Input } from '../Input';\r\nimport { InputType } from '../InputBase';\r\nimport { isMatch, isValid, parse } from 'date-fns';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { EventIcon } from 'react-magma-icons';\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\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate, flip, useFloating, } from '@floating-ui/react-dom';\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        setHelperInformationShown(false);\r\n        lastFocus.current.focus();\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            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        setFocusedDate(getPrevMonthFromDate);\r\n    }\r\n    function onNextMonthClick() {\r\n        setFocusedDate(getNextMonthFromDate);\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                setFocusedDate(newChosenDate);\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 } = useFloating({\r\n        middleware: [flip()],\r\n        placement: 'bottom-start',\r\n        whileElementsMounted: autoUpdate,\r\n    });\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        } },\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: refs.setFloating, 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"]} */"));
|
|
11705
|
+
}, ";overflow:hidden;transition:opacity 0.2s ease-in-out 0s;width:320px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoBsC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { CalendarContext } from './CalendarContext';\r\nimport { CalendarMonth } from './CalendarMonth';\r\nimport { Announce } from '../Announce';\r\nimport { Input } from '../Input';\r\nimport { InputType } from '../InputBase';\r\nimport { addDays, endOfDay, isAfter, isBefore, isMatch, isSameMonth, isValid, parse, setHours, startOfDay, } from 'date-fns';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { EventIcon } from 'react-magma-icons';\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\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport { transparentize } from 'polished';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate, flip, useFloating, } from '@floating-ui/react-dom';\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    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 } = useFloating({\r\n        middleware: [flip()],\r\n        placement: 'bottom-start',\r\n        whileElementsMounted: autoUpdate,\r\n    });\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            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: refs.setFloating, 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"]} */"));
|
|
11693
11706
|
var DatePicker = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
11694
11707
|
var theme = useContext(ThemeContext);
|
|
11695
11708
|
var i18n = useContext(I18nContext);
|
|
@@ -11730,8 +11743,13 @@ var DatePicker = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
|
11730
11743
|
setHelperInformationShown(true);
|
|
11731
11744
|
}
|
|
11732
11745
|
function hideHelperInformation() {
|
|
11733
|
-
setHelperInformationShown(false);
|
|
11734
11746
|
lastFocus.current.focus();
|
|
11747
|
+
setHelperInformationShown(false);
|
|
11748
|
+
}
|
|
11749
|
+
function closeHelperInformation() {
|
|
11750
|
+
setHelperInformationShown(false);
|
|
11751
|
+
iconRef.current.focus();
|
|
11752
|
+
setCalendarOpened(false);
|
|
11735
11753
|
}
|
|
11736
11754
|
function setDateFromConsumer(date) {
|
|
11737
11755
|
var convertedDate = getDateFromString(date);
|
|
@@ -11744,6 +11762,9 @@ var DatePicker = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
|
11744
11762
|
var convertedMinDate = getDateFromString(props.minDate);
|
|
11745
11763
|
var convertedMaxDate = getDateFromString(props.maxDate);
|
|
11746
11764
|
if (inDateRange(newDate, convertedMinDate, convertedMaxDate)) {
|
|
11765
|
+
if (isBefore(startOfDay(newDate), convertedMinDate)) {
|
|
11766
|
+
return addDays(newDate, 1);
|
|
11767
|
+
}
|
|
11747
11768
|
return newDate;
|
|
11748
11769
|
} else if (convertedMaxDate || convertedMinDate) {
|
|
11749
11770
|
return convertedMinDate ? convertedMinDate : convertedMaxDate;
|
|
@@ -11755,10 +11776,12 @@ var DatePicker = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
|
11755
11776
|
return getCalendarMonthWeeks(date, enableOutsideDates, days.indexOf(startOfWeek));
|
|
11756
11777
|
}
|
|
11757
11778
|
function onPrevMonthClick() {
|
|
11758
|
-
|
|
11779
|
+
var newDate = getPrevMonthFromDate(focusedDate);
|
|
11780
|
+
setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);
|
|
11759
11781
|
}
|
|
11760
11782
|
function onNextMonthClick() {
|
|
11761
|
-
|
|
11783
|
+
var newDate = getNextMonthFromDate(focusedDate);
|
|
11784
|
+
setFocusedDate(isSameMonth(newDate, minDate) ? setDefaultFocusedDate : newDate);
|
|
11762
11785
|
}
|
|
11763
11786
|
function onDateChange(day) {
|
|
11764
11787
|
setChosenDate(day);
|
|
@@ -11812,7 +11835,21 @@ var DatePicker = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
|
11812
11835
|
if (dateFocused && document.activeElement.closest('table')) {
|
|
11813
11836
|
var newChosenDate = handleKeyPress(event, focusedDate, setCalendarOpened, showHelperInformation, onDateChange, iconRef);
|
|
11814
11837
|
if (newChosenDate) {
|
|
11815
|
-
|
|
11838
|
+
if (minDate && maxDate) {
|
|
11839
|
+
if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate)) && isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {
|
|
11840
|
+
setFocusedDate(newChosenDate);
|
|
11841
|
+
}
|
|
11842
|
+
} else if (minDate && !maxDate) {
|
|
11843
|
+
if (isAfter(setHours(newChosenDate, 12), startOfDay(minDate))) {
|
|
11844
|
+
setFocusedDate(newChosenDate);
|
|
11845
|
+
}
|
|
11846
|
+
} else if (maxDate && !minDate) {
|
|
11847
|
+
if (isBefore(setHours(newChosenDate, 12), endOfDay(maxDate))) {
|
|
11848
|
+
setFocusedDate(newChosenDate);
|
|
11849
|
+
}
|
|
11850
|
+
} else {
|
|
11851
|
+
setFocusedDate(newChosenDate);
|
|
11852
|
+
}
|
|
11816
11853
|
}
|
|
11817
11854
|
}
|
|
11818
11855
|
}
|
|
@@ -11820,7 +11857,7 @@ var DatePicker = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
|
11820
11857
|
props.onDateChange && typeof props.onDateChange === 'function' && props.onDateChange(day, event);
|
|
11821
11858
|
props.onChange && typeof props.onChange === 'function' && props.onChange(day == null ? void 0 : day.toISOString(), event);
|
|
11822
11859
|
onDateChange(day);
|
|
11823
|
-
setFocusedDate(day);
|
|
11860
|
+
setFocusedDate(isAfter(setHours(day, 12), minDate) ? day : setDefaultFocusedDate);
|
|
11824
11861
|
}
|
|
11825
11862
|
function handleDaySelection(day, event) {
|
|
11826
11863
|
handleDateChange(day, event);
|
|
@@ -11878,7 +11915,8 @@ var DatePicker = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
|
11878
11915
|
onPrevMonthClick: onPrevMonthClick,
|
|
11879
11916
|
onNextMonthClick: onNextMonthClick,
|
|
11880
11917
|
onDateChange: handleDaySelection,
|
|
11881
|
-
setDateFocused: setDateFocused
|
|
11918
|
+
setDateFocused: setDateFocused,
|
|
11919
|
+
onClose: closeHelperInformation
|
|
11882
11920
|
}
|
|
11883
11921
|
}, createElement(DatePickerContainer, {
|
|
11884
11922
|
"data-testid": testId,
|