@amboss/design-system 3.43.0 → 3.43.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cjs/components/Content/ContentTableModal/ContentTableModal.d.ts +16 -0
- package/build/cjs/components/Content/ContentTableModal/ContentTableModal.js +10 -0
- package/build/cjs/components/Content/ContentTableModal/ContentTableModal.mocks.d.ts +3 -0
- package/build/cjs/components/Content/ContentTableModal/ContentTableModal.mocks.js +1 -0
- package/build/cjs/components/RoundButton/RoundButton.js +1 -1
- package/build/cjs/components/Utilities/AnimatedBorder/useAnimatedBorder.js +2 -7
- package/build/cjs/index.d.ts +1 -0
- package/build/cjs/index.js +1 -1
- package/build/esm/components/Content/ContentTableModal/ContentTableModal.d.ts +16 -0
- package/build/esm/components/Content/ContentTableModal/ContentTableModal.js +10 -0
- package/build/esm/components/Content/ContentTableModal/ContentTableModal.mocks.d.ts +3 -0
- package/build/esm/components/Content/ContentTableModal/ContentTableModal.mocks.js +1 -0
- package/build/esm/components/RoundButton/RoundButton.js +1 -1
- package/build/esm/components/Utilities/AnimatedBorder/useAnimatedBorder.js +2 -7
- package/build/esm/index.d.ts +1 -0
- package/build/esm/index.js +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import React, { type AriaAttributes } from "react";
|
|
2
|
+
import type { ModalProps } from "src/components/Patterns/Modal/Modal";
|
|
3
|
+
/** Either aria-label or aria-labelledby must be provided for accessibility */
|
|
4
|
+
type LabelProps = {
|
|
5
|
+
"aria-label": AriaAttributes["aria-label"];
|
|
6
|
+
"aria-labelledby"?: AriaAttributes["aria-label"];
|
|
7
|
+
} | {
|
|
8
|
+
"aria-label"?: AriaAttributes["aria-label"];
|
|
9
|
+
"aria-labelledby": AriaAttributes["aria-label"];
|
|
10
|
+
};
|
|
11
|
+
export type ContentTableModalProps = Pick<ModalProps, "role" | "onAction" | "portalContainer" | "initialFocus" | "closeButtonAriaLabel" | "data-e2e-test-id" | "children"> & LabelProps & {
|
|
12
|
+
tableControls?: React.ReactElement;
|
|
13
|
+
"aria-describedby"?: AriaAttributes["aria-describedby"];
|
|
14
|
+
};
|
|
15
|
+
export declare function ContentTableModal({ children, role, onAction, portalContainer, closeButtonAriaLabel, "data-e2e-test-id": dataE2eTestId, initialFocus, tableControls, "aria-label": ariaLabel, "aria-describedby": ariaDescribedBy, ...restAriaAttributes }: ContentTableModalProps): React.ReactElement;
|
|
16
|
+
export {};
|
|
@@ -0,0 +1,10 @@
|
|
|
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)`
|
|
2
|
+
from {
|
|
3
|
+
opacity: ${theme.variables.opacity.hidden};
|
|
4
|
+
transform: translateY(20px);
|
|
5
|
+
}
|
|
6
|
+
to {
|
|
7
|
+
opacity: ${theme.variables.opacity.visible};
|
|
8
|
+
transform: translateY(0);
|
|
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))))))))}
|