@amboss/design-system 1.24.0 → 1.24.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,14 +1,20 @@
1
1
  import React from "react";
2
- import type { MQ, SpaceSizes } from "../../../types";
2
+ import type { MQ, SpaceSizes, ButtonSize } from "../../../types";
3
3
  import type { ButtonProps } from "../../Button/Button";
4
- export type ActionButtonProps = {
4
+ export type ButtonGroupButtonProps = {
5
5
  text: string;
6
6
  } & ButtonProps;
7
7
  export type ButtonGroupProps = {
8
- actionButton?: ActionButtonProps;
8
+ /** Text and other props for action Button */
9
+ actionButton?: ButtonGroupButtonProps;
10
+ /** Text and other props for cancel Button */
11
+ secondaryButton?: ButtonGroupButtonProps;
12
+ /** @deprecated Use secondaryButton to pass in text and other props for cancel button */
9
13
  cancelButtonText?: string;
10
14
  onButtonClick?: (action: "cancel" | "action") => void;
11
15
  space?: MQ<SpaceSizes> | SpaceSizes;
16
+ /** Action and Cancel button size */
17
+ buttonSize?: ButtonSize;
12
18
  "data-e2e-test-id"?: string;
13
19
  };
14
- export declare function ButtonGroup({ cancelButtonText, actionButton, onButtonClick, "data-e2e-test-id": dataE2eTestId, }: ButtonGroupProps): React.ReactElement;
20
+ export declare function ButtonGroup({ cancelButtonText, actionButton, secondaryButton, buttonSize, onButtonClick, "data-e2e-test-id": dataE2eTestId, }: ButtonGroupProps): React.ReactElement;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ButtonGroup",{enumerable:!0,get:function(){return ButtonGroup}});const _react=require("@swc/helpers/_/_interop_require_default")._(require("react")),_Columns=require("../../Column/Columns"),_Button=require("../../Button/Button");function ButtonGroup({cancelButtonText,actionButton,onButtonClick,"data-e2e-test-id":dataE2eTestId}){let{text,...rest}=actionButton;return _react.default.createElement(_Columns.Columns,{gap:"s",alignItems:["spaceBetween","right"],"data-e2e-test-id":dataE2eTestId,"data-ds-id":"ButtonGroup"},actionButton&&_react.default.createElement(_Columns.Column,{order:["first","last"],size:[12,"narrow"]},_react.default.createElement(_Button.Button,{variant:"primary",fullWidth:!0,onClick:()=>{onButtonClick("action")},...rest},text)),cancelButtonText&&_react.default.createElement(_Columns.Column,{size:[12,"narrow"]},_react.default.createElement(_Button.Button,{variant:"secondary",fullWidth:!0,onClick:()=>{onButtonClick("cancel")}},cancelButtonText)))}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ButtonGroup",{enumerable:!0,get:function(){return ButtonGroup}});const _react=require("@swc/helpers/_/_interop_require_default")._(require("react")),_Columns=require("../../Column/Columns"),_Button=require("../../Button/Button"),BUTTONSIZE_GAP_MAP={s:"xs",m:"s",l:"m"};function ButtonGroup({cancelButtonText,actionButton,secondaryButton,buttonSize="m",onButtonClick,"data-e2e-test-id":dataE2eTestId}){let{text:actionButtonText,...actionButtonProps}=actionButton,{text,...secondaryButtonProps}=secondaryButton||{},hasSecondaryButton=cancelButtonText||secondaryButton,secondaryButtonLabel=secondaryButton?text:cancelButtonText,gap=BUTTONSIZE_GAP_MAP[buttonSize];return actionButton||hasSecondaryButton?_react.default.createElement(_Columns.Columns,{gap:gap,alignItems:["spaceBetween","right"],"data-e2e-test-id":dataE2eTestId,"data-ds-id":"ButtonGroup"},actionButton&&_react.default.createElement(_Columns.Column,{order:["first","last"],size:[12,"narrow"]},_react.default.createElement(_Button.Button,{onClick:()=>{onButtonClick&&onButtonClick("action")},...actionButtonProps,fullWidth:!0,variant:"primary",size:buttonSize},actionButtonText)),hasSecondaryButton&&_react.default.createElement(_Columns.Column,{size:[12,"narrow"]},_react.default.createElement(_Button.Button,{onClick:()=>{onButtonClick&&onButtonClick("cancel")},...secondaryButtonProps,fullWidth:!0,variant:"secondary",size:buttonSize},secondaryButtonLabel))):null}
@@ -1,6 +1,6 @@
1
1
  import React from "react";
2
2
  import type { StackProps } from "../../Stack/Stack";
3
- import type { ActionButtonProps } from "../ButtonGroup/ButtonGroup";
3
+ import type { ButtonGroupButtonProps } from "../ButtonGroup/ButtonGroup";
4
4
  import type { TextProps } from "../../Typography/Text/Text";
5
5
  type BaseProps = {
6
6
  header: string;
@@ -9,7 +9,11 @@ type BaseProps = {
9
9
  labelHeader?: string;
10
10
  /** The black color is going to be replaced with gray one */
11
11
  subHeader?: string;
12
- actionButton?: ActionButtonProps;
12
+ /** Text and other props for action Button */
13
+ actionButton?: ButtonGroupButtonProps;
14
+ /** Text and other props for action Button */
15
+ secondaryButton?: ButtonGroupButtonProps;
16
+ /** @deprecated Use secondaryButton to pass in text and other props for secondary button */
13
17
  cancelButtonLabel?: string;
14
18
  /** Aim to use <Modal.Text> and <Modal.Stack> */
15
19
  children: React.ReactNode;
@@ -28,7 +32,7 @@ type ConditionalProps = {
28
32
  ImageComponent?: React.ElementType<any>;
29
33
  };
30
34
  export type ModalProps = BaseProps & ConditionalProps;
31
- export declare function Modal({ header, subHeader, labelHeader, children, imageUrl, ImageComponent, cancelButtonLabel, actionButton, role, onAction, privateProps: { skipPortal }, "data-e2e-test-id": dataE2eTestId, }: ModalProps): React.ReactElement;
35
+ export declare function Modal({ header, subHeader, labelHeader, children, imageUrl, ImageComponent, secondaryButton, cancelButtonLabel, actionButton, role, onAction, privateProps: { skipPortal }, "data-e2e-test-id": dataE2eTestId, }: ModalProps): React.ReactElement;
32
36
  export declare namespace Modal {
33
37
  var defaultProps: Partial<ModalProps>;
34
38
  var Stack: ({ children, ...rest }: Omit<StackProps, "space">) => JSX.Element;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Modal",{enumerable:!0,get:function(){return Modal}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=_interop_require_default._(require("@emotion/styled")),_Portal=require("../../Portal/Portal"),_Header=require("../../Typography/Header/Header"),_Stack=require("../../Stack/Stack"),_Container=require("../../Container/Container"),_Box=require("../../Box/Box"),_Inline=require("../../Inline/Inline"),_ButtonGroup=require("../ButtonGroup/ButtonGroup"),_Button=require("../../Button/Button"),_Text=require("../../Typography/Text/Text"),_mediaQueries=require("../../../shared/mediaQueries"),_useOnEscapePress=require("../../../shared/useOnEscapePress"),_useOutsideClick=require("../../../shared/useOutsideClick"),StyledBackdrop=(0,_styled.default)("div",{target:"e1ws3sq80",label:"StyledBackdrop"})(({theme})=>({position:"fixed",top:0,left:0,width:"100%",height:"100vh",background:theme.values.color.background.backdrop.default,display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",flex:"1 0 auto"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport type { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  actionButton?: ActionButtonProps;\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"spaceBetween\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: MQ<HorizontalAlignment> | HorizontalAlignment;\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AAsDuB"} */"),StyledModalWrapper=(0,_styled.default)("div",{target:"e1ws3sq81",label:"StyledModalWrapper"})(({theme})=>({maxWidth:theme.variables.size.dimension.modal.width,...(0,_mediaQueries.mqValue)({width:[`calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,theme.variables.size.dimension.modal.width]})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport type { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  actionButton?: ActionButtonProps;\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"spaceBetween\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: MQ<HorizontalAlignment> | HorizontalAlignment;\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AAoE2B"} */"),StyledInner=(0,_styled.default)("div",{target:"e1ws3sq82",label:"StyledInner"})(()=>({display:"flex",maxHeight:"calc(100vh - 100px)",flexDirection:"column",overflow:"hidden"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport type { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  actionButton?: ActionButtonProps;\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"spaceBetween\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: MQ<HorizontalAlignment> | HorizontalAlignment;\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AA8EoB"} */"),StyledBody=(0,_styled.default)("div",{target:"e1ws3sq83",label:"StyledBody"})(()=>({overflowY:"auto",maxHeight:"100%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport type { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  actionButton?: ActionButtonProps;\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"spaceBetween\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: MQ<HorizontalAlignment> | HorizontalAlignment;\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AAqFmB"} */"),StyledImg=(0,_styled.default)("img",{target:"e1ws3sq84",label:"StyledImg"})(()=>({width:"100%",aspectRatio:"16/9"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport type { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  actionButton?: ActionButtonProps;\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"spaceBetween\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: MQ<HorizontalAlignment> | HorizontalAlignment;\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AA0FkB"} */"),Footer=({children,alignItems=["spaceBetween","right"]})=>_react.default.createElement(_Box.Box,{space:"zero",tSpace:"l"},_react.default.createElement(_Stack.Stack,{alignItems:alignItems},children)),Wrapper=({skipPortal,children})=>skipPortal?_react.default.createElement(_react.default.Fragment,null,children):_react.default.createElement(_Portal.Portal,null,_react.default.createElement(StyledBackdrop,null,children)),ButtonClose=({onClick})=>_react.default.createElement(_Button.Button,{variant:"tertiary",leftIcon:"x",size:"s",onClick:onClick});function Modal({header,subHeader,labelHeader,children,imageUrl,ImageComponent,cancelButtonLabel,actionButton,role,onAction,privateProps:{skipPortal},"data-e2e-test-id":dataE2eTestId}){let modalRef=(0,_react.useRef)(null),handleClose=()=>{onAction("cancel")};(0,_useOutsideClick.useOutsideClick)(modalRef,handleClose,!skipPortal),(0,_useOnEscapePress.useOnEscapePress)(handleClose,[handleClose]);let hasImage=imageUrl||ImageComponent;return _react.default.createElement(Wrapper,{skipPortal:skipPortal},_react.default.createElement(StyledModalWrapper,{ref:modalRef,role:role,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Modal"},_react.default.createElement(_Container.Container,{elevation:4},_react.default.createElement(_Box.Box,{space:["m","xl"]},_react.default.createElement(StyledInner,null,_react.default.createElement(_Box.Box,{space:"zero",bSpace:"s"},_react.default.createElement(_Stack.Stack,{space:hasImage?["s","l"]:"zero"},hasImage&&_react.default.createElement(_react.default.Fragment,null,_react.default.createElement(_Inline.Inline,{alignItems:"right"},_react.default.createElement(ButtonClose,{onClick:handleClose})),imageUrl?_react.default.createElement(StyledImg,{src:imageUrl}):_react.default.createElement(ImageComponent,null)),_react.default.createElement(_Inline.Inline,{alignItems:"spaceBetween",noWrap:!0},_react.default.createElement(_Stack.Stack,{space:"xxs"},labelHeader&&_react.default.createElement(_Header.H6,null,labelHeader),_react.default.createElement(_Stack.Stack,{space:"zero"},_react.default.createElement(_Header.H2,null,header),subHeader&&_react.default.createElement(_Header.H4,{color:"tertiary"},subHeader))),!hasImage&&_react.default.createElement(ButtonClose,{onClick:handleClose})))),_react.default.createElement(StyledBody,null,children),(actionButton||cancelButtonLabel)&&_react.default.createElement(Footer,null,_react.default.createElement(_ButtonGroup.ButtonGroup,{actionButton:actionButton,cancelButtonText:cancelButtonLabel,onButtonClick:onAction})))))))}Modal.defaultProps={role:"dialog","data-e2e-test-id":void 0,privateProps:{skipPortal:!1}},Modal.Stack=({children,...rest})=>_react.default.createElement(_Stack.Stack,{...rest,space:"m"},children),Modal.Text=({children,...rest})=>_react.default.createElement(_Text.Text,{...rest,size:"m",color:"tertiary"},children);
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Modal",{enumerable:!0,get:function(){return Modal}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=_interop_require_default._(require("@emotion/styled")),_Portal=require("../../Portal/Portal"),_Header=require("../../Typography/Header/Header"),_Stack=require("../../Stack/Stack"),_Container=require("../../Container/Container"),_Box=require("../../Box/Box"),_Inline=require("../../Inline/Inline"),_ButtonGroup=require("../ButtonGroup/ButtonGroup"),_Button=require("../../Button/Button"),_Text=require("../../Typography/Text/Text"),_mediaQueries=require("../../../shared/mediaQueries"),_useOnEscapePress=require("../../../shared/useOnEscapePress"),_useOutsideClick=require("../../../shared/useOutsideClick"),StyledBackdrop=(0,_styled.default)("div",{target:"e1d48alb0",label:"StyledBackdrop"})(({theme})=>({position:"fixed",top:0,left:0,width:"100%",height:"100vh",background:theme.values.color.background.backdrop.default,display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",flex:"1 0 auto"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ButtonGroupButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  /** Text and other props for action Button */\n  actionButton?: ButtonGroupButtonProps;\n  /** Text and other props for action Button */\n  secondaryButton?: ButtonGroupButtonProps;\n  /** @deprecated Use secondaryButton to pass in text and other props for secondary button */\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"stretch\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: StackProps[\"alignItems\"];\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  secondaryButton,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const [isOpening, setOpening] = useState(true);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n\n  useEffect(() => {\n    setOpening(false);\n  }, []);\n\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss && !isOpening);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel || secondaryButton) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    secondaryButton={secondaryButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AAyDuB"} */"),StyledModalWrapper=(0,_styled.default)("div",{target:"e1d48alb1",label:"StyledModalWrapper"})(({theme})=>({maxWidth:theme.variables.size.dimension.modal.width,...(0,_mediaQueries.mqValue)({width:[`calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,theme.variables.size.dimension.modal.width]})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ButtonGroupButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  /** Text and other props for action Button */\n  actionButton?: ButtonGroupButtonProps;\n  /** Text and other props for action Button */\n  secondaryButton?: ButtonGroupButtonProps;\n  /** @deprecated Use secondaryButton to pass in text and other props for secondary button */\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"stretch\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: StackProps[\"alignItems\"];\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  secondaryButton,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const [isOpening, setOpening] = useState(true);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n\n  useEffect(() => {\n    setOpening(false);\n  }, []);\n\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss && !isOpening);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel || secondaryButton) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    secondaryButton={secondaryButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AAuE2B"} */"),StyledInner=(0,_styled.default)("div",{target:"e1d48alb2",label:"StyledInner"})(()=>({display:"flex",maxHeight:"calc(100vh - 100px)",flexDirection:"column",overflow:"hidden"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ButtonGroupButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  /** Text and other props for action Button */\n  actionButton?: ButtonGroupButtonProps;\n  /** Text and other props for action Button */\n  secondaryButton?: ButtonGroupButtonProps;\n  /** @deprecated Use secondaryButton to pass in text and other props for secondary button */\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"stretch\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: StackProps[\"alignItems\"];\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  secondaryButton,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const [isOpening, setOpening] = useState(true);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n\n  useEffect(() => {\n    setOpening(false);\n  }, []);\n\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss && !isOpening);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel || secondaryButton) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    secondaryButton={secondaryButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AAiFoB"} */"),StyledBody=(0,_styled.default)("div",{target:"e1d48alb3",label:"StyledBody"})(()=>({overflowY:"auto",maxHeight:"100%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ButtonGroupButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  /** Text and other props for action Button */\n  actionButton?: ButtonGroupButtonProps;\n  /** Text and other props for action Button */\n  secondaryButton?: ButtonGroupButtonProps;\n  /** @deprecated Use secondaryButton to pass in text and other props for secondary button */\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"stretch\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: StackProps[\"alignItems\"];\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  secondaryButton,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const [isOpening, setOpening] = useState(true);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n\n  useEffect(() => {\n    setOpening(false);\n  }, []);\n\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss && !isOpening);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel || secondaryButton) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    secondaryButton={secondaryButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AAwFmB"} */"),StyledImg=(0,_styled.default)("img",{target:"e1d48alb4",label:"StyledImg"})(()=>({width:"100%",aspectRatio:"16/9"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ButtonGroupButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  /** Text and other props for action Button */\n  actionButton?: ButtonGroupButtonProps;\n  /** Text and other props for action Button */\n  secondaryButton?: ButtonGroupButtonProps;\n  /** @deprecated Use secondaryButton to pass in text and other props for secondary button */\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"stretch\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: StackProps[\"alignItems\"];\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  secondaryButton,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const [isOpening, setOpening] = useState(true);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n\n  useEffect(() => {\n    setOpening(false);\n  }, []);\n\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss && !isOpening);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel || secondaryButton) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    secondaryButton={secondaryButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AA6FkB"} */"),Footer=({children,alignItems=["stretch","right"]})=>_react.default.createElement(_Box.Box,{space:"zero",tSpace:"l"},_react.default.createElement(_Stack.Stack,{alignItems:alignItems},children)),Wrapper=({skipPortal,children})=>skipPortal?_react.default.createElement(_react.default.Fragment,null,children):_react.default.createElement(_Portal.Portal,null,_react.default.createElement(StyledBackdrop,null,children)),ButtonClose=({onClick})=>_react.default.createElement(_Button.Button,{variant:"tertiary",leftIcon:"x",size:"s",onClick:onClick});function Modal({header,subHeader,labelHeader,children,imageUrl,ImageComponent,secondaryButton,cancelButtonLabel,actionButton,role,onAction,privateProps:{skipPortal},"data-e2e-test-id":dataE2eTestId}){let modalRef=(0,_react.useRef)(null),[isOpening,setOpening]=(0,_react.useState)(!0),handleClose=()=>{onAction("cancel")};(0,_react.useEffect)(()=>{setOpening(!1)},[]),(0,_useOutsideClick.useOutsideClick)(modalRef,handleClose,!skipPortal&&!isOpening),(0,_useOnEscapePress.useOnEscapePress)(handleClose,[handleClose]);let hasImage=imageUrl||ImageComponent;return _react.default.createElement(Wrapper,{skipPortal:skipPortal},_react.default.createElement(StyledModalWrapper,{ref:modalRef,role:role,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Modal"},_react.default.createElement(_Container.Container,{elevation:4},_react.default.createElement(_Box.Box,{space:["m","xl"]},_react.default.createElement(StyledInner,null,_react.default.createElement(_Box.Box,{space:"zero",bSpace:"s"},_react.default.createElement(_Stack.Stack,{space:hasImage?["s","l"]:"zero"},hasImage&&_react.default.createElement(_react.default.Fragment,null,_react.default.createElement(_Inline.Inline,{alignItems:"right"},_react.default.createElement(ButtonClose,{onClick:handleClose})),imageUrl?_react.default.createElement(StyledImg,{src:imageUrl}):_react.default.createElement(ImageComponent,null)),_react.default.createElement(_Inline.Inline,{alignItems:"spaceBetween",noWrap:!0},_react.default.createElement(_Stack.Stack,{space:"xxs"},labelHeader&&_react.default.createElement(_Header.H6,null,labelHeader),_react.default.createElement(_Stack.Stack,{space:"zero"},_react.default.createElement(_Header.H2,null,header),subHeader&&_react.default.createElement(_Header.H4,{color:"tertiary"},subHeader))),!hasImage&&_react.default.createElement(ButtonClose,{onClick:handleClose})))),_react.default.createElement(StyledBody,null,children),(actionButton||cancelButtonLabel||secondaryButton)&&_react.default.createElement(Footer,null,_react.default.createElement(_ButtonGroup.ButtonGroup,{actionButton:actionButton,secondaryButton:secondaryButton,cancelButtonText:cancelButtonLabel,onButtonClick:onAction})))))))}Modal.defaultProps={role:"dialog","data-e2e-test-id":void 0,privateProps:{skipPortal:!1}},Modal.Stack=({children,...rest})=>_react.default.createElement(_Stack.Stack,{...rest,space:"m"},children),Modal.Text=({children,...rest})=>_react.default.createElement(_Text.Text,{...rest,size:"m",color:"tertiary"},children);
@@ -1,5 +1,6 @@
1
1
  import React from "react";
2
- import type { HorizontalAlignment, MQ, SpaceSizes } from "../../types";
2
+ import type { Property } from "csstype";
3
+ import type { StackHorizontalAlignment, MQ, SpaceSizes, StackVerticalAlignment } from "../../types";
3
4
  export type StackProps = {
4
5
  /** Represents the vertical between the Stack's children
5
6
  * specify [small screen space, medium screen space, large screen space] or one space for all screen sizes
@@ -8,13 +9,20 @@ export type StackProps = {
8
9
  /** Represents elements' horizontal alignment
9
10
  * specify [small screen alignItems, medium screen alignItems, large screen alignItems] or one alignItems for all screen sizes
10
11
  */
11
- alignItems?: MQ<HorizontalAlignment> | HorizontalAlignment;
12
+ alignItems?: MQ<StackHorizontalAlignment> | StackHorizontalAlignment;
13
+ /**
14
+ * Represents elements' vertical alignment
15
+ * specify [small screen vAlignItems, medium screen vAlignItems, large screen vAlignItems] or one alignItems for all screen sizes
16
+ */
17
+ vAlignItems?: MQ<StackVerticalAlignment> | StackVerticalAlignment;
18
+ /** height */
19
+ height?: Property.Height;
12
20
  children: React.ReactNode[] | React.ReactElement;
13
21
  "data-e2e-test-id"?: string;
14
22
  /** @ignore */
15
23
  "data-ds-id"?: string;
16
24
  };
17
- export declare function Stack({ children, space, alignItems, "data-e2e-test-id": dataE2eTestId, "data-ds-id": dataDsId, }: StackProps): React.ReactElement;
25
+ export declare function Stack({ children, space, alignItems, vAlignItems, height, "data-e2e-test-id": dataE2eTestId, "data-ds-id": dataDsId, }: StackProps): React.ReactElement;
18
26
  export declare namespace Stack {
19
27
  var defaultProps: Partial<StackProps>;
20
28
  }
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Stack",{enumerable:!0,get:function(){return Stack}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=_interop_require_default._(require("react")),_styled=_interop_require_default._(require("@emotion/styled")),_flattenChildren=require("../../shared/flattenChildren"),_mediaQueries=require("../../shared/mediaQueries"),StackContainer=(0,_styled.default)("div",{target:"e1yrutbe0",label:"StackContainer"})(({alignItems})=>({...(0,_mediaQueries.mq)({alignItems:[alignItems,{left:"flex-start",right:"flex-end",center:"center",spaceBetween:"space-between"}]}),display:"flex",flexDirection:"column"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU3RhY2svU3RhY2sudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TdGFjay9TdGFjay50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBmbGF0dGVuQ2hpbGRyZW4gfSBmcm9tIFwiLi4vLi4vc2hhcmVkL2ZsYXR0ZW5DaGlsZHJlblwiO1xuaW1wb3J0IHsgbXEgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuXG5pbXBvcnQgdHlwZSB7IEhvcml6b250YWxBbGlnbm1lbnQsIE1RLCBTcGFjZVNpemVzIH0gZnJvbSBcIi4uLy4uL3R5cGVzXCI7XG5cbmV4cG9ydCB0eXBlIFN0YWNrUHJvcHMgPSB7XG4gIC8qKiBSZXByZXNlbnRzIHRoZSB2ZXJ0aWNhbCBiZXR3ZWVuIHRoZSBTdGFjaydzIGNoaWxkcmVuXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBzcGFjZSwgbWVkaXVtIHNjcmVlbiBzcGFjZSwgbGFyZ2Ugc2NyZWVuIHNwYWNlXSBvciBvbmUgc3BhY2UgZm9yIGFsbCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNwYWNlPzogTVE8U3BhY2VTaXplcz4gfCBTcGFjZVNpemVzO1xuICAvKiogUmVwcmVzZW50cyBlbGVtZW50cycgaG9yaXpvbnRhbCBhbGlnbm1lbnRcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gYWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIGFsaWduSXRlbXNdIG9yIG9uZSBhbGlnbkl0ZW1zIGZvciBhbGwgc2NyZWVuIHNpemVzXG4gICAqL1xuICBhbGlnbkl0ZW1zPzogTVE8SG9yaXpvbnRhbEFsaWdubWVudD4gfCBIb3Jpem9udGFsQWxpZ25tZW50O1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdEVsZW1lbnQ7XG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuICAvKiogQGlnbm9yZSAqL1xuICBcImRhdGEtZHMtaWRcIj86IHN0cmluZztcbn07XG5cbnR5cGUgU3RhY2tJdGVtUHJvcHMgPSB7XG4gIC8qKiBSZXByZXNlbnRzIHRoZSB2ZXJ0aWNhbCBiZXR3ZWVuIHRoZSBTdGFjaydzIGNoaWxkcmVuXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBzcGFjZSwgbWVkaXVtIHNjcmVlbiBzcGFjZSwgbGFyZ2Ugc2NyZWVuIHNwYWNlXSBvciBvbmUgc3BhY2UgZm9yIGFsbCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNwYWNlPzogTVE8U3BhY2VTaXplcz4gfCBTcGFjZVNpemVzO1xufTtcblxuY29uc3QgZGVmYXVsdFByb3BzOiBQYXJ0aWFsPFN0YWNrUHJvcHM+ID0ge1xuICBzcGFjZTogXCJ4c1wiLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogdW5kZWZpbmVkLFxuICBcImRhdGEtZHMtaWRcIjogXCJTdGFja1wiLFxufTtcblxuY29uc3QgU3RhY2tDb250YWluZXIgPSBzdHlsZWQuZGl2PFN0YWNrUHJvcHM+KCh7IGFsaWduSXRlbXMgfSkgPT4gKHtcbiAgLi4ubXEoe1xuICAgIGFsaWduSXRlbXM6IFtcbiAgICAgIGFsaWduSXRlbXMsXG4gICAgICB7XG4gICAgICAgIGxlZnQ6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICByaWdodDogXCJmbGV4LWVuZFwiLFxuICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgIHNwYWNlQmV0d2VlbjogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gICAgICB9LFxuICAgIF0sXG4gIH0pLFxuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbn0pKTtcblxuY29uc3QgU3RhY2tJdGVtID0gc3R5bGVkLmRpdjxTdGFja0l0ZW1Qcm9wcz4oKHsgdGhlbWUsIHNwYWNlIH0pID0+ICh7XG4gIC4uLm1xKHtcbiAgICBtYXJnaW5Ub3A6IFtzcGFjZSwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gIH0pLFxuICBcIiY6Zmlyc3Qtb2YtdHlwZVwiOiB7XG4gICAgbWFyZ2luVG9wOiAwLFxuICB9LFxuICBcIiY6ZW1wdHlcIjoge1xuICAgIG1hcmdpblRvcDogMCxcbiAgfSxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFN0YWNrKHtcbiAgY2hpbGRyZW4sXG4gIHNwYWNlLFxuICBhbGlnbkl0ZW1zLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgXCJkYXRhLWRzLWlkXCI6IGRhdGFEc0lkLFxufTogU3RhY2tQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN0YWNrQ29udGFpbmVyXG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgZGF0YS1kcy1pZD17ZGF0YURzSWR9XG4gICAgICBhbGlnbkl0ZW1zPXthbGlnbkl0ZW1zfVxuICAgID5cbiAgICAgIHtSZWFjdC5DaGlsZHJlbi5tYXAoXG4gICAgICAgIGZsYXR0ZW5DaGlsZHJlbihjaGlsZHJlbiksXG4gICAgICAgIChjaGlsZCkgPT4gY2hpbGQgJiYgPFN0YWNrSXRlbSBzcGFjZT17c3BhY2V9PntjaGlsZH08L1N0YWNrSXRlbT5cbiAgICAgICl9XG4gICAgPC9TdGFja0NvbnRhaW5lcj5cbiAgKTtcbn1cblxuU3RhY2suZGVmYXVsdFByb3BzID0gZGVmYXVsdFByb3BzO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1DdUIifQ== */"),StackItem=(0,_styled.default)("div",{target:"e1yrutbe1",label:"StackItem"})(({theme,space})=>({...(0,_mediaQueries.mq)({marginTop:[space,theme.variables.size.spacing]}),"&:first-of-type":{marginTop:0},"&:empty":{marginTop:0}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU3RhY2svU3RhY2sudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TdGFjay9TdGFjay50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBmbGF0dGVuQ2hpbGRyZW4gfSBmcm9tIFwiLi4vLi4vc2hhcmVkL2ZsYXR0ZW5DaGlsZHJlblwiO1xuaW1wb3J0IHsgbXEgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuXG5pbXBvcnQgdHlwZSB7IEhvcml6b250YWxBbGlnbm1lbnQsIE1RLCBTcGFjZVNpemVzIH0gZnJvbSBcIi4uLy4uL3R5cGVzXCI7XG5cbmV4cG9ydCB0eXBlIFN0YWNrUHJvcHMgPSB7XG4gIC8qKiBSZXByZXNlbnRzIHRoZSB2ZXJ0aWNhbCBiZXR3ZWVuIHRoZSBTdGFjaydzIGNoaWxkcmVuXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBzcGFjZSwgbWVkaXVtIHNjcmVlbiBzcGFjZSwgbGFyZ2Ugc2NyZWVuIHNwYWNlXSBvciBvbmUgc3BhY2UgZm9yIGFsbCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNwYWNlPzogTVE8U3BhY2VTaXplcz4gfCBTcGFjZVNpemVzO1xuICAvKiogUmVwcmVzZW50cyBlbGVtZW50cycgaG9yaXpvbnRhbCBhbGlnbm1lbnRcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gYWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIGFsaWduSXRlbXNdIG9yIG9uZSBhbGlnbkl0ZW1zIGZvciBhbGwgc2NyZWVuIHNpemVzXG4gICAqL1xuICBhbGlnbkl0ZW1zPzogTVE8SG9yaXpvbnRhbEFsaWdubWVudD4gfCBIb3Jpem9udGFsQWxpZ25tZW50O1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdEVsZW1lbnQ7XG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuICAvKiogQGlnbm9yZSAqL1xuICBcImRhdGEtZHMtaWRcIj86IHN0cmluZztcbn07XG5cbnR5cGUgU3RhY2tJdGVtUHJvcHMgPSB7XG4gIC8qKiBSZXByZXNlbnRzIHRoZSB2ZXJ0aWNhbCBiZXR3ZWVuIHRoZSBTdGFjaydzIGNoaWxkcmVuXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBzcGFjZSwgbWVkaXVtIHNjcmVlbiBzcGFjZSwgbGFyZ2Ugc2NyZWVuIHNwYWNlXSBvciBvbmUgc3BhY2UgZm9yIGFsbCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNwYWNlPzogTVE8U3BhY2VTaXplcz4gfCBTcGFjZVNpemVzO1xufTtcblxuY29uc3QgZGVmYXVsdFByb3BzOiBQYXJ0aWFsPFN0YWNrUHJvcHM+ID0ge1xuICBzcGFjZTogXCJ4c1wiLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogdW5kZWZpbmVkLFxuICBcImRhdGEtZHMtaWRcIjogXCJTdGFja1wiLFxufTtcblxuY29uc3QgU3RhY2tDb250YWluZXIgPSBzdHlsZWQuZGl2PFN0YWNrUHJvcHM+KCh7IGFsaWduSXRlbXMgfSkgPT4gKHtcbiAgLi4ubXEoe1xuICAgIGFsaWduSXRlbXM6IFtcbiAgICAgIGFsaWduSXRlbXMsXG4gICAgICB7XG4gICAgICAgIGxlZnQ6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICByaWdodDogXCJmbGV4LWVuZFwiLFxuICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgIHNwYWNlQmV0d2VlbjogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gICAgICB9LFxuICAgIF0sXG4gIH0pLFxuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbn0pKTtcblxuY29uc3QgU3RhY2tJdGVtID0gc3R5bGVkLmRpdjxTdGFja0l0ZW1Qcm9wcz4oKHsgdGhlbWUsIHNwYWNlIH0pID0+ICh7XG4gIC4uLm1xKHtcbiAgICBtYXJnaW5Ub3A6IFtzcGFjZSwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gIH0pLFxuICBcIiY6Zmlyc3Qtb2YtdHlwZVwiOiB7XG4gICAgbWFyZ2luVG9wOiAwLFxuICB9LFxuICBcIiY6ZW1wdHlcIjoge1xuICAgIG1hcmdpblRvcDogMCxcbiAgfSxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFN0YWNrKHtcbiAgY2hpbGRyZW4sXG4gIHNwYWNlLFxuICBhbGlnbkl0ZW1zLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgXCJkYXRhLWRzLWlkXCI6IGRhdGFEc0lkLFxufTogU3RhY2tQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN0YWNrQ29udGFpbmVyXG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgZGF0YS1kcy1pZD17ZGF0YURzSWR9XG4gICAgICBhbGlnbkl0ZW1zPXthbGlnbkl0ZW1zfVxuICAgID5cbiAgICAgIHtSZWFjdC5DaGlsZHJlbi5tYXAoXG4gICAgICAgIGZsYXR0ZW5DaGlsZHJlbihjaGlsZHJlbiksXG4gICAgICAgIChjaGlsZCkgPT4gY2hpbGQgJiYgPFN0YWNrSXRlbSBzcGFjZT17c3BhY2V9PntjaGlsZH08L1N0YWNrSXRlbT5cbiAgICAgICl9XG4gICAgPC9TdGFja0NvbnRhaW5lcj5cbiAgKTtcbn1cblxuU3RhY2suZGVmYXVsdFByb3BzID0gZGVmYXVsdFByb3BzO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Ea0IifQ== */");function Stack({children,space,alignItems,"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId}){return _react.default.createElement(StackContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,alignItems:alignItems},_react.default.Children.map((0,_flattenChildren.flattenChildren)(children),child=>child&&_react.default.createElement(StackItem,{space:space},child)))}Stack.defaultProps={space:"xs","data-e2e-test-id":void 0,"data-ds-id":"Stack"};
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Stack",{enumerable:!0,get:function(){return Stack}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=_interop_require_default._(require("react")),_styled=_interop_require_default._(require("@emotion/styled")),_flattenChildren=require("../../shared/flattenChildren"),_mediaQueries=require("../../shared/mediaQueries"),StackContainer=(0,_styled.default)("div",{target:"epibvxs0",label:"StackContainer"})(({alignItems,vAlignItems,height})=>({...(0,_mediaQueries.mq)({justifyContent:[vAlignItems,{top:"flex-start",bottom:"flex-end",center:"center",spaceBetween:"space-between"}],alignItems:[alignItems,{left:"flex-start",right:"flex-end",center:"center",stretch:"stretch"}]}),display:"flex",flexDirection:"column",height}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU3RhY2svU3RhY2sudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TdGFjay9TdGFjay50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFByb3BlcnR5IH0gZnJvbSBcImNzc3R5cGVcIjtcbmltcG9ydCB7IGZsYXR0ZW5DaGlsZHJlbiB9IGZyb20gXCIuLi8uLi9zaGFyZWQvZmxhdHRlbkNoaWxkcmVuXCI7XG5pbXBvcnQgeyBtcSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmltcG9ydCB0eXBlIHtcbiAgU3RhY2tIb3Jpem9udGFsQWxpZ25tZW50LFxuICBNUSxcbiAgU3BhY2VTaXplcyxcbiAgU3RhY2tWZXJ0aWNhbEFsaWdubWVudCxcbn0gZnJvbSBcIi4uLy4uL3R5cGVzXCI7XG5cbmV4cG9ydCB0eXBlIFN0YWNrUHJvcHMgPSB7XG4gIC8qKiBSZXByZXNlbnRzIHRoZSB2ZXJ0aWNhbCBiZXR3ZWVuIHRoZSBTdGFjaydzIGNoaWxkcmVuXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBzcGFjZSwgbWVkaXVtIHNjcmVlbiBzcGFjZSwgbGFyZ2Ugc2NyZWVuIHNwYWNlXSBvciBvbmUgc3BhY2UgZm9yIGFsbCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNwYWNlPzogTVE8U3BhY2VTaXplcz4gfCBTcGFjZVNpemVzO1xuICAvKiogUmVwcmVzZW50cyBlbGVtZW50cycgaG9yaXpvbnRhbCBhbGlnbm1lbnRcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gYWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIGFsaWduSXRlbXNdIG9yIG9uZSBhbGlnbkl0ZW1zIGZvciBhbGwgc2NyZWVuIHNpemVzXG4gICAqL1xuICBhbGlnbkl0ZW1zPzogTVE8U3RhY2tIb3Jpem9udGFsQWxpZ25tZW50PiB8IFN0YWNrSG9yaXpvbnRhbEFsaWdubWVudDtcblxuICAvKipcbiAgICogUmVwcmVzZW50cyBlbGVtZW50cycgdmVydGljYWwgYWxpZ25tZW50XG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiB2QWxpZ25JdGVtcywgbWVkaXVtIHNjcmVlbiB2QWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIHZBbGlnbkl0ZW1zXSBvciBvbmUgYWxpZ25JdGVtcyBmb3IgYWxsIHNjcmVlbiBzaXplc1xuICAgKi9cbiAgdkFsaWduSXRlbXM/OiBNUTxTdGFja1ZlcnRpY2FsQWxpZ25tZW50PiB8IFN0YWNrVmVydGljYWxBbGlnbm1lbnQ7XG5cbiAgLyoqIGhlaWdodCAqL1xuICBoZWlnaHQ/OiBQcm9wZXJ0eS5IZWlnaHQ7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVbXSB8IFJlYWN0LlJlYWN0RWxlbWVudDtcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIC8qKiBAaWdub3JlICovXG4gIFwiZGF0YS1kcy1pZFwiPzogc3RyaW5nO1xufTtcblxudHlwZSBTdGFja0l0ZW1Qcm9wcyA9IHtcbiAgLyoqIFJlcHJlc2VudHMgdGhlIHZlcnRpY2FsIGJldHdlZW4gdGhlIFN0YWNrJ3MgY2hpbGRyZW5cbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIHNwYWNlLCBtZWRpdW0gc2NyZWVuIHNwYWNlLCBsYXJnZSBzY3JlZW4gc3BhY2VdIG9yIG9uZSBzcGFjZSBmb3IgYWxsIHNjcmVlbiBzaXplc1xuICAgKi9cbiAgc3BhY2U/OiBNUTxTcGFjZVNpemVzPiB8IFNwYWNlU2l6ZXM7XG59O1xuXG5jb25zdCBkZWZhdWx0UHJvcHM6IFBhcnRpYWw8U3RhY2tQcm9wcz4gPSB7XG4gIHNwYWNlOiBcInhzXCIsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiB1bmRlZmluZWQsXG4gIFwiZGF0YS1kcy1pZFwiOiBcIlN0YWNrXCIsXG59O1xuXG5jb25zdCBTdGFja0NvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3RhY2tQcm9wcz4oXG4gICh7IGFsaWduSXRlbXMsIHZBbGlnbkl0ZW1zLCBoZWlnaHQgfSkgPT4gKHtcbiAgICAuLi5tcSh7XG4gICAgICBqdXN0aWZ5Q29udGVudDogW1xuICAgICAgICB2QWxpZ25JdGVtcyxcbiAgICAgICAge1xuICAgICAgICAgIHRvcDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgYm90dG9tOiBcImZsZXgtZW5kXCIsXG4gICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIHNwYWNlQmV0d2VlbjogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgICAgYWxpZ25JdGVtczogW1xuICAgICAgICBhbGlnbkl0ZW1zLFxuICAgICAgICB7XG4gICAgICAgICAgbGVmdDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgcmlnaHQ6IFwiZmxleC1lbmRcIixcbiAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgc3RyZXRjaDogXCJzdHJldGNoXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH0pLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gICAgaGVpZ2h0LFxuICB9KVxuKTtcblxuY29uc3QgU3RhY2tJdGVtID0gc3R5bGVkLmRpdjxTdGFja0l0ZW1Qcm9wcz4oKHsgdGhlbWUsIHNwYWNlIH0pID0+ICh7XG4gIC4uLm1xKHtcbiAgICBtYXJnaW5Ub3A6IFtzcGFjZSwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gIH0pLFxuICBcIiY6Zmlyc3Qtb2YtdHlwZVwiOiB7XG4gICAgbWFyZ2luVG9wOiAwLFxuICB9LFxuICBcIiY6ZW1wdHlcIjoge1xuICAgIG1hcmdpblRvcDogMCxcbiAgfSxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFN0YWNrKHtcbiAgY2hpbGRyZW4sXG4gIHNwYWNlLFxuICBhbGlnbkl0ZW1zLFxuICB2QWxpZ25JdGVtcyxcbiAgaGVpZ2h0LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgXCJkYXRhLWRzLWlkXCI6IGRhdGFEc0lkLFxufTogU3RhY2tQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN0YWNrQ29udGFpbmVyXG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgZGF0YS1kcy1pZD17ZGF0YURzSWR9XG4gICAgICBhbGlnbkl0ZW1zPXthbGlnbkl0ZW1zfVxuICAgICAgdkFsaWduSXRlbXM9e3ZBbGlnbkl0ZW1zfVxuICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgPlxuICAgICAge1JlYWN0LkNoaWxkcmVuLm1hcChcbiAgICAgICAgZmxhdHRlbkNoaWxkcmVuKGNoaWxkcmVuKSxcbiAgICAgICAgKGNoaWxkKSA9PiBjaGlsZCAmJiA8U3RhY2tJdGVtIHNwYWNlPXtzcGFjZX0+e2NoaWxkfTwvU3RhY2tJdGVtPlxuICAgICAgKX1cbiAgICA8L1N0YWNrQ29udGFpbmVyPlxuICApO1xufVxuXG5TdGFjay5kZWZhdWx0UHJvcHMgPSBkZWZhdWx0UHJvcHM7XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0R1QiJ9 */"),StackItem=(0,_styled.default)("div",{target:"epibvxs1",label:"StackItem"})(({theme,space})=>({...(0,_mediaQueries.mq)({marginTop:[space,theme.variables.size.spacing]}),"&:first-of-type":{marginTop:0},"&:empty":{marginTop:0}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU3RhY2svU3RhY2sudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TdGFjay9TdGFjay50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFByb3BlcnR5IH0gZnJvbSBcImNzc3R5cGVcIjtcbmltcG9ydCB7IGZsYXR0ZW5DaGlsZHJlbiB9IGZyb20gXCIuLi8uLi9zaGFyZWQvZmxhdHRlbkNoaWxkcmVuXCI7XG5pbXBvcnQgeyBtcSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmltcG9ydCB0eXBlIHtcbiAgU3RhY2tIb3Jpem9udGFsQWxpZ25tZW50LFxuICBNUSxcbiAgU3BhY2VTaXplcyxcbiAgU3RhY2tWZXJ0aWNhbEFsaWdubWVudCxcbn0gZnJvbSBcIi4uLy4uL3R5cGVzXCI7XG5cbmV4cG9ydCB0eXBlIFN0YWNrUHJvcHMgPSB7XG4gIC8qKiBSZXByZXNlbnRzIHRoZSB2ZXJ0aWNhbCBiZXR3ZWVuIHRoZSBTdGFjaydzIGNoaWxkcmVuXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBzcGFjZSwgbWVkaXVtIHNjcmVlbiBzcGFjZSwgbGFyZ2Ugc2NyZWVuIHNwYWNlXSBvciBvbmUgc3BhY2UgZm9yIGFsbCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNwYWNlPzogTVE8U3BhY2VTaXplcz4gfCBTcGFjZVNpemVzO1xuICAvKiogUmVwcmVzZW50cyBlbGVtZW50cycgaG9yaXpvbnRhbCBhbGlnbm1lbnRcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gYWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIGFsaWduSXRlbXNdIG9yIG9uZSBhbGlnbkl0ZW1zIGZvciBhbGwgc2NyZWVuIHNpemVzXG4gICAqL1xuICBhbGlnbkl0ZW1zPzogTVE8U3RhY2tIb3Jpem9udGFsQWxpZ25tZW50PiB8IFN0YWNrSG9yaXpvbnRhbEFsaWdubWVudDtcblxuICAvKipcbiAgICogUmVwcmVzZW50cyBlbGVtZW50cycgdmVydGljYWwgYWxpZ25tZW50XG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiB2QWxpZ25JdGVtcywgbWVkaXVtIHNjcmVlbiB2QWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIHZBbGlnbkl0ZW1zXSBvciBvbmUgYWxpZ25JdGVtcyBmb3IgYWxsIHNjcmVlbiBzaXplc1xuICAgKi9cbiAgdkFsaWduSXRlbXM/OiBNUTxTdGFja1ZlcnRpY2FsQWxpZ25tZW50PiB8IFN0YWNrVmVydGljYWxBbGlnbm1lbnQ7XG5cbiAgLyoqIGhlaWdodCAqL1xuICBoZWlnaHQ/OiBQcm9wZXJ0eS5IZWlnaHQ7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVbXSB8IFJlYWN0LlJlYWN0RWxlbWVudDtcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIC8qKiBAaWdub3JlICovXG4gIFwiZGF0YS1kcy1pZFwiPzogc3RyaW5nO1xufTtcblxudHlwZSBTdGFja0l0ZW1Qcm9wcyA9IHtcbiAgLyoqIFJlcHJlc2VudHMgdGhlIHZlcnRpY2FsIGJldHdlZW4gdGhlIFN0YWNrJ3MgY2hpbGRyZW5cbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIHNwYWNlLCBtZWRpdW0gc2NyZWVuIHNwYWNlLCBsYXJnZSBzY3JlZW4gc3BhY2VdIG9yIG9uZSBzcGFjZSBmb3IgYWxsIHNjcmVlbiBzaXplc1xuICAgKi9cbiAgc3BhY2U/OiBNUTxTcGFjZVNpemVzPiB8IFNwYWNlU2l6ZXM7XG59O1xuXG5jb25zdCBkZWZhdWx0UHJvcHM6IFBhcnRpYWw8U3RhY2tQcm9wcz4gPSB7XG4gIHNwYWNlOiBcInhzXCIsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiB1bmRlZmluZWQsXG4gIFwiZGF0YS1kcy1pZFwiOiBcIlN0YWNrXCIsXG59O1xuXG5jb25zdCBTdGFja0NvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3RhY2tQcm9wcz4oXG4gICh7IGFsaWduSXRlbXMsIHZBbGlnbkl0ZW1zLCBoZWlnaHQgfSkgPT4gKHtcbiAgICAuLi5tcSh7XG4gICAgICBqdXN0aWZ5Q29udGVudDogW1xuICAgICAgICB2QWxpZ25JdGVtcyxcbiAgICAgICAge1xuICAgICAgICAgIHRvcDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgYm90dG9tOiBcImZsZXgtZW5kXCIsXG4gICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIHNwYWNlQmV0d2VlbjogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgICAgYWxpZ25JdGVtczogW1xuICAgICAgICBhbGlnbkl0ZW1zLFxuICAgICAgICB7XG4gICAgICAgICAgbGVmdDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgcmlnaHQ6IFwiZmxleC1lbmRcIixcbiAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgc3RyZXRjaDogXCJzdHJldGNoXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH0pLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gICAgaGVpZ2h0LFxuICB9KVxuKTtcblxuY29uc3QgU3RhY2tJdGVtID0gc3R5bGVkLmRpdjxTdGFja0l0ZW1Qcm9wcz4oKHsgdGhlbWUsIHNwYWNlIH0pID0+ICh7XG4gIC4uLm1xKHtcbiAgICBtYXJnaW5Ub3A6IFtzcGFjZSwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gIH0pLFxuICBcIiY6Zmlyc3Qtb2YtdHlwZVwiOiB7XG4gICAgbWFyZ2luVG9wOiAwLFxuICB9LFxuICBcIiY6ZW1wdHlcIjoge1xuICAgIG1hcmdpblRvcDogMCxcbiAgfSxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFN0YWNrKHtcbiAgY2hpbGRyZW4sXG4gIHNwYWNlLFxuICBhbGlnbkl0ZW1zLFxuICB2QWxpZ25JdGVtcyxcbiAgaGVpZ2h0LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgXCJkYXRhLWRzLWlkXCI6IGRhdGFEc0lkLFxufTogU3RhY2tQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN0YWNrQ29udGFpbmVyXG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgZGF0YS1kcy1pZD17ZGF0YURzSWR9XG4gICAgICBhbGlnbkl0ZW1zPXthbGlnbkl0ZW1zfVxuICAgICAgdkFsaWduSXRlbXM9e3ZBbGlnbkl0ZW1zfVxuICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgPlxuICAgICAge1JlYWN0LkNoaWxkcmVuLm1hcChcbiAgICAgICAgZmxhdHRlbkNoaWxkcmVuKGNoaWxkcmVuKSxcbiAgICAgICAgKGNoaWxkKSA9PiBjaGlsZCAmJiA8U3RhY2tJdGVtIHNwYWNlPXtzcGFjZX0+e2NoaWxkfTwvU3RhY2tJdGVtPlxuICAgICAgKX1cbiAgICA8L1N0YWNrQ29udGFpbmVyPlxuICApO1xufVxuXG5TdGFjay5kZWZhdWx0UHJvcHMgPSBkZWZhdWx0UHJvcHM7XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEVrQiJ9 */");function Stack({children,space,alignItems,vAlignItems,height,"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId}){return _react.default.createElement(StackContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,alignItems:alignItems,vAlignItems:vAlignItems,height:height},_react.default.Children.map((0,_flattenChildren.flattenChildren)(children),child=>child&&_react.default.createElement(StackItem,{space:space},child)))}Stack.defaultProps={space:"xs","data-e2e-test-id":void 0,"data-ds-id":"Stack"};
@@ -1,9 +1,9 @@
1
- import type { ColumnSizes, HorizontalAlignment, MQ, SpaceSizes, TextAlignment, VerticalAlignment, Order, ColumnAlignment, Hyphens } from "../types";
1
+ import type { ColumnSizes, HorizontalAlignment, MQ, SpaceSizes, TextAlignment, VerticalAlignment, StackHorizontalAlignment, StackVerticalAlignment, Order, ColumnAlignment, Hyphens } from "../types";
2
2
  type MqProp<T> = [
3
3
  T | MQ<T>,
4
4
  Record<T extends string ? T : never, string | number>
5
5
  ];
6
- type MqRules = Record<string, MqProp<TextAlignment> | MqProp<SpaceSizes> | MqProp<HorizontalAlignment> | MqProp<VerticalAlignment> | MqProp<ColumnSizes> | MqProp<Order> | MqProp<ColumnAlignment> | MqProp<Hyphens>>;
6
+ type MqRules = Record<string, MqProp<TextAlignment> | MqProp<SpaceSizes> | MqProp<HorizontalAlignment> | MqProp<VerticalAlignment> | MqProp<StackHorizontalAlignment> | MqProp<StackVerticalAlignment> | MqProp<ColumnSizes> | MqProp<Order> | MqProp<ColumnAlignment> | MqProp<Hyphens>>;
7
7
  type EmotionCssPropertyName = string;
8
8
  type EmotionCssValue = string | number;
9
9
  type EmotionCssDescription = Record<EmotionCssPropertyName, EmotionCssValue>;
@@ -13,7 +13,11 @@ export declare const HorizontalAlignmentRuntype: Union<[Literal<"left">, Literal
13
13
  export type HorizontalAlignment = Static<typeof HorizontalAlignmentRuntype>;
14
14
  export declare const VerticalAlignmentRuntype: Union<[Literal<"top">, Literal<"bottom">, Literal<"center">, Literal<"stretch">]>;
15
15
  export type VerticalAlignment = Static<typeof VerticalAlignmentRuntype>;
16
- export declare const SpaceSizesRuntype: Union<[Literal<"zero">, Literal<"xxs">, Literal<"xs">, Literal<"s">, Literal<"m">, Literal<"l">, Literal<"xl">, Literal<"xxl">]>;
16
+ export declare const StackVerticalAlignmentRuntype: Union<[Literal<"top">, Literal<"bottom">, Literal<"center">, Literal<"spaceBetween">]>;
17
+ export type StackVerticalAlignment = Static<typeof StackVerticalAlignmentRuntype>;
18
+ export declare const StackHorizontalAlignmentRuntype: Union<[Literal<"left">, Literal<"right">, Literal<"center">, Literal<"stretch">]>;
19
+ export type StackHorizontalAlignment = Static<typeof StackHorizontalAlignmentRuntype>;
20
+ export declare const SpaceSizesRuntype: Union<[Literal<"zero">, Literal<"xxxs">, Literal<"xxs">, Literal<"xs">, Literal<"s">, Literal<"m">, Literal<"l">, Literal<"xl">, Literal<"xxl">]>;
17
21
  export type SpaceSizes = Static<typeof SpaceSizesRuntype>;
18
22
  export declare const ColumsSizesRuntype: Union<[Literal<1>, Literal<2>, Literal<3>, Literal<4>, Literal<5>, Literal<6>, Literal<7>, Literal<8>, Literal<9>, Literal<10>, Literal<11>, Literal<12>, Literal<"auto">, Literal<"narrow">, Literal<"fill">]>;
19
23
  export type ColumnSizes = Static<typeof ColumsSizesRuntype>;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),function(target,all){for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:all[name]})}(exports,{BaseColorsRuntype:function(){return BaseColorsRuntype},BaseVariationsRuntype:function(){return BaseVariationsRuntype},BorderRadiusRuntype:function(){return BorderRadiusRuntype},ColumnAlignmentRunType:function(){return ColumnAlignmentRunType},ColumsSizesRuntype:function(){return ColumsSizesRuntype},HorizontalAlignmentRuntype:function(){return HorizontalAlignmentRuntype},HyphensRuntype:function(){return HyphensRuntype},LinkTextSizeRuntype:function(){return LinkTextSizeRuntype},OrderRuntype:function(){return OrderRuntype},SpaceSizesRuntype:function(){return SpaceSizesRuntype},TextAlignmentRuntype:function(){return TextAlignmentRuntype},TextSizeRuntype:function(){return TextSizeRuntype},ToggleSizeRuntype:function(){return ToggleSizeRuntype},VerticalAlignmentRuntype:function(){return VerticalAlignmentRuntype}});const _runtypes=require("runtypes"),LinkTextSizeRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("xs"),(0,_runtypes.Literal)("s"),(0,_runtypes.Literal)("m"),(0,_runtypes.Literal)("l")),TextSizeRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("xs"),(0,_runtypes.Literal)("s"),(0,_runtypes.Literal)("m")),BorderRadiusRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("xs"),(0,_runtypes.Literal)("s"),(0,_runtypes.Literal)("m")),TextAlignmentRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("left"),(0,_runtypes.Literal)("right"),(0,_runtypes.Literal)("center")),HorizontalAlignmentRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("left"),(0,_runtypes.Literal)("right"),(0,_runtypes.Literal)("center"),(0,_runtypes.Literal)("spaceBetween")),VerticalAlignmentRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("top"),(0,_runtypes.Literal)("bottom"),(0,_runtypes.Literal)("center"),(0,_runtypes.Literal)("stretch")),SpaceSizesRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("zero"),(0,_runtypes.Literal)("xxs"),(0,_runtypes.Literal)("xs"),(0,_runtypes.Literal)("s"),(0,_runtypes.Literal)("m"),(0,_runtypes.Literal)("l"),(0,_runtypes.Literal)("xl"),(0,_runtypes.Literal)("xxl")),ColumsSizesRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)(1),(0,_runtypes.Literal)(2),(0,_runtypes.Literal)(3),(0,_runtypes.Literal)(4),(0,_runtypes.Literal)(5),(0,_runtypes.Literal)(6),(0,_runtypes.Literal)(7),(0,_runtypes.Literal)(8),(0,_runtypes.Literal)(9),(0,_runtypes.Literal)(10),(0,_runtypes.Literal)(11),(0,_runtypes.Literal)(12),(0,_runtypes.Literal)("auto"),(0,_runtypes.Literal)("narrow"),(0,_runtypes.Literal)("fill")),ColumnAlignmentRunType=(0,_runtypes.Union)((0,_runtypes.Literal)("auto"),(0,_runtypes.Literal)("start"),(0,_runtypes.Literal)("center"),(0,_runtypes.Literal)("end")),OrderRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("first"),(0,_runtypes.Literal)("last"),(0,_runtypes.Literal)("unset")),BaseVariationsRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("primary"),(0,_runtypes.Literal)("secondary"),(0,_runtypes.Literal)("tertiary")),BaseColorsRuntype=(0,_runtypes.Union)(BaseVariationsRuntype,(0,_runtypes.Literal)("accent"));(0,_runtypes.Union)(BaseColorsRuntype,(0,_runtypes.Literal)("success"),(0,_runtypes.Literal)("info"),(0,_runtypes.Literal)("error"),(0,_runtypes.Literal)("warning")),(0,_runtypes.Union)(BaseVariationsRuntype,(0,_runtypes.Literal)("success"),(0,_runtypes.Literal)("info"),(0,_runtypes.Literal)("error"),(0,_runtypes.Literal)("warning")),(0,_runtypes.Union)((0,_runtypes.Literal)("normal"),(0,_runtypes.Literal)("bold"),(0,_runtypes.Literal)("black"),(0,_runtypes.Literal)("inherit")),(0,_runtypes.Union)(BaseColorsRuntype,(0,_runtypes.Literal)("success"),(0,_runtypes.Literal)("info"),(0,_runtypes.Literal)("error"),(0,_runtypes.Literal)("warning"),(0,_runtypes.Literal)("inherit"),(0,_runtypes.Literal)("brand"),(0,_runtypes.Literal)("quaternary")),(0,_runtypes.Union)(BaseVariationsRuntype,(0,_runtypes.Literal)("success"),(0,_runtypes.Literal)("info"),(0,_runtypes.Literal)("error"),(0,_runtypes.Literal)("warning"),(0,_runtypes.Literal)("inherit"),(0,_runtypes.Literal)("brand")),(0,_runtypes.Union)((0,_runtypes.Literal)("info"),(0,_runtypes.Literal)("success"),(0,_runtypes.Literal)("error"),(0,_runtypes.Literal)("warning")),(0,_runtypes.Union)(BaseVariationsRuntype),(0,_runtypes.Union)(BaseColorsRuntype),(0,_runtypes.Union)((0,_runtypes.Literal)("s"),(0,_runtypes.Literal)("m"),(0,_runtypes.Literal)("l"));const HyphensRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("auto"),(0,_runtypes.Literal)("none"),(0,_runtypes.Literal)("manual")),ToggleSizeRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("s"),(0,_runtypes.Literal)("m"));
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),function(target,all){for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:all[name]})}(exports,{BaseColorsRuntype:function(){return BaseColorsRuntype},BaseVariationsRuntype:function(){return BaseVariationsRuntype},BorderRadiusRuntype:function(){return BorderRadiusRuntype},ColumnAlignmentRunType:function(){return ColumnAlignmentRunType},ColumsSizesRuntype:function(){return ColumsSizesRuntype},HorizontalAlignmentRuntype:function(){return HorizontalAlignmentRuntype},HyphensRuntype:function(){return HyphensRuntype},LinkTextSizeRuntype:function(){return LinkTextSizeRuntype},OrderRuntype:function(){return OrderRuntype},SpaceSizesRuntype:function(){return SpaceSizesRuntype},StackHorizontalAlignmentRuntype:function(){return StackHorizontalAlignmentRuntype},StackVerticalAlignmentRuntype:function(){return StackVerticalAlignmentRuntype},TextAlignmentRuntype:function(){return TextAlignmentRuntype},TextSizeRuntype:function(){return TextSizeRuntype},ToggleSizeRuntype:function(){return ToggleSizeRuntype},VerticalAlignmentRuntype:function(){return VerticalAlignmentRuntype}});const _runtypes=require("runtypes"),LinkTextSizeRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("xs"),(0,_runtypes.Literal)("s"),(0,_runtypes.Literal)("m"),(0,_runtypes.Literal)("l")),TextSizeRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("xs"),(0,_runtypes.Literal)("s"),(0,_runtypes.Literal)("m")),BorderRadiusRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("xs"),(0,_runtypes.Literal)("s"),(0,_runtypes.Literal)("m")),TextAlignmentRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("left"),(0,_runtypes.Literal)("right"),(0,_runtypes.Literal)("center")),HorizontalAlignmentRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("left"),(0,_runtypes.Literal)("right"),(0,_runtypes.Literal)("center"),(0,_runtypes.Literal)("spaceBetween")),VerticalAlignmentRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("top"),(0,_runtypes.Literal)("bottom"),(0,_runtypes.Literal)("center"),(0,_runtypes.Literal)("stretch")),StackVerticalAlignmentRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("top"),(0,_runtypes.Literal)("bottom"),(0,_runtypes.Literal)("center"),(0,_runtypes.Literal)("spaceBetween")),StackHorizontalAlignmentRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("left"),(0,_runtypes.Literal)("right"),(0,_runtypes.Literal)("center"),(0,_runtypes.Literal)("stretch")),SpaceSizesRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("zero"),(0,_runtypes.Literal)("xxxs"),(0,_runtypes.Literal)("xxs"),(0,_runtypes.Literal)("xs"),(0,_runtypes.Literal)("s"),(0,_runtypes.Literal)("m"),(0,_runtypes.Literal)("l"),(0,_runtypes.Literal)("xl"),(0,_runtypes.Literal)("xxl")),ColumsSizesRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)(1),(0,_runtypes.Literal)(2),(0,_runtypes.Literal)(3),(0,_runtypes.Literal)(4),(0,_runtypes.Literal)(5),(0,_runtypes.Literal)(6),(0,_runtypes.Literal)(7),(0,_runtypes.Literal)(8),(0,_runtypes.Literal)(9),(0,_runtypes.Literal)(10),(0,_runtypes.Literal)(11),(0,_runtypes.Literal)(12),(0,_runtypes.Literal)("auto"),(0,_runtypes.Literal)("narrow"),(0,_runtypes.Literal)("fill")),ColumnAlignmentRunType=(0,_runtypes.Union)((0,_runtypes.Literal)("auto"),(0,_runtypes.Literal)("start"),(0,_runtypes.Literal)("center"),(0,_runtypes.Literal)("end")),OrderRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("first"),(0,_runtypes.Literal)("last"),(0,_runtypes.Literal)("unset")),BaseVariationsRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("primary"),(0,_runtypes.Literal)("secondary"),(0,_runtypes.Literal)("tertiary")),BaseColorsRuntype=(0,_runtypes.Union)(BaseVariationsRuntype,(0,_runtypes.Literal)("accent"));(0,_runtypes.Union)(BaseColorsRuntype,(0,_runtypes.Literal)("success"),(0,_runtypes.Literal)("info"),(0,_runtypes.Literal)("error"),(0,_runtypes.Literal)("warning")),(0,_runtypes.Union)(BaseVariationsRuntype,(0,_runtypes.Literal)("success"),(0,_runtypes.Literal)("info"),(0,_runtypes.Literal)("error"),(0,_runtypes.Literal)("warning")),(0,_runtypes.Union)((0,_runtypes.Literal)("normal"),(0,_runtypes.Literal)("bold"),(0,_runtypes.Literal)("black"),(0,_runtypes.Literal)("inherit")),(0,_runtypes.Union)(BaseColorsRuntype,(0,_runtypes.Literal)("success"),(0,_runtypes.Literal)("info"),(0,_runtypes.Literal)("error"),(0,_runtypes.Literal)("warning"),(0,_runtypes.Literal)("inherit"),(0,_runtypes.Literal)("brand"),(0,_runtypes.Literal)("quaternary")),(0,_runtypes.Union)(BaseVariationsRuntype,(0,_runtypes.Literal)("success"),(0,_runtypes.Literal)("info"),(0,_runtypes.Literal)("error"),(0,_runtypes.Literal)("warning"),(0,_runtypes.Literal)("inherit"),(0,_runtypes.Literal)("brand")),(0,_runtypes.Union)((0,_runtypes.Literal)("info"),(0,_runtypes.Literal)("success"),(0,_runtypes.Literal)("error"),(0,_runtypes.Literal)("warning")),(0,_runtypes.Union)(BaseVariationsRuntype),(0,_runtypes.Union)(BaseColorsRuntype),(0,_runtypes.Union)((0,_runtypes.Literal)("s"),(0,_runtypes.Literal)("m"),(0,_runtypes.Literal)("l"));const HyphensRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("auto"),(0,_runtypes.Literal)("none"),(0,_runtypes.Literal)("manual")),ToggleSizeRuntype=(0,_runtypes.Union)((0,_runtypes.Literal)("s"),(0,_runtypes.Literal)("m"));
@@ -1,14 +1,20 @@
1
1
  import React from "react";
2
- import type { MQ, SpaceSizes } from "../../../types";
2
+ import type { MQ, SpaceSizes, ButtonSize } from "../../../types";
3
3
  import type { ButtonProps } from "../../Button/Button";
4
- export type ActionButtonProps = {
4
+ export type ButtonGroupButtonProps = {
5
5
  text: string;
6
6
  } & ButtonProps;
7
7
  export type ButtonGroupProps = {
8
- actionButton?: ActionButtonProps;
8
+ /** Text and other props for action Button */
9
+ actionButton?: ButtonGroupButtonProps;
10
+ /** Text and other props for cancel Button */
11
+ secondaryButton?: ButtonGroupButtonProps;
12
+ /** @deprecated Use secondaryButton to pass in text and other props for cancel button */
9
13
  cancelButtonText?: string;
10
14
  onButtonClick?: (action: "cancel" | "action") => void;
11
15
  space?: MQ<SpaceSizes> | SpaceSizes;
16
+ /** Action and Cancel button size */
17
+ buttonSize?: ButtonSize;
12
18
  "data-e2e-test-id"?: string;
13
19
  };
14
- export declare function ButtonGroup({ cancelButtonText, actionButton, onButtonClick, "data-e2e-test-id": dataE2eTestId, }: ButtonGroupProps): React.ReactElement;
20
+ export declare function ButtonGroup({ cancelButtonText, actionButton, secondaryButton, buttonSize, onButtonClick, "data-e2e-test-id": dataE2eTestId, }: ButtonGroupProps): React.ReactElement;
@@ -1 +1 @@
1
- import React from"react";import{Columns,Column}from"../../Column/Columns";import{Button}from"../../Button/Button";export function ButtonGroup({cancelButtonText,actionButton,onButtonClick,"data-e2e-test-id":dataE2eTestId}){let{text,...rest}=actionButton;return React.createElement(Columns,{gap:"s",alignItems:["spaceBetween","right"],"data-e2e-test-id":dataE2eTestId,"data-ds-id":"ButtonGroup"},actionButton&&React.createElement(Column,{order:["first","last"],size:[12,"narrow"]},React.createElement(Button,{variant:"primary",fullWidth:!0,onClick:()=>{onButtonClick("action")},...rest},text)),cancelButtonText&&React.createElement(Column,{size:[12,"narrow"]},React.createElement(Button,{variant:"secondary",fullWidth:!0,onClick:()=>{onButtonClick("cancel")}},cancelButtonText)))}
1
+ import React from"react";import{Columns,Column}from"../../Column/Columns";import{Button}from"../../Button/Button";let BUTTONSIZE_GAP_MAP={s:"xs",m:"s",l:"m"};export function ButtonGroup({cancelButtonText,actionButton,secondaryButton,buttonSize="m",onButtonClick,"data-e2e-test-id":dataE2eTestId}){let{text:actionButtonText,...actionButtonProps}=actionButton,{text,...secondaryButtonProps}=secondaryButton||{},hasSecondaryButton=cancelButtonText||secondaryButton,secondaryButtonLabel=secondaryButton?text:cancelButtonText,gap=BUTTONSIZE_GAP_MAP[buttonSize];return actionButton||hasSecondaryButton?React.createElement(Columns,{gap:gap,alignItems:["spaceBetween","right"],"data-e2e-test-id":dataE2eTestId,"data-ds-id":"ButtonGroup"},actionButton&&React.createElement(Column,{order:["first","last"],size:[12,"narrow"]},React.createElement(Button,{onClick:()=>{onButtonClick&&onButtonClick("action")},...actionButtonProps,fullWidth:!0,variant:"primary",size:buttonSize},actionButtonText)),hasSecondaryButton&&React.createElement(Column,{size:[12,"narrow"]},React.createElement(Button,{onClick:()=>{onButtonClick&&onButtonClick("cancel")},...secondaryButtonProps,fullWidth:!0,variant:"secondary",size:buttonSize},secondaryButtonLabel))):null}
@@ -1,6 +1,6 @@
1
1
  import React from "react";
2
2
  import type { StackProps } from "../../Stack/Stack";
3
- import type { ActionButtonProps } from "../ButtonGroup/ButtonGroup";
3
+ import type { ButtonGroupButtonProps } from "../ButtonGroup/ButtonGroup";
4
4
  import type { TextProps } from "../../Typography/Text/Text";
5
5
  type BaseProps = {
6
6
  header: string;
@@ -9,7 +9,11 @@ type BaseProps = {
9
9
  labelHeader?: string;
10
10
  /** The black color is going to be replaced with gray one */
11
11
  subHeader?: string;
12
- actionButton?: ActionButtonProps;
12
+ /** Text and other props for action Button */
13
+ actionButton?: ButtonGroupButtonProps;
14
+ /** Text and other props for action Button */
15
+ secondaryButton?: ButtonGroupButtonProps;
16
+ /** @deprecated Use secondaryButton to pass in text and other props for secondary button */
13
17
  cancelButtonLabel?: string;
14
18
  /** Aim to use <Modal.Text> and <Modal.Stack> */
15
19
  children: React.ReactNode;
@@ -28,7 +32,7 @@ type ConditionalProps = {
28
32
  ImageComponent?: React.ElementType<any>;
29
33
  };
30
34
  export type ModalProps = BaseProps & ConditionalProps;
31
- export declare function Modal({ header, subHeader, labelHeader, children, imageUrl, ImageComponent, cancelButtonLabel, actionButton, role, onAction, privateProps: { skipPortal }, "data-e2e-test-id": dataE2eTestId, }: ModalProps): React.ReactElement;
35
+ export declare function Modal({ header, subHeader, labelHeader, children, imageUrl, ImageComponent, secondaryButton, cancelButtonLabel, actionButton, role, onAction, privateProps: { skipPortal }, "data-e2e-test-id": dataE2eTestId, }: ModalProps): React.ReactElement;
32
36
  export declare namespace Modal {
33
37
  var defaultProps: Partial<ModalProps>;
34
38
  var Stack: ({ children, ...rest }: Omit<StackProps, "space">) => JSX.Element;
@@ -1 +1 @@
1
- import React,{useRef}from"react";import styled from"@emotion/styled";import{Portal}from"../../Portal/Portal";import{H2,H4,H6}from"../../Typography/Header/Header";import{Stack}from"../../Stack/Stack";import{Container}from"../../Container/Container";import{Box}from"../../Box/Box";import{Inline}from"../../Inline/Inline";import{ButtonGroup}from"../ButtonGroup/ButtonGroup";import{Button}from"../../Button/Button";import{Text}from"../../Typography/Text/Text";import{mqValue}from"../../../shared/mediaQueries";import{useOnEscapePress}from"../../../shared/useOnEscapePress";import{useOutsideClick}from"../../../shared/useOutsideClick";let StyledBackdrop=styled("div",{target:"e1ws3sq80",label:"StyledBackdrop"})(({theme})=>({position:"fixed",top:0,left:0,width:"100%",height:"100vh",background:theme.values.color.background.backdrop.default,display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",flex:"1 0 auto"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport type { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  actionButton?: ActionButtonProps;\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"spaceBetween\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: MQ<HorizontalAlignment> | HorizontalAlignment;\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AAsDuB"} */"),StyledModalWrapper=styled("div",{target:"e1ws3sq81",label:"StyledModalWrapper"})(({theme})=>({maxWidth:theme.variables.size.dimension.modal.width,...mqValue({width:[`calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,theme.variables.size.dimension.modal.width]})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport type { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  actionButton?: ActionButtonProps;\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"spaceBetween\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: MQ<HorizontalAlignment> | HorizontalAlignment;\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AAoE2B"} */"),StyledInner=styled("div",{target:"e1ws3sq82",label:"StyledInner"})(()=>({display:"flex",maxHeight:"calc(100vh - 100px)",flexDirection:"column",overflow:"hidden"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport type { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  actionButton?: ActionButtonProps;\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"spaceBetween\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: MQ<HorizontalAlignment> | HorizontalAlignment;\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AA8EoB"} */"),StyledBody=styled("div",{target:"e1ws3sq83",label:"StyledBody"})(()=>({overflowY:"auto",maxHeight:"100%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport type { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  actionButton?: ActionButtonProps;\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"spaceBetween\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: MQ<HorizontalAlignment> | HorizontalAlignment;\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AAqFmB"} */"),StyledImg=styled("img",{target:"e1ws3sq84",label:"StyledImg"})(()=>({width:"100%",aspectRatio:"16/9"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport type { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  actionButton?: ActionButtonProps;\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"spaceBetween\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: MQ<HorizontalAlignment> | HorizontalAlignment;\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AA0FkB"} */"),Footer=({children,alignItems=["spaceBetween","right"]})=>React.createElement(Box,{space:"zero",tSpace:"l"},React.createElement(Stack,{alignItems:alignItems},children)),Wrapper=({skipPortal,children})=>skipPortal?React.createElement(React.Fragment,null,children):React.createElement(Portal,null,React.createElement(StyledBackdrop,null,children)),ButtonClose=({onClick})=>React.createElement(Button,{variant:"tertiary",leftIcon:"x",size:"s",onClick:onClick});export function Modal({header,subHeader,labelHeader,children,imageUrl,ImageComponent,cancelButtonLabel,actionButton,role,onAction,privateProps:{skipPortal},"data-e2e-test-id":dataE2eTestId}){let modalRef=useRef(null),handleClose=()=>{onAction("cancel")};useOutsideClick(modalRef,handleClose,!skipPortal),useOnEscapePress(handleClose,[handleClose]);let hasImage=imageUrl||ImageComponent;return React.createElement(Wrapper,{skipPortal:skipPortal},React.createElement(StyledModalWrapper,{ref:modalRef,role:role,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Modal"},React.createElement(Container,{elevation:4},React.createElement(Box,{space:["m","xl"]},React.createElement(StyledInner,null,React.createElement(Box,{space:"zero",bSpace:"s"},React.createElement(Stack,{space:hasImage?["s","l"]:"zero"},hasImage&&React.createElement(React.Fragment,null,React.createElement(Inline,{alignItems:"right"},React.createElement(ButtonClose,{onClick:handleClose})),imageUrl?React.createElement(StyledImg,{src:imageUrl}):React.createElement(ImageComponent,null)),React.createElement(Inline,{alignItems:"spaceBetween",noWrap:!0},React.createElement(Stack,{space:"xxs"},labelHeader&&React.createElement(H6,null,labelHeader),React.createElement(Stack,{space:"zero"},React.createElement(H2,null,header),subHeader&&React.createElement(H4,{color:"tertiary"},subHeader))),!hasImage&&React.createElement(ButtonClose,{onClick:handleClose})))),React.createElement(StyledBody,null,children),(actionButton||cancelButtonLabel)&&React.createElement(Footer,null,React.createElement(ButtonGroup,{actionButton:actionButton,cancelButtonText:cancelButtonLabel,onButtonClick:onAction})))))))}Modal.defaultProps={role:"dialog","data-e2e-test-id":void 0,privateProps:{skipPortal:!1}},Modal.Stack=({children,...rest})=>React.createElement(Stack,{...rest,space:"m"},children),Modal.Text=({children,...rest})=>React.createElement(Text,{...rest,size:"m",color:"tertiary"},children);
1
+ import React,{useEffect,useRef,useState}from"react";import styled from"@emotion/styled";import{Portal}from"../../Portal/Portal";import{H2,H4,H6}from"../../Typography/Header/Header";import{Stack}from"../../Stack/Stack";import{Container}from"../../Container/Container";import{Box}from"../../Box/Box";import{Inline}from"../../Inline/Inline";import{ButtonGroup}from"../ButtonGroup/ButtonGroup";import{Button}from"../../Button/Button";import{Text}from"../../Typography/Text/Text";import{mqValue}from"../../../shared/mediaQueries";import{useOnEscapePress}from"../../../shared/useOnEscapePress";import{useOutsideClick}from"../../../shared/useOutsideClick";let StyledBackdrop=styled("div",{target:"e1d48alb0",label:"StyledBackdrop"})(({theme})=>({position:"fixed",top:0,left:0,width:"100%",height:"100vh",background:theme.values.color.background.backdrop.default,display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",flex:"1 0 auto"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ButtonGroupButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  /** Text and other props for action Button */\n  actionButton?: ButtonGroupButtonProps;\n  /** Text and other props for action Button */\n  secondaryButton?: ButtonGroupButtonProps;\n  /** @deprecated Use secondaryButton to pass in text and other props for secondary button */\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"stretch\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: StackProps[\"alignItems\"];\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  secondaryButton,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const [isOpening, setOpening] = useState(true);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n\n  useEffect(() => {\n    setOpening(false);\n  }, []);\n\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss && !isOpening);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel || secondaryButton) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    secondaryButton={secondaryButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AAyDuB"} */"),StyledModalWrapper=styled("div",{target:"e1d48alb1",label:"StyledModalWrapper"})(({theme})=>({maxWidth:theme.variables.size.dimension.modal.width,...mqValue({width:[`calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,theme.variables.size.dimension.modal.width]})}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ButtonGroupButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  /** Text and other props for action Button */\n  actionButton?: ButtonGroupButtonProps;\n  /** Text and other props for action Button */\n  secondaryButton?: ButtonGroupButtonProps;\n  /** @deprecated Use secondaryButton to pass in text and other props for secondary button */\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"stretch\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: StackProps[\"alignItems\"];\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  secondaryButton,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const [isOpening, setOpening] = useState(true);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n\n  useEffect(() => {\n    setOpening(false);\n  }, []);\n\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss && !isOpening);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel || secondaryButton) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    secondaryButton={secondaryButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AAuE2B"} */"),StyledInner=styled("div",{target:"e1d48alb2",label:"StyledInner"})(()=>({display:"flex",maxHeight:"calc(100vh - 100px)",flexDirection:"column",overflow:"hidden"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ButtonGroupButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  /** Text and other props for action Button */\n  actionButton?: ButtonGroupButtonProps;\n  /** Text and other props for action Button */\n  secondaryButton?: ButtonGroupButtonProps;\n  /** @deprecated Use secondaryButton to pass in text and other props for secondary button */\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"stretch\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: StackProps[\"alignItems\"];\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  secondaryButton,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const [isOpening, setOpening] = useState(true);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n\n  useEffect(() => {\n    setOpening(false);\n  }, []);\n\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss && !isOpening);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel || secondaryButton) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    secondaryButton={secondaryButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AAiFoB"} */"),StyledBody=styled("div",{target:"e1d48alb3",label:"StyledBody"})(()=>({overflowY:"auto",maxHeight:"100%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ButtonGroupButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  /** Text and other props for action Button */\n  actionButton?: ButtonGroupButtonProps;\n  /** Text and other props for action Button */\n  secondaryButton?: ButtonGroupButtonProps;\n  /** @deprecated Use secondaryButton to pass in text and other props for secondary button */\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"stretch\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: StackProps[\"alignItems\"];\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  secondaryButton,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const [isOpening, setOpening] = useState(true);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n\n  useEffect(() => {\n    setOpening(false);\n  }, []);\n\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss && !isOpening);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel || secondaryButton) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    secondaryButton={secondaryButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AAwFmB"} */"),StyledImg=styled("img",{target:"e1d48alb4",label:"StyledImg"})(()=>({width:"100%",aspectRatio:"16/9"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Patterns/Modal/Modal.tsx","sources":["src/components/Patterns/Modal/Modal.tsx"],"sourcesContent":["import React, { useEffect, useRef, useState } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Portal } from \"../../Portal/Portal\";\nimport { H2, H4, H6 } from \"../../Typography/Header/Header\";\nimport type { StackProps } from \"../../Stack/Stack\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { ButtonGroupButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { ButtonGroup } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\ntype BaseProps = {\n  header: string;\n  onAction: (action: \"cancel\" | \"action\") => void;\n  role?: \"dialog\" | \"alertdialog\";\n  labelHeader?: string;\n  /** The black color is going to be replaced with gray one */\n  subHeader?: string;\n  /** Text and other props for action Button */\n  actionButton?: ButtonGroupButtonProps;\n  /** Text and other props for action Button */\n  secondaryButton?: ButtonGroupButtonProps;\n  /** @deprecated Use secondaryButton to pass in text and other props for secondary button */\n  cancelButtonLabel?: string;\n  /** Aim to use <Modal.Text> and <Modal.Stack> */\n  children: React.ReactNode;\n  \"data-e2e-test-id\"?: string;\n  privateProps?: { skipPortal?: boolean };\n};\n\ntype ConditionalProps =\n  | {\n      /** Aspect ratio 16:9 */\n      imageUrl?: string;\n      ImageComponent?: never;\n    }\n  | {\n      imageUrl?: never;\n      /** Accept ratio 16:9 */\n      ImageComponent?: React.ElementType<any>;\n    };\n\nexport type ModalProps = BaseProps & ConditionalProps;\n\nconst defaultModalProps: Partial<ModalProps> = {\n  role: \"dialog\",\n  \"data-e2e-test-id\": undefined,\n  privateProps: { skipPortal: false },\n};\n\nconst StyledBackdrop = styled.div(({ theme }) => ({\n  position: \"fixed\",\n  top: 0,\n  left: 0,\n  width: \"100%\",\n  height: \"100vh\",\n  background: theme.values.color.background.backdrop.default,\n  display: \"flex\",\n  flexDirection: \"column\",\n  justifyContent: \"center\",\n  alignItems: \"center\",\n  flex: \"1 0 auto\",\n}));\n\nconst StyledModalWrapper = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.width,\n  ...mqValue({\n    width: [\n      `calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`,\n      theme.variables.size.dimension.modal.width,\n    ],\n  }),\n}));\n\nconst StyledInner = styled.div(() => ({\n  display: \"flex\",\n  maxHeight: `calc(100vh - 100px)`,\n  flexDirection: \"column\",\n  overflow: \"hidden\",\n}));\n\nconst StyledBody = styled.div(() => ({\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n}));\n\nconst StyledImg = styled.img(() => ({\n  width: \"100%\",\n  aspectRatio: \"16/9\",\n}));\n\nconst ModalStack = ({ children, ...rest }: Omit<StackProps, \"space\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Stack {...rest} space=\"m\">\n    {children}\n  </Stack>\n);\n\nconst ModalText = ({\n  children,\n  ...rest\n}: Omit<TextProps, \"size\" | \"variant\">) => (\n  // eslint-disable-next-line react/jsx-props-no-spreading\n  <Text {...rest} size=\"m\" color=\"tertiary\">\n    {children}\n  </Text>\n);\n\nconst Footer = ({\n  children,\n  alignItems = [\"stretch\", \"right\"],\n}: {\n  children: React.ReactNode[] | React.ReactElement;\n  alignItems?: StackProps[\"alignItems\"];\n}) => (\n  <Box space=\"zero\" tSpace=\"l\">\n    <Stack alignItems={alignItems}>{children}</Stack>\n  </Box>\n);\n\nconst Wrapper = ({\n  skipPortal,\n  children,\n}: {\n  skipPortal: boolean;\n  children: React.ReactElement;\n}): React.ReactElement =>\n  skipPortal ? (\n    <>{children}</>\n  ) : (\n    <Portal>\n      <StyledBackdrop>{children}</StyledBackdrop>\n    </Portal>\n  );\n\nconst ButtonClose = ({ onClick }: { onClick: React.ReactEventHandler }) => (\n  <Button variant=\"tertiary\" leftIcon=\"x\" size=\"s\" onClick={onClick} />\n);\n\nexport function Modal({\n  header,\n  subHeader,\n  labelHeader,\n  children,\n  imageUrl,\n  ImageComponent,\n  secondaryButton,\n  cancelButtonLabel,\n  actionButton,\n  role,\n  onAction,\n  privateProps: { skipPortal },\n  \"data-e2e-test-id\": dataE2eTestId,\n}: ModalProps): React.ReactElement {\n  const modalRef = useRef(null);\n  const [isOpening, setOpening] = useState(true);\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n  const hasBackdropDismiss = !skipPortal;\n\n  useEffect(() => {\n    setOpening(false);\n  }, []);\n\n  useOutsideClick(modalRef, handleClose, hasBackdropDismiss && !isOpening);\n  useOnEscapePress(handleClose, [handleClose]);\n\n  const hasImage = imageUrl || ImageComponent;\n\n  return (\n    <Wrapper skipPortal={skipPortal}>\n      <StyledModalWrapper\n        ref={modalRef}\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Modal\"\n      >\n        <Container elevation={4}>\n          <Box space={[\"m\", \"xl\"]}>\n            <StyledInner>\n              <Box space=\"zero\" bSpace=\"s\">\n                <Stack space={hasImage ? [\"s\", \"l\"] : \"zero\"}>\n                  {hasImage && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      {imageUrl ? (\n                        <StyledImg src={imageUrl} />\n                      ) : (\n                        <ImageComponent />\n                      )}\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xxs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"zero\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4 color=\"tertiary\">{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!hasImage && <ButtonClose onClick={handleClose} />}\n                  </Inline>\n                </Stack>\n              </Box>\n\n              <StyledBody>{children}</StyledBody>\n\n              {(actionButton || cancelButtonLabel || secondaryButton) && (\n                <Footer>\n                  <ButtonGroup\n                    actionButton={actionButton}\n                    secondaryButton={secondaryButton}\n                    cancelButtonText={cancelButtonLabel}\n                    onButtonClick={onAction}\n                  />\n                </Footer>\n              )}\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Wrapper>\n  );\n}\n\nModal.defaultProps = defaultModalProps;\n\nModal.Stack = ModalStack;\nModal.Text = ModalText;\n"],"names":[],"mappings":"AA6FkB"} */"),Footer=({children,alignItems=["stretch","right"]})=>React.createElement(Box,{space:"zero",tSpace:"l"},React.createElement(Stack,{alignItems:alignItems},children)),Wrapper=({skipPortal,children})=>skipPortal?React.createElement(React.Fragment,null,children):React.createElement(Portal,null,React.createElement(StyledBackdrop,null,children)),ButtonClose=({onClick})=>React.createElement(Button,{variant:"tertiary",leftIcon:"x",size:"s",onClick:onClick});export function Modal({header,subHeader,labelHeader,children,imageUrl,ImageComponent,secondaryButton,cancelButtonLabel,actionButton,role,onAction,privateProps:{skipPortal},"data-e2e-test-id":dataE2eTestId}){let modalRef=useRef(null),[isOpening,setOpening]=useState(!0),handleClose=()=>{onAction("cancel")};useEffect(()=>{setOpening(!1)},[]),useOutsideClick(modalRef,handleClose,!skipPortal&&!isOpening),useOnEscapePress(handleClose,[handleClose]);let hasImage=imageUrl||ImageComponent;return React.createElement(Wrapper,{skipPortal:skipPortal},React.createElement(StyledModalWrapper,{ref:modalRef,role:role,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Modal"},React.createElement(Container,{elevation:4},React.createElement(Box,{space:["m","xl"]},React.createElement(StyledInner,null,React.createElement(Box,{space:"zero",bSpace:"s"},React.createElement(Stack,{space:hasImage?["s","l"]:"zero"},hasImage&&React.createElement(React.Fragment,null,React.createElement(Inline,{alignItems:"right"},React.createElement(ButtonClose,{onClick:handleClose})),imageUrl?React.createElement(StyledImg,{src:imageUrl}):React.createElement(ImageComponent,null)),React.createElement(Inline,{alignItems:"spaceBetween",noWrap:!0},React.createElement(Stack,{space:"xxs"},labelHeader&&React.createElement(H6,null,labelHeader),React.createElement(Stack,{space:"zero"},React.createElement(H2,null,header),subHeader&&React.createElement(H4,{color:"tertiary"},subHeader))),!hasImage&&React.createElement(ButtonClose,{onClick:handleClose})))),React.createElement(StyledBody,null,children),(actionButton||cancelButtonLabel||secondaryButton)&&React.createElement(Footer,null,React.createElement(ButtonGroup,{actionButton:actionButton,secondaryButton:secondaryButton,cancelButtonText:cancelButtonLabel,onButtonClick:onAction})))))))}Modal.defaultProps={role:"dialog","data-e2e-test-id":void 0,privateProps:{skipPortal:!1}},Modal.Stack=({children,...rest})=>React.createElement(Stack,{...rest,space:"m"},children),Modal.Text=({children,...rest})=>React.createElement(Text,{...rest,size:"m",color:"tertiary"},children);
@@ -1,5 +1,6 @@
1
1
  import React from "react";
2
- import type { HorizontalAlignment, MQ, SpaceSizes } from "../../types";
2
+ import type { Property } from "csstype";
3
+ import type { StackHorizontalAlignment, MQ, SpaceSizes, StackVerticalAlignment } from "../../types";
3
4
  export type StackProps = {
4
5
  /** Represents the vertical between the Stack's children
5
6
  * specify [small screen space, medium screen space, large screen space] or one space for all screen sizes
@@ -8,13 +9,20 @@ export type StackProps = {
8
9
  /** Represents elements' horizontal alignment
9
10
  * specify [small screen alignItems, medium screen alignItems, large screen alignItems] or one alignItems for all screen sizes
10
11
  */
11
- alignItems?: MQ<HorizontalAlignment> | HorizontalAlignment;
12
+ alignItems?: MQ<StackHorizontalAlignment> | StackHorizontalAlignment;
13
+ /**
14
+ * Represents elements' vertical alignment
15
+ * specify [small screen vAlignItems, medium screen vAlignItems, large screen vAlignItems] or one alignItems for all screen sizes
16
+ */
17
+ vAlignItems?: MQ<StackVerticalAlignment> | StackVerticalAlignment;
18
+ /** height */
19
+ height?: Property.Height;
12
20
  children: React.ReactNode[] | React.ReactElement;
13
21
  "data-e2e-test-id"?: string;
14
22
  /** @ignore */
15
23
  "data-ds-id"?: string;
16
24
  };
17
- export declare function Stack({ children, space, alignItems, "data-e2e-test-id": dataE2eTestId, "data-ds-id": dataDsId, }: StackProps): React.ReactElement;
25
+ export declare function Stack({ children, space, alignItems, vAlignItems, height, "data-e2e-test-id": dataE2eTestId, "data-ds-id": dataDsId, }: StackProps): React.ReactElement;
18
26
  export declare namespace Stack {
19
27
  var defaultProps: Partial<StackProps>;
20
28
  }
@@ -1 +1 @@
1
- import React from"react";import styled from"@emotion/styled";import{flattenChildren}from"../../shared/flattenChildren";import{mq}from"../../shared/mediaQueries";let StackContainer=styled("div",{target:"e1yrutbe0",label:"StackContainer"})(({alignItems})=>({...mq({alignItems:[alignItems,{left:"flex-start",right:"flex-end",center:"center",spaceBetween:"space-between"}]}),display:"flex",flexDirection:"column"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU3RhY2svU3RhY2sudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TdGFjay9TdGFjay50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBmbGF0dGVuQ2hpbGRyZW4gfSBmcm9tIFwiLi4vLi4vc2hhcmVkL2ZsYXR0ZW5DaGlsZHJlblwiO1xuaW1wb3J0IHsgbXEgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuXG5pbXBvcnQgdHlwZSB7IEhvcml6b250YWxBbGlnbm1lbnQsIE1RLCBTcGFjZVNpemVzIH0gZnJvbSBcIi4uLy4uL3R5cGVzXCI7XG5cbmV4cG9ydCB0eXBlIFN0YWNrUHJvcHMgPSB7XG4gIC8qKiBSZXByZXNlbnRzIHRoZSB2ZXJ0aWNhbCBiZXR3ZWVuIHRoZSBTdGFjaydzIGNoaWxkcmVuXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBzcGFjZSwgbWVkaXVtIHNjcmVlbiBzcGFjZSwgbGFyZ2Ugc2NyZWVuIHNwYWNlXSBvciBvbmUgc3BhY2UgZm9yIGFsbCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNwYWNlPzogTVE8U3BhY2VTaXplcz4gfCBTcGFjZVNpemVzO1xuICAvKiogUmVwcmVzZW50cyBlbGVtZW50cycgaG9yaXpvbnRhbCBhbGlnbm1lbnRcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gYWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIGFsaWduSXRlbXNdIG9yIG9uZSBhbGlnbkl0ZW1zIGZvciBhbGwgc2NyZWVuIHNpemVzXG4gICAqL1xuICBhbGlnbkl0ZW1zPzogTVE8SG9yaXpvbnRhbEFsaWdubWVudD4gfCBIb3Jpem9udGFsQWxpZ25tZW50O1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdEVsZW1lbnQ7XG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuICAvKiogQGlnbm9yZSAqL1xuICBcImRhdGEtZHMtaWRcIj86IHN0cmluZztcbn07XG5cbnR5cGUgU3RhY2tJdGVtUHJvcHMgPSB7XG4gIC8qKiBSZXByZXNlbnRzIHRoZSB2ZXJ0aWNhbCBiZXR3ZWVuIHRoZSBTdGFjaydzIGNoaWxkcmVuXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBzcGFjZSwgbWVkaXVtIHNjcmVlbiBzcGFjZSwgbGFyZ2Ugc2NyZWVuIHNwYWNlXSBvciBvbmUgc3BhY2UgZm9yIGFsbCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNwYWNlPzogTVE8U3BhY2VTaXplcz4gfCBTcGFjZVNpemVzO1xufTtcblxuY29uc3QgZGVmYXVsdFByb3BzOiBQYXJ0aWFsPFN0YWNrUHJvcHM+ID0ge1xuICBzcGFjZTogXCJ4c1wiLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogdW5kZWZpbmVkLFxuICBcImRhdGEtZHMtaWRcIjogXCJTdGFja1wiLFxufTtcblxuY29uc3QgU3RhY2tDb250YWluZXIgPSBzdHlsZWQuZGl2PFN0YWNrUHJvcHM+KCh7IGFsaWduSXRlbXMgfSkgPT4gKHtcbiAgLi4ubXEoe1xuICAgIGFsaWduSXRlbXM6IFtcbiAgICAgIGFsaWduSXRlbXMsXG4gICAgICB7XG4gICAgICAgIGxlZnQ6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICByaWdodDogXCJmbGV4LWVuZFwiLFxuICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgIHNwYWNlQmV0d2VlbjogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gICAgICB9LFxuICAgIF0sXG4gIH0pLFxuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbn0pKTtcblxuY29uc3QgU3RhY2tJdGVtID0gc3R5bGVkLmRpdjxTdGFja0l0ZW1Qcm9wcz4oKHsgdGhlbWUsIHNwYWNlIH0pID0+ICh7XG4gIC4uLm1xKHtcbiAgICBtYXJnaW5Ub3A6IFtzcGFjZSwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gIH0pLFxuICBcIiY6Zmlyc3Qtb2YtdHlwZVwiOiB7XG4gICAgbWFyZ2luVG9wOiAwLFxuICB9LFxuICBcIiY6ZW1wdHlcIjoge1xuICAgIG1hcmdpblRvcDogMCxcbiAgfSxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFN0YWNrKHtcbiAgY2hpbGRyZW4sXG4gIHNwYWNlLFxuICBhbGlnbkl0ZW1zLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgXCJkYXRhLWRzLWlkXCI6IGRhdGFEc0lkLFxufTogU3RhY2tQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN0YWNrQ29udGFpbmVyXG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgZGF0YS1kcy1pZD17ZGF0YURzSWR9XG4gICAgICBhbGlnbkl0ZW1zPXthbGlnbkl0ZW1zfVxuICAgID5cbiAgICAgIHtSZWFjdC5DaGlsZHJlbi5tYXAoXG4gICAgICAgIGZsYXR0ZW5DaGlsZHJlbihjaGlsZHJlbiksXG4gICAgICAgIChjaGlsZCkgPT4gY2hpbGQgJiYgPFN0YWNrSXRlbSBzcGFjZT17c3BhY2V9PntjaGlsZH08L1N0YWNrSXRlbT5cbiAgICAgICl9XG4gICAgPC9TdGFja0NvbnRhaW5lcj5cbiAgKTtcbn1cblxuU3RhY2suZGVmYXVsdFByb3BzID0gZGVmYXVsdFByb3BzO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1DdUIifQ== */"),StackItem=styled("div",{target:"e1yrutbe1",label:"StackItem"})(({theme,space})=>({...mq({marginTop:[space,theme.variables.size.spacing]}),"&:first-of-type":{marginTop:0},"&:empty":{marginTop:0}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU3RhY2svU3RhY2sudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TdGFjay9TdGFjay50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBmbGF0dGVuQ2hpbGRyZW4gfSBmcm9tIFwiLi4vLi4vc2hhcmVkL2ZsYXR0ZW5DaGlsZHJlblwiO1xuaW1wb3J0IHsgbXEgfSBmcm9tIFwiLi4vLi4vc2hhcmVkL21lZGlhUXVlcmllc1wiO1xuXG5pbXBvcnQgdHlwZSB7IEhvcml6b250YWxBbGlnbm1lbnQsIE1RLCBTcGFjZVNpemVzIH0gZnJvbSBcIi4uLy4uL3R5cGVzXCI7XG5cbmV4cG9ydCB0eXBlIFN0YWNrUHJvcHMgPSB7XG4gIC8qKiBSZXByZXNlbnRzIHRoZSB2ZXJ0aWNhbCBiZXR3ZWVuIHRoZSBTdGFjaydzIGNoaWxkcmVuXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBzcGFjZSwgbWVkaXVtIHNjcmVlbiBzcGFjZSwgbGFyZ2Ugc2NyZWVuIHNwYWNlXSBvciBvbmUgc3BhY2UgZm9yIGFsbCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNwYWNlPzogTVE8U3BhY2VTaXplcz4gfCBTcGFjZVNpemVzO1xuICAvKiogUmVwcmVzZW50cyBlbGVtZW50cycgaG9yaXpvbnRhbCBhbGlnbm1lbnRcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gYWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIGFsaWduSXRlbXNdIG9yIG9uZSBhbGlnbkl0ZW1zIGZvciBhbGwgc2NyZWVuIHNpemVzXG4gICAqL1xuICBhbGlnbkl0ZW1zPzogTVE8SG9yaXpvbnRhbEFsaWdubWVudD4gfCBIb3Jpem9udGFsQWxpZ25tZW50O1xuICBjaGlsZHJlbjogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdEVsZW1lbnQ7XG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiPzogc3RyaW5nO1xuICAvKiogQGlnbm9yZSAqL1xuICBcImRhdGEtZHMtaWRcIj86IHN0cmluZztcbn07XG5cbnR5cGUgU3RhY2tJdGVtUHJvcHMgPSB7XG4gIC8qKiBSZXByZXNlbnRzIHRoZSB2ZXJ0aWNhbCBiZXR3ZWVuIHRoZSBTdGFjaydzIGNoaWxkcmVuXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBzcGFjZSwgbWVkaXVtIHNjcmVlbiBzcGFjZSwgbGFyZ2Ugc2NyZWVuIHNwYWNlXSBvciBvbmUgc3BhY2UgZm9yIGFsbCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNwYWNlPzogTVE8U3BhY2VTaXplcz4gfCBTcGFjZVNpemVzO1xufTtcblxuY29uc3QgZGVmYXVsdFByb3BzOiBQYXJ0aWFsPFN0YWNrUHJvcHM+ID0ge1xuICBzcGFjZTogXCJ4c1wiLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogdW5kZWZpbmVkLFxuICBcImRhdGEtZHMtaWRcIjogXCJTdGFja1wiLFxufTtcblxuY29uc3QgU3RhY2tDb250YWluZXIgPSBzdHlsZWQuZGl2PFN0YWNrUHJvcHM+KCh7IGFsaWduSXRlbXMgfSkgPT4gKHtcbiAgLi4ubXEoe1xuICAgIGFsaWduSXRlbXM6IFtcbiAgICAgIGFsaWduSXRlbXMsXG4gICAgICB7XG4gICAgICAgIGxlZnQ6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICByaWdodDogXCJmbGV4LWVuZFwiLFxuICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgIHNwYWNlQmV0d2VlbjogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gICAgICB9LFxuICAgIF0sXG4gIH0pLFxuICBkaXNwbGF5OiBcImZsZXhcIixcbiAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcbn0pKTtcblxuY29uc3QgU3RhY2tJdGVtID0gc3R5bGVkLmRpdjxTdGFja0l0ZW1Qcm9wcz4oKHsgdGhlbWUsIHNwYWNlIH0pID0+ICh7XG4gIC4uLm1xKHtcbiAgICBtYXJnaW5Ub3A6IFtzcGFjZSwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gIH0pLFxuICBcIiY6Zmlyc3Qtb2YtdHlwZVwiOiB7XG4gICAgbWFyZ2luVG9wOiAwLFxuICB9LFxuICBcIiY6ZW1wdHlcIjoge1xuICAgIG1hcmdpblRvcDogMCxcbiAgfSxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFN0YWNrKHtcbiAgY2hpbGRyZW4sXG4gIHNwYWNlLFxuICBhbGlnbkl0ZW1zLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgXCJkYXRhLWRzLWlkXCI6IGRhdGFEc0lkLFxufTogU3RhY2tQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN0YWNrQ29udGFpbmVyXG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgZGF0YS1kcy1pZD17ZGF0YURzSWR9XG4gICAgICBhbGlnbkl0ZW1zPXthbGlnbkl0ZW1zfVxuICAgID5cbiAgICAgIHtSZWFjdC5DaGlsZHJlbi5tYXAoXG4gICAgICAgIGZsYXR0ZW5DaGlsZHJlbihjaGlsZHJlbiksXG4gICAgICAgIChjaGlsZCkgPT4gY2hpbGQgJiYgPFN0YWNrSXRlbSBzcGFjZT17c3BhY2V9PntjaGlsZH08L1N0YWNrSXRlbT5cbiAgICAgICl9XG4gICAgPC9TdGFja0NvbnRhaW5lcj5cbiAgKTtcbn1cblxuU3RhY2suZGVmYXVsdFByb3BzID0gZGVmYXVsdFByb3BzO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1Ea0IifQ== */");export function Stack({children,space,alignItems,"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId}){return React.createElement(StackContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,alignItems:alignItems},React.Children.map(flattenChildren(children),child=>child&&React.createElement(StackItem,{space:space},child)))}Stack.defaultProps={space:"xs","data-e2e-test-id":void 0,"data-ds-id":"Stack"};
1
+ import React from"react";import styled from"@emotion/styled";import{flattenChildren}from"../../shared/flattenChildren";import{mq}from"../../shared/mediaQueries";let StackContainer=styled("div",{target:"epibvxs0",label:"StackContainer"})(({alignItems,vAlignItems,height})=>({...mq({justifyContent:[vAlignItems,{top:"flex-start",bottom:"flex-end",center:"center",spaceBetween:"space-between"}],alignItems:[alignItems,{left:"flex-start",right:"flex-end",center:"center",stretch:"stretch"}]}),display:"flex",flexDirection:"column",height}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU3RhY2svU3RhY2sudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TdGFjay9TdGFjay50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFByb3BlcnR5IH0gZnJvbSBcImNzc3R5cGVcIjtcbmltcG9ydCB7IGZsYXR0ZW5DaGlsZHJlbiB9IGZyb20gXCIuLi8uLi9zaGFyZWQvZmxhdHRlbkNoaWxkcmVuXCI7XG5pbXBvcnQgeyBtcSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmltcG9ydCB0eXBlIHtcbiAgU3RhY2tIb3Jpem9udGFsQWxpZ25tZW50LFxuICBNUSxcbiAgU3BhY2VTaXplcyxcbiAgU3RhY2tWZXJ0aWNhbEFsaWdubWVudCxcbn0gZnJvbSBcIi4uLy4uL3R5cGVzXCI7XG5cbmV4cG9ydCB0eXBlIFN0YWNrUHJvcHMgPSB7XG4gIC8qKiBSZXByZXNlbnRzIHRoZSB2ZXJ0aWNhbCBiZXR3ZWVuIHRoZSBTdGFjaydzIGNoaWxkcmVuXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBzcGFjZSwgbWVkaXVtIHNjcmVlbiBzcGFjZSwgbGFyZ2Ugc2NyZWVuIHNwYWNlXSBvciBvbmUgc3BhY2UgZm9yIGFsbCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNwYWNlPzogTVE8U3BhY2VTaXplcz4gfCBTcGFjZVNpemVzO1xuICAvKiogUmVwcmVzZW50cyBlbGVtZW50cycgaG9yaXpvbnRhbCBhbGlnbm1lbnRcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gYWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIGFsaWduSXRlbXNdIG9yIG9uZSBhbGlnbkl0ZW1zIGZvciBhbGwgc2NyZWVuIHNpemVzXG4gICAqL1xuICBhbGlnbkl0ZW1zPzogTVE8U3RhY2tIb3Jpem9udGFsQWxpZ25tZW50PiB8IFN0YWNrSG9yaXpvbnRhbEFsaWdubWVudDtcblxuICAvKipcbiAgICogUmVwcmVzZW50cyBlbGVtZW50cycgdmVydGljYWwgYWxpZ25tZW50XG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiB2QWxpZ25JdGVtcywgbWVkaXVtIHNjcmVlbiB2QWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIHZBbGlnbkl0ZW1zXSBvciBvbmUgYWxpZ25JdGVtcyBmb3IgYWxsIHNjcmVlbiBzaXplc1xuICAgKi9cbiAgdkFsaWduSXRlbXM/OiBNUTxTdGFja1ZlcnRpY2FsQWxpZ25tZW50PiB8IFN0YWNrVmVydGljYWxBbGlnbm1lbnQ7XG5cbiAgLyoqIGhlaWdodCAqL1xuICBoZWlnaHQ/OiBQcm9wZXJ0eS5IZWlnaHQ7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVbXSB8IFJlYWN0LlJlYWN0RWxlbWVudDtcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIC8qKiBAaWdub3JlICovXG4gIFwiZGF0YS1kcy1pZFwiPzogc3RyaW5nO1xufTtcblxudHlwZSBTdGFja0l0ZW1Qcm9wcyA9IHtcbiAgLyoqIFJlcHJlc2VudHMgdGhlIHZlcnRpY2FsIGJldHdlZW4gdGhlIFN0YWNrJ3MgY2hpbGRyZW5cbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIHNwYWNlLCBtZWRpdW0gc2NyZWVuIHNwYWNlLCBsYXJnZSBzY3JlZW4gc3BhY2VdIG9yIG9uZSBzcGFjZSBmb3IgYWxsIHNjcmVlbiBzaXplc1xuICAgKi9cbiAgc3BhY2U/OiBNUTxTcGFjZVNpemVzPiB8IFNwYWNlU2l6ZXM7XG59O1xuXG5jb25zdCBkZWZhdWx0UHJvcHM6IFBhcnRpYWw8U3RhY2tQcm9wcz4gPSB7XG4gIHNwYWNlOiBcInhzXCIsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiB1bmRlZmluZWQsXG4gIFwiZGF0YS1kcy1pZFwiOiBcIlN0YWNrXCIsXG59O1xuXG5jb25zdCBTdGFja0NvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3RhY2tQcm9wcz4oXG4gICh7IGFsaWduSXRlbXMsIHZBbGlnbkl0ZW1zLCBoZWlnaHQgfSkgPT4gKHtcbiAgICAuLi5tcSh7XG4gICAgICBqdXN0aWZ5Q29udGVudDogW1xuICAgICAgICB2QWxpZ25JdGVtcyxcbiAgICAgICAge1xuICAgICAgICAgIHRvcDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgYm90dG9tOiBcImZsZXgtZW5kXCIsXG4gICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIHNwYWNlQmV0d2VlbjogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgICAgYWxpZ25JdGVtczogW1xuICAgICAgICBhbGlnbkl0ZW1zLFxuICAgICAgICB7XG4gICAgICAgICAgbGVmdDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgcmlnaHQ6IFwiZmxleC1lbmRcIixcbiAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgc3RyZXRjaDogXCJzdHJldGNoXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH0pLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gICAgaGVpZ2h0LFxuICB9KVxuKTtcblxuY29uc3QgU3RhY2tJdGVtID0gc3R5bGVkLmRpdjxTdGFja0l0ZW1Qcm9wcz4oKHsgdGhlbWUsIHNwYWNlIH0pID0+ICh7XG4gIC4uLm1xKHtcbiAgICBtYXJnaW5Ub3A6IFtzcGFjZSwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gIH0pLFxuICBcIiY6Zmlyc3Qtb2YtdHlwZVwiOiB7XG4gICAgbWFyZ2luVG9wOiAwLFxuICB9LFxuICBcIiY6ZW1wdHlcIjoge1xuICAgIG1hcmdpblRvcDogMCxcbiAgfSxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFN0YWNrKHtcbiAgY2hpbGRyZW4sXG4gIHNwYWNlLFxuICBhbGlnbkl0ZW1zLFxuICB2QWxpZ25JdGVtcyxcbiAgaGVpZ2h0LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgXCJkYXRhLWRzLWlkXCI6IGRhdGFEc0lkLFxufTogU3RhY2tQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN0YWNrQ29udGFpbmVyXG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgZGF0YS1kcy1pZD17ZGF0YURzSWR9XG4gICAgICBhbGlnbkl0ZW1zPXthbGlnbkl0ZW1zfVxuICAgICAgdkFsaWduSXRlbXM9e3ZBbGlnbkl0ZW1zfVxuICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgPlxuICAgICAge1JlYWN0LkNoaWxkcmVuLm1hcChcbiAgICAgICAgZmxhdHRlbkNoaWxkcmVuKGNoaWxkcmVuKSxcbiAgICAgICAgKGNoaWxkKSA9PiBjaGlsZCAmJiA8U3RhY2tJdGVtIHNwYWNlPXtzcGFjZX0+e2NoaWxkfTwvU3RhY2tJdGVtPlxuICAgICAgKX1cbiAgICA8L1N0YWNrQ29udGFpbmVyPlxuICApO1xufVxuXG5TdGFjay5kZWZhdWx0UHJvcHMgPSBkZWZhdWx0UHJvcHM7XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0R1QiJ9 */"),StackItem=styled("div",{target:"epibvxs1",label:"StackItem"})(({theme,space})=>({...mq({marginTop:[space,theme.variables.size.spacing]}),"&:first-of-type":{marginTop:0},"&:empty":{marginTop:0}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvU3RhY2svU3RhY2sudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9TdGFjay9TdGFjay50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFByb3BlcnR5IH0gZnJvbSBcImNzc3R5cGVcIjtcbmltcG9ydCB7IGZsYXR0ZW5DaGlsZHJlbiB9IGZyb20gXCIuLi8uLi9zaGFyZWQvZmxhdHRlbkNoaWxkcmVuXCI7XG5pbXBvcnQgeyBtcSB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5cbmltcG9ydCB0eXBlIHtcbiAgU3RhY2tIb3Jpem9udGFsQWxpZ25tZW50LFxuICBNUSxcbiAgU3BhY2VTaXplcyxcbiAgU3RhY2tWZXJ0aWNhbEFsaWdubWVudCxcbn0gZnJvbSBcIi4uLy4uL3R5cGVzXCI7XG5cbmV4cG9ydCB0eXBlIFN0YWNrUHJvcHMgPSB7XG4gIC8qKiBSZXByZXNlbnRzIHRoZSB2ZXJ0aWNhbCBiZXR3ZWVuIHRoZSBTdGFjaydzIGNoaWxkcmVuXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiBzcGFjZSwgbWVkaXVtIHNjcmVlbiBzcGFjZSwgbGFyZ2Ugc2NyZWVuIHNwYWNlXSBvciBvbmUgc3BhY2UgZm9yIGFsbCBzY3JlZW4gc2l6ZXNcbiAgICovXG4gIHNwYWNlPzogTVE8U3BhY2VTaXplcz4gfCBTcGFjZVNpemVzO1xuICAvKiogUmVwcmVzZW50cyBlbGVtZW50cycgaG9yaXpvbnRhbCBhbGlnbm1lbnRcbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGFsaWduSXRlbXMsIG1lZGl1bSBzY3JlZW4gYWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIGFsaWduSXRlbXNdIG9yIG9uZSBhbGlnbkl0ZW1zIGZvciBhbGwgc2NyZWVuIHNpemVzXG4gICAqL1xuICBhbGlnbkl0ZW1zPzogTVE8U3RhY2tIb3Jpem9udGFsQWxpZ25tZW50PiB8IFN0YWNrSG9yaXpvbnRhbEFsaWdubWVudDtcblxuICAvKipcbiAgICogUmVwcmVzZW50cyBlbGVtZW50cycgdmVydGljYWwgYWxpZ25tZW50XG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiB2QWxpZ25JdGVtcywgbWVkaXVtIHNjcmVlbiB2QWxpZ25JdGVtcywgbGFyZ2Ugc2NyZWVuIHZBbGlnbkl0ZW1zXSBvciBvbmUgYWxpZ25JdGVtcyBmb3IgYWxsIHNjcmVlbiBzaXplc1xuICAgKi9cbiAgdkFsaWduSXRlbXM/OiBNUTxTdGFja1ZlcnRpY2FsQWxpZ25tZW50PiB8IFN0YWNrVmVydGljYWxBbGlnbm1lbnQ7XG5cbiAgLyoqIGhlaWdodCAqL1xuICBoZWlnaHQ/OiBQcm9wZXJ0eS5IZWlnaHQ7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVbXSB8IFJlYWN0LlJlYWN0RWxlbWVudDtcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI/OiBzdHJpbmc7XG4gIC8qKiBAaWdub3JlICovXG4gIFwiZGF0YS1kcy1pZFwiPzogc3RyaW5nO1xufTtcblxudHlwZSBTdGFja0l0ZW1Qcm9wcyA9IHtcbiAgLyoqIFJlcHJlc2VudHMgdGhlIHZlcnRpY2FsIGJldHdlZW4gdGhlIFN0YWNrJ3MgY2hpbGRyZW5cbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIHNwYWNlLCBtZWRpdW0gc2NyZWVuIHNwYWNlLCBsYXJnZSBzY3JlZW4gc3BhY2VdIG9yIG9uZSBzcGFjZSBmb3IgYWxsIHNjcmVlbiBzaXplc1xuICAgKi9cbiAgc3BhY2U/OiBNUTxTcGFjZVNpemVzPiB8IFNwYWNlU2l6ZXM7XG59O1xuXG5jb25zdCBkZWZhdWx0UHJvcHM6IFBhcnRpYWw8U3RhY2tQcm9wcz4gPSB7XG4gIHNwYWNlOiBcInhzXCIsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiB1bmRlZmluZWQsXG4gIFwiZGF0YS1kcy1pZFwiOiBcIlN0YWNrXCIsXG59O1xuXG5jb25zdCBTdGFja0NvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3RhY2tQcm9wcz4oXG4gICh7IGFsaWduSXRlbXMsIHZBbGlnbkl0ZW1zLCBoZWlnaHQgfSkgPT4gKHtcbiAgICAuLi5tcSh7XG4gICAgICBqdXN0aWZ5Q29udGVudDogW1xuICAgICAgICB2QWxpZ25JdGVtcyxcbiAgICAgICAge1xuICAgICAgICAgIHRvcDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgYm90dG9tOiBcImZsZXgtZW5kXCIsXG4gICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIHNwYWNlQmV0d2VlbjogXCJzcGFjZS1iZXR3ZWVuXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgICAgYWxpZ25JdGVtczogW1xuICAgICAgICBhbGlnbkl0ZW1zLFxuICAgICAgICB7XG4gICAgICAgICAgbGVmdDogXCJmbGV4LXN0YXJ0XCIsXG4gICAgICAgICAgcmlnaHQ6IFwiZmxleC1lbmRcIixcbiAgICAgICAgICBjZW50ZXI6IFwiY2VudGVyXCIsXG4gICAgICAgICAgc3RyZXRjaDogXCJzdHJldGNoXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH0pLFxuICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gICAgaGVpZ2h0LFxuICB9KVxuKTtcblxuY29uc3QgU3RhY2tJdGVtID0gc3R5bGVkLmRpdjxTdGFja0l0ZW1Qcm9wcz4oKHsgdGhlbWUsIHNwYWNlIH0pID0+ICh7XG4gIC4uLm1xKHtcbiAgICBtYXJnaW5Ub3A6IFtzcGFjZSwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gIH0pLFxuICBcIiY6Zmlyc3Qtb2YtdHlwZVwiOiB7XG4gICAgbWFyZ2luVG9wOiAwLFxuICB9LFxuICBcIiY6ZW1wdHlcIjoge1xuICAgIG1hcmdpblRvcDogMCxcbiAgfSxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFN0YWNrKHtcbiAgY2hpbGRyZW4sXG4gIHNwYWNlLFxuICBhbGlnbkl0ZW1zLFxuICB2QWxpZ25JdGVtcyxcbiAgaGVpZ2h0LFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbiAgXCJkYXRhLWRzLWlkXCI6IGRhdGFEc0lkLFxufTogU3RhY2tQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN0YWNrQ29udGFpbmVyXG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgZGF0YS1kcy1pZD17ZGF0YURzSWR9XG4gICAgICBhbGlnbkl0ZW1zPXthbGlnbkl0ZW1zfVxuICAgICAgdkFsaWduSXRlbXM9e3ZBbGlnbkl0ZW1zfVxuICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgPlxuICAgICAge1JlYWN0LkNoaWxkcmVuLm1hcChcbiAgICAgICAgZmxhdHRlbkNoaWxkcmVuKGNoaWxkcmVuKSxcbiAgICAgICAgKGNoaWxkKSA9PiBjaGlsZCAmJiA8U3RhY2tJdGVtIHNwYWNlPXtzcGFjZX0+e2NoaWxkfTwvU3RhY2tJdGVtPlxuICAgICAgKX1cbiAgICA8L1N0YWNrQ29udGFpbmVyPlxuICApO1xufVxuXG5TdGFjay5kZWZhdWx0UHJvcHMgPSBkZWZhdWx0UHJvcHM7XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEVrQiJ9 */");export function Stack({children,space,alignItems,vAlignItems,height,"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId}){return React.createElement(StackContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,alignItems:alignItems,vAlignItems:vAlignItems,height:height},React.Children.map(flattenChildren(children),child=>child&&React.createElement(StackItem,{space:space},child)))}Stack.defaultProps={space:"xs","data-e2e-test-id":void 0,"data-ds-id":"Stack"};
@@ -1,9 +1,9 @@
1
- import type { ColumnSizes, HorizontalAlignment, MQ, SpaceSizes, TextAlignment, VerticalAlignment, Order, ColumnAlignment, Hyphens } from "../types";
1
+ import type { ColumnSizes, HorizontalAlignment, MQ, SpaceSizes, TextAlignment, VerticalAlignment, StackHorizontalAlignment, StackVerticalAlignment, Order, ColumnAlignment, Hyphens } from "../types";
2
2
  type MqProp<T> = [
3
3
  T | MQ<T>,
4
4
  Record<T extends string ? T : never, string | number>
5
5
  ];
6
- type MqRules = Record<string, MqProp<TextAlignment> | MqProp<SpaceSizes> | MqProp<HorizontalAlignment> | MqProp<VerticalAlignment> | MqProp<ColumnSizes> | MqProp<Order> | MqProp<ColumnAlignment> | MqProp<Hyphens>>;
6
+ type MqRules = Record<string, MqProp<TextAlignment> | MqProp<SpaceSizes> | MqProp<HorizontalAlignment> | MqProp<VerticalAlignment> | MqProp<StackHorizontalAlignment> | MqProp<StackVerticalAlignment> | MqProp<ColumnSizes> | MqProp<Order> | MqProp<ColumnAlignment> | MqProp<Hyphens>>;
7
7
  type EmotionCssPropertyName = string;
8
8
  type EmotionCssValue = string | number;
9
9
  type EmotionCssDescription = Record<EmotionCssPropertyName, EmotionCssValue>;
@@ -13,7 +13,11 @@ export declare const HorizontalAlignmentRuntype: Union<[Literal<"left">, Literal
13
13
  export type HorizontalAlignment = Static<typeof HorizontalAlignmentRuntype>;
14
14
  export declare const VerticalAlignmentRuntype: Union<[Literal<"top">, Literal<"bottom">, Literal<"center">, Literal<"stretch">]>;
15
15
  export type VerticalAlignment = Static<typeof VerticalAlignmentRuntype>;
16
- export declare const SpaceSizesRuntype: Union<[Literal<"zero">, Literal<"xxs">, Literal<"xs">, Literal<"s">, Literal<"m">, Literal<"l">, Literal<"xl">, Literal<"xxl">]>;
16
+ export declare const StackVerticalAlignmentRuntype: Union<[Literal<"top">, Literal<"bottom">, Literal<"center">, Literal<"spaceBetween">]>;
17
+ export type StackVerticalAlignment = Static<typeof StackVerticalAlignmentRuntype>;
18
+ export declare const StackHorizontalAlignmentRuntype: Union<[Literal<"left">, Literal<"right">, Literal<"center">, Literal<"stretch">]>;
19
+ export type StackHorizontalAlignment = Static<typeof StackHorizontalAlignmentRuntype>;
20
+ export declare const SpaceSizesRuntype: Union<[Literal<"zero">, Literal<"xxxs">, Literal<"xxs">, Literal<"xs">, Literal<"s">, Literal<"m">, Literal<"l">, Literal<"xl">, Literal<"xxl">]>;
17
21
  export type SpaceSizes = Static<typeof SpaceSizesRuntype>;
18
22
  export declare const ColumsSizesRuntype: Union<[Literal<1>, Literal<2>, Literal<3>, Literal<4>, Literal<5>, Literal<6>, Literal<7>, Literal<8>, Literal<9>, Literal<10>, Literal<11>, Literal<12>, Literal<"auto">, Literal<"narrow">, Literal<"fill">]>;
19
23
  export type ColumnSizes = Static<typeof ColumsSizesRuntype>;
@@ -1 +1 @@
1
- import{Literal,Union}from"runtypes";export const LinkTextSizeRuntype=Union(Literal("xs"),Literal("s"),Literal("m"),Literal("l"));export const TextSizeRuntype=Union(Literal("xs"),Literal("s"),Literal("m"));export const BorderRadiusRuntype=Union(Literal("xs"),Literal("s"),Literal("m"));export const TextAlignmentRuntype=Union(Literal("left"),Literal("right"),Literal("center"));export const HorizontalAlignmentRuntype=Union(Literal("left"),Literal("right"),Literal("center"),Literal("spaceBetween"));export const VerticalAlignmentRuntype=Union(Literal("top"),Literal("bottom"),Literal("center"),Literal("stretch"));export const SpaceSizesRuntype=Union(Literal("zero"),Literal("xxs"),Literal("xs"),Literal("s"),Literal("m"),Literal("l"),Literal("xl"),Literal("xxl"));export const ColumsSizesRuntype=Union(Literal(1),Literal(2),Literal(3),Literal(4),Literal(5),Literal(6),Literal(7),Literal(8),Literal(9),Literal(10),Literal(11),Literal(12),Literal("auto"),Literal("narrow"),Literal("fill"));export const ColumnAlignmentRunType=Union(Literal("auto"),Literal("start"),Literal("center"),Literal("end"));export const OrderRuntype=Union(Literal("first"),Literal("last"),Literal("unset"));export const BaseVariationsRuntype=Union(Literal("primary"),Literal("secondary"),Literal("tertiary"));export const BaseColorsRuntype=Union(BaseVariationsRuntype,Literal("accent"));Union(BaseColorsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning")),Union(BaseVariationsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning")),Union(Literal("normal"),Literal("bold"),Literal("black"),Literal("inherit")),Union(BaseColorsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning"),Literal("inherit"),Literal("brand"),Literal("quaternary")),Union(BaseVariationsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning"),Literal("inherit"),Literal("brand")),Union(Literal("info"),Literal("success"),Literal("error"),Literal("warning")),Union(BaseVariationsRuntype),Union(BaseColorsRuntype),Union(Literal("s"),Literal("m"),Literal("l"));export const HyphensRuntype=Union(Literal("auto"),Literal("none"),Literal("manual"));export const ToggleSizeRuntype=Union(Literal("s"),Literal("m"));
1
+ import{Literal,Union}from"runtypes";export const LinkTextSizeRuntype=Union(Literal("xs"),Literal("s"),Literal("m"),Literal("l"));export const TextSizeRuntype=Union(Literal("xs"),Literal("s"),Literal("m"));export const BorderRadiusRuntype=Union(Literal("xs"),Literal("s"),Literal("m"));export const TextAlignmentRuntype=Union(Literal("left"),Literal("right"),Literal("center"));export const HorizontalAlignmentRuntype=Union(Literal("left"),Literal("right"),Literal("center"),Literal("spaceBetween"));export const VerticalAlignmentRuntype=Union(Literal("top"),Literal("bottom"),Literal("center"),Literal("stretch"));export const StackVerticalAlignmentRuntype=Union(Literal("top"),Literal("bottom"),Literal("center"),Literal("spaceBetween"));export const StackHorizontalAlignmentRuntype=Union(Literal("left"),Literal("right"),Literal("center"),Literal("stretch"));export const SpaceSizesRuntype=Union(Literal("zero"),Literal("xxxs"),Literal("xxs"),Literal("xs"),Literal("s"),Literal("m"),Literal("l"),Literal("xl"),Literal("xxl"));export const ColumsSizesRuntype=Union(Literal(1),Literal(2),Literal(3),Literal(4),Literal(5),Literal(6),Literal(7),Literal(8),Literal(9),Literal(10),Literal(11),Literal(12),Literal("auto"),Literal("narrow"),Literal("fill"));export const ColumnAlignmentRunType=Union(Literal("auto"),Literal("start"),Literal("center"),Literal("end"));export const OrderRuntype=Union(Literal("first"),Literal("last"),Literal("unset"));export const BaseVariationsRuntype=Union(Literal("primary"),Literal("secondary"),Literal("tertiary"));export const BaseColorsRuntype=Union(BaseVariationsRuntype,Literal("accent"));Union(BaseColorsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning")),Union(BaseVariationsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning")),Union(Literal("normal"),Literal("bold"),Literal("black"),Literal("inherit")),Union(BaseColorsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning"),Literal("inherit"),Literal("brand"),Literal("quaternary")),Union(BaseVariationsRuntype,Literal("success"),Literal("info"),Literal("error"),Literal("warning"),Literal("inherit"),Literal("brand")),Union(Literal("info"),Literal("success"),Literal("error"),Literal("warning")),Union(BaseVariationsRuntype),Union(BaseColorsRuntype),Union(Literal("s"),Literal("m"),Literal("l"));export const HyphensRuntype=Union(Literal("auto"),Literal("none"),Literal("manual"));export const ToggleSizeRuntype=Union(Literal("s"),Literal("m"));
@@ -108,6 +108,11 @@
108
108
  --color-badge-border-purple: #f2effb;
109
109
  --color-badge-border-red: #fde8e8;
110
110
  --color-badge-border-gray: #eef2f5;
111
+ --color-segmented-progress-bar-monochrome: #607585;
112
+ --color-segmented-progress-bar-success: #39d6ac;
113
+ --color-segmented-progress-bar-warning: #f1d56b;
114
+ --color-segmented-progress-bar-alert: #f07575;
115
+ --color-segmented-progress-bar-in-progress: #e0e6eb;
111
116
  --elevation-a: 0px 0.3px 0.6px rgba(0, 0, 0, 0.0035), 0px 2px 5px rgba(0, 0, 0, 0.07);
112
117
  --elevation-b: 0px 2px 8px 0px rgba(0, 0, 0, 0.12), 0px 0.3px 1px 0px rgba(0, 0, 0, 0.01);
113
118
  --elevation-c: 0px 0.5px 2.5px rgba(0, 0, 0, 0.16), 0px 4px 20px rgba(0, 0, 0, 0.2);
@@ -224,6 +229,11 @@
224
229
  --color-badge-border-purple: #393e47;
225
230
  --color-badge-border-red: #393e47;
226
231
  --color-badge-border-gray: #393e47;
232
+ --color-segmented-progress-bar-monochrome: #ced1d6;
233
+ --color-segmented-progress-bar-success: #28816b;
234
+ --color-segmented-progress-bar-warning: #a4792d;
235
+ --color-segmented-progress-bar-alert: #a45355;
236
+ --color-segmented-progress-bar-in-progress: #5b5f67;
227
237
  --elevation-a: 0px 2px 5px 0px rgba(0, 0, 0, 0.07), 0px 0.3px 0.6px 0px rgba(0, 0, 0, 0), 0px 0px 0px 1px rgba(64, 69, 79, 0.4) inset;
228
238
  --elevation-b: 0px 2px 8px 0px rgba(0, 0, 0, 0.12), 0px 0.3px 1px 0px rgba(0, 0, 0, 0.01), 0px 0px 0px 1px rgba(64, 69, 79, 0.4) inset;
229
239
  --elevation-c: 0px 4px 20px 0px rgba(0, 0, 0, 0.2), 0px 0.5px 2.5px 0px rgba(0, 0, 0, 0.16), 0px 0px 0px 1px rgba(64, 69, 79, 0.5) inset;
@@ -106,6 +106,11 @@ $colorBadgeBorderBrand: var(--color-badge-border-brand);
106
106
  $colorBadgeBorderPurple: var(--color-badge-border-purple);
107
107
  $colorBadgeBorderRed: var(--color-badge-border-red);
108
108
  $colorBadgeBorderGray: var(--color-badge-border-gray);
109
+ $colorSegmentedProgressBarMonochrome: var(--color-segmented-progress-bar-monochrome);
110
+ $colorSegmentedProgressBarSuccess: var(--color-segmented-progress-bar-success);
111
+ $colorSegmentedProgressBarWarning: var(--color-segmented-progress-bar-warning);
112
+ $colorSegmentedProgressBarAlert: var(--color-segmented-progress-bar-alert);
113
+ $colorSegmentedProgressBarInProgress: var(--color-segmented-progress-bar-in-progress);
109
114
  $elevationA: var(--elevation-a);
110
115
  $elevationB: var(--elevation-b);
111
116
  $elevationC: var(--elevation-c);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@amboss/design-system",
3
- "version": "1.24.0",
3
+ "version": "1.24.1",
4
4
  "description": "the design system for AMBOSS products",
5
5
  "author": "AMBOSS",
6
6
  "license": "ISC",