@amboss/design-system 3.43.2 → 3.43.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,6 @@
1
1
  import React, { type AriaAttributes } from "react";
2
2
  import type { ModalProps } from "src/components/Patterns/Modal/Modal";
3
+ import type { PickPreserveOptional } from "../../../shared/typeUtils";
3
4
  /** Either aria-label or aria-labelledby must be provided for accessibility */
4
5
  type LabelProps = {
5
6
  "aria-label": AriaAttributes["aria-label"];
@@ -8,7 +9,7 @@ type LabelProps = {
8
9
  "aria-label"?: AriaAttributes["aria-label"];
9
10
  "aria-labelledby": AriaAttributes["aria-label"];
10
11
  };
11
- export type ContentTableModalProps = Pick<ModalProps, "role" | "onAction" | "portalContainer" | "initialFocus" | "closeButtonAriaLabel" | "data-e2e-test-id" | "children"> & LabelProps & {
12
+ export type ContentTableModalProps = PickPreserveOptional<ModalProps, "role" | "onAction" | "portalContainer" | "initialFocus" | "closeButtonAriaLabel" | "data-e2e-test-id" | "children"> & LabelProps & {
12
13
  tableControls?: React.ReactElement;
13
14
  "aria-describedby"?: AriaAttributes["aria-describedby"];
14
15
  };
@@ -1,4 +1,4 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ContentTableModal",{enumerable:!0,get:function(){return ContentTableModal}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_react1=require("@emotion/react"),_Container=require("../../Container/Container"),_Box=require("../../Box/Box"),_Inline=require("../../Inline/Inline"),_PictogramButton=require("../../PictogramButton/PictogramButton"),_mediaQueries=require("../../../shared/mediaQueries"),_useScrollDetection=require("../../../shared/useScrollDetection"),_Lightbox=require("../../Lightbox/Lightbox"),getDesktopSpace=theme=>theme.variables.size.spacing.l,getDesktopInnerSpace=theme=>theme.variables.size.spacing.xl,getMobileSpace=theme=>theme.variables.size.spacing.m,getMobileInnerSpace=theme=>theme.variables.size.spacing.m,StyledModalWrapper=(0,_styled.default)("div",{target:"e1ddpmuw0",label:"StyledModalWrapper"})(({theme})=>{let fadeInModal=(0,_react.useMemo)(()=>(0,_react1.keyframes)`
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ContentTableModal",{enumerable:!0,get:function(){return ContentTableModal}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_react1=require("@emotion/react"),_Container=require("../../Container/Container"),_Box=require("../../Box/Box"),_Inline=require("../../Inline/Inline"),_PictogramButton=require("../../PictogramButton/PictogramButton"),_mediaQueries=require("../../../shared/mediaQueries"),_useScrollDetection=require("../../../shared/useScrollDetection"),_Lightbox=require("../../Lightbox/Lightbox"),getDesktopSpace=theme=>theme.variables.size.spacing.l,getDesktopInnerSpace=theme=>theme.variables.size.spacing.xl,getMobileSpace=theme=>theme.variables.size.spacing.m,getMobileInnerSpace=theme=>theme.variables.size.spacing.m,StyledModalWrapper=(0,_styled.default)("div",{target:"e1dr36f60",label:"StyledModalWrapper"})(({theme})=>{let fadeInModal=(0,_react.useMemo)(()=>(0,_react1.keyframes)`
2
2
  from {
3
3
  opacity: ${theme.variables.opacity.hidden};
4
4
  transform: translateY(20px);
@@ -7,4 +7,4 @@
7
7
  opacity: ${theme.variables.opacity.visible};
8
8
  transform: translateY(0);
9
9
  }
10
- `,[theme.variables.opacity.hidden,theme.variables.opacity.visible]);return{animation:`${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,"&:focus":{outline:"none"},...(0,_mediaQueries.useResponsiveValue)({width:[`calc(100% - ${getMobileSpace(theme)} * 2)`,"auto"],maxWidth:[`calc(100% - ${getMobileSpace(theme)} * 2)`,`calc(100% - ${getDesktopSpace(theme)} * 2)`]})}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = Pick<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AAwB2B"} */"),StyledInner=(0,_styled.default)("div",{target:"e1ddpmuw1",label:"StyledInner"})(({theme})=>{let mobileVerticalSpace=getMobileSpace(theme),mobileInnerVerticalSpace=getMobileInnerSpace(theme),desktopVerticalSpace=getDesktopSpace(theme),desktopInnerVerticalSpace=getDesktopInnerSpace(theme),fullScreenMobile=`calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;return{display:"flex",...(0,_mediaQueries.useResponsiveValue)({height:[fullScreenMobile,"auto"],maxHeight:[fullScreenMobile,`calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`]}),flexDirection:"column",overflow:"hidden"}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = Pick<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AAoDoB"} */"),StyledBody=(0,_styled.default)("div",{target:"e1ddpmuw2",label:"StyledBody"})(({theme,borderTop})=>({height:"auto",overflowY:"auto",maxHeight:"100%",flex:1,...borderTop&&{borderTop:`1px solid ${theme.values.color.divider.primary}`}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = Pick<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AAiFmB"} */"),StyledMaxWidth=(0,_styled.default)("div",{target:"e1ddpmuw3",label:"StyledMaxWidth"})(({theme})=>({maxWidth:theme.variables.size.dimension.modal.fullScreenContentWidth,margin:"0 auto",height:"100%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = Pick<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AA4FuB"} */"),HorizontalOffset=({children,height})=>_react.default.createElement(_Box.Box,{space:["m","xl"],vSpace:"zero",height:height},_react.default.createElement(StyledMaxWidth,null,children));function ContentTableModal({children,role="dialog",onAction,portalContainer,closeButtonAriaLabel="Dismiss Dialog","data-e2e-test-id":dataE2eTestId,initialFocus,tableControls=_react.default.createElement("div",null),"aria-label":ariaLabel,"aria-describedby":ariaDescribedBy,...restAriaAttributes}){let backdropRef=(0,_react.useRef)(null),{scrollableRef,isScrollTop,hasScroll}=(0,_useScrollDetection.useScrollDetection)(),handleClose=()=>{onAction("cancel")},closeButton=_react.default.createElement(_PictogramButton.PictogramButton,{variant:"tertiary",icon:"x",size:"s",onClick:handleClose,"aria-label":closeButtonAriaLabel,"data-modal-close-btn":!0});return _react.default.createElement(_Lightbox.Lightbox,{backdropRef:backdropRef,portalContainer:portalContainer,handleClose:handleClose,isDismissible:!0,initialFocus:initialFocus},_react.default.createElement(StyledModalWrapper,{role:role,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"ContentTableModal","aria-label":ariaLabel,"aria-describedby":ariaDescribedBy,...restAriaAttributes,"aria-modal":"true",tabIndex:-1},_react.default.createElement(_Container.Container,{elevation:4},_react.default.createElement(_Box.Box,{space:"zero",vSpace:["m","xl"],bSpace:"xs"},_react.default.createElement(StyledInner,null,_react.default.createElement(HorizontalOffset,null,_react.default.createElement(_Box.Box,{space:"zero",bSpace:"xxs"},_react.default.createElement(_Inline.Inline,{alignItems:"spaceBetween"},tableControls,closeButton))),_react.default.createElement(StyledBody,{ref:scrollableRef,borderTop:hasScroll&&!isScrollTop},_react.default.createElement(_Box.Box,{space:"zero",vSpace:"xxxs",height:"100%"},_react.default.createElement(HorizontalOffset,{height:"100%"},children))))))))}
10
+ `,[theme.variables.opacity.hidden,theme.variables.opacity.visible]);return{animation:`${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,"&:focus":{outline:"none"},...(0,_mediaQueries.useResponsiveValue)({width:[`calc(100% - ${getMobileSpace(theme)} * 2)`,"auto"],maxWidth:[`calc(100% - ${getMobileSpace(theme)} * 2)`,`calc(100% - ${getDesktopSpace(theme)} * 2)`]})}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\nimport type { PickPreserveOptional } from \"../../../shared/typeUtils\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = PickPreserveOptional<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AAyB2B"} */"),StyledInner=(0,_styled.default)("div",{target:"e1dr36f61",label:"StyledInner"})(({theme})=>{let mobileVerticalSpace=getMobileSpace(theme),mobileInnerVerticalSpace=getMobileInnerSpace(theme),desktopVerticalSpace=getDesktopSpace(theme),desktopInnerVerticalSpace=getDesktopInnerSpace(theme),fullScreenMobile=`calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;return{display:"flex",...(0,_mediaQueries.useResponsiveValue)({height:[fullScreenMobile,"auto"],maxHeight:[fullScreenMobile,`calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`]}),flexDirection:"column",overflow:"hidden"}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\nimport type { PickPreserveOptional } from \"../../../shared/typeUtils\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = PickPreserveOptional<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AAqDoB"} */"),StyledBody=(0,_styled.default)("div",{target:"e1dr36f62",label:"StyledBody"})(({theme,borderTop})=>({height:"auto",overflowY:"auto",maxHeight:"100%",flex:1,...borderTop&&{borderTop:`1px solid ${theme.values.color.divider.primary}`}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\nimport type { PickPreserveOptional } from \"../../../shared/typeUtils\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = PickPreserveOptional<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AAkFmB"} */"),StyledMaxWidth=(0,_styled.default)("div",{target:"e1dr36f63",label:"StyledMaxWidth"})(({theme})=>({maxWidth:theme.variables.size.dimension.modal.fullScreenContentWidth,margin:"0 auto",height:"100%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\nimport type { PickPreserveOptional } from \"../../../shared/typeUtils\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = PickPreserveOptional<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AA6FuB"} */"),HorizontalOffset=({children,height})=>_react.default.createElement(_Box.Box,{space:["m","xl"],vSpace:"zero",height:height},_react.default.createElement(StyledMaxWidth,null,children));function ContentTableModal({children,role="dialog",onAction,portalContainer,closeButtonAriaLabel="Dismiss Dialog","data-e2e-test-id":dataE2eTestId,initialFocus,tableControls=_react.default.createElement("div",null),"aria-label":ariaLabel,"aria-describedby":ariaDescribedBy,...restAriaAttributes}){let backdropRef=(0,_react.useRef)(null),{scrollableRef,isScrollTop,hasScroll}=(0,_useScrollDetection.useScrollDetection)(),handleClose=()=>{onAction("cancel")},closeButton=_react.default.createElement(_PictogramButton.PictogramButton,{variant:"tertiary",icon:"x",size:"s",onClick:handleClose,"aria-label":closeButtonAriaLabel,"data-modal-close-btn":!0});return _react.default.createElement(_Lightbox.Lightbox,{backdropRef:backdropRef,portalContainer:portalContainer,handleClose:handleClose,isDismissible:!0,initialFocus:initialFocus},_react.default.createElement(StyledModalWrapper,{role:role,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"ContentTableModal","aria-label":ariaLabel,"aria-describedby":ariaDescribedBy,...restAriaAttributes,"aria-modal":"true",tabIndex:-1},_react.default.createElement(_Container.Container,{elevation:4},_react.default.createElement(_Box.Box,{space:"zero",vSpace:["m","xl"],bSpace:"xs"},_react.default.createElement(StyledInner,null,_react.default.createElement(HorizontalOffset,null,_react.default.createElement(_Box.Box,{space:"zero",bSpace:"xxs"},_react.default.createElement(_Inline.Inline,{alignItems:"spaceBetween"},tableControls,closeButton))),_react.default.createElement(StyledBody,{ref:scrollableRef,borderTop:hasScroll&&!isScrollTop},_react.default.createElement(_Box.Box,{space:"zero",vSpace:"xxxs",height:"100%"},_react.default.createElement(HorizontalOffset,{height:"100%"},children))))))))}
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Keys of `T` that are optional (`?`) at the type level.
3
+ */
4
+ export type OptionalKeys<T> = {
5
+ [K in keyof T]-?: Pick<T, K> extends Required<Pick<T, K>> ? never : K;
6
+ }[keyof T];
7
+ /**
8
+ * Like `Pick<T, K>` but guarantees that any keys that are optional in `T`
9
+ * remain optional in the resulting type.
10
+ *
11
+ * This is useful when `T` is a complex intersection/union and downstream tooling
12
+ * ends up treating some picked optional props as required.
13
+ */
14
+ export type PickPreserveOptional<T, K extends keyof T> = {
15
+ [Key in Extract<K, OptionalKeys<T>>]?: T[Key];
16
+ } & {
17
+ [Key in Exclude<K, OptionalKeys<T>>]: T[Key];
18
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});
@@ -1,5 +1,6 @@
1
1
  import React, { type AriaAttributes } from "react";
2
2
  import type { ModalProps } from "src/components/Patterns/Modal/Modal";
3
+ import type { PickPreserveOptional } from "../../../shared/typeUtils";
3
4
  /** Either aria-label or aria-labelledby must be provided for accessibility */
4
5
  type LabelProps = {
5
6
  "aria-label": AriaAttributes["aria-label"];
@@ -8,7 +9,7 @@ type LabelProps = {
8
9
  "aria-label"?: AriaAttributes["aria-label"];
9
10
  "aria-labelledby": AriaAttributes["aria-label"];
10
11
  };
11
- export type ContentTableModalProps = Pick<ModalProps, "role" | "onAction" | "portalContainer" | "initialFocus" | "closeButtonAriaLabel" | "data-e2e-test-id" | "children"> & LabelProps & {
12
+ export type ContentTableModalProps = PickPreserveOptional<ModalProps, "role" | "onAction" | "portalContainer" | "initialFocus" | "closeButtonAriaLabel" | "data-e2e-test-id" | "children"> & LabelProps & {
12
13
  tableControls?: React.ReactElement;
13
14
  "aria-describedby"?: AriaAttributes["aria-describedby"];
14
15
  };
@@ -1,4 +1,4 @@
1
- import React,{useMemo,useRef}from"react";import styled from"@emotion/styled";import{keyframes}from"@emotion/react";import{Container}from"../../Container/Container";import{Box}from"../../Box/Box";import{Inline}from"../../Inline/Inline";import{PictogramButton}from"../../PictogramButton/PictogramButton";import{useResponsiveValue}from"../../../shared/mediaQueries";import{useScrollDetection}from"../../../shared/useScrollDetection";import{Lightbox}from"../../Lightbox/Lightbox";let getDesktopSpace=theme=>theme.variables.size.spacing.l,getDesktopInnerSpace=theme=>theme.variables.size.spacing.xl,getMobileSpace=theme=>theme.variables.size.spacing.m,getMobileInnerSpace=theme=>theme.variables.size.spacing.m,StyledModalWrapper=styled("div",{target:"e1ddpmuw0",label:"StyledModalWrapper"})(({theme})=>{let fadeInModal=useMemo(()=>keyframes`
1
+ import React,{useMemo,useRef}from"react";import styled from"@emotion/styled";import{keyframes}from"@emotion/react";import{Container}from"../../Container/Container";import{Box}from"../../Box/Box";import{Inline}from"../../Inline/Inline";import{PictogramButton}from"../../PictogramButton/PictogramButton";import{useResponsiveValue}from"../../../shared/mediaQueries";import{useScrollDetection}from"../../../shared/useScrollDetection";import{Lightbox}from"../../Lightbox/Lightbox";let getDesktopSpace=theme=>theme.variables.size.spacing.l,getDesktopInnerSpace=theme=>theme.variables.size.spacing.xl,getMobileSpace=theme=>theme.variables.size.spacing.m,getMobileInnerSpace=theme=>theme.variables.size.spacing.m,StyledModalWrapper=styled("div",{target:"e1dr36f60",label:"StyledModalWrapper"})(({theme})=>{let fadeInModal=useMemo(()=>keyframes`
2
2
  from {
3
3
  opacity: ${theme.variables.opacity.hidden};
4
4
  transform: translateY(20px);
@@ -7,4 +7,4 @@ import React,{useMemo,useRef}from"react";import styled from"@emotion/styled";imp
7
7
  opacity: ${theme.variables.opacity.visible};
8
8
  transform: translateY(0);
9
9
  }
10
- `,[theme.variables.opacity.hidden,theme.variables.opacity.visible]);return{animation:`${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,"&:focus":{outline:"none"},...useResponsiveValue({width:[`calc(100% - ${getMobileSpace(theme)} * 2)`,"auto"],maxWidth:[`calc(100% - ${getMobileSpace(theme)} * 2)`,`calc(100% - ${getDesktopSpace(theme)} * 2)`]})}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = Pick<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AAwB2B"} */"),StyledInner=styled("div",{target:"e1ddpmuw1",label:"StyledInner"})(({theme})=>{let mobileVerticalSpace=getMobileSpace(theme),mobileInnerVerticalSpace=getMobileInnerSpace(theme),desktopVerticalSpace=getDesktopSpace(theme),desktopInnerVerticalSpace=getDesktopInnerSpace(theme),fullScreenMobile=`calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;return{display:"flex",...useResponsiveValue({height:[fullScreenMobile,"auto"],maxHeight:[fullScreenMobile,`calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`]}),flexDirection:"column",overflow:"hidden"}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = Pick<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AAoDoB"} */"),StyledBody=styled("div",{target:"e1ddpmuw2",label:"StyledBody"})(({theme,borderTop})=>({height:"auto",overflowY:"auto",maxHeight:"100%",flex:1,...borderTop&&{borderTop:`1px solid ${theme.values.color.divider.primary}`}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = Pick<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AAiFmB"} */"),StyledMaxWidth=styled("div",{target:"e1ddpmuw3",label:"StyledMaxWidth"})(({theme})=>({maxWidth:theme.variables.size.dimension.modal.fullScreenContentWidth,margin:"0 auto",height:"100%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = Pick<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AA4FuB"} */"),HorizontalOffset=({children,height})=>React.createElement(Box,{space:["m","xl"],vSpace:"zero",height:height},React.createElement(StyledMaxWidth,null,children));export function ContentTableModal({children,role="dialog",onAction,portalContainer,closeButtonAriaLabel="Dismiss Dialog","data-e2e-test-id":dataE2eTestId,initialFocus,tableControls=React.createElement("div",null),"aria-label":ariaLabel,"aria-describedby":ariaDescribedBy,...restAriaAttributes}){let backdropRef=useRef(null),{scrollableRef,isScrollTop,hasScroll}=useScrollDetection(),handleClose=()=>{onAction("cancel")},closeButton=React.createElement(PictogramButton,{variant:"tertiary",icon:"x",size:"s",onClick:handleClose,"aria-label":closeButtonAriaLabel,"data-modal-close-btn":!0});return React.createElement(Lightbox,{backdropRef:backdropRef,portalContainer:portalContainer,handleClose:handleClose,isDismissible:!0,initialFocus:initialFocus},React.createElement(StyledModalWrapper,{role:role,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"ContentTableModal","aria-label":ariaLabel,"aria-describedby":ariaDescribedBy,...restAriaAttributes,"aria-modal":"true",tabIndex:-1},React.createElement(Container,{elevation:4},React.createElement(Box,{space:"zero",vSpace:["m","xl"],bSpace:"xs"},React.createElement(StyledInner,null,React.createElement(HorizontalOffset,null,React.createElement(Box,{space:"zero",bSpace:"xxs"},React.createElement(Inline,{alignItems:"spaceBetween"},tableControls,closeButton))),React.createElement(StyledBody,{ref:scrollableRef,borderTop:hasScroll&&!isScrollTop},React.createElement(Box,{space:"zero",vSpace:"xxxs",height:"100%"},React.createElement(HorizontalOffset,{height:"100%"},children))))))))}
10
+ `,[theme.variables.opacity.hidden,theme.variables.opacity.visible]);return{animation:`${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,"&:focus":{outline:"none"},...useResponsiveValue({width:[`calc(100% - ${getMobileSpace(theme)} * 2)`,"auto"],maxWidth:[`calc(100% - ${getMobileSpace(theme)} * 2)`,`calc(100% - ${getDesktopSpace(theme)} * 2)`]})}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\nimport type { PickPreserveOptional } from \"../../../shared/typeUtils\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = PickPreserveOptional<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AAyB2B"} */"),StyledInner=styled("div",{target:"e1dr36f61",label:"StyledInner"})(({theme})=>{let mobileVerticalSpace=getMobileSpace(theme),mobileInnerVerticalSpace=getMobileInnerSpace(theme),desktopVerticalSpace=getDesktopSpace(theme),desktopInnerVerticalSpace=getDesktopInnerSpace(theme),fullScreenMobile=`calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;return{display:"flex",...useResponsiveValue({height:[fullScreenMobile,"auto"],maxHeight:[fullScreenMobile,`calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`]}),flexDirection:"column",overflow:"hidden"}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\nimport type { PickPreserveOptional } from \"../../../shared/typeUtils\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = PickPreserveOptional<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AAqDoB"} */"),StyledBody=styled("div",{target:"e1dr36f62",label:"StyledBody"})(({theme,borderTop})=>({height:"auto",overflowY:"auto",maxHeight:"100%",flex:1,...borderTop&&{borderTop:`1px solid ${theme.values.color.divider.primary}`}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\nimport type { PickPreserveOptional } from \"../../../shared/typeUtils\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = PickPreserveOptional<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AAkFmB"} */"),StyledMaxWidth=styled("div",{target:"e1dr36f63",label:"StyledMaxWidth"})(({theme})=>({maxWidth:theme.variables.size.dimension.modal.fullScreenContentWidth,margin:"0 auto",height:"100%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Content/ContentTableModal/ContentTableModal.tsx","sources":["src/components/Content/ContentTableModal/ContentTableModal.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\n/* eslint-disable react/jsx-no-useless-fragment */\nimport React, { useMemo, useRef, type AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { Theme } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport type { ModalProps } from \"src/components/Patterns/Modal/Modal\";\nimport { Container } from \"../../Container/Container\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { PictogramButton } from \"../../PictogramButton/PictogramButton\";\nimport { useResponsiveValue } from \"../../../shared/mediaQueries\";\nimport { useScrollDetection } from \"../../../shared/useScrollDetection\";\nimport { Lightbox } from \"../../Lightbox/Lightbox\";\nimport type { PickPreserveOptional } from \"../../../shared/typeUtils\";\n\nconst mobileSize = \"m\";\nconst desktopSize = \"xl\";\nconst getDesktopSpace = (theme: Theme) => theme.variables.size.spacing.l;\nconst getDesktopInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[desktopSize];\nconst getMobileSpace = (theme: Theme) => theme.variables.size.spacing.m;\nconst getMobileInnerSpace = (theme: Theme) =>\n  theme.variables.size.spacing[mobileSize];\n\nconst StyledModalWrapper = styled.div(({ theme }) => {\n  const fadeInModal = useMemo(\n    () =>\n      keyframes`\n      from {\n        opacity: ${theme.variables.opacity.hidden};\n        transform: translateY(20px);\n      }\n      to {\n          opacity: ${theme.variables.opacity.visible};\n        transform: translateY(0);\n      }\n    `,\n    [theme.variables.opacity.hidden, theme.variables.opacity.visible]\n  );\n  return {\n    animation: `${fadeInModal} ${theme.variables.animation.modal.open.duration} ${theme.variables.animation.modal.open.delay} ${theme.variables.animation.modal.open.timingFunction} both`,\n    \"&:focus\": { outline: \"none\" },\n    ...useResponsiveValue({\n      width: [`calc(100% - ${getMobileSpace(theme)} * 2)`, \"auto\"],\n      maxWidth: [\n        `calc(100% - ${getMobileSpace(theme)} * 2)`,\n        `calc(100% - ${getDesktopSpace(theme)} * 2)`,\n      ],\n    }),\n  };\n});\n\nconst StyledInner = styled.div(({ theme }) => {\n  const mobileVerticalSpace = getMobileSpace(theme);\n  const mobileInnerVerticalSpace = getMobileInnerSpace(theme);\n  const desktopVerticalSpace = getDesktopSpace(theme);\n  const desktopInnerVerticalSpace = getDesktopInnerSpace(theme);\n\n  const getDesktopHeight = () => \"auto\";\n\n  const getDesktopMaxHeight = () =>\n    `calc(100dvh - ${desktopVerticalSpace} * 2 - ${desktopInnerVerticalSpace} * 2)`;\n\n  const fullScreenMobile = `calc(100dvh - ${mobileVerticalSpace} * 2 - ${mobileInnerVerticalSpace} * 2)`;\n\n  return {\n    display: \"flex\",\n    ...useResponsiveValue({\n      height: [fullScreenMobile, getDesktopHeight()],\n      maxHeight: [fullScreenMobile, getDesktopMaxHeight()],\n    }),\n\n    flexDirection: \"column\",\n    overflow: \"hidden\",\n  };\n});\n\ntype StyledBodyProps = {\n  borderTop: boolean;\n};\n\nconst StyledBody = styled.div<StyledBodyProps>(({ theme, borderTop }) => ({\n  height: \"auto\",\n  overflowY: \"auto\",\n  maxHeight: \"100%\",\n  flex: 1,\n\n  ...(borderTop && {\n    borderTop: `1px solid ${theme.values.color.divider.primary}`,\n  }),\n}));\n\nconst StyledMaxWidth = styled.div(({ theme }) => ({\n  maxWidth: theme.variables.size.dimension.modal.fullScreenContentWidth,\n  margin: \"0 auto\",\n  height: \"100%\",\n}));\n\nconst HorizontalOffset = ({\n  children,\n  height,\n}: {\n  children: React.ReactNode;\n  height?: string;\n}) => (\n  <Box space={[mobileSize, desktopSize]} vSpace=\"zero\" height={height}>\n    <StyledMaxWidth>{children}</StyledMaxWidth>\n  </Box>\n);\n\n/** Either aria-label or aria-labelledby must be provided for accessibility */\ntype LabelProps =\n  | {\n      \"aria-label\": AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\"?: AriaAttributes[\"aria-label\"];\n    }\n  | {\n      \"aria-label\"?: AriaAttributes[\"aria-label\"];\n      \"aria-labelledby\": AriaAttributes[\"aria-label\"];\n    };\n\nexport type ContentTableModalProps = PickPreserveOptional<\n  ModalProps,\n  | \"role\"\n  | \"onAction\"\n  | \"portalContainer\"\n  | \"initialFocus\"\n  | \"closeButtonAriaLabel\"\n  | \"data-e2e-test-id\"\n  | \"children\"\n> &\n  LabelProps & {\n    tableControls?: React.ReactElement;\n    \"aria-describedby\"?: AriaAttributes[\"aria-describedby\"];\n  };\n\nexport function ContentTableModal({\n  children,\n  role = \"dialog\",\n  onAction,\n  portalContainer,\n  closeButtonAriaLabel = \"Dismiss Dialog\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  initialFocus,\n  tableControls = <div />,\n  \"aria-label\": ariaLabel,\n  \"aria-describedby\": ariaDescribedBy,\n  ...restAriaAttributes\n}: ContentTableModalProps): React.ReactElement {\n  const backdropRef = useRef(null);\n  const { scrollableRef, isScrollTop, hasScroll } = useScrollDetection();\n\n  const handleClose = () => {\n    onAction(\"cancel\");\n  };\n\n  const closeButton = (\n    <PictogramButton\n      variant=\"tertiary\"\n      icon=\"x\"\n      size=\"s\"\n      onClick={handleClose}\n      aria-label={closeButtonAriaLabel}\n      data-modal-close-btn\n    />\n  );\n\n  return (\n    <Lightbox\n      backdropRef={backdropRef}\n      portalContainer={portalContainer}\n      handleClose={handleClose}\n      isDismissible\n      initialFocus={initialFocus}\n    >\n      <StyledModalWrapper\n        role={role}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"ContentTableModal\"\n        aria-label={ariaLabel}\n        aria-describedby={ariaDescribedBy}\n        {...restAriaAttributes}\n        aria-modal=\"true\"\n        tabIndex={-1}\n      >\n        <Container elevation={4}>\n          <Box space=\"zero\" vSpace={[mobileSize, desktopSize]} bSpace=\"xs\">\n            <StyledInner>\n              <HorizontalOffset>\n                <Box space=\"zero\" bSpace=\"xxs\">\n                  <Inline alignItems=\"spaceBetween\">\n                    {tableControls}\n                    {closeButton}\n                  </Inline>\n                </Box>\n              </HorizontalOffset>\n              <StyledBody\n                ref={scrollableRef}\n                borderTop={hasScroll && !isScrollTop}\n              >\n                <Box space=\"zero\" vSpace=\"xxxs\" height=\"100%\">\n                  <HorizontalOffset height=\"100%\">{children}</HorizontalOffset>\n                </Box>\n              </StyledBody>\n            </StyledInner>\n          </Box>\n        </Container>\n      </StyledModalWrapper>\n    </Lightbox>\n  );\n}\n"],"names":[],"mappings":"AA6FuB"} */"),HorizontalOffset=({children,height})=>React.createElement(Box,{space:["m","xl"],vSpace:"zero",height:height},React.createElement(StyledMaxWidth,null,children));export function ContentTableModal({children,role="dialog",onAction,portalContainer,closeButtonAriaLabel="Dismiss Dialog","data-e2e-test-id":dataE2eTestId,initialFocus,tableControls=React.createElement("div",null),"aria-label":ariaLabel,"aria-describedby":ariaDescribedBy,...restAriaAttributes}){let backdropRef=useRef(null),{scrollableRef,isScrollTop,hasScroll}=useScrollDetection(),handleClose=()=>{onAction("cancel")},closeButton=React.createElement(PictogramButton,{variant:"tertiary",icon:"x",size:"s",onClick:handleClose,"aria-label":closeButtonAriaLabel,"data-modal-close-btn":!0});return React.createElement(Lightbox,{backdropRef:backdropRef,portalContainer:portalContainer,handleClose:handleClose,isDismissible:!0,initialFocus:initialFocus},React.createElement(StyledModalWrapper,{role:role,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"ContentTableModal","aria-label":ariaLabel,"aria-describedby":ariaDescribedBy,...restAriaAttributes,"aria-modal":"true",tabIndex:-1},React.createElement(Container,{elevation:4},React.createElement(Box,{space:"zero",vSpace:["m","xl"],bSpace:"xs"},React.createElement(StyledInner,null,React.createElement(HorizontalOffset,null,React.createElement(Box,{space:"zero",bSpace:"xxs"},React.createElement(Inline,{alignItems:"spaceBetween"},tableControls,closeButton))),React.createElement(StyledBody,{ref:scrollableRef,borderTop:hasScroll&&!isScrollTop},React.createElement(Box,{space:"zero",vSpace:"xxxs",height:"100%"},React.createElement(HorizontalOffset,{height:"100%"},children))))))))}
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Keys of `T` that are optional (`?`) at the type level.
3
+ */
4
+ export type OptionalKeys<T> = {
5
+ [K in keyof T]-?: Pick<T, K> extends Required<Pick<T, K>> ? never : K;
6
+ }[keyof T];
7
+ /**
8
+ * Like `Pick<T, K>` but guarantees that any keys that are optional in `T`
9
+ * remain optional in the resulting type.
10
+ *
11
+ * This is useful when `T` is a complex intersection/union and downstream tooling
12
+ * ends up treating some picked optional props as required.
13
+ */
14
+ export type PickPreserveOptional<T, K extends keyof T> = {
15
+ [Key in Extract<K, OptionalKeys<T>>]?: T[Key];
16
+ } & {
17
+ [Key in Exclude<K, OptionalKeys<T>>]: T[Key];
18
+ };
@@ -0,0 +1 @@
1
+ export{};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@amboss/design-system",
3
- "version": "3.43.2",
3
+ "version": "3.43.3",
4
4
  "description": "the design system for AMBOSS products",
5
5
  "author": "AMBOSS",
6
6
  "license": "ISC",