@amboss/design-system 3.29.6 → 3.29.7
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/DataTable/header/SortableCellContent.js +1 -1
- package/build/cjs/components/Form/Combobox/Combobox.d.ts +1 -1
- package/build/cjs/components/Form/Combobox/Combobox.js +1 -1
- package/build/cjs/components/Form/FormFieldGroup/FormFieldGroup.js +1 -1
- package/build/cjs/components/MediaItem/MediaItem.js +1 -1
- package/build/cjs/components/Utilities/Expandable/Expandable.js +1 -1
- package/build/cjs/web-tokens/assets/icons.json +3 -3
- package/build/cjs/web-tokens/assets/icons16.json +3 -3
- package/build/esm/components/DataTable/header/SortableCellContent.js +1 -1
- package/build/esm/components/Form/Combobox/Combobox.d.ts +1 -1
- package/build/esm/components/Form/Combobox/Combobox.js +1 -1
- package/build/esm/components/Form/FormFieldGroup/FormFieldGroup.js +1 -1
- package/build/esm/components/MediaItem/MediaItem.js +1 -1
- package/build/esm/components/Utilities/Expandable/Expandable.js +1 -1
- package/build/esm/web-tokens/assets/icons.json +3 -3
- package/build/esm/web-tokens/assets/icons16.json +3 -3
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get MediaItem(){return MediaItem},get mediaSize(){return mediaSize}};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")),_Icon=require("../Icon/Icon"),_Stack=require("../Stack/Stack"),_TextClamped=require("../Typography/TextClamped/TextClamped"),_Text=require("../Typography/Text/Text"),_Inline=require("../Inline/Inline"),_Image=require("../Image/Image"),mediaSize={xs:80,s:88,m:110,l:128,xl:204},StyledTextClamped=(0,_styled.default)(_TextClamped.TextClamped,{target:"etv38dh0",label:"StyledTextClamped"})("/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        {...rest}\n        aria-label={title}\n      >\n        <Stack space=\"xs\">\n          <StyledMediaContainer\n            size={size}\n            height={height}\n            backgroundColor={backgroundColor}\n            squareByWidth={squareByWidth}\n            srcError={srcError}\n          >\n            <StyledMedia squareByWidth={squareByWidth} srcError={srcError}>\n              {srcError ? (\n                <Icon name=\"image-broken\" color=\"tertiary\" />\n              ) : (\n                <Image\n                  src={src}\n                  fit={fit}\n                  title={title}\n                  alt={title}\n                  width=\"100%\"\n                  height=\"100%\"\n                  aria-hidden=\"true\"\n                  onError={onError}\n                />\n              )}\n            </StyledMedia>\n            <StyledOverlay />\n            {showCategoryOver && (\n              <StyledIconContainer>\n                <Icon name={categoryIcon} size=\"s\" color=\"inherit\" />\n              </StyledIconContainer>\n            )}\n          </StyledMediaContainer>\n          {(showCategoryUnder || showTitle) && (\n            <Stack space=\"xxs\">\n              {showCategoryUnder && (\n                <Inline space=\"xxs\" vAlignItems=\"center\">\n                  <Icon name={categoryIcon} color=\"quaternary\" size=\"s\" />\n                  <Text\n                    color=\"tertiary\"\n                    size=\"xs\"\n                    transform=\"uppercase\"\n                    weight=\"bold\"\n                  >\n                    {categoryLabel}\n                  </Text>\n                </Inline>\n              )}\n              {showTitle && (\n                <StyledTextClamped\n                  size={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAwD0B"} */"),StyledMedia=(0,_styled.default)("div",{target:"etv38dh1",label:"StyledMedia"})(({squareByWidth,srcError})=>({height:"100%",...squareByWidth&&{position:"absolute",left:0,bottom:0,top:0,right:0},...srcError&&{display:"flex",alignItems:"center",justifyContent:"center"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        {...rest}\n        aria-label={title}\n      >\n        <Stack space=\"xs\">\n          <StyledMediaContainer\n            size={size}\n            height={height}\n            backgroundColor={backgroundColor}\n            squareByWidth={squareByWidth}\n            srcError={srcError}\n          >\n            <StyledMedia squareByWidth={squareByWidth} srcError={srcError}>\n              {srcError ? (\n                <Icon name=\"image-broken\" color=\"tertiary\" />\n              ) : (\n                <Image\n                  src={src}\n                  fit={fit}\n                  title={title}\n                  alt={title}\n                  width=\"100%\"\n                  height=\"100%\"\n                  aria-hidden=\"true\"\n                  onError={onError}\n                />\n              )}\n            </StyledMedia>\n            <StyledOverlay />\n            {showCategoryOver && (\n              <StyledIconContainer>\n                <Icon name={categoryIcon} size=\"s\" color=\"inherit\" />\n              </StyledIconContainer>\n            )}\n          </StyledMediaContainer>\n          {(showCategoryUnder || showTitle) && (\n            <Stack space=\"xxs\">\n              {showCategoryUnder && (\n                <Inline space=\"xxs\" vAlignItems=\"center\">\n                  <Icon name={categoryIcon} color=\"quaternary\" size=\"s\" />\n                  <Text\n                    color=\"tertiary\"\n                    size=\"xs\"\n                    transform=\"uppercase\"\n                    weight=\"bold\"\n                  >\n                    {categoryLabel}\n                  </Text>\n                </Inline>\n              )}\n              {showTitle && (\n                <StyledTextClamped\n                  size={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AA0DoB"} */"),StyledOverlay=(0,_styled.default)("div",{target:"etv38dh2",label:"StyledOverlay"})(()=>({position:"absolute",left:0,bottom:0,top:0,right:0}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        {...rest}\n        aria-label={title}\n      >\n        <Stack space=\"xs\">\n          <StyledMediaContainer\n            size={size}\n            height={height}\n            backgroundColor={backgroundColor}\n            squareByWidth={squareByWidth}\n            srcError={srcError}\n          >\n            <StyledMedia squareByWidth={squareByWidth} srcError={srcError}>\n              {srcError ? (\n                <Icon name=\"image-broken\" color=\"tertiary\" />\n              ) : (\n                <Image\n                  src={src}\n                  fit={fit}\n                  title={title}\n                  alt={title}\n                  width=\"100%\"\n                  height=\"100%\"\n                  aria-hidden=\"true\"\n                  onError={onError}\n                />\n              )}\n            </StyledMedia>\n            <StyledOverlay />\n            {showCategoryOver && (\n              <StyledIconContainer>\n                <Icon name={categoryIcon} size=\"s\" color=\"inherit\" />\n              </StyledIconContainer>\n            )}\n          </StyledMediaContainer>\n          {(showCategoryUnder || showTitle) && (\n            <Stack space=\"xxs\">\n              {showCategoryUnder && (\n                <Inline space=\"xxs\" vAlignItems=\"center\">\n                  <Icon name={categoryIcon} color=\"quaternary\" size=\"s\" />\n                  <Text\n                    color=\"tertiary\"\n                    size=\"xs\"\n                    transform=\"uppercase\"\n                    weight=\"bold\"\n                  >\n                    {categoryLabel}\n                  </Text>\n                </Inline>\n              )}\n              {showTitle && (\n                <StyledTextClamped\n                  size={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AA4EsB"} */"),StyledButton=(0,_styled.default)("button",{target:"etv38dh3",label:"StyledButton"})(({theme,size,width,isActive})=>({padding:0,backgroundColor:theme.values.color.background.transparent.default,border:"none",cursor:"pointer",borderRadius:theme.variables.size.borderRadius.s,width:mediaSize[size]||width||"100%",outlineOffset:"1px",outline:`solid 2px ${theme.values.color.background.transparent.default}`,transition:"all 0.3s ease",[`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]:{color:theme.values.color.text.primary.default},[`&:hover ${StyledOverlay}`]:{backgroundColor:theme.values.color.mediaItem.overlay.hover},[`&:active ${StyledOverlay}`]:{backgroundColor:theme.values.color.mediaItem.overlay.active},...!isActive&&{"&:focus-visible":{outlineWidth:"2px",outlineStyle:"solid",outlineColor:"Highlight"},"@media (-webkit-min-device-pixel-ratio:0)":{"&:focus-visible":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"auto"}}},...isActive&&{outlineColor:theme.values.color.border.secondary.active}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        {...rest}\n        aria-label={title}\n      >\n        <Stack space=\"xs\">\n          <StyledMediaContainer\n            size={size}\n            height={height}\n            backgroundColor={backgroundColor}\n            squareByWidth={squareByWidth}\n            srcError={srcError}\n          >\n            <StyledMedia squareByWidth={squareByWidth} srcError={srcError}>\n              {srcError ? (\n                <Icon name=\"image-broken\" color=\"tertiary\" />\n              ) : (\n                <Image\n                  src={src}\n                  fit={fit}\n                  title={title}\n                  alt={title}\n                  width=\"100%\"\n                  height=\"100%\"\n                  aria-hidden=\"true\"\n                  onError={onError}\n                />\n              )}\n            </StyledMedia>\n            <StyledOverlay />\n            {showCategoryOver && (\n              <StyledIconContainer>\n                <Icon name={categoryIcon} size=\"s\" color=\"inherit\" />\n              </StyledIconContainer>\n            )}\n          </StyledMediaContainer>\n          {(showCategoryUnder || showTitle) && (\n            <Stack space=\"xxs\">\n              {showCategoryUnder && (\n                <Inline space=\"xxs\" vAlignItems=\"center\">\n                  <Icon name={categoryIcon} color=\"quaternary\" size=\"s\" />\n                  <Text\n                    color=\"tertiary\"\n                    size=\"xs\"\n                    transform=\"uppercase\"\n                    weight=\"bold\"\n                  >\n                    {categoryLabel}\n                  </Text>\n                </Inline>\n              )}\n              {showTitle && (\n                <StyledTextClamped\n                  size={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAuFqB"} */"),StyledMediaContainer=(0,_styled.default)("div",{target:"etv38dh4",label:"StyledMediaContainer"})(({theme,size,height,backgroundColor,squareByWidth,srcError})=>({overflow:"hidden",border:"1px solid",borderColor:theme.values.color.border.secondary.default,borderRadius:theme.variables.size.borderRadius.s,position:"relative",backgroundClip:"padding-box",backgroundColor:theme.values.color.mediaItem.background[backgroundColor],height:mediaSize[size]||height||"auto",...squareByWidth&&{paddingTop:"calc(100% - 2px)",height:"auto"},...srcError&&{backgroundColor:theme.values.color.background.transparent.active}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        {...rest}\n        aria-label={title}\n      >\n        <Stack space=\"xs\">\n          <StyledMediaContainer\n            size={size}\n            height={height}\n            backgroundColor={backgroundColor}\n            squareByWidth={squareByWidth}\n            srcError={srcError}\n          >\n            <StyledMedia squareByWidth={squareByWidth} srcError={srcError}>\n              {srcError ? (\n                <Icon name=\"image-broken\" color=\"tertiary\" />\n              ) : (\n                <Image\n                  src={src}\n                  fit={fit}\n                  title={title}\n                  alt={title}\n                  width=\"100%\"\n                  height=\"100%\"\n                  aria-hidden=\"true\"\n                  onError={onError}\n                />\n              )}\n            </StyledMedia>\n            <StyledOverlay />\n            {showCategoryOver && (\n              <StyledIconContainer>\n                <Icon name={categoryIcon} size=\"s\" color=\"inherit\" />\n              </StyledIconContainer>\n            )}\n          </StyledMediaContainer>\n          {(showCategoryUnder || showTitle) && (\n            <Stack space=\"xxs\">\n              {showCategoryUnder && (\n                <Inline space=\"xxs\" vAlignItems=\"center\">\n                  <Icon name={categoryIcon} color=\"quaternary\" size=\"s\" />\n                  <Text\n                    color=\"tertiary\"\n                    size=\"xs\"\n                    transform=\"uppercase\"\n                    weight=\"bold\"\n                  >\n                    {categoryLabel}\n                  </Text>\n                </Inline>\n              )}\n              {showTitle && (\n                <StyledTextClamped\n                  size={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAgI6B"} */"),StyledIconContainer=(0,_styled.default)("div",{target:"etv38dh5",label:"StyledIconContainer"})(({theme})=>({position:"absolute",left:theme.variables.size.spacing.xxs,bottom:theme.variables.size.spacing.xxs,overflow:"hidden",borderRadius:theme.variables.size.borderRadius.xs,backgroundColor:theme.values.color.mediaItem.categoryIcon.background.default,padding:theme.variables.size.spacing.xxs,color:theme.values.color.text.onAccent.default}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        {...rest}\n        aria-label={title}\n      >\n        <Stack space=\"xs\">\n          <StyledMediaContainer\n            size={size}\n            height={height}\n            backgroundColor={backgroundColor}\n            squareByWidth={squareByWidth}\n            srcError={srcError}\n          >\n            <StyledMedia squareByWidth={squareByWidth} srcError={srcError}>\n              {srcError ? (\n                <Icon name=\"image-broken\" color=\"tertiary\" />\n              ) : (\n                <Image\n                  src={src}\n                  fit={fit}\n                  title={title}\n                  alt={title}\n                  width=\"100%\"\n                  height=\"100%\"\n                  aria-hidden=\"true\"\n                  onError={onError}\n                />\n              )}\n            </StyledMedia>\n            <StyledOverlay />\n            {showCategoryOver && (\n              <StyledIconContainer>\n                <Icon name={categoryIcon} size=\"s\" color=\"inherit\" />\n              </StyledIconContainer>\n            )}\n          </StyledMediaContainer>\n          {(showCategoryUnder || showTitle) && (\n            <Stack space=\"xxs\">\n              {showCategoryUnder && (\n                <Inline space=\"xxs\" vAlignItems=\"center\">\n                  <Icon name={categoryIcon} color=\"quaternary\" size=\"s\" />\n                  <Text\n                    color=\"tertiary\"\n                    size=\"xs\"\n                    transform=\"uppercase\"\n                    weight=\"bold\"\n                  >\n                    {categoryLabel}\n                  </Text>\n                </Inline>\n              )}\n              {showTitle && (\n                <StyledTextClamped\n                  size={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAiJ4B"} */"),MediaItem=_react.default.forwardRef(({"data-e2e-test-id":dataE2eTestId,as,src,title,showTitle=!0,fit="cover",categoryIcon,categoryLabel,categoryPlacement="outside",size,width,height,backgroundColor="transparent",hyphens="none",squareByWidth=!1,isActive,...rest},ref)=>{let[srcError,setSrcError]=(0,_react.useState)(!1),showCategoryOver=categoryIcon&&(!size&&"inside"===categoryPlacement||"xs"===size||"s"===size||"m"===size),showCategoryUnder=categoryIcon&&categoryLabel&&(!size&&"outside"===categoryPlacement||"l"===size||"xl"===size),textSize=["xs","s","m"].includes(size)?"xs":"s";return _react.default.createElement(StyledButton,{"data-ds-id":"MediaItem","data-e2e-test-id":dataE2eTestId,as:as,ref:ref,size:size,width:width,isActive:isActive,...rest,"aria-label":title},_react.default.createElement(_Stack.Stack,{space:"xs"},_react.default.createElement(StyledMediaContainer,{size:size,height:height,backgroundColor:backgroundColor,squareByWidth:squareByWidth,srcError:srcError},_react.default.createElement(StyledMedia,{squareByWidth:squareByWidth,srcError:srcError},srcError?_react.default.createElement(_Icon.Icon,{name:"image-broken",color:"tertiary"}):_react.default.createElement(_Image.Image,{src:src,fit:fit,title:title,alt:title,width:"100%",height:"100%","aria-hidden":"true",onError:()=>{setSrcError(!0)}})),_react.default.createElement(StyledOverlay,null),showCategoryOver&&_react.default.createElement(StyledIconContainer,null,_react.default.createElement(_Icon.Icon,{name:categoryIcon,size:"s",color:"inherit"}))),(showCategoryUnder||showTitle)&&_react.default.createElement(_Stack.Stack,{space:"xxs"},showCategoryUnder&&_react.default.createElement(_Inline.Inline,{space:"xxs",vAlignItems:"center"},_react.default.createElement(_Icon.Icon,{name:categoryIcon,color:"quaternary",size:"s"}),_react.default.createElement(_Text.Text,{color:"tertiary",size:"xs",transform:"uppercase",weight:"bold"},categoryLabel)),showTitle&&_react.default.createElement(StyledTextClamped,{size:textSize,color:"secondary",lines:3,hyphens:hyphens,overflowWrap:"break-word"},title))))});
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get MediaItem(){return MediaItem},get mediaSize(){return mediaSize}};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")),_Icon=require("../Icon/Icon"),_Stack=require("../Stack/Stack"),_TextClamped=require("../Typography/TextClamped/TextClamped"),_Text=require("../Typography/Text/Text"),_Inline=require("../Inline/Inline"),_Image=require("../Image/Image"),mediaSize={xs:80,s:88,m:110,l:128,xl:204},StyledTextClamped=(0,_styled.default)(_TextClamped.TextClamped,{target:"e1we4x3d0",label:"StyledTextClamped"})("/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    const noVisibleText = !showTitle && !showCategoryUnder;\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        {...rest}\n        aria-label={noVisibleText ? title : undefined}\n      >\n        <Stack space=\"xs\">\n          <StyledMediaContainer\n            size={size}\n            height={height}\n            backgroundColor={backgroundColor}\n            squareByWidth={squareByWidth}\n            srcError={srcError}\n          >\n            <StyledMedia squareByWidth={squareByWidth} srcError={srcError}>\n              {srcError ? (\n                <Icon name=\"image-broken\" color=\"tertiary\" />\n              ) : (\n                <Image\n                  src={src}\n                  fit={fit}\n                  title={title}\n                  alt={title}\n                  width=\"100%\"\n                  height=\"100%\"\n                  aria-hidden=\"true\"\n                  onError={onError}\n                />\n              )}\n            </StyledMedia>\n            <StyledOverlay />\n            {showCategoryOver && (\n              <StyledIconContainer>\n                <Icon name={categoryIcon} size=\"s\" color=\"inherit\" />\n              </StyledIconContainer>\n            )}\n          </StyledMediaContainer>\n          {(showCategoryUnder || showTitle) && (\n            <Stack space=\"xxs\">\n              {showCategoryUnder && (\n                <Inline space=\"xxs\" vAlignItems=\"center\">\n                  <Icon name={categoryIcon} color=\"quaternary\" size=\"s\" />\n                  <Text\n                    color=\"tertiary\"\n                    size=\"xs\"\n                    transform=\"uppercase\"\n                    weight=\"bold\"\n                  >\n                    {categoryLabel}\n                  </Text>\n                </Inline>\n              )}\n              {showTitle && (\n                <StyledTextClamped\n                  size={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAwD0B"} */"),StyledMedia=(0,_styled.default)("div",{target:"e1we4x3d1",label:"StyledMedia"})(({squareByWidth,srcError})=>({height:"100%",...squareByWidth&&{position:"absolute",left:0,bottom:0,top:0,right:0},...srcError&&{display:"flex",alignItems:"center",justifyContent:"center"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    const noVisibleText = !showTitle && !showCategoryUnder;\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        {...rest}\n        aria-label={noVisibleText ? title : undefined}\n      >\n        <Stack space=\"xs\">\n          <StyledMediaContainer\n            size={size}\n            height={height}\n            backgroundColor={backgroundColor}\n            squareByWidth={squareByWidth}\n            srcError={srcError}\n          >\n            <StyledMedia squareByWidth={squareByWidth} srcError={srcError}>\n              {srcError ? (\n                <Icon name=\"image-broken\" color=\"tertiary\" />\n              ) : (\n                <Image\n                  src={src}\n                  fit={fit}\n                  title={title}\n                  alt={title}\n                  width=\"100%\"\n                  height=\"100%\"\n                  aria-hidden=\"true\"\n                  onError={onError}\n                />\n              )}\n            </StyledMedia>\n            <StyledOverlay />\n            {showCategoryOver && (\n              <StyledIconContainer>\n                <Icon name={categoryIcon} size=\"s\" color=\"inherit\" />\n              </StyledIconContainer>\n            )}\n          </StyledMediaContainer>\n          {(showCategoryUnder || showTitle) && (\n            <Stack space=\"xxs\">\n              {showCategoryUnder && (\n                <Inline space=\"xxs\" vAlignItems=\"center\">\n                  <Icon name={categoryIcon} color=\"quaternary\" size=\"s\" />\n                  <Text\n                    color=\"tertiary\"\n                    size=\"xs\"\n                    transform=\"uppercase\"\n                    weight=\"bold\"\n                  >\n                    {categoryLabel}\n                  </Text>\n                </Inline>\n              )}\n              {showTitle && (\n                <StyledTextClamped\n                  size={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AA0DoB"} */"),StyledOverlay=(0,_styled.default)("div",{target:"e1we4x3d2",label:"StyledOverlay"})(()=>({position:"absolute",left:0,bottom:0,top:0,right:0}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    const noVisibleText = !showTitle && !showCategoryUnder;\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        {...rest}\n        aria-label={noVisibleText ? title : undefined}\n      >\n        <Stack space=\"xs\">\n          <StyledMediaContainer\n            size={size}\n            height={height}\n            backgroundColor={backgroundColor}\n            squareByWidth={squareByWidth}\n            srcError={srcError}\n          >\n            <StyledMedia squareByWidth={squareByWidth} srcError={srcError}>\n              {srcError ? (\n                <Icon name=\"image-broken\" color=\"tertiary\" />\n              ) : (\n                <Image\n                  src={src}\n                  fit={fit}\n                  title={title}\n                  alt={title}\n                  width=\"100%\"\n                  height=\"100%\"\n                  aria-hidden=\"true\"\n                  onError={onError}\n                />\n              )}\n            </StyledMedia>\n            <StyledOverlay />\n            {showCategoryOver && (\n              <StyledIconContainer>\n                <Icon name={categoryIcon} size=\"s\" color=\"inherit\" />\n              </StyledIconContainer>\n            )}\n          </StyledMediaContainer>\n          {(showCategoryUnder || showTitle) && (\n            <Stack space=\"xxs\">\n              {showCategoryUnder && (\n                <Inline space=\"xxs\" vAlignItems=\"center\">\n                  <Icon name={categoryIcon} color=\"quaternary\" size=\"s\" />\n                  <Text\n                    color=\"tertiary\"\n                    size=\"xs\"\n                    transform=\"uppercase\"\n                    weight=\"bold\"\n                  >\n                    {categoryLabel}\n                  </Text>\n                </Inline>\n              )}\n              {showTitle && (\n                <StyledTextClamped\n                  size={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AA4EsB"} */"),StyledButton=(0,_styled.default)("button",{target:"e1we4x3d3",label:"StyledButton"})(({theme,size,width,isActive})=>({padding:0,backgroundColor:theme.values.color.background.transparent.default,border:"none",cursor:"pointer",borderRadius:theme.variables.size.borderRadius.s,width:mediaSize[size]||width||"100%",outlineOffset:"1px",outline:`solid 2px ${theme.values.color.background.transparent.default}`,transition:"all 0.3s ease",[`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]:{color:theme.values.color.text.primary.default},[`&:hover ${StyledOverlay}`]:{backgroundColor:theme.values.color.mediaItem.overlay.hover},[`&:active ${StyledOverlay}`]:{backgroundColor:theme.values.color.mediaItem.overlay.active},...!isActive&&{"&:focus-visible":{outlineWidth:"2px",outlineStyle:"solid",outlineColor:"Highlight"},"@media (-webkit-min-device-pixel-ratio:0)":{"&:focus-visible":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"auto"}}},...isActive&&{outlineColor:theme.values.color.border.secondary.active}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    const noVisibleText = !showTitle && !showCategoryUnder;\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        {...rest}\n        aria-label={noVisibleText ? title : undefined}\n      >\n        <Stack space=\"xs\">\n          <StyledMediaContainer\n            size={size}\n            height={height}\n            backgroundColor={backgroundColor}\n            squareByWidth={squareByWidth}\n            srcError={srcError}\n          >\n            <StyledMedia squareByWidth={squareByWidth} srcError={srcError}>\n              {srcError ? (\n                <Icon name=\"image-broken\" color=\"tertiary\" />\n              ) : (\n                <Image\n                  src={src}\n                  fit={fit}\n                  title={title}\n                  alt={title}\n                  width=\"100%\"\n                  height=\"100%\"\n                  aria-hidden=\"true\"\n                  onError={onError}\n                />\n              )}\n            </StyledMedia>\n            <StyledOverlay />\n            {showCategoryOver && (\n              <StyledIconContainer>\n                <Icon name={categoryIcon} size=\"s\" color=\"inherit\" />\n              </StyledIconContainer>\n            )}\n          </StyledMediaContainer>\n          {(showCategoryUnder || showTitle) && (\n            <Stack space=\"xxs\">\n              {showCategoryUnder && (\n                <Inline space=\"xxs\" vAlignItems=\"center\">\n                  <Icon name={categoryIcon} color=\"quaternary\" size=\"s\" />\n                  <Text\n                    color=\"tertiary\"\n                    size=\"xs\"\n                    transform=\"uppercase\"\n                    weight=\"bold\"\n                  >\n                    {categoryLabel}\n                  </Text>\n                </Inline>\n              )}\n              {showTitle && (\n                <StyledTextClamped\n                  size={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAuFqB"} */"),StyledMediaContainer=(0,_styled.default)("div",{target:"e1we4x3d4",label:"StyledMediaContainer"})(({theme,size,height,backgroundColor,squareByWidth,srcError})=>({overflow:"hidden",border:"1px solid",borderColor:theme.values.color.border.secondary.default,borderRadius:theme.variables.size.borderRadius.s,position:"relative",backgroundClip:"padding-box",backgroundColor:theme.values.color.mediaItem.background[backgroundColor],height:mediaSize[size]||height||"auto",...squareByWidth&&{paddingTop:"calc(100% - 2px)",height:"auto"},...srcError&&{backgroundColor:theme.values.color.background.transparent.active}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    const noVisibleText = !showTitle && !showCategoryUnder;\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        {...rest}\n        aria-label={noVisibleText ? title : undefined}\n      >\n        <Stack space=\"xs\">\n          <StyledMediaContainer\n            size={size}\n            height={height}\n            backgroundColor={backgroundColor}\n            squareByWidth={squareByWidth}\n            srcError={srcError}\n          >\n            <StyledMedia squareByWidth={squareByWidth} srcError={srcError}>\n              {srcError ? (\n                <Icon name=\"image-broken\" color=\"tertiary\" />\n              ) : (\n                <Image\n                  src={src}\n                  fit={fit}\n                  title={title}\n                  alt={title}\n                  width=\"100%\"\n                  height=\"100%\"\n                  aria-hidden=\"true\"\n                  onError={onError}\n                />\n              )}\n            </StyledMedia>\n            <StyledOverlay />\n            {showCategoryOver && (\n              <StyledIconContainer>\n                <Icon name={categoryIcon} size=\"s\" color=\"inherit\" />\n              </StyledIconContainer>\n            )}\n          </StyledMediaContainer>\n          {(showCategoryUnder || showTitle) && (\n            <Stack space=\"xxs\">\n              {showCategoryUnder && (\n                <Inline space=\"xxs\" vAlignItems=\"center\">\n                  <Icon name={categoryIcon} color=\"quaternary\" size=\"s\" />\n                  <Text\n                    color=\"tertiary\"\n                    size=\"xs\"\n                    transform=\"uppercase\"\n                    weight=\"bold\"\n                  >\n                    {categoryLabel}\n                  </Text>\n                </Inline>\n              )}\n              {showTitle && (\n                <StyledTextClamped\n                  size={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAgI6B"} */"),StyledIconContainer=(0,_styled.default)("div",{target:"e1we4x3d5",label:"StyledIconContainer"})(({theme})=>({position:"absolute",left:theme.variables.size.spacing.xxs,bottom:theme.variables.size.spacing.xxs,overflow:"hidden",borderRadius:theme.variables.size.borderRadius.xs,backgroundColor:theme.values.color.mediaItem.categoryIcon.background.default,padding:theme.variables.size.spacing.xxs,color:theme.values.color.text.onAccent.default}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    const noVisibleText = !showTitle && !showCategoryUnder;\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        {...rest}\n        aria-label={noVisibleText ? title : undefined}\n      >\n        <Stack space=\"xs\">\n          <StyledMediaContainer\n            size={size}\n            height={height}\n            backgroundColor={backgroundColor}\n            squareByWidth={squareByWidth}\n            srcError={srcError}\n          >\n            <StyledMedia squareByWidth={squareByWidth} srcError={srcError}>\n              {srcError ? (\n                <Icon name=\"image-broken\" color=\"tertiary\" />\n              ) : (\n                <Image\n                  src={src}\n                  fit={fit}\n                  title={title}\n                  alt={title}\n                  width=\"100%\"\n                  height=\"100%\"\n                  aria-hidden=\"true\"\n                  onError={onError}\n                />\n              )}\n            </StyledMedia>\n            <StyledOverlay />\n            {showCategoryOver && (\n              <StyledIconContainer>\n                <Icon name={categoryIcon} size=\"s\" color=\"inherit\" />\n              </StyledIconContainer>\n            )}\n          </StyledMediaContainer>\n          {(showCategoryUnder || showTitle) && (\n            <Stack space=\"xxs\">\n              {showCategoryUnder && (\n                <Inline space=\"xxs\" vAlignItems=\"center\">\n                  <Icon name={categoryIcon} color=\"quaternary\" size=\"s\" />\n                  <Text\n                    color=\"tertiary\"\n                    size=\"xs\"\n                    transform=\"uppercase\"\n                    weight=\"bold\"\n                  >\n                    {categoryLabel}\n                  </Text>\n                </Inline>\n              )}\n              {showTitle && (\n                <StyledTextClamped\n                  size={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAiJ4B"} */"),MediaItem=_react.default.forwardRef(({"data-e2e-test-id":dataE2eTestId,as,src,title,showTitle=!0,fit="cover",categoryIcon,categoryLabel,categoryPlacement="outside",size,width,height,backgroundColor="transparent",hyphens="none",squareByWidth=!1,isActive,...rest},ref)=>{let[srcError,setSrcError]=(0,_react.useState)(!1),showCategoryOver=categoryIcon&&(!size&&"inside"===categoryPlacement||"xs"===size||"s"===size||"m"===size),showCategoryUnder=categoryIcon&&categoryLabel&&(!size&&"outside"===categoryPlacement||"l"===size||"xl"===size),textSize=["xs","s","m"].includes(size)?"xs":"s",noVisibleText=!showTitle&&!showCategoryUnder;return _react.default.createElement(StyledButton,{"data-ds-id":"MediaItem","data-e2e-test-id":dataE2eTestId,as:as,ref:ref,size:size,width:width,isActive:isActive,...rest,"aria-label":noVisibleText?title:void 0},_react.default.createElement(_Stack.Stack,{space:"xs"},_react.default.createElement(StyledMediaContainer,{size:size,height:height,backgroundColor:backgroundColor,squareByWidth:squareByWidth,srcError:srcError},_react.default.createElement(StyledMedia,{squareByWidth:squareByWidth,srcError:srcError},srcError?_react.default.createElement(_Icon.Icon,{name:"image-broken",color:"tertiary"}):_react.default.createElement(_Image.Image,{src:src,fit:fit,title:title,alt:title,width:"100%",height:"100%","aria-hidden":"true",onError:()=>{setSrcError(!0)}})),_react.default.createElement(StyledOverlay,null),showCategoryOver&&_react.default.createElement(StyledIconContainer,null,_react.default.createElement(_Icon.Icon,{name:categoryIcon,size:"s",color:"inherit"}))),(showCategoryUnder||showTitle)&&_react.default.createElement(_Stack.Stack,{space:"xxs"},showCategoryUnder&&_react.default.createElement(_Inline.Inline,{space:"xxs",vAlignItems:"center"},_react.default.createElement(_Icon.Icon,{name:categoryIcon,color:"quaternary",size:"s"}),_react.default.createElement(_Text.Text,{color:"tertiary",size:"xs",transform:"uppercase",weight:"bold"},categoryLabel)),showTitle&&_react.default.createElement(StyledTextClamped,{size:textSize,color:"secondary",lines:3,hyphens:hyphens,overflowWrap:"break-word"},title))))});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Expandable",{enumerable:!0,get:function(){return Expandable}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_useWindow=require("../../../shared/useWindow"),StyledContainer=(0,_styled.default)("div",{target:"
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Expandable",{enumerable:!0,get:function(){return Expandable}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_useWindow=require("../../../shared/useWindow"),StyledContainer=(0,_styled.default)("div",{target:"elbd590",label:"StyledContainer"})(({isExpanded,reduceMotion})=>({display:"grid",gridTemplateRows:"0fr",...!reduceMotion&&{transition:"200ms grid-template-rows cubic-bezier(0.0, 0.0, 0.25, 1.0)"},...isExpanded&&{gridTemplateRows:"1fr"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvVXRpbGl0aWVzL0V4cGFuZGFibGUvRXhwYW5kYWJsZS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1V0aWxpdGllcy9FeHBhbmRhYmxlL0V4cGFuZGFibGUudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjaywgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFByb3BlcnR5IH0gZnJvbSBcImNzc3R5cGVcIjtcbmltcG9ydCBpc1Byb3BWYWxpZCBmcm9tIFwiQGVtb3Rpb24vaXMtcHJvcC12YWxpZFwiO1xuaW1wb3J0IHsgdXNlV2luZG93IH0gZnJvbSBcIi4uLy4uLy4uL3NoYXJlZC91c2VXaW5kb3dcIjtcblxuZXhwb3J0IHR5cGUgRXhwYW5kYWJsZVByb3BzID0ge1xuICAvKiogYGlkYCBjYW4gYmUgcmVmZXJlbmNlZCBieSB0aGUgYnV0dG9uIHRyaWdnZXIncyBhcmlhLWNvbnRyb2xzIGF0dHJpYnV0ZSB0byBlc3RhYmxpc2ggYWNjZXNzaWJpbGl0eSBsaW5rYWdlLiAqL1xuICBpZD86IHN0cmluZztcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbiAgaXNFeHBhbmRlZD86IGJvb2xlYW47XG4gIC8qKiBJbnRlcm5hbGx5IG92ZXJmbG93IGlzIHNldCB0byBoaWRkZW4gd2hlbiBjb2xsYXBzZWQuIFVzZSB0aGlzIHByb3AgdG8gcmVzdG9yZSBvdmVyZmxvdyBvbiBleHBhbmQgKi9cbiAgb3ZlcmZsb3c/OiBQcm9wZXJ0eS5PdmVyZmxvdztcbiAgcmVkdWNlTW90aW9uPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IEFOSU1BVElPTl9USU1FID0gMjAwO1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2PFBhcnRpYWw8RXhwYW5kYWJsZVByb3BzPj4oXG4gICh7IGlzRXhwYW5kZWQsIHJlZHVjZU1vdGlvbiB9KSA9PiAoe1xuICAgIGRpc3BsYXk6IFwiZ3JpZFwiLFxuICAgIGdyaWRUZW1wbGF0ZVJvd3M6IFwiMGZyXCIsXG5cbiAgICAuLi4oIXJlZHVjZU1vdGlvbiAmJiB7XG4gICAgICB0cmFuc2l0aW9uOiBgJHtBTklNQVRJT05fVElNRX1tcyBncmlkLXRlbXBsYXRlLXJvd3MgY3ViaWMtYmV6aWVyKDAuMCwgMC4wLCAwLjI1LCAxLjApYCxcbiAgICB9KSxcblxuICAgIC4uLihpc0V4cGFuZGVkICYmIHtcbiAgICAgIGdyaWRUZW1wbGF0ZVJvd3M6IFwiMWZyXCIsXG4gICAgfSksXG4gIH0pXG4pO1xuXG50eXBlIFN0eWxlZENvbnRlbnRDb250YWluZXJQcm9wcyA9IHtcbiAgaXNFeHBhbmRlZDogYm9vbGVhbjtcbn0gJiBQaWNrPEV4cGFuZGFibGVQcm9wcywgXCJvdmVyZmxvd1wiPjtcblxuY29uc3QgU3R5bGVkQ29udGVudENvbnRhaW5lciA9IHN0eWxlZChcImRpdlwiLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiAocHJvcCkgPT5cbiAgICBpc1Byb3BWYWxpZChwcm9wKSAmJiBwcm9wICE9PSBcIm92ZXJmbG93XCIgJiYgcHJvcCAhPT0gXCJpc0V4cGFuZGVkXCIsXG59KTxTdHlsZWRDb250ZW50Q29udGFpbmVyUHJvcHM+KCh7IGlzRXhwYW5kZWQsIG92ZXJmbG93IH0pID0+ICh7XG4gIG92ZXJmbG93OiBcImhpZGRlblwiLFxuXG4gIC4uLihpc0V4cGFuZGVkICYmIHtcbiAgICBvdmVyZmxvdyxcbiAgfSksXG59KSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBFeHBhbmRhYmxlKHtcbiAgaWQsXG4gIGlzRXhwYW5kZWQsXG4gIGNoaWxkcmVuLFxuICBvdmVyZmxvdyA9IFwidmlzaWJsZVwiLFxuICByZWR1Y2VNb3Rpb24gPSBmYWxzZSxcbiAgLi4uYXJpYUF0dHJpYnV0ZXNcbn06IEV4cGFuZGFibGVQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIGNvbnN0IFtpc0NvbnRlbnRDb250YWluZXJFeHBhbmRlZCwgc2V0SXNDb250ZW50Q29udGFpbmVyRXhwYW5kZWRdID0gdXNlU3RhdGUoXG4gICAgISFpc0V4cGFuZGVkXG4gICk7XG5cbiAgY29uc3Qgd2luZG93ID0gdXNlV2luZG93KCk7XG4gIGNvbnN0IGlzTW90aW9uUmVkdWNlZCA9XG4gICAgcmVkdWNlTW90aW9uIHx8XG4gICAgd2luZG93Py5tYXRjaE1lZGlhKFwiKHByZWZlcnMtcmVkdWNlZC1tb3Rpb246IHJlZHVjZSlcIikubWF0Y2hlcztcblxuICBjb25zdCBoYW5kbGVUcmFuc2l0aW9uRW5kID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgIGlmIChpc0V4cGFuZGVkKSB7XG4gICAgICBzZXRJc0NvbnRlbnRDb250YWluZXJFeHBhbmRlZCh0cnVlKTtcbiAgICB9XG4gIH0sIFtpc0V4cGFuZGVkXSk7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoaXNNb3Rpb25SZWR1Y2VkKSB7XG4gICAgICBzZXRJc0NvbnRlbnRDb250YWluZXJFeHBhbmRlZChpc0V4cGFuZGVkKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBpZiAoIWlzRXhwYW5kZWQpIHtcbiAgICAgIHNldElzQ29udGVudENvbnRhaW5lckV4cGFuZGVkKGZhbHNlKTtcbiAgICB9XG4gIH0sIFtpc0V4cGFuZGVkLCBpc01vdGlvblJlZHVjZWRdKTtcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgIG9uVHJhbnNpdGlvbkVuZD17aGFuZGxlVHJhbnNpdGlvbkVuZH1cbiAgICAgIGlzRXhwYW5kZWQ9e2lzRXhwYW5kZWR9XG4gICAgICBkYXRhLWRzLWlkPVwiRXhwYW5kYWJsZVwiXG4gICAgICBpZD17aWR9XG4gICAgICByZWR1Y2VNb3Rpb249e2lzTW90aW9uUmVkdWNlZH1cbiAgICAgIHsuLi5hcmlhQXR0cmlidXRlc31cbiAgICA+XG4gICAgICA8U3R5bGVkQ29udGVudENvbnRhaW5lclxuICAgICAgICBpc0V4cGFuZGVkPXtpc0NvbnRlbnRDb250YWluZXJFeHBhbmRlZH1cbiAgICAgICAgb3ZlcmZsb3c9e292ZXJmbG93fVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L1N0eWxlZENvbnRlbnRDb250YWluZXI+XG4gICAgPC9TdHlsZWRDb250YWluZXI+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0J3QiJ9 */"),StyledContentContainer=(0,_styled.default)("div",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"overflow"!==prop&&"isExpanded"!==prop,target:"elbd591",label:"StyledContentContainer"})(({isExpanded,overflow})=>({overflow:"hidden",...isExpanded&&{overflow}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvVXRpbGl0aWVzL0V4cGFuZGFibGUvRXhwYW5kYWJsZS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1V0aWxpdGllcy9FeHBhbmRhYmxlL0V4cGFuZGFibGUudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjaywgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFByb3BlcnR5IH0gZnJvbSBcImNzc3R5cGVcIjtcbmltcG9ydCBpc1Byb3BWYWxpZCBmcm9tIFwiQGVtb3Rpb24vaXMtcHJvcC12YWxpZFwiO1xuaW1wb3J0IHsgdXNlV2luZG93IH0gZnJvbSBcIi4uLy4uLy4uL3NoYXJlZC91c2VXaW5kb3dcIjtcblxuZXhwb3J0IHR5cGUgRXhwYW5kYWJsZVByb3BzID0ge1xuICAvKiogYGlkYCBjYW4gYmUgcmVmZXJlbmNlZCBieSB0aGUgYnV0dG9uIHRyaWdnZXIncyBhcmlhLWNvbnRyb2xzIGF0dHJpYnV0ZSB0byBlc3RhYmxpc2ggYWNjZXNzaWJpbGl0eSBsaW5rYWdlLiAqL1xuICBpZD86IHN0cmluZztcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbiAgaXNFeHBhbmRlZD86IGJvb2xlYW47XG4gIC8qKiBJbnRlcm5hbGx5IG92ZXJmbG93IGlzIHNldCB0byBoaWRkZW4gd2hlbiBjb2xsYXBzZWQuIFVzZSB0aGlzIHByb3AgdG8gcmVzdG9yZSBvdmVyZmxvdyBvbiBleHBhbmQgKi9cbiAgb3ZlcmZsb3c/OiBQcm9wZXJ0eS5PdmVyZmxvdztcbiAgcmVkdWNlTW90aW9uPzogYm9vbGVhbjtcbn07XG5cbmNvbnN0IEFOSU1BVElPTl9USU1FID0gMjAwO1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2PFBhcnRpYWw8RXhwYW5kYWJsZVByb3BzPj4oXG4gICh7IGlzRXhwYW5kZWQsIHJlZHVjZU1vdGlvbiB9KSA9PiAoe1xuICAgIGRpc3BsYXk6IFwiZ3JpZFwiLFxuICAgIGdyaWRUZW1wbGF0ZVJvd3M6IFwiMGZyXCIsXG5cbiAgICAuLi4oIXJlZHVjZU1vdGlvbiAmJiB7XG4gICAgICB0cmFuc2l0aW9uOiBgJHtBTklNQVRJT05fVElNRX1tcyBncmlkLXRlbXBsYXRlLXJvd3MgY3ViaWMtYmV6aWVyKDAuMCwgMC4wLCAwLjI1LCAxLjApYCxcbiAgICB9KSxcblxuICAgIC4uLihpc0V4cGFuZGVkICYmIHtcbiAgICAgIGdyaWRUZW1wbGF0ZVJvd3M6IFwiMWZyXCIsXG4gICAgfSksXG4gIH0pXG4pO1xuXG50eXBlIFN0eWxlZENvbnRlbnRDb250YWluZXJQcm9wcyA9IHtcbiAgaXNFeHBhbmRlZDogYm9vbGVhbjtcbn0gJiBQaWNrPEV4cGFuZGFibGVQcm9wcywgXCJvdmVyZmxvd1wiPjtcblxuY29uc3QgU3R5bGVkQ29udGVudENvbnRhaW5lciA9IHN0eWxlZChcImRpdlwiLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiAocHJvcCkgPT5cbiAgICBpc1Byb3BWYWxpZChwcm9wKSAmJiBwcm9wICE9PSBcIm92ZXJmbG93XCIgJiYgcHJvcCAhPT0gXCJpc0V4cGFuZGVkXCIsXG59KTxTdHlsZWRDb250ZW50Q29udGFpbmVyUHJvcHM+KCh7IGlzRXhwYW5kZWQsIG92ZXJmbG93IH0pID0+ICh7XG4gIG92ZXJmbG93OiBcImhpZGRlblwiLFxuXG4gIC4uLihpc0V4cGFuZGVkICYmIHtcbiAgICBvdmVyZmxvdyxcbiAgfSksXG59KSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBFeHBhbmRhYmxlKHtcbiAgaWQsXG4gIGlzRXhwYW5kZWQsXG4gIGNoaWxkcmVuLFxuICBvdmVyZmxvdyA9IFwidmlzaWJsZVwiLFxuICByZWR1Y2VNb3Rpb24gPSBmYWxzZSxcbiAgLi4uYXJpYUF0dHJpYnV0ZXNcbn06IEV4cGFuZGFibGVQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIGNvbnN0IFtpc0NvbnRlbnRDb250YWluZXJFeHBhbmRlZCwgc2V0SXNDb250ZW50Q29udGFpbmVyRXhwYW5kZWRdID0gdXNlU3RhdGUoXG4gICAgISFpc0V4cGFuZGVkXG4gICk7XG5cbiAgY29uc3Qgd2luZG93ID0gdXNlV2luZG93KCk7XG4gIGNvbnN0IGlzTW90aW9uUmVkdWNlZCA9XG4gICAgcmVkdWNlTW90aW9uIHx8XG4gICAgd2luZG93Py5tYXRjaE1lZGlhKFwiKHByZWZlcnMtcmVkdWNlZC1tb3Rpb246IHJlZHVjZSlcIikubWF0Y2hlcztcblxuICBjb25zdCBoYW5kbGVUcmFuc2l0aW9uRW5kID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgIGlmIChpc0V4cGFuZGVkKSB7XG4gICAgICBzZXRJc0NvbnRlbnRDb250YWluZXJFeHBhbmRlZCh0cnVlKTtcbiAgICB9XG4gIH0sIFtpc0V4cGFuZGVkXSk7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoaXNNb3Rpb25SZWR1Y2VkKSB7XG4gICAgICBzZXRJc0NvbnRlbnRDb250YWluZXJFeHBhbmRlZChpc0V4cGFuZGVkKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBpZiAoIWlzRXhwYW5kZWQpIHtcbiAgICAgIHNldElzQ29udGVudENvbnRhaW5lckV4cGFuZGVkKGZhbHNlKTtcbiAgICB9XG4gIH0sIFtpc0V4cGFuZGVkLCBpc01vdGlvblJlZHVjZWRdKTtcblxuICByZXR1cm4gKFxuICAgIDxTdHlsZWRDb250YWluZXJcbiAgICAgIG9uVHJhbnNpdGlvbkVuZD17aGFuZGxlVHJhbnNpdGlvbkVuZH1cbiAgICAgIGlzRXhwYW5kZWQ9e2lzRXhwYW5kZWR9XG4gICAgICBkYXRhLWRzLWlkPVwiRXhwYW5kYWJsZVwiXG4gICAgICBpZD17aWR9XG4gICAgICByZWR1Y2VNb3Rpb249e2lzTW90aW9uUmVkdWNlZH1cbiAgICAgIHsuLi5hcmlhQXR0cmlidXRlc31cbiAgICA+XG4gICAgICA8U3R5bGVkQ29udGVudENvbnRhaW5lclxuICAgICAgICBpc0V4cGFuZGVkPXtpc0NvbnRlbnRDb250YWluZXJFeHBhbmRlZH1cbiAgICAgICAgb3ZlcmZsb3c9e292ZXJmbG93fVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L1N0eWxlZENvbnRlbnRDb250YWluZXI+XG4gICAgPC9TdHlsZWRDb250YWluZXI+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUMrQiJ9 */");function Expandable({id,isExpanded,children,overflow="visible",reduceMotion=!1,...ariaAttributes}){let[isContentContainerExpanded,setIsContentContainerExpanded]=(0,_react.useState)(!!isExpanded),window=(0,_useWindow.useWindow)(),isMotionReduced=reduceMotion||window?.matchMedia("(prefers-reduced-motion: reduce)").matches,handleTransitionEnd=(0,_react.useCallback)(()=>{isExpanded&&setIsContentContainerExpanded(!0)},[isExpanded]);return(0,_react.useEffect)(()=>{if(isMotionReduced)return void setIsContentContainerExpanded(isExpanded);isExpanded||setIsContentContainerExpanded(!1)},[isExpanded,isMotionReduced]),_react.default.createElement(StyledContainer,{onTransitionEnd:handleTransitionEnd,isExpanded:isExpanded,"data-ds-id":"Expandable",id:id,reduceMotion:isMotionReduced,...ariaAttributes},_react.default.createElement(StyledContentContainer,{isExpanded:isContentContainerExpanded,overflow:overflow},children))}
|
|
@@ -187,9 +187,9 @@
|
|
|
187
187
|
"smartzoom": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" d=\"m7.593 15.164-1.7-1a1 1 0 0 1 1.013-1.724l1.701.999a1.002 1.002 0 0 1-1.014 1.725m7.288-8.6C17.989 7.917 20 10.926 20 14.401c0 4.676-3.504 8.372-8.151 8.6H5a1 1 0 1 1 0-1.999h6.8c3.514-.173 6.2-3.01 6.2-6.6 0-2.997-1.954-5.543-4.862-6.336a1 1 0 0 1-.598-1.475l1.076-1.817-2.545-1.42-3.695 6.37 2.561 1.43 1.103-1.862a1 1 0 0 1 1.082-.466c2.653.603 4.578 2.948 4.578 5.575 0 3.143-2.656 5.8-5.8 5.8a5.76 5.76 0 0 1-3.791-1.4H5a1 1 0 1 1 0-2h2.5c.265 0 .52.106.707.293a3.78 3.78 0 0 0 2.693 1.107c2.06 0 3.8-1.74 3.8-3.8 0-1.474-.953-2.815-2.345-3.406l-1.195 2.016a1 1 0 0 1-1.347.363l-4.3-2.4A1.003 1.003 0 0 1 5.135 9.6l4.701-8.1a.996.996 0 0 1 1.352-.37l4.299 2.4a1 1 0 0 1 .373 1.382z\"/></svg>",
|
|
188
188
|
"sop": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"currentColor\" viewBox=\"0 0 24 24\"><path d=\"M7 11a2 2 0 0 1 2 2v1h1a2 2 0 0 1 2 2v2a2 2 0 0 1-2 2H9v1a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-1H2a2 2 0 0 1-2-2v-2a2 2 0 0 1 2-2h1v-1a2 2 0 0 1 2-2zm8-10a2 2 0 0 1 2 2h1a3 3 0 0 1 3 3v14a3 3 0 0 1-3 3h-5a1 1 0 1 1 0-2h5a1 1 0 0 0 1-1V6a1 1 0 0 0-1-1h-1a2 2 0 0 1-2 2H9a2 2 0 0 1-2-2H6a1 1 0 0 0-1 1v2a1 1 0 0 1-2 0V6a3 3 0 0 1 3-3h1a2 2 0 0 1 2-2zM5 16H2v2h3v3h2v-3h3v-2H7v-3H5zM9 5h6V3H9z\"/></svg>",
|
|
189
189
|
"sort": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M6 5v15m5-5-5 5-5-5m17 4V4m-5 5 5-5 5 5\"/></svg>",
|
|
190
|
-
"sort-ascending": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m6 11 4.94-6.06a1.5 1.5 0 0 1 2.12 0L18 11z\" clip-rule=\"evenodd\"/><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m18 13-4.94 6.06a1.5 1.5 0 0 1-2.12 0L6 13z\" clip-rule=\"evenodd\" opacity=\".
|
|
191
|
-
"sort-descending": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m18 13-4.94 6.06a1.5 1.5 0 0 1-2.12 0L6 13z\" clip-rule=\"evenodd\"/><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m6 11 4.94-6.06a1.5 1.5 0 0 1 2.12 0L18 11z\" clip-rule=\"evenodd\" opacity=\".
|
|
192
|
-
"sort-neutral": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" d=\"m18 11-4.94-6.06a1.5 1.5 0 0 0-2.12 0L6 11zM6 13l4.94 6.06a1.5 1.5 0 0 0 2.12 0L18 13z\" opacity=\".
|
|
190
|
+
"sort-ascending": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m6 11 4.94-6.06a1.5 1.5 0 0 1 2.12 0L18 11z\" clip-rule=\"evenodd\"/><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m18 13-4.94 6.06a1.5 1.5 0 0 1-2.12 0L6 13z\" clip-rule=\"evenodd\" opacity=\".47\"/></svg>",
|
|
191
|
+
"sort-descending": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m18 13-4.94 6.06a1.5 1.5 0 0 1-2.12 0L6 13z\" clip-rule=\"evenodd\"/><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m6 11 4.94-6.06a1.5 1.5 0 0 1 2.12 0L18 11z\" clip-rule=\"evenodd\" opacity=\".47\"/></svg>",
|
|
192
|
+
"sort-neutral": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" d=\"m18 11-4.94-6.06a1.5 1.5 0 0 0-2.12 0L6 11zM6 13l4.94 6.06a1.5 1.5 0 0 0 2.12 0L18 13z\" opacity=\".47\"/></svg>",
|
|
193
193
|
"special-character": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" viewBox=\"0 0 24 24\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"M12 4a7 7 0 0 0-7 7c0 1.181.522 2.354 1.384 3.432.86 1.076 2.008 1.991 3.117 2.632a1 1 0 0 1 .499.866V21a1 1 0 0 1-1 1H4a1 1 0 1 1 0-2h4v-1.508c-1.127-.719-2.27-1.676-3.178-2.81C3.782 14.38 3 12.78 3 11a9 9 0 0 1 18 0c0 1.78-.782 3.38-1.822 4.681-.908 1.135-2.05 2.092-3.178 2.81V20h4a1 1 0 1 1 0 2h-5a1 1 0 0 1-1-1v-3.07a1 1 0 0 1 .5-.866c1.107-.64 2.256-1.556 3.116-2.632C18.478 13.354 19 12.182 19 11a7 7 0 0 0-7-7\" clip-rule=\"evenodd\"/></svg>",
|
|
194
194
|
"split-view": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"currentColor\" viewBox=\"0 0 24 24\"><path fill-rule=\"evenodd\" d=\"M19 2a3 3 0 0 1 3 3v14a3 3 0 0 1-3 3H5a3 3 0 0 1-3-3V5a3 3 0 0 1 3-3zm-6 18h6a1 1 0 0 0 1-1V5a1 1 0 0 0-1-1h-6zM5 4a1 1 0 0 0-1 1v14a1 1 0 0 0 1 1h6V4z\" clip-rule=\"evenodd\"/></svg>",
|
|
195
195
|
"square": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" fill=\"none\" stroke=\"currentColor\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke-width=\"2\" viewBox=\"0 0 24 24\"><rect width=\"18\" height=\"18\" x=\"3\" y=\"3\" rx=\"2\" ry=\"2\"/></svg>",
|
|
@@ -187,9 +187,9 @@
|
|
|
187
187
|
"smartzoom": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"M4.182 5.768a1 1 0 0 0 .05 1.414l.266.248-.828.887a.25.25 0 0 0 .013.353l2.012 1.875a.25.25 0 0 0 .353-.012l.827-.887.283.263a1 1 0 0 0 1.413-.05l2.69-2.885a3.5 3.5 0 1 1-4.37 5.359L6.593 12H2v4h7c3.028 0 5.307-2.245 5.867-4.793a5.49 5.49 0 0 0-2.221-5.72l.698-.748a1 1 0 0 0-.05-1.413L10.368.598a1 1 0 0 0-1.413.05zm2.145.633L7.79 7.764l3.409-3.657-1.463-1.364z\" clip-rule=\"evenodd\"/></svg>",
|
|
188
188
|
"sop": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\"><path fill-rule=\"evenodd\" d=\"M6.5 6A1.5 1.5 0 0 1 8 7.5V8h.5A1.5 1.5 0 0 1 10 9.5v3A1.5 1.5 0 0 1 8.5 14H8v.5A1.5 1.5 0 0 1 6.5 16h-3A1.5 1.5 0 0 1 2 14.5V14h-.5A1.5 1.5 0 0 1 0 12.5v-3A1.5 1.5 0 0 1 1.5 8H2v-.5A1.5 1.5 0 0 1 3.5 6zM4 10H2v2h2v2h2v-2h2v-2H6V8H4z\" clip-rule=\"evenodd\"/><path d=\"M10 0a1 1 0 0 1 1 1h.75C13.052 1 14 2.106 14 3.333v9.334C14 13.894 13.052 15 11.75 15H11v-2h.75c.078 0 .25-.087.25-.333V3.333c0-.246-.172-.333-.25-.333H11l-.005.103A1 1 0 0 1 10 4H6a1 1 0 0 1-1-1h-.75c-.078 0-.25.087-.25.333V5H2V3.333C2 2.106 2.948 1 4.25 1H5a1 1 0 0 1 1-1z\"/></svg>",
|
|
189
189
|
"sort": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><g stroke=\"currentColor\" stroke-linecap=\"round\" stroke-width=\"2\"><path stroke-linejoin=\"bevel\" d=\"M4 3v9\"/><path stroke-linejoin=\"round\" d=\"m7 10-3 3-3-3\"/><path stroke-linejoin=\"bevel\" d=\"M12 13V4\"/><path stroke-linejoin=\"round\" d=\"m9 6 3-3 3 3\"/></g></svg>",
|
|
190
|
-
"sort-ascending": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m4.293 7 3-3.707a1 1 0 0 1 1.414 0l3 3.707z\" clip-rule=\"evenodd\"/><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m11.707 9-3 3.707a1 1 0 0 1-1.414 0L4.293 9z\" clip-rule=\"evenodd\" opacity=\".
|
|
191
|
-
"sort-descending": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m11.707 9-3 3.707a1 1 0 0 1-1.414 0L4.293 9z\" clip-rule=\"evenodd\"/><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m4.293 7 3-3.707a1 1 0 0 1 1.414 0l3 3.707z\" clip-rule=\"evenodd\" opacity=\".
|
|
192
|
-
"sort-neutral": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" d=\"m11.707 7-3-3.707a1 1 0 0 0-1.414 0L4.293 7zM4.293 9l3 3.707a1 1 0 0 0 1.414 0l3-3.707z\" opacity=\".
|
|
190
|
+
"sort-ascending": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m4.293 7 3-3.707a1 1 0 0 1 1.414 0l3 3.707z\" clip-rule=\"evenodd\"/><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m11.707 9-3 3.707a1 1 0 0 1-1.414 0L4.293 9z\" clip-rule=\"evenodd\" opacity=\".47\"/></svg>",
|
|
191
|
+
"sort-descending": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m11.707 9-3 3.707a1 1 0 0 1-1.414 0L4.293 9z\" clip-rule=\"evenodd\"/><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"m4.293 7 3-3.707a1 1 0 0 1 1.414 0l3 3.707z\" clip-rule=\"evenodd\" opacity=\".47\"/></svg>",
|
|
192
|
+
"sort-neutral": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" d=\"m11.707 7-3-3.707a1 1 0 0 0-1.414 0L4.293 7zM4.293 9l3 3.707a1 1 0 0 0 1.414 0l3-3.707z\" opacity=\".47\"/></svg>",
|
|
193
193
|
"special-character": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path stroke=\"currentColor\" stroke-linecap=\"square\" stroke-linejoin=\"round\" stroke-width=\"2\" d=\"M3 13h3v-1.876c-1.495-.846-3-2.426-3-4.235C3 4.189 5.239 2 8 2s5 2.189 5 4.889c0 1.81-1.505 3.39-3 4.235V13h3\"/></svg>",
|
|
194
194
|
"split-view": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"currentColor\" viewBox=\"0 0 16 16\"><path fill-rule=\"evenodd\" d=\"M13 1a2 2 0 0 1 2 2v10a2 2 0 0 1-1.796 1.99L13 15H3l-.204-.01a2 2 0 0 1-1.785-1.786L1 13V3a2 2 0 0 1 2-2zM3 13h4V3H3zm6 0h4V3H9z\" clip-rule=\"evenodd\"/></svg>",
|
|
195
195
|
"square": "<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" fill=\"none\" viewBox=\"0 0 16 16\"><path fill=\"currentColor\" fill-rule=\"evenodd\" d=\"M1 4a3 3 0 0 1 3-3h8a3 3 0 0 1 3 3v8a3 3 0 0 1-3 3H4a3 3 0 0 1-3-3zm3-1a1 1 0 0 0-1 1v8a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V4a1 1 0 0 0-1-1z\" clip-rule=\"evenodd\"/></svg>",
|