@amboss/design-system 3.40.2 → 3.40.4

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 (30) hide show
  1. package/build/cjs/components/CatalogCard/CatalogCard.d.ts +6 -1
  2. package/build/cjs/components/CatalogCard/CatalogCard.js +1 -1
  3. package/build/cjs/components/Content/ContentTable/ContentTableContext.d.ts +4 -2
  4. package/build/cjs/components/Content/DosageButton/DosageButton.d.ts +5 -0
  5. package/build/cjs/components/Content/DosageButton/DosageButton.js +1 -0
  6. package/build/cjs/components/Content/DosageButton/index.d.ts +1 -0
  7. package/build/cjs/components/Content/DosageButton/index.js +1 -0
  8. package/build/cjs/components/Link/Link.js +1 -1
  9. package/build/cjs/index.d.ts +1 -0
  10. package/build/cjs/index.js +1 -1
  11. package/build/cjs/web-tokens/_colors.json +16 -0
  12. package/build/cjs/web-tokens/visualConfig.d.ts +10 -0
  13. package/build/cjs/web-tokens/visualConfig.js +1 -1
  14. package/build/esm/components/CatalogCard/CatalogCard.d.ts +6 -1
  15. package/build/esm/components/CatalogCard/CatalogCard.js +1 -1
  16. package/build/esm/components/Content/ContentTable/ContentTableContext.d.ts +4 -2
  17. package/build/esm/components/Content/DosageButton/DosageButton.d.ts +5 -0
  18. package/build/esm/components/Content/DosageButton/DosageButton.js +1 -0
  19. package/build/esm/components/Content/DosageButton/index.d.ts +1 -0
  20. package/build/esm/components/Content/DosageButton/index.js +1 -0
  21. package/build/esm/components/Link/Link.js +1 -1
  22. package/build/esm/index.d.ts +1 -0
  23. package/build/esm/index.js +1 -1
  24. package/build/esm/web-tokens/_colors.json +16 -0
  25. package/build/esm/web-tokens/visualConfig.d.ts +10 -0
  26. package/build/esm/web-tokens/visualConfig.js +1 -1
  27. package/build/scss/_dark.scss +4 -0
  28. package/build/scss/_light.scss +4 -0
  29. package/build/scss/_variables.scss +4 -0
  30. package/package.json +1 -1
@@ -14,5 +14,10 @@ export type CatalogCardProps = Omit<ContainerProps, "id" | "elevation" | "overfl
14
14
  onClick?: VoidFunction;
15
15
  onDropdownClick?: (ev: MouseEvent | KeyboardEvent) => void;
16
16
  topLeftElement?: React.ReactNode;
17
+ slotProps?: {
18
+ dropdownMenu?: {
19
+ "aria-label"?: string;
20
+ };
21
+ };
17
22
  };
18
- export declare function CatalogCard({ title, subtitle, dropdownMenuOptions, onClick, onDropdownClick, topLeftElement, portalContainer, borderRadius, subtitleLines, colorPickerProps, "data-e2e-test-id": dataE2eTestId, "data-ds-id": dataDsId, ...ariaAttributes }: CatalogCardProps): React.ReactElement;
23
+ export declare function CatalogCard({ title, subtitle, dropdownMenuOptions, onClick, onDropdownClick, topLeftElement, portalContainer, borderRadius, subtitleLines, colorPickerProps, slotProps, "data-e2e-test-id": dataE2eTestId, "data-ds-id": dataDsId, ...ariaAttributes }: CatalogCardProps): React.ReactElement;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"CatalogCard",{enumerable:!0,get:function(){return CatalogCard}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Container=require("../Container/Container"),_DropdownMenu=require("../DropdownMenu/DropdownMenu"),_Box=require("../Box/Box"),_Columns=require("../Column/Columns"),_Stack=require("../Stack/Stack"),_Text=require("../Typography/Text/Text"),_TextClamped=require("../Typography/TextClamped/TextClamped"),_ColorPickerDropdown=require("../ColorPicker/ColorPickerDropdown"),_useBreakpoints=require("../../shared/useBreakpoints"),StyledDropdownMenuContainer=(0,_styled.default)("div",{target:"eiw0i0a0",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 { useBreakpoints } from \"../../shared/useBreakpoints\";\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  ...ariaAttributes\n}: CatalogCardProps): React.ReactElement {\n  const { isMobile } = useBreakpoints();\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        outlined\n        {...ariaAttributes}\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=(0,_styled.default)("button",{target:"eiw0i0a1",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 { useBreakpoints } from \"../../shared/useBreakpoints\";\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  ...ariaAttributes\n}: CatalogCardProps): React.ReactElement {\n  const { isMobile } = useBreakpoints();\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        outlined\n        {...ariaAttributes}\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=(0,_styled.default)("div",{target:"eiw0i0a2",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 { useBreakpoints } from \"../../shared/useBreakpoints\";\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  ...ariaAttributes\n}: CatalogCardProps): React.ReactElement {\n  const { isMobile } = useBreakpoints();\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        outlined\n        {...ariaAttributes}\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=(0,_styled.default)("div",{target:"eiw0i0a3",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 { useBreakpoints } from \"../../shared/useBreakpoints\";\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  ...ariaAttributes\n}: CatalogCardProps): React.ReactElement {\n  const { isMobile } = useBreakpoints();\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        outlined\n        {...ariaAttributes}\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=(0,_styled.default)("div",{target:"eiw0i0a4",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 { useBreakpoints } from \"../../shared/useBreakpoints\";\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  ...ariaAttributes\n}: CatalogCardProps): React.ReactElement {\n  const { isMobile } = useBreakpoints();\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        outlined\n        {...ariaAttributes}\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.default.createElement(_Box.Box,{space:"xxs",bSpace:"zero"},_react.default.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},_react.default.createElement(_DropdownMenu.DropdownMenu,{iconName:"more-horizontal",menuItems:menuItems,onMenuOpen:onMenuOpen,portalContainer:portalContainer,size:"xs"}))),TopRightColorPicker=({colorPickerProps,menuItems,portalContainer,isMobile})=>_react.default.createElement(_Box.Box,{space:"xxs",bSpace:"zero"},_react.default.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},_react.default.createElement(_ColorPickerDropdown.ColorPickerDropdown,{portalContainer:portalContainer,...colorPickerProps,menuItems:menuItems})));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",...ariaAttributes}){let{isMobile}=(0,_useBreakpoints.useBreakpoints)(),topRightElement=colorPickerProps?_react.default.createElement(TopRightColorPicker,{colorPickerProps:colorPickerProps,menuItems:dropdownMenuOptions,portalContainer:portalContainer,isMobile:isMobile}):dropdownMenuOptions.length>0?_react.default.createElement(TopRightDropdownMenu,{menuItems:dropdownMenuOptions,onMenuOpen:onDropdownClick,portalContainer:portalContainer,isMobile:isMobile}):null,SubtitleComponent="none"===subtitleLines?_Text.Text:_TextClamped.TextClamped;return _react.default.createElement(StyledWrapper,null,_react.default.createElement(StyledButton,{onClick:onClick,"aria-label":title}),_react.default.createElement(_Container.Container,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,borderRadius:borderRadius,outlined:!0,...ariaAttributes},_react.default.createElement(StyledContainer,{isMobile:isMobile},_react.default.createElement(_Box.Box,{space:"m"},_react.default.createElement(_Columns.Columns,null,_react.default.createElement(_Columns.Column,{size:"fill"},_react.default.createElement("div",{onClick:onClick},_react.default.createElement(_Stack.Stack,{vAlignItems:"spaceBetween",space:"s"},topLeftElement,_react.default.createElement(_Stack.Stack,{space:"xxs",vAlignItems:"bottom"},_react.default.createElement(StyledTitle,null,_react.default.createElement(_TextClamped.TextClamped,{size:"m",weight:"bold",lines:2},title)),subtitle&&_react.default.createElement(SubtitleComponent,{size:"s",color:"tertiary",..."none"!==subtitleLines&&{lines:subtitleLines}},subtitle))))),topRightElement&&_react.default.createElement(_Columns.Column,{size:"narrow"},topRightElement))))))}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"CatalogCard",{enumerable:!0,get:function(){return CatalogCard}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Container=require("../Container/Container"),_DropdownMenu=require("../DropdownMenu/DropdownMenu"),_Box=require("../Box/Box"),_Columns=require("../Column/Columns"),_Stack=require("../Stack/Stack"),_Text=require("../Typography/Text/Text"),_TextClamped=require("../Typography/TextClamped/TextClamped"),_ColorPickerDropdown=require("../ColorPicker/ColorPickerDropdown"),_useBreakpoints=require("../../shared/useBreakpoints"),StyledDropdownMenuContainer=(0,_styled.default)("div",{target:"enec9m90",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 { useBreakpoints } from \"../../shared/useBreakpoints\";\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  \"aria-label\"?: string;\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  \"aria-label\": ariaLabel,\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        aria-label={ariaLabel}\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  slotProps?: {\n    dropdownMenu?: {\n      \"aria-label\"?: string;\n    };\n  };\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  slotProps,\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n  ...ariaAttributes\n}: CatalogCardProps): React.ReactElement {\n  const { isMobile } = useBreakpoints();\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          aria-label={slotProps?.dropdownMenu?.[\"aria-label\"]}\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        outlined\n        {...ariaAttributes}\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=(0,_styled.default)("button",{target:"enec9m91",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 { useBreakpoints } from \"../../shared/useBreakpoints\";\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  \"aria-label\"?: string;\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  \"aria-label\": ariaLabel,\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        aria-label={ariaLabel}\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  slotProps?: {\n    dropdownMenu?: {\n      \"aria-label\"?: string;\n    };\n  };\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  slotProps,\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n  ...ariaAttributes\n}: CatalogCardProps): React.ReactElement {\n  const { isMobile } = useBreakpoints();\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          aria-label={slotProps?.dropdownMenu?.[\"aria-label\"]}\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        outlined\n        {...ariaAttributes}\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=(0,_styled.default)("div",{target:"enec9m92",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 { useBreakpoints } from \"../../shared/useBreakpoints\";\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  \"aria-label\"?: string;\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  \"aria-label\": ariaLabel,\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        aria-label={ariaLabel}\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  slotProps?: {\n    dropdownMenu?: {\n      \"aria-label\"?: string;\n    };\n  };\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  slotProps,\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n  ...ariaAttributes\n}: CatalogCardProps): React.ReactElement {\n  const { isMobile } = useBreakpoints();\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          aria-label={slotProps?.dropdownMenu?.[\"aria-label\"]}\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        outlined\n        {...ariaAttributes}\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":"AAqDsB"} */"),StyledContainer=(0,_styled.default)("div",{target:"enec9m93",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 { useBreakpoints } from \"../../shared/useBreakpoints\";\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  \"aria-label\"?: string;\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  \"aria-label\": ariaLabel,\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        aria-label={ariaLabel}\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  slotProps?: {\n    dropdownMenu?: {\n      \"aria-label\"?: string;\n    };\n  };\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  slotProps,\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n  ...ariaAttributes\n}: CatalogCardProps): React.ReactElement {\n  const { isMobile } = useBreakpoints();\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          aria-label={slotProps?.dropdownMenu?.[\"aria-label\"]}\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        outlined\n        {...ariaAttributes}\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":"AA2FwB"} */"),StyledTitle=(0,_styled.default)("div",{target:"enec9m94",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 { useBreakpoints } from \"../../shared/useBreakpoints\";\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  \"aria-label\"?: string;\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  \"aria-label\": ariaLabel,\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        aria-label={ariaLabel}\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  slotProps?: {\n    dropdownMenu?: {\n      \"aria-label\"?: string;\n    };\n  };\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  slotProps,\n  \"data-e2e-test-id\": dataE2eTestId = \"CatalogCard\",\n  \"data-ds-id\": dataDsId = \"CatalogCard\",\n  ...ariaAttributes\n}: CatalogCardProps): React.ReactElement {\n  const { isMobile } = useBreakpoints();\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          aria-label={slotProps?.dropdownMenu?.[\"aria-label\"]}\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        outlined\n        {...ariaAttributes}\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":"AAkHoB"} */"),TopRightDropdownMenu=({menuItems,onMenuOpen,portalContainer,isMobile,"aria-label":ariaLabel})=>_react.default.createElement(_Box.Box,{space:"xxs",bSpace:"zero"},_react.default.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},_react.default.createElement(_DropdownMenu.DropdownMenu,{iconName:"more-horizontal",menuItems:menuItems,onMenuOpen:onMenuOpen,portalContainer:portalContainer,size:"xs","aria-label":ariaLabel}))),TopRightColorPicker=({colorPickerProps,menuItems,portalContainer,isMobile})=>_react.default.createElement(_Box.Box,{space:"xxs",bSpace:"zero"},_react.default.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},_react.default.createElement(_ColorPickerDropdown.ColorPickerDropdown,{portalContainer:portalContainer,...colorPickerProps,menuItems:menuItems})));function CatalogCard({title,subtitle,dropdownMenuOptions=[],onClick,onDropdownClick,topLeftElement,portalContainer,borderRadius="s",subtitleLines=1,colorPickerProps,slotProps,"data-e2e-test-id":dataE2eTestId="CatalogCard","data-ds-id":dataDsId="CatalogCard",...ariaAttributes}){let{isMobile}=(0,_useBreakpoints.useBreakpoints)(),topRightElement=colorPickerProps?_react.default.createElement(TopRightColorPicker,{colorPickerProps:colorPickerProps,menuItems:dropdownMenuOptions,portalContainer:portalContainer,isMobile:isMobile}):dropdownMenuOptions.length>0?_react.default.createElement(TopRightDropdownMenu,{menuItems:dropdownMenuOptions,onMenuOpen:onDropdownClick,portalContainer:portalContainer,isMobile:isMobile,"aria-label":slotProps?.dropdownMenu?.["aria-label"]}):null,SubtitleComponent="none"===subtitleLines?_Text.Text:_TextClamped.TextClamped;return _react.default.createElement(StyledWrapper,null,_react.default.createElement(StyledButton,{onClick:onClick,"aria-label":title}),_react.default.createElement(_Container.Container,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,borderRadius:borderRadius,outlined:!0,...ariaAttributes},_react.default.createElement(StyledContainer,{isMobile:isMobile},_react.default.createElement(_Box.Box,{space:"m"},_react.default.createElement(_Columns.Columns,null,_react.default.createElement(_Columns.Column,{size:"fill"},_react.default.createElement("div",{onClick:onClick},_react.default.createElement(_Stack.Stack,{vAlignItems:"spaceBetween",space:"s"},topLeftElement,_react.default.createElement(_Stack.Stack,{space:"xxs",vAlignItems:"bottom"},_react.default.createElement(StyledTitle,null,_react.default.createElement(_TextClamped.TextClamped,{size:"m",weight:"bold",lines:2},title)),subtitle&&_react.default.createElement(SubtitleComponent,{size:"s",color:"tertiary",..."none"!==subtitleLines&&{lines:subtitleLines}},subtitle))))),topRightElement&&_react.default.createElement(_Columns.Column,{size:"narrow"},topRightElement))))))}
@@ -1,4 +1,6 @@
1
1
  export type ContentTableContextValue = {
2
2
  fontSizeOffset: number;
3
- };
4
- export declare const ContentTableContext: React.Context<ContentTableContextValue>;
3
+ } | null;
4
+ export declare const ContentTableContext: React.Context<{
5
+ fontSizeOffset: number;
6
+ }>;
@@ -0,0 +1,5 @@
1
+ import React from "react";
2
+ export type DosageButtonProps = React.ComponentPropsWithRef<"button">;
3
+ export declare const DosageButton: React.ForwardRefExoticComponent<Omit<Omit<React.DetailedHTMLProps<React.ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, "ref"> & {
4
+ ref?: React.Ref<HTMLButtonElement>;
5
+ }, "ref"> & React.RefAttributes<HTMLButtonElement>>;
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"DosageButton",{enumerable:!0,get:function(){return DosageButton}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Icon=require("../../Icon/Icon"),_ContentFontResizer=require("../ContentFontResizer"),StyledIcon=(0,_styled.default)(_Icon.Icon,{target:"e1uu7rms0",label:"StyledIcon"})("/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29udGVudC9Eb3NhZ2VCdXR0b24vRG9zYWdlQnV0dG9uLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvQ29udGVudC9Eb3NhZ2VCdXR0b24vRG9zYWdlQnV0dG9uLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlQ29udGV4dCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgRm9udFNpemVPZmZzZXRDb250ZXh0IH0gZnJvbSBcIi4uL0NvbnRlbnRGb250UmVzaXplclwiO1xuXG5leHBvcnQgdHlwZSBEb3NhZ2VCdXR0b25Qcm9wcyA9IFJlYWN0LkNvbXBvbmVudFByb3BzV2l0aFJlZjxcImJ1dHRvblwiPjtcblxuY29uc3QgRE9TQUdFX0JVVFRPTl9GT05UX1NJWkUgPSA4O1xuXG5jb25zdCBTdHlsZWRJY29uID0gc3R5bGVkKEljb24pKCk7XG5cbnR5cGUgU3R5bGVkQ29udGVudFByb3BzID0ge1xuICBmb250U2l6ZU9mZnNldDogbnVtYmVyO1xufTtcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5zcGFuPFN0eWxlZENvbnRlbnRQcm9wcz4oXG4gICh7IHRoZW1lLCBmb250U2l6ZU9mZnNldCB9KSA9PiAoe1xuICAgIGRpc3BsYXk6IFwiaW5saW5lLWZsZXhcIixcbiAgICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICAgIGdhcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHhzLFxuICAgIHBhZGRpbmdMZWZ0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzLFxuICAgIHBhZGRpbmdSaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54cyxcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54bCxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5jb250ZW50LmRvc2FnZUJ1dHRvbi5iYWNrZ3JvdW5kLmRlZmF1bHQsXG4gICAgbGluZUhlaWdodDogMixcbiAgICBmb250U2l6ZTpcbiAgICAgIGZvbnRTaXplT2Zmc2V0ICE9PSAwXG4gICAgICAgID8gYGNhbGMoJHtET1NBR0VfQlVUVE9OX0ZPTlRfU0laRX1weCArICR7Zm9udFNpemVPZmZzZXR9cHgpYFxuICAgICAgICA6IERPU0FHRV9CVVRUT05fRk9OVF9TSVpFLFxuICAgIGxldHRlclNwYWNpbmc6IDAuNSxcbiAgICBmb250RmFtaWx5OiB0aGVtZS52YXJpYWJsZXMuZm9udEZhbWlseS5sYXRvLFxuICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy53ZWlnaHQuYmxhY2ssXG4gICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5jb250ZW50LmRvc2FnZUJ1dHRvbi50ZXh0LmRlZmF1bHQsXG5cbiAgICBbYCR7U3R5bGVkSWNvbn1gXToge1xuICAgICAgd2lkdGg6IFwiMS4yNWVtXCIsIC8vIFRoZXNlIGFyZSBpbiBlbSB0byBzY2FsZSB3aXRoIHRoZSBmb250IHNpemUgb2YgdGhlIGJ1dHRvblxuICAgICAgaGVpZ2h0OiBcIjEuNWVtXCIsXG5cbiAgICAgIHN2Zzoge1xuICAgICAgICB3aWR0aDogXCIxLjI1ZW1cIixcbiAgICAgICAgaGVpZ2h0OiBcIjEuMjVlbVwiLFxuICAgICAgfSxcbiAgICB9LFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkQnV0dG9uID0gc3R5bGVkLmJ1dHRvbigoeyB0aGVtZSB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImlubGluZS1ibG9ja1wiLFxuICB2ZXJ0aWNhbEFsaWduOiBcIm1pZGRsZVwiLFxuICBjdXJzb3I6IFwicG9pbnRlclwiLFxuICBib3JkZXI6IFwibm9uZVwiLFxuICBiYWNrZ3JvdW5kOiBcIm5vbmVcIixcbiAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gIGxpbmVIZWlnaHQ6IDAsXG4gIG91dGxpbmVPZmZzZXQ6IC0yLFxuICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54bCxcblxuICBbYCY6aG92ZXIgJHtTdHlsZWRDb250ZW50fWBdOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuY29udGVudC5kb3NhZ2VCdXR0b24uYmFja2dyb3VuZC5ob3ZlcixcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmNvbnRlbnQuZG9zYWdlQnV0dG9uLnRleHQuaG92ZXIsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBEb3NhZ2VCdXR0b24gPSBSZWFjdC5mb3J3YXJkUmVmPFxuICBIVE1MQnV0dG9uRWxlbWVudCxcbiAgRG9zYWdlQnV0dG9uUHJvcHNcbj4oKHsgdHlwZSA9IFwiYnV0dG9uXCIsIGNoaWxkcmVuLCAuLi5yZXN0IH0sIHJlZikgPT4ge1xuICBjb25zdCBmb250U2l6ZU9mZnNldCA9IHVzZUNvbnRleHQoRm9udFNpemVPZmZzZXRDb250ZXh0KTtcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRCdXR0b24gZGF0YS1kcy1pZD1cIkRvc2FnZUJ1dHRvblwiIHJlZj17cmVmfSB0eXBlPXt0eXBlfSB7Li4ucmVzdH0+XG4gICAgICA8U3R5bGVkQ29udGVudCBmb250U2l6ZU9mZnNldD17Zm9udFNpemVPZmZzZXR9PlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgIDxTdHlsZWRJY29uIG5hbWU9XCJjaGV2cm9uLWRvd25cIiBzaXplPVwic1wiIC8+XG4gICAgICA8L1N0eWxlZENvbnRlbnQ+XG4gICAgPC9TdHlsZWRCdXR0b24+XG4gICk7XG59KTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTbUIifQ== */"),StyledContent=(0,_styled.default)("span",{target:"e1uu7rms1",label:"StyledContent"})(({theme,fontSizeOffset})=>({display:"inline-flex",alignItems:"center",gap:theme.variables.size.spacing.xxxs,paddingLeft:theme.variables.size.spacing.xs,paddingRight:theme.variables.size.spacing.xs,borderRadius:theme.variables.size.borderRadius.xl,backgroundColor:theme.values.color.content.dosageButton.background.default,lineHeight:2,fontSize:0!==fontSizeOffset?`calc(8px + ${fontSizeOffset}px)`:8,letterSpacing:.5,fontFamily:theme.variables.fontFamily.lato,fontWeight:theme.variables.weight.black,color:theme.values.color.content.dosageButton.text.default,[`${StyledIcon}`]:{width:"1.25em",height:"1.5em",svg:{width:"1.25em",height:"1.25em"}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29udGVudC9Eb3NhZ2VCdXR0b24vRG9zYWdlQnV0dG9uLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvQ29udGVudC9Eb3NhZ2VCdXR0b24vRG9zYWdlQnV0dG9uLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlQ29udGV4dCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgRm9udFNpemVPZmZzZXRDb250ZXh0IH0gZnJvbSBcIi4uL0NvbnRlbnRGb250UmVzaXplclwiO1xuXG5leHBvcnQgdHlwZSBEb3NhZ2VCdXR0b25Qcm9wcyA9IFJlYWN0LkNvbXBvbmVudFByb3BzV2l0aFJlZjxcImJ1dHRvblwiPjtcblxuY29uc3QgRE9TQUdFX0JVVFRPTl9GT05UX1NJWkUgPSA4O1xuXG5jb25zdCBTdHlsZWRJY29uID0gc3R5bGVkKEljb24pKCk7XG5cbnR5cGUgU3R5bGVkQ29udGVudFByb3BzID0ge1xuICBmb250U2l6ZU9mZnNldDogbnVtYmVyO1xufTtcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5zcGFuPFN0eWxlZENvbnRlbnRQcm9wcz4oXG4gICh7IHRoZW1lLCBmb250U2l6ZU9mZnNldCB9KSA9PiAoe1xuICAgIGRpc3BsYXk6IFwiaW5saW5lLWZsZXhcIixcbiAgICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICAgIGdhcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHhzLFxuICAgIHBhZGRpbmdMZWZ0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzLFxuICAgIHBhZGRpbmdSaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54cyxcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54bCxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5jb250ZW50LmRvc2FnZUJ1dHRvbi5iYWNrZ3JvdW5kLmRlZmF1bHQsXG4gICAgbGluZUhlaWdodDogMixcbiAgICBmb250U2l6ZTpcbiAgICAgIGZvbnRTaXplT2Zmc2V0ICE9PSAwXG4gICAgICAgID8gYGNhbGMoJHtET1NBR0VfQlVUVE9OX0ZPTlRfU0laRX1weCArICR7Zm9udFNpemVPZmZzZXR9cHgpYFxuICAgICAgICA6IERPU0FHRV9CVVRUT05fRk9OVF9TSVpFLFxuICAgIGxldHRlclNwYWNpbmc6IDAuNSxcbiAgICBmb250RmFtaWx5OiB0aGVtZS52YXJpYWJsZXMuZm9udEZhbWlseS5sYXRvLFxuICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy53ZWlnaHQuYmxhY2ssXG4gICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5jb250ZW50LmRvc2FnZUJ1dHRvbi50ZXh0LmRlZmF1bHQsXG5cbiAgICBbYCR7U3R5bGVkSWNvbn1gXToge1xuICAgICAgd2lkdGg6IFwiMS4yNWVtXCIsIC8vIFRoZXNlIGFyZSBpbiBlbSB0byBzY2FsZSB3aXRoIHRoZSBmb250IHNpemUgb2YgdGhlIGJ1dHRvblxuICAgICAgaGVpZ2h0OiBcIjEuNWVtXCIsXG5cbiAgICAgIHN2Zzoge1xuICAgICAgICB3aWR0aDogXCIxLjI1ZW1cIixcbiAgICAgICAgaGVpZ2h0OiBcIjEuMjVlbVwiLFxuICAgICAgfSxcbiAgICB9LFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkQnV0dG9uID0gc3R5bGVkLmJ1dHRvbigoeyB0aGVtZSB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImlubGluZS1ibG9ja1wiLFxuICB2ZXJ0aWNhbEFsaWduOiBcIm1pZGRsZVwiLFxuICBjdXJzb3I6IFwicG9pbnRlclwiLFxuICBib3JkZXI6IFwibm9uZVwiLFxuICBiYWNrZ3JvdW5kOiBcIm5vbmVcIixcbiAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gIGxpbmVIZWlnaHQ6IDAsXG4gIG91dGxpbmVPZmZzZXQ6IC0yLFxuICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54bCxcblxuICBbYCY6aG92ZXIgJHtTdHlsZWRDb250ZW50fWBdOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuY29udGVudC5kb3NhZ2VCdXR0b24uYmFja2dyb3VuZC5ob3ZlcixcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmNvbnRlbnQuZG9zYWdlQnV0dG9uLnRleHQuaG92ZXIsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBEb3NhZ2VCdXR0b24gPSBSZWFjdC5mb3J3YXJkUmVmPFxuICBIVE1MQnV0dG9uRWxlbWVudCxcbiAgRG9zYWdlQnV0dG9uUHJvcHNcbj4oKHsgdHlwZSA9IFwiYnV0dG9uXCIsIGNoaWxkcmVuLCAuLi5yZXN0IH0sIHJlZikgPT4ge1xuICBjb25zdCBmb250U2l6ZU9mZnNldCA9IHVzZUNvbnRleHQoRm9udFNpemVPZmZzZXRDb250ZXh0KTtcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRCdXR0b24gZGF0YS1kcy1pZD1cIkRvc2FnZUJ1dHRvblwiIHJlZj17cmVmfSB0eXBlPXt0eXBlfSB7Li4ucmVzdH0+XG4gICAgICA8U3R5bGVkQ29udGVudCBmb250U2l6ZU9mZnNldD17Zm9udFNpemVPZmZzZXR9PlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgIDxTdHlsZWRJY29uIG5hbWU9XCJjaGV2cm9uLWRvd25cIiBzaXplPVwic1wiIC8+XG4gICAgICA8L1N0eWxlZENvbnRlbnQ+XG4gICAgPC9TdHlsZWRCdXR0b24+XG4gICk7XG59KTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlc0IifQ== */"),StyledButton=(0,_styled.default)("button",{target:"e1uu7rms2",label:"StyledButton"})(({theme})=>({display:"inline-block",verticalAlign:"middle",cursor:"pointer",border:"none",background:"none",padding:theme.variables.size.spacing.xxs,lineHeight:0,outlineOffset:-2,borderRadius:theme.variables.size.borderRadius.xl,[`&:hover ${StyledContent}`]:{backgroundColor:theme.values.color.content.dosageButton.background.hover,color:theme.values.color.content.dosageButton.text.hover}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQ29udGVudC9Eb3NhZ2VCdXR0b24vRG9zYWdlQnV0dG9uLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvQ29udGVudC9Eb3NhZ2VCdXR0b24vRG9zYWdlQnV0dG9uLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlQ29udGV4dCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSBcIi4uLy4uL0ljb24vSWNvblwiO1xuaW1wb3J0IHsgRm9udFNpemVPZmZzZXRDb250ZXh0IH0gZnJvbSBcIi4uL0NvbnRlbnRGb250UmVzaXplclwiO1xuXG5leHBvcnQgdHlwZSBEb3NhZ2VCdXR0b25Qcm9wcyA9IFJlYWN0LkNvbXBvbmVudFByb3BzV2l0aFJlZjxcImJ1dHRvblwiPjtcblxuY29uc3QgRE9TQUdFX0JVVFRPTl9GT05UX1NJWkUgPSA4O1xuXG5jb25zdCBTdHlsZWRJY29uID0gc3R5bGVkKEljb24pKCk7XG5cbnR5cGUgU3R5bGVkQ29udGVudFByb3BzID0ge1xuICBmb250U2l6ZU9mZnNldDogbnVtYmVyO1xufTtcblxuY29uc3QgU3R5bGVkQ29udGVudCA9IHN0eWxlZC5zcGFuPFN0eWxlZENvbnRlbnRQcm9wcz4oXG4gICh7IHRoZW1lLCBmb250U2l6ZU9mZnNldCB9KSA9PiAoe1xuICAgIGRpc3BsYXk6IFwiaW5saW5lLWZsZXhcIixcbiAgICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICAgIGdhcDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHhzLFxuICAgIHBhZGRpbmdMZWZ0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzLFxuICAgIHBhZGRpbmdSaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54cyxcbiAgICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54bCxcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5jb250ZW50LmRvc2FnZUJ1dHRvbi5iYWNrZ3JvdW5kLmRlZmF1bHQsXG4gICAgbGluZUhlaWdodDogMixcbiAgICBmb250U2l6ZTpcbiAgICAgIGZvbnRTaXplT2Zmc2V0ICE9PSAwXG4gICAgICAgID8gYGNhbGMoJHtET1NBR0VfQlVUVE9OX0ZPTlRfU0laRX1weCArICR7Zm9udFNpemVPZmZzZXR9cHgpYFxuICAgICAgICA6IERPU0FHRV9CVVRUT05fRk9OVF9TSVpFLFxuICAgIGxldHRlclNwYWNpbmc6IDAuNSxcbiAgICBmb250RmFtaWx5OiB0aGVtZS52YXJpYWJsZXMuZm9udEZhbWlseS5sYXRvLFxuICAgIGZvbnRXZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy53ZWlnaHQuYmxhY2ssXG4gICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5jb250ZW50LmRvc2FnZUJ1dHRvbi50ZXh0LmRlZmF1bHQsXG5cbiAgICBbYCR7U3R5bGVkSWNvbn1gXToge1xuICAgICAgd2lkdGg6IFwiMS4yNWVtXCIsIC8vIFRoZXNlIGFyZSBpbiBlbSB0byBzY2FsZSB3aXRoIHRoZSBmb250IHNpemUgb2YgdGhlIGJ1dHRvblxuICAgICAgaGVpZ2h0OiBcIjEuNWVtXCIsXG5cbiAgICAgIHN2Zzoge1xuICAgICAgICB3aWR0aDogXCIxLjI1ZW1cIixcbiAgICAgICAgaGVpZ2h0OiBcIjEuMjVlbVwiLFxuICAgICAgfSxcbiAgICB9LFxuICB9KVxuKTtcblxuY29uc3QgU3R5bGVkQnV0dG9uID0gc3R5bGVkLmJ1dHRvbigoeyB0aGVtZSB9KSA9PiAoe1xuICBkaXNwbGF5OiBcImlubGluZS1ibG9ja1wiLFxuICB2ZXJ0aWNhbEFsaWduOiBcIm1pZGRsZVwiLFxuICBjdXJzb3I6IFwicG9pbnRlclwiLFxuICBib3JkZXI6IFwibm9uZVwiLFxuICBiYWNrZ3JvdW5kOiBcIm5vbmVcIixcbiAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHMsXG4gIGxpbmVIZWlnaHQ6IDAsXG4gIG91dGxpbmVPZmZzZXQ6IC0yLFxuICBib3JkZXJSYWRpdXM6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1cy54bCxcblxuICBbYCY6aG92ZXIgJHtTdHlsZWRDb250ZW50fWBdOiB7XG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuY29udGVudC5kb3NhZ2VCdXR0b24uYmFja2dyb3VuZC5ob3ZlcixcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmNvbnRlbnQuZG9zYWdlQnV0dG9uLnRleHQuaG92ZXIsXG4gIH0sXG59KSk7XG5cbmV4cG9ydCBjb25zdCBEb3NhZ2VCdXR0b24gPSBSZWFjdC5mb3J3YXJkUmVmPFxuICBIVE1MQnV0dG9uRWxlbWVudCxcbiAgRG9zYWdlQnV0dG9uUHJvcHNcbj4oKHsgdHlwZSA9IFwiYnV0dG9uXCIsIGNoaWxkcmVuLCAuLi5yZXN0IH0sIHJlZikgPT4ge1xuICBjb25zdCBmb250U2l6ZU9mZnNldCA9IHVzZUNvbnRleHQoRm9udFNpemVPZmZzZXRDb250ZXh0KTtcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRCdXR0b24gZGF0YS1kcy1pZD1cIkRvc2FnZUJ1dHRvblwiIHJlZj17cmVmfSB0eXBlPXt0eXBlfSB7Li4ucmVzdH0+XG4gICAgICA8U3R5bGVkQ29udGVudCBmb250U2l6ZU9mZnNldD17Zm9udFNpemVPZmZzZXR9PlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgIDxTdHlsZWRJY29uIG5hbWU9XCJjaGV2cm9uLWRvd25cIiBzaXplPVwic1wiIC8+XG4gICAgICA8L1N0eWxlZENvbnRlbnQ+XG4gICAgPC9TdHlsZWRCdXR0b24+XG4gICk7XG59KTtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4Q3FCIn0= */"),DosageButton=_react.default.forwardRef(({type="button",children,...rest},ref)=>{let fontSizeOffset=(0,_react.useContext)(_ContentFontResizer.FontSizeOffsetContext);return _react.default.createElement(StyledButton,{"data-ds-id":"DosageButton",ref:ref,type:type,...rest},_react.default.createElement(StyledContent,{fontSizeOffset:fontSizeOffset},children,_react.default.createElement(StyledIcon,{name:"chevron-down",size:"s"})))});
@@ -0,0 +1 @@
1
+ export * from "./DosageButton";
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),require("@swc/helpers/_/_export_star")._(require("./DosageButton"),exports);
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Link",{enumerable:!0,get:function(){return Link}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_Text=require("../Typography/Text/Text"),_Icon=require("../Icon/Icon"),StyledLink=(0,_styled.default)("a",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"inline"!==prop,target:"e1foykt90",label:"StyledLink"})(({theme,weight,size,color,inline,as})=>({cursor:"pointer",background:"none",border:"none",padding:0,fontSize:theme.variables.size.font[size]??"inherit",fontWeight:theme.variables.weight[weight]??"inherit",lineHeight:({xs:theme.variables.size.lineHeight.xl,s:theme.variables.size.lineHeight.l,m:theme.variables.size.lineHeight.xl})[size],fontFamily:theme.variables.fontFamily.lato,textDecorationLine:inline?"underline":"none",color:color?theme.values.color.text[color].default:"inherit",...("primary"===color||"secondary"===color||"tertiary"===color)&&{textDecorationColor:theme.values.color.text.underline.default},"&:hover":{textDecorationLine:"underline",textDecorationThickness:"0.125em",...("primary"===color||"secondary"===color||"tertiary"===color)&&{textDecorationColor:theme.values.color.text.underline.hover,color:theme.values.color.text[color].hover}},..."button"===as&&{whiteSpace:"pre-wrap"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Link/Link.tsx","sources":["src/components/Link/Link.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useContext, type AriaAttributes } from \"react\";\nimport type { CSSObject } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport { TextContext } from \"../Typography/Text/Text\";\nimport type { IconProps } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  TextColors,\n  TextSize,\n  TextWeight,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n  LinkVariations,\n} from \"../../types\";\n\ntype SupplementaryIconProps = Pick<IconProps, \"name\" | \"color\">;\n\nexport type LinkConditionalProps =\n  | {\n      /** It forces to inherit color, weight, size from parent */\n      inline: true;\n      /** A color is inherited from its parent Text otherwise set as 'primary' */\n      color: TextColors;\n      /** Icons are not supported for inline links */\n      iconLeft?: never;\n      /** Icons are not supported for inline links */\n      iconRight?: never;\n    }\n  | {\n      inline?: false | undefined;\n      color?: TextColors;\n      /** Icon displayed on the left side of the link */\n      iconLeft?: SupplementaryIconProps;\n      /** Icon displayed on the right side of the link */\n      iconRight?: SupplementaryIconProps;\n    };\n\nexport type LinkProps = {\n  /** A size is inherited from its parent */\n  size?: TextSize;\n  /** A weight is inherited from its parent */\n  weight?: TextWeight;\n  /** @deprecated variant, please use \"color\" prop instead */\n  variant?: LinkVariations;\n  \"data-e2e-test-id\"?: string;\n} & LinkConditionalProps &\n  AriaAttributes;\n\nexport type LinkComponent = <C extends React.ElementType = \"a\">(\n  props: PolymorphicComponentPropsWithRef<C, LinkProps>\n) => React.ReactNode | null;\n\nconst StyledLink = styled(\"a\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"inline\",\n})<Partial<LinkProps>>(\n  ({ theme, weight, size, color, inline, as }) =>\n    ({\n      cursor: \"pointer\",\n      background: \"none\",\n      border: \"none\",\n      padding: 0,\n      fontSize: theme.variables.size.font[size] ?? \"inherit\",\n      fontWeight: theme.variables.weight[weight] ?? \"inherit\",\n      lineHeight: {\n        xs: theme.variables.size.lineHeight.xl,\n        s: theme.variables.size.lineHeight.l,\n        m: theme.variables.size.lineHeight.xl,\n      }[size],\n      fontFamily: theme.variables.fontFamily.lato,\n\n      textDecorationLine: inline ? \"underline\" : \"none\",\n      color: color ? theme.values.color.text[color].default : \"inherit\",\n\n      ...((color === \"primary\" ||\n        color === \"secondary\" ||\n        color === \"tertiary\") && {\n        textDecorationColor: theme.values.color.text.underline.default,\n      }),\n\n      \"&:hover\": {\n        textDecorationLine: \"underline\",\n        textDecorationThickness: \"0.125em\", // it's not working in Safari for a link as button\n        ...((color === \"primary\" ||\n          color === \"secondary\" ||\n          color === \"tertiary\") && {\n          textDecorationColor: theme.values.color.text.underline.hover,\n          color: theme.values.color.text[color].hover,\n        }),\n      },\n\n      ...(as === \"button\" && {\n        whiteSpace: \"pre-wrap\", // preserve trailing spaces\n      }),\n    } as CSSObject)\n);\n\nconst StyledIcon = styled(Icon)<{ position: \"left\" | \"right\" }>(\n  ({ position, theme }) => ({\n    ...(position === \"left\" && {\n      marginRight: theme.variables.size.spacing.xxs,\n    }),\n    ...(position === \"right\" && {\n      marginLeft: theme.variables.size.spacing.xxs,\n    }),\n  })\n);\n\nexport const Link: LinkComponent = React.forwardRef(\n  <C extends React.ElementType = \"a\">(\n    {\n      weight,\n      color: colorProp,\n      size,\n      variant,\n      inline,\n      iconLeft,\n      iconRight,\n      children,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, LinkProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const inheritPropsFromText = useContext(TextContext);\n\n    const getColor = () => {\n      if (variant) {\n        // this is going to be deleted after migration\n        if (variant === \"primary\") return \"accent\";\n        if (variant === \"secondary\") return \"primary\";\n        return variant;\n      }\n      if (colorProp) return colorProp;\n      if (inheritPropsFromText?.color) return inheritPropsFromText?.color;\n      if (!inline) return \"accent\";\n      return undefined;\n    };\n\n    const linkColor = getColor();\n\n    /* Why do we need inline prop? We inherit size and color from Text (if Link is wrapped in it), but we need to support Links within Headers and other custom components. Thus by default, size and color are not required props */\n    const isInlineLink = inline || !!inheritPropsFromText;\n\n    const hasIcons = !isInlineLink && (iconLeft || iconRight);\n\n    const linkContent = hasIcons ? (\n      <>\n        {iconLeft && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconLeft.name}\n            color={iconLeft.color ?? linkColor}\n            inline\n            position=\"left\"\n          />\n        )}\n        {children}\n        {iconRight && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconRight.name}\n            color={iconRight.color ?? linkColor}\n            inline\n            position=\"right\"\n          />\n        )}\n      </>\n    ) : (\n      children\n    );\n\n    return (\n      <StyledLink\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Link\"\n        ref={ref}\n        inline={isInlineLink}\n        color={linkColor}\n        size={size || inheritPropsFromText?.size}\n        weight={weight || inheritPropsFromText?.weight}\n        {...rest}\n      >\n        {linkContent}\n      </StyledLink>\n    );\n  }\n);\n"],"names":[],"mappings":"AAsDmB"} */"),StyledIcon=(0,_styled.default)(_Icon.Icon,{target:"e1foykt91",label:"StyledIcon"})(({position,theme})=>({..."left"===position&&{marginRight:theme.variables.size.spacing.xxs},..."right"===position&&{marginLeft:theme.variables.size.spacing.xxs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Link/Link.tsx","sources":["src/components/Link/Link.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useContext, type AriaAttributes } from \"react\";\nimport type { CSSObject } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport { TextContext } from \"../Typography/Text/Text\";\nimport type { IconProps } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  TextColors,\n  TextSize,\n  TextWeight,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n  LinkVariations,\n} from \"../../types\";\n\ntype SupplementaryIconProps = Pick<IconProps, \"name\" | \"color\">;\n\nexport type LinkConditionalProps =\n  | {\n      /** It forces to inherit color, weight, size from parent */\n      inline: true;\n      /** A color is inherited from its parent Text otherwise set as 'primary' */\n      color: TextColors;\n      /** Icons are not supported for inline links */\n      iconLeft?: never;\n      /** Icons are not supported for inline links */\n      iconRight?: never;\n    }\n  | {\n      inline?: false | undefined;\n      color?: TextColors;\n      /** Icon displayed on the left side of the link */\n      iconLeft?: SupplementaryIconProps;\n      /** Icon displayed on the right side of the link */\n      iconRight?: SupplementaryIconProps;\n    };\n\nexport type LinkProps = {\n  /** A size is inherited from its parent */\n  size?: TextSize;\n  /** A weight is inherited from its parent */\n  weight?: TextWeight;\n  /** @deprecated variant, please use \"color\" prop instead */\n  variant?: LinkVariations;\n  \"data-e2e-test-id\"?: string;\n} & LinkConditionalProps &\n  AriaAttributes;\n\nexport type LinkComponent = <C extends React.ElementType = \"a\">(\n  props: PolymorphicComponentPropsWithRef<C, LinkProps>\n) => React.ReactNode | null;\n\nconst StyledLink = styled(\"a\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"inline\",\n})<Partial<LinkProps>>(\n  ({ theme, weight, size, color, inline, as }) =>\n    ({\n      cursor: \"pointer\",\n      background: \"none\",\n      border: \"none\",\n      padding: 0,\n      fontSize: theme.variables.size.font[size] ?? \"inherit\",\n      fontWeight: theme.variables.weight[weight] ?? \"inherit\",\n      lineHeight: {\n        xs: theme.variables.size.lineHeight.xl,\n        s: theme.variables.size.lineHeight.l,\n        m: theme.variables.size.lineHeight.xl,\n      }[size],\n      fontFamily: theme.variables.fontFamily.lato,\n\n      textDecorationLine: inline ? \"underline\" : \"none\",\n      color: color ? theme.values.color.text[color].default : \"inherit\",\n\n      ...((color === \"primary\" ||\n        color === \"secondary\" ||\n        color === \"tertiary\") && {\n        textDecorationColor: theme.values.color.text.underline.default,\n      }),\n\n      \"&:hover\": {\n        textDecorationLine: \"underline\",\n        textDecorationThickness: \"0.125em\", // it's not working in Safari for a link as button\n        ...((color === \"primary\" ||\n          color === \"secondary\" ||\n          color === \"tertiary\") && {\n          textDecorationColor: theme.values.color.text.underline.hover,\n          color: theme.values.color.text[color].hover,\n        }),\n      },\n\n      ...(as === \"button\" && {\n        whiteSpace: \"pre-wrap\", // preserve trailing spaces\n      }),\n    } as CSSObject)\n);\n\nconst StyledIcon = styled(Icon)<{ position: \"left\" | \"right\" }>(\n  ({ position, theme }) => ({\n    ...(position === \"left\" && {\n      marginRight: theme.variables.size.spacing.xxs,\n    }),\n    ...(position === \"right\" && {\n      marginLeft: theme.variables.size.spacing.xxs,\n    }),\n  })\n);\n\nexport const Link: LinkComponent = React.forwardRef(\n  <C extends React.ElementType = \"a\">(\n    {\n      weight,\n      color: colorProp,\n      size,\n      variant,\n      inline,\n      iconLeft,\n      iconRight,\n      children,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, LinkProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const inheritPropsFromText = useContext(TextContext);\n\n    const getColor = () => {\n      if (variant) {\n        // this is going to be deleted after migration\n        if (variant === \"primary\") return \"accent\";\n        if (variant === \"secondary\") return \"primary\";\n        return variant;\n      }\n      if (colorProp) return colorProp;\n      if (inheritPropsFromText?.color) return inheritPropsFromText?.color;\n      if (!inline) return \"accent\";\n      return undefined;\n    };\n\n    const linkColor = getColor();\n\n    /* Why do we need inline prop? We inherit size and color from Text (if Link is wrapped in it), but we need to support Links within Headers and other custom components. Thus by default, size and color are not required props */\n    const isInlineLink = inline || !!inheritPropsFromText;\n\n    const hasIcons = !isInlineLink && (iconLeft || iconRight);\n\n    const linkContent = hasIcons ? (\n      <>\n        {iconLeft && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconLeft.name}\n            color={iconLeft.color ?? linkColor}\n            inline\n            position=\"left\"\n          />\n        )}\n        {children}\n        {iconRight && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconRight.name}\n            color={iconRight.color ?? linkColor}\n            inline\n            position=\"right\"\n          />\n        )}\n      </>\n    ) : (\n      children\n    );\n\n    return (\n      <StyledLink\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Link\"\n        ref={ref}\n        inline={isInlineLink}\n        color={linkColor}\n        size={size || inheritPropsFromText?.size}\n        weight={weight || inheritPropsFromText?.weight}\n        {...rest}\n      >\n        {linkContent}\n      </StyledLink>\n    );\n  }\n);\n"],"names":[],"mappings":"AAkGmB"} */"),Link=_react.default.forwardRef(({weight,color:colorProp,size,variant,inline,iconLeft,iconRight,children,"data-e2e-test-id":dataE2eTestId,...rest},ref)=>{let inheritPropsFromText=(0,_react.useContext)(_Text.TextContext),linkColor=variant?"primary"===variant?"accent":"secondary"===variant?"primary":variant:colorProp||(inheritPropsFromText?.color?inheritPropsFromText?.color:inline?void 0:"accent"),isInlineLink=inline||!!inheritPropsFromText,linkContent=!isInlineLink&&(iconLeft||iconRight)?_react.default.createElement(_react.default.Fragment,null,iconLeft&&_react.default.createElement(StyledIcon,{"aria-hidden":!0,size:"s",name:iconLeft.name,color:iconLeft.color??linkColor,inline:!0,position:"left"}),children,iconRight&&_react.default.createElement(StyledIcon,{"aria-hidden":!0,size:"s",name:iconRight.name,color:iconRight.color??linkColor,inline:!0,position:"right"})):children;return _react.default.createElement(StyledLink,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Link",ref:ref,inline:isInlineLink,color:linkColor,size:size||inheritPropsFromText?.size,weight:weight||inheritPropsFromText?.weight,...rest},linkContent)});
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Link",{enumerable:!0,get:function(){return Link}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_Text=require("../Typography/Text/Text"),_Icon=require("../Icon/Icon"),StyledLink=(0,_styled.default)("a",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"inline"!==prop,target:"e17cerj70",label:"StyledLink"})(({theme,weight,size,color,inline})=>({cursor:"pointer",background:"none",border:"none",padding:0,fontSize:theme.variables.size.font[size]??"inherit",fontWeight:theme.variables.weight[weight]??"inherit",lineHeight:({xs:theme.variables.size.lineHeight.xl,s:theme.variables.size.lineHeight.l,m:theme.variables.size.lineHeight.xl})[size],fontFamily:theme.variables.fontFamily.lato,textDecorationLine:inline?"underline":"none",color:color?theme.values.color.text[color].default:"inherit",...("primary"===color||"secondary"===color||"tertiary"===color)&&{textDecorationColor:theme.values.color.text.underline.default},"&:hover":{textDecorationLine:"underline",textDecorationThickness:"0.125em",...("primary"===color||"secondary"===color||"tertiary"===color)&&{textDecorationColor:theme.values.color.text.underline.hover,color:theme.values.color.text[color].hover}}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Link/Link.tsx","sources":["src/components/Link/Link.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useContext, type AriaAttributes } from \"react\";\nimport type { CSSObject } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport { TextContext } from \"../Typography/Text/Text\";\nimport type { IconProps } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  TextColors,\n  TextSize,\n  TextWeight,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n  LinkVariations,\n} from \"../../types\";\n\ntype SupplementaryIconProps = Pick<IconProps, \"name\" | \"color\">;\n\nexport type LinkConditionalProps =\n  | {\n      /** It forces to inherit color, weight, size from parent */\n      inline: true;\n      /** A color is inherited from its parent Text otherwise set as 'primary' */\n      color: TextColors;\n      /** Icons are not supported for inline links */\n      iconLeft?: never;\n      /** Icons are not supported for inline links */\n      iconRight?: never;\n    }\n  | {\n      inline?: false | undefined;\n      color?: TextColors;\n      /** Icon displayed on the left side of the link */\n      iconLeft?: SupplementaryIconProps;\n      /** Icon displayed on the right side of the link */\n      iconRight?: SupplementaryIconProps;\n    };\n\nexport type LinkProps = {\n  /** A size is inherited from its parent */\n  size?: TextSize;\n  /** A weight is inherited from its parent */\n  weight?: TextWeight;\n  /** @deprecated variant, please use \"color\" prop instead */\n  variant?: LinkVariations;\n  \"data-e2e-test-id\"?: string;\n} & LinkConditionalProps &\n  AriaAttributes;\n\nexport type LinkComponent = <C extends React.ElementType = \"a\">(\n  props: PolymorphicComponentPropsWithRef<C, LinkProps>\n) => React.ReactNode | null;\n\nconst StyledLink = styled(\"a\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"inline\",\n})<Partial<LinkProps>>(\n  ({ theme, weight, size, color, inline }) =>\n    ({\n      cursor: \"pointer\",\n      background: \"none\",\n      border: \"none\",\n      padding: 0,\n      fontSize: theme.variables.size.font[size] ?? \"inherit\",\n      fontWeight: theme.variables.weight[weight] ?? \"inherit\",\n      lineHeight: {\n        xs: theme.variables.size.lineHeight.xl,\n        s: theme.variables.size.lineHeight.l,\n        m: theme.variables.size.lineHeight.xl,\n      }[size],\n      fontFamily: theme.variables.fontFamily.lato,\n\n      textDecorationLine: inline ? \"underline\" : \"none\",\n      color: color ? theme.values.color.text[color].default : \"inherit\",\n\n      ...((color === \"primary\" ||\n        color === \"secondary\" ||\n        color === \"tertiary\") && {\n        textDecorationColor: theme.values.color.text.underline.default,\n      }),\n\n      \"&:hover\": {\n        textDecorationLine: \"underline\",\n        textDecorationThickness: \"0.125em\", // it's not working in Safari for a link as button\n        ...((color === \"primary\" ||\n          color === \"secondary\" ||\n          color === \"tertiary\") && {\n          textDecorationColor: theme.values.color.text.underline.hover,\n          color: theme.values.color.text[color].hover,\n        }),\n      },\n    } as CSSObject)\n);\n\nconst StyledIcon = styled(Icon)<{ position: \"left\" | \"right\" }>(\n  ({ position, theme }) => ({\n    ...(position === \"left\" && {\n      marginRight: theme.variables.size.spacing.xxs,\n    }),\n    ...(position === \"right\" && {\n      marginLeft: theme.variables.size.spacing.xxs,\n    }),\n  })\n);\n\nexport const Link: LinkComponent = React.forwardRef(\n  <C extends React.ElementType = \"a\">(\n    {\n      weight,\n      color: colorProp,\n      size,\n      variant,\n      inline,\n      iconLeft,\n      iconRight,\n      children,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, LinkProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const inheritPropsFromText = useContext(TextContext);\n\n    const getColor = () => {\n      if (variant) {\n        // this is going to be deleted after migration\n        if (variant === \"primary\") return \"accent\";\n        if (variant === \"secondary\") return \"primary\";\n        return variant;\n      }\n      if (colorProp) return colorProp;\n      if (inheritPropsFromText?.color) return inheritPropsFromText?.color;\n      if (!inline) return \"accent\";\n      return undefined;\n    };\n\n    const linkColor = getColor();\n\n    /* Why do we need inline prop? We inherit size and color from Text (if Link is wrapped in it), but we need to support Links within Headers and other custom components. Thus by default, size and color are not required props */\n    const isInlineLink = inline || !!inheritPropsFromText;\n\n    const hasIcons = !isInlineLink && (iconLeft || iconRight);\n\n    const linkContent = hasIcons ? (\n      <>\n        {iconLeft && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconLeft.name}\n            color={iconLeft.color ?? linkColor}\n            inline\n            position=\"left\"\n          />\n        )}\n        {children}\n        {iconRight && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconRight.name}\n            color={iconRight.color ?? linkColor}\n            inline\n            position=\"right\"\n          />\n        )}\n      </>\n    ) : (\n      children\n    );\n\n    return (\n      <StyledLink\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Link\"\n        ref={ref}\n        inline={isInlineLink}\n        color={linkColor}\n        size={size || inheritPropsFromText?.size}\n        weight={weight || inheritPropsFromText?.weight}\n        {...rest}\n      >\n        {linkContent}\n      </StyledLink>\n    );\n  }\n);\n"],"names":[],"mappings":"AAsDmB"} */"),StyledIcon=(0,_styled.default)(_Icon.Icon,{target:"e17cerj71",label:"StyledIcon"})(({position,theme})=>({..."left"===position&&{marginRight:theme.variables.size.spacing.xxs},..."right"===position&&{marginLeft:theme.variables.size.spacing.xxs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Link/Link.tsx","sources":["src/components/Link/Link.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useContext, type AriaAttributes } from \"react\";\nimport type { CSSObject } from \"@emotion/react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport { TextContext } from \"../Typography/Text/Text\";\nimport type { IconProps } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  TextColors,\n  TextSize,\n  TextWeight,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n  LinkVariations,\n} from \"../../types\";\n\ntype SupplementaryIconProps = Pick<IconProps, \"name\" | \"color\">;\n\nexport type LinkConditionalProps =\n  | {\n      /** It forces to inherit color, weight, size from parent */\n      inline: true;\n      /** A color is inherited from its parent Text otherwise set as 'primary' */\n      color: TextColors;\n      /** Icons are not supported for inline links */\n      iconLeft?: never;\n      /** Icons are not supported for inline links */\n      iconRight?: never;\n    }\n  | {\n      inline?: false | undefined;\n      color?: TextColors;\n      /** Icon displayed on the left side of the link */\n      iconLeft?: SupplementaryIconProps;\n      /** Icon displayed on the right side of the link */\n      iconRight?: SupplementaryIconProps;\n    };\n\nexport type LinkProps = {\n  /** A size is inherited from its parent */\n  size?: TextSize;\n  /** A weight is inherited from its parent */\n  weight?: TextWeight;\n  /** @deprecated variant, please use \"color\" prop instead */\n  variant?: LinkVariations;\n  \"data-e2e-test-id\"?: string;\n} & LinkConditionalProps &\n  AriaAttributes;\n\nexport type LinkComponent = <C extends React.ElementType = \"a\">(\n  props: PolymorphicComponentPropsWithRef<C, LinkProps>\n) => React.ReactNode | null;\n\nconst StyledLink = styled(\"a\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"inline\",\n})<Partial<LinkProps>>(\n  ({ theme, weight, size, color, inline }) =>\n    ({\n      cursor: \"pointer\",\n      background: \"none\",\n      border: \"none\",\n      padding: 0,\n      fontSize: theme.variables.size.font[size] ?? \"inherit\",\n      fontWeight: theme.variables.weight[weight] ?? \"inherit\",\n      lineHeight: {\n        xs: theme.variables.size.lineHeight.xl,\n        s: theme.variables.size.lineHeight.l,\n        m: theme.variables.size.lineHeight.xl,\n      }[size],\n      fontFamily: theme.variables.fontFamily.lato,\n\n      textDecorationLine: inline ? \"underline\" : \"none\",\n      color: color ? theme.values.color.text[color].default : \"inherit\",\n\n      ...((color === \"primary\" ||\n        color === \"secondary\" ||\n        color === \"tertiary\") && {\n        textDecorationColor: theme.values.color.text.underline.default,\n      }),\n\n      \"&:hover\": {\n        textDecorationLine: \"underline\",\n        textDecorationThickness: \"0.125em\", // it's not working in Safari for a link as button\n        ...((color === \"primary\" ||\n          color === \"secondary\" ||\n          color === \"tertiary\") && {\n          textDecorationColor: theme.values.color.text.underline.hover,\n          color: theme.values.color.text[color].hover,\n        }),\n      },\n    } as CSSObject)\n);\n\nconst StyledIcon = styled(Icon)<{ position: \"left\" | \"right\" }>(\n  ({ position, theme }) => ({\n    ...(position === \"left\" && {\n      marginRight: theme.variables.size.spacing.xxs,\n    }),\n    ...(position === \"right\" && {\n      marginLeft: theme.variables.size.spacing.xxs,\n    }),\n  })\n);\n\nexport const Link: LinkComponent = React.forwardRef(\n  <C extends React.ElementType = \"a\">(\n    {\n      weight,\n      color: colorProp,\n      size,\n      variant,\n      inline,\n      iconLeft,\n      iconRight,\n      children,\n      \"data-e2e-test-id\": dataE2eTestId,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, LinkProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const inheritPropsFromText = useContext(TextContext);\n\n    const getColor = () => {\n      if (variant) {\n        // this is going to be deleted after migration\n        if (variant === \"primary\") return \"accent\";\n        if (variant === \"secondary\") return \"primary\";\n        return variant;\n      }\n      if (colorProp) return colorProp;\n      if (inheritPropsFromText?.color) return inheritPropsFromText?.color;\n      if (!inline) return \"accent\";\n      return undefined;\n    };\n\n    const linkColor = getColor();\n\n    /* Why do we need inline prop? We inherit size and color from Text (if Link is wrapped in it), but we need to support Links within Headers and other custom components. Thus by default, size and color are not required props */\n    const isInlineLink = inline || !!inheritPropsFromText;\n\n    const hasIcons = !isInlineLink && (iconLeft || iconRight);\n\n    const linkContent = hasIcons ? (\n      <>\n        {iconLeft && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconLeft.name}\n            color={iconLeft.color ?? linkColor}\n            inline\n            position=\"left\"\n          />\n        )}\n        {children}\n        {iconRight && (\n          <StyledIcon\n            aria-hidden\n            size=\"s\"\n            name={iconRight.name}\n            color={iconRight.color ?? linkColor}\n            inline\n            position=\"right\"\n          />\n        )}\n      </>\n    ) : (\n      children\n    );\n\n    return (\n      <StyledLink\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Link\"\n        ref={ref}\n        inline={isInlineLink}\n        color={linkColor}\n        size={size || inheritPropsFromText?.size}\n        weight={weight || inheritPropsFromText?.weight}\n        {...rest}\n      >\n        {linkContent}\n      </StyledLink>\n    );\n  }\n);\n"],"names":[],"mappings":"AA8FmB"} */"),Link=_react.default.forwardRef(({weight,color:colorProp,size,variant,inline,iconLeft,iconRight,children,"data-e2e-test-id":dataE2eTestId,...rest},ref)=>{let inheritPropsFromText=(0,_react.useContext)(_Text.TextContext),linkColor=variant?"primary"===variant?"accent":"secondary"===variant?"primary":variant:colorProp||(inheritPropsFromText?.color?inheritPropsFromText?.color:inline?void 0:"accent"),isInlineLink=inline||!!inheritPropsFromText,linkContent=!isInlineLink&&(iconLeft||iconRight)?_react.default.createElement(_react.default.Fragment,null,iconLeft&&_react.default.createElement(StyledIcon,{"aria-hidden":!0,size:"s",name:iconLeft.name,color:iconLeft.color??linkColor,inline:!0,position:"left"}),children,iconRight&&_react.default.createElement(StyledIcon,{"aria-hidden":!0,size:"s",name:iconRight.name,color:iconRight.color??linkColor,inline:!0,position:"right"})):children;return _react.default.createElement(StyledLink,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Link",ref:ref,inline:isInlineLink,color:linkColor,size:size||inheritPropsFromText?.size,weight:weight||inheritPropsFromText?.weight,...rest},linkContent)});
@@ -103,4 +103,5 @@ export * from "./components/Content/ContentPictogramButton/ContentPictogramButto
103
103
  export * from "./components/Content/ContentText/ContentText";
104
104
  export * from "./components/Content/ContentList";
105
105
  export * from "./components/Content/ContentTable";
106
+ export * from "./components/Content/DosageButton";
106
107
  export * from "./components/Content/ReferenceButton";
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get CacheProvider(){return _react.CacheProvider},get ThemeProvider(){return _react.ThemeProvider},get createCache(){return _cache.default},get dark(){return dark},get light(){return light}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _export_star=require("@swc/helpers/_/_export_star"),_interop_require_default=require("@swc/helpers/_/_interop_require_default"),_visualConfig=require("./web-tokens/visualConfig"),_react=require("@emotion/react"),_cache=/*#__PURE__*/_interop_require_default._(require("@emotion/cache"));_export_star._(require("./components/AccessCardItem/AccessCardItem"),exports),_export_star._(require("./components/Avatar/Avatar"),exports),_export_star._(require("./components/AvatarGroup/AvatarGroup"),exports),_export_star._(require("./components/Badge/Badge"),exports),_export_star._(require("./components/BinaryFeedback/BinaryFeedback"),exports),_export_star._(require("./components/Box/Box"),exports),_export_star._(require("./components/BulkActionsToolbar/BulkActionsToolbar"),exports),_export_star._(require("./components/Button/Button"),exports),_export_star._(require("./components/Callout/Callout"),exports),_export_star._(require("./components/Card/Card"),exports),_export_star._(require("./components/Card/CardBox"),exports),_export_star._(require("./components/CatalogCard/CatalogCard"),exports),_export_star._(require("./components/CheckboxCard/CheckboxCard"),exports),_export_star._(require("./components/Collapsible/Collapsible"),exports),_export_star._(require("./components/ColorIndicator/ColorIndicator"),exports),_export_star._(require("./components/ColorPicker/ColorPicker"),exports),_export_star._(require("./components/Column/Columns"),exports),_export_star._(require("./components/Container"),exports),_export_star._(require("./components/CountButton/CountButton"),exports),_export_star._(require("./components/DataTable"),exports),_export_star._(require("./components/Divider/Divider"),exports),_export_star._(require("./components/DropdownMenu/DropdownMenu"),exports),_export_star._(require("./components/EntityList"),exports),_export_star._(require("./components/EntityTree"),exports),_export_star._(require("./components/Composite/FilterDialog/FilterDialog"),exports),_export_star._(require("./components/Form/Checkbox/Checkbox"),exports),_export_star._(require("./components/Form/Combobox/Combobox"),exports),_export_star._(require("./components/Form/DateInput/DateInput"),exports),_export_star._(require("./components/Form/DatePicker"),exports),_export_star._(require("./components/Form/FormFieldGroup/FormFieldGroup"),exports),_export_star._(require("./components/Form/Input"),exports),_export_star._(require("./components/Form/MaskedInput/MaskedInput"),exports),_export_star._(require("./components/Form/PasswordInput"),exports),_export_star._(require("./components/Form/Radio/Radio"),exports),_export_star._(require("./components/Form/RadioButton/RadioButton"),exports),_export_star._(require("./components/Form/RangeInput/RangeInput"),exports),_export_star._(require("./components/Form/SearchInput/SearchInput"),exports),_export_star._(require("./components/Form/SegmentedControl/SegmentedControl"),exports),_export_star._(require("./components/Form/Select"),exports),_export_star._(require("./components/Form/Textarea/Textarea"),exports),_export_star._(require("./components/Form/Toggle/Toggle"),exports),_export_star._(require("./components/Form/ToggleButton/ToggleButton"),exports),_export_star._(require("./components/Grid/Grid"),exports),_export_star._(require("./components/Icon/Icon"),exports),_export_star._(require("./components/IconTile/IconTile"),exports),_export_star._(require("./components/Image/Image"),exports),_export_star._(require("./components/Inline/Inline"),exports),_export_star._(require("./components/InteractiveBox/InteractiveBox"),exports),_export_star._(require("./components/Lightbox/Lightbox"),exports),_export_star._(require("./components/Link/Link"),exports),_export_star._(require("./components/LoadingSpinner/LoadingSpinner"),exports),_export_star._(require("./components/Logo/Logo"),exports),_export_star._(require("./components/MediaItem"),exports),_export_star._(require("./components/MediaViewerBar/MediaViewerBar"),exports),_export_star._(require("./components/MediaViewerCarousel/MediaViewerCarousel"),exports),_export_star._(require("./components/NavBar"),exports),_export_star._(require("./components/Notification/Notification"),exports),_export_star._(require("./components/Pagination/Pagination"),exports),_export_star._(require("./components/Patterns/ButtonGroup/ButtonGroup"),exports),_export_star._(require("./components/Patterns/Modal/Modal"),exports),_export_star._(require("./components/PictogramButton/PictogramButton"),exports),_export_star._(require("./components/Popover/Popover"),exports),_export_star._(require("./components/ProgressBar/ProgressBar"),exports),_export_star._(require("./components/PromptInput/PromptInput"),exports),_export_star._(require("./components/SplashCard/SplashCard"),exports),_export_star._(require("./components/SplashCardMedia/SplashCardMedia"),exports),_export_star._(require("./components/QBankRichText/QBankRichText"),exports),_export_star._(require("./components/RadioCard/RadioCard"),exports),_export_star._(require("./components/RoundButton/RoundButton"),exports),_export_star._(require("./components/SearchResult/SearchResult"),exports),_export_star._(require("./components/SegmentedProgressBar/SegmentedProgressBar"),exports),_export_star._(require("./components/Sheet/Sheet"),exports),_export_star._(require("./components/Stack/Stack"),exports),_export_star._(require("./components/SubThemeProvider/SubThemeProvider"),exports),_export_star._(require("./components/Tabs/Tabs"),exports),_export_star._(require("./components/Tag/Tag"),exports),_export_star._(require("./components/TagGroup/TagGroup"),exports),_export_star._(require("./components/Toast"),exports),_export_star._(require("./components/Toggletip/Toggletip"),exports),_export_star._(require("./components/Tooltip/Tooltip"),exports),_export_star._(require("./components/Tutorialtip/Tutorialtip"),exports),_export_star._(require("./components/Typography/Header"),exports),_export_star._(require("./components/Typography/StyledText/StyledText"),exports),_export_star._(require("./components/Typography/Text"),exports),_export_star._(require("./components/Typography/TextClamped/TextClamped"),exports),_export_star._(require("./components/UserHighlightTooltip/UserHighlightTooltip"),exports),_export_star._(require("./components/Utilities/AnimatedBorder/AnimatedBorder"),exports),_export_star._(require("./components/Utilities/ContainerQuery/ContainerQuery"),exports),_export_star._(require("./components/Utilities/Expandable/Expandable"),exports),_export_star._(require("./components/Utilities/ScreenReaderText/ScreenReaderText"),exports),_export_star._(require("./components/Patterns/EmptyState/EmptyState"),exports),_export_star._(require("./components/Content/ContentBox/ContentBox"),exports),_export_star._(require("./components/Content/ContentFontResizer"),exports),_export_star._(require("./components/Content/ContentHeading/ContentHeading"),exports),_export_star._(require("./components/Content/ContentLink/ContentLink"),exports),_export_star._(require("./components/Content/ContentPictogramButton/ContentPictogramButton"),exports),_export_star._(require("./components/Content/ContentText/ContentText"),exports),_export_star._(require("./components/Content/ContentList"),exports),_export_star._(require("./components/Content/ContentTable"),exports),_export_star._(require("./components/Content/ReferenceButton"),exports);const{dark,light}=_visualConfig.ambossVisualConfiguration;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get CacheProvider(){return _react.CacheProvider},get ThemeProvider(){return _react.ThemeProvider},get createCache(){return _cache.default},get dark(){return dark},get light(){return light}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _export_star=require("@swc/helpers/_/_export_star"),_interop_require_default=require("@swc/helpers/_/_interop_require_default"),_visualConfig=require("./web-tokens/visualConfig"),_react=require("@emotion/react"),_cache=/*#__PURE__*/_interop_require_default._(require("@emotion/cache"));_export_star._(require("./components/AccessCardItem/AccessCardItem"),exports),_export_star._(require("./components/Avatar/Avatar"),exports),_export_star._(require("./components/AvatarGroup/AvatarGroup"),exports),_export_star._(require("./components/Badge/Badge"),exports),_export_star._(require("./components/BinaryFeedback/BinaryFeedback"),exports),_export_star._(require("./components/Box/Box"),exports),_export_star._(require("./components/BulkActionsToolbar/BulkActionsToolbar"),exports),_export_star._(require("./components/Button/Button"),exports),_export_star._(require("./components/Callout/Callout"),exports),_export_star._(require("./components/Card/Card"),exports),_export_star._(require("./components/Card/CardBox"),exports),_export_star._(require("./components/CatalogCard/CatalogCard"),exports),_export_star._(require("./components/CheckboxCard/CheckboxCard"),exports),_export_star._(require("./components/Collapsible/Collapsible"),exports),_export_star._(require("./components/ColorIndicator/ColorIndicator"),exports),_export_star._(require("./components/ColorPicker/ColorPicker"),exports),_export_star._(require("./components/Column/Columns"),exports),_export_star._(require("./components/Container"),exports),_export_star._(require("./components/CountButton/CountButton"),exports),_export_star._(require("./components/DataTable"),exports),_export_star._(require("./components/Divider/Divider"),exports),_export_star._(require("./components/DropdownMenu/DropdownMenu"),exports),_export_star._(require("./components/EntityList"),exports),_export_star._(require("./components/EntityTree"),exports),_export_star._(require("./components/Composite/FilterDialog/FilterDialog"),exports),_export_star._(require("./components/Form/Checkbox/Checkbox"),exports),_export_star._(require("./components/Form/Combobox/Combobox"),exports),_export_star._(require("./components/Form/DateInput/DateInput"),exports),_export_star._(require("./components/Form/DatePicker"),exports),_export_star._(require("./components/Form/FormFieldGroup/FormFieldGroup"),exports),_export_star._(require("./components/Form/Input"),exports),_export_star._(require("./components/Form/MaskedInput/MaskedInput"),exports),_export_star._(require("./components/Form/PasswordInput"),exports),_export_star._(require("./components/Form/Radio/Radio"),exports),_export_star._(require("./components/Form/RadioButton/RadioButton"),exports),_export_star._(require("./components/Form/RangeInput/RangeInput"),exports),_export_star._(require("./components/Form/SearchInput/SearchInput"),exports),_export_star._(require("./components/Form/SegmentedControl/SegmentedControl"),exports),_export_star._(require("./components/Form/Select"),exports),_export_star._(require("./components/Form/Textarea/Textarea"),exports),_export_star._(require("./components/Form/Toggle/Toggle"),exports),_export_star._(require("./components/Form/ToggleButton/ToggleButton"),exports),_export_star._(require("./components/Grid/Grid"),exports),_export_star._(require("./components/Icon/Icon"),exports),_export_star._(require("./components/IconTile/IconTile"),exports),_export_star._(require("./components/Image/Image"),exports),_export_star._(require("./components/Inline/Inline"),exports),_export_star._(require("./components/InteractiveBox/InteractiveBox"),exports),_export_star._(require("./components/Lightbox/Lightbox"),exports),_export_star._(require("./components/Link/Link"),exports),_export_star._(require("./components/LoadingSpinner/LoadingSpinner"),exports),_export_star._(require("./components/Logo/Logo"),exports),_export_star._(require("./components/MediaItem"),exports),_export_star._(require("./components/MediaViewerBar/MediaViewerBar"),exports),_export_star._(require("./components/MediaViewerCarousel/MediaViewerCarousel"),exports),_export_star._(require("./components/NavBar"),exports),_export_star._(require("./components/Notification/Notification"),exports),_export_star._(require("./components/Pagination/Pagination"),exports),_export_star._(require("./components/Patterns/ButtonGroup/ButtonGroup"),exports),_export_star._(require("./components/Patterns/Modal/Modal"),exports),_export_star._(require("./components/PictogramButton/PictogramButton"),exports),_export_star._(require("./components/Popover/Popover"),exports),_export_star._(require("./components/ProgressBar/ProgressBar"),exports),_export_star._(require("./components/PromptInput/PromptInput"),exports),_export_star._(require("./components/SplashCard/SplashCard"),exports),_export_star._(require("./components/SplashCardMedia/SplashCardMedia"),exports),_export_star._(require("./components/QBankRichText/QBankRichText"),exports),_export_star._(require("./components/RadioCard/RadioCard"),exports),_export_star._(require("./components/RoundButton/RoundButton"),exports),_export_star._(require("./components/SearchResult/SearchResult"),exports),_export_star._(require("./components/SegmentedProgressBar/SegmentedProgressBar"),exports),_export_star._(require("./components/Sheet/Sheet"),exports),_export_star._(require("./components/Stack/Stack"),exports),_export_star._(require("./components/SubThemeProvider/SubThemeProvider"),exports),_export_star._(require("./components/Tabs/Tabs"),exports),_export_star._(require("./components/Tag/Tag"),exports),_export_star._(require("./components/TagGroup/TagGroup"),exports),_export_star._(require("./components/Toast"),exports),_export_star._(require("./components/Toggletip/Toggletip"),exports),_export_star._(require("./components/Tooltip/Tooltip"),exports),_export_star._(require("./components/Tutorialtip/Tutorialtip"),exports),_export_star._(require("./components/Typography/Header"),exports),_export_star._(require("./components/Typography/StyledText/StyledText"),exports),_export_star._(require("./components/Typography/Text"),exports),_export_star._(require("./components/Typography/TextClamped/TextClamped"),exports),_export_star._(require("./components/UserHighlightTooltip/UserHighlightTooltip"),exports),_export_star._(require("./components/Utilities/AnimatedBorder/AnimatedBorder"),exports),_export_star._(require("./components/Utilities/ContainerQuery/ContainerQuery"),exports),_export_star._(require("./components/Utilities/Expandable/Expandable"),exports),_export_star._(require("./components/Utilities/ScreenReaderText/ScreenReaderText"),exports),_export_star._(require("./components/Patterns/EmptyState/EmptyState"),exports),_export_star._(require("./components/Content/ContentBox/ContentBox"),exports),_export_star._(require("./components/Content/ContentFontResizer"),exports),_export_star._(require("./components/Content/ContentHeading/ContentHeading"),exports),_export_star._(require("./components/Content/ContentLink/ContentLink"),exports),_export_star._(require("./components/Content/ContentPictogramButton/ContentPictogramButton"),exports),_export_star._(require("./components/Content/ContentText/ContentText"),exports),_export_star._(require("./components/Content/ContentList"),exports),_export_star._(require("./components/Content/ContentTable"),exports),_export_star._(require("./components/Content/DosageButton"),exports),_export_star._(require("./components/Content/ReferenceButton"),exports);const{dark,light}=_visualConfig.ambossVisualConfiguration;
@@ -2010,6 +2010,22 @@
2010
2010
  "lightValue": "#a3b2bd",
2011
2011
  "lightOriginalValue": "gray.light01"
2012
2012
  },
2013
+ "color-content-dosage-button-background": {
2014
+ "name": "content.dosage-button",
2015
+ "subState": "background",
2016
+ "darkValue": "#6d37c8",
2017
+ "darkOriginalValue": "night-purple.regular",
2018
+ "lightValue": "#ddd7fd",
2019
+ "lightOriginalValue": "purple.light02"
2020
+ },
2021
+ "color-content-dosage-button-text": {
2022
+ "name": "content.dosage-button",
2023
+ "subState": "text",
2024
+ "darkValue": "#ffffff",
2025
+ "darkOriginalValue": "neutral.white",
2026
+ "lightValue": "#6934c4",
2027
+ "lightOriginalValue": "purple.dark01"
2028
+ },
2013
2029
  "color-content-table-row": {
2014
2030
  "name": "content.table",
2015
2031
  "subState": "row",
@@ -766,6 +766,16 @@ export type AmbossTheme = {
766
766
  "active": string;
767
767
  };
768
768
  };
769
+ "dosageButton": {
770
+ "background": {
771
+ "default": string;
772
+ "hover": string;
773
+ };
774
+ "text": {
775
+ "default": string;
776
+ "hover": string;
777
+ };
778
+ };
769
779
  "table": {
770
780
  "row": {
771
781
  "hover": string;