react-magma-dom 4.6.0 → 4.7.0-next.1

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.
@@ -1467,10 +1467,6 @@ var defaultI18n = {
1467
1467
  ariaLabel: 'Escape key',
1468
1468
  displayValue: 'ESC',
1469
1469
  explanation: 'Return to the date input field.'
1470
- },
1471
- questionMark: {
1472
- ariaLabel: 'Question Mark',
1473
- explanation: 'Open this panel.'
1474
1470
  }
1475
1471
  }
1476
1472
  },
@@ -6099,10 +6095,6 @@ function handleKeyPress(e, prevDate, toggleCalendar, showHelperInformation, onDa
6099
6095
  toggleCalendar(false);
6100
6096
  iconRef.current.focus();
6101
6097
  break;
6102
- case '?':
6103
- e.preventDefault();
6104
- showHelperInformation();
6105
- break;
6106
6098
  }
6107
6099
  }
6108
6100
  function getCalendarMonthWeeks(month, enableOutsideDays, firstDayOfWeek) {
@@ -6391,7 +6383,7 @@ var List = /*#__PURE__*/_styled("ul", {
6391
6383
  })( {
6392
6384
  name: "1s0dwnn",
6393
6385
  styles: "list-style:none;margin:0;padding:0;text-align:left",
6394
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAUuB","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\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 isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\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.onClose }, \"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                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.questionMark.ariaLabel, isInverse: isInverse }, \"?\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.questionMark.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */",
6386
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAUuB","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\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 isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\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.onClose }, \"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"]} */",
6395
6387
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$h
6396
6388
  });
6397
6389
  var Item = /*#__PURE__*/_styled("li", {
@@ -6401,7 +6393,7 @@ var Item = /*#__PURE__*/_styled("li", {
6401
6393
  return props.theme.typeScale.size02.fontSize;
6402
6394
  }, ";line-height:", function (props) {
6403
6395
  return props.theme.typeScale.size02.lineHeight;
6404
- }, ";align-items:center;span{flex:0 0 100px;overflow:hidden;line-height:28px;min-height:36px;height:max-content;text-align:center;}div{flex:1;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAgBuB","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\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 isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\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.onClose }, \"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                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.questionMark.ariaLabel, isInverse: isInverse }, \"?\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.questionMark.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
6396
+ }, ";align-items:center;span{flex:0 0 100px;overflow:hidden;line-height:28px;min-height:36px;height:max-content;text-align:center;}div{flex:1;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAgBuB","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\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 isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\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.onClose }, \"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"]} */"));
6405
6397
  var KeyboardShortcutButtonWrapper = /*#__PURE__*/_styled("span", {
6406
6398
  target: "egx42px4",
6407
6399
  label: "KeyboardShortcutButtonWrapper"
@@ -6419,14 +6411,14 @@ var KeyboardShortcutButtonWrapper = /*#__PURE__*/_styled("span", {
6419
6411
  return props.theme.spaceScale.spacing02;
6420
6412
  }, " ", function (props) {
6421
6413
  return props.theme.spaceScale.spacing04;
6422
- }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAmCkD","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\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 isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\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.onClose }, \"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                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.questionMark.ariaLabel, isInverse: isInverse }, \"?\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.questionMark.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
6414
+ }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAmCkD","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\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 isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\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.onClose }, \"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"]} */"));
6423
6415
  var StyledPopup = /*#__PURE__*/_styled("div", {
6424
6416
  target: "egx42px3",
6425
6417
  label: "StyledPopup"
6426
6418
  })( {
6427
6419
  name: "bjn8wh",
6428
6420
  styles: "position:relative",
6429
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAgD+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\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 isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\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.onClose }, \"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                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.questionMark.ariaLabel, isInverse: isInverse }, \"?\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.questionMark.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */",
6421
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAgD+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\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 isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\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.onClose }, \"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"]} */",
6430
6422
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$h
6431
6423
  });
6432
6424
  var StyledNavContainer = /*#__PURE__*/_styled("div", {
@@ -6435,7 +6427,7 @@ var StyledNavContainer = /*#__PURE__*/_styled("div", {
6435
6427
  })( {
6436
6428
  name: "l6h0c2",
6437
6429
  styles: "display:flex;justify-content:space-between;padding:2px",
6438
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAmDsC","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\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 isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\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.onClose }, \"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                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.questionMark.ariaLabel, isInverse: isInverse }, \"?\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.questionMark.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */",
6430
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAmDsC","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\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 isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\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.onClose }, \"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"]} */",
6439
6431
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$h
6440
6432
  });
6441
6433
  var StyledContent = /*#__PURE__*/_styled("div", {
@@ -6444,13 +6436,13 @@ var StyledContent = /*#__PURE__*/_styled("div", {
6444
6436
  })("z-index:9999;position:relative;color:", function (props) {
6445
6437
  var _props$theme, _props$theme2;
6446
6438
  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;
6447
- }, ";h2{margin:10px 0 12px 0;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAwDiC","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\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 isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\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.onClose }, \"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                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.questionMark.ariaLabel, isInverse: isInverse }, \"?\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.questionMark.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
6439
+ }, ";h2{margin:10px 0 12px 0;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAwDiC","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\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 isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\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.onClose }, \"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"]} */"));
6448
6440
  var StyledDescription = /*#__PURE__*/_styled("p", {
6449
6441
  target: "egx42px0",
6450
6442
  label: "StyledDescription"
6451
6443
  })("font-family:", function (props) {
6452
6444
  return props.theme.bodyFont;
6453
- }, ";margin:0;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAmEmC","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\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 isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\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.onClose }, \"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                React.createElement(Item, { theme: theme },\r\n                    React.createElement(KeyboardShortcutButtonWrapper, { role: \"img\", theme: theme, \"aria-label\": i18n.datePicker.helpModal.questionMark.ariaLabel, isInverse: isInverse }, \"?\"),\r\n                    React.createElement(StyledDescription, { theme: theme }, i18n.datePicker.helpModal.questionMark.explanation))))));\r\n};\r\n//# sourceMappingURL=HelperInformation.js.map"]} */"));
6445
+ }, ";margin:0;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["HelperInformation.tsx"],"names":[],"mappings":"AAmEmC","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\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 isInverse = useIsInverse(props.isInverse);\r\n    return (React.createElement(StyledPopup, null,\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.onClose }, \"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"]} */"));
6454
6446
  var HelperInformation = function HelperInformation(props) {
6455
6447
  var i18n = React.useContext(I18nContext);
6456
6448
  var theme = React.useContext(ThemeContext);
@@ -6540,16 +6532,7 @@ var HelperInformation = function HelperInformation(props) {
6540
6532
  isInverse: isInverse
6541
6533
  }, i18n.datePicker.helpModal.escape.displayValue), React.createElement(StyledDescription, {
6542
6534
  theme: theme
6543
- }, i18n.datePicker.helpModal.escape.explanation)), React.createElement(Item, {
6544
- theme: theme
6545
- }, React.createElement(KeyboardShortcutButtonWrapper, {
6546
- role: "img",
6547
- theme: theme,
6548
- "aria-label": i18n.datePicker.helpModal.questionMark.ariaLabel,
6549
- isInverse: isInverse
6550
- }, "?"), React.createElement(StyledDescription, {
6551
- theme: theme
6552
- }, i18n.datePicker.helpModal.questionMark.explanation)))));
6535
+ }, i18n.datePicker.helpModal.escape.explanation)))));
6553
6536
  };
6554
6537
 
6555
6538
  function useFocusLock(active, header, body) {
@@ -6886,7 +6869,7 @@ var DatePickerContainer = /*#__PURE__*/_styled("div", {
6886
6869
  })( {
6887
6870
  name: "bjn8wh",
6888
6871
  styles: "position:relative",
6889
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgBuC","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 { isValid, parse, isMatch } from 'date-fns';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { EventIcon } from 'react-magma-icons';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nimport { handleKeyPress, getCalendarMonthWeeks, getPrevMonthFromDate, getNextMonthFromDate, i18nFormat as format, getDateFromString, inDateRange, } from './utils';\r\nimport { omit, useGenerateId, useForkedRef } 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\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-top: ${props => props.theme.spaceScale.spacing01};\n  opacity: ${props => (props.opened ? '1' : '0')};\n  overflow: hidden;\n  position: absolute;\n  transition: opacity 0.2s ease-in-out 0s;\n  width: 320px;\n  z-index: ${props => (props.opened ? '998' : '-1')};\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        else {\r\n            if (event.key === '?') {\r\n                showHelperInformation();\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    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 })),\r\n            React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n                React.createElement(DatePickerCalendar, { \"data-testid\": \"calendarContainer\", opened: calendarOpened, isInverse: isInverse, theme: theme },\r\n                    React.createElement(CalendarMonth, { focusOnOpen: calendarOpened && Boolean(focusedDate) && Boolean(chosenDate), isInverse: isInverse, handleCloseButtonClick: handleCloseButtonClick, calendarOpened: calendarOpened, setDateFocused: setDateFocused }))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
6872
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgBuC","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 { isValid, parse, isMatch } from 'date-fns';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { EventIcon } from 'react-magma-icons';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nimport { handleKeyPress, getCalendarMonthWeeks, getPrevMonthFromDate, getNextMonthFromDate, i18nFormat as format, getDateFromString, inDateRange, } from './utils';\r\nimport { omit, useGenerateId, useForkedRef } 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\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-top: ${props => props.theme.spaceScale.spacing01};\n  opacity: ${props => (props.opened ? '1' : '0')};\n  overflow: hidden;\n  position: absolute;\n  transition: opacity 0.2s ease-in-out 0s;\n  width: 320px;\n  z-index: ${props => (props.opened ? '998' : '-1')};\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    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 })),\r\n            React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n                React.createElement(DatePickerCalendar, { \"data-testid\": \"calendarContainer\", opened: calendarOpened, isInverse: isInverse, theme: theme },\r\n                    React.createElement(CalendarMonth, { focusOnOpen: calendarOpened && Boolean(focusedDate) && Boolean(chosenDate), isInverse: isInverse, handleCloseButtonClick: handleCloseButtonClick, calendarOpened: calendarOpened, setDateFocused: setDateFocused }))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
6890
6873
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$i
6891
6874
  });
6892
6875
  var DatePickerCalendar = /*#__PURE__*/_styled("div", {
@@ -6906,7 +6889,7 @@ var DatePickerCalendar = /*#__PURE__*/_styled("div", {
6906
6889
  return props.opened ? '1' : '0';
6907
6890
  }, ";overflow:hidden;position:absolute;transition:opacity 0.2s ease-in-out 0s;width:320px;z-index:", function (props) {
6908
6891
  return props.opened ? '998' : '-1';
6909
- }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAmBsC","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 { isValid, parse, isMatch } from 'date-fns';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { EventIcon } from 'react-magma-icons';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nimport { handleKeyPress, getCalendarMonthWeeks, getPrevMonthFromDate, getNextMonthFromDate, i18nFormat as format, getDateFromString, inDateRange, } from './utils';\r\nimport { omit, useGenerateId, useForkedRef } 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\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-top: ${props => props.theme.spaceScale.spacing01};\n  opacity: ${props => (props.opened ? '1' : '0')};\n  overflow: hidden;\n  position: absolute;\n  transition: opacity 0.2s ease-in-out 0s;\n  width: 320px;\n  z-index: ${props => (props.opened ? '998' : '-1')};\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        else {\r\n            if (event.key === '?') {\r\n                showHelperInformation();\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    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 })),\r\n            React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n                React.createElement(DatePickerCalendar, { \"data-testid\": \"calendarContainer\", opened: calendarOpened, isInverse: isInverse, theme: theme },\r\n                    React.createElement(CalendarMonth, { focusOnOpen: calendarOpened && Boolean(focusedDate) && Boolean(chosenDate), isInverse: isInverse, handleCloseButtonClick: handleCloseButtonClick, calendarOpened: calendarOpened, setDateFocused: setDateFocused }))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
6892
+ }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAmBsC","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 { isValid, parse, isMatch } from 'date-fns';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { EventIcon } from 'react-magma-icons';\r\nimport { VisuallyHidden } from '../VisuallyHidden';\r\nimport { handleKeyPress, getCalendarMonthWeeks, getPrevMonthFromDate, getNextMonthFromDate, i18nFormat as format, getDateFromString, inDateRange, } from './utils';\r\nimport { omit, useGenerateId, useForkedRef } 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\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-top: ${props => props.theme.spaceScale.spacing01};\n  opacity: ${props => (props.opened ? '1' : '0')};\n  overflow: hidden;\n  position: absolute;\n  transition: opacity 0.2s ease-in-out 0s;\n  width: 320px;\n  z-index: ${props => (props.opened ? '998' : '-1')};\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    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 })),\r\n            React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n                React.createElement(DatePickerCalendar, { \"data-testid\": \"calendarContainer\", opened: calendarOpened, isInverse: isInverse, theme: theme },\r\n                    React.createElement(CalendarMonth, { focusOnOpen: calendarOpened && Boolean(focusedDate) && Boolean(chosenDate), isInverse: isInverse, handleCloseButtonClick: handleCloseButtonClick, calendarOpened: calendarOpened, setDateFocused: setDateFocused }))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
6910
6893
  var DatePicker = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
6911
6894
  var theme = React.useContext(ThemeContext);
6912
6895
  var i18n = React.useContext(I18nContext);
@@ -7031,10 +7014,6 @@ var DatePicker = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
7031
7014
  if (newChosenDate) {
7032
7015
  setFocusedDate(newChosenDate);
7033
7016
  }
7034
- } else {
7035
- if (event.key === '?') {
7036
- showHelperInformation();
7037
- }
7038
7017
  }
7039
7018
  }
7040
7019
  function handleDateChange(day, event) {
@@ -14305,1380 +14284,1046 @@ var BlockQuoteItem = /*#__PURE__*/React.forwardRef(function (props, ref) {
14305
14284
  }, rest), hasAttribution ? React.createElement(React.Fragment, null, "\u2015\xA0", children) : React.createElement(React.Fragment, null, "\u201C", children, "\u201D"));
14306
14285
  });
14307
14286
 
14308
- (function (TreeNodeType) {
14309
- TreeNodeType["branch"] = "branch";
14310
- TreeNodeType["leaf"] = "leaf";
14311
- })(exports.TreeNodeType || (exports.TreeNodeType = {}));
14312
- /**
14313
- * Leaf node - 1st level has 40px of left padding.
14314
- * Each level after that adds 56px of left padding.
14315
- * 40, 64, 88, 112, 136, etc.
14316
- *
14317
- * Branch node - 1st level has 8px of left padding.
14318
- * Each level after that adds 24px of left padding.
14319
- * 8, 32, 56, 80, 104, etc.
14320
- *
14321
- * The label element (the div inside the li) gets additional spacing.
14322
- * In order to highlight the entire line, we need to negate the value for margin.
14323
- */
14324
- function calculateOffset(type, depth, labelElem, negative) {
14325
- if (depth === void 0) {
14326
- depth = 0;
14327
- }
14328
- if (labelElem === void 0) {
14329
- labelElem = false;
14330
- }
14331
- if (negative === void 0) {
14332
- negative = false;
14287
+ (function (TreeViewSelectable) {
14288
+ TreeViewSelectable["single"] = "single";
14289
+ TreeViewSelectable["multi"] = "multi";
14290
+ TreeViewSelectable["off"] = "off";
14291
+ })(exports.TreeViewSelectable || (exports.TreeViewSelectable = {}));
14292
+
14293
+ var TreeViewContext = /*#__PURE__*/React.createContext({
14294
+ hasIcons: false,
14295
+ initialExpandedItems: [],
14296
+ initialExpandedItemsNeedUpdate: false,
14297
+ registerTreeItem: function registerTreeItem(elements, element) {},
14298
+ selectable: exports.TreeViewSelectable.single,
14299
+ selectedItems: [],
14300
+ setInitialExpandedItemsNeedUpdate: function setInitialExpandedItemsNeedUpdate() {},
14301
+ checkParents: true,
14302
+ checkChildren: true,
14303
+ items: [],
14304
+ selectItem: function selectItem() {
14305
+ return undefined;
14333
14306
  }
14334
- var padding = 0;
14335
- if (type === exports.TreeNodeType.leaf) {
14336
- if (labelElem) {
14337
- padding = depth * 8 + 40;
14338
- if (depth !== 0) {
14339
- padding += depth * 16;
14340
- }
14341
- } else if (depth === 0) {
14342
- padding = 40;
14343
- } else {
14344
- padding = 56;
14307
+ });
14308
+
14309
+ var checkedStatusToBoolean = function checkedStatusToBoolean(status) {
14310
+ return status === exports.IndeterminateCheckboxStatus.checked;
14311
+ };
14312
+ function useTreeItem(props, forwardedRef) {
14313
+ var children = props.children,
14314
+ _props$isDisabled = props.isDisabled,
14315
+ isDisabled = _props$isDisabled === void 0 ? false : _props$isDisabled,
14316
+ itemDepth = props.itemDepth,
14317
+ itemId = props.itemId,
14318
+ onClick = props.onClick,
14319
+ parentDepth = props.parentDepth,
14320
+ topLevel = props.topLevel;
14321
+ var _React$useContext = React.useContext(TreeViewContext),
14322
+ initialExpandedItems = _React$useContext.initialExpandedItems,
14323
+ registerTreeItem = _React$useContext.registerTreeItem,
14324
+ selectable = _React$useContext.selectable,
14325
+ selectedItems = _React$useContext.selectedItems,
14326
+ treeItemRefArray = _React$useContext.treeItemRefArray,
14327
+ initialExpandedItemsNeedUpdate = _React$useContext.initialExpandedItemsNeedUpdate,
14328
+ items = _React$useContext.items,
14329
+ selectItem = _React$useContext.selectItem;
14330
+ var treeViewItemData = React.useMemo(function () {
14331
+ return items.find(function (item) {
14332
+ return item.itemId === itemId;
14333
+ });
14334
+ }, [itemId, items]);
14335
+ var checkedStatus = React.useMemo(function () {
14336
+ var _treeViewItemData$che;
14337
+ return (_treeViewItemData$che = treeViewItemData == null ? void 0 : treeViewItemData.checkedStatus) != null ? _treeViewItemData$che : exports.IndeterminateCheckboxStatus.unchecked;
14338
+ }, [treeViewItemData]);
14339
+ var hasOwnTreeItems = React.useMemo(function () {
14340
+ return treeViewItemData == null ? void 0 : treeViewItemData.hasOwnTreeItems;
14341
+ }, [treeViewItemData]);
14342
+ var _React$useState = React.useState(false),
14343
+ expanded = _React$useState[0],
14344
+ setExpanded = _React$useState[1];
14345
+ var treeItemChildren = React.Children.toArray(children).filter(function (child) {
14346
+ return child.type === TreeItem;
14347
+ });
14348
+ var ownRef = React.useRef();
14349
+ var ref = useForkedRef(forwardedRef, ownRef);
14350
+ var forceUpdate = useForceUpdate();
14351
+ var generatedId = useGenerateId();
14352
+ React.useEffect(function () {
14353
+ if (!isDisabled && ownRef.current !== null) {
14354
+ registerTreeItem(treeItemRefArray, ownRef);
14345
14355
  }
14346
- } else if (type === exports.TreeNodeType.branch) {
14347
- if (labelElem) {
14348
- padding = depth * 8 + 8;
14349
- if (depth !== 0) {
14350
- padding += depth * 16;
14356
+ forceUpdate();
14357
+ }, []);
14358
+ React.useEffect(function () {
14359
+ if (initialExpandedItemsNeedUpdate) {
14360
+ updateInitialExpanded();
14361
+ }
14362
+ }, [initialExpandedItemsNeedUpdate]);
14363
+ var updateInitialExpanded = function updateInitialExpanded() {
14364
+ if ((initialExpandedItems == null ? void 0 : initialExpandedItems.length) !== 0 && !isDisabled) {
14365
+ var childrenItemIds = getChildrenItemIdsFlat(treeItemChildren);
14366
+ var allExpanded = [].concat(initialExpandedItems, childrenItemIds);
14367
+ if (allExpanded != null && allExpanded.some(function (item) {
14368
+ return item === itemId;
14369
+ })) {
14370
+ setExpanded(true);
14371
+ } else {
14372
+ setExpanded(false);
14351
14373
  }
14352
- } else if (depth === 0) {
14353
- padding = 8;
14354
14374
  } else {
14355
- padding = 24;
14375
+ setExpanded(false);
14356
14376
  }
14357
- }
14358
- return "" + (negative ? '-' : '') + padding + "px";
14359
- }
14360
- function getTreeItemLabelColor(isInverse, disabled, theme) {
14361
- if (disabled) {
14362
- if (isInverse) {
14363
- return polished.transparentize(0.6, theme.colors.neutral100);
14377
+ };
14378
+ var checkboxChangeHandler = function checkboxChangeHandler(event) {
14379
+ handleClick(event, itemId);
14380
+ };
14381
+ var handleClick = function handleClick(event, itemId) {
14382
+ if (selectable !== exports.TreeViewSelectable.off) {
14383
+ selectItem({
14384
+ itemId: itemId,
14385
+ checkedStatus: checkedStatus === exports.IndeterminateCheckboxStatus.checked ? exports.IndeterminateCheckboxStatus.unchecked : exports.IndeterminateCheckboxStatus.checked
14386
+ });
14387
+ onClick && typeof onClick === 'function' && onClick();
14364
14388
  }
14365
- return polished.transparentize(0.6, theme.colors.neutral500);
14366
- }
14367
- if (isInverse) {
14368
- return theme.colors.neutral100;
14369
- }
14370
- return theme.colors.neutral700;
14371
- }
14372
- function getTreeItemWrapperCursor(disabled, selectable, nodeType) {
14373
- if (disabled) {
14374
- return 'not-allowed';
14375
- }
14376
- if (nodeType === exports.TreeNodeType.branch && selectable === exports.TreeViewSelectable.off || selectable === exports.TreeViewSelectable.single) {
14377
- return 'pointer';
14378
- }
14379
- return 'default';
14380
- }
14381
- // Returns boolean if itemsArray has itemId
14382
- function arrayIncludesId(itemsArray, itemId) {
14383
- return itemsArray == null ? void 0 : itemsArray.some(function (item) {
14384
- return item.itemId === itemId;
14385
- });
14386
- }
14387
- // Return an array of objects of all the enabled children ids recursively
14388
- function getChildrenItemIds(children, status) {
14389
- if (status === void 0) {
14390
- status = '';
14389
+ };
14390
+ function getFocusIndex(filteredArrayCurrent) {
14391
+ return itemId && (filteredArrayCurrent == null ? void 0 : filteredArrayCurrent.findIndex(function (_ref) {
14392
+ var item = _ref.current;
14393
+ if (!item || !ownRef.current) return false;
14394
+ return item === ownRef.current;
14395
+ }));
14391
14396
  }
14392
- var itemIds = [];
14393
- React__default.Children.forEach(children, function (child) {
14394
- var _child$props;
14395
- if (!((_child$props = child.props) != null && _child$props.isDisabled)) {
14396
- var _child$props2, _child$props3;
14397
- var childStatus = status === exports.IndeterminateCheckboxStatus.checked ? exports.IndeterminateCheckboxStatus.checked : exports.IndeterminateCheckboxStatus.unchecked;
14398
- if ((_child$props2 = child.props) != null && _child$props2.itemId && childStatus !== exports.IndeterminateCheckboxStatus.unchecked) {
14399
- itemIds.push({
14400
- itemId: child.props.itemId,
14401
- checkedStatus: childStatus
14397
+ var focusIndex = getFocusIndex(treeItemRefArray == null ? void 0 : treeItemRefArray.current);
14398
+ React.useEffect(function () {
14399
+ treeItemRefArray == null || treeItemRefArray.current.map(function (itemRef) {
14400
+ if (!itemRef.current) {
14401
+ treeItemRefArray.current = treeItemRefArray.current.filter(function (item) {
14402
+ return itemRef.current !== item.current;
14402
14403
  });
14403
14404
  }
14404
- if ((_child$props3 = child.props) != null && _child$props3.children) {
14405
- var nestedItemIds = getChildrenItemIds(child.props.children, childStatus);
14406
- itemIds = itemIds.concat(nestedItemIds);
14407
- }
14405
+ });
14406
+ }, [treeItemRefArray]);
14407
+ var focusFirst = function focusFirst() {
14408
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
14409
+ var curr = filteredRefArray['current'];
14410
+ curr == null || curr[0].current.focus();
14411
+ };
14412
+ var focusNext = function focusNext() {
14413
+ var _curr$newIndex;
14414
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
14415
+ var curr = filteredRefArray['current'];
14416
+ var arrLength = curr.length;
14417
+ focusIndex = getFocusIndex(curr);
14418
+ var newIndex = focusIndex + 1;
14419
+ var next = curr == null || (_curr$newIndex = curr[newIndex]) == null ? void 0 : _curr$newIndex.current;
14420
+ while (!next && newIndex < arrLength) {
14421
+ var _curr$newIndex2;
14422
+ newIndex++;
14423
+ next = curr == null || (_curr$newIndex2 = curr[newIndex]) == null ? void 0 : _curr$newIndex2.current;
14408
14424
  }
14409
- });
14410
- return itemIds;
14411
- }
14412
- // Return an array of strings of all enabled children ids recursively
14413
- function getChildrenItemIdsFlat(children) {
14414
- var itemIds = [];
14415
- React__default.Children.forEach(children, function (child) {
14416
- var _child$props4;
14417
- if (!((_child$props4 = child.props) != null && _child$props4.isDisabled)) {
14418
- var _child$props5, _child$props6;
14419
- if ((_child$props5 = child.props) != null && _child$props5.itemId) {
14420
- itemIds.push(child.props.itemId);
14421
- }
14422
- if ((_child$props6 = child.props) != null && _child$props6.children) {
14423
- var nestedItemIds = getChildrenItemIdsFlat(child.props.children);
14424
- itemIds = itemIds.concat(nestedItemIds);
14425
+ if (next) {
14426
+ next.focus();
14427
+ } else {
14428
+ var _curr;
14429
+ var nextNext = curr == null || (_curr = curr[focusIndex + 2]) == null ? void 0 : _curr.current;
14430
+ if (nextNext) {
14431
+ nextNext.focus();
14432
+ } else {
14433
+ focusFirst();
14425
14434
  }
14426
14435
  }
14427
- });
14428
- return itemIds;
14429
- }
14430
- // Return an array of objects where all children are items are nested in the parents
14431
- function getChildrenItemIdsInTree(children) {
14432
- var itemIds = [];
14433
- React__default.Children.forEach(children, function (child) {
14434
- var _child$props7, _child$props8;
14435
- if ((_child$props7 = child.props) != null && _child$props7.itemId && !((_child$props8 = child.props) != null && _child$props8.isDisabled)) {
14436
- var _child$props9, _child$props10;
14437
- itemIds.push({
14438
- itemId: (_child$props9 = child.props) == null ? void 0 : _child$props9.itemId,
14439
- children: getChildrenItemIdsInTree((_child$props10 = child.props) == null ? void 0 : _child$props10.children)
14440
- });
14436
+ };
14437
+ var focusPrev = function focusPrev() {
14438
+ var _curr$newIndex3;
14439
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
14440
+ var curr = filteredRefArray['current'];
14441
+ focusIndex = getFocusIndex(curr);
14442
+ var newIndex = focusIndex - 1;
14443
+ var itemToFocus = curr == null || (_curr$newIndex3 = curr[newIndex]) == null ? void 0 : _curr$newIndex3.current;
14444
+ while (!itemToFocus && newIndex >= 0) {
14445
+ var _curr$newIndex4;
14446
+ newIndex--;
14447
+ itemToFocus = curr == null || (_curr$newIndex4 = curr[newIndex]) == null ? void 0 : _curr$newIndex4.current;
14441
14448
  }
14442
- });
14443
- return itemIds;
14444
- }
14445
- function getAllParentIds(childrenArr, itemId, parentItemIds) {
14446
- if (parentItemIds === void 0) {
14447
- parentItemIds = [];
14448
- }
14449
- for (var _iterator = _createForOfIteratorHelperLoose(childrenArr), _step; !(_step = _iterator()).done;) {
14450
- var child = _step.value;
14451
- if (child.itemId === itemId) {
14452
- return parentItemIds; // Return the parentItemIds array if the itemId is found
14453
- }
14454
- if (child.children && child.children.length > 0) {
14455
- var updatedParentItemIds = [].concat(parentItemIds, [child.itemId]);
14456
- var result = getAllParentIds(child.children, itemId, updatedParentItemIds);
14457
- if (result) {
14458
- return result; // Return the result if the itemId is found in the child's subtree
14459
- }
14460
- }
14461
- }
14462
- return null; // Return null if the itemId is not found
14463
- }
14464
- // Return the node of an itemId by traversing through the children
14465
- function findChildByItemId(children, itemId) {
14466
- if (!children) {
14467
- return null;
14468
- }
14469
- for (var _iterator2 = _createForOfIteratorHelperLoose(children), _step2; !(_step2 = _iterator2()).done;) {
14470
- var _child$props11, _child$props12;
14471
- var child = _step2.value;
14472
- if ((child == null || (_child$props11 = child.props) == null ? void 0 : _child$props11.itemId) === itemId) {
14473
- return child;
14474
- }
14475
- if (child != null && (_child$props12 = child.props) != null && _child$props12.children) {
14476
- var _child$props13;
14477
- var nestedChild = findChildByItemId([child == null || (_child$props13 = child.props) == null ? void 0 : _child$props13.children], itemId);
14478
- if (nestedChild) {
14479
- return nestedChild;
14480
- }
14481
- }
14482
- }
14483
- return null;
14484
- }
14485
- // Return whether all the children are enabled
14486
- function getAllChildrenEnabled(children) {
14487
- return !children.some(function (child) {
14488
- return child.props.isDisabled;
14489
- });
14490
- }
14491
- // Return an array that filters out the childrenIds & itemId from selectedItems
14492
- // (used for deselecting indeterminate checkboxes)
14493
- function filterSelectedItems(selectedItems, childrenIds, itemId) {
14494
- var allItems = [].concat(childrenIds, [itemId]);
14495
- var ids = allItems.map(function (item) {
14496
- return item.itemId;
14497
- });
14498
- return selectedItems.filter(function (item) {
14499
- return !ids.includes(item.itemId);
14500
- });
14501
- }
14502
- // Return an array of childrenIds that are missing from selectedItems
14503
- function getMissingChildrenIds(selectedItems, childrenIds) {
14504
- var selectedIds = selectedItems.map(function (item) {
14505
- return item.itemId;
14506
- });
14507
- return childrenIds.filter(function (item) {
14508
- return !selectedIds.includes(item.itemId);
14509
- });
14510
- }
14511
- // Return an array of statuses for all enabled children
14512
- function getChildrenCheckedStatus(childrenIds, status) {
14513
- return childrenIds.map(function (child) {
14514
- return child.isDisabled ? exports.IndeterminateCheckboxStatus.unchecked : status;
14515
- });
14516
- }
14517
- // Return the length of enabled children
14518
- function getEnabledTreeItemChildrenLength(treeItemChildren) {
14519
- return treeItemChildren.reduce(function (count, child) {
14520
- if (!child.props.isDisabled) {
14521
- return count + 1;
14522
- }
14523
- return count;
14524
- }, 0);
14525
- }
14526
- // Updates the checkedStatus of the itemId in selectedItems and returns the selectedItems
14527
- function getUpdatedSelectedItems(selectedItems, itemId, checkedStatus) {
14528
- var updatedItems = selectedItems.map(function (item) {
14529
- if (item.itemId === itemId) {
14530
- return _extends({}, item, {
14531
- checkedStatus: checkedStatus
14532
- });
14533
- }
14534
- return item;
14535
- });
14536
- return updatedItems;
14537
- }
14538
- // Return an array of unique items from the previous state, initially selected items and the childrem item ids
14539
- function getUniqueSelectedItemsArray(itemArr0, itemArr1, itemArr2) {
14540
- var combinedArray = [].concat(itemArr0, itemArr2, itemArr1);
14541
- var uniqueItemsMap = new Map();
14542
- for (var _iterator3 = _createForOfIteratorHelperLoose(combinedArray), _step3; !(_step3 = _iterator3()).done;) {
14543
- var item = _step3.value;
14544
- uniqueItemsMap.set(item.itemId, item);
14545
- }
14546
- return Array.from(uniqueItemsMap.values());
14547
- }
14548
- // Return items in both arrays
14549
- function findCommonItems(initialItemsArr, childrenItemsArr) {
14550
- var commonItems = [];
14551
- for (var _iterator4 = _createForOfIteratorHelperLoose(initialItemsArr), _step4; !(_step4 = _iterator4()).done;) {
14552
- var initialItem = _step4.value;
14553
- for (var _iterator5 = _createForOfIteratorHelperLoose(childrenItemsArr), _step5; !(_step5 = _iterator5()).done;) {
14554
- var childItem = _step5.value;
14555
- if (initialItem.itemId === childItem.itemId) {
14556
- commonItems.push(initialItem);
14557
- break;
14558
- }
14559
- }
14560
- }
14561
- return commonItems;
14562
- }
14563
- // Compares two arrays
14564
- function areArraysEqual(array1, array2) {
14565
- if (array1.length !== array2.length) {
14566
- return false;
14567
- }
14568
- for (var i = 0; i < array1.length; i++) {
14569
- var obj1 = array1[i];
14570
- var obj2 = array2[i];
14571
- var keys1 = Object.keys(obj1);
14572
- var keys2 = Object.keys(obj2);
14573
- if (keys1.length !== keys2.length) {
14574
- return false;
14575
- }
14576
- for (var _i = 0, _keys = keys1; _i < _keys.length; _i++) {
14577
- var key = _keys[_i];
14578
- if (obj1[key] !== obj2[key]) {
14579
- return false;
14580
- }
14581
- }
14582
- }
14583
- return true;
14584
- }
14585
- // Return the checkedStatus of an itemId
14586
- function getCheckedStatus(itemId, selectedItems) {
14587
- for (var _iterator6 = _createForOfIteratorHelperLoose(selectedItems), _step6; !(_step6 = _iterator6()).done;) {
14588
- var item = _step6.value;
14589
- if (item.itemId === itemId) {
14590
- return item.checkedStatus;
14591
- }
14592
- }
14593
- return null;
14594
- }
14595
- // Return first child that is a branch
14596
- function findFirstBranchNode(children) {
14597
- for (var _iterator7 = _createForOfIteratorHelperLoose(children), _step7; !(_step7 = _iterator7()).done;) {
14598
- var _item$props, _item$props2, _item$props3, _item$props4;
14599
- var item = _step7.value;
14600
- if ((_item$props = item.props) != null && _item$props.children && (_item$props2 = item.props) != null && _item$props2.children) {
14601
- return item;
14449
+ if (itemToFocus) {
14450
+ itemToFocus.focus();
14602
14451
  }
14603
- if ((_item$props3 = item.props) != null && _item$props3.children && ((_item$props4 = item.props) == null ? void 0 : _item$props4.children.length) === 0) {
14604
- var _item$props5;
14605
- var childResult = findFirstBranchNode((_item$props5 = item.props) == null ? void 0 : _item$props5.children);
14606
- if (childResult) {
14607
- return childResult;
14452
+ };
14453
+ var focusLast = function focusLast() {
14454
+ var _filteredRefArray$cur;
14455
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
14456
+ var arrLength = filteredRefArray['current'].length;
14457
+ (_filteredRefArray$cur = filteredRefArray['current']) == null || _filteredRefArray$cur[arrLength - 1].current.focus();
14458
+ };
14459
+ var focusSelf = function focusSelf() {
14460
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
14461
+ var curr = filteredRefArray['current'];
14462
+ focusIndex = getFocusIndex(curr);
14463
+ curr == null || curr[focusIndex].current.focus();
14464
+ };
14465
+ var expandFocusedNode = function expandFocusedNode() {
14466
+ if (hasOwnTreeItems) {
14467
+ if (expanded) {
14468
+ focusNext();
14469
+ } else {
14470
+ setExpanded(true);
14471
+ focusSelf();
14608
14472
  }
14609
14473
  }
14610
- }
14611
- return null;
14612
- }
14613
- // Returns the first item in the tree from the array of selected items
14614
- function getFirstItemInTree(arr, children) {
14615
- // If there's only 1 item, return that one first
14616
- if (arr.length === 1) {
14617
- var _arr$;
14618
- return (_arr$ = arr[0]) == null ? void 0 : _arr$.itemId;
14619
- }
14620
- var allFoundItems = [];
14621
- var _loop2 = function _loop2() {
14622
- var _children$props, _children$props2;
14623
- var item = _step8.value;
14624
- var foundItem = Array.isArray(children) ? children.find(function (child) {
14625
- var _child$props14;
14626
- return ((_child$props14 = child.props) == null ? void 0 : _child$props14.itemId) === item.itemId;
14627
- }) : ((_children$props = children.props) == null ? void 0 : _children$props.itemId) === item.itemId;
14628
- if (foundItem) {
14629
- var _foundItem$props;
14630
- allFoundItems.push((_foundItem$props = foundItem.props) == null ? void 0 : _foundItem$props.itemId);
14631
- } else if ((_children$props2 = children.props) != null && _children$props2.children) {
14632
- var result = getFirstItemInTree(arr, children.props.children);
14633
- if (result) {
14634
- allFoundItems.push(result);
14474
+ };
14475
+ var collapseFocusedNode = function collapseFocusedNode() {
14476
+ if (hasOwnTreeItems) {
14477
+ if (expanded) {
14478
+ setExpanded(false);
14479
+ focusSelf();
14480
+ } else {
14481
+ focusPrev();
14635
14482
  }
14483
+ } else {
14484
+ focusPrev();
14636
14485
  }
14637
14486
  };
14638
- for (var _iterator8 = _createForOfIteratorHelperLoose(arr), _step8; !(_step8 = _iterator8()).done;) {
14639
- _loop2();
14640
- }
14641
- // After finding all the items, return the one that comes first on the tree (top to bottom)
14642
- if (allFoundItems.length === 1) {
14643
- return allFoundItems[0];
14644
- } else if (allFoundItems.length > 1) {
14645
- var _loop = function _loop() {
14646
- var ch = _step9.value;
14647
- return {
14648
- v: allFoundItems.find(function (i) {
14649
- var _ch$props;
14650
- return i === ((_ch$props = ch.props) == null ? void 0 : _ch$props.itemId);
14651
- })
14652
- };
14653
- },
14654
- _ret;
14655
- for (var _iterator9 = _createForOfIteratorHelperLoose(children), _step9; !(_step9 = _iterator9()).done;) {
14656
- _ret = _loop();
14657
- if (_ret) return _ret.v;
14658
- }
14659
- }
14660
- return null;
14661
- }
14662
- // Return a treeItemRefArray object with no null children
14663
- function filterNullEntries(obj) {
14664
- if (Array.isArray(obj.current)) {
14665
- var filteredArray = obj.current.filter(function (item) {
14666
- return (item == null ? void 0 : item.current) !== null;
14667
- });
14668
- if (filteredArray.length > 0) {
14669
- return {
14670
- current: filteredArray
14671
- };
14672
- }
14673
- }
14674
- return {};
14675
- }
14676
-
14677
- (function (TreeViewSelectable) {
14678
- TreeViewSelectable["single"] = "single";
14679
- TreeViewSelectable["multi"] = "multi";
14680
- TreeViewSelectable["off"] = "off";
14681
- })(exports.TreeViewSelectable || (exports.TreeViewSelectable = {}));
14682
- function useTreeView(props) {
14683
- var _props$selectable = props.selectable,
14684
- selectable = _props$selectable === void 0 ? exports.TreeViewSelectable.single : _props$selectable,
14685
- onSelectedItemChange = props.onSelectedItemChange,
14686
- onExpandedChange = props.onExpandedChange,
14687
- initialExpandedItems = props.initialExpandedItems,
14688
- preselectedItems = props.preselectedItems,
14689
- _props$checkChildren = props.checkChildren,
14690
- checkChildren = _props$checkChildren === void 0 ? true : _props$checkChildren,
14691
- _props$checkParents = props.checkParents,
14692
- checkParents = _props$checkParents === void 0 ? true : _props$checkParents,
14693
- children = props.children;
14694
- var _React$useState = React.useState(false),
14695
- hasIcons = _React$useState[0],
14696
- setHasIcons = _React$useState[1];
14697
- var _React$useState2 = React.useState(preselectedItems || []),
14698
- selectedItems = _React$useState2[0],
14699
- setSelectedItems = _React$useState2[1];
14700
- var _React$useState3 = React.useState(false),
14701
- preselectedItemsNeedUpdate = _React$useState3[0],
14702
- setPreselectedItemsNeedUpdate = _React$useState3[1];
14703
- var _React$useState4 = React.useState(false),
14704
- initialExpandedItemsNeedUpdate = _React$useState4[0],
14705
- setInitialExpandedItemsNeedUpdate = _React$useState4[1];
14706
- var _React$useState5 = React.useState(false),
14707
- selectedItemsChanged = _React$useState5[0],
14708
- setSelectedItemsChanged = _React$useState5[1];
14709
- var _React$useState6 = React.useState(null),
14710
- itemToFocus = _React$useState6[0],
14711
- setItemToFocus = _React$useState6[1];
14712
- var _useDescendants = useDescendants(),
14713
- treeItemRefArray = _useDescendants[0],
14714
- registerTreeItem = _useDescendants[1];
14715
- React.useEffect(function () {
14716
- if (selectable !== exports.TreeViewSelectable.off && preselectedItems) {
14717
- setPreselectedItemsNeedUpdate(true);
14718
- }
14719
- if (initialExpandedItems) {
14720
- setInitialExpandedItemsNeedUpdate(true);
14487
+ var handleKeyDown = function handleKeyDown(event) {
14488
+ var filteredRefArray = filterNullEntries(treeItemRefArray);
14489
+ var curr = filteredRefArray['current'];
14490
+ var arrLength = curr.length;
14491
+ if (['ArrowDown', 'ArrowUp', 'Home', 'End', ' '].includes(event.key)) {
14492
+ event.preventDefault();
14721
14493
  }
14722
- getItemToFocusFirst();
14723
- }, []);
14724
- React.useEffect(function () {
14725
- if (selectable !== exports.TreeViewSelectable.off && selectedItemsChanged) {
14726
- onSelectedItemChange && typeof onSelectedItemChange === 'function' && onSelectedItemChange(selectedItems);
14727
- setSelectedItemsChanged(false);
14728
- getItemToFocusFirst();
14729
- }
14730
- }, [selectedItemsChanged]);
14731
- function getItemToFocusFirst() {
14732
- var item = null;
14733
- if ((children == null ? void 0 : children.length) > 0) {
14734
- var _findFirstBranchNode;
14735
- var allChildrenInTree = getChildrenItemIdsInTree(children);
14736
- var firstBranchNode = (_findFirstBranchNode = findFirstBranchNode(children)) == null ? void 0 : _findFirstBranchNode.props.itemId;
14737
- var firstItemSelected = getFirstItemInTree(selectedItems, children);
14738
- var firstNode = allChildrenInTree == null ? void 0 : allChildrenInTree[0].itemId;
14739
- if (selectable === exports.TreeViewSelectable.off) {
14740
- /*
14741
- If there is at least one node with a branch, focus is set on the first branch node.
14742
- If there are no nodes with branches, the first item is focused and the tree can be traversed
14743
- */
14744
- item = firstBranchNode || (allChildrenInTree == null ? void 0 : allChildrenInTree[0].itemId);
14745
- } else {
14746
- // Same behavior for Single and Multiple
14747
- if (selectedItems.length === 0) {
14748
- // If none of the nodes are selected before the tree receives focus, focus is set on the first node.
14749
- item = firstNode;
14750
- } else if (selectedItems.length > 0) {
14751
- // If one or more nodes are selected before the tree receives focus, focus is set on the first selected node.
14752
- item = firstItemSelected;
14494
+ switch (event.key) {
14495
+ case 'ArrowDown':
14496
+ {
14497
+ // Move to the next item, or wrap to first
14498
+ focusIndex === arrLength - 1 ? focusFirst() : focusNext();
14499
+ break;
14753
14500
  }
14754
- }
14501
+ case 'ArrowUp':
14502
+ {
14503
+ // Move to the previous item, or wrap to last
14504
+ focusIndex === 0 ? focusLast() : focusPrev();
14505
+ break;
14506
+ }
14507
+ case 'ArrowRight':
14508
+ {
14509
+ // Open parent nodes
14510
+ expandFocusedNode();
14511
+ break;
14512
+ }
14513
+ case 'ArrowLeft':
14514
+ {
14515
+ // Close open parent nodes
14516
+ collapseFocusedNode();
14517
+ break;
14518
+ }
14519
+ case 'Home':
14520
+ {
14521
+ // Moves focus to the first node in the tree without opening or closing a node.
14522
+ focusFirst();
14523
+ break;
14524
+ }
14525
+ case 'End':
14526
+ {
14527
+ // Moves focus to the last node in the tree that is focusable without opening a node.
14528
+ focusLast();
14529
+ break;
14530
+ }
14531
+ case 'Enter':
14532
+ {
14533
+ // Activates a node, i.e., performs its default action.
14534
+ if (selectable === exports.TreeViewSelectable.off && hasOwnTreeItems) {
14535
+ setExpanded(!expanded);
14536
+ } else if (selectable === exports.TreeViewSelectable.single) {
14537
+ // In single-select it selects the focused node.
14538
+ selectItem({
14539
+ itemId: itemId,
14540
+ checkedStatus: exports.IndeterminateCheckboxStatus.checked
14541
+ });
14542
+ } else if (selectable === exports.TreeViewSelectable.multi) {
14543
+ // In multi-select, it toggles the selection state of the focused node.
14544
+ selectItem({
14545
+ itemId: itemId,
14546
+ checkedStatus: checkedStatus === exports.IndeterminateCheckboxStatus.checked ? exports.IndeterminateCheckboxStatus.unchecked : exports.IndeterminateCheckboxStatus.checked
14547
+ });
14548
+ }
14549
+ break;
14550
+ }
14551
+ case ' ':
14552
+ {
14553
+ // Toggles the selection state of the focused node.
14554
+ if (selectable === exports.TreeViewSelectable.off && hasOwnTreeItems) {
14555
+ setExpanded(!expanded);
14556
+ } else if (selectable === exports.TreeViewSelectable.single) {
14557
+ if (hasOwnTreeItems) {
14558
+ setExpanded(!expanded);
14559
+ } else {
14560
+ selectItem({
14561
+ itemId: itemId,
14562
+ checkedStatus: exports.IndeterminateCheckboxStatus.checked
14563
+ });
14564
+ }
14565
+ } else if (selectable === exports.TreeViewSelectable.multi) {
14566
+ selectItem({
14567
+ itemId: itemId,
14568
+ checkedStatus: checkedStatus === exports.IndeterminateCheckboxStatus.checked ? exports.IndeterminateCheckboxStatus.unchecked : exports.IndeterminateCheckboxStatus.checked
14569
+ });
14570
+ }
14571
+ break;
14572
+ }
14573
+ default:
14574
+ return;
14755
14575
  }
14756
- setItemToFocus(item);
14757
- }
14576
+ };
14758
14577
  var contextValue = {
14759
- hasIcons: hasIcons,
14760
- itemToFocus: itemToFocus,
14761
- onSelectedItemChange: onSelectedItemChange,
14762
- onExpandedChange: onExpandedChange,
14763
- selectable: selectable,
14764
- setHasIcons: setHasIcons,
14578
+ checkboxChangeHandler: checkboxChangeHandler,
14579
+ checkedStatus: checkedStatus,
14580
+ expanded: expanded,
14581
+ hasOwnTreeItems: hasOwnTreeItems,
14582
+ itemDepth: parentDepth === 0 && topLevel ? 0 : itemDepth + 1,
14583
+ itemId: itemId || generatedId,
14584
+ parentDepth: parentDepth,
14585
+ ref: ref,
14765
14586
  selectedItems: selectedItems,
14766
- setSelectedItems: setSelectedItems,
14767
- initialExpandedItems: initialExpandedItems,
14768
- treeItemRefArray: treeItemRefArray,
14769
- registerTreeItem: registerTreeItem,
14770
- preselectedItemsNeedUpdate: preselectedItemsNeedUpdate,
14771
- setPreselectedItemsNeedUpdate: setPreselectedItemsNeedUpdate,
14772
- initialExpandedItemsNeedUpdate: initialExpandedItemsNeedUpdate,
14773
- setInitialExpandedItemsNeedUpdate: setInitialExpandedItemsNeedUpdate,
14774
- selectedItemsChanged: selectedItemsChanged,
14775
- setSelectedItemsChanged: setSelectedItemsChanged,
14776
- checkChildren: checkChildren,
14777
- checkParents: checkParents
14587
+ setExpanded: setExpanded,
14588
+ treeItemChildren: treeItemChildren
14778
14589
  };
14779
14590
  return {
14780
- contextValue: contextValue
14591
+ contextValue: contextValue,
14592
+ handleClick: handleClick,
14593
+ handleKeyDown: handleKeyDown
14781
14594
  };
14782
14595
  }
14783
14596
 
14784
- var TreeViewContext = /*#__PURE__*/React.createContext({
14785
- hasIcons: false,
14786
- initialExpandedItems: [],
14787
- initialExpandedItemsNeedUpdate: false,
14788
- preselectedItemsNeedUpdate: false,
14789
- registerTreeItem: function registerTreeItem(elements, element) {},
14790
- selectable: exports.TreeViewSelectable.single,
14791
- selectedItems: [],
14792
- selectedItemsChanged: false,
14793
- setHasIcons: function setHasIcons() {},
14794
- setInitialExpandedItemsNeedUpdate: function setInitialExpandedItemsNeedUpdate() {},
14795
- setPreselectedItemsNeedUpdate: function setPreselectedItemsNeedUpdate() {},
14796
- setSelectedItems: function setSelectedItems() {},
14797
- setSelectedItemsChanged: function setSelectedItemsChanged() {},
14798
- checkParents: true,
14799
- checkChildren: true
14597
+ var TreeItemContext = /*#__PURE__*/React.createContext({
14598
+ expanded: false,
14599
+ setExpanded: function setExpanded() {},
14600
+ checkedStatus: exports.IndeterminateCheckboxStatus.unchecked,
14601
+ checkboxChangeHandler: function checkboxChangeHandler() {},
14602
+ hasOwnTreeItems: false,
14603
+ parentDepth: 0
14800
14604
  });
14801
14605
 
14802
- var checkedStatusToBoolean = function checkedStatusToBoolean(status) {
14803
- return status === exports.IndeterminateCheckboxStatus.checked;
14804
- };
14805
- function useTreeItem(props, forwardedRef) {
14606
+ var _excluded$1B = ["children", "icon", "index", "isDisabled", "label", "labelStyle", "style", "testId", "topLevel"];
14607
+ var StyledTreeItem = /*#__PURE__*/_styled("li", {
14608
+ target: "e1xiryew5",
14609
+ label: "StyledTreeItem"
14610
+ })("color:", function (props) {
14611
+ return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
14612
+ }, ";list-style-type:none;cursor:", function (props) {
14613
+ return getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType);
14614
+ }, ";position:relative;margin-bottom:0;padding-inline-start:", function (props) {
14615
+ return calculateOffset(props.nodeType, props.depth);
14616
+ }, ";>div:first-of-type{background:", function (props) {
14617
+ return props.selected && props.isInverse ? polished.transparentize(0.7, props.theme.colors.neutral900) : props.selected && polished.transparentize(0.92, props.theme.colors.neutral900);
14618
+ }, ";position:relative;padding-inline-start:", function (props) {
14619
+ return calculateOffset(props.nodeType, props.depth, true);
14620
+ }, ";margin-inline-start:", function (props) {
14621
+ return calculateOffset(props.nodeType, props.depth, true, true);
14622
+ }, ";padding-block-end:", function (props) {
14623
+ return props.theme.spaceScale.spacing02;
14624
+ }, ";padding-block-start:", function (props) {
14625
+ return props.theme.spaceScale.spacing02;
14626
+ }, ";padding-right:", function (props) {
14627
+ return props.theme.spaceScale.spacing02;
14628
+ }, ";", function (props) {
14629
+ return props.selected && /*#__PURE__*/react.css("&:before{position:absolute;background-color:", props.isInverse ? props.theme.colors.tertiary500 : props.theme.colors.primary500, ";block-size:100%;content:'';inline-size:", props.theme.spaceScale.spacing02, ";inset-block-start:0;inset-inline-start:0;};label:StyledTreeItem;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAwCQ","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './types';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, style, testId, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
14630
+ }, " &:hover{background:", function (props) {
14631
+ return !props.isDisabled ? props.isInverse ? polished.transparentize(0.8, props.theme.colors.neutral900) : polished.transparentize(0.95, props.theme.colors.neutral900) : undefined;
14632
+ }, ";}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAeiC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './types';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, style, testId, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
14633
+ var IconWrapper$8 = /*#__PURE__*/_styled("span", {
14634
+ target: "e1xiryew4",
14635
+ label: "IconWrapper"
14636
+ })("color:", function (props) {
14637
+ return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
14638
+ }, ";margin-right:", function (props) {
14639
+ return props.theme.spaceScale.spacing03;
14640
+ }, ";margin-left:0px;svg{height:", function (props) {
14641
+ return props.theme.iconSizes.medium;
14642
+ }, "px;width:", function (props) {
14643
+ return props.theme.iconSizes.medium;
14644
+ }, "px;vertical-align:middle;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AA8DgC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './types';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, style, testId, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
14645
+ var StyledLabelWrapper = /*#__PURE__*/_styled("span", {
14646
+ target: "e1xiryew3",
14647
+ label: "StyledLabelWrapper"
14648
+ })("display:flex;align-items:flex-start;color:", function (props) {
14649
+ return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
14650
+ }, ";width:100%;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAwEuC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './types';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, style, testId, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
14651
+ var StyledExpandWrapper = /*#__PURE__*/_styled("div", {
14652
+ target: "e1xiryew2",
14653
+ label: "StyledExpandWrapper"
14654
+ })("display:inline-block;vertical-align:middle;margin-right:", function (props) {
14655
+ return props.theme.spaceScale.spacing03;
14656
+ }, ";color:", function (props) {
14657
+ return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
14658
+ }, ";border-radius:0;width:", function (props) {
14659
+ return props.theme.spaceScale.spacing06;
14660
+ }, ";height:", function (props) {
14661
+ return props.theme.spaceScale.spacing06;
14662
+ }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AA8EuC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './types';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, style, testId, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
14663
+ var StyledCheckboxWrapper = /*#__PURE__*/_styled("div", {
14664
+ target: "e1xiryew1",
14665
+ label: "StyledCheckboxWrapper"
14666
+ })("margin-right:", function (props) {
14667
+ return props.theme.spaceScale.spacing03;
14668
+ }, ";vertical-align:middle;display:inline-flex;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAuFyC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './types';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, style, testId, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
14669
+ var StyledItemWrapper = /*#__PURE__*/_styled("div", {
14670
+ target: "e1xiryew0",
14671
+ label: "StyledItemWrapper"
14672
+ })("display:flex;align-items:flex-start;cursor:", function (props) {
14673
+ return getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType);
14674
+ }, ";&:focus{outline-offset:-2px;outline:2px solid ", function (props) {
14675
+ return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
14676
+ }, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AA4FqC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './types';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, style, testId, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
14677
+ var TreeItem = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
14678
+ var _selectedItems$;
14806
14679
  var children = props.children,
14807
14680
  icon = props.icon,
14808
- index = props.index,
14809
- _props$isDisabled = props.isDisabled,
14810
- isDisabled = _props$isDisabled === void 0 ? false : _props$isDisabled,
14811
- itemDepth = props.itemDepth,
14812
- itemId = props.itemId,
14813
- onClick = props.onClick,
14814
- parentCheckedStatus = props.parentCheckedStatus,
14815
- parentDepth = props.parentDepth,
14816
- topLevel = props.topLevel,
14817
- updateParentCheckStatus = props.updateParentCheckStatus;
14681
+ isDisabled = props.isDisabled,
14682
+ label = props.label,
14683
+ labelStyle = props.labelStyle,
14684
+ style = props.style,
14685
+ testId = props.testId,
14686
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1B);
14687
+ var theme = React.useContext(ThemeContext);
14688
+ var isInverse = useIsInverse();
14818
14689
  var _React$useContext = React.useContext(TreeViewContext),
14819
- initialExpandedItems = _React$useContext.initialExpandedItems,
14820
- registerTreeItem = _React$useContext.registerTreeItem,
14821
14690
  selectable = _React$useContext.selectable,
14822
- selectedItems = _React$useContext.selectedItems,
14823
- setHasIcons = _React$useContext.setHasIcons,
14824
- setSelectedItems = _React$useContext.setSelectedItems,
14825
- treeItemRefArray = _React$useContext.treeItemRefArray,
14826
- preselectedItemsNeedUpdate = _React$useContext.preselectedItemsNeedUpdate,
14827
- setPreselectedItemsNeedUpdate = _React$useContext.setPreselectedItemsNeedUpdate,
14828
- initialExpandedItemsNeedUpdate = _React$useContext.initialExpandedItemsNeedUpdate,
14829
- setSelectedItemsChanged = _React$useContext.setSelectedItemsChanged,
14830
- selectedItemsChanged = _React$useContext.selectedItemsChanged,
14831
- checkParents = _React$useContext.checkParents,
14832
- checkChildren = _React$useContext.checkChildren;
14833
- // Needs to skip sending an "onSelection" event during the initial render of items
14834
- var _React$useState = React.useState(false),
14835
- isSkipSelectedItemsUpdate = _React$useState[0],
14836
- setIsSkipSelectedItemsUpdate = _React$useState[1];
14837
- var _React$useState2 = React.useState(false),
14838
- expanded = _React$useState2[0],
14839
- setExpanded = _React$useState2[1];
14840
- var _React$useState3 = React.useState(exports.IndeterminateCheckboxStatus.unchecked),
14841
- checkedStatus = _React$useState3[0],
14842
- setCheckedStatus = _React$useState3[1];
14843
- var _React$useState4 = React.useState(undefined),
14844
- statusUpdatedBy = _React$useState4[0],
14845
- setStatusUpdatedBy = _React$useState4[1];
14846
- var treeItemChildren = React.Children.toArray(children).filter(function (child) {
14847
- return child.type === TreeItem;
14691
+ hasIcons = _React$useContext.hasIcons,
14692
+ onExpandedChange = _React$useContext.onExpandedChange,
14693
+ itemToFocus = _React$useContext.itemToFocus;
14694
+ var _useTreeItem = useTreeItem(props, forwardedRef),
14695
+ contextValue = _useTreeItem.contextValue,
14696
+ handleClick = _useTreeItem.handleClick,
14697
+ handleKeyDown = _useTreeItem.handleKeyDown;
14698
+ var checkboxChangeHandler = contextValue.checkboxChangeHandler,
14699
+ checkedStatus = contextValue.checkedStatus,
14700
+ expanded = contextValue.expanded,
14701
+ hasOwnTreeItems = contextValue.hasOwnTreeItems,
14702
+ itemDepth = contextValue.itemDepth,
14703
+ itemId = contextValue.itemId,
14704
+ parentDepth = contextValue.parentDepth,
14705
+ ref = contextValue.ref,
14706
+ selectedItems = contextValue.selectedItems,
14707
+ setExpanded = contextValue.setExpanded;
14708
+ var nodeType = hasOwnTreeItems ? exports.TreeNodeType.branch : exports.TreeNodeType.leaf;
14709
+ var selectedItem = selectable === exports.TreeViewSelectable.single ? (selectedItems == null || (_selectedItems$ = selectedItems[0]) == null ? void 0 : _selectedItems$.itemId) === itemId : null;
14710
+ var ariaCheckedValue = selectable === exports.TreeViewSelectable.multi ? checkedStatus === exports.IndeterminateCheckboxStatus.indeterminate ? 'mixed' : checkedStatus === exports.IndeterminateCheckboxStatus.checked : null;
14711
+ var defaultIcon = nodeType === exports.TreeNodeType.branch ? React.createElement(reactMagmaIcons.FolderIcon, {
14712
+ "aria-hidden": true
14713
+ }) : React.createElement(reactMagmaIcons.ArticleIcon, {
14714
+ "aria-hidden": true
14848
14715
  });
14849
- // TODO fix for disabled items (issue #1305)
14850
- // const numberOfTreeItemChildren = getEnabledTreeItemChildrenLength(treeItemChildren);
14851
- var numberOfTreeItemChildren = treeItemChildren.length;
14852
- var hasOwnTreeItems = numberOfTreeItemChildren > 0;
14853
- var _React$useState5 = React.useState(Array(numberOfTreeItemChildren).fill(exports.IndeterminateCheckboxStatus.unchecked)),
14854
- childrenCheckedStatus = _React$useState5[0],
14855
- setChildrenCheckedStatus = _React$useState5[1];
14856
- var ownRef = React.useRef();
14857
- var ref = useForkedRef(forwardedRef, ownRef);
14858
- var forceUpdate = useForceUpdate();
14859
- var generatedId = useGenerateId();
14860
- React.useEffect(function () {
14861
- setTreeViewIconVisibility();
14862
- selectedItems.map(function (item) {
14863
- if ((item == null ? void 0 : item.itemId) === itemId) {
14864
- var newStatus = item == null ? void 0 : item.checkedStatus;
14865
- if (checkedStatus !== newStatus) {
14866
- var childrenOfItemId = getChildrenItemIds(treeItemChildren, exports.IndeterminateCheckboxStatus.checked);
14867
- var itemIdChildrenInTree = getChildrenItemIdsInTree(treeItemChildren);
14868
- var parentIds = itemId && itemIdChildrenInTree.length > 0 ? getAllParentIds(itemIdChildrenInTree, itemId) : [];
14869
- var additionalItems = [];
14870
- if (newStatus === exports.IndeterminateCheckboxStatus.checked) {
14871
- if (parentIds && checkParents) additionalItems.push.apply(additionalItems, parentIds);
14872
- if (hasOwnTreeItems && checkChildren) additionalItems.push.apply(additionalItems, childrenOfItemId);
14873
- }
14874
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
14875
- setCheckedStatus(item == null ? void 0 : item.checkedStatus);
14876
- if (selectable === exports.TreeViewSelectable.multi) {
14877
- // Pass "true" as isInitialRender value to skip sending an "onSelection" event
14878
- // Required since this useEffect handles initial rendering of the item
14879
- updateParentCheckStatus(index, newStatus, true);
14880
- }
14881
- setSelectedItems(function (prev) {
14882
- return getUniqueSelectedItemsArray([{
14883
- itemId: itemId,
14884
- checkedStatus: newStatus
14885
- }], prev, additionalItems);
14886
- });
14887
- }
14888
- return;
14716
+ var labelText = React.createElement(StyledLabelWrapper, {
14717
+ theme: theme,
14718
+ isDisabled: isDisabled,
14719
+ isInverse: isInverse,
14720
+ style: labelStyle,
14721
+ id: itemId + "-label",
14722
+ "data-testid": (testId || itemId) + "-label",
14723
+ onClick: function onClick(e) {
14724
+ if (selectable === exports.TreeViewSelectable.single && !isDisabled) {
14725
+ handleClick(e, itemId);
14889
14726
  }
14890
- });
14891
- if (!isDisabled && ownRef.current !== null) {
14892
- registerTreeItem(treeItemRefArray, ownRef);
14893
- }
14894
- forceUpdate();
14895
- }, []);
14896
- function setTreeViewIconVisibility() {
14897
- if (treeItemChildren.length === 0 && icon) {
14898
- setHasIcons(true);
14899
- return;
14900
- }
14901
- treeItemChildren.forEach(function (child) {
14902
- if (child != null && child.props.icon) {
14903
- setHasIcons(true);
14904
- return;
14905
- }
14906
- });
14907
- }
14908
- function updateSelectedItemsChanged() {
14909
- if (topLevel && !selectedItemsChanged) {
14910
- setSelectedItemsChanged(true);
14911
- }
14912
- }
14913
- React.useEffect(function () {
14914
- if (preselectedItemsNeedUpdate) {
14915
- updateInitialSelected();
14916
- }
14917
- }, [preselectedItemsNeedUpdate]);
14918
- React.useEffect(function () {
14919
- if (initialExpandedItemsNeedUpdate) {
14920
- updateInitialExpanded();
14921
- }
14922
- }, [initialExpandedItemsNeedUpdate]);
14923
- var updateCheckedStatusFromChild = function updateCheckedStatusFromChild(index, status, isInitialRender) {
14924
- if (checkParents) {
14925
- // Set isSkipSelectedItemsUpdate as true if this update caused by the initial render of children during expanding
14926
- setIsSkipSelectedItemsUpdate(Boolean(isInitialRender));
14927
- setStatusUpdatedBy("children" /* children */);
14928
- setChildrenCheckedStatus(function (prev) {
14929
- var newChildrenCheckedStatus = [].concat(prev);
14930
- newChildrenCheckedStatus[index] = status;
14931
- return newChildrenCheckedStatus;
14932
- });
14933
14727
  }
14728
+ }, hasIcons && React.createElement(IconWrapper$8, {
14729
+ isInverse: isInverse,
14730
+ theme: theme,
14731
+ isDisabled: isDisabled,
14732
+ "data-testid": (testId || itemId) + "-icon"
14733
+ }, icon || defaultIcon), label);
14734
+ // Props shared by Checkbox and IndeterminateCheckbox
14735
+ var checkboxProps = {
14736
+ disabled: isDisabled,
14737
+ hideFocus: true,
14738
+ id: itemId + "-checkbox",
14739
+ inputStyle: {
14740
+ marginRight: theme.spaceScale.spacing03
14741
+ },
14742
+ labelStyle: {
14743
+ padding: 0
14744
+ },
14745
+ labelText: labelText,
14746
+ onChange: checkboxChangeHandler,
14747
+ tabIndex: -1,
14748
+ testId: itemId + "-checkbox"
14934
14749
  };
14935
- var updateStatusForItem = function updateStatusForItem(childrenItemIds, preselectedChildrenItems, itemId, itemIdChildren) {
14936
- var item = preselectedChildrenItems.find(function (child) {
14937
- return child.itemId === itemId;
14938
- });
14939
- var itemStatus = item != null && item.checkedStatus || areArraysEqual(preselectedChildrenItems, childrenItemIds) ? exports.IndeterminateCheckboxStatus.checked : exports.IndeterminateCheckboxStatus.indeterminate;
14940
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
14941
- setCheckedStatus(itemStatus);
14942
- updateParentCheckStatus(index, itemStatus);
14943
- if (!item) {
14944
- setSelectedItems(function (prev) {
14945
- return getUniqueSelectedItemsArray([{
14946
- itemId: itemId,
14947
- checkedStatus: itemStatus
14948
- }], preselectedChildrenItems, prev);
14949
- });
14950
- setSelectedItemsChanged(true);
14951
- return;
14952
- }
14953
- var thisItem = itemIdChildren.find(function (child) {
14954
- return child.itemId === itemId;
14750
+ var onExpandedClicked = function onExpandedClicked(event) {
14751
+ setExpanded(function (state) {
14752
+ return !state;
14955
14753
  });
14956
- if ((thisItem == null ? void 0 : thisItem.children.length) > 0 && (item == null ? void 0 : item.checkedStatus) === exports.IndeterminateCheckboxStatus.checked) {
14957
- var itemNode = findChildByItemId(treeItemChildren, thisItem == null ? void 0 : thisItem.itemId);
14958
- var newChildren = getChildrenItemIds(itemNode == null ? void 0 : itemNode.props.children, checkedStatus);
14959
- setSelectedItems(function (prev) {
14960
- return getUniqueSelectedItemsArray([{
14961
- itemId: itemId,
14962
- checkedStatus: itemStatus
14963
- }], newChildren, prev);
14964
- });
14965
- setSelectedItemsChanged(true);
14966
- }
14967
- };
14968
- var updateInitialExpanded = function updateInitialExpanded() {
14969
- if ((initialExpandedItems == null ? void 0 : initialExpandedItems.length) !== 0 && !isDisabled) {
14970
- var childrenItemIds = getChildrenItemIdsFlat(treeItemChildren);
14971
- var allExpanded = [].concat(initialExpandedItems, childrenItemIds);
14972
- if (allExpanded != null && allExpanded.some(function (item) {
14973
- return item === itemId;
14974
- })) {
14975
- setExpanded(true);
14976
- } else {
14977
- setExpanded(false);
14978
- }
14979
- } else {
14980
- setExpanded(false);
14981
- }
14754
+ event.preventDefault();
14755
+ onExpandedChange && typeof onExpandedChange === 'function' && onExpandedChange(event);
14982
14756
  };
14983
- var updateInitialSelected = function updateInitialSelected() {
14984
- if (selectable === exports.TreeViewSelectable.single && selectedItems) {
14985
- var _selectedItems$;
14986
- var firstItemId = selectedItems == null || (_selectedItems$ = selectedItems[0]) == null ? void 0 : _selectedItems$.itemId;
14987
- if (firstItemId && !isDisabled) {
14988
- setSelectedItems(function (prev) {
14989
- if (!arrayIncludesId(prev, firstItemId)) {
14990
- return [{
14991
- itemId: firstItemId,
14992
- checkedStatus: exports.IndeterminateCheckboxStatus.checked
14993
- }];
14994
- }
14995
- });
14996
- setSelectedItemsChanged(true);
14997
- }
14998
- } else if (selectable === exports.TreeViewSelectable.multi && selectedItems) {
14999
- var item = selectedItems.find(function (obj) {
15000
- return obj.itemId === itemId;
15001
- });
15002
- var status = item == null ? void 0 : item.checkedStatus;
15003
- var childrenItemIds = getChildrenItemIds(treeItemChildren, status || exports.IndeterminateCheckboxStatus.checked);
15004
- // Items from selectedItems that are children
15005
- var preselectedChildrenItems = findCommonItems(childrenItemIds, selectedItems);
15006
- if (!isDisabled && (arrayIncludesId(selectedItems, itemId) || childrenItemIds != null && childrenItemIds.includes(itemId))) {
15007
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
15008
- setCheckedStatus(status);
15009
- updateParentCheckStatus(index, status);
15010
- if (childrenItemIds.length > 0 && status === exports.IndeterminateCheckboxStatus.checked) {
15011
- var newChildrenCheckedStatus = getChildrenCheckedStatus(childrenItemIds, checkChildren && status);
15012
- setChildrenCheckedStatus(newChildrenCheckedStatus);
15013
- }
15014
- setSelectedItems(function (prev) {
15015
- var allItems = getUniqueSelectedItemsArray(childrenItemIds, selectedItems, prev);
15016
- return allItems;
15017
- });
15018
- updateSelectedItemsChanged();
15019
- } else if (!isDisabled && preselectedChildrenItems.length > 0 && checkParents) {
15020
- // Case for selectedItems that are inside a collapsed item
15021
- var itemIdChildren = getChildrenItemIdsInTree(treeItemChildren);
15022
- for (var _iterator = _createForOfIteratorHelperLoose(preselectedChildrenItems), _step; !(_step = _iterator()).done;) {
15023
- var _itemIdNode$props;
15024
- var i = _step.value;
15025
- var itemIdNode = findChildByItemId(treeItemChildren, i.itemId);
15026
- var childrenOfItemId = getChildrenItemIds(itemIdNode == null || (_itemIdNode$props = itemIdNode.props) == null ? void 0 : _itemIdNode$props.children, exports.IndeterminateCheckboxStatus.checked);
15027
- var parentIds = getAllParentIds(itemIdChildren, i.itemId);
15028
- for (var _iterator2 = _createForOfIteratorHelperLoose(parentIds), _step2; !(_step2 = _iterator2()).done;) {
15029
- var p = _step2.value;
15030
- updateStatusForItem(childrenOfItemId, preselectedChildrenItems, p, itemIdChildren);
15031
- }
15032
- }
15033
- updateStatusForItem(childrenItemIds, preselectedChildrenItems, itemId, itemIdChildren);
14757
+ return React.createElement(TreeItemContext.Provider, {
14758
+ value: contextValue
14759
+ }, React.createElement(StyledTreeItem, Object.assign({}, rest, {
14760
+ "aria-expanded": hasOwnTreeItems ? expanded : null,
14761
+ "aria-selected": selectedItem,
14762
+ "aria-checked": ariaCheckedValue,
14763
+ "data-testid": testId,
14764
+ depth: itemDepth,
14765
+ hasOwnTreeItems: true,
14766
+ id: itemId,
14767
+ isDisabled: isDisabled,
14768
+ isInverse: isInverse,
14769
+ nodeType: nodeType,
14770
+ role: "treeitem",
14771
+ selectableType: selectable,
14772
+ selected: selectedItem,
14773
+ theme: theme
14774
+ }), React.createElement(StyledItemWrapper, {
14775
+ "data-testid": (testId || itemId) + "-itemwrapper",
14776
+ depth: itemDepth,
14777
+ id: itemId + "-itemwrapper",
14778
+ isDisabled: isDisabled,
14779
+ isInverse: isInverse,
14780
+ nodeType: nodeType,
14781
+ onClick: function onClick(event) {
14782
+ if (selectable === exports.TreeViewSelectable.off && hasOwnTreeItems) {
14783
+ onExpandedClicked(event);
15034
14784
  }
15035
- }
15036
- setPreselectedItemsNeedUpdate(false);
15037
- };
15038
- React.useEffect(function () {
15039
- if (statusUpdatedBy && updateParentCheckStatus && !topLevel) {
15040
- updateParentCheckStatus(index, checkedStatus);
15041
- }
15042
- setStatusUpdatedBy(undefined);
15043
- }, [checkedStatus]);
15044
- React.useEffect(function () {
15045
- if (parentCheckedStatus && checkChildren && checkedStatus !== parentCheckedStatus && parentCheckedStatus !== exports.IndeterminateCheckboxStatus.indeterminate && !topLevel && !isDisabled) {
15046
- setStatusUpdatedBy("parent" /* parent */);
15047
- setCheckedStatus(parentCheckedStatus);
15048
- if (hasOwnTreeItems) {
15049
- if (getAllChildrenEnabled(treeItemChildren)) {
15050
- setChildrenCheckedStatus(Array(numberOfTreeItemChildren).fill(parentCheckedStatus));
15051
- } else {
15052
- var childrenIds = getChildrenItemIds(treeItemChildren);
15053
- var newChildrenCheckedStatus = getChildrenCheckedStatus(childrenIds, parentCheckedStatus);
15054
- setChildrenCheckedStatus(newChildrenCheckedStatus);
15055
- }
14785
+ },
14786
+ onKeyDown: function onKeyDown(e) {
14787
+ handleKeyDown(e);
14788
+ },
14789
+ ref: ref,
14790
+ selectable: selectable,
14791
+ style: style,
14792
+ tabIndex: itemToFocus === itemId ? 0 : -1,
14793
+ theme: theme
14794
+ }, hasOwnTreeItems && React.createElement(StyledExpandWrapper, {
14795
+ "aria-hidden": Boolean(!expanded),
14796
+ "data-testid": (testId || itemId) + "-expand",
14797
+ isDisabled: isDisabled,
14798
+ isInverse: isInverse,
14799
+ onClick: function onClick(event) {
14800
+ if (!isDisabled && selectable !== exports.TreeViewSelectable.off) {
14801
+ onExpandedClicked(event);
15056
14802
  }
15057
- }
15058
- }, [parentCheckedStatus]);
15059
- React.useEffect(function () {
15060
- if (statusUpdatedBy && (childrenCheckedStatus == null ? void 0 : childrenCheckedStatus[0]) !== undefined) {
15061
- var statusFromChildren = childrenCheckedStatus.every(function (status) {
15062
- return status === childrenCheckedStatus[0];
15063
- }) ? childrenCheckedStatus[0] : exports.IndeterminateCheckboxStatus.indeterminate;
15064
- var updateItemStatus = getUpdatedSelectedItems(selectedItems, itemId, statusFromChildren);
15065
- if (checkedStatus !== statusFromChildren && statusUpdatedBy !== "parent" /* parent */) {
15066
- setStatusUpdatedBy("children" /* children */);
15067
- setCheckedStatus(statusFromChildren);
15068
- if (statusFromChildren === exports.IndeterminateCheckboxStatus.checked || statusFromChildren === exports.IndeterminateCheckboxStatus.indeterminate) {
15069
- if (itemId && !arrayIncludesId(selectedItems, itemId)) {
15070
- setSelectedItems([].concat(selectedItems, [{
15071
- itemId: itemId,
15072
- checkedStatus: statusFromChildren
15073
- }]));
15074
- updateSelectedItemsChanged();
15075
- } else {
15076
- setSelectedItems(updateItemStatus);
15077
- updateSelectedItemsChanged();
15078
- }
15079
- } else if (statusFromChildren === exports.IndeterminateCheckboxStatus.unchecked) {
15080
- setSelectedItems(selectedItems.filter(function (obj) {
15081
- return obj.itemId !== itemId;
15082
- }));
15083
- updateSelectedItemsChanged();
15084
- }
15085
- } else if (checkedStatus === statusFromChildren && statusUpdatedBy !== "parent" /* parent */ && statusFromChildren === exports.IndeterminateCheckboxStatus.indeterminate && expanded) {
15086
- if (!arrayIncludesId(selectedItems, itemId)) {
15087
- setSelectedItems([].concat(selectedItems, [{
15088
- itemId: itemId,
15089
- checkedStatus: statusFromChildren
15090
- }]));
15091
- updateSelectedItemsChanged();
15092
- } else {
15093
- var itemStatus = getCheckedStatus(itemId, selectedItems);
15094
- if (itemStatus === parentCheckedStatus) {
15095
- // Skip updating items if instructed to do so
15096
- if (isSkipSelectedItemsUpdate) return;
15097
- if (!selectedItemsChanged) {
15098
- if (!topLevel && updateParentCheckStatus) {
15099
- setSelectedItemsChanged(true);
15100
- } else {
15101
- updateSelectedItemsChanged();
15102
- }
15103
- }
15104
- } else {
15105
- updateSelectedItemsChanged();
15106
- }
15107
- }
15108
- } else {
15109
- setSelectedItems(updateItemStatus);
15110
- if (!expanded) {
15111
- updateSelectedItemsChanged();
15112
- }
14803
+ },
14804
+ theme: theme
14805
+ }, expanded ? React.createElement(reactMagmaIcons.ExpandMoreIcon, {
14806
+ "aria-hidden": true
14807
+ }) : React.createElement(reactMagmaIcons.ChevronRightIcon, {
14808
+ "aria-hidden": true
14809
+ })), selectable === exports.TreeViewSelectable.multi ? React.createElement(StyledCheckboxWrapper, {
14810
+ theme: theme
14811
+ }, hasOwnTreeItems ? React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, {
14812
+ status: checkedStatus
14813
+ })) : React.createElement(Checkbox, Object.assign({}, checkboxProps, {
14814
+ checked: checkedStatusToBoolean(checkedStatus)
14815
+ }))) : React.createElement(React.Fragment, null, labelText)), React.Children.map(children, function (child, index) {
14816
+ var component = child.type === TreeItem ? React.createElement(Transition, {
14817
+ isOpen: expanded,
14818
+ collapse: true,
14819
+ unmountOnExit: true
14820
+ }, React.createElement("ul", {
14821
+ role: "group"
14822
+ }, React.cloneElement(child, {
14823
+ index: index,
14824
+ key: index,
14825
+ itemDepth: itemDepth,
14826
+ parentDepth: parentDepth
14827
+ }))) : child;
14828
+ // hide the disabled item + the children
14829
+ if (isDisabled) return React.createElement(React.Fragment, null);
14830
+ return component;
14831
+ })));
14832
+ });
14833
+
14834
+ (function (TreeNodeType) {
14835
+ TreeNodeType["branch"] = "branch";
14836
+ TreeNodeType["leaf"] = "leaf";
14837
+ })(exports.TreeNodeType || (exports.TreeNodeType = {}));
14838
+ /**
14839
+ * Leaf node - 1st level has 40px of left padding.
14840
+ * Each level after that adds 56px of left padding.
14841
+ * 40, 64, 88, 112, 136, etc.
14842
+ *
14843
+ * Branch node - 1st level has 8px of left padding.
14844
+ * Each level after that adds 24px of left padding.
14845
+ * 8, 32, 56, 80, 104, etc.
14846
+ *
14847
+ * The label element (the div inside the li) gets additional spacing.
14848
+ * In order to highlight the entire line, we need to negate the value for margin.
14849
+ */
14850
+ function calculateOffset(type, depth, labelElem, negative) {
14851
+ if (depth === void 0) {
14852
+ depth = 0;
14853
+ }
14854
+ if (labelElem === void 0) {
14855
+ labelElem = false;
14856
+ }
14857
+ if (negative === void 0) {
14858
+ negative = false;
14859
+ }
14860
+ var padding = 0;
14861
+ if (type === exports.TreeNodeType.leaf) {
14862
+ if (labelElem) {
14863
+ padding = depth * 8 + 40;
14864
+ if (depth !== 0) {
14865
+ padding += depth * 16;
15113
14866
  }
14867
+ } else if (depth === 0) {
14868
+ padding = 40;
14869
+ } else {
14870
+ padding = 56;
15114
14871
  }
15115
- }, [childrenCheckedStatus]);
15116
- var checkboxChangeHandler = function checkboxChangeHandler(event) {
15117
- var status = event.target.checked ? exports.IndeterminateCheckboxStatus.checked : exports.IndeterminateCheckboxStatus.unchecked;
15118
- if (checkedStatus !== status) {
15119
- setCheckedStatus(status);
15120
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
15121
- updateParentCheckStatus(index, status);
15122
- if (hasOwnTreeItems && checkChildren) {
15123
- if (getAllChildrenEnabled(treeItemChildren)) {
15124
- setChildrenCheckedStatus(Array(numberOfTreeItemChildren).fill(status));
15125
- } else {
15126
- var childrenIds = getChildrenItemIds(treeItemChildren);
15127
- var newChildrenCheckedStatus = getChildrenCheckedStatus(childrenIds, status);
15128
- setChildrenCheckedStatus(newChildrenCheckedStatus);
15129
- }
14872
+ } else if (type === exports.TreeNodeType.branch) {
14873
+ if (labelElem) {
14874
+ padding = depth * 8 + 8;
14875
+ if (depth !== 0) {
14876
+ padding += depth * 16;
15130
14877
  }
14878
+ } else if (depth === 0) {
14879
+ padding = 8;
14880
+ } else {
14881
+ padding = 24;
15131
14882
  }
15132
- handleClick(event, itemId);
15133
- };
15134
- var singleSelectChangeHandler = function singleSelectChangeHandler(event, itemId) {
15135
- if (!arrayIncludesId(selectedItems, itemId)) {
15136
- setSelectedItems([{
15137
- itemId: itemId,
15138
- checkedStatus: exports.IndeterminateCheckboxStatus.checked
15139
- }]);
15140
- setSelectedItemsChanged(true);
14883
+ }
14884
+ return "" + (negative ? '-' : '') + padding + "px";
14885
+ }
14886
+ function getTreeItemLabelColor(isInverse, disabled, theme) {
14887
+ if (disabled) {
14888
+ if (isInverse) {
14889
+ return polished.transparentize(0.6, theme.colors.neutral100);
15141
14890
  }
15142
- };
15143
- var multiSelectChangeHandler = function multiSelectChangeHandler(event) {
15144
- if (!checkParents) {
15145
- setSelectedItemsChanged(true);
15146
- }
15147
- if (hasOwnTreeItems && checkChildren) {
15148
- var childrenIds = getChildrenItemIds(treeItemChildren, exports.IndeterminateCheckboxStatus.checked);
15149
- if (event.target.checked) {
15150
- updateParentCheckStatus(index, exports.IndeterminateCheckboxStatus.checked);
15151
- if (!arrayIncludesId(selectedItems, itemId)) {
15152
- setSelectedItems([].concat(selectedItems, childrenIds, [{
15153
- itemId: itemId,
15154
- checkedStatus: exports.IndeterminateCheckboxStatus.checked
15155
- }]));
15156
- updateSelectedItemsChanged();
15157
- } else {
15158
- var missingChildren = getMissingChildrenIds(selectedItems, childrenIds);
15159
- setSelectedItems([].concat(selectedItems, missingChildren));
15160
- updateSelectedItemsChanged();
15161
- }
15162
- } else if (!event.target.checked) {
15163
- var newSelectedItems = filterSelectedItems(selectedItems, childrenIds, {
15164
- itemId: itemId,
15165
- checkedStatus: checkedStatus
14891
+ return polished.transparentize(0.6, theme.colors.neutral500);
14892
+ }
14893
+ if (isInverse) {
14894
+ return theme.colors.neutral100;
14895
+ }
14896
+ return theme.colors.neutral700;
14897
+ }
14898
+ function getTreeItemWrapperCursor(disabled, selectable, nodeType) {
14899
+ if (disabled) {
14900
+ return 'not-allowed';
14901
+ }
14902
+ if (nodeType === exports.TreeNodeType.branch && selectable === exports.TreeViewSelectable.off || selectable === exports.TreeViewSelectable.single) {
14903
+ return 'pointer';
14904
+ }
14905
+ return 'default';
14906
+ }
14907
+ // Return an array of objects of all the enabled children ids recursively
14908
+ function getChildrenItemIds(children, status) {
14909
+ if (status === void 0) {
14910
+ status = '';
14911
+ }
14912
+ var itemIds = [];
14913
+ React__default.Children.forEach(children, function (child) {
14914
+ var _child$props;
14915
+ if (!((_child$props = child.props) != null && _child$props.isDisabled)) {
14916
+ var _child$props2, _child$props3;
14917
+ var childStatus = status === exports.IndeterminateCheckboxStatus.checked ? exports.IndeterminateCheckboxStatus.checked : exports.IndeterminateCheckboxStatus.unchecked;
14918
+ if ((_child$props2 = child.props) != null && _child$props2.itemId && childStatus !== exports.IndeterminateCheckboxStatus.unchecked) {
14919
+ itemIds.push({
14920
+ itemId: child.props.itemId,
14921
+ checkedStatus: childStatus
15166
14922
  });
15167
- setSelectedItems(newSelectedItems);
15168
- updateSelectedItemsChanged();
15169
14923
  }
15170
- } else {
15171
- if (event.target.checked) {
15172
- if (!arrayIncludesId(selectedItems, itemId)) {
15173
- setSelectedItems([].concat(selectedItems, [{
15174
- itemId: itemId,
15175
- checkedStatus: exports.IndeterminateCheckboxStatus.checked
15176
- }]));
15177
- updateSelectedItemsChanged();
15178
- }
15179
- } else if (!event.target.checked) {
15180
- setSelectedItems(selectedItems.filter(function (obj) {
15181
- return obj.itemId !== itemId;
15182
- }));
15183
- updateSelectedItemsChanged();
14924
+ if ((_child$props3 = child.props) != null && _child$props3.children) {
14925
+ var nestedItemIds = getChildrenItemIds(child.props.children, childStatus);
14926
+ itemIds = itemIds.concat(nestedItemIds);
15184
14927
  }
15185
14928
  }
15186
- };
15187
- var handleClick = function handleClick(event, itemId) {
15188
- if (selectable !== exports.TreeViewSelectable.off) {
15189
- if (selectable === exports.TreeViewSelectable.single) {
15190
- singleSelectChangeHandler(event, itemId);
15191
- } else if (selectable === exports.TreeViewSelectable.multi) {
15192
- multiSelectChangeHandler(event);
14929
+ });
14930
+ return itemIds;
14931
+ }
14932
+ // Return an array of strings of all enabled children ids recursively
14933
+ function getChildrenItemIdsFlat(children) {
14934
+ var itemIds = [];
14935
+ React__default.Children.forEach(children, function (child) {
14936
+ var _child$props4;
14937
+ if (!((_child$props4 = child.props) != null && _child$props4.isDisabled)) {
14938
+ var _child$props5, _child$props6;
14939
+ if ((_child$props5 = child.props) != null && _child$props5.itemId) {
14940
+ itemIds.push(child.props.itemId);
15193
14941
  }
15194
- onClick && typeof onClick === 'function' && onClick();
14942
+ if ((_child$props6 = child.props) != null && _child$props6.children) {
14943
+ var nestedItemIds = getChildrenItemIdsFlat(child.props.children);
14944
+ itemIds = itemIds.concat(nestedItemIds);
14945
+ }
14946
+ }
14947
+ });
14948
+ return itemIds;
14949
+ }
14950
+ // Return an array of objects where all children are items are nested in the parents
14951
+ function getChildrenItemIdsInTree(children) {
14952
+ var itemIds = [];
14953
+ React__default.Children.forEach(children, function (child) {
14954
+ var _child$props7, _child$props8;
14955
+ if ((_child$props7 = child.props) != null && _child$props7.itemId && !((_child$props8 = child.props) != null && _child$props8.isDisabled)) {
14956
+ var _child$props9, _child$props10;
14957
+ itemIds.push({
14958
+ itemId: (_child$props9 = child.props) == null ? void 0 : _child$props9.itemId,
14959
+ children: getChildrenItemIdsInTree((_child$props10 = child.props) == null ? void 0 : _child$props10.children)
14960
+ });
14961
+ }
14962
+ });
14963
+ return itemIds;
14964
+ }
14965
+ // Return a treeItemRefArray object with no null children
14966
+ function filterNullEntries(obj) {
14967
+ if (Array.isArray(obj.current)) {
14968
+ var filteredArray = obj.current.filter(function (item) {
14969
+ return (item == null ? void 0 : item.current) !== null;
14970
+ });
14971
+ if (filteredArray.length > 0) {
14972
+ return {
14973
+ current: filteredArray
14974
+ };
15195
14975
  }
15196
- };
15197
- function getFocusIndex(filteredArrayCurrent) {
15198
- return itemId && (filteredArrayCurrent == null ? void 0 : filteredArrayCurrent.findIndex(function (_ref) {
15199
- var item = _ref.current;
15200
- if (!item || !ownRef.current) return false;
15201
- return item === ownRef.current;
15202
- }));
15203
14976
  }
15204
- var focusIndex = getFocusIndex(treeItemRefArray == null ? void 0 : treeItemRefArray.current);
15205
- React.useEffect(function () {
15206
- treeItemRefArray == null || treeItemRefArray.current.map(function (itemRef) {
15207
- if (!itemRef.current) {
15208
- treeItemRefArray.current = treeItemRefArray.current.filter(function (item) {
15209
- return itemRef.current !== item.current;
15210
- });
15211
- }
14977
+ return {};
14978
+ }
14979
+ var getTreeViewData = function getTreeViewData(children, parentId) {
14980
+ if (parentId === void 0) {
14981
+ parentId = null;
14982
+ }
14983
+ var treeItemChildren = React__default.Children.toArray(children).filter(function (child) {
14984
+ return child.type === TreeItem;
14985
+ });
14986
+ return treeItemChildren.map(function (_ref) {
14987
+ var props = _ref.props;
14988
+ return [{
14989
+ itemId: props.itemId,
14990
+ parentId: parentId,
14991
+ icon: props.icon,
14992
+ hasOwnTreeItems: Boolean(props.children)
14993
+ }].concat(props.children ? getTreeViewData(props.children, props.itemId) : []);
14994
+ }).flat();
14995
+ };
14996
+ var getChildrenIds = function getChildrenIds(_ref2) {
14997
+ var items = _ref2.items,
14998
+ itemId = _ref2.itemId;
14999
+ return items.reduce(function (result, item) {
15000
+ if (item.parentId !== itemId) {
15001
+ return result;
15002
+ }
15003
+ if (item.hasOwnTreeItems) {
15004
+ return [].concat(result, getChildrenIds({
15005
+ items: items,
15006
+ itemId: item.itemId
15007
+ }));
15008
+ }
15009
+ return [].concat(result, [item.itemId]);
15010
+ }, [itemId]);
15011
+ };
15012
+ var getChildrenUniqueStatuses = function getChildrenUniqueStatuses(_ref3) {
15013
+ var items = _ref3.items,
15014
+ itemId = _ref3.itemId;
15015
+ var childrenAndItemIds = getChildrenIds({
15016
+ items: items,
15017
+ itemId: itemId
15018
+ });
15019
+ var leaves = items.filter(function (item) {
15020
+ return !item.hasOwnTreeItems && childrenAndItemIds.includes(item.itemId);
15021
+ });
15022
+ var uniqueStatuses = Array.from(new Set(leaves.map(function (item) {
15023
+ var _item$checkedStatus;
15024
+ return (_item$checkedStatus = item.checkedStatus) != null ? _item$checkedStatus : exports.IndeterminateCheckboxStatus.unchecked;
15025
+ })));
15026
+ return uniqueStatuses.filter(function (checkedStatus) {
15027
+ return checkedStatus && checkedStatus !== exports.IndeterminateCheckboxStatus.indeterminate;
15028
+ });
15029
+ };
15030
+ var processInitialParentStatuses = function processInitialParentStatuses(_ref4) {
15031
+ var items = _ref4.items;
15032
+ var itemsWithSelectedChildren = items.reduce(function (result, item) {
15033
+ if (!item.hasOwnTreeItems || item.checkedStatus !== exports.IndeterminateCheckboxStatus.checked) {
15034
+ return result;
15035
+ }
15036
+ return processChildrenSelection({
15037
+ items: result,
15038
+ itemId: item.itemId,
15039
+ checkedStatus: exports.IndeterminateCheckboxStatus.checked
15212
15040
  });
15213
- }, [treeItemRefArray]);
15214
- var focusFirst = function focusFirst() {
15215
- var filteredRefArray = filterNullEntries(treeItemRefArray);
15216
- var curr = filteredRefArray['current'];
15217
- curr == null || curr[0].current.focus();
15218
- };
15219
- var focusNext = function focusNext() {
15220
- var _curr$newIndex;
15221
- var filteredRefArray = filterNullEntries(treeItemRefArray);
15222
- var curr = filteredRefArray['current'];
15223
- var arrLength = curr.length;
15224
- focusIndex = getFocusIndex(curr);
15225
- var newIndex = focusIndex + 1;
15226
- var next = curr == null || (_curr$newIndex = curr[newIndex]) == null ? void 0 : _curr$newIndex.current;
15227
- while (!next && newIndex < arrLength) {
15228
- var _curr$newIndex2;
15229
- newIndex++;
15230
- next = curr == null || (_curr$newIndex2 = curr[newIndex]) == null ? void 0 : _curr$newIndex2.current;
15041
+ }, items);
15042
+ return itemsWithSelectedChildren.map(function (item) {
15043
+ if (!item.hasOwnTreeItems) {
15044
+ return item;
15231
15045
  }
15232
- if (next) {
15233
- next.focus();
15234
- } else {
15235
- var _curr;
15236
- var nextNext = curr == null || (_curr = curr[focusIndex + 2]) == null ? void 0 : _curr.current;
15237
- if (nextNext) {
15238
- nextNext.focus();
15239
- } else {
15240
- focusFirst();
15241
- }
15046
+ var childrenUniqueStatuses = getChildrenUniqueStatuses({
15047
+ items: itemsWithSelectedChildren,
15048
+ itemId: item.itemId
15049
+ });
15050
+ var parentStatus = childrenUniqueStatuses.length > 1 ? exports.IndeterminateCheckboxStatus.indeterminate : childrenUniqueStatuses[0];
15051
+ return parentStatus ? _extends({}, item, {
15052
+ checkedStatus: parentStatus
15053
+ }) : item;
15054
+ });
15055
+ };
15056
+ var getInitialItems = function getInitialItems(_ref5) {
15057
+ var children = _ref5.children,
15058
+ rawPreselectedItems = _ref5.preselectedItems,
15059
+ checkParents = _ref5.checkParents,
15060
+ selectable = _ref5.selectable;
15061
+ var treeViewData = getTreeViewData(children);
15062
+ var preselectedItems = rawPreselectedItems != null && rawPreselectedItems.length && selectable === exports.TreeViewSelectable.single ? [rawPreselectedItems[0]] : rawPreselectedItems;
15063
+ var enhancedWithPreselectedItems = preselectedItems ? treeViewData.map(function (treeViewDataItem) {
15064
+ var preselectedItem = preselectedItems.find(function (_ref6) {
15065
+ var itemId = _ref6.itemId;
15066
+ return treeViewDataItem.itemId === itemId;
15067
+ });
15068
+ return preselectedItem ? _extends({}, treeViewDataItem, {
15069
+ checkedStatus: preselectedItem.checkedStatus
15070
+ }) : treeViewDataItem;
15071
+ }) : treeViewData;
15072
+ return selectable === exports.TreeViewSelectable.multi && checkParents && preselectedItems ? processInitialParentStatuses({
15073
+ items: enhancedWithPreselectedItems
15074
+ }) : enhancedWithPreselectedItems;
15075
+ };
15076
+ var selectSingle = function selectSingle(_ref7) {
15077
+ var items = _ref7.items,
15078
+ itemId = _ref7.itemId,
15079
+ checkedStatus = _ref7.checkedStatus;
15080
+ return items.map(function (item) {
15081
+ return _extends({}, item, {
15082
+ checkedStatus: item.itemId === itemId ? checkedStatus : exports.IndeterminateCheckboxStatus.unchecked
15083
+ });
15084
+ });
15085
+ };
15086
+ var processChildrenSelection = function processChildrenSelection(_ref8) {
15087
+ var items = _ref8.items,
15088
+ itemId = _ref8.itemId,
15089
+ checkedStatus = _ref8.checkedStatus;
15090
+ var childrenAndItemIds = getChildrenIds({
15091
+ items: items,
15092
+ itemId: itemId
15093
+ });
15094
+ return items.map(function (item) {
15095
+ return childrenAndItemIds.includes(item.itemId) ? _extends({}, item, {
15096
+ checkedStatus: checkedStatus
15097
+ }) : item;
15098
+ });
15099
+ };
15100
+ var processParentsSelection = function processParentsSelection(_ref9) {
15101
+ var items = _ref9.items,
15102
+ itemId = _ref9.itemId,
15103
+ checkedStatus = _ref9.checkedStatus;
15104
+ var item = items.find(function (item) {
15105
+ return item.itemId === itemId;
15106
+ });
15107
+ var parentId = item.parentId;
15108
+ if (parentId === null) {
15109
+ return items;
15110
+ }
15111
+ var siblings = items.filter(function (item) {
15112
+ return item.parentId === parentId;
15113
+ });
15114
+ var isAllSiblingsHasTheSameStatus = siblings.every(function (item) {
15115
+ return (item.checkedStatus || exports.IndeterminateCheckboxStatus.unchecked) === checkedStatus;
15116
+ });
15117
+ var parentStatus = isAllSiblingsHasTheSameStatus ? checkedStatus : exports.IndeterminateCheckboxStatus.indeterminate;
15118
+ var parent = items.find(function (item) {
15119
+ return item.itemId === parentId;
15120
+ });
15121
+ var nextItems = items.map(function (item) {
15122
+ return item.itemId === parent.itemId ? _extends({}, item, {
15123
+ checkedStatus: parentStatus
15124
+ }) : item;
15125
+ });
15126
+ return processParentsSelection({
15127
+ items: nextItems,
15128
+ itemId: parent.itemId,
15129
+ checkedStatus: parentStatus
15130
+ });
15131
+ };
15132
+ var selectMulti = function selectMulti(_ref10) {
15133
+ var items = _ref10.items,
15134
+ itemId = _ref10.itemId,
15135
+ checkedStatus = _ref10.checkedStatus,
15136
+ checkChildren = _ref10.checkChildren,
15137
+ checkParents = _ref10.checkParents;
15138
+ var itemsWithProcessedItemSelection = items.map(function (item) {
15139
+ return item.itemId === itemId ? _extends({}, item, {
15140
+ checkedStatus: checkedStatus
15141
+ }) : item;
15142
+ });
15143
+ var itemsWithProcessedChildrenSelection = checkChildren ? processChildrenSelection({
15144
+ items: itemsWithProcessedItemSelection,
15145
+ itemId: itemId,
15146
+ checkedStatus: checkedStatus
15147
+ }) : itemsWithProcessedItemSelection;
15148
+ return checkParents ? processParentsSelection({
15149
+ items: itemsWithProcessedChildrenSelection,
15150
+ itemId: itemId,
15151
+ checkedStatus: checkedStatus
15152
+ }) : itemsWithProcessedChildrenSelection;
15153
+ };
15154
+
15155
+ var _excluded$1C = ["checkedStatus"];
15156
+ function useTreeView(props) {
15157
+ var _props$selectable = props.selectable,
15158
+ selectable = _props$selectable === void 0 ? exports.TreeViewSelectable.single : _props$selectable,
15159
+ onSelectedItemChange = props.onSelectedItemChange,
15160
+ onExpandedChange = props.onExpandedChange,
15161
+ initialExpandedItems = props.initialExpandedItems,
15162
+ preselectedItems = props.preselectedItems,
15163
+ _props$checkChildren = props.checkChildren,
15164
+ checkChildren = _props$checkChildren === void 0 ? selectable !== exports.TreeViewSelectable.single : _props$checkChildren,
15165
+ _props$checkParents = props.checkParents,
15166
+ checkParents = _props$checkParents === void 0 ? selectable !== exports.TreeViewSelectable.single : _props$checkParents,
15167
+ children = props.children,
15168
+ apiRef = props.apiRef;
15169
+ var hasPreselectedItems = Boolean(preselectedItems);
15170
+ var _React$useState = React.useState(function () {
15171
+ return getInitialItems({
15172
+ children: children,
15173
+ preselectedItems: preselectedItems,
15174
+ checkParents: checkParents,
15175
+ selectable: selectable
15176
+ });
15177
+ }),
15178
+ items = _React$useState[0],
15179
+ setItems = _React$useState[1];
15180
+ var _React$useState2 = React.useState(function () {
15181
+ var initialItems = getInitialItems({
15182
+ children: children,
15183
+ preselectedItems: preselectedItems,
15184
+ checkParents: checkParents,
15185
+ selectable: selectable
15186
+ });
15187
+ return initialItems.some(function (item) {
15188
+ return item.icon;
15189
+ });
15190
+ }),
15191
+ hasIcons = _React$useState2[0];
15192
+ var selectedItems = React.useMemo(function () {
15193
+ return items.filter(function (item) {
15194
+ return item.checkedStatus === exports.IndeterminateCheckboxStatus.checked;
15195
+ });
15196
+ }, [items]);
15197
+ var itemToFocus = React.useMemo(function () {
15198
+ var firstItem = items[0];
15199
+ if (selectable === exports.TreeViewSelectable.off) {
15200
+ var firstExpandableItem = items.find(function (item) {
15201
+ return item.hasOwnTreeItems;
15202
+ });
15203
+ return firstExpandableItem ? firstExpandableItem.itemId : firstItem == null ? void 0 : firstItem.itemId;
15242
15204
  }
15243
- };
15244
- var focusPrev = function focusPrev() {
15245
- var _curr$newIndex3;
15246
- var filteredRefArray = filterNullEntries(treeItemRefArray);
15247
- var curr = filteredRefArray['current'];
15248
- focusIndex = getFocusIndex(curr);
15249
- var newIndex = focusIndex - 1;
15250
- var itemToFocus = curr == null || (_curr$newIndex3 = curr[newIndex]) == null ? void 0 : _curr$newIndex3.current;
15251
- while (!itemToFocus && newIndex >= 0) {
15252
- var _curr$newIndex4;
15253
- newIndex--;
15254
- itemToFocus = curr == null || (_curr$newIndex4 = curr[newIndex]) == null ? void 0 : _curr$newIndex4.current;
15205
+ var firstNonUncheckedItem = items.find(function (item) {
15206
+ return item.checkedStatus && item.checkedStatus !== exports.IndeterminateCheckboxStatus.unchecked;
15207
+ });
15208
+ if (firstNonUncheckedItem) {
15209
+ return firstNonUncheckedItem.itemId;
15255
15210
  }
15256
- if (itemToFocus) {
15257
- itemToFocus.focus();
15211
+ return firstItem == null ? void 0 : firstItem.itemId;
15212
+ }, [items]);
15213
+ var initializationRef = React.useRef(true);
15214
+ React.useEffect(function () {
15215
+ if (initializationRef.current && !hasPreselectedItems) {
15216
+ initializationRef.current = false;
15217
+ return;
15258
15218
  }
15259
- };
15260
- var focusLast = function focusLast() {
15261
- var _filteredRefArray$cur;
15262
- var filteredRefArray = filterNullEntries(treeItemRefArray);
15263
- var arrLength = filteredRefArray['current'].length;
15264
- (_filteredRefArray$cur = filteredRefArray['current']) == null || _filteredRefArray$cur[arrLength - 1].current.focus();
15265
- };
15266
- var focusSelf = function focusSelf() {
15267
- var filteredRefArray = filterNullEntries(treeItemRefArray);
15268
- var curr = filteredRefArray['current'];
15269
- focusIndex = getFocusIndex(curr);
15270
- curr == null || curr[focusIndex].current.focus();
15271
- };
15272
- var expandFocusedNode = function expandFocusedNode() {
15273
- if (hasOwnTreeItems) {
15274
- if (expanded) {
15275
- focusNext();
15276
- } else {
15277
- setExpanded(true);
15278
- focusSelf();
15279
- }
15219
+ if (selectable === exports.TreeViewSelectable.off) {
15220
+ return;
15280
15221
  }
15281
- };
15282
- var collapseFocusedNode = function collapseFocusedNode() {
15283
- if (hasOwnTreeItems) {
15284
- if (expanded) {
15285
- setExpanded(false);
15286
- focusSelf();
15287
- } else {
15288
- focusPrev();
15289
- }
15290
- } else {
15291
- focusPrev();
15222
+ onSelectedItemChange && onSelectedItemChange(items.filter(function (_ref) {
15223
+ var checkedStatus = _ref.checkedStatus;
15224
+ return checkedStatus && checkedStatus !== exports.IndeterminateCheckboxStatus.unchecked;
15225
+ }).map(function (_ref2) {
15226
+ var itemId = _ref2.itemId,
15227
+ checkedStatus = _ref2.checkedStatus;
15228
+ return {
15229
+ itemId: itemId,
15230
+ checkedStatus: checkedStatus
15231
+ };
15232
+ }));
15233
+ }, [items, selectable, hasPreselectedItems]);
15234
+ var selectItem = React.useCallback(function (_ref3) {
15235
+ var itemId = _ref3.itemId,
15236
+ checkedStatus = _ref3.checkedStatus;
15237
+ if (selectable === exports.TreeViewSelectable.off) {
15238
+ return;
15292
15239
  }
15293
- };
15294
- var toggleMultiSelectItems = function toggleMultiSelectItems() {
15295
- var status = arrayIncludesId(selectedItems, itemId) ? exports.IndeterminateCheckboxStatus.unchecked : exports.IndeterminateCheckboxStatus.checked;
15296
- setStatusUpdatedBy("checkboxChange" /* checkboxChange */);
15297
- setCheckedStatus(status);
15298
- updateParentCheckStatus(index, status);
15299
- if (hasOwnTreeItems && checkChildren) {
15300
- var childrenIds = getChildrenItemIds(treeItemChildren, exports.IndeterminateCheckboxStatus.checked);
15301
- if (!arrayIncludesId(selectedItems, itemId)) {
15302
- setSelectedItems([].concat(selectedItems, childrenIds, [{
15303
- itemId: itemId,
15304
- checkedStatus: status
15305
- }]));
15306
- } else {
15307
- var newSelectedItems = filterSelectedItems(selectedItems, childrenIds, {
15240
+ setItems(function (prevItems) {
15241
+ if (selectable === exports.TreeViewSelectable.single) {
15242
+ return selectSingle({
15243
+ items: prevItems,
15308
15244
  itemId: itemId,
15309
15245
  checkedStatus: checkedStatus
15310
15246
  });
15311
- setSelectedItems(newSelectedItems);
15312
15247
  }
15313
- } else {
15314
- if (!arrayIncludesId(selectedItems, itemId)) {
15315
- setSelectedItems([].concat(selectedItems, [{
15248
+ if (selectable === exports.TreeViewSelectable.multi) {
15249
+ return selectMulti({
15250
+ items: prevItems,
15316
15251
  itemId: itemId,
15317
- checkedStatus: exports.IndeterminateCheckboxStatus.checked
15318
- }]));
15319
- } else {
15320
- setSelectedItems(selectedItems.filter(function (obj) {
15321
- return obj.itemId !== itemId;
15322
- }));
15252
+ checkedStatus: checkedStatus,
15253
+ checkChildren: checkChildren,
15254
+ checkParents: checkParents
15255
+ });
15323
15256
  }
15324
- }
15325
- updateSelectedItemsChanged();
15326
- };
15327
- var handleKeyDown = function handleKeyDown(event) {
15328
- var filteredRefArray = filterNullEntries(treeItemRefArray);
15329
- var curr = filteredRefArray['current'];
15330
- var arrLength = curr.length;
15331
- switch (event.key) {
15332
- case 'ArrowDown':
15333
- {
15334
- // Move to the next item, or wrap to first
15335
- focusIndex === arrLength - 1 ? focusFirst() : focusNext();
15336
- break;
15337
- }
15338
- case 'ArrowUp':
15339
- {
15340
- // Move to the previous item, or wrap to last
15341
- focusIndex === 0 ? focusLast() : focusPrev();
15342
- break;
15343
- }
15344
- case 'ArrowRight':
15345
- {
15346
- // Open parent nodes
15347
- expandFocusedNode();
15348
- break;
15349
- }
15350
- case 'ArrowLeft':
15351
- {
15352
- // Close open parent nodes
15353
- collapseFocusedNode();
15354
- break;
15355
- }
15356
- case 'Home':
15357
- {
15358
- // Moves focus to the first node in the tree without opening or closing a node.
15359
- focusFirst();
15360
- break;
15361
- }
15362
- case 'End':
15363
- {
15364
- // Moves focus to the last node in the tree that is focusable without opening a node.
15365
- focusLast();
15366
- break;
15367
- }
15368
- case 'Enter':
15369
- {
15370
- // Activates a node, i.e., performs its default action.
15371
- if (selectable === exports.TreeViewSelectable.off && hasOwnTreeItems) {
15372
- setExpanded(!expanded);
15373
- } else if (selectable === exports.TreeViewSelectable.single) {
15374
- // In single-select it selects the focused node.
15375
- setSelectedItems([{
15376
- itemId: itemId,
15377
- checkedStatus: exports.IndeterminateCheckboxStatus.checked
15378
- }]);
15379
- setSelectedItemsChanged(true);
15380
- } else if (selectable === exports.TreeViewSelectable.multi) {
15381
- // In multi-select, it toggles the selection state of the focused node.
15382
- toggleMultiSelectItems();
15257
+ return prevItems;
15258
+ });
15259
+ }, [selectable, checkChildren, checkParents]);
15260
+ React.useEffect(function () {
15261
+ if (apiRef) {
15262
+ apiRef.current = {
15263
+ selectItem: selectItem,
15264
+ selectAll: function selectAll() {
15265
+ if ([exports.TreeViewSelectable.single, exports.TreeViewSelectable.single].includes(selectable)) {
15266
+ return;
15383
15267
  }
15384
- break;
15385
- }
15386
- case ' ':
15387
- {
15388
- // Toggles the selection state of the focused node.
15389
- if (selectable === exports.TreeViewSelectable.off && hasOwnTreeItems) {
15390
- setExpanded(!expanded);
15391
- } else if (selectable === exports.TreeViewSelectable.single) {
15392
- if (hasOwnTreeItems) {
15393
- setExpanded(!expanded);
15394
- } else {
15395
- setSelectedItems([{
15396
- itemId: itemId,
15268
+ setItems(function (prevItems) {
15269
+ return prevItems.map(function (item) {
15270
+ return _extends({}, item, {
15397
15271
  checkedStatus: exports.IndeterminateCheckboxStatus.checked
15398
- }]);
15399
- setSelectedItemsChanged(true);
15400
- }
15401
- } else if (selectable === exports.TreeViewSelectable.multi) {
15402
- toggleMultiSelectItems();
15403
- }
15404
- break;
15272
+ });
15273
+ });
15274
+ });
15275
+ },
15276
+ clearAll: function clearAll() {
15277
+ setItems(function (prevItems) {
15278
+ return prevItems.map(function (_ref4) {
15279
+ var itemWithoutCheckedStatus = _objectWithoutPropertiesLoose(_ref4, _excluded$1C);
15280
+ return itemWithoutCheckedStatus;
15281
+ });
15282
+ });
15405
15283
  }
15406
- default:
15407
- return;
15284
+ };
15408
15285
  }
15409
- };
15286
+ }, [selectItem]);
15287
+ var _React$useState3 = React.useState(false),
15288
+ initialExpandedItemsNeedUpdate = _React$useState3[0],
15289
+ setInitialExpandedItemsNeedUpdate = _React$useState3[1];
15290
+ var _useDescendants = useDescendants(),
15291
+ treeItemRefArray = _useDescendants[0],
15292
+ registerTreeItem = _useDescendants[1];
15293
+ React.useEffect(function () {
15294
+ if (initialExpandedItems) {
15295
+ setInitialExpandedItemsNeedUpdate(true);
15296
+ }
15297
+ }, []);
15410
15298
  var contextValue = {
15411
- checkboxChangeHandler: checkboxChangeHandler,
15412
- checkedStatus: checkedStatus,
15413
- expanded: expanded,
15414
- hasOwnTreeItems: hasOwnTreeItems,
15415
- itemDepth: parentDepth === 0 && topLevel ? 0 : itemDepth + 1,
15416
- itemId: itemId || generatedId,
15417
- numberOfTreeItemChildren: numberOfTreeItemChildren,
15418
- parentCheckedStatus: parentCheckedStatus,
15419
- parentDepth: parentDepth,
15420
- ref: ref,
15299
+ hasIcons: hasIcons,
15300
+ itemToFocus: itemToFocus,
15301
+ onSelectedItemChange: onSelectedItemChange,
15302
+ onExpandedChange: onExpandedChange,
15303
+ selectable: selectable,
15421
15304
  selectedItems: selectedItems,
15422
- setExpanded: setExpanded,
15423
- updateCheckedStatusFromChild: updateCheckedStatusFromChild,
15424
- treeItemChildren: treeItemChildren
15305
+ initialExpandedItems: initialExpandedItems,
15306
+ treeItemRefArray: treeItemRefArray,
15307
+ registerTreeItem: registerTreeItem,
15308
+ initialExpandedItemsNeedUpdate: initialExpandedItemsNeedUpdate,
15309
+ setInitialExpandedItemsNeedUpdate: setInitialExpandedItemsNeedUpdate,
15310
+ checkChildren: checkChildren,
15311
+ checkParents: checkParents,
15312
+ items: items,
15313
+ selectItem: selectItem
15425
15314
  };
15426
15315
  return {
15427
- contextValue: contextValue,
15428
- handleClick: handleClick,
15429
- handleKeyDown: handleKeyDown
15316
+ contextValue: contextValue
15430
15317
  };
15431
15318
  }
15432
15319
 
15433
- var TreeItemContext = /*#__PURE__*/React.createContext({
15434
- expanded: false,
15435
- setExpanded: function setExpanded() {},
15436
- checkedStatus: exports.IndeterminateCheckboxStatus.unchecked,
15437
- checkboxChangeHandler: function checkboxChangeHandler() {},
15438
- hasOwnTreeItems: false,
15439
- updateCheckedStatusFromChild: function updateCheckedStatusFromChild() {},
15440
- numberOfTreeItemChildren: 0,
15441
- parentDepth: 0
15442
- });
15443
-
15444
- var _excluded$1B = ["children", "icon", "index", "isDisabled", "label", "labelStyle", "parentCheckedStatus", "style", "testId", "updateParentCheckStatus", "topLevel"];
15445
- var StyledTreeItem = /*#__PURE__*/_styled("li", {
15446
- target: "e1xiryew5",
15447
- label: "StyledTreeItem"
15448
- })("color:", function (props) {
15449
- return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral700;
15450
- }, ";list-style-type:none;cursor:", function (props) {
15451
- return getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType);
15452
- }, ";position:relative;margin-bottom:0;padding-inline-start:", function (props) {
15453
- return calculateOffset(props.nodeType, props.depth);
15454
- }, ";>div:first-of-type{background:", function (props) {
15455
- return props.selected && props.isInverse ? polished.transparentize(0.7, props.theme.colors.neutral900) : props.selected && polished.transparentize(0.92, props.theme.colors.neutral900);
15456
- }, ";position:relative;padding-inline-start:", function (props) {
15457
- return calculateOffset(props.nodeType, props.depth, true);
15458
- }, ";margin-inline-start:", function (props) {
15459
- return calculateOffset(props.nodeType, props.depth, true, true);
15460
- }, ";padding-block-end:", function (props) {
15461
- return props.theme.spaceScale.spacing02;
15462
- }, ";padding-block-start:", function (props) {
15463
- return props.theme.spaceScale.spacing02;
15464
- }, ";padding-right:", function (props) {
15465
- return props.theme.spaceScale.spacing02;
15466
- }, ";", function (props) {
15467
- return props.selected && /*#__PURE__*/react.css("&:before{position:absolute;background-color:", props.isInverse ? props.theme.colors.tertiary500 : props.theme.colors.primary500, ";block-size:100%;content:'';inline-size:", props.theme.spaceScale.spacing02, ";inset-block-start:0;inset-inline-start:0;};label:StyledTreeItem;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAwCQ","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
15468
- }, " &:hover{background:", function (props) {
15469
- return !props.isDisabled ? props.isInverse ? polished.transparentize(0.8, props.theme.colors.neutral900) : polished.transparentize(0.95, props.theme.colors.neutral900) : undefined;
15470
- }, ";}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAeiC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
15471
- var IconWrapper$8 = /*#__PURE__*/_styled("span", {
15472
- target: "e1xiryew4",
15473
- label: "IconWrapper"
15474
- })("color:", function (props) {
15475
- return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
15476
- }, ";margin-right:", function (props) {
15477
- return props.theme.spaceScale.spacing03;
15478
- }, ";margin-left:0px;svg{height:", function (props) {
15479
- return props.theme.iconSizes.medium;
15480
- }, "px;width:", function (props) {
15481
- return props.theme.iconSizes.medium;
15482
- }, "px;vertical-align:middle;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AA8DgC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
15483
- var StyledLabelWrapper = /*#__PURE__*/_styled("span", {
15484
- target: "e1xiryew3",
15485
- label: "StyledLabelWrapper"
15486
- })("display:flex;align-items:flex-start;color:", function (props) {
15487
- return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
15488
- }, ";width:100%;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAwEuC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
15489
- var StyledExpandWrapper = /*#__PURE__*/_styled("div", {
15490
- target: "e1xiryew2",
15491
- label: "StyledExpandWrapper"
15492
- })("display:inline-block;vertical-align:middle;margin-right:", function (props) {
15493
- return props.theme.spaceScale.spacing03;
15494
- }, ";color:", function (props) {
15495
- return getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme);
15496
- }, ";border-radius:0;width:", function (props) {
15497
- return props.theme.spaceScale.spacing06;
15498
- }, ";height:", function (props) {
15499
- return props.theme.spaceScale.spacing06;
15500
- }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AA8EuC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
15501
- var StyledCheckboxWrapper = /*#__PURE__*/_styled("div", {
15502
- target: "e1xiryew1",
15503
- label: "StyledCheckboxWrapper"
15504
- })("margin-right:", function (props) {
15505
- return props.theme.spaceScale.spacing03;
15506
- }, ";vertical-align:middle;display:inline-flex;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AAuFyC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
15507
- var StyledItemWrapper = /*#__PURE__*/_styled("div", {
15508
- target: "e1xiryew0",
15509
- label: "StyledItemWrapper"
15510
- })("display:flex;align-items:flex-start;cursor:", function (props) {
15511
- return getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType);
15512
- }, ";&:focus{outline-offset:-2px;outline:2px solid ", function (props) {
15513
- return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
15514
- }, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TreeItem.tsx"],"names":[],"mappings":"AA4FqC","file":"TreeItem.tsx","sourcesContent":["import * as React from 'react';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { css } from '@emotion/react';\r\nimport { useTreeItem, checkedStatusToBoolean, } from './useTreeItem';\r\nimport { TreeViewSelectable } from './useTreeView';\r\nimport { FolderIcon, ArticleIcon, ExpandMoreIcon, ChevronRightIcon, } from 'react-magma-icons';\r\nimport { Checkbox } from '../Checkbox';\r\nimport { IndeterminateCheckbox, IndeterminateCheckboxStatus, } from '../IndeterminateCheckbox';\r\nimport { Transition } from '../Transition';\r\nimport { calculateOffset, TreeNodeType, getTreeItemLabelColor, getTreeItemWrapperCursor, } from './utils';\r\nimport { transparentize } from 'polished';\r\nimport { TreeItemContext } from './TreeItemContext';\r\nimport { TreeViewContext } from './TreeViewContext';\r\nimport styled from '@emotion/styled';\r\nconst StyledTreeItem = styled.li `\n  color: ${props => props.isInverse\r\n    ? props.theme.colors.neutral100\r\n    : props.theme.colors.neutral700};\n  list-style-type: none;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectableType, props.nodeType)};\n  position: relative;\n  margin-bottom: 0;\n\n  padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth)};\n\n  > div:first-of-type {\n    background: ${props => props.selected && props.isInverse\r\n    ? transparentize(0.7, props.theme.colors.neutral900)\r\n    : props.selected &&\r\n        transparentize(0.92, props.theme.colors.neutral900)};\n    position: relative;\n\n    padding-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true)};\n    margin-inline-start: ${props => calculateOffset(props.nodeType, props.depth, true, true)};\n    padding-block-end: ${props => props.theme.spaceScale.spacing02};\n    padding-block-start: ${props => props.theme.spaceScale.spacing02};\n    padding-right: ${props => props.theme.spaceScale.spacing02};\n\n    ${props => props.selected &&\r\n    css `\n        &:before {\n          position: absolute;\n          background-color: ${props.isInverse\r\n        ? props.theme.colors.tertiary500\r\n        : props.theme.colors.primary500};\n          block-size: 100%;\n          content: '';\n          inline-size: ${props.theme.spaceScale.spacing02};\n          inset-block-start: 0;\n          inset-inline-start: 0;\n        }\n      `}\n\n    &:hover {\n      background: ${props => !props.isDisabled\r\n    ? props.isInverse\r\n        ? transparentize(0.8, props.theme.colors.neutral900)\r\n        : transparentize(0.95, props.theme.colors.neutral900)\r\n    : undefined}\n    }\n  `;\r\nconst IconWrapper = styled.span `\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  margin-left: 0px;\n  svg {\n    height: ${props => props.theme.iconSizes.medium}px;\n    width: ${props => props.theme.iconSizes.medium}px;\n    vertical-align: middle;\n  }\n`;\r\nconst StyledLabelWrapper = styled.span `\n  display: flex;\n  align-items: flex-start;\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  width: 100%;\n`;\r\nconst StyledExpandWrapper = styled.div `\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  color: ${props => getTreeItemLabelColor(props.isInverse, props.isDisabled, props.theme)};\n  border-radius: 0;\n  width: ${props => props.theme.spaceScale.spacing06};\n  height: ${props => props.theme.spaceScale.spacing06};\n`;\r\nconst StyledCheckboxWrapper = styled.div `\n  margin-right: ${props => props.theme.spaceScale.spacing03};\n  vertical-align: middle;\n  display: inline-flex;\n`;\r\nconst StyledItemWrapper = styled.div `\n  display: flex;\n  align-items: flex-start;\n  cursor: ${props => getTreeItemWrapperCursor(props.isDisabled, props.selectable, props.nodeType)};\n  &:focus {\n    outline-offset: -2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nexport const TreeItem = React.forwardRef((props, forwardedRef) => {\r\n    const { children, icon, index, isDisabled, label, labelStyle, parentCheckedStatus, style, testId, updateParentCheckStatus, topLevel, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse();\r\n    const { selectable, hasIcons, onExpandedChange, itemToFocus } = React.useContext(TreeViewContext);\r\n    const { contextValue, handleClick, handleKeyDown } = useTreeItem(props, forwardedRef);\r\n    const { checkboxChangeHandler, checkedStatus, expanded, hasOwnTreeItems, itemDepth, itemId, parentDepth, ref, selectedItems, setExpanded, updateCheckedStatusFromChild, } = contextValue;\r\n    const nodeType = hasOwnTreeItems ? TreeNodeType.branch : TreeNodeType.leaf;\r\n    const selectedItem = selectable === TreeViewSelectable.single\r\n        ? selectedItems?.[0]?.itemId === itemId\r\n        : null;\r\n    const ariaCheckedValue = selectable === TreeViewSelectable.multi\r\n        ? checkedStatus === IndeterminateCheckboxStatus.indeterminate\r\n            ? 'mixed'\r\n            : checkedStatus === IndeterminateCheckboxStatus.checked\r\n        : null;\r\n    const defaultIcon = nodeType === TreeNodeType.branch ? (React.createElement(FolderIcon, { \"aria-hidden\": true })) : (React.createElement(ArticleIcon, { \"aria-hidden\": true }));\r\n    const labelText = (React.createElement(StyledLabelWrapper, { theme: theme, isDisabled: isDisabled, isInverse: isInverse, style: labelStyle, id: `${itemId}-label`, \"data-testid\": `${testId || itemId}-label`, onClick: (e) => {\r\n            if (selectable === TreeViewSelectable.single && !isDisabled) {\r\n                handleClick(e, itemId);\r\n            }\r\n        } },\r\n        hasIcons && (React.createElement(IconWrapper, { isInverse: isInverse, theme: theme, isDisabled: isDisabled, \"data-testid\": `${testId || itemId}-icon` }, icon || defaultIcon)),\r\n        label));\r\n    // Props shared by Checkbox and IndeterminateCheckbox\r\n    const checkboxProps = {\r\n        disabled: isDisabled,\r\n        hideFocus: true,\r\n        id: `${itemId}-checkbox`,\r\n        inputStyle: { marginRight: theme.spaceScale.spacing03 },\r\n        labelStyle: {\r\n            padding: 0,\r\n        },\r\n        labelText: labelText,\r\n        onChange: checkboxChangeHandler,\r\n        tabIndex: -1,\r\n        testId: `${itemId}-checkbox`,\r\n    };\r\n    const onExpandedClicked = (event) => {\r\n        setExpanded(state => !state);\r\n        event.preventDefault();\r\n        onExpandedChange &&\r\n            typeof onExpandedChange === 'function' &&\r\n            onExpandedChange(event);\r\n    };\r\n    return (React.createElement(TreeItemContext.Provider, { value: contextValue },\r\n        React.createElement(StyledTreeItem, Object.assign({}, rest, { \"aria-expanded\": hasOwnTreeItems ? expanded : null, \"aria-selected\": selectedItem, \"aria-checked\": ariaCheckedValue, \"data-testid\": testId, depth: itemDepth, hasOwnTreeItems: true, id: itemId, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, role: \"treeitem\", selectableType: selectable, selected: selectedItem, theme: theme }),\r\n            React.createElement(StyledItemWrapper, { \"data-testid\": `${testId || itemId}-itemwrapper`, depth: itemDepth, id: `${itemId}-itemwrapper`, isDisabled: isDisabled, isInverse: isInverse, nodeType: nodeType, onClick: event => {\r\n                    if (selectable === TreeViewSelectable.off && hasOwnTreeItems) {\r\n                        onExpandedClicked(event);\r\n                    }\r\n                }, onKeyDown: e => {\r\n                    handleKeyDown(e);\r\n                }, ref: ref, selectable: selectable, style: style, tabIndex: itemToFocus === itemId ? 0 : -1, theme: theme },\r\n                hasOwnTreeItems && (React.createElement(StyledExpandWrapper, { \"aria-hidden\": Boolean(!expanded), \"data-testid\": `${testId || itemId}-expand`, isDisabled: isDisabled, isInverse: isInverse, onClick: event => {\r\n                        if (!isDisabled && selectable !== TreeViewSelectable.off) {\r\n                            onExpandedClicked(event);\r\n                        }\r\n                    }, theme: theme }, expanded ? (React.createElement(ExpandMoreIcon, { \"aria-hidden\": true })) : (React.createElement(ChevronRightIcon, { \"aria-hidden\": true })))),\r\n                selectable === TreeViewSelectable.multi ? (React.createElement(StyledCheckboxWrapper, { theme: theme }, hasOwnTreeItems ? (React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, { status: checkedStatus }))) : (React.createElement(Checkbox, Object.assign({}, checkboxProps, { checked: checkedStatusToBoolean(checkedStatus) }))))) : (React.createElement(React.Fragment, null, labelText))),\r\n            React.Children.map(children, (child, index) => {\r\n                const component = child.type === TreeItem ? (React.createElement(Transition, { isOpen: expanded, collapse: true, unmountOnExit: true },\r\n                    React.createElement(\"ul\", { role: \"group\" }, React.cloneElement(child, {\r\n                        index,\r\n                        key: index,\r\n                        itemDepth,\r\n                        parentDepth,\r\n                        parentCheckedStatus: checkedStatus,\r\n                        updateParentCheckStatus: updateCheckedStatusFromChild,\r\n                    })))) : (child);\r\n                // hide the disabled item + the children\r\n                if (isDisabled)\r\n                    return React.createElement(React.Fragment, null);\r\n                return component;\r\n            }))));\r\n});\r\n//# sourceMappingURL=TreeItem.js.map"]} */"));
15515
- var TreeItem = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
15516
- var _selectedItems$;
15517
- var children = props.children,
15518
- icon = props.icon,
15519
- isDisabled = props.isDisabled,
15520
- label = props.label,
15521
- labelStyle = props.labelStyle,
15522
- style = props.style,
15523
- testId = props.testId,
15524
- rest = _objectWithoutPropertiesLoose(props, _excluded$1B);
15525
- var theme = React.useContext(ThemeContext);
15526
- var isInverse = useIsInverse();
15527
- var _React$useContext = React.useContext(TreeViewContext),
15528
- selectable = _React$useContext.selectable,
15529
- hasIcons = _React$useContext.hasIcons,
15530
- onExpandedChange = _React$useContext.onExpandedChange,
15531
- itemToFocus = _React$useContext.itemToFocus;
15532
- var _useTreeItem = useTreeItem(props, forwardedRef),
15533
- contextValue = _useTreeItem.contextValue,
15534
- handleClick = _useTreeItem.handleClick,
15535
- handleKeyDown = _useTreeItem.handleKeyDown;
15536
- var checkboxChangeHandler = contextValue.checkboxChangeHandler,
15537
- checkedStatus = contextValue.checkedStatus,
15538
- expanded = contextValue.expanded,
15539
- hasOwnTreeItems = contextValue.hasOwnTreeItems,
15540
- itemDepth = contextValue.itemDepth,
15541
- itemId = contextValue.itemId,
15542
- parentDepth = contextValue.parentDepth,
15543
- ref = contextValue.ref,
15544
- selectedItems = contextValue.selectedItems,
15545
- setExpanded = contextValue.setExpanded,
15546
- updateCheckedStatusFromChild = contextValue.updateCheckedStatusFromChild;
15547
- var nodeType = hasOwnTreeItems ? exports.TreeNodeType.branch : exports.TreeNodeType.leaf;
15548
- var selectedItem = selectable === exports.TreeViewSelectable.single ? (selectedItems == null || (_selectedItems$ = selectedItems[0]) == null ? void 0 : _selectedItems$.itemId) === itemId : null;
15549
- var ariaCheckedValue = selectable === exports.TreeViewSelectable.multi ? checkedStatus === exports.IndeterminateCheckboxStatus.indeterminate ? 'mixed' : checkedStatus === exports.IndeterminateCheckboxStatus.checked : null;
15550
- var defaultIcon = nodeType === exports.TreeNodeType.branch ? React.createElement(reactMagmaIcons.FolderIcon, {
15551
- "aria-hidden": true
15552
- }) : React.createElement(reactMagmaIcons.ArticleIcon, {
15553
- "aria-hidden": true
15554
- });
15555
- var labelText = React.createElement(StyledLabelWrapper, {
15556
- theme: theme,
15557
- isDisabled: isDisabled,
15558
- isInverse: isInverse,
15559
- style: labelStyle,
15560
- id: itemId + "-label",
15561
- "data-testid": (testId || itemId) + "-label",
15562
- onClick: function onClick(e) {
15563
- if (selectable === exports.TreeViewSelectable.single && !isDisabled) {
15564
- handleClick(e, itemId);
15565
- }
15566
- }
15567
- }, hasIcons && React.createElement(IconWrapper$8, {
15568
- isInverse: isInverse,
15569
- theme: theme,
15570
- isDisabled: isDisabled,
15571
- "data-testid": (testId || itemId) + "-icon"
15572
- }, icon || defaultIcon), label);
15573
- // Props shared by Checkbox and IndeterminateCheckbox
15574
- var checkboxProps = {
15575
- disabled: isDisabled,
15576
- hideFocus: true,
15577
- id: itemId + "-checkbox",
15578
- inputStyle: {
15579
- marginRight: theme.spaceScale.spacing03
15580
- },
15581
- labelStyle: {
15582
- padding: 0
15583
- },
15584
- labelText: labelText,
15585
- onChange: checkboxChangeHandler,
15586
- tabIndex: -1,
15587
- testId: itemId + "-checkbox"
15588
- };
15589
- var onExpandedClicked = function onExpandedClicked(event) {
15590
- setExpanded(function (state) {
15591
- return !state;
15592
- });
15593
- event.preventDefault();
15594
- onExpandedChange && typeof onExpandedChange === 'function' && onExpandedChange(event);
15595
- };
15596
- return React.createElement(TreeItemContext.Provider, {
15597
- value: contextValue
15598
- }, React.createElement(StyledTreeItem, Object.assign({}, rest, {
15599
- "aria-expanded": hasOwnTreeItems ? expanded : null,
15600
- "aria-selected": selectedItem,
15601
- "aria-checked": ariaCheckedValue,
15602
- "data-testid": testId,
15603
- depth: itemDepth,
15604
- hasOwnTreeItems: true,
15605
- id: itemId,
15606
- isDisabled: isDisabled,
15607
- isInverse: isInverse,
15608
- nodeType: nodeType,
15609
- role: "treeitem",
15610
- selectableType: selectable,
15611
- selected: selectedItem,
15612
- theme: theme
15613
- }), React.createElement(StyledItemWrapper, {
15614
- "data-testid": (testId || itemId) + "-itemwrapper",
15615
- depth: itemDepth,
15616
- id: itemId + "-itemwrapper",
15617
- isDisabled: isDisabled,
15618
- isInverse: isInverse,
15619
- nodeType: nodeType,
15620
- onClick: function onClick(event) {
15621
- if (selectable === exports.TreeViewSelectable.off && hasOwnTreeItems) {
15622
- onExpandedClicked(event);
15623
- }
15624
- },
15625
- onKeyDown: function onKeyDown(e) {
15626
- handleKeyDown(e);
15627
- },
15628
- ref: ref,
15629
- selectable: selectable,
15630
- style: style,
15631
- tabIndex: itemToFocus === itemId ? 0 : -1,
15632
- theme: theme
15633
- }, hasOwnTreeItems && React.createElement(StyledExpandWrapper, {
15634
- "aria-hidden": Boolean(!expanded),
15635
- "data-testid": (testId || itemId) + "-expand",
15636
- isDisabled: isDisabled,
15637
- isInverse: isInverse,
15638
- onClick: function onClick(event) {
15639
- if (!isDisabled && selectable !== exports.TreeViewSelectable.off) {
15640
- onExpandedClicked(event);
15641
- }
15642
- },
15643
- theme: theme
15644
- }, expanded ? React.createElement(reactMagmaIcons.ExpandMoreIcon, {
15645
- "aria-hidden": true
15646
- }) : React.createElement(reactMagmaIcons.ChevronRightIcon, {
15647
- "aria-hidden": true
15648
- })), selectable === exports.TreeViewSelectable.multi ? React.createElement(StyledCheckboxWrapper, {
15649
- theme: theme
15650
- }, hasOwnTreeItems ? React.createElement(IndeterminateCheckbox, Object.assign({}, checkboxProps, {
15651
- status: checkedStatus
15652
- })) : React.createElement(Checkbox, Object.assign({}, checkboxProps, {
15653
- checked: checkedStatusToBoolean(checkedStatus)
15654
- }))) : React.createElement(React.Fragment, null, labelText)), React.Children.map(children, function (child, index) {
15655
- var component = child.type === TreeItem ? React.createElement(Transition, {
15656
- isOpen: expanded,
15657
- collapse: true,
15658
- unmountOnExit: true
15659
- }, React.createElement("ul", {
15660
- role: "group"
15661
- }, React.cloneElement(child, {
15662
- index: index,
15663
- key: index,
15664
- itemDepth: itemDepth,
15665
- parentDepth: parentDepth,
15666
- parentCheckedStatus: checkedStatus,
15667
- updateParentCheckStatus: updateCheckedStatusFromChild
15668
- }))) : child;
15669
- // hide the disabled item + the children
15670
- if (isDisabled) return React.createElement(React.Fragment, null);
15671
- return component;
15672
- })));
15673
- });
15674
-
15675
- var _excluded$1C = ["ariaLabel", "ariaLabelledBy", "children", "isInverse", "onExpandedChange", "onSelectedItemChange", "selectable", "testId"];
15320
+ var _excluded$1D = ["ariaLabel", "ariaLabelledBy", "children", "isInverse", "onExpandedChange", "onSelectedItemChange", "selectable", "testId", "apiRef"];
15676
15321
  var StyledTreeView = /*#__PURE__*/_styled("ul", {
15677
15322
  target: "e1tyeayj0",
15678
15323
  label: "StyledTreeView"
15679
15324
  })("padding:0;margin:0;color:", function (props) {
15680
15325
  return props.isInverse ? props.theme.colors.neutral100 : props.theme.colors.neutral;
15681
- }, ";ul{padding:0;margin:0;li{margin:0;}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyZWVWaWV3LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRaUMiLCJmaWxlIjoiVHJlZVZpZXcudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyB1c2VUcmVlVmlldywgVHJlZVZpZXdTZWxlY3RhYmxlLCB9IGZyb20gJy4vdXNlVHJlZVZpZXcnO1xyXG5pbXBvcnQgeyBUcmVlSXRlbSB9IGZyb20gJy4vVHJlZUl0ZW0nO1xyXG5pbXBvcnQgeyBUaGVtZUNvbnRleHQgfSBmcm9tICcuLi8uLi90aGVtZS9UaGVtZUNvbnRleHQnO1xyXG5pbXBvcnQgeyBJbnZlcnNlQ29udGV4dCwgdXNlSXNJbnZlcnNlIH0gZnJvbSAnLi4vLi4vaW52ZXJzZSc7XHJcbmltcG9ydCB7IHVzZVRyZWVJdGVtIH0gZnJvbSAnLi91c2VUcmVlSXRlbSc7XHJcbmltcG9ydCB7IFRyZWVWaWV3Q29udGV4dCB9IGZyb20gJy4vVHJlZVZpZXdDb250ZXh0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5jb25zdCBTdHlsZWRUcmVlVmlldyA9IHN0eWxlZC51bCBgXG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMDtcbiAgY29sb3I6ICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsMTAwXHJcbiAgICA6IHByb3BzLnRoZW1lLmNvbG9ycy5uZXV0cmFsfTtcbiAgdWwge1xuICAgIHBhZGRpbmc6IDA7XG4gICAgbWFyZ2luOiAwO1xuICAgIGxpIHtcbiAgICAgIG1hcmdpbjogMDtcbiAgICB9XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBUcmVlVmlldyA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCByZWYpID0+IHtcclxuICAgIGNvbnN0IHsgYXJpYUxhYmVsLCBhcmlhTGFiZWxsZWRCeSwgY2hpbGRyZW4sIGlzSW52ZXJzZTogaXNJbnZlcnNlUHJvcCwgb25FeHBhbmRlZENoYW5nZSwgb25TZWxlY3RlZEl0ZW1DaGFuZ2UsIHNlbGVjdGFibGUsIHRlc3RJZCwgLi4ucmVzdCB9ID0gcHJvcHM7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IGlzSW52ZXJzZSA9IHVzZUlzSW52ZXJzZShpc0ludmVyc2VQcm9wKTtcclxuICAgIGNvbnN0IHsgY29udGV4dFZhbHVlIH0gPSB1c2VUcmVlVmlldyhwcm9wcyk7XHJcbiAgICBjb25zdCB7IGNvbnRleHRWYWx1ZTogdHJlZUl0ZW1Db250ZXh0VmFsdWUgfSA9IHVzZVRyZWVJdGVtKHsgbGFiZWw6IGFyaWFMYWJlbCwgaXRlbUlkOiAnJyB9LCByZWYpO1xyXG4gICAgbGV0IHRyZWVJdGVtSW5kZXggPSAwO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEludmVyc2VDb250ZXh0LlByb3ZpZGVyLCB7IHZhbHVlOiB7IGlzSW52ZXJzZSB9IH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUcmVlVmlld0NvbnRleHQuUHJvdmlkZXIsIHsgdmFsdWU6IGNvbnRleHRWYWx1ZSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZFRyZWVWaWV3LCBPYmplY3QuYXNzaWduKHt9LCByZXN0LCB7IFwiYXJpYS1sYWJlbFwiOiBhcmlhTGFiZWwsIFwiYXJpYS1sYWJlbGxlZGJ5XCI6IGFyaWFMYWJlbGxlZEJ5LCBcImFyaWEtbXVsdGlzZWxlY3RhYmxlXCI6IHNlbGVjdGFibGUgPT09IFRyZWVWaWV3U2VsZWN0YWJsZS5tdWx0aSwgXCJkYXRhLXRlc3RpZFwiOiB0ZXN0SWQsIGlzSW52ZXJzZTogaXNJbnZlcnNlLCByZWY6IHJlZiwgcm9sZTogXCJ0cmVlXCIsIHRoZW1lOiB0aGVtZSB9KSwgUmVhY3QuQ2hpbGRyZW4ubWFwKGNoaWxkcmVuLCAoY2hpbGQpID0+IHtcclxuICAgICAgICAgICAgICAgIGlmIChjaGlsZC50eXBlID09PSBUcmVlSXRlbSkge1xyXG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IGl0ZW0gPSBSZWFjdC5jbG9uZUVsZW1lbnQoY2hpbGQsIHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgaW5kZXg6IHRyZWVJdGVtSW5kZXgsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGtleTogdHJlZUl0ZW1JbmRleCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgcGFyZW50RGVwdGg6IDAsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGl0ZW1EZXB0aDogMCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgdG9wTGV2ZWw6IHRydWUsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHBhcmVudENoZWNrZWRTdGF0dXM6IHRyZWVJdGVtQ29udGV4dFZhbHVlLmNoZWNrZWRTdGF0dXMgfHwgbnVsbCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgdXBkYXRlUGFyZW50Q2hlY2tTdGF0dXM6IHRyZWVJdGVtQ29udGV4dFZhbHVlLnVwZGF0ZUNoZWNrZWRTdGF0dXNGcm9tQ2hpbGQsXHJcbiAgICAgICAgICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgICAgICAgICAgICAgdHJlZUl0ZW1JbmRleCsrO1xyXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBpdGVtO1xyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9KSkpKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UcmVlVmlldy5qcy5tYXAiXX0= */"));
15326
+ }, ";ul{padding:0;margin:0;li{margin:0;}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyZWVWaWV3LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTaUMiLCJmaWxlIjoiVHJlZVZpZXcudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyB1c2VUcmVlVmlldywgfSBmcm9tICcuL3VzZVRyZWVWaWV3JztcclxuaW1wb3J0IHsgVHJlZVZpZXdTZWxlY3RhYmxlIH0gZnJvbSAnLi90eXBlcyc7XHJcbmltcG9ydCB7IFRyZWVJdGVtIH0gZnJvbSAnLi9UcmVlSXRlbSc7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IEludmVyc2VDb250ZXh0LCB1c2VJc0ludmVyc2UgfSBmcm9tICcuLi8uLi9pbnZlcnNlJztcclxuaW1wb3J0IHsgdXNlVHJlZUl0ZW0gfSBmcm9tICcuL3VzZVRyZWVJdGVtJztcclxuaW1wb3J0IHsgVHJlZVZpZXdDb250ZXh0IH0gZnJvbSAnLi9UcmVlVmlld0NvbnRleHQnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmNvbnN0IFN0eWxlZFRyZWVWaWV3ID0gc3R5bGVkLnVsIGBcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAwO1xuICBjb2xvcjogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWx9O1xuICB1bCB7XG4gICAgcGFkZGluZzogMDtcbiAgICBtYXJnaW46IDA7XG4gICAgbGkge1xuICAgICAgbWFyZ2luOiAwO1xuICAgIH1cbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IFRyZWVWaWV3ID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIHJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBhcmlhTGFiZWwsIGFyaWFMYWJlbGxlZEJ5LCBjaGlsZHJlbiwgaXNJbnZlcnNlOiBpc0ludmVyc2VQcm9wLCBvbkV4cGFuZGVkQ2hhbmdlLCBvblNlbGVjdGVkSXRlbUNoYW5nZSwgc2VsZWN0YWJsZSwgdGVzdElkLCBhcGlSZWYsIC4uLnJlc3QgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgdGhlbWUgPSBSZWFjdC51c2VDb250ZXh0KFRoZW1lQ29udGV4dCk7XHJcbiAgICBjb25zdCBpc0ludmVyc2UgPSB1c2VJc0ludmVyc2UoaXNJbnZlcnNlUHJvcCk7XHJcbiAgICBjb25zdCB7IGNvbnRleHRWYWx1ZSB9ID0gdXNlVHJlZVZpZXcocHJvcHMpO1xyXG4gICAgdXNlVHJlZUl0ZW0oeyBsYWJlbDogYXJpYUxhYmVsLCBpdGVtSWQ6ICcnIH0sIHJlZik7XHJcbiAgICBsZXQgdHJlZUl0ZW1JbmRleCA9IDA7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW52ZXJzZUNvbnRleHQuUHJvdmlkZXIsIHsgdmFsdWU6IHsgaXNJbnZlcnNlIH0gfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFRyZWVWaWV3Q29udGV4dC5Qcm92aWRlciwgeyB2YWx1ZTogY29udGV4dFZhbHVlIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkVHJlZVZpZXcsIE9iamVjdC5hc3NpZ24oe30sIHJlc3QsIHsgXCJhcmlhLWxhYmVsXCI6IGFyaWFMYWJlbCwgXCJhcmlhLWxhYmVsbGVkYnlcIjogYXJpYUxhYmVsbGVkQnksIFwiYXJpYS1tdWx0aXNlbGVjdGFibGVcIjogc2VsZWN0YWJsZSA9PT0gVHJlZVZpZXdTZWxlY3RhYmxlLm11bHRpLCBcImRhdGEtdGVzdGlkXCI6IHRlc3RJZCwgaXNJbnZlcnNlOiBpc0ludmVyc2UsIHJlZjogcmVmLCByb2xlOiBcInRyZWVcIiwgdGhlbWU6IHRoZW1lIH0pLCBSZWFjdC5DaGlsZHJlbi5tYXAoY2hpbGRyZW4sIChjaGlsZCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgaWYgKGNoaWxkLnR5cGUgPT09IFRyZWVJdGVtKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgaXRlbSA9IFJlYWN0LmNsb25lRWxlbWVudChjaGlsZCwge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBpbmRleDogdHJlZUl0ZW1JbmRleCxcclxuICAgICAgICAgICAgICAgICAgICAgICAga2V5OiB0cmVlSXRlbUluZGV4LFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBwYXJlbnREZXB0aDogMCxcclxuICAgICAgICAgICAgICAgICAgICAgICAgaXRlbURlcHRoOiAwLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICB0b3BMZXZlbDogdHJ1ZSxcclxuICAgICAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgICAgICAgICB0cmVlSXRlbUluZGV4Kys7XHJcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGl0ZW07XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIH0pKSkpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVRyZWVWaWV3LmpzLm1hcCJdfQ== */"));
15682
15327
  var TreeView = /*#__PURE__*/React.forwardRef(function (props, ref) {
15683
15328
  var ariaLabel = props.ariaLabel,
15684
15329
  ariaLabelledBy = props.ariaLabelledBy,
@@ -15686,16 +15331,15 @@ var TreeView = /*#__PURE__*/React.forwardRef(function (props, ref) {
15686
15331
  isInverseProp = props.isInverse,
15687
15332
  selectable = props.selectable,
15688
15333
  testId = props.testId,
15689
- rest = _objectWithoutPropertiesLoose(props, _excluded$1C);
15334
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1D);
15690
15335
  var theme = React.useContext(ThemeContext);
15691
15336
  var isInverse = useIsInverse(isInverseProp);
15692
15337
  var _useTreeView = useTreeView(props),
15693
15338
  contextValue = _useTreeView.contextValue;
15694
- var _useTreeItem = useTreeItem({
15695
- label: ariaLabel,
15696
- itemId: ''
15697
- }, ref),
15698
- treeItemContextValue = _useTreeItem.contextValue;
15339
+ useTreeItem({
15340
+ label: ariaLabel,
15341
+ itemId: ''
15342
+ }, ref);
15699
15343
  var treeItemIndex = 0;
15700
15344
  return React.createElement(InverseContext.Provider, {
15701
15345
  value: {
@@ -15719,9 +15363,7 @@ var TreeView = /*#__PURE__*/React.forwardRef(function (props, ref) {
15719
15363
  key: treeItemIndex,
15720
15364
  parentDepth: 0,
15721
15365
  itemDepth: 0,
15722
- topLevel: true,
15723
- parentCheckedStatus: treeItemContextValue.checkedStatus || null,
15724
- updateParentCheckStatus: treeItemContextValue.updateCheckedStatusFromChild
15366
+ topLevel: true
15725
15367
  });
15726
15368
  treeItemIndex++;
15727
15369
  return item;
@@ -15729,7 +15371,7 @@ var TreeView = /*#__PURE__*/React.forwardRef(function (props, ref) {
15729
15371
  }))));
15730
15372
  });
15731
15373
 
15732
- var _excluded$1D = ["children", "enforced", "exclusive", "id", "isInverse", "noSpace", "onChange", "size", "value", "testId"];
15374
+ var _excluded$1E = ["children", "enforced", "exclusive", "id", "isInverse", "noSpace", "onChange", "size", "value", "testId"];
15733
15375
  var ToggleButtonGroupContext = /*#__PURE__*/React.createContext({});
15734
15376
  var ToggleButtonGroup = /*#__PURE__*/React.forwardRef(function (props, ref) {
15735
15377
  var children = props.children,
@@ -15741,7 +15383,7 @@ var ToggleButtonGroup = /*#__PURE__*/React.forwardRef(function (props, ref) {
15741
15383
  size = props.size,
15742
15384
  value = props.value,
15743
15385
  testId = props.testId,
15744
- rest = _objectWithoutPropertiesLoose(props, _excluded$1D);
15386
+ rest = _objectWithoutPropertiesLoose(props, _excluded$1E);
15745
15387
  var theme = React.useContext(ThemeContext);
15746
15388
  var defaultSelectedValues = value ? [value] : [];
15747
15389
  // Array of currently selected items
@@ -16070,36 +15712,24 @@ exports.Transition = Transition;
16070
15712
  exports.TreeItem = TreeItem;
16071
15713
  exports.TreeView = TreeView;
16072
15714
  exports.VisuallyHidden = VisuallyHidden;
16073
- exports.areArraysEqual = areArraysEqual;
16074
- exports.arrayIncludesId = arrayIncludesId;
16075
15715
  exports.blockQuoteStyles = blockQuoteStyles;
16076
15716
  exports.calculateOffset = calculateOffset;
16077
15717
  exports.checkedStatusToBoolean = checkedStatusToBoolean;
16078
15718
  exports.defaultI18n = defaultI18n;
16079
15719
  exports.filterNullEntries = filterNullEntries;
16080
- exports.filterSelectedItems = filterSelectedItems;
16081
- exports.findChildByItemId = findChildByItemId;
16082
- exports.findCommonItems = findCommonItems;
16083
- exports.findFirstBranchNode = findFirstBranchNode;
16084
- exports.getAllChildrenEnabled = getAllChildrenEnabled;
16085
- exports.getAllParentIds = getAllParentIds;
16086
- exports.getCheckedStatus = getCheckedStatus;
16087
- exports.getChildrenCheckedStatus = getChildrenCheckedStatus;
16088
15720
  exports.getChildrenItemIds = getChildrenItemIds;
16089
15721
  exports.getChildrenItemIdsFlat = getChildrenItemIdsFlat;
16090
15722
  exports.getChildrenItemIdsInTree = getChildrenItemIdsInTree;
16091
15723
  exports.getDateFromString = getDateFromString;
16092
- exports.getEnabledTreeItemChildrenLength = getEnabledTreeItemChildrenLength;
16093
- exports.getFirstItemInTree = getFirstItemInTree;
16094
15724
  exports.getIconSizes = getIconSizes;
15725
+ exports.getInitialItems = getInitialItems;
16095
15726
  exports.getListAlignment = getListAlignment;
16096
- exports.getMissingChildrenIds = getMissingChildrenIds;
16097
15727
  exports.getTreeItemLabelColor = getTreeItemLabelColor;
16098
15728
  exports.getTreeItemWrapperCursor = getTreeItemWrapperCursor;
16099
- exports.getUniqueSelectedItemsArray = getUniqueSelectedItemsArray;
16100
- exports.getUpdatedSelectedItems = getUpdatedSelectedItems;
16101
15729
  exports.inDateRange = inDateRange;
16102
15730
  exports.magma = magma;
15731
+ exports.selectMulti = selectMulti;
15732
+ exports.selectSingle = selectSingle;
16103
15733
  exports.setBackgroundColor = setBackgroundColor;
16104
15734
  exports.setIconWidth = setIconWidth;
16105
15735
  exports.useAccordion = useAccordion;