@amboss/design-system 1.17.1 → 1.17.2

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.
@@ -51,7 +51,7 @@ const StyledBackdrop = /*#__PURE__*/_styled__default.default("div", process.env.
51
51
  alignItems: "center",
52
52
  flex: "1 0 auto"
53
53
  };
54
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAuCuB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\nexport type ModalProps = {\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  /** Aspect ratio 16:9 */\n  imageUrl?: 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\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  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  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={imageUrl ? [\"s\", \"l\"] : \"zero\"}>\n                  {imageUrl && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      <StyledImg src={imageUrl} />\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!imageUrl && <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"]} */");
54
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAmDuB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { 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=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{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"]} */");
55
55
  const StyledModalWrapper = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
56
56
  target: "encqoj3"
57
57
  } : {
@@ -67,7 +67,7 @@ const StyledModalWrapper = /*#__PURE__*/_styled__default.default("div", process.
67
67
  width: [`calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`, theme.variables.size.dimension.modal.width]
68
68
  })
69
69
  };
70
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAqD2B","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\nexport type ModalProps = {\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  /** Aspect ratio 16:9 */\n  imageUrl?: 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\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  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  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={imageUrl ? [\"s\", \"l\"] : \"zero\"}>\n                  {imageUrl && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      <StyledImg src={imageUrl} />\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!imageUrl && <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"]} */");
70
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAiE2B","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { 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=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{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"]} */");
71
71
  const StyledInner = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
72
72
  target: "encqoj2"
73
73
  } : {
@@ -78,7 +78,7 @@ const StyledInner = /*#__PURE__*/_styled__default.default("div", process.env.NOD
78
78
  maxHeight: `calc(100vh - 100px)`,
79
79
  flexDirection: "column",
80
80
  overflow: "hidden"
81
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA+DoB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\nexport type ModalProps = {\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  /** Aspect ratio 16:9 */\n  imageUrl?: 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\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  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  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={imageUrl ? [\"s\", \"l\"] : \"zero\"}>\n                  {imageUrl && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      <StyledImg src={imageUrl} />\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!imageUrl && <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"]} */");
81
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA2EoB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { 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=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{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"]} */");
82
82
  const StyledBody = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
83
83
  target: "encqoj1"
84
84
  } : {
@@ -87,7 +87,7 @@ const StyledBody = /*#__PURE__*/_styled__default.default("div", process.env.NODE
87
87
  })(() => ({
88
88
  overflowY: "auto",
89
89
  maxHeight: "100%"
90
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAsEmB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\nexport type ModalProps = {\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  /** Aspect ratio 16:9 */\n  imageUrl?: 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\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  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  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={imageUrl ? [\"s\", \"l\"] : \"zero\"}>\n                  {imageUrl && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      <StyledImg src={imageUrl} />\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!imageUrl && <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"]} */");
90
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAkFmB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { 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=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{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"]} */");
91
91
  const StyledImg = /*#__PURE__*/_styled__default.default("img", process.env.NODE_ENV === "production" ? {
92
92
  target: "encqoj0"
93
93
  } : {
@@ -96,7 +96,7 @@ const StyledImg = /*#__PURE__*/_styled__default.default("img", process.env.NODE_
96
96
  })(() => ({
97
97
  width: "100%",
98
98
  aspectRatio: "16/9"
99
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA2EkB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\nexport type ModalProps = {\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  /** Aspect ratio 16:9 */\n  imageUrl?: 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\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  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  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={imageUrl ? [\"s\", \"l\"] : \"zero\"}>\n                  {imageUrl && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      <StyledImg src={imageUrl} />\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!imageUrl && <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"]} */");
99
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAuFkB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { 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=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{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"]} */");
100
100
  const ModalStack = _ref3 => {
101
101
  let {
102
102
  children,
@@ -161,6 +161,7 @@ function Modal(_ref8) {
161
161
  labelHeader,
162
162
  children,
163
163
  imageUrl,
164
+ ImageComponent,
164
165
  cancelButtonLabel,
165
166
  actionButton,
166
167
  role,
@@ -177,6 +178,7 @@ function Modal(_ref8) {
177
178
  const hasBackdropDismiss = !skipPortal;
178
179
  useOutsideClick.useOutsideClick(modalRef, handleClose, hasBackdropDismiss);
179
180
  useOnEscapePress.useOnEscapePress(handleClose, [handleClose]);
181
+ const hasImage = imageUrl || ImageComponent;
180
182
  return /*#__PURE__*/React__default.default.createElement(Wrapper, {
181
183
  skipPortal: skipPortal
182
184
  }, /*#__PURE__*/React__default.default.createElement(StyledModalWrapper, {
@@ -192,21 +194,21 @@ function Modal(_ref8) {
192
194
  space: "zero",
193
195
  bSpace: "s"
194
196
  }, /*#__PURE__*/React__default.default.createElement(Stack.Stack, {
195
- space: imageUrl ? ["s", "l"] : "zero"
196
- }, imageUrl && /*#__PURE__*/React__default.default.createElement(React__default.default.Fragment, null, /*#__PURE__*/React__default.default.createElement(Inline.Inline, {
197
+ space: hasImage ? ["s", "l"] : "zero"
198
+ }, hasImage && /*#__PURE__*/React__default.default.createElement(React__default.default.Fragment, null, /*#__PURE__*/React__default.default.createElement(Inline.Inline, {
197
199
  alignItems: "right"
198
200
  }, /*#__PURE__*/React__default.default.createElement(ButtonClose, {
199
201
  onClick: handleClose
200
- })), /*#__PURE__*/React__default.default.createElement(StyledImg, {
202
+ })), imageUrl ? /*#__PURE__*/React__default.default.createElement(StyledImg, {
201
203
  src: imageUrl
202
- })), /*#__PURE__*/React__default.default.createElement(Inline.Inline, {
204
+ }) : /*#__PURE__*/React__default.default.createElement(ImageComponent, null)), /*#__PURE__*/React__default.default.createElement(Inline.Inline, {
203
205
  alignItems: "spaceBetween",
204
206
  noWrap: true
205
207
  }, /*#__PURE__*/React__default.default.createElement(Stack.Stack, {
206
208
  space: "xs"
207
209
  }, labelHeader && /*#__PURE__*/React__default.default.createElement(Header.H6, null, labelHeader), /*#__PURE__*/React__default.default.createElement(Stack.Stack, {
208
210
  space: "xxs"
209
- }, /*#__PURE__*/React__default.default.createElement(Header.H2, null, header), subHeader && /*#__PURE__*/React__default.default.createElement(Header.H4, null, subHeader))), !imageUrl && /*#__PURE__*/React__default.default.createElement(ButtonClose, {
211
+ }, /*#__PURE__*/React__default.default.createElement(Header.H2, null, header), subHeader && /*#__PURE__*/React__default.default.createElement(Header.H4, null, subHeader))), !hasImage && /*#__PURE__*/React__default.default.createElement(ButtonClose, {
210
212
  onClick: handleClose
211
213
  })))), /*#__PURE__*/React__default.default.createElement(StyledBody, null, children), (actionButton || cancelButtonLabel) && /*#__PURE__*/React__default.default.createElement(Footer, null, /*#__PURE__*/React__default.default.createElement(ButtonGroup.ButtonGroup, {
212
214
  actionButton: actionButton,
@@ -2,15 +2,13 @@ import React from "react";
2
2
  import { StackProps } from "../../Stack/Stack";
3
3
  import { ActionButtonProps } from "../ButtonGroup/ButtonGroup";
4
4
  import { TextProps } from "../../Typography/Text/Text";
5
- export type ModalProps = {
5
+ type BaseProps = {
6
6
  header: string;
7
7
  onAction: (action: "cancel" | "action") => void;
8
8
  role?: "dialog" | "alertdialog";
9
9
  labelHeader?: string;
10
10
  /** The black color is going to be replaced with gray one */
11
11
  subHeader?: string;
12
- /** Aspect ratio 16:9 */
13
- imageUrl?: string;
14
12
  actionButton?: ActionButtonProps;
15
13
  cancelButtonLabel?: string;
16
14
  /** Aim to use <Modal.Text> and <Modal.Stack> */
@@ -20,9 +18,20 @@ export type ModalProps = {
20
18
  skipPortal?: boolean;
21
19
  };
22
20
  };
23
- export declare function Modal({ header, subHeader, labelHeader, children, imageUrl, cancelButtonLabel, actionButton, role, onAction, privateProps: { skipPortal }, "data-e2e-test-id": dataE2eTestId, }: ModalProps): React.ReactElement;
21
+ type ConditionalProps = {
22
+ /** Aspect ratio 16:9 */
23
+ imageUrl?: string;
24
+ ImageComponent?: never;
25
+ } | {
26
+ imageUrl?: never;
27
+ /** Accept ratio 16:9 */
28
+ ImageComponent?: React.ElementType<any>;
29
+ };
30
+ 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;
24
32
  export declare namespace Modal {
25
33
  var defaultProps: Partial<ModalProps>;
26
34
  var Stack: ({ children, ...rest }: Omit<StackProps, "space">) => JSX.Element;
27
35
  var Text: ({ children, ...rest }: Omit<TextProps, "size" | "variant">) => JSX.Element;
28
36
  }
37
+ export {};
@@ -43,7 +43,7 @@ const StyledBackdrop = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pro
43
43
  alignItems: "center",
44
44
  flex: "1 0 auto"
45
45
  };
46
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAuCuB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\nexport type ModalProps = {\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  /** Aspect ratio 16:9 */\n  imageUrl?: 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\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  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  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={imageUrl ? [\"s\", \"l\"] : \"zero\"}>\n                  {imageUrl && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      <StyledImg src={imageUrl} />\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!imageUrl && <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"]} */");
46
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAmDuB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { 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=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{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"]} */");
47
47
  const StyledModalWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
48
48
  target: "encqoj3"
49
49
  } : {
@@ -59,7 +59,7 @@ const StyledModalWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV ===
59
59
  width: [`calc(100vw - calc(${theme.variables.size.spacing.m} * 2))`, theme.variables.size.dimension.modal.width]
60
60
  })
61
61
  };
62
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAqD2B","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\nexport type ModalProps = {\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  /** Aspect ratio 16:9 */\n  imageUrl?: 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\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  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  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={imageUrl ? [\"s\", \"l\"] : \"zero\"}>\n                  {imageUrl && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      <StyledImg src={imageUrl} />\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!imageUrl && <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"]} */");
62
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAiE2B","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { 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=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{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"]} */");
63
63
  const StyledInner = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
64
64
  target: "encqoj2"
65
65
  } : {
@@ -70,7 +70,7 @@ const StyledInner = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "produc
70
70
  maxHeight: `calc(100vh - 100px)`,
71
71
  flexDirection: "column",
72
72
  overflow: "hidden"
73
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA+DoB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\nexport type ModalProps = {\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  /** Aspect ratio 16:9 */\n  imageUrl?: 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\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  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  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={imageUrl ? [\"s\", \"l\"] : \"zero\"}>\n                  {imageUrl && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      <StyledImg src={imageUrl} />\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!imageUrl && <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"]} */");
73
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA2EoB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { 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=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{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"]} */");
74
74
  const StyledBody = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
75
75
  target: "encqoj1"
76
76
  } : {
@@ -79,7 +79,7 @@ const StyledBody = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "product
79
79
  })(() => ({
80
80
  overflowY: "auto",
81
81
  maxHeight: "100%"
82
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAsEmB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\nexport type ModalProps = {\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  /** Aspect ratio 16:9 */\n  imageUrl?: 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\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  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  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={imageUrl ? [\"s\", \"l\"] : \"zero\"}>\n                  {imageUrl && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      <StyledImg src={imageUrl} />\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!imageUrl && <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"]} */");
82
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAkFmB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { 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=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{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"]} */");
83
83
  const StyledImg = /*#__PURE__*/_styled("img", process.env.NODE_ENV === "production" ? {
84
84
  target: "encqoj0"
85
85
  } : {
@@ -88,7 +88,7 @@ const StyledImg = /*#__PURE__*/_styled("img", process.env.NODE_ENV === "producti
88
88
  })(() => ({
89
89
  width: "100%",
90
90
  aspectRatio: "16/9"
91
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AA2EkB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\nexport type ModalProps = {\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  /** Aspect ratio 16:9 */\n  imageUrl?: 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\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  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  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={imageUrl ? [\"s\", \"l\"] : \"zero\"}>\n                  {imageUrl && (\n                    <>\n                      <Inline alignItems=\"right\">\n                        <ButtonClose onClick={handleClose} />\n                      </Inline>\n                      <StyledImg src={imageUrl} />\n                    </>\n                  )}\n                  <Inline alignItems=\"spaceBetween\" noWrap>\n                    <Stack space=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{subHeader}</H4>}\n                      </Stack>\n                    </Stack>\n                    {!imageUrl && <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"]} */");
91
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Modal.tsx"],"names":[],"mappings":"AAuFkB","file":"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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { 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=\"xs\">\n                      {labelHeader && <H6>{labelHeader}</H6>}\n                      <Stack space=\"xxs\">\n                        <H2>{header}</H2>\n                        {subHeader && <H4>{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"]} */");
92
92
  const ModalStack = _ref3 => {
93
93
  let {
94
94
  children,
@@ -153,6 +153,7 @@ function Modal(_ref8) {
153
153
  labelHeader,
154
154
  children,
155
155
  imageUrl,
156
+ ImageComponent,
156
157
  cancelButtonLabel,
157
158
  actionButton,
158
159
  role,
@@ -169,6 +170,7 @@ function Modal(_ref8) {
169
170
  const hasBackdropDismiss = !skipPortal;
170
171
  useOutsideClick(modalRef, handleClose, hasBackdropDismiss);
171
172
  useOnEscapePress(handleClose, [handleClose]);
173
+ const hasImage = imageUrl || ImageComponent;
172
174
  return /*#__PURE__*/React.createElement(Wrapper, {
173
175
  skipPortal: skipPortal
174
176
  }, /*#__PURE__*/React.createElement(StyledModalWrapper, {
@@ -184,21 +186,21 @@ function Modal(_ref8) {
184
186
  space: "zero",
185
187
  bSpace: "s"
186
188
  }, /*#__PURE__*/React.createElement(Stack, {
187
- space: imageUrl ? ["s", "l"] : "zero"
188
- }, imageUrl && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Inline, {
189
+ space: hasImage ? ["s", "l"] : "zero"
190
+ }, hasImage && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Inline, {
189
191
  alignItems: "right"
190
192
  }, /*#__PURE__*/React.createElement(ButtonClose, {
191
193
  onClick: handleClose
192
- })), /*#__PURE__*/React.createElement(StyledImg, {
194
+ })), imageUrl ? /*#__PURE__*/React.createElement(StyledImg, {
193
195
  src: imageUrl
194
- })), /*#__PURE__*/React.createElement(Inline, {
196
+ }) : /*#__PURE__*/React.createElement(ImageComponent, null)), /*#__PURE__*/React.createElement(Inline, {
195
197
  alignItems: "spaceBetween",
196
198
  noWrap: true
197
199
  }, /*#__PURE__*/React.createElement(Stack, {
198
200
  space: "xs"
199
201
  }, labelHeader && /*#__PURE__*/React.createElement(H6, null, labelHeader), /*#__PURE__*/React.createElement(Stack, {
200
202
  space: "xxs"
201
- }, /*#__PURE__*/React.createElement(H2, null, header), subHeader && /*#__PURE__*/React.createElement(H4, null, subHeader))), !imageUrl && /*#__PURE__*/React.createElement(ButtonClose, {
203
+ }, /*#__PURE__*/React.createElement(H2, null, header), subHeader && /*#__PURE__*/React.createElement(H4, null, subHeader))), !hasImage && /*#__PURE__*/React.createElement(ButtonClose, {
202
204
  onClick: handleClose
203
205
  })))), /*#__PURE__*/React.createElement(StyledBody, null, children), (actionButton || cancelButtonLabel) && /*#__PURE__*/React.createElement(Footer, null, /*#__PURE__*/React.createElement(ButtonGroup, {
204
206
  actionButton: actionButton,
@@ -1 +1 @@
1
- {"version":3,"file":"Modal.js","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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { HorizontalAlignment, MQ } from \"../../../types\";\nimport { mqValue } from \"../../../shared/mediaQueries\";\nimport { useOnEscapePress } from \"../../../shared/useOnEscapePress\";\nimport { useOutsideClick } from \"../../../shared/useOutsideClick\";\n\nexport type ModalProps = {\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 /** Aspect ratio 16:9 */\n imageUrl?: 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\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 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 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={imageUrl ? [\"s\", \"l\"] : \"zero\"}>\n {imageUrl && (\n <>\n <Inline alignItems=\"right\">\n <ButtonClose onClick={handleClose} />\n </Inline>\n <StyledImg src={imageUrl} />\n </>\n )}\n <Inline alignItems=\"spaceBetween\" noWrap>\n <Stack space=\"xs\">\n {labelHeader && <H6>{labelHeader}</H6>}\n <Stack space=\"xxs\">\n <H2>{header}</H2>\n {subHeader && <H4>{subHeader}</H4>}\n </Stack>\n </Stack>\n {!imageUrl && <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":["defaultModalProps","role","undefined","privateProps","skipPortal","StyledBackdrop","_styled","process","env","NODE_ENV","target","label","_ref","theme","position","top","left","width","height","background","values","color","backdrop","default","display","flexDirection","justifyContent","alignItems","flex","StyledModalWrapper","_ref2","maxWidth","variables","size","dimension","modal","mqValue","spacing","m","StyledInner","maxHeight","overflow","StyledBody","overflowY","StyledImg","aspectRatio","ModalStack","_ref3","children","rest","React","createElement","Stack","_extends","space","ModalText","_ref4","Text","Footer","_ref5","Box","tSpace","Wrapper","_ref6","Fragment","Portal","ButtonClose","_ref7","onClick","Button","variant","leftIcon","Modal","_ref8","header","subHeader","labelHeader","imageUrl","cancelButtonLabel","actionButton","onAction","dataE2eTestId","modalRef","useRef","handleClose","hasBackdropDismiss","useOutsideClick","useOnEscapePress","ref","Container","elevation","bSpace","Inline","src","noWrap","H6","H2","H4","ButtonGroup","cancelButtonText","onButtonClick","defaultProps"],"mappings":"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"}
1
+ {"version":3,"file":"Modal.js","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 { Stack, StackProps } from \"../../Stack/Stack\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { ButtonGroup, ActionButtonProps } from \"../ButtonGroup/ButtonGroup\";\nimport { Button } from \"../../Button/Button\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport { 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=\"xs\">\n {labelHeader && <H6>{labelHeader}</H6>}\n <Stack space=\"xxs\">\n <H2>{header}</H2>\n {subHeader && <H4>{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":["defaultModalProps","role","undefined","privateProps","skipPortal","StyledBackdrop","_styled","process","env","NODE_ENV","target","label","_ref","theme","position","top","left","width","height","background","values","color","backdrop","default","display","flexDirection","justifyContent","alignItems","flex","StyledModalWrapper","_ref2","maxWidth","variables","size","dimension","modal","mqValue","spacing","m","StyledInner","maxHeight","overflow","StyledBody","overflowY","StyledImg","aspectRatio","ModalStack","_ref3","children","rest","React","createElement","Stack","_extends","space","ModalText","_ref4","Text","Footer","_ref5","Box","tSpace","Wrapper","_ref6","Fragment","Portal","ButtonClose","_ref7","onClick","Button","variant","leftIcon","Modal","_ref8","header","subHeader","labelHeader","imageUrl","ImageComponent","cancelButtonLabel","actionButton","onAction","dataE2eTestId","modalRef","useRef","handleClose","hasBackdropDismiss","useOutsideClick","useOnEscapePress","hasImage","ref","Container","elevation","bSpace","Inline","src","noWrap","H6","H2","H4","ButtonGroup","cancelButtonText","onButtonClick","defaultProps"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@amboss/design-system",
3
- "version": "1.17.1",
3
+ "version": "1.17.2",
4
4
  "description": "the design system for AMBOSS products",
5
5
  "author": "Bagrat Gobedashvili",
6
6
  "license": "ISC",