@amboss/design-system 3.15.8 → 3.17.0

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.
Files changed (26) hide show
  1. package/build/cjs/components/BulkActionsToolbar/BulkActionsToolbar.js +1 -1
  2. package/build/cjs/components/CatalogCard/CatalogCard.js +1 -1
  3. package/build/cjs/components/DropdownMenu/DropdownMenu.d.ts +8 -3
  4. package/build/cjs/components/DropdownMenu/DropdownMenu.js +1 -1
  5. package/build/cjs/components/Form/SegmentedControl/SegmentedControl.js +1 -1
  6. package/build/cjs/components/Form/SegmentedControl/SegmentedControlOption.js +1 -1
  7. package/build/cjs/components/MediaViewerCarousel/MediaViewerCarousel.js +1 -1
  8. package/build/cjs/components/Toggletip/BasePopover.js +1 -1
  9. package/build/cjs/shared/mediaQueries.js +1 -1
  10. package/build/cjs/web-tokens/_breakpoints.json +21 -9
  11. package/build/cjs/web-tokens/visualConfig.d.ts +5 -3
  12. package/build/cjs/web-tokens/visualConfig.js +1 -1
  13. package/build/esm/components/BulkActionsToolbar/BulkActionsToolbar.js +1 -1
  14. package/build/esm/components/CatalogCard/CatalogCard.js +1 -1
  15. package/build/esm/components/DropdownMenu/DropdownMenu.d.ts +8 -3
  16. package/build/esm/components/DropdownMenu/DropdownMenu.js +1 -1
  17. package/build/esm/components/Form/SegmentedControl/SegmentedControl.js +1 -1
  18. package/build/esm/components/Form/SegmentedControl/SegmentedControlOption.js +1 -1
  19. package/build/esm/components/MediaViewerCarousel/MediaViewerCarousel.js +1 -1
  20. package/build/esm/components/Toggletip/BasePopover.js +1 -1
  21. package/build/esm/shared/mediaQueries.js +1 -1
  22. package/build/esm/web-tokens/_breakpoints.json +21 -9
  23. package/build/esm/web-tokens/visualConfig.d.ts +5 -3
  24. package/build/esm/web-tokens/visualConfig.js +1 -1
  25. package/build/scss/_variables.scss +5 -3
  26. package/package.json +1 -1
@@ -1 +1 @@
1
- import React from"react";import styled from"@emotion/styled";import{Container}from"../Container/Container";import{DropdownMenu}from"../DropdownMenu/DropdownMenu";import{Box}from"../Box/Box";import{Column,Columns}from"../Column/Columns";import{Stack}from"../Stack/Stack";import{Text}from"../Typography/Text/Text";import{TextClamped}from"../Typography/TextClamped/TextClamped";import{ColorPickerDropdown}from"../ColorPicker/ColorPickerDropdown";import breakpoints from"../../web-tokens/_breakpoints.json";let StyledDropdownMenuContainer=styled("div",{target:"e1g0lujp0",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 { type DropdownItem, DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport type { ColorPickerProps } from \"../ColorPicker/ColorPicker\";\nimport {\n  ColorPickerDropdown,\n  type ColorPickerDropdownItemProps,\n} from \"../ColorPicker/ColorPickerDropdown\";\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 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\n// Shared types for component props\ntype TopRightComponentProps = {\n  portalContainer?: PortalProps[\"portalContainer\"];\n  isMobile: boolean;\n};\n\ntype TopRightDropdownMenuProps = TopRightComponentProps & {\n  menuItems: DropdownItem[];\n  onMenuOpen?: (ev: MouseEvent | KeyboardEvent) => void;\n};\n\ntype TopRightColorPickerProps = TopRightComponentProps & {\n  colorPickerProps: ColorPickerProps;\n  menuItems: (DropdownItem | ColorPickerDropdownItemProps)[];\n};\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  // Make sure that focus indicator is only visivle when the hidden button is in focus\n  [`&:has(${StyledButton}:focus-visible)`]: {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        outlineColor: \"-webkit-focus-ring-color\",\n        outlineStyle: \"solid\",\n      },\n    },\n  },\n\n  \"&:focus-within\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      outline: \"none\",\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 StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\nconst TopRightDropdownMenu = ({\n  menuItems,\n  onMenuOpen,\n  portalContainer,\n  isMobile,\n}: TopRightDropdownMenuProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <DropdownMenu\n        iconName=\"more-horizontal\"\n        menuItems={menuItems}\n        onMenuOpen={onMenuOpen}\n        portalContainer={portalContainer}\n        size=\"s\"\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nconst TopRightColorPicker = ({\n  colorPickerProps,\n  menuItems,\n  portalContainer,\n  isMobile,\n}: TopRightColorPickerProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <ColorPickerDropdown\n        portalContainer={portalContainer}\n        {...colorPickerProps}\n        menuItems={menuItems}\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  subtitleLines?: number | \"none\";\n  dropdownMenuOptions?: (DropdownItem | ColorPickerDropdownItemProps)[];\n  colorPickerProps?: ColorPickerProps;\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  subtitleLines = 1,\n  colorPickerProps,\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\n  const renderTopRightElement = () => {\n    if (colorPickerProps) {\n      return (\n        <TopRightColorPicker\n          colorPickerProps={colorPickerProps}\n          menuItems={dropdownMenuOptions}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    if (dropdownMenuOptions.length > 0) {\n      return (\n        <TopRightDropdownMenu\n          menuItems={dropdownMenuOptions as DropdownItem[]}\n          onMenuOpen={onDropdownClick}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    return null;\n  };\n\n  const topRightElement = renderTopRightElement();\n  const SubtitleComponent = subtitleLines === \"none\" ? Text : TextClamped;\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        privateProps={{ border: true }}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size=\"fill\">\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                        <SubtitleComponent\n                          size=\"s\"\n                          color=\"tertiary\"\n                          {...(subtitleLines !== \"none\" && {\n                            lines: subtitleLines,\n                          })}\n                        >\n                          {subtitle}\n                        </SubtitleComponent>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              {topRightElement && (\n                <Column size=\"narrow\">{topRightElement}</Column>\n              )}\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAiBoC"} */"),StyledButton=styled("button",{target:"e1g0lujp1",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 { type DropdownItem, DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport type { ColorPickerProps } from \"../ColorPicker/ColorPicker\";\nimport {\n  ColorPickerDropdown,\n  type ColorPickerDropdownItemProps,\n} from \"../ColorPicker/ColorPickerDropdown\";\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 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\n// Shared types for component props\ntype TopRightComponentProps = {\n  portalContainer?: PortalProps[\"portalContainer\"];\n  isMobile: boolean;\n};\n\ntype TopRightDropdownMenuProps = TopRightComponentProps & {\n  menuItems: DropdownItem[];\n  onMenuOpen?: (ev: MouseEvent | KeyboardEvent) => void;\n};\n\ntype TopRightColorPickerProps = TopRightComponentProps & {\n  colorPickerProps: ColorPickerProps;\n  menuItems: (DropdownItem | ColorPickerDropdownItemProps)[];\n};\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  // Make sure that focus indicator is only visivle when the hidden button is in focus\n  [`&:has(${StyledButton}:focus-visible)`]: {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        outlineColor: \"-webkit-focus-ring-color\",\n        outlineStyle: \"solid\",\n      },\n    },\n  },\n\n  \"&:focus-within\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      outline: \"none\",\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 StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\nconst TopRightDropdownMenu = ({\n  menuItems,\n  onMenuOpen,\n  portalContainer,\n  isMobile,\n}: TopRightDropdownMenuProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <DropdownMenu\n        iconName=\"more-horizontal\"\n        menuItems={menuItems}\n        onMenuOpen={onMenuOpen}\n        portalContainer={portalContainer}\n        size=\"s\"\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nconst TopRightColorPicker = ({\n  colorPickerProps,\n  menuItems,\n  portalContainer,\n  isMobile,\n}: TopRightColorPickerProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <ColorPickerDropdown\n        portalContainer={portalContainer}\n        {...colorPickerProps}\n        menuItems={menuItems}\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  subtitleLines?: number | \"none\";\n  dropdownMenuOptions?: (DropdownItem | ColorPickerDropdownItemProps)[];\n  colorPickerProps?: ColorPickerProps;\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  subtitleLines = 1,\n  colorPickerProps,\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\n  const renderTopRightElement = () => {\n    if (colorPickerProps) {\n      return (\n        <TopRightColorPicker\n          colorPickerProps={colorPickerProps}\n          menuItems={dropdownMenuOptions}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    if (dropdownMenuOptions.length > 0) {\n      return (\n        <TopRightDropdownMenu\n          menuItems={dropdownMenuOptions as DropdownItem[]}\n          onMenuOpen={onDropdownClick}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    return null;\n  };\n\n  const topRightElement = renderTopRightElement();\n  const SubtitleComponent = subtitleLines === \"none\" ? Text : TextClamped;\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        privateProps={{ border: true }}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size=\"fill\">\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                        <SubtitleComponent\n                          size=\"s\"\n                          color=\"tertiary\"\n                          {...(subtitleLines !== \"none\" && {\n                            lines: subtitleLines,\n                          })}\n                        >\n                          {subtitle}\n                        </SubtitleComponent>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              {topRightElement && (\n                <Column size=\"narrow\">{topRightElement}</Column>\n              )}\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AA0BqB"} */"),StyledWrapper=styled("div",{target:"e1g0lujp2",label:"StyledWrapper"})(({theme})=>({position:"relative",height:"100%","> div":{height:"100%"},[`&:has(${StyledButton}:focus-visible)`]:{"> div":{outlineWidth:2,outlineStyle:"solid",outlineColor:"Highlight",outlineOffset:-1,"@media (-webkit-min-device-pixel-ratio:0)":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"solid"}}},"&:focus-within":{[`${StyledDropdownMenuContainer}`]:{visibility:"visible"}},"&:hover":{"> div":{outline:"none",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 { type DropdownItem, DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport type { ColorPickerProps } from \"../ColorPicker/ColorPicker\";\nimport {\n  ColorPickerDropdown,\n  type ColorPickerDropdownItemProps,\n} from \"../ColorPicker/ColorPickerDropdown\";\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 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\n// Shared types for component props\ntype TopRightComponentProps = {\n  portalContainer?: PortalProps[\"portalContainer\"];\n  isMobile: boolean;\n};\n\ntype TopRightDropdownMenuProps = TopRightComponentProps & {\n  menuItems: DropdownItem[];\n  onMenuOpen?: (ev: MouseEvent | KeyboardEvent) => void;\n};\n\ntype TopRightColorPickerProps = TopRightComponentProps & {\n  colorPickerProps: ColorPickerProps;\n  menuItems: (DropdownItem | ColorPickerDropdownItemProps)[];\n};\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  // Make sure that focus indicator is only visivle when the hidden button is in focus\n  [`&:has(${StyledButton}:focus-visible)`]: {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        outlineColor: \"-webkit-focus-ring-color\",\n        outlineStyle: \"solid\",\n      },\n    },\n  },\n\n  \"&:focus-within\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      outline: \"none\",\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 StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\nconst TopRightDropdownMenu = ({\n  menuItems,\n  onMenuOpen,\n  portalContainer,\n  isMobile,\n}: TopRightDropdownMenuProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <DropdownMenu\n        iconName=\"more-horizontal\"\n        menuItems={menuItems}\n        onMenuOpen={onMenuOpen}\n        portalContainer={portalContainer}\n        size=\"s\"\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nconst TopRightColorPicker = ({\n  colorPickerProps,\n  menuItems,\n  portalContainer,\n  isMobile,\n}: TopRightColorPickerProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <ColorPickerDropdown\n        portalContainer={portalContainer}\n        {...colorPickerProps}\n        menuItems={menuItems}\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  subtitleLines?: number | \"none\";\n  dropdownMenuOptions?: (DropdownItem | ColorPickerDropdownItemProps)[];\n  colorPickerProps?: ColorPickerProps;\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  subtitleLines = 1,\n  colorPickerProps,\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\n  const renderTopRightElement = () => {\n    if (colorPickerProps) {\n      return (\n        <TopRightColorPicker\n          colorPickerProps={colorPickerProps}\n          menuItems={dropdownMenuOptions}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    if (dropdownMenuOptions.length > 0) {\n      return (\n        <TopRightDropdownMenu\n          menuItems={dropdownMenuOptions as DropdownItem[]}\n          onMenuOpen={onDropdownClick}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    return null;\n  };\n\n  const topRightElement = renderTopRightElement();\n  const SubtitleComponent = subtitleLines === \"none\" ? Text : TextClamped;\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        privateProps={{ border: true }}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size=\"fill\">\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                        <SubtitleComponent\n                          size=\"s\"\n                          color=\"tertiary\"\n                          {...(subtitleLines !== \"none\" && {\n                            lines: subtitleLines,\n                          })}\n                        >\n                          {subtitle}\n                        </SubtitleComponent>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              {topRightElement && (\n                <Column size=\"narrow\">{topRightElement}</Column>\n              )}\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAoDsB"} */"),StyledContainer=styled("div",{target:"e1g0lujp3",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 { type DropdownItem, DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport type { ColorPickerProps } from \"../ColorPicker/ColorPicker\";\nimport {\n  ColorPickerDropdown,\n  type ColorPickerDropdownItemProps,\n} from \"../ColorPicker/ColorPickerDropdown\";\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 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\n// Shared types for component props\ntype TopRightComponentProps = {\n  portalContainer?: PortalProps[\"portalContainer\"];\n  isMobile: boolean;\n};\n\ntype TopRightDropdownMenuProps = TopRightComponentProps & {\n  menuItems: DropdownItem[];\n  onMenuOpen?: (ev: MouseEvent | KeyboardEvent) => void;\n};\n\ntype TopRightColorPickerProps = TopRightComponentProps & {\n  colorPickerProps: ColorPickerProps;\n  menuItems: (DropdownItem | ColorPickerDropdownItemProps)[];\n};\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  // Make sure that focus indicator is only visivle when the hidden button is in focus\n  [`&:has(${StyledButton}:focus-visible)`]: {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        outlineColor: \"-webkit-focus-ring-color\",\n        outlineStyle: \"solid\",\n      },\n    },\n  },\n\n  \"&:focus-within\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      outline: \"none\",\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 StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\nconst TopRightDropdownMenu = ({\n  menuItems,\n  onMenuOpen,\n  portalContainer,\n  isMobile,\n}: TopRightDropdownMenuProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <DropdownMenu\n        iconName=\"more-horizontal\"\n        menuItems={menuItems}\n        onMenuOpen={onMenuOpen}\n        portalContainer={portalContainer}\n        size=\"s\"\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nconst TopRightColorPicker = ({\n  colorPickerProps,\n  menuItems,\n  portalContainer,\n  isMobile,\n}: TopRightColorPickerProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <ColorPickerDropdown\n        portalContainer={portalContainer}\n        {...colorPickerProps}\n        menuItems={menuItems}\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  subtitleLines?: number | \"none\";\n  dropdownMenuOptions?: (DropdownItem | ColorPickerDropdownItemProps)[];\n  colorPickerProps?: ColorPickerProps;\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  subtitleLines = 1,\n  colorPickerProps,\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\n  const renderTopRightElement = () => {\n    if (colorPickerProps) {\n      return (\n        <TopRightColorPicker\n          colorPickerProps={colorPickerProps}\n          menuItems={dropdownMenuOptions}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    if (dropdownMenuOptions.length > 0) {\n      return (\n        <TopRightDropdownMenu\n          menuItems={dropdownMenuOptions as DropdownItem[]}\n          onMenuOpen={onDropdownClick}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    return null;\n  };\n\n  const topRightElement = renderTopRightElement();\n  const SubtitleComponent = subtitleLines === \"none\" ? Text : TextClamped;\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        privateProps={{ border: true }}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size=\"fill\">\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                        <SubtitleComponent\n                          size=\"s\"\n                          color=\"tertiary\"\n                          {...(subtitleLines !== \"none\" && {\n                            lines: subtitleLines,\n                          })}\n                        >\n                          {subtitle}\n                        </SubtitleComponent>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              {topRightElement && (\n                <Column size=\"narrow\">{topRightElement}</Column>\n              )}\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AA0FwB"} */"),StyledTitle=styled("div",{target:"e1g0lujp4",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 { type DropdownItem, DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport type { ColorPickerProps } from \"../ColorPicker/ColorPicker\";\nimport {\n  ColorPickerDropdown,\n  type ColorPickerDropdownItemProps,\n} from \"../ColorPicker/ColorPickerDropdown\";\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 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\n// Shared types for component props\ntype TopRightComponentProps = {\n  portalContainer?: PortalProps[\"portalContainer\"];\n  isMobile: boolean;\n};\n\ntype TopRightDropdownMenuProps = TopRightComponentProps & {\n  menuItems: DropdownItem[];\n  onMenuOpen?: (ev: MouseEvent | KeyboardEvent) => void;\n};\n\ntype TopRightColorPickerProps = TopRightComponentProps & {\n  colorPickerProps: ColorPickerProps;\n  menuItems: (DropdownItem | ColorPickerDropdownItemProps)[];\n};\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  // Make sure that focus indicator is only visivle when the hidden button is in focus\n  [`&:has(${StyledButton}:focus-visible)`]: {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        outlineColor: \"-webkit-focus-ring-color\",\n        outlineStyle: \"solid\",\n      },\n    },\n  },\n\n  \"&:focus-within\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      outline: \"none\",\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 StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\nconst TopRightDropdownMenu = ({\n  menuItems,\n  onMenuOpen,\n  portalContainer,\n  isMobile,\n}: TopRightDropdownMenuProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <DropdownMenu\n        iconName=\"more-horizontal\"\n        menuItems={menuItems}\n        onMenuOpen={onMenuOpen}\n        portalContainer={portalContainer}\n        size=\"s\"\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nconst TopRightColorPicker = ({\n  colorPickerProps,\n  menuItems,\n  portalContainer,\n  isMobile,\n}: TopRightColorPickerProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <ColorPickerDropdown\n        portalContainer={portalContainer}\n        {...colorPickerProps}\n        menuItems={menuItems}\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  subtitleLines?: number | \"none\";\n  dropdownMenuOptions?: (DropdownItem | ColorPickerDropdownItemProps)[];\n  colorPickerProps?: ColorPickerProps;\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  subtitleLines = 1,\n  colorPickerProps,\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\n  const renderTopRightElement = () => {\n    if (colorPickerProps) {\n      return (\n        <TopRightColorPicker\n          colorPickerProps={colorPickerProps}\n          menuItems={dropdownMenuOptions}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    if (dropdownMenuOptions.length > 0) {\n      return (\n        <TopRightDropdownMenu\n          menuItems={dropdownMenuOptions as DropdownItem[]}\n          onMenuOpen={onDropdownClick}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    return null;\n  };\n\n  const topRightElement = renderTopRightElement();\n  const SubtitleComponent = subtitleLines === \"none\" ? Text : TextClamped;\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        privateProps={{ border: true }}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size=\"fill\">\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                        <SubtitleComponent\n                          size=\"s\"\n                          color=\"tertiary\"\n                          {...(subtitleLines !== \"none\" && {\n                            lines: subtitleLines,\n                          })}\n                        >\n                          {subtitle}\n                        </SubtitleComponent>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              {topRightElement && (\n                <Column size=\"narrow\">{topRightElement}</Column>\n              )}\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAiHoB"} */"),TopRightDropdownMenu=({menuItems,onMenuOpen,portalContainer,isMobile})=>React.createElement(Box,{space:"xxs",bSpace:"zero"},React.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},React.createElement(DropdownMenu,{iconName:"more-horizontal",menuItems:menuItems,onMenuOpen:onMenuOpen,portalContainer:portalContainer,size:"s"}))),TopRightColorPicker=({colorPickerProps,menuItems,portalContainer,isMobile})=>React.createElement(Box,{space:"xxs",bSpace:"zero"},React.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},React.createElement(ColorPickerDropdown,{portalContainer:portalContainer,...colorPickerProps,menuItems:menuItems})));export function CatalogCard({title,subtitle,dropdownMenuOptions=[],onClick,onDropdownClick,topLeftElement,portalContainer,borderRadius="s",subtitleLines=1,colorPickerProps,"data-e2e-test-id":dataE2eTestId="CatalogCard","data-ds-id":dataDsId="CatalogCard"}){let isMobile=!!window&&window.innerWidth<=breakpoints.medium.value,topRightElement=colorPickerProps?React.createElement(TopRightColorPicker,{colorPickerProps:colorPickerProps,menuItems:dropdownMenuOptions,portalContainer:portalContainer,isMobile:isMobile}):dropdownMenuOptions.length>0?React.createElement(TopRightDropdownMenu,{menuItems:dropdownMenuOptions,onMenuOpen:onDropdownClick,portalContainer:portalContainer,isMobile:isMobile}):null,SubtitleComponent="none"===subtitleLines?Text:TextClamped;return React.createElement(StyledWrapper,null,React.createElement(StyledButton,{onClick:onClick,"aria-label":title}),React.createElement(Container,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,borderRadius:borderRadius,privateProps:{border:!0}},React.createElement(StyledContainer,{isMobile:isMobile},React.createElement(Box,{space:"m"},React.createElement(Columns,null,React.createElement(Column,{size:"fill"},React.createElement("div",{onClick:onClick},React.createElement(Stack,{vAlignItems:"spaceBetween",space:"s"},topLeftElement,React.createElement(Stack,{space:"xxs",vAlignItems:"bottom"},React.createElement(StyledTitle,null,React.createElement(TextClamped,{size:"m",weight:"bold",lines:2},title)),subtitle&&React.createElement(SubtitleComponent,{size:"s",color:"tertiary",..."none"!==subtitleLines&&{lines:subtitleLines}},subtitle))))),topRightElement&&React.createElement(Column,{size:"narrow"},topRightElement))))))}
1
+ import React from"react";import styled from"@emotion/styled";import{Container}from"../Container/Container";import{DropdownMenu}from"../DropdownMenu/DropdownMenu";import{Box}from"../Box/Box";import{Column,Columns}from"../Column/Columns";import{Stack}from"../Stack/Stack";import{Text}from"../Typography/Text/Text";import{TextClamped}from"../Typography/TextClamped/TextClamped";import{ColorPickerDropdown}from"../ColorPicker/ColorPickerDropdown";import breakpoints from"../../web-tokens/_breakpoints.json";let StyledDropdownMenuContainer=styled("div",{target:"e1rfcex10",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 { type DropdownItem, DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport type { ColorPickerProps } from \"../ColorPicker/ColorPicker\";\nimport {\n  ColorPickerDropdown,\n  type ColorPickerDropdownItemProps,\n} from \"../ColorPicker/ColorPickerDropdown\";\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 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\n// Shared types for component props\ntype TopRightComponentProps = {\n  portalContainer?: PortalProps[\"portalContainer\"];\n  isMobile: boolean;\n};\n\ntype TopRightDropdownMenuProps = TopRightComponentProps & {\n  menuItems: DropdownItem[];\n  onMenuOpen?: (ev: MouseEvent | KeyboardEvent) => void;\n};\n\ntype TopRightColorPickerProps = TopRightComponentProps & {\n  colorPickerProps: ColorPickerProps;\n  menuItems: (DropdownItem | ColorPickerDropdownItemProps)[];\n};\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  // Make sure that focus indicator is only visivle when the hidden button is in focus\n  [`&:has(${StyledButton}:focus-visible)`]: {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        outlineColor: \"-webkit-focus-ring-color\",\n        outlineStyle: \"solid\",\n      },\n    },\n  },\n\n  \"&:focus-within\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      outline: \"none\",\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 StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\nconst TopRightDropdownMenu = ({\n  menuItems,\n  onMenuOpen,\n  portalContainer,\n  isMobile,\n}: TopRightDropdownMenuProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <DropdownMenu\n        iconName=\"more-horizontal\"\n        menuItems={menuItems}\n        onMenuOpen={onMenuOpen}\n        portalContainer={portalContainer}\n        size=\"xs\"\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nconst TopRightColorPicker = ({\n  colorPickerProps,\n  menuItems,\n  portalContainer,\n  isMobile,\n}: TopRightColorPickerProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <ColorPickerDropdown\n        portalContainer={portalContainer}\n        {...colorPickerProps}\n        menuItems={menuItems}\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  subtitleLines?: number | \"none\";\n  dropdownMenuOptions?: (DropdownItem | ColorPickerDropdownItemProps)[];\n  colorPickerProps?: ColorPickerProps;\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  subtitleLines = 1,\n  colorPickerProps,\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.m.value;\n\n  const renderTopRightElement = () => {\n    if (colorPickerProps) {\n      return (\n        <TopRightColorPicker\n          colorPickerProps={colorPickerProps}\n          menuItems={dropdownMenuOptions}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    if (dropdownMenuOptions.length > 0) {\n      return (\n        <TopRightDropdownMenu\n          menuItems={dropdownMenuOptions as DropdownItem[]}\n          onMenuOpen={onDropdownClick}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    return null;\n  };\n\n  const topRightElement = renderTopRightElement();\n  const SubtitleComponent = subtitleLines === \"none\" ? Text : TextClamped;\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        privateProps={{ border: true }}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size=\"fill\">\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                        <SubtitleComponent\n                          size=\"s\"\n                          color=\"tertiary\"\n                          {...(subtitleLines !== \"none\" && {\n                            lines: subtitleLines,\n                          })}\n                        >\n                          {subtitle}\n                        </SubtitleComponent>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              {topRightElement && (\n                <Column size=\"narrow\">{topRightElement}</Column>\n              )}\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAiBoC"} */"),StyledButton=styled("button",{target:"e1rfcex11",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 { type DropdownItem, DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport type { ColorPickerProps } from \"../ColorPicker/ColorPicker\";\nimport {\n  ColorPickerDropdown,\n  type ColorPickerDropdownItemProps,\n} from \"../ColorPicker/ColorPickerDropdown\";\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 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\n// Shared types for component props\ntype TopRightComponentProps = {\n  portalContainer?: PortalProps[\"portalContainer\"];\n  isMobile: boolean;\n};\n\ntype TopRightDropdownMenuProps = TopRightComponentProps & {\n  menuItems: DropdownItem[];\n  onMenuOpen?: (ev: MouseEvent | KeyboardEvent) => void;\n};\n\ntype TopRightColorPickerProps = TopRightComponentProps & {\n  colorPickerProps: ColorPickerProps;\n  menuItems: (DropdownItem | ColorPickerDropdownItemProps)[];\n};\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  // Make sure that focus indicator is only visivle when the hidden button is in focus\n  [`&:has(${StyledButton}:focus-visible)`]: {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        outlineColor: \"-webkit-focus-ring-color\",\n        outlineStyle: \"solid\",\n      },\n    },\n  },\n\n  \"&:focus-within\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      outline: \"none\",\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 StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\nconst TopRightDropdownMenu = ({\n  menuItems,\n  onMenuOpen,\n  portalContainer,\n  isMobile,\n}: TopRightDropdownMenuProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <DropdownMenu\n        iconName=\"more-horizontal\"\n        menuItems={menuItems}\n        onMenuOpen={onMenuOpen}\n        portalContainer={portalContainer}\n        size=\"xs\"\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nconst TopRightColorPicker = ({\n  colorPickerProps,\n  menuItems,\n  portalContainer,\n  isMobile,\n}: TopRightColorPickerProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <ColorPickerDropdown\n        portalContainer={portalContainer}\n        {...colorPickerProps}\n        menuItems={menuItems}\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  subtitleLines?: number | \"none\";\n  dropdownMenuOptions?: (DropdownItem | ColorPickerDropdownItemProps)[];\n  colorPickerProps?: ColorPickerProps;\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  subtitleLines = 1,\n  colorPickerProps,\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.m.value;\n\n  const renderTopRightElement = () => {\n    if (colorPickerProps) {\n      return (\n        <TopRightColorPicker\n          colorPickerProps={colorPickerProps}\n          menuItems={dropdownMenuOptions}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    if (dropdownMenuOptions.length > 0) {\n      return (\n        <TopRightDropdownMenu\n          menuItems={dropdownMenuOptions as DropdownItem[]}\n          onMenuOpen={onDropdownClick}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    return null;\n  };\n\n  const topRightElement = renderTopRightElement();\n  const SubtitleComponent = subtitleLines === \"none\" ? Text : TextClamped;\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        privateProps={{ border: true }}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size=\"fill\">\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                        <SubtitleComponent\n                          size=\"s\"\n                          color=\"tertiary\"\n                          {...(subtitleLines !== \"none\" && {\n                            lines: subtitleLines,\n                          })}\n                        >\n                          {subtitle}\n                        </SubtitleComponent>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              {topRightElement && (\n                <Column size=\"narrow\">{topRightElement}</Column>\n              )}\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AA0BqB"} */"),StyledWrapper=styled("div",{target:"e1rfcex12",label:"StyledWrapper"})(({theme})=>({position:"relative",height:"100%","> div":{height:"100%"},[`&:has(${StyledButton}:focus-visible)`]:{"> div":{outlineWidth:2,outlineStyle:"solid",outlineColor:"Highlight",outlineOffset:-1,"@media (-webkit-min-device-pixel-ratio:0)":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"solid"}}},"&:focus-within":{[`${StyledDropdownMenuContainer}`]:{visibility:"visible"}},"&:hover":{"> div":{outline:"none",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 { type DropdownItem, DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport type { ColorPickerProps } from \"../ColorPicker/ColorPicker\";\nimport {\n  ColorPickerDropdown,\n  type ColorPickerDropdownItemProps,\n} from \"../ColorPicker/ColorPickerDropdown\";\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 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\n// Shared types for component props\ntype TopRightComponentProps = {\n  portalContainer?: PortalProps[\"portalContainer\"];\n  isMobile: boolean;\n};\n\ntype TopRightDropdownMenuProps = TopRightComponentProps & {\n  menuItems: DropdownItem[];\n  onMenuOpen?: (ev: MouseEvent | KeyboardEvent) => void;\n};\n\ntype TopRightColorPickerProps = TopRightComponentProps & {\n  colorPickerProps: ColorPickerProps;\n  menuItems: (DropdownItem | ColorPickerDropdownItemProps)[];\n};\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  // Make sure that focus indicator is only visivle when the hidden button is in focus\n  [`&:has(${StyledButton}:focus-visible)`]: {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        outlineColor: \"-webkit-focus-ring-color\",\n        outlineStyle: \"solid\",\n      },\n    },\n  },\n\n  \"&:focus-within\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      outline: \"none\",\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 StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\nconst TopRightDropdownMenu = ({\n  menuItems,\n  onMenuOpen,\n  portalContainer,\n  isMobile,\n}: TopRightDropdownMenuProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <DropdownMenu\n        iconName=\"more-horizontal\"\n        menuItems={menuItems}\n        onMenuOpen={onMenuOpen}\n        portalContainer={portalContainer}\n        size=\"xs\"\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nconst TopRightColorPicker = ({\n  colorPickerProps,\n  menuItems,\n  portalContainer,\n  isMobile,\n}: TopRightColorPickerProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <ColorPickerDropdown\n        portalContainer={portalContainer}\n        {...colorPickerProps}\n        menuItems={menuItems}\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  subtitleLines?: number | \"none\";\n  dropdownMenuOptions?: (DropdownItem | ColorPickerDropdownItemProps)[];\n  colorPickerProps?: ColorPickerProps;\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  subtitleLines = 1,\n  colorPickerProps,\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.m.value;\n\n  const renderTopRightElement = () => {\n    if (colorPickerProps) {\n      return (\n        <TopRightColorPicker\n          colorPickerProps={colorPickerProps}\n          menuItems={dropdownMenuOptions}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    if (dropdownMenuOptions.length > 0) {\n      return (\n        <TopRightDropdownMenu\n          menuItems={dropdownMenuOptions as DropdownItem[]}\n          onMenuOpen={onDropdownClick}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    return null;\n  };\n\n  const topRightElement = renderTopRightElement();\n  const SubtitleComponent = subtitleLines === \"none\" ? Text : TextClamped;\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        privateProps={{ border: true }}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size=\"fill\">\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                        <SubtitleComponent\n                          size=\"s\"\n                          color=\"tertiary\"\n                          {...(subtitleLines !== \"none\" && {\n                            lines: subtitleLines,\n                          })}\n                        >\n                          {subtitle}\n                        </SubtitleComponent>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              {topRightElement && (\n                <Column size=\"narrow\">{topRightElement}</Column>\n              )}\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAoDsB"} */"),StyledContainer=styled("div",{target:"e1rfcex13",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 { type DropdownItem, DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport type { ColorPickerProps } from \"../ColorPicker/ColorPicker\";\nimport {\n  ColorPickerDropdown,\n  type ColorPickerDropdownItemProps,\n} from \"../ColorPicker/ColorPickerDropdown\";\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 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\n// Shared types for component props\ntype TopRightComponentProps = {\n  portalContainer?: PortalProps[\"portalContainer\"];\n  isMobile: boolean;\n};\n\ntype TopRightDropdownMenuProps = TopRightComponentProps & {\n  menuItems: DropdownItem[];\n  onMenuOpen?: (ev: MouseEvent | KeyboardEvent) => void;\n};\n\ntype TopRightColorPickerProps = TopRightComponentProps & {\n  colorPickerProps: ColorPickerProps;\n  menuItems: (DropdownItem | ColorPickerDropdownItemProps)[];\n};\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  // Make sure that focus indicator is only visivle when the hidden button is in focus\n  [`&:has(${StyledButton}:focus-visible)`]: {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        outlineColor: \"-webkit-focus-ring-color\",\n        outlineStyle: \"solid\",\n      },\n    },\n  },\n\n  \"&:focus-within\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      outline: \"none\",\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 StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\nconst TopRightDropdownMenu = ({\n  menuItems,\n  onMenuOpen,\n  portalContainer,\n  isMobile,\n}: TopRightDropdownMenuProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <DropdownMenu\n        iconName=\"more-horizontal\"\n        menuItems={menuItems}\n        onMenuOpen={onMenuOpen}\n        portalContainer={portalContainer}\n        size=\"xs\"\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nconst TopRightColorPicker = ({\n  colorPickerProps,\n  menuItems,\n  portalContainer,\n  isMobile,\n}: TopRightColorPickerProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <ColorPickerDropdown\n        portalContainer={portalContainer}\n        {...colorPickerProps}\n        menuItems={menuItems}\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  subtitleLines?: number | \"none\";\n  dropdownMenuOptions?: (DropdownItem | ColorPickerDropdownItemProps)[];\n  colorPickerProps?: ColorPickerProps;\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  subtitleLines = 1,\n  colorPickerProps,\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.m.value;\n\n  const renderTopRightElement = () => {\n    if (colorPickerProps) {\n      return (\n        <TopRightColorPicker\n          colorPickerProps={colorPickerProps}\n          menuItems={dropdownMenuOptions}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    if (dropdownMenuOptions.length > 0) {\n      return (\n        <TopRightDropdownMenu\n          menuItems={dropdownMenuOptions as DropdownItem[]}\n          onMenuOpen={onDropdownClick}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    return null;\n  };\n\n  const topRightElement = renderTopRightElement();\n  const SubtitleComponent = subtitleLines === \"none\" ? Text : TextClamped;\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        privateProps={{ border: true }}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size=\"fill\">\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                        <SubtitleComponent\n                          size=\"s\"\n                          color=\"tertiary\"\n                          {...(subtitleLines !== \"none\" && {\n                            lines: subtitleLines,\n                          })}\n                        >\n                          {subtitle}\n                        </SubtitleComponent>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              {topRightElement && (\n                <Column size=\"narrow\">{topRightElement}</Column>\n              )}\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AA0FwB"} */"),StyledTitle=styled("div",{target:"e1rfcex14",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 { type DropdownItem, DropdownMenu } from \"../DropdownMenu/DropdownMenu\";\nimport type { PortalProps } from \"../Portal/Portal\";\nimport { Box } from \"../Box/Box\";\nimport { Column, Columns } from \"../Column/Columns\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport type { ColorPickerProps } from \"../ColorPicker/ColorPicker\";\nimport {\n  ColorPickerDropdown,\n  type ColorPickerDropdownItemProps,\n} from \"../ColorPicker/ColorPickerDropdown\";\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 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\n// Shared types for component props\ntype TopRightComponentProps = {\n  portalContainer?: PortalProps[\"portalContainer\"];\n  isMobile: boolean;\n};\n\ntype TopRightDropdownMenuProps = TopRightComponentProps & {\n  menuItems: DropdownItem[];\n  onMenuOpen?: (ev: MouseEvent | KeyboardEvent) => void;\n};\n\ntype TopRightColorPickerProps = TopRightComponentProps & {\n  colorPickerProps: ColorPickerProps;\n  menuItems: (DropdownItem | ColorPickerDropdownItemProps)[];\n};\n\nconst StyledWrapper = styled.div(({ theme }) => ({\n  position: \"relative\",\n  height: \"100%\",\n\n  // <Container/>\n  \"> div\": {\n    height: \"100%\",\n  },\n\n  // Make sure that focus indicator is only visivle when the hidden button is in focus\n  [`&:has(${StyledButton}:focus-visible)`]: {\n    \"> div\": {\n      outlineWidth: 2,\n      outlineStyle: \"solid\",\n      outlineColor: \"Highlight\",\n      outlineOffset: -1,\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        outlineColor: \"-webkit-focus-ring-color\",\n        outlineStyle: \"solid\",\n      },\n    },\n  },\n\n  \"&:focus-within\": {\n    [`${StyledDropdownMenuContainer}`]: {\n      visibility: \"visible\",\n    },\n  },\n\n  \"&:hover\": {\n    \"> div\": {\n      outline: \"none\",\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 StyledTitle = styled.div(({ theme }) => ({\n  display: \"flex\",\n  flexDirection: \"column\",\n  height: theme.variables.size.spacing.xxl,\n  justifyContent: \"flex-end\",\n}));\n\nconst TopRightDropdownMenu = ({\n  menuItems,\n  onMenuOpen,\n  portalContainer,\n  isMobile,\n}: TopRightDropdownMenuProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <DropdownMenu\n        iconName=\"more-horizontal\"\n        menuItems={menuItems}\n        onMenuOpen={onMenuOpen}\n        portalContainer={portalContainer}\n        size=\"xs\"\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nconst TopRightColorPicker = ({\n  colorPickerProps,\n  menuItems,\n  portalContainer,\n  isMobile,\n}: TopRightColorPickerProps) => (\n  <Box space=\"xxs\" bSpace=\"zero\">\n    <StyledDropdownMenuContainer isMobile={isMobile}>\n      <ColorPickerDropdown\n        portalContainer={portalContainer}\n        {...colorPickerProps}\n        menuItems={menuItems}\n      />\n    </StyledDropdownMenuContainer>\n  </Box>\n);\n\nexport type CatalogCardProps = Omit<\n  ContainerProps,\n  \"id\" | \"elevation\" | \"overflow\" | \"squareCorners\" | \"children\"\n> & {\n  title: string;\n  subtitle?: string;\n  subtitleLines?: number | \"none\";\n  dropdownMenuOptions?: (DropdownItem | ColorPickerDropdownItemProps)[];\n  colorPickerProps?: ColorPickerProps;\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  subtitleLines = 1,\n  colorPickerProps,\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n}: CatalogCardProps): React.ReactElement {\n  const isMobile = !!window && window.innerWidth <= breakpoints.m.value;\n\n  const renderTopRightElement = () => {\n    if (colorPickerProps) {\n      return (\n        <TopRightColorPicker\n          colorPickerProps={colorPickerProps}\n          menuItems={dropdownMenuOptions}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    if (dropdownMenuOptions.length > 0) {\n      return (\n        <TopRightDropdownMenu\n          menuItems={dropdownMenuOptions as DropdownItem[]}\n          onMenuOpen={onDropdownClick}\n          portalContainer={portalContainer}\n          isMobile={isMobile}\n        />\n      );\n    }\n\n    return null;\n  };\n\n  const topRightElement = renderTopRightElement();\n  const SubtitleComponent = subtitleLines === \"none\" ? Text : TextClamped;\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        privateProps={{ border: true }}\n      >\n        <StyledContainer isMobile={isMobile}>\n          <Box space=\"m\">\n            <Columns>\n              <Column size=\"fill\">\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                        <SubtitleComponent\n                          size=\"s\"\n                          color=\"tertiary\"\n                          {...(subtitleLines !== \"none\" && {\n                            lines: subtitleLines,\n                          })}\n                        >\n                          {subtitle}\n                        </SubtitleComponent>\n                      )}\n                    </Stack>\n                  </Stack>\n                </div>\n              </Column>\n              {topRightElement && (\n                <Column size=\"narrow\">{topRightElement}</Column>\n              )}\n            </Columns>\n          </Box>\n        </StyledContainer>\n      </Container>\n    </StyledWrapper>\n  );\n}\n"],"names":[],"mappings":"AAiHoB"} */"),TopRightDropdownMenu=({menuItems,onMenuOpen,portalContainer,isMobile})=>React.createElement(Box,{space:"xxs",bSpace:"zero"},React.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},React.createElement(DropdownMenu,{iconName:"more-horizontal",menuItems:menuItems,onMenuOpen:onMenuOpen,portalContainer:portalContainer,size:"xs"}))),TopRightColorPicker=({colorPickerProps,menuItems,portalContainer,isMobile})=>React.createElement(Box,{space:"xxs",bSpace:"zero"},React.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},React.createElement(ColorPickerDropdown,{portalContainer:portalContainer,...colorPickerProps,menuItems:menuItems})));export function CatalogCard({title,subtitle,dropdownMenuOptions=[],onClick,onDropdownClick,topLeftElement,portalContainer,borderRadius="s",subtitleLines=1,colorPickerProps,"data-e2e-test-id":dataE2eTestId="CatalogCard","data-ds-id":dataDsId="CatalogCard"}){let isMobile=!!window&&window.innerWidth<=breakpoints.m.value,topRightElement=colorPickerProps?React.createElement(TopRightColorPicker,{colorPickerProps:colorPickerProps,menuItems:dropdownMenuOptions,portalContainer:portalContainer,isMobile:isMobile}):dropdownMenuOptions.length>0?React.createElement(TopRightDropdownMenu,{menuItems:dropdownMenuOptions,onMenuOpen:onDropdownClick,portalContainer:portalContainer,isMobile:isMobile}):null,SubtitleComponent="none"===subtitleLines?Text:TextClamped;return React.createElement(StyledWrapper,null,React.createElement(StyledButton,{onClick:onClick,"aria-label":title}),React.createElement(Container,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,borderRadius:borderRadius,privateProps:{border:!0}},React.createElement(StyledContainer,{isMobile:isMobile},React.createElement(Box,{space:"m"},React.createElement(Columns,null,React.createElement(Column,{size:"fill"},React.createElement("div",{onClick:onClick},React.createElement(Stack,{vAlignItems:"spaceBetween",space:"s"},topLeftElement,React.createElement(Stack,{space:"xxs",vAlignItems:"bottom"},React.createElement(StyledTitle,null,React.createElement(TextClamped,{size:"m",weight:"bold",lines:2},title)),subtitle&&React.createElement(SubtitleComponent,{size:"s",color:"tertiary",..."none"!==subtitleLines&&{lines:subtitleLines}},subtitle))))),topRightElement&&React.createElement(Column,{size:"narrow"},topRightElement))))))}
@@ -13,9 +13,7 @@ export type DropdownMenuProps = {
13
13
  menuItems: DropdownItem[];
14
14
  /** the text variant of menu items */
15
15
  menuItemTextVariant?: "uppercase" | "capitalize" | "lowercase" | "none";
16
- label?: string;
17
16
  iconName?: IconName;
18
- size?: ButtonSize;
19
17
  disabled?: boolean;
20
18
  triggerAriaLabel?: string;
21
19
  /** Dropdown menu open state callback */
@@ -24,6 +22,13 @@ export type DropdownMenuProps = {
24
22
  onMenuClose?: (e: MouseEvent | KeyboardEvent) => void;
25
23
  privateProps?: DropdownPrivateProps;
26
24
  "data-e2e-test-id"?: string;
27
- } & Pick<PortalProps, "portalContainer">;
25
+ } & Pick<PortalProps, "portalContainer"> & ConditionalProps;
26
+ type ConditionalProps = {
27
+ size?: "xs";
28
+ label?: never;
29
+ } | {
30
+ size?: ButtonSize;
31
+ label?: string;
32
+ };
28
33
  export declare function DropdownMenu({ menuItems, menuItemTextVariant, label, iconName, size, disabled, portalContainer, triggerAriaLabel, onMenuOpen, onMenuClose, privateProps: { dropdownSquareCorners }, "data-e2e-test-id": dataE2eTestId, }: DropdownMenuProps): React.ReactElement;
29
34
  export {};
@@ -1 +1 @@
1
- import React,{useState,useCallback,useRef}from"react";import{useKeyboard}from"../../shared/useKeyboard";import{Button}from"../Button/Button";import{Menu}from"./Menu";let isSeperator=item=>"separator"===item;export function DropdownMenu({menuItems,menuItemTextVariant="uppercase",label,iconName="more-horizontal",size="m",disabled=!1,portalContainer,triggerAriaLabel,onMenuOpen=()=>void 0,onMenuClose=()=>void 0,privateProps:{dropdownSquareCorners}={dropdownSquareCorners:!1},"data-e2e-test-id":dataE2eTestId}){let[isOpen,setIsOpen]=useState(!1),buttonRef=useRef(null),openMenu=useCallback(e=>{setIsOpen(!0),onMenuOpen(e)},[setIsOpen,onMenuOpen]),closeMenu=useCallback(e=>{setIsOpen(!1),buttonRef.current.focus({preventScroll:!0}),onMenuClose(e)},[setIsOpen,onMenuClose]),toggleMenu=useCallback(e=>{isOpen?closeMenu(e.nativeEvent):openMenu(e.nativeEvent)},[isOpen,openMenu,closeMenu]),items=menuItems.map(item=>isSeperator(item)?item:{...item,onSelect:e=>{item.onSelect(e),closeMenu(e.nativeEvent)}});return useKeyboard({"ArrowUp ArrowDown":openMenu},buttonRef,!isOpen),React.createElement(React.Fragment,null,React.createElement(Button,{tabIndex:0,ref:buttonRef,size:size,rightIcon:iconName,variant:"tertiary",onClick:toggleMenu,disabled:disabled,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"DropdownMenu",privateProps:{squareCorners:dropdownSquareCorners},"aria-label":triggerAriaLabel},label),React.createElement(Menu,{items:items,isOpen:isOpen,onCloseMenu:closeMenu,triggerRef:buttonRef,menuItemTextVariant:menuItemTextVariant,portalContainer:portalContainer}))}
1
+ import React,{useState,useCallback,useRef}from"react";import{useKeyboard}from"../../shared/useKeyboard";import{Button}from"../Button/Button";import{Menu}from"./Menu";import{PictogramButton}from"../PictogramButton/PictogramButton";let isSeperator=item=>"separator"===item;export function DropdownMenu({menuItems,menuItemTextVariant="uppercase",label,iconName="more-horizontal",size="m",disabled=!1,portalContainer,triggerAriaLabel,onMenuOpen=()=>void 0,onMenuClose=()=>void 0,privateProps:{dropdownSquareCorners}={dropdownSquareCorners:!1},"data-e2e-test-id":dataE2eTestId}){let[isOpen,setIsOpen]=useState(!1),buttonRef=useRef(null),openMenu=useCallback(e=>{setIsOpen(!0),onMenuOpen(e)},[setIsOpen,onMenuOpen]),closeMenu=useCallback(e=>{setIsOpen(!1),buttonRef.current.focus({preventScroll:!0}),onMenuClose(e)},[setIsOpen,onMenuClose]),toggleMenu=useCallback(e=>{isOpen?closeMenu(e.nativeEvent):openMenu(e.nativeEvent)},[isOpen,openMenu,closeMenu]),items=menuItems.map(item=>isSeperator(item)?item:{...item,onSelect:e=>{item.onSelect(e),closeMenu(e.nativeEvent)}});return useKeyboard({"ArrowUp ArrowDown":openMenu},buttonRef,!isOpen),React.createElement(React.Fragment,null,"xs"===size?React.createElement(PictogramButton,{tabIndex:0,ref:buttonRef,size:size,icon:iconName,variant:"tertiary",onClick:toggleMenu,disabled:disabled,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"DropdownMenu","aria-label":triggerAriaLabel}):React.createElement(Button,{tabIndex:0,ref:buttonRef,size:size,rightIcon:iconName,variant:"tertiary",onClick:toggleMenu,disabled:disabled,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"DropdownMenu",privateProps:{squareCorners:dropdownSquareCorners},"aria-label":triggerAriaLabel},label),React.createElement(Menu,{items:items,isOpen:isOpen,onCloseMenu:closeMenu,triggerRef:buttonRef,menuItemTextVariant:menuItemTextVariant,portalContainer:portalContainer}))}
@@ -1 +1 @@
1
- import React,{Fragment}from"react";import styled from"@emotion/styled";import{FormFieldGroup}from"../FormFieldGroup/FormFieldGroup";import{SegmentedControlOption}from"./SegmentedControlOption";import breakpoints from"../../../web-tokens/_breakpoints.json";let StyledDivider=styled("div",{target:"ejbr9ni0",label:"StyledDivider"})(({theme,isChecked,isDisabled,isPrevOptionChecked,isPrevOptionDisabled,justified})=>{let border=`1px solid ${theme.values.color.border.secondary.default}`,otherStyles={backgroundColor:theme.values.color.background.primary.default,...(isChecked||isPrevOptionChecked)&&{borderColor:theme.values.color.border.accent.default},...isDisabled&&isPrevOptionDisabled&&{opacity:theme.variables.opacity.disabled}},borderRightStyle={borderRight:border,...otherStyles};return justified?{[`@media (min-width: ${breakpoints.medium.value}px)`]:{...borderRightStyle},[`@media (max-width: ${breakpoints.medium.value}px)`]:{borderBottom:border,...otherStyles}}:borderRightStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkR3JvdXAgfSBmcm9tIFwiLi4vRm9ybUZpZWxkR3JvdXAvRm9ybUZpZWxkR3JvdXBcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uRGlzYWJsZWQ6IGJvb2xlYW47XG59ICYgUGljazxTZWdtZW50ZWRDb250cm9sUHJvcHMsIFwianVzdGlmaWVkXCI+O1xuXG5jb25zdCBTdHlsZWREaXZpZGVyID0gc3R5bGVkLmRpdjxTdHlsZWREaXZpZGVyUHJvcHM+KFxuICAoe1xuICAgIHRoZW1lLFxuICAgIGlzQ2hlY2tlZCxcbiAgICBpc0Rpc2FibGVkLFxuICAgIGlzUHJldk9wdGlvbkNoZWNrZWQsXG4gICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQsXG4gICAganVzdGlmaWVkLFxuICB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBvdGhlclN0eWxlcyA9IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICAgICAgLi4uKChpc0NoZWNrZWQgfHwgaXNQcmV2T3B0aW9uQ2hlY2tlZCkgJiYge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5hY2NlbnQuZGVmYXVsdCxcbiAgICAgIH0pLFxuICAgICAgLi4uKGlzRGlzYWJsZWQgJiZcbiAgICAgICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQgJiYge1xuICAgICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmRpc2FibGVkLFxuICAgICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgYm9yZGVyUmlnaHRTdHlsZSA9IHtcbiAgICAgIGJvcmRlclJpZ2h0OiBib3JkZXIsXG4gICAgICAuLi5vdGhlclN0eWxlcyxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICAuLi5ib3JkZXJSaWdodFN0eWxlLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIG1vYmlsZVxuICAgICAgW2BAbWVkaWEgKG1heC13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgYm9yZGVyQm90dG9tOiBib3JkZXIsXG4gICAgICAgIC4uLm90aGVyU3R5bGVzLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG50eXBlIFN0eWxlZENvbnRhaW5lclByb3BzID0gUGljazxcbiAgU2VnbWVudGVkQ29udHJvbFByb3BzLFxuICBcImp1c3RpZmllZFwiIHwgXCJvcHRpb25zXCJcbj47XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkQ29udGFpbmVyUHJvcHM+KFxuICAoeyBqdXN0aWZpZWQsIG9wdGlvbnMgfSkgPT4ge1xuICAgIGNvbnN0IGJhc2VTdHlsZSA9IHtcbiAgICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIH07XG5cbiAgICBpZiAoIWp1c3RpZmllZCkge1xuICAgICAgcmV0dXJuIGJhc2VTdHlsZTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uYmFzZVN0eWxlLFxuICAgICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcblxuICAgICAgXCImID4gKlwiOiB7XG4gICAgICAgIGZsZXg6IGAxIDEgJHsxMDAgLyBvcHRpb25zLmxlbmd0aH0lYCxcbiAgICAgIH0sXG5cbiAgICAgIFtgJiA+ICR7U3R5bGVkRGl2aWRlcn1gXToge1xuICAgICAgICBmbGV4OiBcIjAgMCBhdXRvXCIsXG4gICAgICB9LFxuXG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VnbWVudGVkQ29udHJvbCh7XG4gIG9wdGlvbnMsXG4gIHZhbHVlLFxuICBqdXN0aWZpZWQsXG4gIHNpemUgPSBcIm1cIixcbiAgb25DaGFuZ2UsXG4gIGlzTGFiZWxIaWRkZW4gPSB0cnVlLFxuICAuLi5yZXN0XG59OiBTZWdtZW50ZWRDb250cm9sUHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBoYW5kbGVDaGFuZ2U6IEZvcm1FdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD4gPSAoZXZ0KSA9PiB7XG4gICAgb25DaGFuZ2UoKGV2dC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkudmFsdWUpO1xuICB9O1xuXG4gIGNvbnN0IG9wdGlvbkVsbXMgPSBvcHRpb25zLm1hcChcbiAgICAoeyB2YWx1ZTogb3B0aW9uVmFsdWUsIGRpc2FibGVkLCAuLi5vdGhlclByb3BzIH0sIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBpc0NoZWNrZWQgPSB2YWx1ZSA9PT0gb3B0aW9uVmFsdWU7XG4gICAgICBjb25zdCBkaXZpZGVyRWxtID1cbiAgICAgICAgaW5kZXggIT09IDAgPyAoXG4gICAgICAgICAgPFN0eWxlZERpdmlkZXJcbiAgICAgICAgICAgIGlzUHJldk9wdGlvbkNoZWNrZWQ9e29wdGlvbnNbaW5kZXggLSAxXS52YWx1ZSA9PT0gdmFsdWV9XG4gICAgICAgICAgICBpc1ByZXZPcHRpb25EaXNhYmxlZD17b3B0aW9uc1tpbmRleCAtIDFdLmRpc2FibGVkfVxuICAgICAgICAgICAgaXNDaGVja2VkPXtpc0NoZWNrZWR9XG4gICAgICAgICAgICBpc0Rpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIGp1c3RpZmllZD17anVzdGlmaWVkfVxuICAgICAgICAgIC8+XG4gICAgICAgICkgOiBudWxsO1xuXG4gICAgICByZXR1cm4gKFxuICAgICAgICA8RnJhZ21lbnQga2V5PXtvcHRpb25WYWx1ZX0+XG4gICAgICAgICAge2RpdmlkZXJFbG19XG4gICAgICAgICAgPFNlZ21lbnRlZENvbnRyb2xPcHRpb25cbiAgICAgICAgICAgIHZhbHVlPXtvcHRpb25WYWx1ZX1cbiAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICBjaGVja2VkPXtpc0NoZWNrZWR9XG4gICAgICAgICAgICBpc1Jlc3BvbnNpdmU9e2p1c3RpZmllZH1cbiAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIG9uQ2hhbmdlPXtoYW5kbGVDaGFuZ2V9XG4gICAgICAgICAgICB7Li4ub3RoZXJQcm9wc31cbiAgICAgICAgICAvPlxuICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgKTtcbiAgICB9XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybUZpZWxkR3JvdXBcbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRDb250cm9sXCJcbiAgICAgIGlzTGFiZWxIaWRkZW49e2lzTGFiZWxIaWRkZW59XG4gICAgICB7Li4ucmVzdH1cbiAgICA+XG4gICAgICA8U3R5bGVkQ29udGFpbmVyIGp1c3RpZmllZD17anVzdGlmaWVkfSBvcHRpb25zPXtvcHRpb25zfT5cbiAgICAgICAge29wdGlvbkVsbXN9XG4gICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZEdyb3VwPlxuICApO1xufVxuXG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQnNCIn0= */"),StyledContainer=styled("div",{target:"ejbr9ni1",label:"StyledContainer"})(({justified,options})=>{let baseStyle={display:"flex"};return justified?{...baseStyle,flexDirection:"column","& > *":{flex:`1 1 ${100/options.length}%`},[`& > ${StyledDivider}`]:{flex:"0 0 auto"},[`@media (min-width: ${breakpoints.medium.value}px)`]:{flexDirection:"row"}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkR3JvdXAgfSBmcm9tIFwiLi4vRm9ybUZpZWxkR3JvdXAvRm9ybUZpZWxkR3JvdXBcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uRGlzYWJsZWQ6IGJvb2xlYW47XG59ICYgUGljazxTZWdtZW50ZWRDb250cm9sUHJvcHMsIFwianVzdGlmaWVkXCI+O1xuXG5jb25zdCBTdHlsZWREaXZpZGVyID0gc3R5bGVkLmRpdjxTdHlsZWREaXZpZGVyUHJvcHM+KFxuICAoe1xuICAgIHRoZW1lLFxuICAgIGlzQ2hlY2tlZCxcbiAgICBpc0Rpc2FibGVkLFxuICAgIGlzUHJldk9wdGlvbkNoZWNrZWQsXG4gICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQsXG4gICAganVzdGlmaWVkLFxuICB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBvdGhlclN0eWxlcyA9IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICAgICAgLi4uKChpc0NoZWNrZWQgfHwgaXNQcmV2T3B0aW9uQ2hlY2tlZCkgJiYge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5hY2NlbnQuZGVmYXVsdCxcbiAgICAgIH0pLFxuICAgICAgLi4uKGlzRGlzYWJsZWQgJiZcbiAgICAgICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQgJiYge1xuICAgICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmRpc2FibGVkLFxuICAgICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgYm9yZGVyUmlnaHRTdHlsZSA9IHtcbiAgICAgIGJvcmRlclJpZ2h0OiBib3JkZXIsXG4gICAgICAuLi5vdGhlclN0eWxlcyxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICAuLi5ib3JkZXJSaWdodFN0eWxlLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIG1vYmlsZVxuICAgICAgW2BAbWVkaWEgKG1heC13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgYm9yZGVyQm90dG9tOiBib3JkZXIsXG4gICAgICAgIC4uLm90aGVyU3R5bGVzLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG50eXBlIFN0eWxlZENvbnRhaW5lclByb3BzID0gUGljazxcbiAgU2VnbWVudGVkQ29udHJvbFByb3BzLFxuICBcImp1c3RpZmllZFwiIHwgXCJvcHRpb25zXCJcbj47XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkQ29udGFpbmVyUHJvcHM+KFxuICAoeyBqdXN0aWZpZWQsIG9wdGlvbnMgfSkgPT4ge1xuICAgIGNvbnN0IGJhc2VTdHlsZSA9IHtcbiAgICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIH07XG5cbiAgICBpZiAoIWp1c3RpZmllZCkge1xuICAgICAgcmV0dXJuIGJhc2VTdHlsZTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uYmFzZVN0eWxlLFxuICAgICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcblxuICAgICAgXCImID4gKlwiOiB7XG4gICAgICAgIGZsZXg6IGAxIDEgJHsxMDAgLyBvcHRpb25zLmxlbmd0aH0lYCxcbiAgICAgIH0sXG5cbiAgICAgIFtgJiA+ICR7U3R5bGVkRGl2aWRlcn1gXToge1xuICAgICAgICBmbGV4OiBcIjAgMCBhdXRvXCIsXG4gICAgICB9LFxuXG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VnbWVudGVkQ29udHJvbCh7XG4gIG9wdGlvbnMsXG4gIHZhbHVlLFxuICBqdXN0aWZpZWQsXG4gIHNpemUgPSBcIm1cIixcbiAgb25DaGFuZ2UsXG4gIGlzTGFiZWxIaWRkZW4gPSB0cnVlLFxuICAuLi5yZXN0XG59OiBTZWdtZW50ZWRDb250cm9sUHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBoYW5kbGVDaGFuZ2U6IEZvcm1FdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD4gPSAoZXZ0KSA9PiB7XG4gICAgb25DaGFuZ2UoKGV2dC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkudmFsdWUpO1xuICB9O1xuXG4gIGNvbnN0IG9wdGlvbkVsbXMgPSBvcHRpb25zLm1hcChcbiAgICAoeyB2YWx1ZTogb3B0aW9uVmFsdWUsIGRpc2FibGVkLCAuLi5vdGhlclByb3BzIH0sIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBpc0NoZWNrZWQgPSB2YWx1ZSA9PT0gb3B0aW9uVmFsdWU7XG4gICAgICBjb25zdCBkaXZpZGVyRWxtID1cbiAgICAgICAgaW5kZXggIT09IDAgPyAoXG4gICAgICAgICAgPFN0eWxlZERpdmlkZXJcbiAgICAgICAgICAgIGlzUHJldk9wdGlvbkNoZWNrZWQ9e29wdGlvbnNbaW5kZXggLSAxXS52YWx1ZSA9PT0gdmFsdWV9XG4gICAgICAgICAgICBpc1ByZXZPcHRpb25EaXNhYmxlZD17b3B0aW9uc1tpbmRleCAtIDFdLmRpc2FibGVkfVxuICAgICAgICAgICAgaXNDaGVja2VkPXtpc0NoZWNrZWR9XG4gICAgICAgICAgICBpc0Rpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIGp1c3RpZmllZD17anVzdGlmaWVkfVxuICAgICAgICAgIC8+XG4gICAgICAgICkgOiBudWxsO1xuXG4gICAgICByZXR1cm4gKFxuICAgICAgICA8RnJhZ21lbnQga2V5PXtvcHRpb25WYWx1ZX0+XG4gICAgICAgICAge2RpdmlkZXJFbG19XG4gICAgICAgICAgPFNlZ21lbnRlZENvbnRyb2xPcHRpb25cbiAgICAgICAgICAgIHZhbHVlPXtvcHRpb25WYWx1ZX1cbiAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICBjaGVja2VkPXtpc0NoZWNrZWR9XG4gICAgICAgICAgICBpc1Jlc3BvbnNpdmU9e2p1c3RpZmllZH1cbiAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIG9uQ2hhbmdlPXtoYW5kbGVDaGFuZ2V9XG4gICAgICAgICAgICB7Li4ub3RoZXJQcm9wc31cbiAgICAgICAgICAvPlxuICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgKTtcbiAgICB9XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybUZpZWxkR3JvdXBcbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRDb250cm9sXCJcbiAgICAgIGlzTGFiZWxIaWRkZW49e2lzTGFiZWxIaWRkZW59XG4gICAgICB7Li4ucmVzdH1cbiAgICA+XG4gICAgICA8U3R5bGVkQ29udGFpbmVyIGp1c3RpZmllZD17anVzdGlmaWVkfSBvcHRpb25zPXtvcHRpb25zfT5cbiAgICAgICAge29wdGlvbkVsbXN9XG4gICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZEdyb3VwPlxuICApO1xufVxuXG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrRXdCIn0= */");export function SegmentedControl({options,value,justified,size="m",onChange,isLabelHidden=!0,...rest}){let handleChange=evt=>{onChange(evt.target.value)},optionElms=options.map(({value:optionValue,disabled,...otherProps},index)=>{let isChecked=value===optionValue,dividerElm=0!==index?React.createElement(StyledDivider,{isPrevOptionChecked:options[index-1].value===value,isPrevOptionDisabled:options[index-1].disabled,isChecked:isChecked,isDisabled:disabled,justified:justified}):null;return React.createElement(Fragment,{key:optionValue},dividerElm,React.createElement(SegmentedControlOption,{value:optionValue,size:size,checked:isChecked,isResponsive:justified,disabled:disabled,onChange:handleChange,...otherProps}))});return React.createElement(FormFieldGroup,{"data-ds-id":"SegmentedControl",isLabelHidden:isLabelHidden,...rest},React.createElement(StyledContainer,{justified:justified,options:options},optionElms))}
1
+ import React,{Fragment}from"react";import styled from"@emotion/styled";import{FormFieldGroup}from"../FormFieldGroup/FormFieldGroup";import{SegmentedControlOption}from"./SegmentedControlOption";import breakpoints from"../../../web-tokens/_breakpoints.json";let StyledDivider=styled("div",{target:"ed0qz3a0",label:"StyledDivider"})(({theme,isChecked,isDisabled,isPrevOptionChecked,isPrevOptionDisabled,justified})=>{let border=`1px solid ${theme.values.color.border.secondary.default}`,otherStyles={backgroundColor:theme.values.color.background.primary.default,...(isChecked||isPrevOptionChecked)&&{borderColor:theme.values.color.border.accent.default},...isDisabled&&isPrevOptionDisabled&&{opacity:theme.variables.opacity.disabled}},borderRightStyle={borderRight:border,...otherStyles};return justified?{[`@media (min-width: ${breakpoints.m.value}px)`]:{...borderRightStyle},[`@media (max-width: ${breakpoints.m.value}px)`]:{borderBottom:border,...otherStyles}}:borderRightStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkR3JvdXAgfSBmcm9tIFwiLi4vRm9ybUZpZWxkR3JvdXAvRm9ybUZpZWxkR3JvdXBcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uRGlzYWJsZWQ6IGJvb2xlYW47XG59ICYgUGljazxTZWdtZW50ZWRDb250cm9sUHJvcHMsIFwianVzdGlmaWVkXCI+O1xuXG5jb25zdCBTdHlsZWREaXZpZGVyID0gc3R5bGVkLmRpdjxTdHlsZWREaXZpZGVyUHJvcHM+KFxuICAoe1xuICAgIHRoZW1lLFxuICAgIGlzQ2hlY2tlZCxcbiAgICBpc0Rpc2FibGVkLFxuICAgIGlzUHJldk9wdGlvbkNoZWNrZWQsXG4gICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQsXG4gICAganVzdGlmaWVkLFxuICB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBvdGhlclN0eWxlcyA9IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICAgICAgLi4uKChpc0NoZWNrZWQgfHwgaXNQcmV2T3B0aW9uQ2hlY2tlZCkgJiYge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5hY2NlbnQuZGVmYXVsdCxcbiAgICAgIH0pLFxuICAgICAgLi4uKGlzRGlzYWJsZWQgJiZcbiAgICAgICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQgJiYge1xuICAgICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmRpc2FibGVkLFxuICAgICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgYm9yZGVyUmlnaHRTdHlsZSA9IHtcbiAgICAgIGJvcmRlclJpZ2h0OiBib3JkZXIsXG4gICAgICAuLi5vdGhlclN0eWxlcyxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgLi4uYm9yZGVyUmlnaHRTdHlsZSxcbiAgICAgIH0sXG5cbiAgICAgIC8vIExheW91dCBvbiBtb2JpbGVcbiAgICAgIFtgQG1lZGlhIChtYXgtd2lkdGg6ICR7YnJlYWtwb2ludHMubS52YWx1ZX1weClgXToge1xuICAgICAgICBib3JkZXJCb3R0b206IGJvcmRlcixcbiAgICAgICAgLi4ub3RoZXJTdHlsZXMsXG4gICAgICB9LFxuICAgIH07XG4gIH1cbik7XG5cbnR5cGUgU3R5bGVkQ29udGFpbmVyUHJvcHMgPSBQaWNrPFxuICBTZWdtZW50ZWRDb250cm9sUHJvcHMsXG4gIFwianVzdGlmaWVkXCIgfCBcIm9wdGlvbnNcIlxuPjtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdjxTdHlsZWRDb250YWluZXJQcm9wcz4oXG4gICh7IGp1c3RpZmllZCwgb3B0aW9ucyB9KSA9PiB7XG4gICAgY29uc3QgYmFzZVN0eWxlID0ge1xuICAgICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgfTtcblxuICAgIGlmICghanVzdGlmaWVkKSB7XG4gICAgICByZXR1cm4gYmFzZVN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAuLi5iYXNlU3R5bGUsXG4gICAgICBmbGV4RGlyZWN0aW9uOiBcImNvbHVtblwiLFxuXG4gICAgICBcIiYgPiAqXCI6IHtcbiAgICAgICAgZmxleDogYDEgMSAkezEwMCAvIG9wdGlvbnMubGVuZ3RofSVgLFxuICAgICAgfSxcblxuICAgICAgW2AmID4gJHtTdHlsZWREaXZpZGVyfWBdOiB7XG4gICAgICAgIGZsZXg6IFwiMCAwIGF1dG9cIixcbiAgICAgIH0sXG5cbiAgICAgIC8vIExheW91dCBvbiB0YWJsZXQgYW5kIGRlc2t0b3BcbiAgICAgIFtgQG1lZGlhIChtaW4td2lkdGg6ICR7YnJlYWtwb2ludHMubS52YWx1ZX1weClgXToge1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VnbWVudGVkQ29udHJvbCh7XG4gIG9wdGlvbnMsXG4gIHZhbHVlLFxuICBqdXN0aWZpZWQsXG4gIHNpemUgPSBcIm1cIixcbiAgb25DaGFuZ2UsXG4gIGlzTGFiZWxIaWRkZW4gPSB0cnVlLFxuICAuLi5yZXN0XG59OiBTZWdtZW50ZWRDb250cm9sUHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBoYW5kbGVDaGFuZ2U6IEZvcm1FdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD4gPSAoZXZ0KSA9PiB7XG4gICAgb25DaGFuZ2UoKGV2dC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkudmFsdWUpO1xuICB9O1xuXG4gIGNvbnN0IG9wdGlvbkVsbXMgPSBvcHRpb25zLm1hcChcbiAgICAoeyB2YWx1ZTogb3B0aW9uVmFsdWUsIGRpc2FibGVkLCAuLi5vdGhlclByb3BzIH0sIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBpc0NoZWNrZWQgPSB2YWx1ZSA9PT0gb3B0aW9uVmFsdWU7XG4gICAgICBjb25zdCBkaXZpZGVyRWxtID1cbiAgICAgICAgaW5kZXggIT09IDAgPyAoXG4gICAgICAgICAgPFN0eWxlZERpdmlkZXJcbiAgICAgICAgICAgIGlzUHJldk9wdGlvbkNoZWNrZWQ9e29wdGlvbnNbaW5kZXggLSAxXS52YWx1ZSA9PT0gdmFsdWV9XG4gICAgICAgICAgICBpc1ByZXZPcHRpb25EaXNhYmxlZD17b3B0aW9uc1tpbmRleCAtIDFdLmRpc2FibGVkfVxuICAgICAgICAgICAgaXNDaGVja2VkPXtpc0NoZWNrZWR9XG4gICAgICAgICAgICBpc0Rpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIGp1c3RpZmllZD17anVzdGlmaWVkfVxuICAgICAgICAgIC8+XG4gICAgICAgICkgOiBudWxsO1xuXG4gICAgICByZXR1cm4gKFxuICAgICAgICA8RnJhZ21lbnQga2V5PXtvcHRpb25WYWx1ZX0+XG4gICAgICAgICAge2RpdmlkZXJFbG19XG4gICAgICAgICAgPFNlZ21lbnRlZENvbnRyb2xPcHRpb25cbiAgICAgICAgICAgIHZhbHVlPXtvcHRpb25WYWx1ZX1cbiAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICBjaGVja2VkPXtpc0NoZWNrZWR9XG4gICAgICAgICAgICBpc1Jlc3BvbnNpdmU9e2p1c3RpZmllZH1cbiAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIG9uQ2hhbmdlPXtoYW5kbGVDaGFuZ2V9XG4gICAgICAgICAgICB7Li4ub3RoZXJQcm9wc31cbiAgICAgICAgICAvPlxuICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgKTtcbiAgICB9XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybUZpZWxkR3JvdXBcbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRDb250cm9sXCJcbiAgICAgIGlzTGFiZWxIaWRkZW49e2lzTGFiZWxIaWRkZW59XG4gICAgICB7Li4ucmVzdH1cbiAgICA+XG4gICAgICA8U3R5bGVkQ29udGFpbmVyIGp1c3RpZmllZD17anVzdGlmaWVkfSBvcHRpb25zPXtvcHRpb25zfT5cbiAgICAgICAge29wdGlvbkVsbXN9XG4gICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZEdyb3VwPlxuICApO1xufVxuXG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQnNCIn0= */"),StyledContainer=styled("div",{target:"ed0qz3a1",label:"StyledContainer"})(({justified,options})=>{let baseStyle={display:"flex"};return justified?{...baseStyle,flexDirection:"column","& > *":{flex:`1 1 ${100/options.length}%`},[`& > ${StyledDivider}`]:{flex:"0 0 auto"},[`@media (min-width: ${breakpoints.m.value}px)`]:{flexDirection:"row"}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkR3JvdXAgfSBmcm9tIFwiLi4vRm9ybUZpZWxkR3JvdXAvRm9ybUZpZWxkR3JvdXBcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uRGlzYWJsZWQ6IGJvb2xlYW47XG59ICYgUGljazxTZWdtZW50ZWRDb250cm9sUHJvcHMsIFwianVzdGlmaWVkXCI+O1xuXG5jb25zdCBTdHlsZWREaXZpZGVyID0gc3R5bGVkLmRpdjxTdHlsZWREaXZpZGVyUHJvcHM+KFxuICAoe1xuICAgIHRoZW1lLFxuICAgIGlzQ2hlY2tlZCxcbiAgICBpc0Rpc2FibGVkLFxuICAgIGlzUHJldk9wdGlvbkNoZWNrZWQsXG4gICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQsXG4gICAganVzdGlmaWVkLFxuICB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBvdGhlclN0eWxlcyA9IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICAgICAgLi4uKChpc0NoZWNrZWQgfHwgaXNQcmV2T3B0aW9uQ2hlY2tlZCkgJiYge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5hY2NlbnQuZGVmYXVsdCxcbiAgICAgIH0pLFxuICAgICAgLi4uKGlzRGlzYWJsZWQgJiZcbiAgICAgICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQgJiYge1xuICAgICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmRpc2FibGVkLFxuICAgICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgYm9yZGVyUmlnaHRTdHlsZSA9IHtcbiAgICAgIGJvcmRlclJpZ2h0OiBib3JkZXIsXG4gICAgICAuLi5vdGhlclN0eWxlcyxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgLi4uYm9yZGVyUmlnaHRTdHlsZSxcbiAgICAgIH0sXG5cbiAgICAgIC8vIExheW91dCBvbiBtb2JpbGVcbiAgICAgIFtgQG1lZGlhIChtYXgtd2lkdGg6ICR7YnJlYWtwb2ludHMubS52YWx1ZX1weClgXToge1xuICAgICAgICBib3JkZXJCb3R0b206IGJvcmRlcixcbiAgICAgICAgLi4ub3RoZXJTdHlsZXMsXG4gICAgICB9LFxuICAgIH07XG4gIH1cbik7XG5cbnR5cGUgU3R5bGVkQ29udGFpbmVyUHJvcHMgPSBQaWNrPFxuICBTZWdtZW50ZWRDb250cm9sUHJvcHMsXG4gIFwianVzdGlmaWVkXCIgfCBcIm9wdGlvbnNcIlxuPjtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdjxTdHlsZWRDb250YWluZXJQcm9wcz4oXG4gICh7IGp1c3RpZmllZCwgb3B0aW9ucyB9KSA9PiB7XG4gICAgY29uc3QgYmFzZVN0eWxlID0ge1xuICAgICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgfTtcblxuICAgIGlmICghanVzdGlmaWVkKSB7XG4gICAgICByZXR1cm4gYmFzZVN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAuLi5iYXNlU3R5bGUsXG4gICAgICBmbGV4RGlyZWN0aW9uOiBcImNvbHVtblwiLFxuXG4gICAgICBcIiYgPiAqXCI6IHtcbiAgICAgICAgZmxleDogYDEgMSAkezEwMCAvIG9wdGlvbnMubGVuZ3RofSVgLFxuICAgICAgfSxcblxuICAgICAgW2AmID4gJHtTdHlsZWREaXZpZGVyfWBdOiB7XG4gICAgICAgIGZsZXg6IFwiMCAwIGF1dG9cIixcbiAgICAgIH0sXG5cbiAgICAgIC8vIExheW91dCBvbiB0YWJsZXQgYW5kIGRlc2t0b3BcbiAgICAgIFtgQG1lZGlhIChtaW4td2lkdGg6ICR7YnJlYWtwb2ludHMubS52YWx1ZX1weClgXToge1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VnbWVudGVkQ29udHJvbCh7XG4gIG9wdGlvbnMsXG4gIHZhbHVlLFxuICBqdXN0aWZpZWQsXG4gIHNpemUgPSBcIm1cIixcbiAgb25DaGFuZ2UsXG4gIGlzTGFiZWxIaWRkZW4gPSB0cnVlLFxuICAuLi5yZXN0XG59OiBTZWdtZW50ZWRDb250cm9sUHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBoYW5kbGVDaGFuZ2U6IEZvcm1FdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD4gPSAoZXZ0KSA9PiB7XG4gICAgb25DaGFuZ2UoKGV2dC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkudmFsdWUpO1xuICB9O1xuXG4gIGNvbnN0IG9wdGlvbkVsbXMgPSBvcHRpb25zLm1hcChcbiAgICAoeyB2YWx1ZTogb3B0aW9uVmFsdWUsIGRpc2FibGVkLCAuLi5vdGhlclByb3BzIH0sIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBpc0NoZWNrZWQgPSB2YWx1ZSA9PT0gb3B0aW9uVmFsdWU7XG4gICAgICBjb25zdCBkaXZpZGVyRWxtID1cbiAgICAgICAgaW5kZXggIT09IDAgPyAoXG4gICAgICAgICAgPFN0eWxlZERpdmlkZXJcbiAgICAgICAgICAgIGlzUHJldk9wdGlvbkNoZWNrZWQ9e29wdGlvbnNbaW5kZXggLSAxXS52YWx1ZSA9PT0gdmFsdWV9XG4gICAgICAgICAgICBpc1ByZXZPcHRpb25EaXNhYmxlZD17b3B0aW9uc1tpbmRleCAtIDFdLmRpc2FibGVkfVxuICAgICAgICAgICAgaXNDaGVja2VkPXtpc0NoZWNrZWR9XG4gICAgICAgICAgICBpc0Rpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIGp1c3RpZmllZD17anVzdGlmaWVkfVxuICAgICAgICAgIC8+XG4gICAgICAgICkgOiBudWxsO1xuXG4gICAgICByZXR1cm4gKFxuICAgICAgICA8RnJhZ21lbnQga2V5PXtvcHRpb25WYWx1ZX0+XG4gICAgICAgICAge2RpdmlkZXJFbG19XG4gICAgICAgICAgPFNlZ21lbnRlZENvbnRyb2xPcHRpb25cbiAgICAgICAgICAgIHZhbHVlPXtvcHRpb25WYWx1ZX1cbiAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICBjaGVja2VkPXtpc0NoZWNrZWR9XG4gICAgICAgICAgICBpc1Jlc3BvbnNpdmU9e2p1c3RpZmllZH1cbiAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIG9uQ2hhbmdlPXtoYW5kbGVDaGFuZ2V9XG4gICAgICAgICAgICB7Li4ub3RoZXJQcm9wc31cbiAgICAgICAgICAvPlxuICAgICAgICA8L0ZyYWdtZW50PlxuICAgICAgKTtcbiAgICB9XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybUZpZWxkR3JvdXBcbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRDb250cm9sXCJcbiAgICAgIGlzTGFiZWxIaWRkZW49e2lzTGFiZWxIaWRkZW59XG4gICAgICB7Li4ucmVzdH1cbiAgICA+XG4gICAgICA8U3R5bGVkQ29udGFpbmVyIGp1c3RpZmllZD17anVzdGlmaWVkfSBvcHRpb25zPXtvcHRpb25zfT5cbiAgICAgICAge29wdGlvbkVsbXN9XG4gICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZEdyb3VwPlxuICApO1xufVxuXG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrRXdCIn0= */");export function SegmentedControl({options,value,justified,size="m",onChange,isLabelHidden=!0,...rest}){let handleChange=evt=>{onChange(evt.target.value)},optionElms=options.map(({value:optionValue,disabled,...otherProps},index)=>{let isChecked=value===optionValue,dividerElm=0!==index?React.createElement(StyledDivider,{isPrevOptionChecked:options[index-1].value===value,isPrevOptionDisabled:options[index-1].disabled,isChecked:isChecked,isDisabled:disabled,justified:justified}):null;return React.createElement(Fragment,{key:optionValue},dividerElm,React.createElement(SegmentedControlOption,{value:optionValue,size:size,checked:isChecked,isResponsive:justified,disabled:disabled,onChange:handleChange,...otherProps}))});return React.createElement(FormFieldGroup,{"data-ds-id":"SegmentedControl",isLabelHidden:isLabelHidden,...rest},React.createElement(StyledContainer,{justified:justified,options:options},optionElms))}