@amboss/design-system 3.40.0 → 3.40.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cjs/components/CatalogCard/CatalogCard.d.ts +6 -1
- package/build/cjs/components/CatalogCard/CatalogCard.js +1 -1
- package/build/cjs/components/Lightbox/Lightbox.js +2 -2
- package/build/esm/components/CatalogCard/CatalogCard.d.ts +6 -1
- package/build/esm/components/CatalogCard/CatalogCard.js +1 -1
- package/build/esm/components/Lightbox/Lightbox.js +2 -2
- 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,8 +1,8 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get Lightbox(){return Lightbox},get StyledBackdrop(){return StyledBackdrop},get StyledChildrenWrapper(){return StyledChildrenWrapper}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_react1=require("@emotion/react"),_Portal=require("../Portal/Portal"),_FocusTrapWrapper=require("../../shared/FocusTrapWrapper"),_mediaQueries=require("../../shared/mediaQueries"),_DialogContext=require("../Patterns/Dialog/DialogContext"),StyledBackdrop=(0,_styled.default)("div",{target:"
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get Lightbox(){return Lightbox},get StyledBackdrop(){return StyledBackdrop},get StyledChildrenWrapper(){return StyledChildrenWrapper}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_react1=require("@emotion/react"),_Portal=require("../Portal/Portal"),_FocusTrapWrapper=require("../../shared/FocusTrapWrapper"),_mediaQueries=require("../../shared/mediaQueries"),_DialogContext=require("../Patterns/Dialog/DialogContext"),StyledBackdrop=(0,_styled.default)("div",{target:"ew3tr1y0",label:"StyledBackdrop"})(({theme,justifyContent})=>{let fadeInBackdrop=(0,_react1.keyframes)`
|
|
2
2
|
from {
|
|
3
3
|
opacity: ${theme.variables.opacity.hidden};
|
|
4
4
|
}
|
|
5
5
|
to {
|
|
6
6
|
opacity: ${theme.variables.opacity.visible};
|
|
7
7
|
}
|
|
8
|
-
`;return{position:"fixed",top:0,left:0,zIndex:theme.variables.zIndex.modal,width:"100%",height:"100dvh",background:theme.values.color.background.backdrop.default,display:"flex",flexDirection:"column",...(0,_mediaQueries.useResponsiveStyles)({justifyContent:[justifyContent,{top:"flex-start",center:"center"}]}),alignItems:"center",flex:"1 0 auto",animation:`${fadeInBackdrop} ${theme.variables.animation.modalBackdrop.open.duration} ${theme.variables.animation.modalBackdrop.open.timingFunction} both`}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTGlnaHRib3gvTGlnaHRib3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9MaWdodGJveC9MaWdodGJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIHVzZUNhbGxiYWNrLFxuICB1c2VSZWYsXG4gIHR5cGUgUHJvcHNXaXRoQ2hpbGRyZW4sXG4gIHR5cGUgUmVmT2JqZWN0LFxufSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQsIE1RIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB1c2VQb3J0YWxDb250YWluZXJFbGVtZW50LFxuICB0eXBlIFBvcnRhbFByb3BzLFxufSBmcm9tIFwiLi4vUG9ydGFsL1BvcnRhbFwiO1xuaW1wb3J0IHsgRm9jdXNUcmFwV3JhcHBlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvRm9jdXNUcmFwV3JhcHBlclwiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBEaWFsb2dDb250ZXh0IH0gZnJvbSBcIi4uL1BhdHRlcm5zL0RpYWxvZy9EaWFsb2dDb250ZXh0XCI7XG5cbmV4cG9ydCB0eXBlIExpZ2h0Ym94UHJvcHMgPSBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4gJiB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG4gIGJhY2tkcm9wUmVmPzogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgaGFuZGxlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBpc0Rpc21pc3NpYmxlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEEgcmVmIHRvIHRoZSBlbGVtZW50IHRoYXQgc2hvdWxkIHJlY2VpdmUgZm9jdXMgd2hlbiB0aGUgbGlnaHRib3ggb3BlbnMuXG4gICAqIFdoZW4gbm90IHByb3ZpZGVkLCB0aGUgZmlyc3QgZm9jdXNhYmxlIGVsZW1lbnQgaW5zaWRlIHRoZSBsaWdodGJveCBpcyB1c2VkLlxuICAgKi9cbiAgaW5pdGlhbEZvY3VzPzogUmVmT2JqZWN0PEhUTUxFbGVtZW50IHwgU1ZHRWxlbWVudD4gfCBzdHJpbmc7XG4gIGp1c3RpZnlDb250ZW50PzogTVE8TGlnaHRib3hWZXJ0aWNhbEFsaWdubWVudD4gfCBMaWdodGJveFZlcnRpY2FsQWxpZ25tZW50O1xuICBwcml2YXRlUHJvcHM/OiB7XG4gICAgc2tpcFBvcnRhbD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQGludGVybmFsXG4gICAgICogT3B0aW9ucyBwYXNzZWQgdG8gZm9jdXMtdHJhcCdzIHRhYmJhYmxlIGRldGVjdGlvbi5cbiAgICAgKiBVc2UgYHsgZGlzcGxheUNoZWNrOiBcIm5vbmVcIiB9YCBmb3IgdGVzdGluZyB0byBhdm9pZCBKU0RPTSB2aXNpYmlsaXR5IGlzc3Vlcy5cbiAgICAgKi9cbiAgICB0YWJiYWJsZU9wdGlvbnM/OiB7XG4gICAgICBkaXNwbGF5Q2hlY2s/OiBcImZ1bGxcIiB8IFwibGVnYWN5LWZ1bGxcIiB8IFwibm9uLXplcm8tYXJlYVwiIHwgXCJub25lXCI7XG4gICAgfTtcbiAgfTtcbn0gJiBQaWNrPFBvcnRhbFByb3BzLCBcInBvcnRhbENvbnRhaW5lclwiPjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEJhY2tkcm9wID0gc3R5bGVkLmRpdjxQaWNrPExpZ2h0Ym94UHJvcHMsIFwianVzdGlmeUNvbnRlbnRcIj4+KFxuICAoeyB0aGVtZSwganVzdGlmeUNvbnRlbnQgfSkgPT4ge1xuICAgIGNvbnN0IGZhZGVJbkJhY2tkcm9wID0ga2V5ZnJhbWVzYFxuICAgIGZyb20ge1xuICAgICAgb3BhY2l0eTogJHt0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW59O1xuICAgIH1cbiAgICB0byB7XG4gICAgICBvcGFjaXR5OiAke3RoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LnZpc2libGV9O1xuICAgIH1cbiAgYDtcblxuICAgIHJldHVybiB7XG4gICAgICBwb3NpdGlvbjogXCJmaXhlZFwiLFxuICAgICAgdG9wOiAwLFxuICAgICAgbGVmdDogMCxcbiAgICAgIHpJbmRleDogdGhlbWUudmFyaWFibGVzLnpJbmRleC5tb2RhbCxcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGhlaWdodDogXCIxMDBkdmhcIixcbiAgICAgIGJhY2tncm91bmQ6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmJhY2tkcm9wLmRlZmF1bHQsXG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gICAgICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICAgICAganVzdGlmeUNvbnRlbnQ6IFtcbiAgICAgICAgICBqdXN0aWZ5Q29udGVudCxcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0b3A6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIH0sXG4gICAgICAgIF0sXG4gICAgICB9KSxcbiAgICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgICBmbGV4OiBcIjEgMCBhdXRvXCIsXG4gICAgICBhbmltYXRpb246IGAke2ZhZGVJbkJhY2tkcm9wfSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLmR1cmF0aW9ufSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLnRpbWluZ0Z1bmN0aW9ufSBib3RoYCxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ2hpbGRyZW5XcmFwcGVyID0gc3R5bGVkLmRpdih7XG4gIGRpc3BsYXk6IFwiY29udGVudHNcIixcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gTGlnaHRib3goe1xuICBiYWNrZHJvcFJlZixcbiAgcG9ydGFsQ29udGFpbmVyLFxuICBpbml0aWFsRm9jdXMsXG4gIGlzRGlzbWlzc2libGUgPSB0cnVlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlQ2xvc2UsXG4gIGp1c3RpZnlDb250ZW50ID0gXCJjZW50ZXJcIixcbiAgcHJpdmF0ZVByb3BzOiB7IHNraXBQb3J0YWwsIHRhYmJhYmxlT3B0aW9ucyB9ID0ge1xuICAgIHNraXBQb3J0YWw6IGZhbHNlLFxuICB9LFxufTogUHJvcHNXaXRoQ2hpbGRyZW48TGlnaHRib3hQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwb3J0YWxDb250YWluZXJFbGVtZW50ID0gdXNlUG9ydGFsQ29udGFpbmVyRWxlbWVudChwb3J0YWxDb250YWluZXIpO1xuICBjb25zdCBtb2RhbFJlZiA9IHVzZVJlZihudWxsKTtcblxuICBjb25zdCBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyA9IHVzZUNhbGxiYWNrKFxuICAgIChldnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICAvLyBEbyBub3QgY2xvc2Ugb24gY2xpY2sgdGhhdCBvY2N1cnMgb24gZWxlbWVudHMgd2l0aGluIHRoZSBzYW1lIHBvcnRhbCwgZm9yIGVnLCBkcm9wZG93biBhbmQgc2VsZWN0IG1lbnVzXG4gICAgICBpZiAoXG4gICAgICAgIHBvcnRhbENvbnRhaW5lckVsZW1lbnQuY29udGFpbnMoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgJiZcbiAgICAgICAgZXZ0LnRhcmdldCAhPT0gYmFja2Ryb3BSZWY/LmN1cnJlbnRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpc0Rpc21pc3NpYmxlO1xuICAgIH0sXG4gICAgW2JhY2tkcm9wUmVmLCBwb3J0YWxDb250YWluZXJFbGVtZW50LCBpc0Rpc21pc3NpYmxlXVxuICApO1xuXG4gIGNvbnN0IGdldEZvY3VzVGFyZ2V0ID0gKCkgPT4ge1xuICAgIGNvbnN0IGNvbnRhaW5lciA9IG1vZGFsUmVmPy5jdXJyZW50XG4gICAgICA/LmZpcnN0RWxlbWVudENoaWxkIGFzIEhUTUxFbGVtZW50IHwgbnVsbDtcblxuICAgIGNvbnN0IGZvY3VzYWJsZVNlbGVjdG9yID1cbiAgICAgICdhW2hyZWZdLCBidXR0b246bm90KFtkaXNhYmxlZF0pLCBpbnB1dDpub3QoW2Rpc2FibGVkXSksIHNlbGVjdDpub3QoW2Rpc2FibGVkXSksIHRleHRhcmVhOm5vdChbZGlzYWJsZWRdKSwgW3RhYmluZGV4XTpub3QoW3RhYmluZGV4PVwiLTFcIl0pJztcbiAgICBjb25zdCBmaXJzdEZvY3VzYWJsZSA9XG4gICAgICBjb250YWluZXI/LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KGZvY3VzYWJsZVNlbGVjdG9yKTtcbiAgICBpZiAoZmlyc3RGb2N1c2FibGUpIHtcbiAgICAgIHJldHVybiBmaXJzdEZvY3VzYWJsZTtcbiAgICB9XG5cbiAgICByZXR1cm4gY29udGFpbmVyIHx8IGRvY3VtZW50LmJvZHk7XG4gIH07XG5cbiAgY29uc3QgZ2V0SW5pdGlhbEZvY3VzID0gKCkgPT4ge1xuICAgIGlmICh0eXBlb2YgaW5pdGlhbEZvY3VzID09PSBcInN0cmluZ1wiKSB7XG4gICAgICByZXR1cm4gaW5pdGlhbEZvY3VzO1xuICAgIH1cbiAgICByZXR1cm4gaW5pdGlhbEZvY3VzPy5jdXJyZW50ID8/IGdldEZvY3VzVGFyZ2V0KCk7XG4gIH07XG5cbiAgY29uc3QgY29udGVudCA9IChcbiAgICA8U3R5bGVkQmFja2Ryb3BcbiAgICAgIHJlZj17YmFja2Ryb3BSZWZ9XG4gICAgICBqdXN0aWZ5Q29udGVudD17anVzdGlmeUNvbnRlbnR9XG4gICAgICBkYXRhLWRzLWlkPVwiTGlnaHRib3hcIlxuICAgID5cbiAgICAgIDxGb2N1c1RyYXBXcmFwcGVyXG4gICAgICAgIGFjdGl2ZVxuICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgYWxsb3dPdXRzaWRlQ2xpY2s6IHRydWUsIC8vIGFsbG93IGNsaWNrIG9uIG1vYmlsZSBpbiBhbnkgZHJvcGRvd25zXG4gICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IGhhbmRsZUNsaWNrT3V0c2lkZURlYWN0aXZhdGVzLFxuICAgICAgICAgIGVzY2FwZURlYWN0aXZhdGVzOiBpc0Rpc21pc3NpYmxlLCAvLyBkZS1hY3RpdmF0ZSBmb2N1cyB0cmFwIG9uIGVzY2FwZSBrZXlcbiAgICAgICAgICBwcmV2ZW50U2Nyb2xsOiB0cnVlLFxuICAgICAgICAgIGluaXRpYWxGb2N1czogKCkgPT4gZ2V0SW5pdGlhbEZvY3VzKCksXG4gICAgICAgICAgZmFsbGJhY2tGb2N1czogKCkgPT4gZ2V0Rm9jdXNUYXJnZXQoKSxcbiAgICAgICAgICAuLi4odGFiYmFibGVPcHRpb25zICYmIHsgdGFiYmFibGVPcHRpb25zIH0pLFxuICAgICAgICAgIC4uLihoYW5kbGVDbG9zZSAmJiB7IG9uUG9zdERlYWN0aXZhdGU6IGhhbmRsZUNsb3NlIH0pLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICA8U3R5bGVkQ2hpbGRyZW5XcmFwcGVyIHJlZj17bW9kYWxSZWZ9PlxuICAgICAgICAgIDxEaWFsb2dDb250ZXh0LlByb3ZpZGVyIHZhbHVlPntjaGlsZHJlbn08L0RpYWxvZ0NvbnRleHQuUHJvdmlkZXI+XG4gICAgICAgIDwvU3R5bGVkQ2hpbGRyZW5XcmFwcGVyPlxuICAgICAgPC9Gb2N1c1RyYXBXcmFwcGVyPlxuICAgIDwvU3R5bGVkQmFja2Ryb3A+XG4gICk7XG5cbiAgLy8gRm9yIHRlc3RpbmcgYW5kIE1vZGFsIHN0b3J5IHdlIGRvbid0IHdhbnQgdG8gcmVuZGVyIHRoZSBjb250ZW50IGluc2lkZSBhIHBvcnRhbFxuICBpZiAoc2tpcFBvcnRhbCkge1xuICAgIHJldHVybiBjb250ZW50O1xuICB9XG5cbiAgcmV0dXJuIDxQb3J0YWwgcG9ydGFsQ29udGFpbmVyPXtwb3J0YWxDb250YWluZXJ9Pntjb250ZW50fTwvUG9ydGFsPjtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQzhCIn0= */"),StyledChildrenWrapper=(0,_styled.default)("div",{target:"e1v68oqn1",label:"StyledChildrenWrapper"})({display:"contents"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTGlnaHRib3gvTGlnaHRib3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9MaWdodGJveC9MaWdodGJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIHVzZUNhbGxiYWNrLFxuICB1c2VSZWYsXG4gIHR5cGUgUHJvcHNXaXRoQ2hpbGRyZW4sXG4gIHR5cGUgUmVmT2JqZWN0LFxufSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQsIE1RIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB1c2VQb3J0YWxDb250YWluZXJFbGVtZW50LFxuICB0eXBlIFBvcnRhbFByb3BzLFxufSBmcm9tIFwiLi4vUG9ydGFsL1BvcnRhbFwiO1xuaW1wb3J0IHsgRm9jdXNUcmFwV3JhcHBlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvRm9jdXNUcmFwV3JhcHBlclwiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBEaWFsb2dDb250ZXh0IH0gZnJvbSBcIi4uL1BhdHRlcm5zL0RpYWxvZy9EaWFsb2dDb250ZXh0XCI7XG5cbmV4cG9ydCB0eXBlIExpZ2h0Ym94UHJvcHMgPSBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4gJiB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG4gIGJhY2tkcm9wUmVmPzogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgaGFuZGxlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBpc0Rpc21pc3NpYmxlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEEgcmVmIHRvIHRoZSBlbGVtZW50IHRoYXQgc2hvdWxkIHJlY2VpdmUgZm9jdXMgd2hlbiB0aGUgbGlnaHRib3ggb3BlbnMuXG4gICAqIFdoZW4gbm90IHByb3ZpZGVkLCB0aGUgZmlyc3QgZm9jdXNhYmxlIGVsZW1lbnQgaW5zaWRlIHRoZSBsaWdodGJveCBpcyB1c2VkLlxuICAgKi9cbiAgaW5pdGlhbEZvY3VzPzogUmVmT2JqZWN0PEhUTUxFbGVtZW50IHwgU1ZHRWxlbWVudD4gfCBzdHJpbmc7XG4gIGp1c3RpZnlDb250ZW50PzogTVE8TGlnaHRib3hWZXJ0aWNhbEFsaWdubWVudD4gfCBMaWdodGJveFZlcnRpY2FsQWxpZ25tZW50O1xuICBwcml2YXRlUHJvcHM/OiB7XG4gICAgc2tpcFBvcnRhbD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQGludGVybmFsXG4gICAgICogT3B0aW9ucyBwYXNzZWQgdG8gZm9jdXMtdHJhcCdzIHRhYmJhYmxlIGRldGVjdGlvbi5cbiAgICAgKiBVc2UgYHsgZGlzcGxheUNoZWNrOiBcIm5vbmVcIiB9YCBmb3IgdGVzdGluZyB0byBhdm9pZCBKU0RPTSB2aXNpYmlsaXR5IGlzc3Vlcy5cbiAgICAgKi9cbiAgICB0YWJiYWJsZU9wdGlvbnM/OiB7XG4gICAgICBkaXNwbGF5Q2hlY2s/OiBcImZ1bGxcIiB8IFwibGVnYWN5LWZ1bGxcIiB8IFwibm9uLXplcm8tYXJlYVwiIHwgXCJub25lXCI7XG4gICAgfTtcbiAgfTtcbn0gJiBQaWNrPFBvcnRhbFByb3BzLCBcInBvcnRhbENvbnRhaW5lclwiPjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEJhY2tkcm9wID0gc3R5bGVkLmRpdjxQaWNrPExpZ2h0Ym94UHJvcHMsIFwianVzdGlmeUNvbnRlbnRcIj4+KFxuICAoeyB0aGVtZSwganVzdGlmeUNvbnRlbnQgfSkgPT4ge1xuICAgIGNvbnN0IGZhZGVJbkJhY2tkcm9wID0ga2V5ZnJhbWVzYFxuICAgIGZyb20ge1xuICAgICAgb3BhY2l0eTogJHt0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW59O1xuICAgIH1cbiAgICB0byB7XG4gICAgICBvcGFjaXR5OiAke3RoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LnZpc2libGV9O1xuICAgIH1cbiAgYDtcblxuICAgIHJldHVybiB7XG4gICAgICBwb3NpdGlvbjogXCJmaXhlZFwiLFxuICAgICAgdG9wOiAwLFxuICAgICAgbGVmdDogMCxcbiAgICAgIHpJbmRleDogdGhlbWUudmFyaWFibGVzLnpJbmRleC5tb2RhbCxcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGhlaWdodDogXCIxMDBkdmhcIixcbiAgICAgIGJhY2tncm91bmQ6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmJhY2tkcm9wLmRlZmF1bHQsXG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gICAgICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICAgICAganVzdGlmeUNvbnRlbnQ6IFtcbiAgICAgICAgICBqdXN0aWZ5Q29udGVudCxcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0b3A6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIH0sXG4gICAgICAgIF0sXG4gICAgICB9KSxcbiAgICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgICBmbGV4OiBcIjEgMCBhdXRvXCIsXG4gICAgICBhbmltYXRpb246IGAke2ZhZGVJbkJhY2tkcm9wfSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLmR1cmF0aW9ufSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLnRpbWluZ0Z1bmN0aW9ufSBib3RoYCxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ2hpbGRyZW5XcmFwcGVyID0gc3R5bGVkLmRpdih7XG4gIGRpc3BsYXk6IFwiY29udGVudHNcIixcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gTGlnaHRib3goe1xuICBiYWNrZHJvcFJlZixcbiAgcG9ydGFsQ29udGFpbmVyLFxuICBpbml0aWFsRm9jdXMsXG4gIGlzRGlzbWlzc2libGUgPSB0cnVlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlQ2xvc2UsXG4gIGp1c3RpZnlDb250ZW50ID0gXCJjZW50ZXJcIixcbiAgcHJpdmF0ZVByb3BzOiB7IHNraXBQb3J0YWwsIHRhYmJhYmxlT3B0aW9ucyB9ID0ge1xuICAgIHNraXBQb3J0YWw6IGZhbHNlLFxuICB9LFxufTogUHJvcHNXaXRoQ2hpbGRyZW48TGlnaHRib3hQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwb3J0YWxDb250YWluZXJFbGVtZW50ID0gdXNlUG9ydGFsQ29udGFpbmVyRWxlbWVudChwb3J0YWxDb250YWluZXIpO1xuICBjb25zdCBtb2RhbFJlZiA9IHVzZVJlZihudWxsKTtcblxuICBjb25zdCBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyA9IHVzZUNhbGxiYWNrKFxuICAgIChldnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICAvLyBEbyBub3QgY2xvc2Ugb24gY2xpY2sgdGhhdCBvY2N1cnMgb24gZWxlbWVudHMgd2l0aGluIHRoZSBzYW1lIHBvcnRhbCwgZm9yIGVnLCBkcm9wZG93biBhbmQgc2VsZWN0IG1lbnVzXG4gICAgICBpZiAoXG4gICAgICAgIHBvcnRhbENvbnRhaW5lckVsZW1lbnQuY29udGFpbnMoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgJiZcbiAgICAgICAgZXZ0LnRhcmdldCAhPT0gYmFja2Ryb3BSZWY/LmN1cnJlbnRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpc0Rpc21pc3NpYmxlO1xuICAgIH0sXG4gICAgW2JhY2tkcm9wUmVmLCBwb3J0YWxDb250YWluZXJFbGVtZW50LCBpc0Rpc21pc3NpYmxlXVxuICApO1xuXG4gIGNvbnN0IGdldEZvY3VzVGFyZ2V0ID0gKCkgPT4ge1xuICAgIGNvbnN0IGNvbnRhaW5lciA9IG1vZGFsUmVmPy5jdXJyZW50XG4gICAgICA/LmZpcnN0RWxlbWVudENoaWxkIGFzIEhUTUxFbGVtZW50IHwgbnVsbDtcblxuICAgIGNvbnN0IGZvY3VzYWJsZVNlbGVjdG9yID1cbiAgICAgICdhW2hyZWZdLCBidXR0b246bm90KFtkaXNhYmxlZF0pLCBpbnB1dDpub3QoW2Rpc2FibGVkXSksIHNlbGVjdDpub3QoW2Rpc2FibGVkXSksIHRleHRhcmVhOm5vdChbZGlzYWJsZWRdKSwgW3RhYmluZGV4XTpub3QoW3RhYmluZGV4PVwiLTFcIl0pJztcbiAgICBjb25zdCBmaXJzdEZvY3VzYWJsZSA9XG4gICAgICBjb250YWluZXI/LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KGZvY3VzYWJsZVNlbGVjdG9yKTtcbiAgICBpZiAoZmlyc3RGb2N1c2FibGUpIHtcbiAgICAgIHJldHVybiBmaXJzdEZvY3VzYWJsZTtcbiAgICB9XG5cbiAgICByZXR1cm4gY29udGFpbmVyIHx8IGRvY3VtZW50LmJvZHk7XG4gIH07XG5cbiAgY29uc3QgZ2V0SW5pdGlhbEZvY3VzID0gKCkgPT4ge1xuICAgIGlmICh0eXBlb2YgaW5pdGlhbEZvY3VzID09PSBcInN0cmluZ1wiKSB7XG4gICAgICByZXR1cm4gaW5pdGlhbEZvY3VzO1xuICAgIH1cbiAgICByZXR1cm4gaW5pdGlhbEZvY3VzPy5jdXJyZW50ID8/IGdldEZvY3VzVGFyZ2V0KCk7XG4gIH07XG5cbiAgY29uc3QgY29udGVudCA9IChcbiAgICA8U3R5bGVkQmFja2Ryb3BcbiAgICAgIHJlZj17YmFja2Ryb3BSZWZ9XG4gICAgICBqdXN0aWZ5Q29udGVudD17anVzdGlmeUNvbnRlbnR9XG4gICAgICBkYXRhLWRzLWlkPVwiTGlnaHRib3hcIlxuICAgID5cbiAgICAgIDxGb2N1c1RyYXBXcmFwcGVyXG4gICAgICAgIGFjdGl2ZVxuICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgYWxsb3dPdXRzaWRlQ2xpY2s6IHRydWUsIC8vIGFsbG93IGNsaWNrIG9uIG1vYmlsZSBpbiBhbnkgZHJvcGRvd25zXG4gICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IGhhbmRsZUNsaWNrT3V0c2lkZURlYWN0aXZhdGVzLFxuICAgICAgICAgIGVzY2FwZURlYWN0aXZhdGVzOiBpc0Rpc21pc3NpYmxlLCAvLyBkZS1hY3RpdmF0ZSBmb2N1cyB0cmFwIG9uIGVzY2FwZSBrZXlcbiAgICAgICAgICBwcmV2ZW50U2Nyb2xsOiB0cnVlLFxuICAgICAgICAgIGluaXRpYWxGb2N1czogKCkgPT4gZ2V0SW5pdGlhbEZvY3VzKCksXG4gICAgICAgICAgZmFsbGJhY2tGb2N1czogKCkgPT4gZ2V0Rm9jdXNUYXJnZXQoKSxcbiAgICAgICAgICAuLi4odGFiYmFibGVPcHRpb25zICYmIHsgdGFiYmFibGVPcHRpb25zIH0pLFxuICAgICAgICAgIC4uLihoYW5kbGVDbG9zZSAmJiB7IG9uUG9zdERlYWN0aXZhdGU6IGhhbmRsZUNsb3NlIH0pLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICA8U3R5bGVkQ2hpbGRyZW5XcmFwcGVyIHJlZj17bW9kYWxSZWZ9PlxuICAgICAgICAgIDxEaWFsb2dDb250ZXh0LlByb3ZpZGVyIHZhbHVlPntjaGlsZHJlbn08L0RpYWxvZ0NvbnRleHQuUHJvdmlkZXI+XG4gICAgICAgIDwvU3R5bGVkQ2hpbGRyZW5XcmFwcGVyPlxuICAgICAgPC9Gb2N1c1RyYXBXcmFwcGVyPlxuICAgIDwvU3R5bGVkQmFja2Ryb3A+XG4gICk7XG5cbiAgLy8gRm9yIHRlc3RpbmcgYW5kIE1vZGFsIHN0b3J5IHdlIGRvbid0IHdhbnQgdG8gcmVuZGVyIHRoZSBjb250ZW50IGluc2lkZSBhIHBvcnRhbFxuICBpZiAoc2tpcFBvcnRhbCkge1xuICAgIHJldHVybiBjb250ZW50O1xuICB9XG5cbiAgcmV0dXJuIDxQb3J0YWwgcG9ydGFsQ29udGFpbmVyPXtwb3J0YWxDb250YWluZXJ9Pntjb250ZW50fTwvUG9ydGFsPjtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRnFDIn0= */");function Lightbox({backdropRef,portalContainer,initialFocus,isDismissible=!0,children,handleClose,justifyContent="center",privateProps:{skipPortal,tabbableOptions}={skipPortal:!1}}){let portalContainerElement=(0,_Portal.usePortalContainerElement)(portalContainer),modalRef=(0,_react.useRef)(null),handleClickOutsideDeactivates=(0,_react.useCallback)(evt=>(!portalContainerElement.contains(evt.target)||evt.target===backdropRef?.current)&&isDismissible,[backdropRef,portalContainerElement,isDismissible]),getFocusTarget=()=>{let container=modalRef?.current?.firstElementChild,firstFocusable=container?.querySelector('a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), [tabindex]:not([tabindex="-1"])');return firstFocusable||container||document.body},getInitialFocus=()=>"string"==typeof initialFocus?initialFocus:initialFocus?.current??getFocusTarget(),content=_react.default.createElement(StyledBackdrop,{ref:backdropRef,justifyContent:justifyContent,"data-ds-id":"Lightbox"},_react.default.createElement(_FocusTrapWrapper.FocusTrapWrapper,{active:!0,focusTrapOptions:{allowOutsideClick:!0,clickOutsideDeactivates:handleClickOutsideDeactivates,escapeDeactivates:isDismissible,preventScroll:!0,initialFocus:()=>getInitialFocus(),fallbackFocus:()=>getFocusTarget(),...tabbableOptions&&{tabbableOptions},...handleClose&&{onPostDeactivate:handleClose}}},_react.default.createElement(StyledChildrenWrapper,{ref:modalRef},_react.default.createElement(_DialogContext.DialogContext.Provider,{value:!0},children))));return skipPortal?content:_react.default.createElement(_Portal.Portal,{portalContainer:portalContainer},content)}
|
|
8
|
+
`;return{position:"fixed",top:0,left:0,zIndex:theme.variables.zIndex.modal,width:"100%",height:"100dvh",background:theme.values.color.background.backdrop.default,display:"flex",flexDirection:"column",...(0,_mediaQueries.useResponsiveStyles)({justifyContent:[justifyContent,{top:"flex-start",center:"center"}]}),alignItems:"center",flex:"1 0 auto",animation:`${fadeInBackdrop} ${theme.variables.animation.modalBackdrop.open.duration} ${theme.variables.animation.modalBackdrop.open.timingFunction} both`}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTGlnaHRib3gvTGlnaHRib3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9MaWdodGJveC9MaWdodGJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIHVzZUNhbGxiYWNrLFxuICB1c2VSZWYsXG4gIHR5cGUgUHJvcHNXaXRoQ2hpbGRyZW4sXG4gIHR5cGUgUmVmT2JqZWN0LFxufSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQsIE1RIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB1c2VQb3J0YWxDb250YWluZXJFbGVtZW50LFxuICB0eXBlIFBvcnRhbFByb3BzLFxufSBmcm9tIFwiLi4vUG9ydGFsL1BvcnRhbFwiO1xuaW1wb3J0IHsgRm9jdXNUcmFwV3JhcHBlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvRm9jdXNUcmFwV3JhcHBlclwiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBEaWFsb2dDb250ZXh0IH0gZnJvbSBcIi4uL1BhdHRlcm5zL0RpYWxvZy9EaWFsb2dDb250ZXh0XCI7XG5cbmV4cG9ydCB0eXBlIExpZ2h0Ym94UHJvcHMgPSBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4gJiB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG4gIGJhY2tkcm9wUmVmPzogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgaGFuZGxlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBpc0Rpc21pc3NpYmxlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEEgcmVmIHRvIHRoZSBlbGVtZW50IHRoYXQgc2hvdWxkIHJlY2VpdmUgZm9jdXMgd2hlbiB0aGUgbGlnaHRib3ggb3BlbnMuXG4gICAqIFdoZW4gbm90IHByb3ZpZGVkLCB0aGUgZmlyc3QgZm9jdXNhYmxlIGVsZW1lbnQgaW5zaWRlIHRoZSBsaWdodGJveCBpcyB1c2VkLlxuICAgKi9cbiAgaW5pdGlhbEZvY3VzPzogUmVmT2JqZWN0PEhUTUxFbGVtZW50IHwgU1ZHRWxlbWVudD4gfCBzdHJpbmc7XG4gIGp1c3RpZnlDb250ZW50PzogTVE8TGlnaHRib3hWZXJ0aWNhbEFsaWdubWVudD4gfCBMaWdodGJveFZlcnRpY2FsQWxpZ25tZW50O1xuICBwcml2YXRlUHJvcHM/OiB7XG4gICAgc2tpcFBvcnRhbD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQGludGVybmFsXG4gICAgICogT3B0aW9ucyBwYXNzZWQgdG8gZm9jdXMtdHJhcCdzIHRhYmJhYmxlIGRldGVjdGlvbi5cbiAgICAgKiBVc2UgYHsgZGlzcGxheUNoZWNrOiBcIm5vbmVcIiB9YCBmb3IgdGVzdGluZyB0byBhdm9pZCBKU0RPTSB2aXNpYmlsaXR5IGlzc3Vlcy5cbiAgICAgKi9cbiAgICB0YWJiYWJsZU9wdGlvbnM/OiB7XG4gICAgICBkaXNwbGF5Q2hlY2s/OiBcImZ1bGxcIiB8IFwibGVnYWN5LWZ1bGxcIiB8IFwibm9uLXplcm8tYXJlYVwiIHwgXCJub25lXCI7XG4gICAgfTtcbiAgfTtcbn0gJiBQaWNrPFBvcnRhbFByb3BzLCBcInBvcnRhbENvbnRhaW5lclwiPjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEJhY2tkcm9wID0gc3R5bGVkLmRpdjxQaWNrPExpZ2h0Ym94UHJvcHMsIFwianVzdGlmeUNvbnRlbnRcIj4+KFxuICAoeyB0aGVtZSwganVzdGlmeUNvbnRlbnQgfSkgPT4ge1xuICAgIGNvbnN0IGZhZGVJbkJhY2tkcm9wID0ga2V5ZnJhbWVzYFxuICAgIGZyb20ge1xuICAgICAgb3BhY2l0eTogJHt0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW59O1xuICAgIH1cbiAgICB0byB7XG4gICAgICBvcGFjaXR5OiAke3RoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LnZpc2libGV9O1xuICAgIH1cbiAgYDtcblxuICAgIHJldHVybiB7XG4gICAgICBwb3NpdGlvbjogXCJmaXhlZFwiLFxuICAgICAgdG9wOiAwLFxuICAgICAgbGVmdDogMCxcbiAgICAgIHpJbmRleDogdGhlbWUudmFyaWFibGVzLnpJbmRleC5tb2RhbCxcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGhlaWdodDogXCIxMDBkdmhcIixcbiAgICAgIGJhY2tncm91bmQ6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmJhY2tkcm9wLmRlZmF1bHQsXG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gICAgICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICAgICAganVzdGlmeUNvbnRlbnQ6IFtcbiAgICAgICAgICBqdXN0aWZ5Q29udGVudCxcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0b3A6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIH0sXG4gICAgICAgIF0sXG4gICAgICB9KSxcbiAgICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgICBmbGV4OiBcIjEgMCBhdXRvXCIsXG4gICAgICBhbmltYXRpb246IGAke2ZhZGVJbkJhY2tkcm9wfSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLmR1cmF0aW9ufSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLnRpbWluZ0Z1bmN0aW9ufSBib3RoYCxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ2hpbGRyZW5XcmFwcGVyID0gc3R5bGVkLmRpdih7XG4gIGRpc3BsYXk6IFwiY29udGVudHNcIixcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gTGlnaHRib3goe1xuICBiYWNrZHJvcFJlZixcbiAgcG9ydGFsQ29udGFpbmVyLFxuICBpbml0aWFsRm9jdXMsXG4gIGlzRGlzbWlzc2libGUgPSB0cnVlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlQ2xvc2UsXG4gIGp1c3RpZnlDb250ZW50ID0gXCJjZW50ZXJcIixcbiAgcHJpdmF0ZVByb3BzOiB7IHNraXBQb3J0YWwsIHRhYmJhYmxlT3B0aW9ucyB9ID0ge1xuICAgIHNraXBQb3J0YWw6IGZhbHNlLFxuICB9LFxufTogUHJvcHNXaXRoQ2hpbGRyZW48TGlnaHRib3hQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwb3J0YWxDb250YWluZXJFbGVtZW50ID0gdXNlUG9ydGFsQ29udGFpbmVyRWxlbWVudChwb3J0YWxDb250YWluZXIpO1xuICBjb25zdCBtb2RhbFJlZiA9IHVzZVJlZihudWxsKTtcblxuICBjb25zdCBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyA9IHVzZUNhbGxiYWNrKFxuICAgIChldnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICAvLyBEbyBub3QgY2xvc2Ugb24gY2xpY2sgdGhhdCBvY2N1cnMgb24gZWxlbWVudHMgd2l0aGluIHRoZSBzYW1lIHBvcnRhbCwgZm9yIGVnLCBkcm9wZG93biBhbmQgc2VsZWN0IG1lbnVzXG4gICAgICBpZiAoXG4gICAgICAgIHBvcnRhbENvbnRhaW5lckVsZW1lbnQuY29udGFpbnMoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgJiZcbiAgICAgICAgZXZ0LnRhcmdldCAhPT0gYmFja2Ryb3BSZWY/LmN1cnJlbnRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpc0Rpc21pc3NpYmxlO1xuICAgIH0sXG4gICAgW2JhY2tkcm9wUmVmLCBwb3J0YWxDb250YWluZXJFbGVtZW50LCBpc0Rpc21pc3NpYmxlXVxuICApO1xuXG4gIGNvbnN0IGdldEZvY3VzVGFyZ2V0ID0gKCkgPT4ge1xuICAgIGNvbnN0IGNvbnRhaW5lciA9IG1vZGFsUmVmPy5jdXJyZW50XG4gICAgICA/LmZpcnN0RWxlbWVudENoaWxkIGFzIEhUTUxFbGVtZW50IHwgbnVsbDtcblxuICAgIGNvbnN0IGZvY3VzYWJsZVNlbGVjdG9yID1cbiAgICAgICdhW2hyZWZdLCBidXR0b246bm90KFtkaXNhYmxlZF0pLCBpbnB1dDpub3QoW2Rpc2FibGVkXSksIHNlbGVjdDpub3QoW2Rpc2FibGVkXSksIHRleHRhcmVhOm5vdChbZGlzYWJsZWRdKSwgW3RhYmluZGV4XTpub3QoW3RhYmluZGV4PVwiLTFcIl0pJztcbiAgICBjb25zdCBmaXJzdEZvY3VzYWJsZSA9XG4gICAgICBjb250YWluZXI/LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KGZvY3VzYWJsZVNlbGVjdG9yKTtcbiAgICBpZiAoZmlyc3RGb2N1c2FibGUpIHtcbiAgICAgIHJldHVybiBmaXJzdEZvY3VzYWJsZTtcbiAgICB9XG5cbiAgICByZXR1cm4gY29udGFpbmVyIHx8IGRvY3VtZW50LmJvZHk7XG4gIH07XG5cbiAgY29uc3QgZ2V0SW5pdGlhbEZvY3VzID0gKCkgPT4ge1xuICAgIGlmICh0eXBlb2YgaW5pdGlhbEZvY3VzID09PSBcInN0cmluZ1wiKSB7XG4gICAgICByZXR1cm4gaW5pdGlhbEZvY3VzO1xuICAgIH1cbiAgICByZXR1cm4gaW5pdGlhbEZvY3VzPy5jdXJyZW50ID8/IGdldEZvY3VzVGFyZ2V0KCk7XG4gIH07XG5cbiAgY29uc3QgY29udGVudCA9IChcbiAgICA8U3R5bGVkQmFja2Ryb3BcbiAgICAgIHJlZj17YmFja2Ryb3BSZWZ9XG4gICAgICBqdXN0aWZ5Q29udGVudD17anVzdGlmeUNvbnRlbnR9XG4gICAgICBkYXRhLWRzLWlkPVwiTGlnaHRib3hcIlxuICAgID5cbiAgICAgIDxGb2N1c1RyYXBXcmFwcGVyXG4gICAgICAgIGFjdGl2ZVxuICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgYWxsb3dPdXRzaWRlQ2xpY2s6IHRydWUsIC8vIGFsbG93IGNsaWNrIG9uIG1vYmlsZSBpbiBhbnkgZHJvcGRvd25zXG4gICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IGhhbmRsZUNsaWNrT3V0c2lkZURlYWN0aXZhdGVzLFxuICAgICAgICAgIGVzY2FwZURlYWN0aXZhdGVzOiBpc0Rpc21pc3NpYmxlLCAvLyBkZS1hY3RpdmF0ZSBmb2N1cyB0cmFwIG9uIGVzY2FwZSBrZXlcbiAgICAgICAgICBwcmV2ZW50U2Nyb2xsOiB0cnVlLFxuICAgICAgICAgIGluaXRpYWxGb2N1czogKCkgPT4gZ2V0SW5pdGlhbEZvY3VzKCksXG4gICAgICAgICAgZmFsbGJhY2tGb2N1czogKCkgPT4gZ2V0Rm9jdXNUYXJnZXQoKSxcbiAgICAgICAgICAuLi4odGFiYmFibGVPcHRpb25zICYmIHsgdGFiYmFibGVPcHRpb25zIH0pLFxuICAgICAgICAgIC4uLihoYW5kbGVDbG9zZSAmJiB7IG9uUG9zdERlYWN0aXZhdGU6IGhhbmRsZUNsb3NlIH0pLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICA8U3R5bGVkQ2hpbGRyZW5XcmFwcGVyIHJlZj17bW9kYWxSZWZ9PntjaGlsZHJlbn08L1N0eWxlZENoaWxkcmVuV3JhcHBlcj5cbiAgICAgIDwvRm9jdXNUcmFwV3JhcHBlcj5cbiAgICA8L1N0eWxlZEJhY2tkcm9wPlxuICApO1xuXG4gIC8vIEZvciB0ZXN0aW5nIGFuZCBNb2RhbCBzdG9yeSB3ZSBkb24ndCB3YW50IHRvIHJlbmRlciB0aGUgY29udGVudCBpbnNpZGUgYSBwb3J0YWxcbiAgaWYgKHNraXBQb3J0YWwpIHtcbiAgICByZXR1cm4gY29udGVudDtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPERpYWxvZ0NvbnRleHQuUHJvdmlkZXIgdmFsdWU+XG4gICAgICA8UG9ydGFsIHBvcnRhbENvbnRhaW5lcj17cG9ydGFsQ29udGFpbmVyfT57Y29udGVudH08L1BvcnRhbD5cbiAgICA8L0RpYWxvZ0NvbnRleHQuUHJvdmlkZXI+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkM4QiJ9 */"),StyledChildrenWrapper=(0,_styled.default)("div",{target:"ew3tr1y1",label:"StyledChildrenWrapper"})({display:"contents"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTGlnaHRib3gvTGlnaHRib3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9MaWdodGJveC9MaWdodGJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIHVzZUNhbGxiYWNrLFxuICB1c2VSZWYsXG4gIHR5cGUgUHJvcHNXaXRoQ2hpbGRyZW4sXG4gIHR5cGUgUmVmT2JqZWN0LFxufSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQsIE1RIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB1c2VQb3J0YWxDb250YWluZXJFbGVtZW50LFxuICB0eXBlIFBvcnRhbFByb3BzLFxufSBmcm9tIFwiLi4vUG9ydGFsL1BvcnRhbFwiO1xuaW1wb3J0IHsgRm9jdXNUcmFwV3JhcHBlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvRm9jdXNUcmFwV3JhcHBlclwiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBEaWFsb2dDb250ZXh0IH0gZnJvbSBcIi4uL1BhdHRlcm5zL0RpYWxvZy9EaWFsb2dDb250ZXh0XCI7XG5cbmV4cG9ydCB0eXBlIExpZ2h0Ym94UHJvcHMgPSBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4gJiB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG4gIGJhY2tkcm9wUmVmPzogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgaGFuZGxlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBpc0Rpc21pc3NpYmxlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEEgcmVmIHRvIHRoZSBlbGVtZW50IHRoYXQgc2hvdWxkIHJlY2VpdmUgZm9jdXMgd2hlbiB0aGUgbGlnaHRib3ggb3BlbnMuXG4gICAqIFdoZW4gbm90IHByb3ZpZGVkLCB0aGUgZmlyc3QgZm9jdXNhYmxlIGVsZW1lbnQgaW5zaWRlIHRoZSBsaWdodGJveCBpcyB1c2VkLlxuICAgKi9cbiAgaW5pdGlhbEZvY3VzPzogUmVmT2JqZWN0PEhUTUxFbGVtZW50IHwgU1ZHRWxlbWVudD4gfCBzdHJpbmc7XG4gIGp1c3RpZnlDb250ZW50PzogTVE8TGlnaHRib3hWZXJ0aWNhbEFsaWdubWVudD4gfCBMaWdodGJveFZlcnRpY2FsQWxpZ25tZW50O1xuICBwcml2YXRlUHJvcHM/OiB7XG4gICAgc2tpcFBvcnRhbD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQGludGVybmFsXG4gICAgICogT3B0aW9ucyBwYXNzZWQgdG8gZm9jdXMtdHJhcCdzIHRhYmJhYmxlIGRldGVjdGlvbi5cbiAgICAgKiBVc2UgYHsgZGlzcGxheUNoZWNrOiBcIm5vbmVcIiB9YCBmb3IgdGVzdGluZyB0byBhdm9pZCBKU0RPTSB2aXNpYmlsaXR5IGlzc3Vlcy5cbiAgICAgKi9cbiAgICB0YWJiYWJsZU9wdGlvbnM/OiB7XG4gICAgICBkaXNwbGF5Q2hlY2s/OiBcImZ1bGxcIiB8IFwibGVnYWN5LWZ1bGxcIiB8IFwibm9uLXplcm8tYXJlYVwiIHwgXCJub25lXCI7XG4gICAgfTtcbiAgfTtcbn0gJiBQaWNrPFBvcnRhbFByb3BzLCBcInBvcnRhbENvbnRhaW5lclwiPjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEJhY2tkcm9wID0gc3R5bGVkLmRpdjxQaWNrPExpZ2h0Ym94UHJvcHMsIFwianVzdGlmeUNvbnRlbnRcIj4+KFxuICAoeyB0aGVtZSwganVzdGlmeUNvbnRlbnQgfSkgPT4ge1xuICAgIGNvbnN0IGZhZGVJbkJhY2tkcm9wID0ga2V5ZnJhbWVzYFxuICAgIGZyb20ge1xuICAgICAgb3BhY2l0eTogJHt0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW59O1xuICAgIH1cbiAgICB0byB7XG4gICAgICBvcGFjaXR5OiAke3RoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LnZpc2libGV9O1xuICAgIH1cbiAgYDtcblxuICAgIHJldHVybiB7XG4gICAgICBwb3NpdGlvbjogXCJmaXhlZFwiLFxuICAgICAgdG9wOiAwLFxuICAgICAgbGVmdDogMCxcbiAgICAgIHpJbmRleDogdGhlbWUudmFyaWFibGVzLnpJbmRleC5tb2RhbCxcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGhlaWdodDogXCIxMDBkdmhcIixcbiAgICAgIGJhY2tncm91bmQ6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmJhY2tkcm9wLmRlZmF1bHQsXG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gICAgICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICAgICAganVzdGlmeUNvbnRlbnQ6IFtcbiAgICAgICAgICBqdXN0aWZ5Q29udGVudCxcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0b3A6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIH0sXG4gICAgICAgIF0sXG4gICAgICB9KSxcbiAgICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgICBmbGV4OiBcIjEgMCBhdXRvXCIsXG4gICAgICBhbmltYXRpb246IGAke2ZhZGVJbkJhY2tkcm9wfSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLmR1cmF0aW9ufSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLnRpbWluZ0Z1bmN0aW9ufSBib3RoYCxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ2hpbGRyZW5XcmFwcGVyID0gc3R5bGVkLmRpdih7XG4gIGRpc3BsYXk6IFwiY29udGVudHNcIixcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gTGlnaHRib3goe1xuICBiYWNrZHJvcFJlZixcbiAgcG9ydGFsQ29udGFpbmVyLFxuICBpbml0aWFsRm9jdXMsXG4gIGlzRGlzbWlzc2libGUgPSB0cnVlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlQ2xvc2UsXG4gIGp1c3RpZnlDb250ZW50ID0gXCJjZW50ZXJcIixcbiAgcHJpdmF0ZVByb3BzOiB7IHNraXBQb3J0YWwsIHRhYmJhYmxlT3B0aW9ucyB9ID0ge1xuICAgIHNraXBQb3J0YWw6IGZhbHNlLFxuICB9LFxufTogUHJvcHNXaXRoQ2hpbGRyZW48TGlnaHRib3hQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwb3J0YWxDb250YWluZXJFbGVtZW50ID0gdXNlUG9ydGFsQ29udGFpbmVyRWxlbWVudChwb3J0YWxDb250YWluZXIpO1xuICBjb25zdCBtb2RhbFJlZiA9IHVzZVJlZihudWxsKTtcblxuICBjb25zdCBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyA9IHVzZUNhbGxiYWNrKFxuICAgIChldnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICAvLyBEbyBub3QgY2xvc2Ugb24gY2xpY2sgdGhhdCBvY2N1cnMgb24gZWxlbWVudHMgd2l0aGluIHRoZSBzYW1lIHBvcnRhbCwgZm9yIGVnLCBkcm9wZG93biBhbmQgc2VsZWN0IG1lbnVzXG4gICAgICBpZiAoXG4gICAgICAgIHBvcnRhbENvbnRhaW5lckVsZW1lbnQuY29udGFpbnMoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgJiZcbiAgICAgICAgZXZ0LnRhcmdldCAhPT0gYmFja2Ryb3BSZWY/LmN1cnJlbnRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpc0Rpc21pc3NpYmxlO1xuICAgIH0sXG4gICAgW2JhY2tkcm9wUmVmLCBwb3J0YWxDb250YWluZXJFbGVtZW50LCBpc0Rpc21pc3NpYmxlXVxuICApO1xuXG4gIGNvbnN0IGdldEZvY3VzVGFyZ2V0ID0gKCkgPT4ge1xuICAgIGNvbnN0IGNvbnRhaW5lciA9IG1vZGFsUmVmPy5jdXJyZW50XG4gICAgICA/LmZpcnN0RWxlbWVudENoaWxkIGFzIEhUTUxFbGVtZW50IHwgbnVsbDtcblxuICAgIGNvbnN0IGZvY3VzYWJsZVNlbGVjdG9yID1cbiAgICAgICdhW2hyZWZdLCBidXR0b246bm90KFtkaXNhYmxlZF0pLCBpbnB1dDpub3QoW2Rpc2FibGVkXSksIHNlbGVjdDpub3QoW2Rpc2FibGVkXSksIHRleHRhcmVhOm5vdChbZGlzYWJsZWRdKSwgW3RhYmluZGV4XTpub3QoW3RhYmluZGV4PVwiLTFcIl0pJztcbiAgICBjb25zdCBmaXJzdEZvY3VzYWJsZSA9XG4gICAgICBjb250YWluZXI/LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KGZvY3VzYWJsZVNlbGVjdG9yKTtcbiAgICBpZiAoZmlyc3RGb2N1c2FibGUpIHtcbiAgICAgIHJldHVybiBmaXJzdEZvY3VzYWJsZTtcbiAgICB9XG5cbiAgICByZXR1cm4gY29udGFpbmVyIHx8IGRvY3VtZW50LmJvZHk7XG4gIH07XG5cbiAgY29uc3QgZ2V0SW5pdGlhbEZvY3VzID0gKCkgPT4ge1xuICAgIGlmICh0eXBlb2YgaW5pdGlhbEZvY3VzID09PSBcInN0cmluZ1wiKSB7XG4gICAgICByZXR1cm4gaW5pdGlhbEZvY3VzO1xuICAgIH1cbiAgICByZXR1cm4gaW5pdGlhbEZvY3VzPy5jdXJyZW50ID8/IGdldEZvY3VzVGFyZ2V0KCk7XG4gIH07XG5cbiAgY29uc3QgY29udGVudCA9IChcbiAgICA8U3R5bGVkQmFja2Ryb3BcbiAgICAgIHJlZj17YmFja2Ryb3BSZWZ9XG4gICAgICBqdXN0aWZ5Q29udGVudD17anVzdGlmeUNvbnRlbnR9XG4gICAgICBkYXRhLWRzLWlkPVwiTGlnaHRib3hcIlxuICAgID5cbiAgICAgIDxGb2N1c1RyYXBXcmFwcGVyXG4gICAgICAgIGFjdGl2ZVxuICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgYWxsb3dPdXRzaWRlQ2xpY2s6IHRydWUsIC8vIGFsbG93IGNsaWNrIG9uIG1vYmlsZSBpbiBhbnkgZHJvcGRvd25zXG4gICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IGhhbmRsZUNsaWNrT3V0c2lkZURlYWN0aXZhdGVzLFxuICAgICAgICAgIGVzY2FwZURlYWN0aXZhdGVzOiBpc0Rpc21pc3NpYmxlLCAvLyBkZS1hY3RpdmF0ZSBmb2N1cyB0cmFwIG9uIGVzY2FwZSBrZXlcbiAgICAgICAgICBwcmV2ZW50U2Nyb2xsOiB0cnVlLFxuICAgICAgICAgIGluaXRpYWxGb2N1czogKCkgPT4gZ2V0SW5pdGlhbEZvY3VzKCksXG4gICAgICAgICAgZmFsbGJhY2tGb2N1czogKCkgPT4gZ2V0Rm9jdXNUYXJnZXQoKSxcbiAgICAgICAgICAuLi4odGFiYmFibGVPcHRpb25zICYmIHsgdGFiYmFibGVPcHRpb25zIH0pLFxuICAgICAgICAgIC4uLihoYW5kbGVDbG9zZSAmJiB7IG9uUG9zdERlYWN0aXZhdGU6IGhhbmRsZUNsb3NlIH0pLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICA8U3R5bGVkQ2hpbGRyZW5XcmFwcGVyIHJlZj17bW9kYWxSZWZ9PntjaGlsZHJlbn08L1N0eWxlZENoaWxkcmVuV3JhcHBlcj5cbiAgICAgIDwvRm9jdXNUcmFwV3JhcHBlcj5cbiAgICA8L1N0eWxlZEJhY2tkcm9wPlxuICApO1xuXG4gIC8vIEZvciB0ZXN0aW5nIGFuZCBNb2RhbCBzdG9yeSB3ZSBkb24ndCB3YW50IHRvIHJlbmRlciB0aGUgY29udGVudCBpbnNpZGUgYSBwb3J0YWxcbiAgaWYgKHNraXBQb3J0YWwpIHtcbiAgICByZXR1cm4gY29udGVudDtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPERpYWxvZ0NvbnRleHQuUHJvdmlkZXIgdmFsdWU+XG4gICAgICA8UG9ydGFsIHBvcnRhbENvbnRhaW5lcj17cG9ydGFsQ29udGFpbmVyfT57Y29udGVudH08L1BvcnRhbD5cbiAgICA8L0RpYWxvZ0NvbnRleHQuUHJvdmlkZXI+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0ZxQyJ9 */");function Lightbox({backdropRef,portalContainer,initialFocus,isDismissible=!0,children,handleClose,justifyContent="center",privateProps:{skipPortal,tabbableOptions}={skipPortal:!1}}){let portalContainerElement=(0,_Portal.usePortalContainerElement)(portalContainer),modalRef=(0,_react.useRef)(null),handleClickOutsideDeactivates=(0,_react.useCallback)(evt=>(!portalContainerElement.contains(evt.target)||evt.target===backdropRef?.current)&&isDismissible,[backdropRef,portalContainerElement,isDismissible]),getFocusTarget=()=>{let container=modalRef?.current?.firstElementChild,firstFocusable=container?.querySelector('a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), [tabindex]:not([tabindex="-1"])');return firstFocusable||container||document.body},getInitialFocus=()=>"string"==typeof initialFocus?initialFocus:initialFocus?.current??getFocusTarget(),content=_react.default.createElement(StyledBackdrop,{ref:backdropRef,justifyContent:justifyContent,"data-ds-id":"Lightbox"},_react.default.createElement(_FocusTrapWrapper.FocusTrapWrapper,{active:!0,focusTrapOptions:{allowOutsideClick:!0,clickOutsideDeactivates:handleClickOutsideDeactivates,escapeDeactivates:isDismissible,preventScroll:!0,initialFocus:()=>getInitialFocus(),fallbackFocus:()=>getFocusTarget(),...tabbableOptions&&{tabbableOptions},...handleClose&&{onPostDeactivate:handleClose}}},_react.default.createElement(StyledChildrenWrapper,{ref:modalRef},children)));return skipPortal?content:_react.default.createElement(_DialogContext.DialogContext.Provider,{value:!0},_react.default.createElement(_Portal.Portal,{portalContainer:portalContainer},content))}
|
|
@@ -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
|
-
import React from"react";import styled from"@emotion/styled";import{Container}from"../Container/Container";import{DropdownMenu}from"../DropdownMenu/DropdownMenu";import{Box}from"../Box/Box";import{Column,Columns}from"../Column/Columns";import{Stack}from"../Stack/Stack";import{Text}from"../Typography/Text/Text";import{TextClamped}from"../Typography/TextClamped/TextClamped";import{ColorPickerDropdown}from"../ColorPicker/ColorPickerDropdown";import{useBreakpoints}from"../../shared/useBreakpoints";let StyledDropdownMenuContainer=styled("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=styled("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=styled("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=styled("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=styled("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.createElement(Box,{space:"xxs",bSpace:"zero"},React.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},React.createElement(DropdownMenu,{iconName:"more-horizontal",menuItems:menuItems,onMenuOpen:onMenuOpen,portalContainer:portalContainer,size:"xs"}))),TopRightColorPicker=({colorPickerProps,menuItems,portalContainer,isMobile})=>React.createElement(Box,{space:"xxs",bSpace:"zero"},React.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},React.createElement(ColorPickerDropdown,{portalContainer:portalContainer,...colorPickerProps,menuItems:menuItems})));export function CatalogCard({title,subtitle,dropdownMenuOptions=[],onClick,onDropdownClick,topLeftElement,portalContainer,borderRadius="s",subtitleLines=1,colorPickerProps,"data-e2e-test-id":dataE2eTestId="CatalogCard","data-ds-id":dataDsId="CatalogCard",...ariaAttributes}){let{isMobile}=useBreakpoints(),topRightElement=colorPickerProps?React.createElement(TopRightColorPicker,{colorPickerProps:colorPickerProps,menuItems:dropdownMenuOptions,portalContainer:portalContainer,isMobile:isMobile}):dropdownMenuOptions.length>0?React.createElement(TopRightDropdownMenu,{menuItems:dropdownMenuOptions,onMenuOpen:onDropdownClick,portalContainer:portalContainer,isMobile:isMobile}):null,SubtitleComponent="none"===subtitleLines?Text:TextClamped;return React.createElement(StyledWrapper,null,React.createElement(StyledButton,{onClick:onClick,"aria-label":title}),React.createElement(Container,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,borderRadius:borderRadius,outlined:!0,...ariaAttributes},React.createElement(StyledContainer,{isMobile:isMobile},React.createElement(Box,{space:"m"},React.createElement(Columns,null,React.createElement(Column,{size:"fill"},React.createElement("div",{onClick:onClick},React.createElement(Stack,{vAlignItems:"spaceBetween",space:"s"},topLeftElement,React.createElement(Stack,{space:"xxs",vAlignItems:"bottom"},React.createElement(StyledTitle,null,React.createElement(TextClamped,{size:"m",weight:"bold",lines:2},title)),subtitle&&React.createElement(SubtitleComponent,{size:"s",color:"tertiary",..."none"!==subtitleLines&&{lines:subtitleLines}},subtitle))))),topRightElement&&React.createElement(Column,{size:"narrow"},topRightElement))))))}
|
|
1
|
+
import React from"react";import styled from"@emotion/styled";import{Container}from"../Container/Container";import{DropdownMenu}from"../DropdownMenu/DropdownMenu";import{Box}from"../Box/Box";import{Column,Columns}from"../Column/Columns";import{Stack}from"../Stack/Stack";import{Text}from"../Typography/Text/Text";import{TextClamped}from"../Typography/TextClamped/TextClamped";import{ColorPickerDropdown}from"../ColorPicker/ColorPickerDropdown";import{useBreakpoints}from"../../shared/useBreakpoints";let StyledDropdownMenuContainer=styled("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=styled("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=styled("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=styled("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=styled("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.createElement(Box,{space:"xxs",bSpace:"zero"},React.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},React.createElement(DropdownMenu,{iconName:"more-horizontal",menuItems:menuItems,onMenuOpen:onMenuOpen,portalContainer:portalContainer,size:"xs","aria-label":ariaLabel}))),TopRightColorPicker=({colorPickerProps,menuItems,portalContainer,isMobile})=>React.createElement(Box,{space:"xxs",bSpace:"zero"},React.createElement(StyledDropdownMenuContainer,{isMobile:isMobile},React.createElement(ColorPickerDropdown,{portalContainer:portalContainer,...colorPickerProps,menuItems:menuItems})));export function CatalogCard({title,subtitle,dropdownMenuOptions=[],onClick,onDropdownClick,topLeftElement,portalContainer,borderRadius="s",subtitleLines=1,colorPickerProps,slotProps,"data-e2e-test-id":dataE2eTestId="CatalogCard","data-ds-id":dataDsId="CatalogCard",...ariaAttributes}){let{isMobile}=useBreakpoints(),topRightElement=colorPickerProps?React.createElement(TopRightColorPicker,{colorPickerProps:colorPickerProps,menuItems:dropdownMenuOptions,portalContainer:portalContainer,isMobile:isMobile}):dropdownMenuOptions.length>0?React.createElement(TopRightDropdownMenu,{menuItems:dropdownMenuOptions,onMenuOpen:onDropdownClick,portalContainer:portalContainer,isMobile:isMobile,"aria-label":slotProps?.dropdownMenu?.["aria-label"]}):null,SubtitleComponent="none"===subtitleLines?Text:TextClamped;return React.createElement(StyledWrapper,null,React.createElement(StyledButton,{onClick:onClick,"aria-label":title}),React.createElement(Container,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":dataDsId,borderRadius:borderRadius,outlined:!0,...ariaAttributes},React.createElement(StyledContainer,{isMobile:isMobile},React.createElement(Box,{space:"m"},React.createElement(Columns,null,React.createElement(Column,{size:"fill"},React.createElement("div",{onClick:onClick},React.createElement(Stack,{vAlignItems:"spaceBetween",space:"s"},topLeftElement,React.createElement(Stack,{space:"xxs",vAlignItems:"bottom"},React.createElement(StyledTitle,null,React.createElement(TextClamped,{size:"m",weight:"bold",lines:2},title)),subtitle&&React.createElement(SubtitleComponent,{size:"s",color:"tertiary",..."none"!==subtitleLines&&{lines:subtitleLines}},subtitle))))),topRightElement&&React.createElement(Column,{size:"narrow"},topRightElement))))))}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import React,{useCallback,useRef}from"react";import styled from"@emotion/styled";import{keyframes}from"@emotion/react";import{Portal,usePortalContainerElement}from"../Portal/Portal";import{FocusTrapWrapper}from"../../shared/FocusTrapWrapper";import{useResponsiveStyles}from"../../shared/mediaQueries";import{DialogContext}from"../Patterns/Dialog/DialogContext";export const StyledBackdrop=styled("div",{target:"
|
|
1
|
+
import React,{useCallback,useRef}from"react";import styled from"@emotion/styled";import{keyframes}from"@emotion/react";import{Portal,usePortalContainerElement}from"../Portal/Portal";import{FocusTrapWrapper}from"../../shared/FocusTrapWrapper";import{useResponsiveStyles}from"../../shared/mediaQueries";import{DialogContext}from"../Patterns/Dialog/DialogContext";export const StyledBackdrop=styled("div",{target:"ew3tr1y0",label:"StyledBackdrop"})(({theme,justifyContent})=>{let fadeInBackdrop=keyframes`
|
|
2
2
|
from {
|
|
3
3
|
opacity: ${theme.variables.opacity.hidden};
|
|
4
4
|
}
|
|
5
5
|
to {
|
|
6
6
|
opacity: ${theme.variables.opacity.visible};
|
|
7
7
|
}
|
|
8
|
-
`;return{position:"fixed",top:0,left:0,zIndex:theme.variables.zIndex.modal,width:"100%",height:"100dvh",background:theme.values.color.background.backdrop.default,display:"flex",flexDirection:"column",...useResponsiveStyles({justifyContent:[justifyContent,{top:"flex-start",center:"center"}]}),alignItems:"center",flex:"1 0 auto",animation:`${fadeInBackdrop} ${theme.variables.animation.modalBackdrop.open.duration} ${theme.variables.animation.modalBackdrop.open.timingFunction} both`}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTGlnaHRib3gvTGlnaHRib3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9MaWdodGJveC9MaWdodGJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIHVzZUNhbGxiYWNrLFxuICB1c2VSZWYsXG4gIHR5cGUgUHJvcHNXaXRoQ2hpbGRyZW4sXG4gIHR5cGUgUmVmT2JqZWN0LFxufSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQsIE1RIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB1c2VQb3J0YWxDb250YWluZXJFbGVtZW50LFxuICB0eXBlIFBvcnRhbFByb3BzLFxufSBmcm9tIFwiLi4vUG9ydGFsL1BvcnRhbFwiO1xuaW1wb3J0IHsgRm9jdXNUcmFwV3JhcHBlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvRm9jdXNUcmFwV3JhcHBlclwiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBEaWFsb2dDb250ZXh0IH0gZnJvbSBcIi4uL1BhdHRlcm5zL0RpYWxvZy9EaWFsb2dDb250ZXh0XCI7XG5cbmV4cG9ydCB0eXBlIExpZ2h0Ym94UHJvcHMgPSBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4gJiB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG4gIGJhY2tkcm9wUmVmPzogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgaGFuZGxlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBpc0Rpc21pc3NpYmxlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEEgcmVmIHRvIHRoZSBlbGVtZW50IHRoYXQgc2hvdWxkIHJlY2VpdmUgZm9jdXMgd2hlbiB0aGUgbGlnaHRib3ggb3BlbnMuXG4gICAqIFdoZW4gbm90IHByb3ZpZGVkLCB0aGUgZmlyc3QgZm9jdXNhYmxlIGVsZW1lbnQgaW5zaWRlIHRoZSBsaWdodGJveCBpcyB1c2VkLlxuICAgKi9cbiAgaW5pdGlhbEZvY3VzPzogUmVmT2JqZWN0PEhUTUxFbGVtZW50IHwgU1ZHRWxlbWVudD4gfCBzdHJpbmc7XG4gIGp1c3RpZnlDb250ZW50PzogTVE8TGlnaHRib3hWZXJ0aWNhbEFsaWdubWVudD4gfCBMaWdodGJveFZlcnRpY2FsQWxpZ25tZW50O1xuICBwcml2YXRlUHJvcHM/OiB7XG4gICAgc2tpcFBvcnRhbD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQGludGVybmFsXG4gICAgICogT3B0aW9ucyBwYXNzZWQgdG8gZm9jdXMtdHJhcCdzIHRhYmJhYmxlIGRldGVjdGlvbi5cbiAgICAgKiBVc2UgYHsgZGlzcGxheUNoZWNrOiBcIm5vbmVcIiB9YCBmb3IgdGVzdGluZyB0byBhdm9pZCBKU0RPTSB2aXNpYmlsaXR5IGlzc3Vlcy5cbiAgICAgKi9cbiAgICB0YWJiYWJsZU9wdGlvbnM/OiB7XG4gICAgICBkaXNwbGF5Q2hlY2s/OiBcImZ1bGxcIiB8IFwibGVnYWN5LWZ1bGxcIiB8IFwibm9uLXplcm8tYXJlYVwiIHwgXCJub25lXCI7XG4gICAgfTtcbiAgfTtcbn0gJiBQaWNrPFBvcnRhbFByb3BzLCBcInBvcnRhbENvbnRhaW5lclwiPjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEJhY2tkcm9wID0gc3R5bGVkLmRpdjxQaWNrPExpZ2h0Ym94UHJvcHMsIFwianVzdGlmeUNvbnRlbnRcIj4+KFxuICAoeyB0aGVtZSwganVzdGlmeUNvbnRlbnQgfSkgPT4ge1xuICAgIGNvbnN0IGZhZGVJbkJhY2tkcm9wID0ga2V5ZnJhbWVzYFxuICAgIGZyb20ge1xuICAgICAgb3BhY2l0eTogJHt0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW59O1xuICAgIH1cbiAgICB0byB7XG4gICAgICBvcGFjaXR5OiAke3RoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LnZpc2libGV9O1xuICAgIH1cbiAgYDtcblxuICAgIHJldHVybiB7XG4gICAgICBwb3NpdGlvbjogXCJmaXhlZFwiLFxuICAgICAgdG9wOiAwLFxuICAgICAgbGVmdDogMCxcbiAgICAgIHpJbmRleDogdGhlbWUudmFyaWFibGVzLnpJbmRleC5tb2RhbCxcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGhlaWdodDogXCIxMDBkdmhcIixcbiAgICAgIGJhY2tncm91bmQ6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmJhY2tkcm9wLmRlZmF1bHQsXG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gICAgICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICAgICAganVzdGlmeUNvbnRlbnQ6IFtcbiAgICAgICAgICBqdXN0aWZ5Q29udGVudCxcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0b3A6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIH0sXG4gICAgICAgIF0sXG4gICAgICB9KSxcbiAgICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgICBmbGV4OiBcIjEgMCBhdXRvXCIsXG4gICAgICBhbmltYXRpb246IGAke2ZhZGVJbkJhY2tkcm9wfSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLmR1cmF0aW9ufSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLnRpbWluZ0Z1bmN0aW9ufSBib3RoYCxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ2hpbGRyZW5XcmFwcGVyID0gc3R5bGVkLmRpdih7XG4gIGRpc3BsYXk6IFwiY29udGVudHNcIixcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gTGlnaHRib3goe1xuICBiYWNrZHJvcFJlZixcbiAgcG9ydGFsQ29udGFpbmVyLFxuICBpbml0aWFsRm9jdXMsXG4gIGlzRGlzbWlzc2libGUgPSB0cnVlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlQ2xvc2UsXG4gIGp1c3RpZnlDb250ZW50ID0gXCJjZW50ZXJcIixcbiAgcHJpdmF0ZVByb3BzOiB7IHNraXBQb3J0YWwsIHRhYmJhYmxlT3B0aW9ucyB9ID0ge1xuICAgIHNraXBQb3J0YWw6IGZhbHNlLFxuICB9LFxufTogUHJvcHNXaXRoQ2hpbGRyZW48TGlnaHRib3hQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwb3J0YWxDb250YWluZXJFbGVtZW50ID0gdXNlUG9ydGFsQ29udGFpbmVyRWxlbWVudChwb3J0YWxDb250YWluZXIpO1xuICBjb25zdCBtb2RhbFJlZiA9IHVzZVJlZihudWxsKTtcblxuICBjb25zdCBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyA9IHVzZUNhbGxiYWNrKFxuICAgIChldnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICAvLyBEbyBub3QgY2xvc2Ugb24gY2xpY2sgdGhhdCBvY2N1cnMgb24gZWxlbWVudHMgd2l0aGluIHRoZSBzYW1lIHBvcnRhbCwgZm9yIGVnLCBkcm9wZG93biBhbmQgc2VsZWN0IG1lbnVzXG4gICAgICBpZiAoXG4gICAgICAgIHBvcnRhbENvbnRhaW5lckVsZW1lbnQuY29udGFpbnMoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgJiZcbiAgICAgICAgZXZ0LnRhcmdldCAhPT0gYmFja2Ryb3BSZWY/LmN1cnJlbnRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpc0Rpc21pc3NpYmxlO1xuICAgIH0sXG4gICAgW2JhY2tkcm9wUmVmLCBwb3J0YWxDb250YWluZXJFbGVtZW50LCBpc0Rpc21pc3NpYmxlXVxuICApO1xuXG4gIGNvbnN0IGdldEZvY3VzVGFyZ2V0ID0gKCkgPT4ge1xuICAgIGNvbnN0IGNvbnRhaW5lciA9IG1vZGFsUmVmPy5jdXJyZW50XG4gICAgICA/LmZpcnN0RWxlbWVudENoaWxkIGFzIEhUTUxFbGVtZW50IHwgbnVsbDtcblxuICAgIGNvbnN0IGZvY3VzYWJsZVNlbGVjdG9yID1cbiAgICAgICdhW2hyZWZdLCBidXR0b246bm90KFtkaXNhYmxlZF0pLCBpbnB1dDpub3QoW2Rpc2FibGVkXSksIHNlbGVjdDpub3QoW2Rpc2FibGVkXSksIHRleHRhcmVhOm5vdChbZGlzYWJsZWRdKSwgW3RhYmluZGV4XTpub3QoW3RhYmluZGV4PVwiLTFcIl0pJztcbiAgICBjb25zdCBmaXJzdEZvY3VzYWJsZSA9XG4gICAgICBjb250YWluZXI/LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KGZvY3VzYWJsZVNlbGVjdG9yKTtcbiAgICBpZiAoZmlyc3RGb2N1c2FibGUpIHtcbiAgICAgIHJldHVybiBmaXJzdEZvY3VzYWJsZTtcbiAgICB9XG5cbiAgICByZXR1cm4gY29udGFpbmVyIHx8IGRvY3VtZW50LmJvZHk7XG4gIH07XG5cbiAgY29uc3QgZ2V0SW5pdGlhbEZvY3VzID0gKCkgPT4ge1xuICAgIGlmICh0eXBlb2YgaW5pdGlhbEZvY3VzID09PSBcInN0cmluZ1wiKSB7XG4gICAgICByZXR1cm4gaW5pdGlhbEZvY3VzO1xuICAgIH1cbiAgICByZXR1cm4gaW5pdGlhbEZvY3VzPy5jdXJyZW50ID8/IGdldEZvY3VzVGFyZ2V0KCk7XG4gIH07XG5cbiAgY29uc3QgY29udGVudCA9IChcbiAgICA8U3R5bGVkQmFja2Ryb3BcbiAgICAgIHJlZj17YmFja2Ryb3BSZWZ9XG4gICAgICBqdXN0aWZ5Q29udGVudD17anVzdGlmeUNvbnRlbnR9XG4gICAgICBkYXRhLWRzLWlkPVwiTGlnaHRib3hcIlxuICAgID5cbiAgICAgIDxGb2N1c1RyYXBXcmFwcGVyXG4gICAgICAgIGFjdGl2ZVxuICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgYWxsb3dPdXRzaWRlQ2xpY2s6IHRydWUsIC8vIGFsbG93IGNsaWNrIG9uIG1vYmlsZSBpbiBhbnkgZHJvcGRvd25zXG4gICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IGhhbmRsZUNsaWNrT3V0c2lkZURlYWN0aXZhdGVzLFxuICAgICAgICAgIGVzY2FwZURlYWN0aXZhdGVzOiBpc0Rpc21pc3NpYmxlLCAvLyBkZS1hY3RpdmF0ZSBmb2N1cyB0cmFwIG9uIGVzY2FwZSBrZXlcbiAgICAgICAgICBwcmV2ZW50U2Nyb2xsOiB0cnVlLFxuICAgICAgICAgIGluaXRpYWxGb2N1czogKCkgPT4gZ2V0SW5pdGlhbEZvY3VzKCksXG4gICAgICAgICAgZmFsbGJhY2tGb2N1czogKCkgPT4gZ2V0Rm9jdXNUYXJnZXQoKSxcbiAgICAgICAgICAuLi4odGFiYmFibGVPcHRpb25zICYmIHsgdGFiYmFibGVPcHRpb25zIH0pLFxuICAgICAgICAgIC4uLihoYW5kbGVDbG9zZSAmJiB7IG9uUG9zdERlYWN0aXZhdGU6IGhhbmRsZUNsb3NlIH0pLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICA8U3R5bGVkQ2hpbGRyZW5XcmFwcGVyIHJlZj17bW9kYWxSZWZ9PlxuICAgICAgICAgIDxEaWFsb2dDb250ZXh0LlByb3ZpZGVyIHZhbHVlPntjaGlsZHJlbn08L0RpYWxvZ0NvbnRleHQuUHJvdmlkZXI+XG4gICAgICAgIDwvU3R5bGVkQ2hpbGRyZW5XcmFwcGVyPlxuICAgICAgPC9Gb2N1c1RyYXBXcmFwcGVyPlxuICAgIDwvU3R5bGVkQmFja2Ryb3A+XG4gICk7XG5cbiAgLy8gRm9yIHRlc3RpbmcgYW5kIE1vZGFsIHN0b3J5IHdlIGRvbid0IHdhbnQgdG8gcmVuZGVyIHRoZSBjb250ZW50IGluc2lkZSBhIHBvcnRhbFxuICBpZiAoc2tpcFBvcnRhbCkge1xuICAgIHJldHVybiBjb250ZW50O1xuICB9XG5cbiAgcmV0dXJuIDxQb3J0YWwgcG9ydGFsQ29udGFpbmVyPXtwb3J0YWxDb250YWluZXJ9Pntjb250ZW50fTwvUG9ydGFsPjtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQzhCIn0= */");export const StyledChildrenWrapper=styled("div",{target:"e1v68oqn1",label:"StyledChildrenWrapper"})({display:"contents"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTGlnaHRib3gvTGlnaHRib3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9MaWdodGJveC9MaWdodGJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIHVzZUNhbGxiYWNrLFxuICB1c2VSZWYsXG4gIHR5cGUgUHJvcHNXaXRoQ2hpbGRyZW4sXG4gIHR5cGUgUmVmT2JqZWN0LFxufSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQsIE1RIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB1c2VQb3J0YWxDb250YWluZXJFbGVtZW50LFxuICB0eXBlIFBvcnRhbFByb3BzLFxufSBmcm9tIFwiLi4vUG9ydGFsL1BvcnRhbFwiO1xuaW1wb3J0IHsgRm9jdXNUcmFwV3JhcHBlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvRm9jdXNUcmFwV3JhcHBlclwiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBEaWFsb2dDb250ZXh0IH0gZnJvbSBcIi4uL1BhdHRlcm5zL0RpYWxvZy9EaWFsb2dDb250ZXh0XCI7XG5cbmV4cG9ydCB0eXBlIExpZ2h0Ym94UHJvcHMgPSBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4gJiB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG4gIGJhY2tkcm9wUmVmPzogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgaGFuZGxlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBpc0Rpc21pc3NpYmxlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEEgcmVmIHRvIHRoZSBlbGVtZW50IHRoYXQgc2hvdWxkIHJlY2VpdmUgZm9jdXMgd2hlbiB0aGUgbGlnaHRib3ggb3BlbnMuXG4gICAqIFdoZW4gbm90IHByb3ZpZGVkLCB0aGUgZmlyc3QgZm9jdXNhYmxlIGVsZW1lbnQgaW5zaWRlIHRoZSBsaWdodGJveCBpcyB1c2VkLlxuICAgKi9cbiAgaW5pdGlhbEZvY3VzPzogUmVmT2JqZWN0PEhUTUxFbGVtZW50IHwgU1ZHRWxlbWVudD4gfCBzdHJpbmc7XG4gIGp1c3RpZnlDb250ZW50PzogTVE8TGlnaHRib3hWZXJ0aWNhbEFsaWdubWVudD4gfCBMaWdodGJveFZlcnRpY2FsQWxpZ25tZW50O1xuICBwcml2YXRlUHJvcHM/OiB7XG4gICAgc2tpcFBvcnRhbD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQGludGVybmFsXG4gICAgICogT3B0aW9ucyBwYXNzZWQgdG8gZm9jdXMtdHJhcCdzIHRhYmJhYmxlIGRldGVjdGlvbi5cbiAgICAgKiBVc2UgYHsgZGlzcGxheUNoZWNrOiBcIm5vbmVcIiB9YCBmb3IgdGVzdGluZyB0byBhdm9pZCBKU0RPTSB2aXNpYmlsaXR5IGlzc3Vlcy5cbiAgICAgKi9cbiAgICB0YWJiYWJsZU9wdGlvbnM/OiB7XG4gICAgICBkaXNwbGF5Q2hlY2s/OiBcImZ1bGxcIiB8IFwibGVnYWN5LWZ1bGxcIiB8IFwibm9uLXplcm8tYXJlYVwiIHwgXCJub25lXCI7XG4gICAgfTtcbiAgfTtcbn0gJiBQaWNrPFBvcnRhbFByb3BzLCBcInBvcnRhbENvbnRhaW5lclwiPjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEJhY2tkcm9wID0gc3R5bGVkLmRpdjxQaWNrPExpZ2h0Ym94UHJvcHMsIFwianVzdGlmeUNvbnRlbnRcIj4+KFxuICAoeyB0aGVtZSwganVzdGlmeUNvbnRlbnQgfSkgPT4ge1xuICAgIGNvbnN0IGZhZGVJbkJhY2tkcm9wID0ga2V5ZnJhbWVzYFxuICAgIGZyb20ge1xuICAgICAgb3BhY2l0eTogJHt0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW59O1xuICAgIH1cbiAgICB0byB7XG4gICAgICBvcGFjaXR5OiAke3RoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LnZpc2libGV9O1xuICAgIH1cbiAgYDtcblxuICAgIHJldHVybiB7XG4gICAgICBwb3NpdGlvbjogXCJmaXhlZFwiLFxuICAgICAgdG9wOiAwLFxuICAgICAgbGVmdDogMCxcbiAgICAgIHpJbmRleDogdGhlbWUudmFyaWFibGVzLnpJbmRleC5tb2RhbCxcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGhlaWdodDogXCIxMDBkdmhcIixcbiAgICAgIGJhY2tncm91bmQ6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmJhY2tkcm9wLmRlZmF1bHQsXG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gICAgICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICAgICAganVzdGlmeUNvbnRlbnQ6IFtcbiAgICAgICAgICBqdXN0aWZ5Q29udGVudCxcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0b3A6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIH0sXG4gICAgICAgIF0sXG4gICAgICB9KSxcbiAgICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgICBmbGV4OiBcIjEgMCBhdXRvXCIsXG4gICAgICBhbmltYXRpb246IGAke2ZhZGVJbkJhY2tkcm9wfSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLmR1cmF0aW9ufSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLnRpbWluZ0Z1bmN0aW9ufSBib3RoYCxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ2hpbGRyZW5XcmFwcGVyID0gc3R5bGVkLmRpdih7XG4gIGRpc3BsYXk6IFwiY29udGVudHNcIixcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gTGlnaHRib3goe1xuICBiYWNrZHJvcFJlZixcbiAgcG9ydGFsQ29udGFpbmVyLFxuICBpbml0aWFsRm9jdXMsXG4gIGlzRGlzbWlzc2libGUgPSB0cnVlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlQ2xvc2UsXG4gIGp1c3RpZnlDb250ZW50ID0gXCJjZW50ZXJcIixcbiAgcHJpdmF0ZVByb3BzOiB7IHNraXBQb3J0YWwsIHRhYmJhYmxlT3B0aW9ucyB9ID0ge1xuICAgIHNraXBQb3J0YWw6IGZhbHNlLFxuICB9LFxufTogUHJvcHNXaXRoQ2hpbGRyZW48TGlnaHRib3hQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwb3J0YWxDb250YWluZXJFbGVtZW50ID0gdXNlUG9ydGFsQ29udGFpbmVyRWxlbWVudChwb3J0YWxDb250YWluZXIpO1xuICBjb25zdCBtb2RhbFJlZiA9IHVzZVJlZihudWxsKTtcblxuICBjb25zdCBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyA9IHVzZUNhbGxiYWNrKFxuICAgIChldnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICAvLyBEbyBub3QgY2xvc2Ugb24gY2xpY2sgdGhhdCBvY2N1cnMgb24gZWxlbWVudHMgd2l0aGluIHRoZSBzYW1lIHBvcnRhbCwgZm9yIGVnLCBkcm9wZG93biBhbmQgc2VsZWN0IG1lbnVzXG4gICAgICBpZiAoXG4gICAgICAgIHBvcnRhbENvbnRhaW5lckVsZW1lbnQuY29udGFpbnMoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgJiZcbiAgICAgICAgZXZ0LnRhcmdldCAhPT0gYmFja2Ryb3BSZWY/LmN1cnJlbnRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpc0Rpc21pc3NpYmxlO1xuICAgIH0sXG4gICAgW2JhY2tkcm9wUmVmLCBwb3J0YWxDb250YWluZXJFbGVtZW50LCBpc0Rpc21pc3NpYmxlXVxuICApO1xuXG4gIGNvbnN0IGdldEZvY3VzVGFyZ2V0ID0gKCkgPT4ge1xuICAgIGNvbnN0IGNvbnRhaW5lciA9IG1vZGFsUmVmPy5jdXJyZW50XG4gICAgICA/LmZpcnN0RWxlbWVudENoaWxkIGFzIEhUTUxFbGVtZW50IHwgbnVsbDtcblxuICAgIGNvbnN0IGZvY3VzYWJsZVNlbGVjdG9yID1cbiAgICAgICdhW2hyZWZdLCBidXR0b246bm90KFtkaXNhYmxlZF0pLCBpbnB1dDpub3QoW2Rpc2FibGVkXSksIHNlbGVjdDpub3QoW2Rpc2FibGVkXSksIHRleHRhcmVhOm5vdChbZGlzYWJsZWRdKSwgW3RhYmluZGV4XTpub3QoW3RhYmluZGV4PVwiLTFcIl0pJztcbiAgICBjb25zdCBmaXJzdEZvY3VzYWJsZSA9XG4gICAgICBjb250YWluZXI/LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KGZvY3VzYWJsZVNlbGVjdG9yKTtcbiAgICBpZiAoZmlyc3RGb2N1c2FibGUpIHtcbiAgICAgIHJldHVybiBmaXJzdEZvY3VzYWJsZTtcbiAgICB9XG5cbiAgICByZXR1cm4gY29udGFpbmVyIHx8IGRvY3VtZW50LmJvZHk7XG4gIH07XG5cbiAgY29uc3QgZ2V0SW5pdGlhbEZvY3VzID0gKCkgPT4ge1xuICAgIGlmICh0eXBlb2YgaW5pdGlhbEZvY3VzID09PSBcInN0cmluZ1wiKSB7XG4gICAgICByZXR1cm4gaW5pdGlhbEZvY3VzO1xuICAgIH1cbiAgICByZXR1cm4gaW5pdGlhbEZvY3VzPy5jdXJyZW50ID8/IGdldEZvY3VzVGFyZ2V0KCk7XG4gIH07XG5cbiAgY29uc3QgY29udGVudCA9IChcbiAgICA8U3R5bGVkQmFja2Ryb3BcbiAgICAgIHJlZj17YmFja2Ryb3BSZWZ9XG4gICAgICBqdXN0aWZ5Q29udGVudD17anVzdGlmeUNvbnRlbnR9XG4gICAgICBkYXRhLWRzLWlkPVwiTGlnaHRib3hcIlxuICAgID5cbiAgICAgIDxGb2N1c1RyYXBXcmFwcGVyXG4gICAgICAgIGFjdGl2ZVxuICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgYWxsb3dPdXRzaWRlQ2xpY2s6IHRydWUsIC8vIGFsbG93IGNsaWNrIG9uIG1vYmlsZSBpbiBhbnkgZHJvcGRvd25zXG4gICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IGhhbmRsZUNsaWNrT3V0c2lkZURlYWN0aXZhdGVzLFxuICAgICAgICAgIGVzY2FwZURlYWN0aXZhdGVzOiBpc0Rpc21pc3NpYmxlLCAvLyBkZS1hY3RpdmF0ZSBmb2N1cyB0cmFwIG9uIGVzY2FwZSBrZXlcbiAgICAgICAgICBwcmV2ZW50U2Nyb2xsOiB0cnVlLFxuICAgICAgICAgIGluaXRpYWxGb2N1czogKCkgPT4gZ2V0SW5pdGlhbEZvY3VzKCksXG4gICAgICAgICAgZmFsbGJhY2tGb2N1czogKCkgPT4gZ2V0Rm9jdXNUYXJnZXQoKSxcbiAgICAgICAgICAuLi4odGFiYmFibGVPcHRpb25zICYmIHsgdGFiYmFibGVPcHRpb25zIH0pLFxuICAgICAgICAgIC4uLihoYW5kbGVDbG9zZSAmJiB7IG9uUG9zdERlYWN0aXZhdGU6IGhhbmRsZUNsb3NlIH0pLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICA8U3R5bGVkQ2hpbGRyZW5XcmFwcGVyIHJlZj17bW9kYWxSZWZ9PlxuICAgICAgICAgIDxEaWFsb2dDb250ZXh0LlByb3ZpZGVyIHZhbHVlPntjaGlsZHJlbn08L0RpYWxvZ0NvbnRleHQuUHJvdmlkZXI+XG4gICAgICAgIDwvU3R5bGVkQ2hpbGRyZW5XcmFwcGVyPlxuICAgICAgPC9Gb2N1c1RyYXBXcmFwcGVyPlxuICAgIDwvU3R5bGVkQmFja2Ryb3A+XG4gICk7XG5cbiAgLy8gRm9yIHRlc3RpbmcgYW5kIE1vZGFsIHN0b3J5IHdlIGRvbid0IHdhbnQgdG8gcmVuZGVyIHRoZSBjb250ZW50IGluc2lkZSBhIHBvcnRhbFxuICBpZiAoc2tpcFBvcnRhbCkge1xuICAgIHJldHVybiBjb250ZW50O1xuICB9XG5cbiAgcmV0dXJuIDxQb3J0YWwgcG9ydGFsQ29udGFpbmVyPXtwb3J0YWxDb250YWluZXJ9Pntjb250ZW50fTwvUG9ydGFsPjtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRnFDIn0= */");export function Lightbox({backdropRef,portalContainer,initialFocus,isDismissible=!0,children,handleClose,justifyContent="center",privateProps:{skipPortal,tabbableOptions}={skipPortal:!1}}){let portalContainerElement=usePortalContainerElement(portalContainer),modalRef=useRef(null),handleClickOutsideDeactivates=useCallback(evt=>(!portalContainerElement.contains(evt.target)||evt.target===backdropRef?.current)&&isDismissible,[backdropRef,portalContainerElement,isDismissible]),getFocusTarget=()=>{let container=modalRef?.current?.firstElementChild,firstFocusable=container?.querySelector('a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), [tabindex]:not([tabindex="-1"])');return firstFocusable||container||document.body},getInitialFocus=()=>"string"==typeof initialFocus?initialFocus:initialFocus?.current??getFocusTarget(),content=React.createElement(StyledBackdrop,{ref:backdropRef,justifyContent:justifyContent,"data-ds-id":"Lightbox"},React.createElement(FocusTrapWrapper,{active:!0,focusTrapOptions:{allowOutsideClick:!0,clickOutsideDeactivates:handleClickOutsideDeactivates,escapeDeactivates:isDismissible,preventScroll:!0,initialFocus:()=>getInitialFocus(),fallbackFocus:()=>getFocusTarget(),...tabbableOptions&&{tabbableOptions},...handleClose&&{onPostDeactivate:handleClose}}},React.createElement(StyledChildrenWrapper,{ref:modalRef},React.createElement(DialogContext.Provider,{value:!0},children))));return skipPortal?content:React.createElement(Portal,{portalContainer:portalContainer},content)}
|
|
8
|
+
`;return{position:"fixed",top:0,left:0,zIndex:theme.variables.zIndex.modal,width:"100%",height:"100dvh",background:theme.values.color.background.backdrop.default,display:"flex",flexDirection:"column",...useResponsiveStyles({justifyContent:[justifyContent,{top:"flex-start",center:"center"}]}),alignItems:"center",flex:"1 0 auto",animation:`${fadeInBackdrop} ${theme.variables.animation.modalBackdrop.open.duration} ${theme.variables.animation.modalBackdrop.open.timingFunction} both`}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTGlnaHRib3gvTGlnaHRib3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9MaWdodGJveC9MaWdodGJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIHVzZUNhbGxiYWNrLFxuICB1c2VSZWYsXG4gIHR5cGUgUHJvcHNXaXRoQ2hpbGRyZW4sXG4gIHR5cGUgUmVmT2JqZWN0LFxufSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQsIE1RIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB1c2VQb3J0YWxDb250YWluZXJFbGVtZW50LFxuICB0eXBlIFBvcnRhbFByb3BzLFxufSBmcm9tIFwiLi4vUG9ydGFsL1BvcnRhbFwiO1xuaW1wb3J0IHsgRm9jdXNUcmFwV3JhcHBlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvRm9jdXNUcmFwV3JhcHBlclwiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBEaWFsb2dDb250ZXh0IH0gZnJvbSBcIi4uL1BhdHRlcm5zL0RpYWxvZy9EaWFsb2dDb250ZXh0XCI7XG5cbmV4cG9ydCB0eXBlIExpZ2h0Ym94UHJvcHMgPSBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4gJiB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG4gIGJhY2tkcm9wUmVmPzogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgaGFuZGxlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBpc0Rpc21pc3NpYmxlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEEgcmVmIHRvIHRoZSBlbGVtZW50IHRoYXQgc2hvdWxkIHJlY2VpdmUgZm9jdXMgd2hlbiB0aGUgbGlnaHRib3ggb3BlbnMuXG4gICAqIFdoZW4gbm90IHByb3ZpZGVkLCB0aGUgZmlyc3QgZm9jdXNhYmxlIGVsZW1lbnQgaW5zaWRlIHRoZSBsaWdodGJveCBpcyB1c2VkLlxuICAgKi9cbiAgaW5pdGlhbEZvY3VzPzogUmVmT2JqZWN0PEhUTUxFbGVtZW50IHwgU1ZHRWxlbWVudD4gfCBzdHJpbmc7XG4gIGp1c3RpZnlDb250ZW50PzogTVE8TGlnaHRib3hWZXJ0aWNhbEFsaWdubWVudD4gfCBMaWdodGJveFZlcnRpY2FsQWxpZ25tZW50O1xuICBwcml2YXRlUHJvcHM/OiB7XG4gICAgc2tpcFBvcnRhbD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQGludGVybmFsXG4gICAgICogT3B0aW9ucyBwYXNzZWQgdG8gZm9jdXMtdHJhcCdzIHRhYmJhYmxlIGRldGVjdGlvbi5cbiAgICAgKiBVc2UgYHsgZGlzcGxheUNoZWNrOiBcIm5vbmVcIiB9YCBmb3IgdGVzdGluZyB0byBhdm9pZCBKU0RPTSB2aXNpYmlsaXR5IGlzc3Vlcy5cbiAgICAgKi9cbiAgICB0YWJiYWJsZU9wdGlvbnM/OiB7XG4gICAgICBkaXNwbGF5Q2hlY2s/OiBcImZ1bGxcIiB8IFwibGVnYWN5LWZ1bGxcIiB8IFwibm9uLXplcm8tYXJlYVwiIHwgXCJub25lXCI7XG4gICAgfTtcbiAgfTtcbn0gJiBQaWNrPFBvcnRhbFByb3BzLCBcInBvcnRhbENvbnRhaW5lclwiPjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEJhY2tkcm9wID0gc3R5bGVkLmRpdjxQaWNrPExpZ2h0Ym94UHJvcHMsIFwianVzdGlmeUNvbnRlbnRcIj4+KFxuICAoeyB0aGVtZSwganVzdGlmeUNvbnRlbnQgfSkgPT4ge1xuICAgIGNvbnN0IGZhZGVJbkJhY2tkcm9wID0ga2V5ZnJhbWVzYFxuICAgIGZyb20ge1xuICAgICAgb3BhY2l0eTogJHt0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW59O1xuICAgIH1cbiAgICB0byB7XG4gICAgICBvcGFjaXR5OiAke3RoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LnZpc2libGV9O1xuICAgIH1cbiAgYDtcblxuICAgIHJldHVybiB7XG4gICAgICBwb3NpdGlvbjogXCJmaXhlZFwiLFxuICAgICAgdG9wOiAwLFxuICAgICAgbGVmdDogMCxcbiAgICAgIHpJbmRleDogdGhlbWUudmFyaWFibGVzLnpJbmRleC5tb2RhbCxcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGhlaWdodDogXCIxMDBkdmhcIixcbiAgICAgIGJhY2tncm91bmQ6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmJhY2tkcm9wLmRlZmF1bHQsXG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gICAgICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICAgICAganVzdGlmeUNvbnRlbnQ6IFtcbiAgICAgICAgICBqdXN0aWZ5Q29udGVudCxcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0b3A6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIH0sXG4gICAgICAgIF0sXG4gICAgICB9KSxcbiAgICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgICBmbGV4OiBcIjEgMCBhdXRvXCIsXG4gICAgICBhbmltYXRpb246IGAke2ZhZGVJbkJhY2tkcm9wfSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLmR1cmF0aW9ufSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLnRpbWluZ0Z1bmN0aW9ufSBib3RoYCxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ2hpbGRyZW5XcmFwcGVyID0gc3R5bGVkLmRpdih7XG4gIGRpc3BsYXk6IFwiY29udGVudHNcIixcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gTGlnaHRib3goe1xuICBiYWNrZHJvcFJlZixcbiAgcG9ydGFsQ29udGFpbmVyLFxuICBpbml0aWFsRm9jdXMsXG4gIGlzRGlzbWlzc2libGUgPSB0cnVlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlQ2xvc2UsXG4gIGp1c3RpZnlDb250ZW50ID0gXCJjZW50ZXJcIixcbiAgcHJpdmF0ZVByb3BzOiB7IHNraXBQb3J0YWwsIHRhYmJhYmxlT3B0aW9ucyB9ID0ge1xuICAgIHNraXBQb3J0YWw6IGZhbHNlLFxuICB9LFxufTogUHJvcHNXaXRoQ2hpbGRyZW48TGlnaHRib3hQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwb3J0YWxDb250YWluZXJFbGVtZW50ID0gdXNlUG9ydGFsQ29udGFpbmVyRWxlbWVudChwb3J0YWxDb250YWluZXIpO1xuICBjb25zdCBtb2RhbFJlZiA9IHVzZVJlZihudWxsKTtcblxuICBjb25zdCBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyA9IHVzZUNhbGxiYWNrKFxuICAgIChldnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICAvLyBEbyBub3QgY2xvc2Ugb24gY2xpY2sgdGhhdCBvY2N1cnMgb24gZWxlbWVudHMgd2l0aGluIHRoZSBzYW1lIHBvcnRhbCwgZm9yIGVnLCBkcm9wZG93biBhbmQgc2VsZWN0IG1lbnVzXG4gICAgICBpZiAoXG4gICAgICAgIHBvcnRhbENvbnRhaW5lckVsZW1lbnQuY29udGFpbnMoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgJiZcbiAgICAgICAgZXZ0LnRhcmdldCAhPT0gYmFja2Ryb3BSZWY/LmN1cnJlbnRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpc0Rpc21pc3NpYmxlO1xuICAgIH0sXG4gICAgW2JhY2tkcm9wUmVmLCBwb3J0YWxDb250YWluZXJFbGVtZW50LCBpc0Rpc21pc3NpYmxlXVxuICApO1xuXG4gIGNvbnN0IGdldEZvY3VzVGFyZ2V0ID0gKCkgPT4ge1xuICAgIGNvbnN0IGNvbnRhaW5lciA9IG1vZGFsUmVmPy5jdXJyZW50XG4gICAgICA/LmZpcnN0RWxlbWVudENoaWxkIGFzIEhUTUxFbGVtZW50IHwgbnVsbDtcblxuICAgIGNvbnN0IGZvY3VzYWJsZVNlbGVjdG9yID1cbiAgICAgICdhW2hyZWZdLCBidXR0b246bm90KFtkaXNhYmxlZF0pLCBpbnB1dDpub3QoW2Rpc2FibGVkXSksIHNlbGVjdDpub3QoW2Rpc2FibGVkXSksIHRleHRhcmVhOm5vdChbZGlzYWJsZWRdKSwgW3RhYmluZGV4XTpub3QoW3RhYmluZGV4PVwiLTFcIl0pJztcbiAgICBjb25zdCBmaXJzdEZvY3VzYWJsZSA9XG4gICAgICBjb250YWluZXI/LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KGZvY3VzYWJsZVNlbGVjdG9yKTtcbiAgICBpZiAoZmlyc3RGb2N1c2FibGUpIHtcbiAgICAgIHJldHVybiBmaXJzdEZvY3VzYWJsZTtcbiAgICB9XG5cbiAgICByZXR1cm4gY29udGFpbmVyIHx8IGRvY3VtZW50LmJvZHk7XG4gIH07XG5cbiAgY29uc3QgZ2V0SW5pdGlhbEZvY3VzID0gKCkgPT4ge1xuICAgIGlmICh0eXBlb2YgaW5pdGlhbEZvY3VzID09PSBcInN0cmluZ1wiKSB7XG4gICAgICByZXR1cm4gaW5pdGlhbEZvY3VzO1xuICAgIH1cbiAgICByZXR1cm4gaW5pdGlhbEZvY3VzPy5jdXJyZW50ID8/IGdldEZvY3VzVGFyZ2V0KCk7XG4gIH07XG5cbiAgY29uc3QgY29udGVudCA9IChcbiAgICA8U3R5bGVkQmFja2Ryb3BcbiAgICAgIHJlZj17YmFja2Ryb3BSZWZ9XG4gICAgICBqdXN0aWZ5Q29udGVudD17anVzdGlmeUNvbnRlbnR9XG4gICAgICBkYXRhLWRzLWlkPVwiTGlnaHRib3hcIlxuICAgID5cbiAgICAgIDxGb2N1c1RyYXBXcmFwcGVyXG4gICAgICAgIGFjdGl2ZVxuICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgYWxsb3dPdXRzaWRlQ2xpY2s6IHRydWUsIC8vIGFsbG93IGNsaWNrIG9uIG1vYmlsZSBpbiBhbnkgZHJvcGRvd25zXG4gICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IGhhbmRsZUNsaWNrT3V0c2lkZURlYWN0aXZhdGVzLFxuICAgICAgICAgIGVzY2FwZURlYWN0aXZhdGVzOiBpc0Rpc21pc3NpYmxlLCAvLyBkZS1hY3RpdmF0ZSBmb2N1cyB0cmFwIG9uIGVzY2FwZSBrZXlcbiAgICAgICAgICBwcmV2ZW50U2Nyb2xsOiB0cnVlLFxuICAgICAgICAgIGluaXRpYWxGb2N1czogKCkgPT4gZ2V0SW5pdGlhbEZvY3VzKCksXG4gICAgICAgICAgZmFsbGJhY2tGb2N1czogKCkgPT4gZ2V0Rm9jdXNUYXJnZXQoKSxcbiAgICAgICAgICAuLi4odGFiYmFibGVPcHRpb25zICYmIHsgdGFiYmFibGVPcHRpb25zIH0pLFxuICAgICAgICAgIC4uLihoYW5kbGVDbG9zZSAmJiB7IG9uUG9zdERlYWN0aXZhdGU6IGhhbmRsZUNsb3NlIH0pLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICA8U3R5bGVkQ2hpbGRyZW5XcmFwcGVyIHJlZj17bW9kYWxSZWZ9PntjaGlsZHJlbn08L1N0eWxlZENoaWxkcmVuV3JhcHBlcj5cbiAgICAgIDwvRm9jdXNUcmFwV3JhcHBlcj5cbiAgICA8L1N0eWxlZEJhY2tkcm9wPlxuICApO1xuXG4gIC8vIEZvciB0ZXN0aW5nIGFuZCBNb2RhbCBzdG9yeSB3ZSBkb24ndCB3YW50IHRvIHJlbmRlciB0aGUgY29udGVudCBpbnNpZGUgYSBwb3J0YWxcbiAgaWYgKHNraXBQb3J0YWwpIHtcbiAgICByZXR1cm4gY29udGVudDtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPERpYWxvZ0NvbnRleHQuUHJvdmlkZXIgdmFsdWU+XG4gICAgICA8UG9ydGFsIHBvcnRhbENvbnRhaW5lcj17cG9ydGFsQ29udGFpbmVyfT57Y29udGVudH08L1BvcnRhbD5cbiAgICA8L0RpYWxvZ0NvbnRleHQuUHJvdmlkZXI+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkM4QiJ9 */");export const StyledChildrenWrapper=styled("div",{target:"ew3tr1y1",label:"StyledChildrenWrapper"})({display:"contents"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTGlnaHRib3gvTGlnaHRib3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9MaWdodGJveC9MaWdodGJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7XG4gIHVzZUNhbGxiYWNrLFxuICB1c2VSZWYsXG4gIHR5cGUgUHJvcHNXaXRoQ2hpbGRyZW4sXG4gIHR5cGUgUmVmT2JqZWN0LFxufSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSBcIkBlbW90aW9uL3JlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IExpZ2h0Ym94VmVydGljYWxBbGlnbm1lbnQsIE1RIH0gZnJvbSBcInNyYy90eXBlc1wiO1xuaW1wb3J0IHtcbiAgUG9ydGFsLFxuICB1c2VQb3J0YWxDb250YWluZXJFbGVtZW50LFxuICB0eXBlIFBvcnRhbFByb3BzLFxufSBmcm9tIFwiLi4vUG9ydGFsL1BvcnRhbFwiO1xuaW1wb3J0IHsgRm9jdXNUcmFwV3JhcHBlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvRm9jdXNUcmFwV3JhcHBlclwiO1xuaW1wb3J0IHsgdXNlUmVzcG9uc2l2ZVN0eWxlcyB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWVkaWFRdWVyaWVzXCI7XG5pbXBvcnQgeyBEaWFsb2dDb250ZXh0IH0gZnJvbSBcIi4uL1BhdHRlcm5zL0RpYWxvZy9EaWFsb2dDb250ZXh0XCI7XG5cbmV4cG9ydCB0eXBlIExpZ2h0Ym94UHJvcHMgPSBSZWFjdC5IVE1MQXR0cmlidXRlczxIVE1MRGl2RWxlbWVudD4gJiB7XG4gIGNoaWxkcmVuPzogUmVhY3QuUmVhY3ROb2RlW10gfCBSZWFjdC5SZWFjdE5vZGU7XG4gIGJhY2tkcm9wUmVmPzogUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50PjtcbiAgaGFuZGxlQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBpc0Rpc21pc3NpYmxlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEEgcmVmIHRvIHRoZSBlbGVtZW50IHRoYXQgc2hvdWxkIHJlY2VpdmUgZm9jdXMgd2hlbiB0aGUgbGlnaHRib3ggb3BlbnMuXG4gICAqIFdoZW4gbm90IHByb3ZpZGVkLCB0aGUgZmlyc3QgZm9jdXNhYmxlIGVsZW1lbnQgaW5zaWRlIHRoZSBsaWdodGJveCBpcyB1c2VkLlxuICAgKi9cbiAgaW5pdGlhbEZvY3VzPzogUmVmT2JqZWN0PEhUTUxFbGVtZW50IHwgU1ZHRWxlbWVudD4gfCBzdHJpbmc7XG4gIGp1c3RpZnlDb250ZW50PzogTVE8TGlnaHRib3hWZXJ0aWNhbEFsaWdubWVudD4gfCBMaWdodGJveFZlcnRpY2FsQWxpZ25tZW50O1xuICBwcml2YXRlUHJvcHM/OiB7XG4gICAgc2tpcFBvcnRhbD86IGJvb2xlYW47XG4gICAgLyoqXG4gICAgICogQGludGVybmFsXG4gICAgICogT3B0aW9ucyBwYXNzZWQgdG8gZm9jdXMtdHJhcCdzIHRhYmJhYmxlIGRldGVjdGlvbi5cbiAgICAgKiBVc2UgYHsgZGlzcGxheUNoZWNrOiBcIm5vbmVcIiB9YCBmb3IgdGVzdGluZyB0byBhdm9pZCBKU0RPTSB2aXNpYmlsaXR5IGlzc3Vlcy5cbiAgICAgKi9cbiAgICB0YWJiYWJsZU9wdGlvbnM/OiB7XG4gICAgICBkaXNwbGF5Q2hlY2s/OiBcImZ1bGxcIiB8IFwibGVnYWN5LWZ1bGxcIiB8IFwibm9uLXplcm8tYXJlYVwiIHwgXCJub25lXCI7XG4gICAgfTtcbiAgfTtcbn0gJiBQaWNrPFBvcnRhbFByb3BzLCBcInBvcnRhbENvbnRhaW5lclwiPjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEJhY2tkcm9wID0gc3R5bGVkLmRpdjxQaWNrPExpZ2h0Ym94UHJvcHMsIFwianVzdGlmeUNvbnRlbnRcIj4+KFxuICAoeyB0aGVtZSwganVzdGlmeUNvbnRlbnQgfSkgPT4ge1xuICAgIGNvbnN0IGZhZGVJbkJhY2tkcm9wID0ga2V5ZnJhbWVzYFxuICAgIGZyb20ge1xuICAgICAgb3BhY2l0eTogJHt0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5oaWRkZW59O1xuICAgIH1cbiAgICB0byB7XG4gICAgICBvcGFjaXR5OiAke3RoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LnZpc2libGV9O1xuICAgIH1cbiAgYDtcblxuICAgIHJldHVybiB7XG4gICAgICBwb3NpdGlvbjogXCJmaXhlZFwiLFxuICAgICAgdG9wOiAwLFxuICAgICAgbGVmdDogMCxcbiAgICAgIHpJbmRleDogdGhlbWUudmFyaWFibGVzLnpJbmRleC5tb2RhbCxcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGhlaWdodDogXCIxMDBkdmhcIixcbiAgICAgIGJhY2tncm91bmQ6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLmJhY2tkcm9wLmRlZmF1bHQsXG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG4gICAgICAuLi51c2VSZXNwb25zaXZlU3R5bGVzKHtcbiAgICAgICAganVzdGlmeUNvbnRlbnQ6IFtcbiAgICAgICAgICBqdXN0aWZ5Q29udGVudCxcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0b3A6IFwiZmxleC1zdGFydFwiLFxuICAgICAgICAgICAgY2VudGVyOiBcImNlbnRlclwiLFxuICAgICAgICAgIH0sXG4gICAgICAgIF0sXG4gICAgICB9KSxcbiAgICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgICBmbGV4OiBcIjEgMCBhdXRvXCIsXG4gICAgICBhbmltYXRpb246IGAke2ZhZGVJbkJhY2tkcm9wfSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLmR1cmF0aW9ufSAke3RoZW1lLnZhcmlhYmxlcy5hbmltYXRpb24ubW9kYWxCYWNrZHJvcC5vcGVuLnRpbWluZ0Z1bmN0aW9ufSBib3RoYCxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ2hpbGRyZW5XcmFwcGVyID0gc3R5bGVkLmRpdih7XG4gIGRpc3BsYXk6IFwiY29udGVudHNcIixcbn0pO1xuXG5leHBvcnQgZnVuY3Rpb24gTGlnaHRib3goe1xuICBiYWNrZHJvcFJlZixcbiAgcG9ydGFsQ29udGFpbmVyLFxuICBpbml0aWFsRm9jdXMsXG4gIGlzRGlzbWlzc2libGUgPSB0cnVlLFxuICBjaGlsZHJlbixcbiAgaGFuZGxlQ2xvc2UsXG4gIGp1c3RpZnlDb250ZW50ID0gXCJjZW50ZXJcIixcbiAgcHJpdmF0ZVByb3BzOiB7IHNraXBQb3J0YWwsIHRhYmJhYmxlT3B0aW9ucyB9ID0ge1xuICAgIHNraXBQb3J0YWw6IGZhbHNlLFxuICB9LFxufTogUHJvcHNXaXRoQ2hpbGRyZW48TGlnaHRib3hQcm9wcz4pOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwb3J0YWxDb250YWluZXJFbGVtZW50ID0gdXNlUG9ydGFsQ29udGFpbmVyRWxlbWVudChwb3J0YWxDb250YWluZXIpO1xuICBjb25zdCBtb2RhbFJlZiA9IHVzZVJlZihudWxsKTtcblxuICBjb25zdCBoYW5kbGVDbGlja091dHNpZGVEZWFjdGl2YXRlcyA9IHVzZUNhbGxiYWNrKFxuICAgIChldnQ6IE1vdXNlRXZlbnQgfCBUb3VjaEV2ZW50KSA9PiB7XG4gICAgICAvLyBEbyBub3QgY2xvc2Ugb24gY2xpY2sgdGhhdCBvY2N1cnMgb24gZWxlbWVudHMgd2l0aGluIHRoZSBzYW1lIHBvcnRhbCwgZm9yIGVnLCBkcm9wZG93biBhbmQgc2VsZWN0IG1lbnVzXG4gICAgICBpZiAoXG4gICAgICAgIHBvcnRhbENvbnRhaW5lckVsZW1lbnQuY29udGFpbnMoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgJiZcbiAgICAgICAgZXZ0LnRhcmdldCAhPT0gYmFja2Ryb3BSZWY/LmN1cnJlbnRcbiAgICAgICkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBpc0Rpc21pc3NpYmxlO1xuICAgIH0sXG4gICAgW2JhY2tkcm9wUmVmLCBwb3J0YWxDb250YWluZXJFbGVtZW50LCBpc0Rpc21pc3NpYmxlXVxuICApO1xuXG4gIGNvbnN0IGdldEZvY3VzVGFyZ2V0ID0gKCkgPT4ge1xuICAgIGNvbnN0IGNvbnRhaW5lciA9IG1vZGFsUmVmPy5jdXJyZW50XG4gICAgICA/LmZpcnN0RWxlbWVudENoaWxkIGFzIEhUTUxFbGVtZW50IHwgbnVsbDtcblxuICAgIGNvbnN0IGZvY3VzYWJsZVNlbGVjdG9yID1cbiAgICAgICdhW2hyZWZdLCBidXR0b246bm90KFtkaXNhYmxlZF0pLCBpbnB1dDpub3QoW2Rpc2FibGVkXSksIHNlbGVjdDpub3QoW2Rpc2FibGVkXSksIHRleHRhcmVhOm5vdChbZGlzYWJsZWRdKSwgW3RhYmluZGV4XTpub3QoW3RhYmluZGV4PVwiLTFcIl0pJztcbiAgICBjb25zdCBmaXJzdEZvY3VzYWJsZSA9XG4gICAgICBjb250YWluZXI/LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KGZvY3VzYWJsZVNlbGVjdG9yKTtcbiAgICBpZiAoZmlyc3RGb2N1c2FibGUpIHtcbiAgICAgIHJldHVybiBmaXJzdEZvY3VzYWJsZTtcbiAgICB9XG5cbiAgICByZXR1cm4gY29udGFpbmVyIHx8IGRvY3VtZW50LmJvZHk7XG4gIH07XG5cbiAgY29uc3QgZ2V0SW5pdGlhbEZvY3VzID0gKCkgPT4ge1xuICAgIGlmICh0eXBlb2YgaW5pdGlhbEZvY3VzID09PSBcInN0cmluZ1wiKSB7XG4gICAgICByZXR1cm4gaW5pdGlhbEZvY3VzO1xuICAgIH1cbiAgICByZXR1cm4gaW5pdGlhbEZvY3VzPy5jdXJyZW50ID8/IGdldEZvY3VzVGFyZ2V0KCk7XG4gIH07XG5cbiAgY29uc3QgY29udGVudCA9IChcbiAgICA8U3R5bGVkQmFja2Ryb3BcbiAgICAgIHJlZj17YmFja2Ryb3BSZWZ9XG4gICAgICBqdXN0aWZ5Q29udGVudD17anVzdGlmeUNvbnRlbnR9XG4gICAgICBkYXRhLWRzLWlkPVwiTGlnaHRib3hcIlxuICAgID5cbiAgICAgIDxGb2N1c1RyYXBXcmFwcGVyXG4gICAgICAgIGFjdGl2ZVxuICAgICAgICBmb2N1c1RyYXBPcHRpb25zPXt7XG4gICAgICAgICAgYWxsb3dPdXRzaWRlQ2xpY2s6IHRydWUsIC8vIGFsbG93IGNsaWNrIG9uIG1vYmlsZSBpbiBhbnkgZHJvcGRvd25zXG4gICAgICAgICAgY2xpY2tPdXRzaWRlRGVhY3RpdmF0ZXM6IGhhbmRsZUNsaWNrT3V0c2lkZURlYWN0aXZhdGVzLFxuICAgICAgICAgIGVzY2FwZURlYWN0aXZhdGVzOiBpc0Rpc21pc3NpYmxlLCAvLyBkZS1hY3RpdmF0ZSBmb2N1cyB0cmFwIG9uIGVzY2FwZSBrZXlcbiAgICAgICAgICBwcmV2ZW50U2Nyb2xsOiB0cnVlLFxuICAgICAgICAgIGluaXRpYWxGb2N1czogKCkgPT4gZ2V0SW5pdGlhbEZvY3VzKCksXG4gICAgICAgICAgZmFsbGJhY2tGb2N1czogKCkgPT4gZ2V0Rm9jdXNUYXJnZXQoKSxcbiAgICAgICAgICAuLi4odGFiYmFibGVPcHRpb25zICYmIHsgdGFiYmFibGVPcHRpb25zIH0pLFxuICAgICAgICAgIC4uLihoYW5kbGVDbG9zZSAmJiB7IG9uUG9zdERlYWN0aXZhdGU6IGhhbmRsZUNsb3NlIH0pLFxuICAgICAgICB9fVxuICAgICAgPlxuICAgICAgICA8U3R5bGVkQ2hpbGRyZW5XcmFwcGVyIHJlZj17bW9kYWxSZWZ9PntjaGlsZHJlbn08L1N0eWxlZENoaWxkcmVuV3JhcHBlcj5cbiAgICAgIDwvRm9jdXNUcmFwV3JhcHBlcj5cbiAgICA8L1N0eWxlZEJhY2tkcm9wPlxuICApO1xuXG4gIC8vIEZvciB0ZXN0aW5nIGFuZCBNb2RhbCBzdG9yeSB3ZSBkb24ndCB3YW50IHRvIHJlbmRlciB0aGUgY29udGVudCBpbnNpZGUgYSBwb3J0YWxcbiAgaWYgKHNraXBQb3J0YWwpIHtcbiAgICByZXR1cm4gY29udGVudDtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPERpYWxvZ0NvbnRleHQuUHJvdmlkZXIgdmFsdWU+XG4gICAgICA8UG9ydGFsIHBvcnRhbENvbnRhaW5lcj17cG9ydGFsQ29udGFpbmVyfT57Y29udGVudH08L1BvcnRhbD5cbiAgICA8L0RpYWxvZ0NvbnRleHQuUHJvdmlkZXI+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0ZxQyJ9 */");export function Lightbox({backdropRef,portalContainer,initialFocus,isDismissible=!0,children,handleClose,justifyContent="center",privateProps:{skipPortal,tabbableOptions}={skipPortal:!1}}){let portalContainerElement=usePortalContainerElement(portalContainer),modalRef=useRef(null),handleClickOutsideDeactivates=useCallback(evt=>(!portalContainerElement.contains(evt.target)||evt.target===backdropRef?.current)&&isDismissible,[backdropRef,portalContainerElement,isDismissible]),getFocusTarget=()=>{let container=modalRef?.current?.firstElementChild,firstFocusable=container?.querySelector('a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), [tabindex]:not([tabindex="-1"])');return firstFocusable||container||document.body},getInitialFocus=()=>"string"==typeof initialFocus?initialFocus:initialFocus?.current??getFocusTarget(),content=React.createElement(StyledBackdrop,{ref:backdropRef,justifyContent:justifyContent,"data-ds-id":"Lightbox"},React.createElement(FocusTrapWrapper,{active:!0,focusTrapOptions:{allowOutsideClick:!0,clickOutsideDeactivates:handleClickOutsideDeactivates,escapeDeactivates:isDismissible,preventScroll:!0,initialFocus:()=>getInitialFocus(),fallbackFocus:()=>getFocusTarget(),...tabbableOptions&&{tabbableOptions},...handleClose&&{onPostDeactivate:handleClose}}},React.createElement(StyledChildrenWrapper,{ref:modalRef},children)));return skipPortal?content:React.createElement(DialogContext.Provider,{value:!0},React.createElement(Portal,{portalContainer:portalContainer},content))}
|