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 +21 -0
- package/dist/es/DateControl/DateControl.d.ts +4 -2
- package/dist/es/DateControl/DateControl.js +6 -5
- package/dist/es/Icon/staticTypes.d.ts +2 -0
- package/dist/es/Icon/types.js +4 -0
- package/dist/es/Modal/Modal.d.ts +1 -0
- package/dist/es/Modal/components/MenuBody.d.ts +9 -1
- package/dist/es/Modal/components/MenuBody.js +114 -46
- package/package.json +1 -1
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
|
-
|
|
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.
|
|
208
|
-
props.
|
|
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']>;
|
package/dist/es/Icon/types.js
CHANGED
|
@@ -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",
|
package/dist/es/Modal/Modal.d.ts
CHANGED
|
@@ -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 (
|
|
137
|
-
var 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 (
|
|
160
|
-
var theme =
|
|
161
|
-
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 (
|
|
176
|
-
var theme =
|
|
177
|
-
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 (
|
|
198
|
-
var 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 (
|
|
203
|
-
var theme =
|
|
204
|
-
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 (
|
|
216
|
-
var 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 (
|
|
241
|
-
var
|
|
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(
|
|
291
|
-
var 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
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
showPageNumber = _ref13$showPageNumber === void 0 ? false : _ref13$showPageNumber,
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
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:
|
|
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;
|