td-stylekit 26.16.1 → 26.19.0

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,24 @@
1
+ # [26.19.0](https://github.com/treasure-data/td-stylekit/compare/v26.18.0...v26.19.0) (2022-07-15)
2
+
3
+
4
+ ### Features
5
+
6
+ * **CON-10356:** Wrap modal menu labels by default and add noWrap prop ([#1302](https://github.com/treasure-data/td-stylekit/issues/1302)) ([5c3992e](https://github.com/treasure-data/td-stylekit/commit/5c3992e))
7
+
8
+ # [26.18.0](https://github.com/treasure-data/td-stylekit/compare/v26.17.0...v26.18.0) (2022-07-04)
9
+
10
+
11
+ ### Features
12
+
13
+ * **CON-10020:** Add Union icon ([#1301](https://github.com/treasure-data/td-stylekit/issues/1301)) ([9c3bdc3](https://github.com/treasure-data/td-stylekit/commit/9c3bdc3))
14
+
15
+ # [26.17.0](https://github.com/treasure-data/td-stylekit/compare/v26.16.1...v26.17.0) (2022-06-28)
16
+
17
+
18
+ ### Features
19
+
20
+ * Add disabled date message ([#1300](https://github.com/treasure-data/td-stylekit/issues/1300)) ([404992f](https://github.com/treasure-data/td-stylekit/commit/404992f))
21
+
1
22
  ## [26.16.1](https://github.com/treasure-data/td-stylekit/compare/v26.16.0...v26.16.1) (2022-06-24)
2
23
 
3
24
 
@@ -58,15 +58,17 @@ export declare type DateControlProps = Omit<FormControlProps<'text'>, 'blockLabe
58
58
  /** Locale */
59
59
  locale?: string;
60
60
  /** Event raised when an error occurs or changes. */
61
- onErrorChange?: (value?: string | string[] | Immutable.List<string> | null) => void;
61
+ handleErrorChange?: (value?: string | string[] | Immutable.List<string> | null) => void;
62
62
  /** Allow switching between 12- and 24-hour formats when `minutes` timeEditor format is selected. */
63
63
  showPeriodSelectorForHours?: boolean;
64
+ /** Message for when a date is disabled */
65
+ disabledDateMessage?: string;
64
66
  };
65
67
  /**
66
68
  * Displays a text Input component with a popover DatePicker for selecting a date.
67
69
  */
68
70
  export declare const UnstyledDateControl: {
69
- ({ className, clearable, dateDisplayFormat, disabledDays, "data-instrumentation": dataInstrumentation, enableFutureDates, enablePastDates, error, hideErrors, minDatetime, name, onMenuClose, onMenuOpen, onChange, placeholder, inline, popoverPlacement, popoverRenderer, theme, value, variant, editor, timeEditor, locale, disabled, showPeriodSelectorForHours, ...props }: DateControlProps): import("@emotion/react/jsx-runtime").JSX.Element;
71
+ ({ className, clearable, dateDisplayFormat, disabledDays, "data-instrumentation": dataInstrumentation, enableFutureDates, enablePastDates, error, hideErrors, minDatetime, name, onMenuClose, onMenuOpen, onChange, placeholder, inline, popoverPlacement, popoverRenderer, theme, value, variant, editor, timeEditor, locale, disabled, showPeriodSelectorForHours, disabledDateMessage, ...props }: DateControlProps): import("@emotion/react/jsx-runtime").JSX.Element;
70
72
  defaultProps: {
71
73
  'data-instrumentation': string;
72
74
  };
@@ -32,7 +32,7 @@ var _TimePicker = _interopRequireDefault(require("../TimePicker"));
32
32
 
33
33
  var _jsxRuntime = require("@emotion/react/jsx-runtime");
34
34
 
35
- var _excluded = ["className", "clearable", "dateDisplayFormat", "disabledDays", "data-instrumentation", "enableFutureDates", "enablePastDates", "error", "hideErrors", "minDatetime", "name", "onMenuClose", "onMenuOpen", "onChange", "placeholder", "inline", "popoverPlacement", "popoverRenderer", "theme", "value", "variant", "editor", "timeEditor", "locale", "disabled", "showPeriodSelectorForHours"];
35
+ var _excluded = ["className", "clearable", "dateDisplayFormat", "disabledDays", "data-instrumentation", "enableFutureDates", "enablePastDates", "error", "hideErrors", "minDatetime", "name", "onMenuClose", "onMenuOpen", "onChange", "placeholder", "inline", "popoverPlacement", "popoverRenderer", "theme", "value", "variant", "editor", "timeEditor", "locale", "disabled", "showPeriodSelectorForHours", "disabledDateMessage"];
36
36
 
37
37
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
38
38
 
@@ -166,6 +166,7 @@ var UnstyledDateControl = function UnstyledDateControl(_ref) {
166
166
  disabled = _ref$disabled === void 0 ? false : _ref$disabled,
167
167
  _ref$showPeriodSelect = _ref.showPeriodSelectorForHours,
168
168
  showPeriodSelectorForHours = _ref$showPeriodSelect === void 0 ? false : _ref$showPeriodSelect,
169
+ disabledDateMessage = _ref.disabledDateMessage,
169
170
  props = _objectWithoutProperties(_ref, _excluded);
170
171
 
171
172
  var _useState = (0, _react.useState)('24'),
@@ -204,8 +205,8 @@ var UnstyledDateControl = function UnstyledDateControl(_ref) {
204
205
 
205
206
  var dateIsValid = value && (0, _dateFns.isValid)(value);
206
207
  (0, _react.useEffect)(function () {
207
- if (props.onErrorChange) {
208
- props.onErrorChange(errors);
208
+ if (props.handleErrorChange) {
209
+ props.handleErrorChange(errors);
209
210
  } // eslint-disable-next-line react-hooks/exhaustive-deps
210
211
 
211
212
  }, [errors]);
@@ -350,11 +351,11 @@ var UnstyledDateControl = function UnstyledDateControl(_ref) {
350
351
  }
351
352
 
352
353
  if (inputValue && date && disabledDays && disabledDays(date)) {
353
- errorList.unshift(DISABLED_DAY_ERROR_MESSAGE);
354
+ errorList.unshift(disabledDateMessage !== null && disabledDateMessage !== void 0 ? disabledDateMessage : DISABLED_DAY_ERROR_MESSAGE);
354
355
  }
355
356
 
356
357
  setErrors(errorList);
357
- }, [inputValue, resolvedDisplayFormat, error, errorMessage, disabledDays, setErrors, locale]);
358
+ }, [inputValue, resolvedDisplayFormat, error, errorMessage, disabledDays, setErrors, locale, disabledDateMessage]);
358
359
  (0, _useOnclickoutside["default"])(datePickerRef, onRootClose);
359
360
  return (0, _jsxRuntime.jsxs)(_elements.Container, {
360
361
  "data-gs": gs("src", "datecontrol", "datecontrol.tsx", "container"),
@@ -584,6 +584,8 @@ export declare type IconTypes = {
584
584
  TypeStringIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
585
585
  Undo: React.ComponentType<JSX.IntrinsicElements['svg']>;
586
586
  UndoIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
587
+ Union: React.ComponentType<JSX.IntrinsicElements['svg']>;
588
+ UnionIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
587
589
  Upload: React.ComponentType<JSX.IntrinsicElements['svg']>;
588
590
  UploadIcon: React.ComponentType<JSX.IntrinsicElements['svg']>;
589
591
  User: React.ComponentType<JSX.IntrinsicElements['svg']>;
@@ -1273,6 +1273,10 @@ React.createElement("path", {
1273
1273
  React.createElement("path", {
1274
1274
  d: "M8.323 4.501a.5.5 0 00-.853-.354L4.146 7.471a.5.5 0 000 .707l3.324 3.323a.5.5 0 00.853-.353V8.824h5.286a4.286 4.286 0 110 8.572h-2.265a1 1 0 100 2h2.265a6.286 6.286 0 100-12.572H8.323V4.501z",
1275
1275
  fillRule: "evenodd"
1276
+ }),Union: /*#__PURE__*/
1277
+ React.createElement("path", {
1278
+ d: "M12 16.9a5.5 5.5 0 110-9.8 5.5 5.5 0 110 9.8zm-1.8-1.47a3.5 3.5 0 110-6.86A5.477 5.477 0 009 12c0 1.297.45 2.49 1.2 3.43zm3.6-6.86a3.5 3.5 0 110 6.86c.751-.94 1.2-2.133 1.2-3.43s-.45-2.49-1.2-3.43zm-1.8.98c.619.632 1 1.496 1 2.45s-.381 1.818-1 2.45c-.619-.632-1-1.497-1-2.45s.381-1.818 1-2.45z",
1279
+ fillRule: "evenodd"
1276
1280
  }),Upload: /*#__PURE__*/
1277
1281
  React.createElement("path", {
1278
1282
  d: "M5.667 4.496A1 1 0 016.531 4H17.47a1 1 0 01.863.496l1.532 2.625a1 1 0 01.136.504v10.5C20 19.16 19.16 20 18.125 20H5.875A1.875 1.875 0 014 18.125v-10.5a1 1 0 01.136-.504l1.531-2.625zM7.106 6L6 7.895v.058h12v-.058L16.894 6H7.106zm1.929 6.134l2.4-2.4a.8.8 0 011.13 0l2.4 2.4a.8.8 0 01-.564 1.366H13v3a1 1 0 01-2 0v-3H9.6a.8.8 0 01-.566-1.366z",
@@ -59,6 +59,7 @@ export declare class Modal extends Component<ModalProps, ModalState> {
59
59
  }[]) => React.ReactNode) | undefined;
60
60
  noPadding?: boolean | undefined;
61
61
  menuWidth?: string | number | undefined;
62
+ noWrap?: boolean | undefined;
62
63
  }> & {
63
64
  NavItem: typeof import("./components/MenuBody").NavItem;
64
65
  Page: ({ children }: {
@@ -11,6 +11,8 @@ export declare const IconWrapper: import("@emotion/styled").StyledComponent<{
11
11
  as?: React.ElementType<any> | undefined;
12
12
  } & {
13
13
  active?: boolean | undefined;
14
+ noWrap?: boolean | undefined;
15
+ isComponentLabel?: boolean | undefined;
14
16
  }, React.DetailedHTMLProps<React.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, {}>;
15
17
  export declare const NavButton: import("@emotion/styled").StyledComponent<any, {}, {}>;
16
18
  export declare const ErrorIcon: import("@emotion/styled").StyledComponent<((React.SVGProps<SVGSVGElement> | (React.SVGProps<SVGSVGElement> & {
@@ -19,6 +21,8 @@ export declare const ErrorIcon: import("@emotion/styled").StyledComponent<((Reac
19
21
  theme?: import("@emotion/react").Theme | undefined;
20
22
  }) & {
21
23
  active?: boolean | undefined;
24
+ noWrap?: boolean | undefined;
25
+ isComponentLabel?: boolean | undefined;
22
26
  }, {}, {}>;
23
27
  declare type NavItemProps = {
24
28
  active?: boolean;
@@ -26,6 +30,8 @@ declare type NavItemProps = {
26
30
  error?: boolean;
27
31
  icon?: React.ReactNode;
28
32
  pageNumber?: number;
33
+ noWrap?: boolean;
34
+ isComponentLabel?: boolean;
29
35
  };
30
36
  export declare function NavItem(props: NavItemProps): import("@emotion/react/jsx-runtime").JSX.Element;
31
37
  declare type MenuBodyProps = {
@@ -53,13 +59,15 @@ declare type MenuBodyProps = {
53
59
  noPadding?: boolean;
54
60
  /** Sets the width of the menu wrapper, defaults to 10rem */
55
61
  menuWidth?: string | number;
62
+ /** 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. */
63
+ noWrap?: boolean;
56
64
  };
57
65
  declare type MenuBodyPageProps = {
58
66
  children: React.ReactNode;
59
67
  disabled?: boolean;
60
68
  id?: string;
61
69
  error?: boolean;
62
- label?: React.ReactNode;
70
+ label?: React.ReactNode | string;
63
71
  icon?: React.ReactNode;
64
72
  };
65
73
  declare const Page: ({ children }: MenuBodyPageProps) => import("@emotion/react/jsx-runtime").JSX.Element;
@@ -17,6 +17,8 @@ var _Icon = _interopRequireDefault(require("../../Icon"));
17
17
 
18
18
  var _Button = _interopRequireDefault(require("../../Button"));
19
19
 
20
+ var _RightTruncatedText = _interopRequireDefault(require("../../RightTruncatedText"));
21
+
20
22
  var _SecondaryNavigation = _interopRequireDefault(require("../../SecondaryNavigation"));
21
23
 
22
24
  var _elements = require("./elements");
@@ -27,7 +29,7 @@ var _ThemeProvider = require("../../ThemeProvider");
27
29
 
28
30
  var _jsxRuntime = require("@emotion/react/jsx-runtime");
29
31
 
30
- var _excluded = ["active", "children", "error", "pageNumber", "icon"],
32
+ var _excluded = ["active", "children", "error", "pageNumber", "icon", "noWrap", "isComponentLabel"],
31
33
  _excluded2 = ["label"];
32
34
 
33
35
  function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
@@ -64,7 +66,7 @@ var Wrapper = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV ==
64
66
  flexDirection: 'row',
65
67
  height: height || 'unset'
66
68
  };
67
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAUgB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\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: React.FC<UnstyledButtonProps> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{ active?: boolean }>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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    overflow: 'hidden',\n    width: '100%',\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}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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 }>(({ error }) => ({\n  display: 'flex',\n  width: error ? '85%' : '100%',\n  alignItems: 'center'\n}))\n\ntype NavItemProps = {\n  active?: boolean\n  children: React.ReactNode\n  error?: boolean\n  icon?: React.ReactNode\n  pageNumber?: number\n}\nexport function NavItem(props: NavItemProps) {\n  const { active, children, error, pageNumber, icon, ...rest } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton {...rest} active={active}>\n        <LabelWrapper error={error}>\n          {icon ? <IconWrapper active={active}>{icon}</IconWrapper> : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? <ErrorIcon active={active} /> : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode\n  icon?: React.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: React.FunctionComponent<MenuBodyProps> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        const navItemProps = {\n          ...props,\n          children: label,\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          }\n        }\n\n        return navItemProps\n      }\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
69
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAWgB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } 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: React.FC<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: React.ReactNode\n  error?: boolean\n  icon?: React.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 {...rest} active={active}>\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: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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 = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode | string\n  icon?: React.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: React.FunctionComponent<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 = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.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    })\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
68
70
  var NavWrapper = ( /*#__PURE__*/0, _base["default"])(_SecondaryNavigation["default"].Wrapper, process.env.NODE_ENV === "production" ? {
69
71
  target: "e7k75jw6"
70
72
  } : {
@@ -85,7 +87,7 @@ var NavWrapper = ( /*#__PURE__*/0, _base["default"])(_SecondaryNavigation["defau
85
87
  paddingLeft: theme.space[2],
86
88
  paddingRight: theme.space[2]
87
89
  };
88
- }, (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":"AAoB0B","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\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: React.FC<UnstyledButtonProps> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{ active?: boolean }>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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    overflow: 'hidden',\n    width: '100%',\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}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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 }>(({ error }) => ({\n  display: 'flex',\n  width: error ? '85%' : '100%',\n  alignItems: 'center'\n}))\n\ntype NavItemProps = {\n  active?: boolean\n  children: React.ReactNode\n  error?: boolean\n  icon?: React.ReactNode\n  pageNumber?: number\n}\nexport function NavItem(props: NavItemProps) {\n  const { active, children, error, pageNumber, icon, ...rest } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton {...rest} active={active}>\n        <LabelWrapper error={error}>\n          {icon ? <IconWrapper active={active}>{icon}</IconWrapper> : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? <ErrorIcon active={active} /> : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode\n  icon?: React.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: React.FunctionComponent<MenuBodyProps> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        const navItemProps = {\n          ...props,\n          children: label,\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          }\n        }\n\n        return navItemProps\n      }\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
90
+ }, (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":"AAqB0B","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } 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: React.FC<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: React.ReactNode\n  error?: boolean\n  icon?: React.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 {...rest} active={active}>\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: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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 = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode | string\n  icon?: React.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: React.FunctionComponent<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 = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.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    })\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
89
91
  exports.NavWrapper = NavWrapper;
90
92
 
91
93
  var PlainButton = function PlainButton(props) {
@@ -107,7 +109,8 @@ var IconWrapper = ( /*#__PURE__*/0, _base["default"])('span', process.env.NODE_E
107
109
  return {
108
110
  lineHeight: 1,
109
111
  marginRight: theme.space[2],
110
- color: theme.palette.neutral[8]
112
+ color: theme.palette.neutral[8],
113
+ alignSelf: 'flex-start'
111
114
  };
112
115
  }, function (_ref4) {
113
116
  var theme = _ref4.theme,
@@ -115,7 +118,13 @@ var IconWrapper = ( /*#__PURE__*/0, _base["default"])('span', process.env.NODE_E
115
118
  return active && {
116
119
  color: theme.palette.neutral[0]
117
120
  };
118
- }, (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":"AA0C2B","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\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: React.FC<UnstyledButtonProps> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{ active?: boolean }>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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    overflow: 'hidden',\n    width: '100%',\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}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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 }>(({ error }) => ({\n  display: 'flex',\n  width: error ? '85%' : '100%',\n  alignItems: 'center'\n}))\n\ntype NavItemProps = {\n  active?: boolean\n  children: React.ReactNode\n  error?: boolean\n  icon?: React.ReactNode\n  pageNumber?: number\n}\nexport function NavItem(props: NavItemProps) {\n  const { active, children, error, pageNumber, icon, ...rest } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton {...rest} active={active}>\n        <LabelWrapper error={error}>\n          {icon ? <IconWrapper active={active}>{icon}</IconWrapper> : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? <ErrorIcon active={active} /> : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode\n  icon?: React.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: React.FunctionComponent<MenuBodyProps> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        const navItemProps = {\n          ...props,\n          children: label,\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          }\n        }\n\n        return navItemProps\n      }\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
121
+ }, function (_ref5) {
122
+ var noWrap = _ref5.noWrap,
123
+ isComponentLabel = _ref5.isComponentLabel;
124
+ return noWrap && !isComponentLabel && {
125
+ alignSelf: 'center'
126
+ };
127
+ }, (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":"AA2C2B","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } 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: React.FC<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: React.ReactNode\n  error?: boolean\n  icon?: React.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 {...rest} active={active}>\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: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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 = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode | string\n  icon?: React.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: React.FunctionComponent<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 = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.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    })\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
119
128
  exports.IconWrapper = IconWrapper;
120
129
  var NavButton = ( /*#__PURE__*/0, _base["default"])(_SecondaryNavigation["default"].Item.withComponent(PlainButton, process.env.NODE_ENV === "production" ? {
121
130
  target: "e7k75jw8"
@@ -133,14 +142,15 @@ var NavButton = ( /*#__PURE__*/0, _base["default"])(_SecondaryNavigation["defaul
133
142
  },
134
143
  target: "e7k75jw4",
135
144
  label: "NavButton"
136
- })(function (_ref5) {
137
- var theme = _ref5.theme;
145
+ })(function (_ref6) {
146
+ var theme = _ref6.theme;
138
147
  return {
139
148
  justifyContent: 'space-between',
140
149
  paddingLeft: theme.space[4],
141
150
  paddingRight: theme.space[4],
142
- overflow: 'hidden',
143
151
  width: '100%',
152
+ height: 'auto',
153
+ minHeight: '2.5rem',
144
154
  ':focus': {
145
155
  outline: 'none'
146
156
  },
@@ -156,9 +166,9 @@ var NavButton = ( /*#__PURE__*/0, _base["default"])(_SecondaryNavigation["defaul
156
166
  color: 'inherit'
157
167
  })
158
168
  };
159
- }, function (_ref6) {
160
- var theme = _ref6.theme,
161
- active = _ref6.active;
169
+ }, function (_ref7) {
170
+ var theme = _ref7.theme,
171
+ active = _ref7.active;
162
172
  return active && {
163
173
  backgroundColor: theme.palette.secondary[4],
164
174
  border: 'none',
@@ -172,9 +182,9 @@ var NavButton = ( /*#__PURE__*/0, _base["default"])(_SecondaryNavigation["defaul
172
182
  color: theme.palette.neutral[0]
173
183
  }
174
184
  };
175
- }, function (_ref7) {
176
- var theme = _ref7.theme,
177
- disabled = _ref7.disabled;
185
+ }, function (_ref8) {
186
+ var theme = _ref8.theme,
187
+ disabled = _ref8.disabled;
178
188
  return disabled && {
179
189
  background: 'transparent',
180
190
  color: theme.palette.neutral[9],
@@ -187,37 +197,48 @@ var NavButton = ( /*#__PURE__*/0, _base["default"])(_SecondaryNavigation["defaul
187
197
  color: theme.palette.neutral[9]
188
198
  }
189
199
  };
190
- }, (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":"AAoDyB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\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: React.FC<UnstyledButtonProps> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{ active?: boolean }>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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    overflow: 'hidden',\n    width: '100%',\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}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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 }>(({ error }) => ({\n  display: 'flex',\n  width: error ? '85%' : '100%',\n  alignItems: 'center'\n}))\n\ntype NavItemProps = {\n  active?: boolean\n  children: React.ReactNode\n  error?: boolean\n  icon?: React.ReactNode\n  pageNumber?: number\n}\nexport function NavItem(props: NavItemProps) {\n  const { active, children, error, pageNumber, icon, ...rest } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton {...rest} active={active}>\n        <LabelWrapper error={error}>\n          {icon ? <IconWrapper active={active}>{icon}</IconWrapper> : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? <ErrorIcon active={active} /> : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode\n  icon?: React.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: React.FunctionComponent<MenuBodyProps> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        const navItemProps = {\n          ...props,\n          children: label,\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          }\n        }\n\n        return navItemProps\n      }\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
200
+ }, (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":"AA+DyB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } 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: React.FC<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: React.ReactNode\n  error?: boolean\n  icon?: React.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 {...rest} active={active}>\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: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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 = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode | string\n  icon?: React.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: React.FunctionComponent<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 = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.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    })\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
191
201
  exports.NavButton = NavButton;
192
202
  var ErrorIcon = ( /*#__PURE__*/0, _base["default"])(_Icon["default"].Medium.StatusUndefined, process.env.NODE_ENV === "production" ? {
193
203
  target: "e7k75jw3"
194
204
  } : {
195
205
  target: "e7k75jw3",
196
206
  label: "ErrorIcon"
197
- })(function (_ref8) {
198
- var theme = _ref8.theme;
207
+ })(function (_ref9) {
208
+ var theme = _ref9.theme;
199
209
  return {
200
- color: theme.palette.error[1]
210
+ color: theme.palette.error[1],
211
+ alignSelf: 'flex-start',
212
+ marginTop: theme.space[3]
201
213
  };
202
- }, function (_ref9) {
203
- var theme = _ref9.theme,
204
- active = _ref9.active;
214
+ }, function (_ref10) {
215
+ var theme = _ref10.theme,
216
+ active = _ref10.active;
205
217
  return active && {
206
218
  color: theme.palette.neutral[0]
207
219
  };
208
- }, (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":"AA2GyB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\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: React.FC<UnstyledButtonProps> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{ active?: boolean }>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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    overflow: 'hidden',\n    width: '100%',\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}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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 }>(({ error }) => ({\n  display: 'flex',\n  width: error ? '85%' : '100%',\n  alignItems: 'center'\n}))\n\ntype NavItemProps = {\n  active?: boolean\n  children: React.ReactNode\n  error?: boolean\n  icon?: React.ReactNode\n  pageNumber?: number\n}\nexport function NavItem(props: NavItemProps) {\n  const { active, children, error, pageNumber, icon, ...rest } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton {...rest} active={active}>\n        <LabelWrapper error={error}>\n          {icon ? <IconWrapper active={active}>{icon}</IconWrapper> : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? <ErrorIcon active={active} /> : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode\n  icon?: React.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: React.FunctionComponent<MenuBodyProps> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        const navItemProps = {\n          ...props,\n          children: label,\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          }\n        }\n\n        return navItemProps\n      }\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
220
+ }, function (_ref11) {
221
+ var theme = _ref11.theme,
222
+ noWrap = _ref11.noWrap,
223
+ isComponentLabel = _ref11.isComponentLabel;
224
+ return noWrap && {
225
+ // This should ensure the error icon aligns itself to the center
226
+ alignSelf: isComponentLabel ? 'flex-start' : 'center',
227
+ marginTop: isComponentLabel ? theme.space[3] : 0
228
+ };
229
+ }, (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":"AAuHyB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } 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: React.FC<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: React.ReactNode\n  error?: boolean\n  icon?: React.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 {...rest} active={active}>\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: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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 = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode | string\n  icon?: React.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: React.FunctionComponent<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 = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.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    })\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
209
230
  exports.ErrorIcon = ErrorIcon;
210
231
  var StepNo = ( /*#__PURE__*/0, _base["default"])('span', process.env.NODE_ENV === "production" ? {
211
232
  target: "e7k75jw2"
212
233
  } : {
213
234
  target: "e7k75jw2",
214
235
  label: "StepNo"
215
- })(function (_ref10) {
216
- var theme = _ref10.theme;
236
+ })(function (_ref12) {
237
+ var theme = _ref12.theme;
217
238
  return {
218
239
  marginRight: theme.space[3]
219
240
  };
220
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAqHe","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\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: React.FC<UnstyledButtonProps> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{ active?: boolean }>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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    overflow: 'hidden',\n    width: '100%',\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}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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 }>(({ error }) => ({\n  display: 'flex',\n  width: error ? '85%' : '100%',\n  alignItems: 'center'\n}))\n\ntype NavItemProps = {\n  active?: boolean\n  children: React.ReactNode\n  error?: boolean\n  icon?: React.ReactNode\n  pageNumber?: number\n}\nexport function NavItem(props: NavItemProps) {\n  const { active, children, error, pageNumber, icon, ...rest } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton {...rest} active={active}>\n        <LabelWrapper error={error}>\n          {icon ? <IconWrapper active={active}>{icon}</IconWrapper> : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? <ErrorIcon active={active} /> : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode\n  icon?: React.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: React.FunctionComponent<MenuBodyProps> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        const navItemProps = {\n          ...props,\n          children: label,\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          }\n        }\n\n        return navItemProps\n      }\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
241
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AA2Ie","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } 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: React.FC<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: React.ReactNode\n  error?: boolean\n  icon?: React.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 {...rest} active={active}>\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: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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 = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode | string\n  icon?: React.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: React.FunctionComponent<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 = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.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    })\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
221
242
  var NavButtonWrapper = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
222
243
  target: "e7k75jw1"
223
244
  } : {
@@ -229,7 +250,7 @@ var NavButtonWrapper = ( /*#__PURE__*/0, _base["default"])('div', process.env.NO
229
250
  } : {
230
251
  name: "bcffy2",
231
252
  styles: "display:flex;align-items:center;justify-content:space-between",
232
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAyHyB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\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: React.FC<UnstyledButtonProps> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{ active?: boolean }>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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    overflow: 'hidden',\n    width: '100%',\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}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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 }>(({ error }) => ({\n  display: 'flex',\n  width: error ? '85%' : '100%',\n  alignItems: 'center'\n}))\n\ntype NavItemProps = {\n  active?: boolean\n  children: React.ReactNode\n  error?: boolean\n  icon?: React.ReactNode\n  pageNumber?: number\n}\nexport function NavItem(props: NavItemProps) {\n  const { active, children, error, pageNumber, icon, ...rest } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton {...rest} active={active}>\n        <LabelWrapper error={error}>\n          {icon ? <IconWrapper active={active}>{icon}</IconWrapper> : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? <ErrorIcon active={active} /> : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode\n  icon?: React.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: React.FunctionComponent<MenuBodyProps> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        const navItemProps = {\n          ...props,\n          children: label,\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          }\n        }\n\n        return navItemProps\n      }\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */",
253
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AA+IyB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } 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: React.FC<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: React.ReactNode\n  error?: boolean\n  icon?: React.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 {...rest} active={active}>\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: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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 = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode | string\n  icon?: React.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: React.FunctionComponent<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 = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.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    })\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */",
233
254
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
234
255
  });
235
256
  var LabelWrapper = ( /*#__PURE__*/0, _base["default"])('span', process.env.NODE_ENV === "production" ? {
@@ -237,14 +258,29 @@ var LabelWrapper = ( /*#__PURE__*/0, _base["default"])('span', process.env.NODE_
237
258
  } : {
238
259
  target: "e7k75jw0",
239
260
  label: "LabelWrapper"
240
- })(function (_ref11) {
241
- var error = _ref11.error;
261
+ })(function (_ref13) {
262
+ var theme = _ref13.theme;
263
+ return {
264
+ height: 'auto',
265
+ whiteSpace: 'break-spaces',
266
+ lineHeight: 1.2,
267
+ textAlign: 'left',
268
+ paddingTop: theme.space[3],
269
+ paddingBottom: theme.space[3]
270
+ };
271
+ }, function (_ref14) {
272
+ var error = _ref14.error;
242
273
  return {
243
274
  display: 'flex',
244
275
  width: error ? '85%' : '100%',
245
276
  alignItems: 'center'
246
277
  };
247
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AA+HqB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } from 'react'\nimport styled from '@emotion/styled'\nimport Icon from '../../Icon'\nimport Button from '../../Button'\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: React.FC<UnstyledButtonProps> = props => (\n  <Button {...props} plain blurOnClick />\n)\n\nexport const IconWrapper = styled('span')<{ active?: boolean }>(\n  ({ theme }) => ({\n    lineHeight: 1,\n    marginRight: theme.space[2],\n    color: theme.palette.neutral[8]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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    overflow: 'hidden',\n    width: '100%',\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}>(\n  ({ theme }) => ({\n    color: theme.palette.error[1]\n  }),\n  ({ theme, active }) => active && { color: theme.palette.neutral[0] },\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 }>(({ error }) => ({\n  display: 'flex',\n  width: error ? '85%' : '100%',\n  alignItems: 'center'\n}))\n\ntype NavItemProps = {\n  active?: boolean\n  children: React.ReactNode\n  error?: boolean\n  icon?: React.ReactNode\n  pageNumber?: number\n}\nexport function NavItem(props: NavItemProps) {\n  const { active, children, error, pageNumber, icon, ...rest } = props\n  return (\n    <NavButtonWrapper>\n      <NavButton {...rest} active={active}>\n        <LabelWrapper error={error}>\n          {icon ? <IconWrapper active={active}>{icon}</IconWrapper> : null}\n          {pageNumber ? <StepNo>{pageNumber} </StepNo> : null}\n          {children}\n        </LabelWrapper>\n        {error ? <ErrorIcon active={active} /> : null}\n      </NavButton>\n    </NavButtonWrapper>\n  )\n}\n\ntype MenuBodyProps = {\n  /** A set of MenuBody.Page components */\n  children: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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}\n\nfunction currentLabelForInstrumentation(activePage, children) {\n  const page = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode\n  icon?: React.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: React.FunctionComponent<MenuBodyProps> &\n  MenuBodySubComponents = ({\n  children,\n  getBodyRef,\n  height,\n  onPageChange,\n  showPageNumber = false,\n  activePage = 0,\n  menuRenderer,\n  menuWidth,\n  noPadding\n}: MenuBodyProps) => {\n  const { setPageInstrumentation } = useContext(ModalContext)\n  useEffect(() => {\n    const child = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.isValidElement(child)) {\n        const { label, ...props } = child.props\n        if (!label) {\n          return null\n        }\n        const navItemProps = {\n          ...props,\n          children: label,\n          key: index,\n          active: index === activePage,\n          pageNumber: showPageNumber ? index + 1 : null,\n          onClick: () => {\n            onPageChange && onPageChange(index)\n          }\n        }\n\n        return navItemProps\n      }\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
278
+ }, function (_ref15) {
279
+ var noWrap = _ref15.noWrap;
280
+ return noWrap && {
281
+ whiteSpace: 'nowrap'
282
+ };
283
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AAqJqB","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } 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: React.FC<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: React.ReactNode\n  error?: boolean\n  icon?: React.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 {...rest} active={active}>\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: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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 = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode | string\n  icon?: React.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: React.FunctionComponent<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 = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.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    })\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */");
248
284
 
249
285
  function NavItem(props) {
250
286
  var active = props.active,
@@ -252,6 +288,8 @@ function NavItem(props) {
252
288
  error = props.error,
253
289
  pageNumber = props.pageNumber,
254
290
  icon = props.icon,
291
+ noWrap = props.noWrap,
292
+ isComponentLabel = props.isComponentLabel,
255
293
  rest = _objectWithoutProperties(props, _excluded);
256
294
 
257
295
  return (0, _jsxRuntime.jsx)(NavButtonWrapper, {
@@ -263,10 +301,13 @@ function NavItem(props) {
263
301
  children: [(0, _jsxRuntime.jsxs)(LabelWrapper, {
264
302
  "data-gs": gs("src", "modal", "components", "nav-item", "nav-button-wrapper", "nav-button", "label-wrapper"),
265
303
  error: error,
304
+ noWrap: noWrap,
266
305
  children: [icon ? (0, _jsxRuntime.jsx)(IconWrapper, {
267
306
  "data-gs-c": gsC(icon),
268
307
  "data-gs": gs("src", "modal", "components", "nav-item", "nav-button-wrapper", "nav-button", "label-wrapper", "icon-wrapper"),
269
308
  active: active,
309
+ noWrap: noWrap,
310
+ isComponentLabel: isComponentLabel,
270
311
  children: icon
271
312
  }) : null, pageNumber ? (0, _jsxRuntime.jsxs)(StepNo, {
272
313
  "data-gs-c": gsC(pageNumber),
@@ -275,7 +316,9 @@ function NavItem(props) {
275
316
  }) : null, children]
276
317
  }), error ? (0, _jsxRuntime.jsx)(ErrorIcon, {
277
318
  "data-gs": gs("src", "modal", "components", "nav-item", "nav-button-wrapper", "nav-button", "error-icon"),
278
- active: active
319
+ active: active,
320
+ noWrap: noWrap,
321
+ isComponentLabel: isComponentLabel
279
322
  }) : null]
280
323
  }))
281
324
  });
@@ -287,25 +330,36 @@ function currentLabelForInstrumentation(activePage, children) {
287
330
  return page && /*#__PURE__*/_react["default"].isValidElement(page) && page.props && typeof page.props.label === 'string' && page.props.label.toLowerCase().replace(/\s/gi, '-');
288
331
  }
289
332
 
290
- var Page = function Page(_ref12) {
291
- var children = _ref12.children;
333
+ var Page = function Page(_ref16) {
334
+ var children = _ref16.children;
292
335
  return (0, _jsxRuntime.jsx)(_jsxRuntime.Fragment, {
293
336
  children: children
294
337
  });
295
338
  };
296
339
 
297
- var MenuBody = function MenuBody(_ref13) {
298
- var children = _ref13.children,
299
- getBodyRef = _ref13.getBodyRef,
300
- height = _ref13.height,
301
- onPageChange = _ref13.onPageChange,
302
- _ref13$showPageNumber = _ref13.showPageNumber,
303
- showPageNumber = _ref13$showPageNumber === void 0 ? false : _ref13$showPageNumber,
304
- _ref13$activePage = _ref13.activePage,
305
- activePage = _ref13$activePage === void 0 ? 0 : _ref13$activePage,
306
- menuRenderer = _ref13.menuRenderer,
307
- menuWidth = _ref13.menuWidth,
308
- noPadding = _ref13.noPadding;
340
+ var _ref18 = process.env.NODE_ENV === "production" ? {
341
+ name: "1flj9lk",
342
+ styles: "text-align:left"
343
+ } : {
344
+ name: "1qkzhi3-children",
345
+ styles: "text-align:left;label:children;",
346
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/Modal/components/MenuBody.tsx"],"names":[],"mappings":"AA0TkC","file":"../../../../src/Modal/components/MenuBody.tsx","sourcesContent":["import React, { useContext, useEffect } 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: React.FC<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: React.ReactNode\n  error?: boolean\n  icon?: React.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 {...rest} active={active}>\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: React.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: React.ReactNode\n      key: number\n      active: boolean\n      pageNumber?: number\n      onClick: () => void\n    }>\n  ) => React.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 = React.Children.toArray(children)[activePage]\n  return (\n    page &&\n    React.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: React.ReactNode\n  disabled?: boolean\n  id?: string\n  error?: boolean\n  label?: React.ReactNode | string\n  icon?: React.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: React.FunctionComponent<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 = React.Children.toArray(children)[activePage]\n    if (React.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 = React.Children.toArray(children)\n    .map((child: React.ReactNode, index) => {\n      if (React.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    })\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        <>{React.Children.toArray(children)[activePage]}</>\n      </ModalBody>\n    </Wrapper>\n  )\n}\n\nMenuBody.NavItem = NavItem\nMenuBody.Page = Page\n\nexport default MenuBody\n"]} */",
347
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
348
+ };
349
+
350
+ var MenuBody = function MenuBody(_ref17) {
351
+ var children = _ref17.children,
352
+ getBodyRef = _ref17.getBodyRef,
353
+ height = _ref17.height,
354
+ onPageChange = _ref17.onPageChange,
355
+ _ref17$showPageNumber = _ref17.showPageNumber,
356
+ showPageNumber = _ref17$showPageNumber === void 0 ? false : _ref17$showPageNumber,
357
+ _ref17$activePage = _ref17.activePage,
358
+ activePage = _ref17$activePage === void 0 ? 0 : _ref17$activePage,
359
+ menuRenderer = _ref17.menuRenderer,
360
+ menuWidth = _ref17.menuWidth,
361
+ noPadding = _ref17.noPadding,
362
+ noWrap = _ref17.noWrap;
309
363
 
310
364
  var _useContext = (0, _react.useContext)(_context.ModalContext),
311
365
  setPageInstrumentation = _useContext.setPageInstrumentation;
@@ -332,15 +386,29 @@ var MenuBody = function MenuBody(_ref13) {
332
386
  if (!label) {
333
387
  return null;
334
388
  }
389
+ /*
390
+ * If we pass in a string as the label, we're able ensure icons get aligned correctly because we handle
391
+ * how it will get rendered (i.e. it'll wrap or truncate). If it's a component, however, we need to take
392
+ * extra steps to ensure the icons are in consistent positions regardless of what wacky stuff gets passed in.
393
+ */
394
+
395
+
396
+ var isComponentLabel = typeof label !== 'string';
335
397
 
336
398
  var navItemProps = _objectSpread(_objectSpread({}, props), {}, {
337
- children: label,
399
+ children: !isComponentLabel && noWrap ? (0, _jsxRuntime.jsx)(_RightTruncatedText["default"], {
400
+ "data-gs": gs("src", "modal", "components", "right-truncated-text"),
401
+ css: _ref18,
402
+ text: label
403
+ }) : label,
338
404
  key: index,
339
405
  active: index === activePage,
340
406
  pageNumber: showPageNumber ? index + 1 : null,
341
407
  onClick: function onClick() {
342
408
  onPageChange && onPageChange(index);
343
- }
409
+ },
410
+ noWrap: noWrap,
411
+ isComponentLabel: isComponentLabel
344
412
  });
345
413
 
346
414
  return navItemProps;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "td-stylekit",
3
- "version": "26.16.1",
3
+ "version": "26.19.0",
4
4
  "main": "dist/es/index.js",
5
5
  "module": "dist/es/index.js",
6
6
  "types": "dist/es/index.d.ts",