@amboss/design-system 3.9.9 → 3.9.10

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 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"CatalogCard",{enumerable:!0,get:function(){return CatalogCard}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Container=require("../Container/Container"),_DropdownMenu=require("../DropdownMenu/DropdownMenu"),_Box=require("../Box/Box"),_Columns=require("../Column/Columns"),_Inline=require("../Inline/Inline"),_Stack=require("../Stack/Stack"),_TextClamped=require("../Typography/TextClamped/TextClamped"),_breakpointsjson=/*#__PURE__*/_interop_require_default._(require("../../web-tokens/_breakpoints.json")),StyledDropdownMenuContainer=(0,_styled.default)("div",{target:"e1qd7sd30",label:"StyledDropdownMenuContainer"})(({isMobile,theme})=>({marginRight:`-${theme.variables.size.spacing.xs}`,marginTop:`-${theme.variables.size.spacing.xs}`,pointerEvents:"auto",visibility:isMobile?"visible":"collapse"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    outlineWidth: 2,\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n    outlineOffset: -1,\n    borderRadius: theme.variables.size.borderRadius.s,\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n\n      [`${StyledDropdownMenuContainer}`]: {\n        visibility: \"visible\",\n      },\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAYoC"} */"),StyledWrapper=(0,_styled.default)("div",{target:"e1qd7sd31",label:"StyledWrapper"})(({theme})=>({position:"relative",height:"100%","> div":{height:"100%"},"&:focus-within":{outlineWidth:2,outlineStyle:"solid",outlineColor:"Highlight",outlineOffset:-1,borderRadius:theme.variables.size.borderRadius.s,[`${StyledDropdownMenuContainer}`]:{visibility:"visible"}},"@media (-webkit-min-device-pixel-ratio:0)":{"&:focus-within":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"solid",borderRadius:theme.variables.size.borderRadius.s,[`${StyledDropdownMenuContainer}`]:{visibility:"visible"}}},"&:hover":{"> div":{boxShadow:theme.values.elevation[2]}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    outlineWidth: 2,\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n    outlineOffset: -1,\n    borderRadius: theme.variables.size.borderRadius.s,\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n\n      [`${StyledDropdownMenuContainer}`]: {\n        visibility: \"visible\",\n      },\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAqBsB"} */"),StyledContainer=(0,_styled.default)("div",{target:"e1qd7sd32",label:"StyledContainer"})(({isMobile})=>({display:"flex",minHeight:"102px",cursor:"pointer",position:"relative",height:"100%",alignItems:"end",[`${StyledDropdownMenuContainer}`]:{visibility:isMobile?"visible":"collapse"},"> div":{width:"100%"},"&:hover":{[`${StyledDropdownMenuContainer}`]:{visibility:"visible"}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    outlineWidth: 2,\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n    outlineOffset: -1,\n    borderRadius: theme.variables.size.borderRadius.s,\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n\n      [`${StyledDropdownMenuContainer}`]: {\n        visibility: \"visible\",\n      },\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AA4DwB"} */"),StyledButton=(0,_styled.default)("button",{target:"e1qd7sd33",label:"StyledButton"})({position:"absolute",top:0,left:0,width:"1px",height:"1px",opacity:0,border:"none"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    outlineWidth: 2,\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n    outlineOffset: -1,\n    borderRadius: theme.variables.size.borderRadius.s,\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n\n      [`${StyledDropdownMenuContainer}`]: {\n        visibility: \"visible\",\n      },\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAmFqB"} */"),StyledTitle=(0,_styled.default)("div",{target:"e1qd7sd34",label:"StyledTitle"})(({theme})=>({display:"flex",flexDirection:"column",height:theme.variables.size.spacing.xxl,justifyContent:"flex-end"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    outlineWidth: 2,\n    outlineStyle: \"solid\",\n    outlineColor: \"Highlight\",\n    outlineOffset: -1,\n    borderRadius: theme.variables.size.borderRadius.s,\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n\n      [`${StyledDropdownMenuContainer}`]: {\n        visibility: \"visible\",\n      },\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AA6FoB"} */");function CatalogCard({title,subtitle,dropdownMenuOptions=[],onClick,onDropdownClick,topLeftElement,portalContainer,borderRadius="s","data-e2e-test-id":dataE2eTestId="CatalogCard","data-ds-id":dataDsId="CatalogCard"}){let isMobile=!!window&&window.innerWidth<=_breakpointsjson.default.medium.value,canShowDropdownMenu=dropdownMenuOptions?.length>0;return _react.default.createElement(StyledWrapper,null,_react.default.createElement(StyledButton,{onClick:onClick,"aria-label":title}),_react.default.createElement(_Container.Container,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,borderRadius:borderRadius},_react.default.createElement(StyledContainer,{isMobile:isMobile},_react.default.createElement(_Box.Box,{space:"m"},_react.default.createElement(_Columns.Columns,null,_react.default.createElement(_Columns.Column,{size:canShowDropdownMenu?10:12},_react.default.createElement("div",{onClick:onClick},_react.default.createElement(_Stack.Stack,{vAlignItems:"spaceBetween",space:"s"},topLeftElement,_react.default.createElement(_Stack.Stack,{space:"xxs",vAlignItems:"bottom"},_react.default.createElement(StyledTitle,null,_react.default.createElement(_TextClamped.TextClamped,{size:"m",weight:"bold",lines:2},title)),subtitle&&_react.default.createElement(_TextClamped.TextClamped,{size:"s",color:"tertiary"},subtitle))))),_react.default.createElement(_Columns.Column,{size:canShowDropdownMenu?2:"auto"},_react.default.createElement(_Inline.Inline,{alignItems:"right"},canShowDropdownMenu&&_react.default.createElement(_Box.Box,{space:"xxs",bSpace:"zero"},_react.default.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},_react.default.createElement(_DropdownMenu.DropdownMenu,{iconName:"more-horizontal",menuItems:dropdownMenuOptions,onMenuOpen:onDropdownClick,portalContainer:portalContainer,size:"s"}))))))))))}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"CatalogCard",{enumerable:!0,get:function(){return CatalogCard}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Container=require("../Container/Container"),_DropdownMenu=require("../DropdownMenu/DropdownMenu"),_Box=require("../Box/Box"),_Columns=require("../Column/Columns"),_Inline=require("../Inline/Inline"),_Stack=require("../Stack/Stack"),_TextClamped=require("../Typography/TextClamped/TextClamped"),_breakpointsjson=/*#__PURE__*/_interop_require_default._(require("../../web-tokens/_breakpoints.json")),StyledDropdownMenuContainer=(0,_styled.default)("div",{target:"ecnjjdi0",label:"StyledDropdownMenuContainer"})(({isMobile,theme})=>({marginRight:`-${theme.variables.size.spacing.xs}`,marginTop:`-${theme.variables.size.spacing.xs}`,pointerEvents:"auto",visibility:isMobile?"visible":"collapse"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within > div\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAYoC"} */"),StyledWrapper=(0,_styled.default)("div",{target:"ecnjjdi1",label:"StyledWrapper"})(({theme})=>({position:"relative",height:"100%","> div":{height:"100%"},"&:focus-within":{"> div":{outlineWidth:2,outlineStyle:"solid",outlineColor:"Highlight",outlineOffset:-1,borderRadius:theme.variables.size.borderRadius.s},[`${StyledDropdownMenuContainer}`]:{visibility:"visible"}},"@media (-webkit-min-device-pixel-ratio:0)":{"&:focus-within > div":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"solid",borderRadius:theme.variables.size.borderRadius.s}},"&:hover":{"> div":{boxShadow:theme.values.elevation[2]}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within > div\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAqBsB"} */"),StyledContainer=(0,_styled.default)("div",{target:"ecnjjdi2",label:"StyledContainer"})(({isMobile})=>({display:"flex",minHeight:"102px",cursor:"pointer",position:"relative",height:"100%",alignItems:"end",[`${StyledDropdownMenuContainer}`]:{visibility:isMobile?"visible":"collapse"},"> div":{width:"100%"},"&:hover":{[`${StyledDropdownMenuContainer}`]:{visibility:"visible"}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within > div\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AA2DwB"} */"),StyledButton=(0,_styled.default)("button",{target:"ecnjjdi3",label:"StyledButton"})({position:"absolute",top:0,left:0,width:"1px",height:"1px",opacity:0,border:"none"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within > div\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAkFqB"} */"),StyledTitle=(0,_styled.default)("div",{target:"ecnjjdi4",label:"StyledTitle"})(({theme})=>({display:"flex",flexDirection:"column",height:theme.variables.size.spacing.xxl,justifyContent:"flex-end"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/CatalogCard/CatalogCard.tsx","sources":["src/components/CatalogCard/CatalogCard.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Container, type ContainerProps } from \"../Container/Container\";\nimport { DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\nconst StyledDropdownMenuContainer = styled.div<{ isMobile: boolean }>(\n  ({ isMobile, theme }) => ({\n    marginRight: `-${theme.variables.size.spacing.xs}`,\n    marginTop: `-${theme.variables.size.spacing.xs}`,\n    pointerEvents: \"auto\",\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  })\n);\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  \"&:focus-within\": {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"@media (-webkit-min-device-pixel-ratio:0)\": {\n    \"&:focus-within > div\": {\n      outlineColor: \"-webkit-focus-ring-color\",\n      outlineStyle: \"solid\",\n      borderRadius: theme.variables.size.borderRadius.s,\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      boxShadow: theme.values.elevation[2],\n    },\n  },\n}));\n\nconst StyledContainer = styled.div<{ isMobile: boolean }>(({ isMobile }) => ({\n  display: \"flex\",\n  minHeight: \"102px\",\n  cursor: \"pointer\",\n  position: \"relative\",\n  height: \"100%\",\n  alignItems: \"end\",\n\n  [`${StyledDropdownMenuContainer}`]: {\n    visibility: isMobile ? \"visible\" : \"collapse\",\n  },\n\n  \"> div\": {\n    width: \"100%\",\n  },\n\n  \"&:hover\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n}));\n\nconst StyledButton = styled.button({\n  position: \"absolute\",\n  top: 0,\n  left: 0,\n  width: \"1px\",\n  height: \"1px\",\n  opacity: 0,\n  border: \"none\",\n});\n\nconst StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\ntype DropdownMenuOption = {\n  label: string;\n  onSelect: (ev: React.MouseEvent) => void;\n};\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  dropdownMenuOptions?: DropdownMenuOption[];\n  portalContainer?: PortalProps[\"portalContainer\"];\n  onClick?: VoidFunction;\n  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;\n  topLeftElement?: React.ReactNode;\n};\n\nexport function CatalogCard({\n  title,\n  subtitle,\n  dropdownMenuOptions = [],\n  onClick,\n  onDropdownClick,\n  topLeftElement,\n  portalContainer,\n  borderRadius = \"s\",\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.medium.value;\n  const canShowDropdownMenu = dropdownMenuOptions?.length > 0;\n\n  const leftColumnSize = canShowDropdownMenu ? 10 : 12;\n  const rightColumnSize = canShowDropdownMenu ? 2 : \"auto\";\n\n  return (\n    <StyledWrapper>\n      <StyledButton onClick={onClick} aria-label={title} />\n      <Container\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id={dataDsId}\n        borderRadius={borderRadius}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size={leftColumnSize}>\n                {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-static-element-interactions */}\n                <div onClick={onClick}>\n                  <Stack vAlignItems=\"spaceBetween\" space=\"s\">\n                    {topLeftElement}\n                    <Stack space=\"xxs\" vAlignItems=\"bottom\">\n                      <StyledTitle>\n                        <TextClamped size=\"m\" weight=\"bold\" lines={2}>\n                          {title}\n                        </TextClamped>\n                      </StyledTitle>\n                      {subtitle && (\n                        <TextClamped size=\"s\" color=\"tertiary\">\n                          {subtitle}\n                        </TextClamped>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              <Column size={rightColumnSize}>\n                <Inline alignItems=\"right\">\n                  {canShowDropdownMenu && (\n                    <Box space=\"xxs\" bSpace=\"zero\">\n                      <StyledDropdownMenuContainer isMobile={isMobile}>\n                        <DropdownMenu\n                          iconName=\"more-horizontal\"\n                          menuItems={dropdownMenuOptions}\n                          onMenuOpen={onDropdownClick}\n                          portalContainer={portalContainer}\n                          size=\"s\"\n                        />\n                      </StyledDropdownMenuContainer>\n                    </Box>\n                  )}\n                </Inline>\n              </Column>\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AA4FoB"} */");function CatalogCard({title,subtitle,dropdownMenuOptions=[],onClick,onDropdownClick,topLeftElement,portalContainer,borderRadius="s","data-e2e-test-id":dataE2eTestId="CatalogCard","data-ds-id":dataDsId="CatalogCard"}){let isMobile=!!window&&window.innerWidth<=_breakpointsjson.default.medium.value,canShowDropdownMenu=dropdownMenuOptions?.length>0;return _react.default.createElement(StyledWrapper,null,_react.default.createElement(StyledButton,{onClick:onClick,"aria-label":title}),_react.default.createElement(_Container.Container,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,borderRadius:borderRadius},_react.default.createElement(StyledContainer,{isMobile:isMobile},_react.default.createElement(_Box.Box,{space:"m"},_react.default.createElement(_Columns.Columns,null,_react.default.createElement(_Columns.Column,{size:canShowDropdownMenu?10:12},_react.default.createElement("div",{onClick:onClick},_react.default.createElement(_Stack.Stack,{vAlignItems:"spaceBetween",space:"s"},topLeftElement,_react.default.createElement(_Stack.Stack,{space:"xxs",vAlignItems:"bottom"},_react.default.createElement(StyledTitle,null,_react.default.createElement(_TextClamped.TextClamped,{size:"m",weight:"bold",lines:2},title)),subtitle&&_react.default.createElement(_TextClamped.TextClamped,{size:"s",color:"tertiary"},subtitle))))),_react.default.createElement(_Columns.Column,{size:canShowDropdownMenu?2:"auto"},_react.default.createElement(_Inline.Inline,{alignItems:"right"},canShowDropdownMenu&&_react.default.createElement(_Box.Box,{space:"xxs",bSpace:"zero"},_react.default.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},_react.default.createElement(_DropdownMenu.DropdownMenu,{iconName:"more-horizontal",menuItems:dropdownMenuOptions,onMenuOpen:onDropdownClick,portalContainer:portalContainer,size:"s"}))))))))))}
@@ -1,7 +1,6 @@
1
- import React from "react";
1
+ import React, { type PropsWithChildren } from "react";
2
2
  import type { MQ, HorizontalAlignment, SpaceSizes, VerticalAlignment, ColumnSizes, ColumnAlignment, Order } from "../../types";
3
- export type ColumnsProps = {
4
- children: React.ReactNode[] | React.ReactNode;
3
+ export type ColumnsProps = PropsWithChildren<{
5
4
  /** represents the size of both horizontal and vertical gap between children, can be a single string or an array of 3 strings
6
5
  * specify [small screen gap size, medium screen gap size, large screen gap size] to apply different gap sizes for different screen sizes
7
6
  */
@@ -20,9 +19,8 @@ export type ColumnsProps = {
20
19
  "data-e2e-test-id"?: string;
21
20
  /** @ignore */
22
21
  "data-ds-id"?: string;
23
- };
24
- export type ColumnProps = {
25
- children: React.ReactNode[] | React.ReactNode;
22
+ }> & React.HTMLAttributes<HTMLDivElement>;
23
+ export type ColumnProps = PropsWithChildren<{
26
24
  /** represents the size of the column, can be a single number or an array of 3 numbers with a value ranging from 1 to 12
27
25
  * specify [small screen column size, medium screen column size, large screen column size] to apply different values for different screen sizes
28
26
  */
@@ -36,6 +34,6 @@ export type ColumnProps = {
36
34
  "data-e2e-test-id"?: string;
37
35
  /** @ignore */
38
36
  "data-ds-id"?: string;
39
- };
37
+ }> & React.HTMLAttributes<HTMLDivElement>;
40
38
  export declare const Column: ({ children, size, order, alignSelf, show, "data-e2e-test-id": dataE2eTestId, "data-ds-id": dataDsId, ...rest }: ColumnProps) => React.ReactElement;
41
39
  export declare const Columns: ({ children, gap, alwaysFillSpace, alignItems, vAlignItems, "data-e2e-test-id": dataE2eTestId, "data-ds-id": dataDsId, ...rest }: ColumnsProps) => React.ReactElement;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get Column(){return Column},get Columns(){return Columns}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_mediaQueries=require("../../shared/mediaQueries"),columnWidthObject=Array(12).fill("").reduce((acc,_,index)=>({...acc,[index+1]:`${(index+1)*100/12}%`}),{}),makeNegative=obj=>Object.entries(obj).map(([key,value])=>[key,`-${value}`]).reduce((acc,[key,value])=>(acc[key]=value,acc),{}),StyledColumn=(0,_styled.default)("div",{target:"e5ove2x0",label:"StyledColumn"})(({size,order,alignSelf,show})=>({...(0,_mediaQueries.useResponsiveStyles)({width:[size,{...columnWidthObject,fill:"1px"}],flex:[size,{narrow:"none",auto:"1",fill:void 0}],order:[order,{first:"-1",last:"1",unset:"0"}],flexShrink:[size,{fill:1,auto:void 0,narrow:void 0}],flexGrow:[size,{fill:1,auto:void 0,narrow:void 0}],alignSelf:[alignSelf,{auto:"auto",start:"start",center:"center",end:"end"}],display:[show,value=>value?"block":"none"]}),boxSizing:"border-box","&:empty":{width:0,flex:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Column/Columns.tsx","sources":["src/components/Column/Columns.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useResponsiveStyles } from \"../../shared/mediaQueries\";\nimport type {\n  MQ,\n  HorizontalAlignment,\n  SpaceSizes,\n  VerticalAlignment,\n  ColumnSizes,\n  ColumnAlignment,\n  Order,\n} from \"../../types\";\n\nexport type ColumnsProps = {\n  children: React.ReactNode[] | React.ReactNode;\n\n  /** represents the size of both horizontal and vertical gap between children, can be a single string or an array of 3 strings\n   * specify [small screen gap size, medium screen gap size, large screen gap size] to apply different gap sizes for different screen sizes\n   */\n  gap?: SpaceSizes | MQ<SpaceSizes>;\n\n  /** set to true if you want the last element to fill the space\n   */\n  alwaysFillSpace?: boolean;\n\n  /** specify horizontal alignment\n   * specify [small screen alignItems, medium screen alignItems, large screen alignItems] to apply different alignItems for different screen sizes\n   */\n  alignItems?: HorizontalAlignment | MQ<HorizontalAlignment>;\n\n  /** specify vertical alignment\n   * specify [small screen vAlignItems, medium screen vAlignItems, large screen vAlignItems] to apply different vAlignItems for different screen sizes\n   */\n  vAlignItems?: VerticalAlignment | MQ<VerticalAlignment>;\n\n  \"data-e2e-test-id\"?: string;\n\n  /** @ignore */\n  \"data-ds-id\"?: string;\n};\n\nexport type ColumnProps = {\n  children: React.ReactNode[] | React.ReactNode;\n\n  /** represents the size of the column, can be a single number or an array of 3 numbers with a value ranging from 1 to 12\n   * specify [small screen column size, medium screen column size, large screen column size] to apply different values for different screen sizes\n   */\n  size?: ColumnSizes | MQ<ColumnSizes>;\n\n  /** specify the visual positioning of the column. [small screen column order, medium screen column order, large screen column order] to apply different order for different screen sizes\n   */\n  order?: Order | MQ<Order>;\n\n  alignSelf?: ColumnAlignment | MQ<ColumnAlignment>;\n  /** display column at given breakpoint */\n  show?: boolean | MQ<boolean>;\n\n  \"data-e2e-test-id\"?: string;\n\n  /** @ignore */\n  \"data-ds-id\"?: string;\n};\n\nconst columnWidthObject = new Array(12).fill(\"\").reduce(\n  (acc, _, index) => ({\n    ...acc,\n    [index + 1]: `${((index + 1) * 100) / 12}%`,\n  }),\n  {}\n);\n\nconst makeNegative = (obj: Record<string, string>): Record<string, string> =>\n  Object.entries(obj)\n    .map(([key, value]) => [key, `-${value}`])\n    .reduce((acc, [key, value]) => {\n      acc[key] = value;\n      return acc;\n    }, {} as Record<string, string>);\n\nconst StyledColumn = styled.div<Partial<ColumnProps>>(\n  ({ size, order, alignSelf, show }) => ({\n    ...useResponsiveStyles({\n      width: [size, { ...columnWidthObject, fill: \"1px\" }],\n      flex: [size, { narrow: \"none\", auto: \"1\", fill: undefined }],\n      order: [order, { first: \"-1\", last: \"1\", unset: \"0\" }],\n      flexShrink: [size, { fill: 1, auto: undefined, narrow: undefined }],\n      flexGrow: [size, { fill: 1, auto: undefined, narrow: undefined }],\n      alignSelf: [\n        alignSelf,\n        {\n          auto: \"auto\",\n          start: \"start\",\n          center: \"center\",\n          end: \"end\",\n        },\n      ],\n      display: [show, (value: boolean) => (value ? \"block\" : \"none\")],\n    }),\n    boxSizing: \"border-box\",\n    \"&:empty\": {\n      width: 0,\n      flex: \"none\",\n    },\n  })\n);\n\nexport const Column = ({\n  children,\n  size = \"auto\",\n  order,\n  alignSelf = \"auto\",\n  show,\n  \"data-e2e-test-id\": dataE2eTestId,\n  \"data-ds-id\": dataDsId = \"Column\",\n  ...rest\n}: ColumnProps): React.ReactElement => (\n  <StyledColumn\n    size={size}\n    order={order}\n    alignSelf={alignSelf}\n    show={show}\n    data-e2e-test-id={dataE2eTestId}\n    data-ds-id={dataDsId}\n    {...rest}\n  >\n    {children}\n  </StyledColumn>\n);\n\nconst StyledColumns = styled.div<Partial<ColumnsProps>>(\n  ({ theme, alignItems, vAlignItems, gap }) => ({\n    width: \"auto\",\n    display: \"flex\",\n    justifyItems: \"stretch\",\n    justifyContent: \"stretch\",\n    alignItems: \"stretch\",\n    flexWrap: \"wrap\",\n    flexDirection: \"row\",\n    ...useResponsiveStyles({\n      alignItems: [\n        vAlignItems,\n        {\n          top: \"flex-start\",\n          bottom: \"flex-end\",\n          center: \"center\",\n          stretch: \"stretch\",\n        },\n      ],\n      justifyContent: [\n        alignItems,\n        {\n          left: \"flex-start\",\n          right: \"flex-end\",\n          center: \"center\",\n          spaceBetween: \"space-between\",\n        },\n      ],\n      marginRight: [gap, makeNegative(theme.variables.size.spacing)],\n      marginBottom: [gap, makeNegative(theme.variables.size.spacing)],\n    }),\n\n    [`& > ${StyledColumn}`]: {\n      ...useResponsiveStyles({\n        marginBottom: [gap, theme.variables.size.spacing],\n        paddingRight: [gap, theme.variables.size.spacing],\n      }),\n    },\n  }),\n  ({ alwaysFillSpace }) =>\n    alwaysFillSpace && {\n      [`& > ${StyledColumn}`]: {\n        \"&:last-child\": {\n          flexGrow: 1,\n          flexShrink: 1,\n        },\n      },\n    }\n);\n\nexport const Columns = ({\n  children,\n  gap = \"zero\",\n  alwaysFillSpace = false,\n  alignItems = \"left\",\n  vAlignItems = \"top\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  \"data-ds-id\": dataDsId = \"Columns\",\n  ...rest\n}: ColumnsProps): React.ReactElement => (\n  <StyledColumns\n    gap={gap}\n    alwaysFillSpace={alwaysFillSpace}\n    alignItems={alignItems}\n    vAlignItems={vAlignItems}\n    data-e2e-test-id={dataE2eTestId}\n    data-ds-id={dataDsId}\n    {...rest}\n  >\n    {children}\n  </StyledColumns>\n);\n"],"names":[],"mappings":"AAgFqB"} */"),Column=({children,size="auto",order,alignSelf="auto",show,"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId="Column",...rest})=>_react.default.createElement(StyledColumn,{size:size,order:order,alignSelf:alignSelf,show:show,"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,...rest},children),StyledColumns=(0,_styled.default)("div",{target:"e5ove2x1",label:"StyledColumns"})(({theme,alignItems,vAlignItems,gap})=>({width:"auto",display:"flex",justifyItems:"stretch",justifyContent:"stretch",alignItems:"stretch",flexWrap:"wrap",flexDirection:"row",...(0,_mediaQueries.useResponsiveStyles)({alignItems:[vAlignItems,{top:"flex-start",bottom:"flex-end",center:"center",stretch:"stretch"}],justifyContent:[alignItems,{left:"flex-start",right:"flex-end",center:"center",spaceBetween:"space-between"}],marginRight:[gap,makeNegative(theme.variables.size.spacing)],marginBottom:[gap,makeNegative(theme.variables.size.spacing)]}),[`& > ${StyledColumn}`]:{...(0,_mediaQueries.useResponsiveStyles)({marginBottom:[gap,theme.variables.size.spacing],paddingRight:[gap,theme.variables.size.spacing]})}}),({alwaysFillSpace})=>alwaysFillSpace&&{[`& > ${StyledColumn}`]:{"&:last-child":{flexGrow:1,flexShrink:1}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Column/Columns.tsx","sources":["src/components/Column/Columns.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useResponsiveStyles } from \"../../shared/mediaQueries\";\nimport type {\n  MQ,\n  HorizontalAlignment,\n  SpaceSizes,\n  VerticalAlignment,\n  ColumnSizes,\n  ColumnAlignment,\n  Order,\n} from \"../../types\";\n\nexport type ColumnsProps = {\n  children: React.ReactNode[] | React.ReactNode;\n\n  /** represents the size of both horizontal and vertical gap between children, can be a single string or an array of 3 strings\n   * specify [small screen gap size, medium screen gap size, large screen gap size] to apply different gap sizes for different screen sizes\n   */\n  gap?: SpaceSizes | MQ<SpaceSizes>;\n\n  /** set to true if you want the last element to fill the space\n   */\n  alwaysFillSpace?: boolean;\n\n  /** specify horizontal alignment\n   * specify [small screen alignItems, medium screen alignItems, large screen alignItems] to apply different alignItems for different screen sizes\n   */\n  alignItems?: HorizontalAlignment | MQ<HorizontalAlignment>;\n\n  /** specify vertical alignment\n   * specify [small screen vAlignItems, medium screen vAlignItems, large screen vAlignItems] to apply different vAlignItems for different screen sizes\n   */\n  vAlignItems?: VerticalAlignment | MQ<VerticalAlignment>;\n\n  \"data-e2e-test-id\"?: string;\n\n  /** @ignore */\n  \"data-ds-id\"?: string;\n};\n\nexport type ColumnProps = {\n  children: React.ReactNode[] | React.ReactNode;\n\n  /** represents the size of the column, can be a single number or an array of 3 numbers with a value ranging from 1 to 12\n   * specify [small screen column size, medium screen column size, large screen column size] to apply different values for different screen sizes\n   */\n  size?: ColumnSizes | MQ<ColumnSizes>;\n\n  /** specify the visual positioning of the column. [small screen column order, medium screen column order, large screen column order] to apply different order for different screen sizes\n   */\n  order?: Order | MQ<Order>;\n\n  alignSelf?: ColumnAlignment | MQ<ColumnAlignment>;\n  /** display column at given breakpoint */\n  show?: boolean | MQ<boolean>;\n\n  \"data-e2e-test-id\"?: string;\n\n  /** @ignore */\n  \"data-ds-id\"?: string;\n};\n\nconst columnWidthObject = new Array(12).fill(\"\").reduce(\n  (acc, _, index) => ({\n    ...acc,\n    [index + 1]: `${((index + 1) * 100) / 12}%`,\n  }),\n  {}\n);\n\nconst makeNegative = (obj: Record<string, string>): Record<string, string> =>\n  Object.entries(obj)\n    .map(([key, value]) => [key, `-${value}`])\n    .reduce((acc, [key, value]) => {\n      acc[key] = value;\n      return acc;\n    }, {} as Record<string, string>);\n\nconst StyledColumn = styled.div<Partial<ColumnProps>>(\n  ({ size, order, alignSelf, show }) => ({\n    ...useResponsiveStyles({\n      width: [size, { ...columnWidthObject, fill: \"1px\" }],\n      flex: [size, { narrow: \"none\", auto: \"1\", fill: undefined }],\n      order: [order, { first: \"-1\", last: \"1\", unset: \"0\" }],\n      flexShrink: [size, { fill: 1, auto: undefined, narrow: undefined }],\n      flexGrow: [size, { fill: 1, auto: undefined, narrow: undefined }],\n      alignSelf: [\n        alignSelf,\n        {\n          auto: \"auto\",\n          start: \"start\",\n          center: \"center\",\n          end: \"end\",\n        },\n      ],\n      display: [show, (value: boolean) => (value ? \"block\" : \"none\")],\n    }),\n    boxSizing: \"border-box\",\n    \"&:empty\": {\n      width: 0,\n      flex: \"none\",\n    },\n  })\n);\n\nexport const Column = ({\n  children,\n  size = \"auto\",\n  order,\n  alignSelf = \"auto\",\n  show,\n  \"data-e2e-test-id\": dataE2eTestId,\n  \"data-ds-id\": dataDsId = \"Column\",\n  ...rest\n}: ColumnProps): React.ReactElement => (\n  <StyledColumn\n    size={size}\n    order={order}\n    alignSelf={alignSelf}\n    show={show}\n    data-e2e-test-id={dataE2eTestId}\n    data-ds-id={dataDsId}\n    {...rest}\n  >\n    {children}\n  </StyledColumn>\n);\n\nconst StyledColumns = styled.div<Partial<ColumnsProps>>(\n  ({ theme, alignItems, vAlignItems, gap }) => ({\n    width: \"auto\",\n    display: \"flex\",\n    justifyItems: \"stretch\",\n    justifyContent: \"stretch\",\n    alignItems: \"stretch\",\n    flexWrap: \"wrap\",\n    flexDirection: \"row\",\n    ...useResponsiveStyles({\n      alignItems: [\n        vAlignItems,\n        {\n          top: \"flex-start\",\n          bottom: \"flex-end\",\n          center: \"center\",\n          stretch: \"stretch\",\n        },\n      ],\n      justifyContent: [\n        alignItems,\n        {\n          left: \"flex-start\",\n          right: \"flex-end\",\n          center: \"center\",\n          spaceBetween: \"space-between\",\n        },\n      ],\n      marginRight: [gap, makeNegative(theme.variables.size.spacing)],\n      marginBottom: [gap, makeNegative(theme.variables.size.spacing)],\n    }),\n\n    [`& > ${StyledColumn}`]: {\n      ...useResponsiveStyles({\n        marginBottom: [gap, theme.variables.size.spacing],\n        paddingRight: [gap, theme.variables.size.spacing],\n      }),\n    },\n  }),\n  ({ alwaysFillSpace }) =>\n    alwaysFillSpace && {\n      [`& > ${StyledColumn}`]: {\n        \"&:last-child\": {\n          flexGrow: 1,\n          flexShrink: 1,\n        },\n      },\n    }\n);\n\nexport const Columns = ({\n  children,\n  gap = \"zero\",\n  alwaysFillSpace = false,\n  alignItems = \"left\",\n  vAlignItems = \"top\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  \"data-ds-id\": dataDsId = \"Columns\",\n  ...rest\n}: ColumnsProps): React.ReactElement => (\n  <StyledColumns\n    gap={gap}\n    alwaysFillSpace={alwaysFillSpace}\n    alignItems={alignItems}\n    vAlignItems={vAlignItems}\n    data-e2e-test-id={dataE2eTestId}\n    data-ds-id={dataDsId}\n    {...rest}\n  >\n    {children}\n  </StyledColumns>\n);\n"],"names":[],"mappings":"AAkIsB"} */"),Columns=({children,gap="zero",alwaysFillSpace=!1,alignItems="left",vAlignItems="top","data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId="Columns",...rest})=>_react.default.createElement(StyledColumns,{gap:gap,alwaysFillSpace:alwaysFillSpace,alignItems:alignItems,vAlignItems:vAlignItems,"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,...rest},children);
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get Column(){return Column},get Columns(){return Columns}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_mediaQueries=require("../../shared/mediaQueries"),columnWidthObject=Array(12).fill("").reduce((acc,_,index)=>({...acc,[index+1]:`${(index+1)*100/12}%`}),{}),makeNegative=obj=>Object.entries(obj).map(([key,value])=>[key,`-${value}`]).reduce((acc,[key,value])=>(acc[key]=value,acc),{}),StyledColumn=(0,_styled.default)("div",{target:"e144tdwe0",label:"StyledColumn"})(({size,order,alignSelf,show})=>({...(0,_mediaQueries.useResponsiveStyles)({width:[size,{...columnWidthObject,fill:"1px"}],flex:[size,{narrow:"none",auto:"1",fill:void 0}],order:[order,{first:"-1",last:"1",unset:"0"}],flexShrink:[size,{fill:1,auto:void 0,narrow:void 0}],flexGrow:[size,{fill:1,auto:void 0,narrow:void 0}],alignSelf:[alignSelf,{auto:"auto",start:"start",center:"center",end:"end"}],display:[show,value=>value?"block":"none"]}),boxSizing:"border-box","&:empty":{width:0,flex:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Column/Columns.tsx","sources":["src/components/Column/Columns.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { type PropsWithChildren } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useResponsiveStyles } from \"../../shared/mediaQueries\";\nimport type {\n  MQ,\n  HorizontalAlignment,\n  SpaceSizes,\n  VerticalAlignment,\n  ColumnSizes,\n  ColumnAlignment,\n  Order,\n} from \"../../types\";\n\nexport type ColumnsProps = PropsWithChildren<{\n  /** represents the size of both horizontal and vertical gap between children, can be a single string or an array of 3 strings\n   * specify [small screen gap size, medium screen gap size, large screen gap size] to apply different gap sizes for different screen sizes\n   */\n  gap?: SpaceSizes | MQ<SpaceSizes>;\n\n  /** set to true if you want the last element to fill the space\n   */\n  alwaysFillSpace?: boolean;\n\n  /** specify horizontal alignment\n   * specify [small screen alignItems, medium screen alignItems, large screen alignItems] to apply different alignItems for different screen sizes\n   */\n  alignItems?: HorizontalAlignment | MQ<HorizontalAlignment>;\n\n  /** specify vertical alignment\n   * specify [small screen vAlignItems, medium screen vAlignItems, large screen vAlignItems] to apply different vAlignItems for different screen sizes\n   */\n  vAlignItems?: VerticalAlignment | MQ<VerticalAlignment>;\n\n  \"data-e2e-test-id\"?: string;\n\n  /** @ignore */\n  \"data-ds-id\"?: string;\n}> &\n  React.HTMLAttributes<HTMLDivElement>;\n// support all div props due to legacy usages in UIA\n\nexport type ColumnProps = PropsWithChildren<{\n  /** represents the size of the column, can be a single number or an array of 3 numbers with a value ranging from 1 to 12\n   * specify [small screen column size, medium screen column size, large screen column size] to apply different values for different screen sizes\n   */\n  size?: ColumnSizes | MQ<ColumnSizes>;\n\n  /** specify the visual positioning of the column. [small screen column order, medium screen column order, large screen column order] to apply different order for different screen sizes\n   */\n  order?: Order | MQ<Order>;\n\n  alignSelf?: ColumnAlignment | MQ<ColumnAlignment>;\n  /** display column at given breakpoint */\n  show?: boolean | MQ<boolean>;\n\n  \"data-e2e-test-id\"?: string;\n\n  /** @ignore */\n  \"data-ds-id\"?: string;\n}> &\n  React.HTMLAttributes<HTMLDivElement>;\n// support all div props due to legacy usages in UIA\n\nconst columnWidthObject = new Array(12).fill(\"\").reduce(\n  (acc, _, index) => ({\n    ...acc,\n    [index + 1]: `${((index + 1) * 100) / 12}%`,\n  }),\n  {}\n);\n\nconst makeNegative = (obj: Record<string, string>): Record<string, string> =>\n  Object.entries(obj)\n    .map(([key, value]) => [key, `-${value}`])\n    .reduce((acc, [key, value]) => {\n      acc[key] = value;\n      return acc;\n    }, {} as Record<string, string>);\n\nconst StyledColumn = styled.div<Partial<ColumnProps>>(\n  ({ size, order, alignSelf, show }) => ({\n    ...useResponsiveStyles({\n      width: [size, { ...columnWidthObject, fill: \"1px\" }],\n      flex: [size, { narrow: \"none\", auto: \"1\", fill: undefined }],\n      order: [order, { first: \"-1\", last: \"1\", unset: \"0\" }],\n      flexShrink: [size, { fill: 1, auto: undefined, narrow: undefined }],\n      flexGrow: [size, { fill: 1, auto: undefined, narrow: undefined }],\n      alignSelf: [\n        alignSelf,\n        {\n          auto: \"auto\",\n          start: \"start\",\n          center: \"center\",\n          end: \"end\",\n        },\n      ],\n      display: [show, (value: boolean) => (value ? \"block\" : \"none\")],\n    }),\n    boxSizing: \"border-box\",\n    \"&:empty\": {\n      width: 0,\n      flex: \"none\",\n    },\n  })\n);\n\nexport const Column = ({\n  children,\n  size = \"auto\",\n  order,\n  alignSelf = \"auto\",\n  show,\n  \"data-e2e-test-id\": dataE2eTestId,\n  \"data-ds-id\": dataDsId = \"Column\",\n  ...rest\n}: ColumnProps): React.ReactElement => (\n  <StyledColumn\n    size={size}\n    order={order}\n    alignSelf={alignSelf}\n    show={show}\n    data-e2e-test-id={dataE2eTestId}\n    data-ds-id={dataDsId}\n    {...rest}\n  >\n    {children}\n  </StyledColumn>\n);\n\nconst StyledColumns = styled.div<Partial<ColumnsProps>>(\n  ({ theme, alignItems, vAlignItems, gap }) => ({\n    width: \"auto\",\n    display: \"flex\",\n    justifyItems: \"stretch\",\n    justifyContent: \"stretch\",\n    alignItems: \"stretch\",\n    flexWrap: \"wrap\",\n    flexDirection: \"row\",\n    ...useResponsiveStyles({\n      alignItems: [\n        vAlignItems,\n        {\n          top: \"flex-start\",\n          bottom: \"flex-end\",\n          center: \"center\",\n          stretch: \"stretch\",\n        },\n      ],\n      justifyContent: [\n        alignItems,\n        {\n          left: \"flex-start\",\n          right: \"flex-end\",\n          center: \"center\",\n          spaceBetween: \"space-between\",\n        },\n      ],\n      marginRight: [gap, makeNegative(theme.variables.size.spacing)],\n      marginBottom: [gap, makeNegative(theme.variables.size.spacing)],\n    }),\n\n    [`& > ${StyledColumn}`]: {\n      ...useResponsiveStyles({\n        marginBottom: [gap, theme.variables.size.spacing],\n        paddingRight: [gap, theme.variables.size.spacing],\n      }),\n    },\n  }),\n  ({ alwaysFillSpace }) =>\n    alwaysFillSpace && {\n      [`& > ${StyledColumn}`]: {\n        \"&:last-child\": {\n          flexGrow: 1,\n          flexShrink: 1,\n        },\n      },\n    }\n);\n\nexport const Columns = ({\n  children,\n  gap = \"zero\",\n  alwaysFillSpace = false,\n  alignItems = \"left\",\n  vAlignItems = \"top\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  \"data-ds-id\": dataDsId = \"Columns\",\n  ...rest\n}: ColumnsProps): React.ReactElement => (\n  <StyledColumns\n    gap={gap}\n    alwaysFillSpace={alwaysFillSpace}\n    alignItems={alignItems}\n    vAlignItems={vAlignItems}\n    data-e2e-test-id={dataE2eTestId}\n    data-ds-id={dataDsId}\n    {...rest}\n  >\n    {children}\n  </StyledColumns>\n);\n"],"names":[],"mappings":"AAgFqB"} */"),Column=({children,size="auto",order,alignSelf="auto",show,"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId="Column",...rest})=>_react.default.createElement(StyledColumn,{size:size,order:order,alignSelf:alignSelf,show:show,"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,...rest},children),StyledColumns=(0,_styled.default)("div",{target:"e144tdwe1",label:"StyledColumns"})(({theme,alignItems,vAlignItems,gap})=>({width:"auto",display:"flex",justifyItems:"stretch",justifyContent:"stretch",alignItems:"stretch",flexWrap:"wrap",flexDirection:"row",...(0,_mediaQueries.useResponsiveStyles)({alignItems:[vAlignItems,{top:"flex-start",bottom:"flex-end",center:"center",stretch:"stretch"}],justifyContent:[alignItems,{left:"flex-start",right:"flex-end",center:"center",spaceBetween:"space-between"}],marginRight:[gap,makeNegative(theme.variables.size.spacing)],marginBottom:[gap,makeNegative(theme.variables.size.spacing)]}),[`& > ${StyledColumn}`]:{...(0,_mediaQueries.useResponsiveStyles)({marginBottom:[gap,theme.variables.size.spacing],paddingRight:[gap,theme.variables.size.spacing]})}}),({alwaysFillSpace})=>alwaysFillSpace&&{[`& > ${StyledColumn}`]:{"&:last-child":{flexGrow:1,flexShrink:1}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Column/Columns.tsx","sources":["src/components/Column/Columns.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { type PropsWithChildren } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useResponsiveStyles } from \"../../shared/mediaQueries\";\nimport type {\n  MQ,\n  HorizontalAlignment,\n  SpaceSizes,\n  VerticalAlignment,\n  ColumnSizes,\n  ColumnAlignment,\n  Order,\n} from \"../../types\";\n\nexport type ColumnsProps = PropsWithChildren<{\n  /** represents the size of both horizontal and vertical gap between children, can be a single string or an array of 3 strings\n   * specify [small screen gap size, medium screen gap size, large screen gap size] to apply different gap sizes for different screen sizes\n   */\n  gap?: SpaceSizes | MQ<SpaceSizes>;\n\n  /** set to true if you want the last element to fill the space\n   */\n  alwaysFillSpace?: boolean;\n\n  /** specify horizontal alignment\n   * specify [small screen alignItems, medium screen alignItems, large screen alignItems] to apply different alignItems for different screen sizes\n   */\n  alignItems?: HorizontalAlignment | MQ<HorizontalAlignment>;\n\n  /** specify vertical alignment\n   * specify [small screen vAlignItems, medium screen vAlignItems, large screen vAlignItems] to apply different vAlignItems for different screen sizes\n   */\n  vAlignItems?: VerticalAlignment | MQ<VerticalAlignment>;\n\n  \"data-e2e-test-id\"?: string;\n\n  /** @ignore */\n  \"data-ds-id\"?: string;\n}> &\n  React.HTMLAttributes<HTMLDivElement>;\n// support all div props due to legacy usages in UIA\n\nexport type ColumnProps = PropsWithChildren<{\n  /** represents the size of the column, can be a single number or an array of 3 numbers with a value ranging from 1 to 12\n   * specify [small screen column size, medium screen column size, large screen column size] to apply different values for different screen sizes\n   */\n  size?: ColumnSizes | MQ<ColumnSizes>;\n\n  /** specify the visual positioning of the column. [small screen column order, medium screen column order, large screen column order] to apply different order for different screen sizes\n   */\n  order?: Order | MQ<Order>;\n\n  alignSelf?: ColumnAlignment | MQ<ColumnAlignment>;\n  /** display column at given breakpoint */\n  show?: boolean | MQ<boolean>;\n\n  \"data-e2e-test-id\"?: string;\n\n  /** @ignore */\n  \"data-ds-id\"?: string;\n}> &\n  React.HTMLAttributes<HTMLDivElement>;\n// support all div props due to legacy usages in UIA\n\nconst columnWidthObject = new Array(12).fill(\"\").reduce(\n  (acc, _, index) => ({\n    ...acc,\n    [index + 1]: `${((index + 1) * 100) / 12}%`,\n  }),\n  {}\n);\n\nconst makeNegative = (obj: Record<string, string>): Record<string, string> =>\n  Object.entries(obj)\n    .map(([key, value]) => [key, `-${value}`])\n    .reduce((acc, [key, value]) => {\n      acc[key] = value;\n      return acc;\n    }, {} as Record<string, string>);\n\nconst StyledColumn = styled.div<Partial<ColumnProps>>(\n  ({ size, order, alignSelf, show }) => ({\n    ...useResponsiveStyles({\n      width: [size, { ...columnWidthObject, fill: \"1px\" }],\n      flex: [size, { narrow: \"none\", auto: \"1\", fill: undefined }],\n      order: [order, { first: \"-1\", last: \"1\", unset: \"0\" }],\n      flexShrink: [size, { fill: 1, auto: undefined, narrow: undefined }],\n      flexGrow: [size, { fill: 1, auto: undefined, narrow: undefined }],\n      alignSelf: [\n        alignSelf,\n        {\n          auto: \"auto\",\n          start: \"start\",\n          center: \"center\",\n          end: \"end\",\n        },\n      ],\n      display: [show, (value: boolean) => (value ? \"block\" : \"none\")],\n    }),\n    boxSizing: \"border-box\",\n    \"&:empty\": {\n      width: 0,\n      flex: \"none\",\n    },\n  })\n);\n\nexport const Column = ({\n  children,\n  size = \"auto\",\n  order,\n  alignSelf = \"auto\",\n  show,\n  \"data-e2e-test-id\": dataE2eTestId,\n  \"data-ds-id\": dataDsId = \"Column\",\n  ...rest\n}: ColumnProps): React.ReactElement => (\n  <StyledColumn\n    size={size}\n    order={order}\n    alignSelf={alignSelf}\n    show={show}\n    data-e2e-test-id={dataE2eTestId}\n    data-ds-id={dataDsId}\n    {...rest}\n  >\n    {children}\n  </StyledColumn>\n);\n\nconst StyledColumns = styled.div<Partial<ColumnsProps>>(\n  ({ theme, alignItems, vAlignItems, gap }) => ({\n    width: \"auto\",\n    display: \"flex\",\n    justifyItems: \"stretch\",\n    justifyContent: \"stretch\",\n    alignItems: \"stretch\",\n    flexWrap: \"wrap\",\n    flexDirection: \"row\",\n    ...useResponsiveStyles({\n      alignItems: [\n        vAlignItems,\n        {\n          top: \"flex-start\",\n          bottom: \"flex-end\",\n          center: \"center\",\n          stretch: \"stretch\",\n        },\n      ],\n      justifyContent: [\n        alignItems,\n        {\n          left: \"flex-start\",\n          right: \"flex-end\",\n          center: \"center\",\n          spaceBetween: \"space-between\",\n        },\n      ],\n      marginRight: [gap, makeNegative(theme.variables.size.spacing)],\n      marginBottom: [gap, makeNegative(theme.variables.size.spacing)],\n    }),\n\n    [`& > ${StyledColumn}`]: {\n      ...useResponsiveStyles({\n        marginBottom: [gap, theme.variables.size.spacing],\n        paddingRight: [gap, theme.variables.size.spacing],\n      }),\n    },\n  }),\n  ({ alwaysFillSpace }) =>\n    alwaysFillSpace && {\n      [`& > ${StyledColumn}`]: {\n        \"&:last-child\": {\n          flexGrow: 1,\n          flexShrink: 1,\n        },\n      },\n    }\n);\n\nexport const Columns = ({\n  children,\n  gap = \"zero\",\n  alwaysFillSpace = false,\n  alignItems = \"left\",\n  vAlignItems = \"top\",\n  \"data-e2e-test-id\": dataE2eTestId,\n  \"data-ds-id\": dataDsId = \"Columns\",\n  ...rest\n}: ColumnsProps): React.ReactElement => (\n  <StyledColumns\n    gap={gap}\n    alwaysFillSpace={alwaysFillSpace}\n    alignItems={alignItems}\n    vAlignItems={vAlignItems}\n    data-e2e-test-id={dataE2eTestId}\n    data-ds-id={dataDsId}\n    {...rest}\n  >\n    {children}\n  </StyledColumns>\n);\n"],"names":[],"mappings":"AAkIsB"} */"),Columns=({children,gap="zero",alwaysFillSpace=!1,alignItems="left",vAlignItems="top","data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId="Columns",...rest})=>_react.default.createElement(StyledColumns,{gap:gap,alwaysFillSpace:alwaysFillSpace,alignItems:alignItems,vAlignItems:vAlignItems,"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,...rest},children);
@@ -1,6 +1,7 @@
1
- import type { ReactElement, MouseEvent as ReactMouseEvent } from "react";
1
+ import type { ReactElement } from "react";
2
2
  import React from "react";
3
3
  import type { TooltipContentProps } from "../Tooltip/TooltipContent";
4
+ import type { TooltipConditionalProps } from "../Tooltip/types";
4
5
  type BaseProps = Pick<TooltipContentProps, "placement" | "portalContainer" | "maxWidth" | "contentPadding" | "hideArrow" | "subTheme" | "defaultVerticalPlacement" | "onOverflowViewport"> & {
5
6
  name?: string;
6
7
  /** Popover content */
@@ -24,17 +25,6 @@ type BaseProps = Pick<TooltipContentProps, "placement" | "portalContainer" | "ma
24
25
  hasBackdrop?: boolean;
25
26
  };
26
27
  };
27
- type PopoverChildProps = {
28
- tabIndex?: number;
29
- onClick?: (event: ReactMouseEvent) => void;
30
- [key: string]: any;
31
- };
32
- export type BasePopoverProps = BaseProps & ({
33
- children: ReactElement<PopoverChildProps>;
34
- externalTriggerRef?: never;
35
- } | {
36
- children?: never;
37
- externalTriggerRef: React.RefObject<HTMLElement>;
38
- });
28
+ export type BasePopoverProps = BaseProps & TooltipConditionalProps;
39
29
  export declare function BasePopover({ placement, content, children, contentPadding, maxWidth, externalTriggerRef, portalContainer, name, isVisible: isPopoverVisible, dismissOnOutsideClick, "data-e2e-test-id": dataE2eTestId, subTheme, defaultVerticalPlacement, onVisibilityChange, disableInitialFocus, disableReturnFocusToTrigger, renderAsSheetOnMobile, sheetProps, ...restContentProps }: BasePopoverProps): React.ReactElement;
40
30
  export {};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"BasePopover",{enumerable:!0,get:function(){return BasePopover}});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")),_TooltipContent=require("../Tooltip/TooltipContent"),_Sheet=require("../Sheet/Sheet"),_FocusTrapWrapper=require("../../shared/FocusTrapWrapper"),_breakpointsjson=/*#__PURE__*/_interop_require_default._(require("../../web-tokens/_breakpoints.json")),StyledContainer=(0,_styled.default)("div",{target:"e1v8xhbj0",label:"StyledContainer"})(()=>({borderRadius:"inherit"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Toggletip/BasePopover.tsx","sources":["src/components/Toggletip/BasePopover.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type {\n  ReactElement,\n  PropsWithChildren,\n  MouseEvent as ReactMouseEvent,\n} from \"react\";\nimport React, {\n  useState,\n  useRef,\n  useEffect,\n  useCallback,\n  useMemo,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TooltipContentProps } from \"../Tooltip/TooltipContent\";\nimport { TooltipContent } from \"../Tooltip/TooltipContent\";\nimport { Sheet } from \"../Sheet/Sheet\";\nimport { FocusTrapWrapper } from \"../../shared/FocusTrapWrapper\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\ntype BaseProps = Pick<\n  TooltipContentProps,\n  | \"placement\"\n  | \"portalContainer\"\n  | \"maxWidth\"\n  | \"contentPadding\"\n  | \"hideArrow\"\n  | \"subTheme\"\n  | \"defaultVerticalPlacement\"\n  | \"onOverflowViewport\"\n> & {\n  name?: string;\n  /**  Popover content */\n  content: ReactElement;\n  \"data-e2e-test-id\"?: string;\n  /**  Programmatically toggle Popover visibility with this prop */\n  isVisible?: boolean;\n  /**  Called when tooltip appears and disappears */\n  onVisibilityChange?: (isVisible: boolean, reason: string) => void;\n  /**  Controls whether BasePopover  closes on outside click */\n  dismissOnOutsideClick?: boolean;\n  /**  Option for focus-trap, controls whether the first focuable item recieves focus */\n  disableInitialFocus?: boolean;\n  /**  Option for focus-trap, controls whether the trigger should receive back the focus on popover close */\n  disableReturnFocusToTrigger?: boolean;\n  /**  Render as sheet on mobile web */\n  renderAsSheetOnMobile?: boolean;\n  /**  Props for configuring the sheet on mobile web */\n  sheetProps?: {\n    /**  Show the dark scrim backdrop on mobile web when rendering as Sheet */\n    hasBackdrop?: boolean;\n  };\n};\n\n// Define a more specific type for the children prop\ntype PopoverChildProps = {\n  tabIndex?: number;\n  onClick?: (event: ReactMouseEvent) => void;\n  [key: string]: any;\n};\n\nexport type BasePopoverProps = BaseProps &\n  (\n    | { children: ReactElement<PopoverChildProps>; externalTriggerRef?: never }\n    | { children?: never; externalTriggerRef: React.RefObject<HTMLElement> }\n  );\n\nconst StyledContainer = styled.div(() => ({\n  borderRadius: \"inherit\",\n}));\n\nconst FocusTrapContent = React.forwardRef<\n  HTMLDivElement,\n  PropsWithChildren<unknown>\n>(({ children }, ref) => (\n  <StyledContainer ref={ref}>{children}</StyledContainer>\n));\n\nconst VisibilityChangeReason = {\n  triggerClick: \"triggerClick\",\n  outsideClick: \"outsideClick\",\n};\n\nfunction getMobileBreakpoint(renderAsSheetOnMobile: boolean) {\n  return (\n    !!window &&\n    renderAsSheetOnMobile &&\n    window.innerWidth <= breakpoints.medium.value\n  );\n}\n\nexport function BasePopover({\n  placement = \"auto\",\n  content,\n  children,\n  contentPadding = \"m\",\n  maxWidth,\n  externalTriggerRef,\n  portalContainer,\n  name = \"Popover\",\n  isVisible: isPopoverVisible,\n  dismissOnOutsideClick = true,\n  \"data-e2e-test-id\": dataE2eTestId,\n  subTheme,\n  defaultVerticalPlacement,\n  onVisibilityChange,\n  disableInitialFocus = false,\n  disableReturnFocusToTrigger = false,\n  renderAsSheetOnMobile = false,\n  sheetProps,\n  ...restContentProps\n}: BasePopoverProps): React.ReactElement {\n  const tooltipId = useMemo(\n    () => `DS${name}_${Math.floor(Date.now() * Math.random())}`,\n    [name]\n  );\n  const [isVisible, setVisible] = useState(isPopoverVisible);\n  const [isMobileBreakPoint, setIsMobileBreakpoint] = useState(\n    getMobileBreakpoint(renderAsSheetOnMobile)\n  );\n  const internalTriggerRef = useRef<HTMLElement>(null);\n  const triggerRef = externalTriggerRef || internalTriggerRef;\n  const isOutsideClickOnTrigger = useRef(false);\n\n  const toggleVisibility = useCallback(\n    (status: boolean, reason: string) => {\n      setVisible(status);\n\n      if (onVisibilityChange) {\n        onVisibilityChange(status, reason);\n      }\n    },\n    [onVisibilityChange]\n  );\n\n  // Outside click is also fired when the Popover is open and trigger is clicked. `isOutsideClickOnTrigger` saves this condition and we check for it so as to not toggle the Popover twice.\n  const handleTriggerClick = useCallback(() => {\n    if (!isOutsideClickOnTrigger.current) {\n      toggleVisibility(!isVisible, VisibilityChangeReason.triggerClick);\n    } else {\n      // reset this value so that Popover can open in next click\n      isOutsideClickOnTrigger.current = false;\n    }\n  }, [toggleVisibility, isVisible]);\n\n  const handleClickOutsideDeactivates = useCallback(\n    (evt: MouseEvent) => {\n      if (\n        triggerRef.current &&\n        triggerRef.current.contains(evt.target as Node)\n      ) {\n        isOutsideClickOnTrigger.current = true;\n      }\n      return true;\n    },\n    [triggerRef, isOutsideClickOnTrigger]\n  );\n\n  const handlePostDeactivate = useCallback(() => {\n    const reason = isOutsideClickOnTrigger.current\n      ? VisibilityChangeReason.triggerClick\n      : VisibilityChangeReason.outsideClick;\n\n    toggleVisibility(false, reason);\n  }, [toggleVisibility]);\n\n  useEffect(() => {\n    setVisible(isPopoverVisible);\n  }, [isPopoverVisible]);\n\n  useEffect(() => {\n    // Check if this is a mobile breakpoint\n    setIsMobileBreakpoint(getMobileBreakpoint(renderAsSheetOnMobile));\n  }, [isVisible, renderAsSheetOnMobile]);\n\n  useEffect(() => {\n    let trigger: HTMLElement;\n\n    if (externalTriggerRef?.current && !children) {\n      trigger = externalTriggerRef.current;\n      const triggerTabIndex = trigger.getAttribute(\"tabindex\");\n\n      trigger.setAttribute(\"tabindex\", triggerTabIndex ?? \"0\");\n      trigger.addEventListener(\"click\", handleTriggerClick);\n    }\n\n    return () => {\n      if (trigger) {\n        trigger.removeEventListener(\"click\", handleTriggerClick);\n      }\n    };\n  }, [externalTriggerRef, children, handleTriggerClick]);\n\n  useEffect(() => {\n    if (externalTriggerRef?.current && !children) {\n      const trigger = externalTriggerRef.current;\n\n      trigger.setAttribute(\"aria-haspopup\", \"true\");\n      if (isVisible) {\n        trigger.setAttribute(\"aria-expanded\", \"true\");\n        trigger.setAttribute(\"aria-controls\", tooltipId);\n      } else {\n        trigger.removeAttribute(\"aria-expanded\");\n        trigger.removeAttribute(\"aria-controls\");\n      }\n    }\n  }, [externalTriggerRef, children, tooltipId, isVisible]);\n\n  const triggerElm = children\n    ? React.cloneElement(children, {\n        ref: triggerRef,\n        ...(isVisible && {\n          \"aria-expanded\": true,\n          \"aria-controls\": tooltipId,\n        }),\n        tabIndex: children.props.tabIndex ?? 0,\n        \"aria-haspopup\": true,\n        onClick: (evt: ReactMouseEvent) => {\n          handleTriggerClick();\n          if (children.props.onClick) {\n            children.props.onClick(evt);\n          }\n        },\n      })\n    : null;\n\n  if (isMobileBreakPoint) {\n    // render as Sheet\n    const sheetElm = (\n      <Sheet\n        id={tooltipId}\n        isVisible={isVisible}\n        portalContainer={portalContainer}\n        dismissOnOutsideClick={dismissOnOutsideClick}\n        disableInitialFocus={disableInitialFocus}\n        disableReturnFocusToTrigger={disableReturnFocusToTrigger}\n        onClose={handlePostDeactivate}\n        onClickOutsideDeactivates={handleClickOutsideDeactivates}\n        {...(sheetProps ?? {})}\n      >\n        {content}\n      </Sheet>\n    );\n\n    return (\n      <>\n        {triggerElm}\n        {sheetElm}\n      </>\n    );\n  }\n\n  // render as Popover\n  const contentElm = (\n    <FocusTrapWrapper\n      active={isVisible}\n      focusTrapOptions={{\n        clickOutsideDeactivates:\n          dismissOnOutsideClick && handleClickOutsideDeactivates, // de-activate focus trap on outside click\n        allowOutsideClick: true,\n        escapeDeactivates: true,\n        fallbackFocus: `#${tooltipId}`, // set focus to tooltip content container if it has no focusable element\n        onPostDeactivate: handlePostDeactivate,\n        preventScroll: true,\n        initialFocus: () => !disableInitialFocus,\n        returnFocusOnDeactivate: !disableReturnFocusToTrigger,\n      }}\n    >\n      <FocusTrapContent>{content}</FocusTrapContent>\n    </FocusTrapWrapper>\n  );\n\n  const tooltipElm = (\n    <TooltipContent\n      {...restContentProps} // eslint-disable-line react/jsx-props-no-spreading\n      defaultVerticalPlacement={defaultVerticalPlacement}\n      dataDSId={name}\n      content={contentElm}\n      contentPadding={contentPadding}\n      maxWidth={maxWidth}\n      placement={placement}\n      portalContainer={portalContainer}\n      dataE2eTestId={dataE2eTestId}\n      subTheme={subTheme}\n      isVisible={isVisible}\n      tooltipId={tooltipId}\n      triggerRef={triggerRef}\n    />\n  );\n\n  return (\n    <>\n      {triggerElm}\n      {tooltipElm}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAmEwB"} */"),FocusTrapContent=_react.default.forwardRef(({children},ref)=>_react.default.createElement(StyledContainer,{ref:ref},children)),VisibilityChangeReason={triggerClick:"triggerClick",outsideClick:"outsideClick"};function getMobileBreakpoint(renderAsSheetOnMobile){return!!window&&renderAsSheetOnMobile&&window.innerWidth<=_breakpointsjson.default.medium.value}function BasePopover({placement="auto",content,children,contentPadding="m",maxWidth,externalTriggerRef,portalContainer,name="Popover",isVisible:isPopoverVisible,dismissOnOutsideClick=!0,"data-e2e-test-id":dataE2eTestId,subTheme,defaultVerticalPlacement,onVisibilityChange,disableInitialFocus=!1,disableReturnFocusToTrigger=!1,renderAsSheetOnMobile=!1,sheetProps,...restContentProps}){let tooltipId=(0,_react.useMemo)(()=>`DS${name}_${Math.floor(Date.now()*Math.random())}`,[name]),[isVisible,setVisible]=(0,_react.useState)(isPopoverVisible),[isMobileBreakPoint,setIsMobileBreakpoint]=(0,_react.useState)(getMobileBreakpoint(renderAsSheetOnMobile)),internalTriggerRef=(0,_react.useRef)(null),triggerRef=externalTriggerRef||internalTriggerRef,isOutsideClickOnTrigger=(0,_react.useRef)(!1),toggleVisibility=(0,_react.useCallback)((status,reason)=>{setVisible(status),onVisibilityChange&&onVisibilityChange(status,reason)},[onVisibilityChange]),handleTriggerClick=(0,_react.useCallback)(()=>{isOutsideClickOnTrigger.current?isOutsideClickOnTrigger.current=!1:toggleVisibility(!isVisible,VisibilityChangeReason.triggerClick)},[toggleVisibility,isVisible]),handleClickOutsideDeactivates=(0,_react.useCallback)(evt=>(triggerRef.current&&triggerRef.current.contains(evt.target)&&(isOutsideClickOnTrigger.current=!0),!0),[triggerRef,isOutsideClickOnTrigger]),handlePostDeactivate=(0,_react.useCallback)(()=>{toggleVisibility(!1,isOutsideClickOnTrigger.current?VisibilityChangeReason.triggerClick:VisibilityChangeReason.outsideClick)},[toggleVisibility]);(0,_react.useEffect)(()=>{setVisible(isPopoverVisible)},[isPopoverVisible]),(0,_react.useEffect)(()=>{setIsMobileBreakpoint(getMobileBreakpoint(renderAsSheetOnMobile))},[isVisible,renderAsSheetOnMobile]),(0,_react.useEffect)(()=>{let trigger;if(externalTriggerRef?.current&&!children){let triggerTabIndex=(trigger=externalTriggerRef.current).getAttribute("tabindex");trigger.setAttribute("tabindex",triggerTabIndex??"0"),trigger.addEventListener("click",handleTriggerClick)}return()=>{trigger&&trigger.removeEventListener("click",handleTriggerClick)}},[externalTriggerRef,children,handleTriggerClick]),(0,_react.useEffect)(()=>{if(externalTriggerRef?.current&&!children){let trigger=externalTriggerRef.current;trigger.setAttribute("aria-haspopup","true"),isVisible?(trigger.setAttribute("aria-expanded","true"),trigger.setAttribute("aria-controls",tooltipId)):(trigger.removeAttribute("aria-expanded"),trigger.removeAttribute("aria-controls"))}},[externalTriggerRef,children,tooltipId,isVisible]);let triggerElm=children?_react.default.cloneElement(children,{ref:triggerRef,...isVisible&&{"aria-expanded":!0,"aria-controls":tooltipId},tabIndex:children.props.tabIndex??0,"aria-haspopup":!0,onClick:evt=>{handleTriggerClick(),children.props.onClick&&children.props.onClick(evt)}}):null;if(isMobileBreakPoint){let sheetElm=_react.default.createElement(_Sheet.Sheet,{id:tooltipId,isVisible:isVisible,portalContainer:portalContainer,dismissOnOutsideClick:dismissOnOutsideClick,disableInitialFocus:disableInitialFocus,disableReturnFocusToTrigger:disableReturnFocusToTrigger,onClose:handlePostDeactivate,onClickOutsideDeactivates:handleClickOutsideDeactivates,...sheetProps??{}},content);return _react.default.createElement(_react.default.Fragment,null,triggerElm,sheetElm)}let contentElm=_react.default.createElement(_FocusTrapWrapper.FocusTrapWrapper,{active:isVisible,focusTrapOptions:{clickOutsideDeactivates:dismissOnOutsideClick&&handleClickOutsideDeactivates,allowOutsideClick:!0,escapeDeactivates:!0,fallbackFocus:`#${tooltipId}`,onPostDeactivate:handlePostDeactivate,preventScroll:!0,initialFocus:()=>!disableInitialFocus,returnFocusOnDeactivate:!disableReturnFocusToTrigger}},_react.default.createElement(FocusTrapContent,null,content)),tooltipElm=_react.default.createElement(_TooltipContent.TooltipContent,{...restContentProps,defaultVerticalPlacement:defaultVerticalPlacement,dataDSId:name,content:contentElm,contentPadding:contentPadding,maxWidth:maxWidth,placement:placement,portalContainer:portalContainer,dataE2eTestId:dataE2eTestId,subTheme:subTheme,isVisible:isVisible,tooltipId:tooltipId,triggerRef:triggerRef});return _react.default.createElement(_react.default.Fragment,null,triggerElm,tooltipElm)}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"BasePopover",{enumerable:!0,get:function(){return BasePopover}});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")),_TooltipContent=require("../Tooltip/TooltipContent"),_Sheet=require("../Sheet/Sheet"),_FocusTrapWrapper=require("../../shared/FocusTrapWrapper"),_breakpointsjson=/*#__PURE__*/_interop_require_default._(require("../../web-tokens/_breakpoints.json")),StyledContainer=(0,_styled.default)("div",{target:"equiaof0",label:"StyledContainer"})(()=>({borderRadius:"inherit"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Toggletip/BasePopover.tsx","sources":["src/components/Toggletip/BasePopover.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type {\n  ReactElement,\n  PropsWithChildren,\n  MouseEvent as ReactMouseEvent,\n} from \"react\";\nimport React, {\n  useState,\n  useRef,\n  useEffect,\n  useCallback,\n  useMemo,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TooltipContentProps } from \"../Tooltip/TooltipContent\";\nimport type { TooltipConditionalProps } from \"../Tooltip/types\";\nimport { TooltipContent } from \"../Tooltip/TooltipContent\";\nimport { Sheet } from \"../Sheet/Sheet\";\nimport { FocusTrapWrapper } from \"../../shared/FocusTrapWrapper\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\n\ntype BaseProps = Pick<\n  TooltipContentProps,\n  | \"placement\"\n  | \"portalContainer\"\n  | \"maxWidth\"\n  | \"contentPadding\"\n  | \"hideArrow\"\n  | \"subTheme\"\n  | \"defaultVerticalPlacement\"\n  | \"onOverflowViewport\"\n> & {\n  name?: string;\n  /**  Popover content */\n  content: ReactElement;\n  \"data-e2e-test-id\"?: string;\n  /**  Programmatically toggle Popover visibility with this prop */\n  isVisible?: boolean;\n  /**  Called when tooltip appears and disappears */\n  onVisibilityChange?: (isVisible: boolean, reason: string) => void;\n  /**  Controls whether BasePopover  closes on outside click */\n  dismissOnOutsideClick?: boolean;\n  /**  Option for focus-trap, controls whether the first focuable item recieves focus */\n  disableInitialFocus?: boolean;\n  /**  Option for focus-trap, controls whether the trigger should receive back the focus on popover close */\n  disableReturnFocusToTrigger?: boolean;\n  /**  Render as sheet on mobile web */\n  renderAsSheetOnMobile?: boolean;\n  /**  Props for configuring the sheet on mobile web */\n  sheetProps?: {\n    /**  Show the dark scrim backdrop on mobile web when rendering as Sheet */\n    hasBackdrop?: boolean;\n  };\n};\n\nexport type BasePopoverProps = BaseProps & TooltipConditionalProps;\n\nconst StyledContainer = styled.div(() => ({\n  borderRadius: \"inherit\",\n}));\n\nconst FocusTrapContent = React.forwardRef<\n  HTMLDivElement,\n  PropsWithChildren<unknown>\n>(({ children }, ref) => (\n  <StyledContainer ref={ref}>{children}</StyledContainer>\n));\n\nconst VisibilityChangeReason = {\n  triggerClick: \"triggerClick\",\n  outsideClick: \"outsideClick\",\n};\n\nfunction getMobileBreakpoint(renderAsSheetOnMobile: boolean) {\n  return (\n    !!window &&\n    renderAsSheetOnMobile &&\n    window.innerWidth <= breakpoints.medium.value\n  );\n}\n\nexport function BasePopover({\n  placement = \"auto\",\n  content,\n  children,\n  contentPadding = \"m\",\n  maxWidth,\n  externalTriggerRef,\n  portalContainer,\n  name = \"Popover\",\n  isVisible: isPopoverVisible,\n  dismissOnOutsideClick = true,\n  \"data-e2e-test-id\": dataE2eTestId,\n  subTheme,\n  defaultVerticalPlacement,\n  onVisibilityChange,\n  disableInitialFocus = false,\n  disableReturnFocusToTrigger = false,\n  renderAsSheetOnMobile = false,\n  sheetProps,\n  ...restContentProps\n}: BasePopoverProps): React.ReactElement {\n  const tooltipId = useMemo(\n    () => `DS${name}_${Math.floor(Date.now() * Math.random())}`,\n    [name]\n  );\n  const [isVisible, setVisible] = useState(isPopoverVisible);\n  const [isMobileBreakPoint, setIsMobileBreakpoint] = useState(\n    getMobileBreakpoint(renderAsSheetOnMobile)\n  );\n  const internalTriggerRef = useRef<HTMLElement>(null);\n  const triggerRef = externalTriggerRef || internalTriggerRef;\n  const isOutsideClickOnTrigger = useRef(false);\n\n  const toggleVisibility = useCallback(\n    (status: boolean, reason: string) => {\n      setVisible(status);\n\n      if (onVisibilityChange) {\n        onVisibilityChange(status, reason);\n      }\n    },\n    [onVisibilityChange]\n  );\n\n  // Outside click is also fired when the Popover is open and trigger is clicked. `isOutsideClickOnTrigger` saves this condition and we check for it so as to not toggle the Popover twice.\n  const handleTriggerClick = useCallback(() => {\n    if (!isOutsideClickOnTrigger.current) {\n      toggleVisibility(!isVisible, VisibilityChangeReason.triggerClick);\n    } else {\n      // reset this value so that Popover can open in next click\n      isOutsideClickOnTrigger.current = false;\n    }\n  }, [toggleVisibility, isVisible]);\n\n  const handleClickOutsideDeactivates = useCallback(\n    (evt: MouseEvent) => {\n      if (\n        triggerRef.current &&\n        triggerRef.current.contains(evt.target as Node)\n      ) {\n        isOutsideClickOnTrigger.current = true;\n      }\n      return true;\n    },\n    [triggerRef, isOutsideClickOnTrigger]\n  );\n\n  const handlePostDeactivate = useCallback(() => {\n    const reason = isOutsideClickOnTrigger.current\n      ? VisibilityChangeReason.triggerClick\n      : VisibilityChangeReason.outsideClick;\n\n    toggleVisibility(false, reason);\n  }, [toggleVisibility]);\n\n  useEffect(() => {\n    setVisible(isPopoverVisible);\n  }, [isPopoverVisible]);\n\n  useEffect(() => {\n    // Check if this is a mobile breakpoint\n    setIsMobileBreakpoint(getMobileBreakpoint(renderAsSheetOnMobile));\n  }, [isVisible, renderAsSheetOnMobile]);\n\n  useEffect(() => {\n    let trigger: HTMLElement;\n\n    if (externalTriggerRef?.current && !children) {\n      trigger = externalTriggerRef.current;\n      const triggerTabIndex = trigger.getAttribute(\"tabindex\");\n\n      trigger.setAttribute(\"tabindex\", triggerTabIndex ?? \"0\");\n      trigger.addEventListener(\"click\", handleTriggerClick);\n    }\n\n    return () => {\n      if (trigger) {\n        trigger.removeEventListener(\"click\", handleTriggerClick);\n      }\n    };\n  }, [externalTriggerRef, children, handleTriggerClick]);\n\n  useEffect(() => {\n    if (externalTriggerRef?.current && !children) {\n      const trigger = externalTriggerRef.current;\n\n      trigger.setAttribute(\"aria-haspopup\", \"true\");\n      if (isVisible) {\n        trigger.setAttribute(\"aria-expanded\", \"true\");\n        trigger.setAttribute(\"aria-controls\", tooltipId);\n      } else {\n        trigger.removeAttribute(\"aria-expanded\");\n        trigger.removeAttribute(\"aria-controls\");\n      }\n    }\n  }, [externalTriggerRef, children, tooltipId, isVisible]);\n\n  const triggerElm = children\n    ? React.cloneElement(children, {\n        ref: triggerRef,\n        ...(isVisible && {\n          \"aria-expanded\": true,\n          \"aria-controls\": tooltipId,\n        }),\n        tabIndex: children.props.tabIndex ?? 0,\n        \"aria-haspopup\": true,\n        onClick: (evt: ReactMouseEvent) => {\n          handleTriggerClick();\n          if (children.props.onClick) {\n            children.props.onClick(evt);\n          }\n        },\n      })\n    : null;\n\n  if (isMobileBreakPoint) {\n    // render as Sheet\n    const sheetElm = (\n      <Sheet\n        id={tooltipId}\n        isVisible={isVisible}\n        portalContainer={portalContainer}\n        dismissOnOutsideClick={dismissOnOutsideClick}\n        disableInitialFocus={disableInitialFocus}\n        disableReturnFocusToTrigger={disableReturnFocusToTrigger}\n        onClose={handlePostDeactivate}\n        onClickOutsideDeactivates={handleClickOutsideDeactivates}\n        {...(sheetProps ?? {})}\n      >\n        {content}\n      </Sheet>\n    );\n\n    return (\n      <>\n        {triggerElm}\n        {sheetElm}\n      </>\n    );\n  }\n\n  // render as Popover\n  const contentElm = (\n    <FocusTrapWrapper\n      active={isVisible}\n      focusTrapOptions={{\n        clickOutsideDeactivates:\n          dismissOnOutsideClick && handleClickOutsideDeactivates, // de-activate focus trap on outside click\n        allowOutsideClick: true,\n        escapeDeactivates: true,\n        fallbackFocus: `#${tooltipId}`, // set focus to tooltip content container if it has no focusable element\n        onPostDeactivate: handlePostDeactivate,\n        preventScroll: true,\n        initialFocus: () => !disableInitialFocus,\n        returnFocusOnDeactivate: !disableReturnFocusToTrigger,\n      }}\n    >\n      <FocusTrapContent>{content}</FocusTrapContent>\n    </FocusTrapWrapper>\n  );\n\n  const tooltipElm = (\n    <TooltipContent\n      {...restContentProps} // eslint-disable-line react/jsx-props-no-spreading\n      defaultVerticalPlacement={defaultVerticalPlacement}\n      dataDSId={name}\n      content={contentElm}\n      contentPadding={contentPadding}\n      maxWidth={maxWidth}\n      placement={placement}\n      portalContainer={portalContainer}\n      dataE2eTestId={dataE2eTestId}\n      subTheme={subTheme}\n      isVisible={isVisible}\n      tooltipId={tooltipId}\n      triggerRef={triggerRef}\n    />\n  );\n\n  return (\n    <>\n      {triggerElm}\n      {tooltipElm}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAyDwB"} */"),FocusTrapContent=_react.default.forwardRef(({children},ref)=>_react.default.createElement(StyledContainer,{ref:ref},children)),VisibilityChangeReason={triggerClick:"triggerClick",outsideClick:"outsideClick"};function getMobileBreakpoint(renderAsSheetOnMobile){return!!window&&renderAsSheetOnMobile&&window.innerWidth<=_breakpointsjson.default.medium.value}function BasePopover({placement="auto",content,children,contentPadding="m",maxWidth,externalTriggerRef,portalContainer,name="Popover",isVisible:isPopoverVisible,dismissOnOutsideClick=!0,"data-e2e-test-id":dataE2eTestId,subTheme,defaultVerticalPlacement,onVisibilityChange,disableInitialFocus=!1,disableReturnFocusToTrigger=!1,renderAsSheetOnMobile=!1,sheetProps,...restContentProps}){let tooltipId=(0,_react.useMemo)(()=>`DS${name}_${Math.floor(Date.now()*Math.random())}`,[name]),[isVisible,setVisible]=(0,_react.useState)(isPopoverVisible),[isMobileBreakPoint,setIsMobileBreakpoint]=(0,_react.useState)(getMobileBreakpoint(renderAsSheetOnMobile)),internalTriggerRef=(0,_react.useRef)(null),triggerRef=externalTriggerRef||internalTriggerRef,isOutsideClickOnTrigger=(0,_react.useRef)(!1),toggleVisibility=(0,_react.useCallback)((status,reason)=>{setVisible(status),onVisibilityChange&&onVisibilityChange(status,reason)},[onVisibilityChange]),handleTriggerClick=(0,_react.useCallback)(()=>{isOutsideClickOnTrigger.current?isOutsideClickOnTrigger.current=!1:toggleVisibility(!isVisible,VisibilityChangeReason.triggerClick)},[toggleVisibility,isVisible]),handleClickOutsideDeactivates=(0,_react.useCallback)(evt=>(triggerRef.current&&triggerRef.current.contains(evt.target)&&(isOutsideClickOnTrigger.current=!0),!0),[triggerRef,isOutsideClickOnTrigger]),handlePostDeactivate=(0,_react.useCallback)(()=>{toggleVisibility(!1,isOutsideClickOnTrigger.current?VisibilityChangeReason.triggerClick:VisibilityChangeReason.outsideClick)},[toggleVisibility]);(0,_react.useEffect)(()=>{setVisible(isPopoverVisible)},[isPopoverVisible]),(0,_react.useEffect)(()=>{setIsMobileBreakpoint(getMobileBreakpoint(renderAsSheetOnMobile))},[isVisible,renderAsSheetOnMobile]),(0,_react.useEffect)(()=>{let trigger;if(externalTriggerRef?.current&&!children){let triggerTabIndex=(trigger=externalTriggerRef.current).getAttribute("tabindex");trigger.setAttribute("tabindex",triggerTabIndex??"0"),trigger.addEventListener("click",handleTriggerClick)}return()=>{trigger&&trigger.removeEventListener("click",handleTriggerClick)}},[externalTriggerRef,children,handleTriggerClick]),(0,_react.useEffect)(()=>{if(externalTriggerRef?.current&&!children){let trigger=externalTriggerRef.current;trigger.setAttribute("aria-haspopup","true"),isVisible?(trigger.setAttribute("aria-expanded","true"),trigger.setAttribute("aria-controls",tooltipId)):(trigger.removeAttribute("aria-expanded"),trigger.removeAttribute("aria-controls"))}},[externalTriggerRef,children,tooltipId,isVisible]);let triggerElm=children?_react.default.cloneElement(children,{ref:triggerRef,...isVisible&&{"aria-expanded":!0,"aria-controls":tooltipId},tabIndex:children.props.tabIndex??0,"aria-haspopup":!0,onClick:evt=>{handleTriggerClick(),children.props.onClick&&children.props.onClick(evt)}}):null;if(isMobileBreakPoint){let sheetElm=_react.default.createElement(_Sheet.Sheet,{id:tooltipId,isVisible:isVisible,portalContainer:portalContainer,dismissOnOutsideClick:dismissOnOutsideClick,disableInitialFocus:disableInitialFocus,disableReturnFocusToTrigger:disableReturnFocusToTrigger,onClose:handlePostDeactivate,onClickOutsideDeactivates:handleClickOutsideDeactivates,...sheetProps??{}},content);return _react.default.createElement(_react.default.Fragment,null,triggerElm,sheetElm)}let contentElm=_react.default.createElement(_FocusTrapWrapper.FocusTrapWrapper,{active:isVisible,focusTrapOptions:{clickOutsideDeactivates:dismissOnOutsideClick&&handleClickOutsideDeactivates,allowOutsideClick:!0,escapeDeactivates:!0,fallbackFocus:`#${tooltipId}`,onPostDeactivate:handlePostDeactivate,preventScroll:!0,initialFocus:()=>!disableInitialFocus,returnFocusOnDeactivate:!disableReturnFocusToTrigger}},_react.default.createElement(FocusTrapContent,null,content)),tooltipElm=_react.default.createElement(_TooltipContent.TooltipContent,{...restContentProps,defaultVerticalPlacement:defaultVerticalPlacement,dataDSId:name,content:contentElm,contentPadding:contentPadding,maxWidth:maxWidth,placement:placement,portalContainer:portalContainer,dataE2eTestId:dataE2eTestId,subTheme:subTheme,isVisible:isVisible,tooltipId:tooltipId,triggerRef:triggerRef});return _react.default.createElement(_react.default.Fragment,null,triggerElm,tooltipElm)}
@@ -11,7 +11,7 @@ export type HeaderProps = {
11
11
  color?: BaseColors;
12
12
  overflowWrap?: OverflowWrap;
13
13
  hyphens?: Hyphens;
14
- };
14
+ } & React.HTMLAttributes<HTMLHeadingElement>;
15
15
  export declare const H1: ({ "data-ds-id": dataDsId, ...props }: HeaderProps) => React.ReactElement;
16
16
  export declare const H2: ({ "data-ds-id": dataDsId, ...props }: HeaderProps) => React.ReactElement;
17
17
  export declare const H3: ({ "data-ds-id": dataDsId, ...props }: HeaderProps) => React.ReactElement;