td-stylekit 30.9.2 → 30.9.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,3 +1,10 @@
1
+ ## [30.9.3](https://github.com/treasure-data/td-stylekit/compare/v30.9.2...v30.9.3) (2025-05-22)
2
+
3
+
4
+ ### Bug Fixes
5
+
6
+ * **FG-21:** Remove key prop from NavItem props in MenuBody ([#1658](https://github.com/treasure-data/td-stylekit/issues/1658)) ([4559ea0](https://github.com/treasure-data/td-stylekit/commit/4559ea0d895203f4837e3368481eb569879297e3))
7
+
1
8
  ## [30.9.2](https://github.com/treasure-data/td-stylekit/compare/v30.9.1...v30.9.2) (2025-05-21)
2
9
 
3
10
 
@@ -44,7 +44,7 @@ var Wrapper = /*#__PURE__*/(0, _base["default"])('div', process.env.NODE_ENV ===
44
44
  flexDirection: 'row',
45
45
  height: height || 'unset'
46
46
  };
47
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAoBgB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
47
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAoBgB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
48
48
  var NavWrapper = exports.NavWrapper = /*#__PURE__*/(0, _base["default"])(_SecondaryNavigation["default"].Wrapper, process.env.NODE_ENV === "production" ? {
49
49
  target: "e7k75jw6"
50
50
  } : {
@@ -65,7 +65,7 @@ var NavWrapper = exports.NavWrapper = /*#__PURE__*/(0, _base["default"])(_Second
65
65
  paddingLeft: theme.space[2],
66
66
  paddingRight: theme.space[2]
67
67
  };
68
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Modal.NavWrapper), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AA8B0B","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
68
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Modal.NavWrapper), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AA8B0B","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
69
69
  var PlainButton = function PlainButton(props) {
70
70
  return (0, _jsxRuntime.jsx)(_Button["default"], _objectSpread(_objectSpread({
71
71
  "data-gs": gs("src", "modal", "components", "button")
@@ -99,7 +99,7 @@ var IconWrapper = exports.IconWrapper = /*#__PURE__*/(0, _base["default"])('span
99
99
  return noWrap && !isComponentLabel && {
100
100
  alignSelf: 'center'
101
101
  };
102
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Modal.NavButtonIconWrapper), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAoD2B","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
102
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Modal.NavButtonIconWrapper), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAoD2B","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
103
103
  var NavButton = exports.NavButton = /*#__PURE__*/(0, _base["default"])(_SecondaryNavigation["default"].Item.withComponent(PlainButton, process.env.NODE_ENV === "production" ? {
104
104
  target: "e7k75jw8"
105
105
  } : {
@@ -171,7 +171,7 @@ var NavButton = exports.NavButton = /*#__PURE__*/(0, _base["default"])(_Secondar
171
171
  color: theme.palette.neutral[9]
172
172
  }
173
173
  };
174
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Modal.NavButton), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAwEyB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
174
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Modal.NavButton), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAwEyB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
175
175
  var ErrorIcon = exports.ErrorIcon = /*#__PURE__*/(0, _base["default"])(_Icon["default"].Medium.StatusUndefined, process.env.NODE_ENV === "production" ? {
176
176
  target: "e7k75jw3"
177
177
  } : {
@@ -199,7 +199,7 @@ var ErrorIcon = exports.ErrorIcon = /*#__PURE__*/(0, _base["default"])(_Icon["de
199
199
  alignSelf: isComponentLabel ? 'flex-start' : 'center',
200
200
  marginTop: isComponentLabel ? theme.space[3] : 0
201
201
  };
202
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Modal.ErrorIcon), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAgIyB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
202
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Modal.ErrorIcon), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAgIyB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
203
203
  var StepNo = /*#__PURE__*/(0, _base["default"])('span', process.env.NODE_ENV === "production" ? {
204
204
  target: "e7k75jw2"
205
205
  } : {
@@ -210,7 +210,7 @@ var StepNo = /*#__PURE__*/(0, _base["default"])('span', process.env.NODE_ENV ===
210
210
  return {
211
211
  marginRight: theme.space[3]
212
212
  };
213
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAoJe","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
213
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAoJe","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
214
214
  var NavButtonWrapper = /*#__PURE__*/(0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
215
215
  target: "e7k75jw1"
216
216
  } : {
@@ -222,7 +222,7 @@ var NavButtonWrapper = /*#__PURE__*/(0, _base["default"])('div', process.env.NOD
222
222
  } : {
223
223
  name: "bcffy2",
224
224
  styles: "display:flex;align-items:center;justify-content:space-between",
225
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAwJyB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */",
225
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAwJyB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */",
226
226
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
227
227
  });
228
228
  var LabelWrapper = /*#__PURE__*/(0, _base["default"])('span', process.env.NODE_ENV === "production" ? {
@@ -252,7 +252,7 @@ var LabelWrapper = /*#__PURE__*/(0, _base["default"])('span', process.env.NODE_E
252
252
  return noWrap && {
253
253
  whiteSpace: 'nowrap'
254
254
  };
255
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AA8JqB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
255
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AA8JqB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
256
256
  function NavItem(props) {
257
257
  var active = props.active,
258
258
  children = props.children,
@@ -311,7 +311,7 @@ var _ref18 = process.env.NODE_ENV === "production" ? {
311
311
  } : {
312
312
  name: "1qkzhi3-children",
313
313
  styles: "text-align:left;label:children;",
314
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAuUkC","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */",
314
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAuUkC","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  FC,\n  ReactNode,\n  FunctionComponent,\n  Children,\n  isValidElement,\n  useContext,\n  useEffect\n} from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\nimport RightTruncatedText from '../../RightTruncatedText'\nimport type { UnstyledButtonProps } from '../../Button'\nimport Nav from '../../SecondaryNavigation'\nimport { ModalBody } from './elements'\nimport { ModalContext } from '../context'\nimport { getOverrides, Overridable } from '../../ThemeProvider'\n\nconst Wrapper = styled('div')<{\n  height?: string | number\n}>(({ height }) => ({\n  display: 'flex',\n  flex: '1 1 auto',\n  overflow: 'auto',\n  flexDirection: 'row',\n  height: height || 'unset'\n}))\n\nexport const NavWrapper = styled(Nav.Wrapper)<{\n  width?: string | number\n}>(\n  ({ theme, width }) => ({\n    display: 'flex',\n    flex: '0 0 auto',\n    width: width || '11rem',\n    minHeight: 'unset',\n    paddingTop: theme.space[2],\n    backgroundColor: theme.palette.secondary[0],\n    borderTopRightRadius: theme.radius[3],\n    border: `1px solid ${theme.palette.secondary[2]}`,\n    paddingLeft: theme.space[2],\n    paddingRight: theme.space[2]\n  }),\n  getOverrides(Overridable.Modal.NavWrapper)\n)\n\nconst PlainButton: FC<PropsWithChildren<UnstyledButtonProps>> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8],\n    alignSelf: 'flex-start'\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ noWrap, isComponentLabel }) =>\n    noWrap &&\n    !isComponentLabel && {\n      alignSelf: 'center'\n    },\n  getOverrides(Overridable.Modal.NavButtonIconWrapper)\n)\n\nexport const NavButton = styled(Nav.Item.withComponent(PlainButton), {\n  shouldForwardProp: (prop: string) => !['active'].includes(prop)\n})(\n  ({ theme }) => ({\n    justifyContent: 'space-between',\n    paddingLeft: theme.space[4],\n    paddingRight: theme.space[4],\n    width: '100%',\n    height: 'auto',\n    minHeight: '2.5rem',\n    ':focus': {\n      outline: 'none'\n    },\n    ':active': {\n      backgroundColor: 'inherit',\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none'\n    },\n    ':hover': {\n      color: theme.palette.secondary[4],\n      [IconWrapper as any]: {\n        color: 'inherit'\n      }\n    }\n  }),\n  ({ theme, active }) =>\n    active && {\n      backgroundColor: theme.palette.secondary[4],\n      border: 'none',\n      borderRadius: theme.radius[4],\n      boxShadow: 'none',\n      color: theme.palette.neutral[0],\n      ':active': {\n        backgroundColor: theme.palette.secondary[4]\n      },\n      ':hover': {\n        color: theme.palette.neutral[0]\n      }\n    },\n  ({ theme, disabled }) =>\n    disabled && {\n      background: 'transparent',\n      color: theme.palette.neutral[9],\n      cursor: 'not-allowed',\n      ':active': {\n        background: 'transparent',\n        color: theme.palette.neutral[9]\n      },\n      ':hover': {\n        color: theme.palette.neutral[9]\n      }\n    },\n  getOverrides(Overridable.Modal.NavButton)\n)\n\nexport const ErrorIcon = styled(Icon.Medium.StatusUndefined)<{\n  active?: boolean\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1],\n    alignSelf: 'flex-start',\n    marginTop: theme.space[3]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\n  ({ theme, noWrap, isComponentLabel }) =>\n    noWrap && {\n      // This should ensure the error icon aligns itself to the center\n      alignSelf: isComponentLabel ? 'flex-start' : 'center',\n      marginTop: isComponentLabel ? theme.space[3] : 0\n    },\n  getOverrides(Overridable.Modal.ErrorIcon)\n)\n\nconst StepNo = styled('span')(({ theme }) => ({\n  marginRight: theme.space[3]\n}))\n\nconst NavButtonWrapper = styled('div')({\n  display: 'flex',\n  alignItems: 'center',\n  justifyContent: 'space-between'\n})\n\nconst LabelWrapper = styled('span')<{ error?: boolean; noWrap?: boolean }>(\n  ({ theme }) => ({\n    height: 'auto',\n    whiteSpace: 'break-spaces',\n    lineHeight: 1.2,\n    textAlign: 'left',\n    paddingTop: theme.space[3],\n    paddingBottom: theme.space[3]\n  }),\n  ({ error }) => ({\n    display: 'flex',\n    width: error ? '85%' : '100%',\n    alignItems: 'center'\n  }),\n  ({ noWrap }) => noWrap && { whiteSpace: 'nowrap' }\n)\n\ntype NavItemProps = {\n  active?: boolean\n  children: ReactNode\n  error?: boolean\n  icon?: ReactNode\n  pageNumber?: number\n  noWrap?: boolean\n  isComponentLabel?: boolean\n}\nexport function NavItem(props: NavItemProps) {\n  const {\n    active,\n    children,\n    error,\n    pageNumber,\n    icon,\n    noWrap,\n    isComponentLabel,\n    ...rest\n  } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton\n        {...rest}\n        active={active}\n        aria-current={active ? 'step' : false}\n      >\n        <LabelWrapper error={error} noWrap={noWrap}>\n          {icon ? (\n            <IconWrapper\n              active={active}\n              noWrap={noWrap}\n              isComponentLabel={isComponentLabel}\n            >\n              {icon}\n            </IconWrapper>\n          ) : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? (\n          <ErrorIcon\n            active={active}\n            noWrap={noWrap}\n            isComponentLabel={isComponentLabel}\n          />\n        ) : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: ReactNode\n  /** A function that will receive the ref of the ModalBody */\n  getBodyRef?: () => void\n  /** A callback which returns the index of the menu item clicked */\n  onPageChange?: (index: number) => void\n  /** Enabled numeric step labels */\n  showPageNumber?: boolean\n  /** Allows for setting of specific height --- useful for tabbed modals --- does not override min/maxHeight */\n  height?: number | string\n  /** The index of the active page */\n  activePage: number\n  /** Provide a custom renderer for the menu content */\n  menuRenderer?: (\n    navItems: Array<{\n      children: ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => ReactNode\n  /** Passed to Modal.Body */\n  noPadding?: boolean\n  /** Sets the width of the menu wrapper, defaults to 10rem */\n  menuWidth?: string | number\n  /** Removes line wrapping from long menu labels, truncating them instead. Passing a component to a label (as opposed to a string) will override this prop. */\n  noWrap?: boolean\n}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = Children.toArray(children)[activePage]\n  return (\n    page &&\n    isValidElement(page) &&\n    page.props &&\n    typeof page.props.label === 'string' &&\n    page.props.label.toLowerCase().replace(/\\s/gi, '-')\n  )\n}\n\ntype MenuBodyPageProps = {\n  children: ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: ReactNode | string\n  icon?: ReactNode\n}\nconst Page = function ({ children }: MenuBodyPageProps) {\n  return <>{children}</>\n}\n\ntype MenuBodySubComponents = {\n  NavItem: typeof NavItem\n  Page: typeof Page\n}\n\nexport const MenuBody: FunctionComponent<PropsWithChildren<MenuBodyProps>> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding,\n  noWrap\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = Children.toArray(children)[activePage]\n    if (isValidElement(child)) {\n      setPageInstrumentation(child.props['data-instrumentation'] || '')\n    }\n    /*\n     * The current page might be set externally, e.g. for \"Next\" or \"Previous\" buttons in the page content component.\n     * Therefore this hook needs to run every time the activePage changes\n     */\n  }, [activePage, children, setPageInstrumentation])\n  const navItems = Children.toArray(children)\n    .map((child: ReactNode, index) => {\n      if (isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        /*\n         * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle\n         * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take\n         * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.\n         */\n        const isComponentLabel = typeof label !== 'string'\n        const navItemProps = {\n          ...props,\n          children:\n            !isComponentLabel && noWrap ? (\n              <RightTruncatedText css={{ textAlign: 'left' }} text={label} />\n            ) : (\n              label\n            ),\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          },\n          noWrap,\n          isComponentLabel\n        }\n\n        return navItemProps\n      }\n      return null\n    })\n    .filter(navItem => navItem)\n\n  return (\n    <Wrapper height={height}>\n      <NavWrapper width={menuWidth}>\n        {menuRenderer\n          ? menuRenderer(navItems)\n          : navItems.map(navItem => <NavItem key={navItem.key} {...navItem} />)}\n      </NavWrapper>\n      <ModalBody\n        ref={getBodyRef}\n        noPadding={noPadding}\n        data-gs-c={currentLabelForInstrumentation(activePage, children)}\n      >\n        <>{Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */",
315
315
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
316
316
  };
317
317
  var MenuBody = exports.MenuBody = function MenuBody(_ref17) {
@@ -359,7 +359,6 @@ var MenuBody = exports.MenuBody = function MenuBody(_ref17) {
359
359
  css: _ref18,
360
360
  text: label
361
361
  }) : label,
362
- key: index,
363
362
  active: index === activePage,
364
363
  pageNumber: showPageNumber ? index + 1 : null,
365
364
  onClick: function onClick() {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "td-stylekit",
3
- "version": "30.9.2",
3
+ "version": "30.9.3",
4
4
  "main": "dist/es/index.js",
5
5
  "module": "dist/es/index.js",
6
6
  "types": "dist/es/index.d.ts",