@amboss/design-system 2.4.0 → 2.4.1
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/Form/SearchInput/SearchInput.js +1 -1
- package/build/cjs/components/Form/ToggleButton/ToggleButton.js +1 -1
- package/build/cjs/components/MediaItem/MediaItem.js +1 -1
- package/build/cjs/components/Tag/Tag.js +1 -1
- package/build/cjs/web-tokens/_colors.json +198 -198
- package/build/cjs/web-tokens/visualConfig.d.ts +32 -32
- package/build/cjs/web-tokens/visualConfig.js +1 -1
- package/build/esm/components/Form/SearchInput/SearchInput.js +1 -1
- package/build/esm/components/Form/ToggleButton/ToggleButton.js +1 -1
- package/build/esm/components/MediaItem/MediaItem.js +1 -1
- package/build/esm/components/Tag/Tag.js +1 -1
- package/build/esm/web-tokens/_colors.json +198 -198
- package/build/esm/web-tokens/visualConfig.d.ts +32 -32
- package/build/esm/web-tokens/visualConfig.js +1 -1
- package/build/scss/_theming.scss +100 -48
- package/build/scss/_variables.scss +81 -55
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
import React,{useState}from"react";import styled from"@emotion/styled";import{Icon}from"../Icon/Icon";import{Stack}from"../Stack/Stack";import{TextClamped}from"../Typography/TextClamped/TextClamped";import{Text}from"../Typography/Text/Text";import{Inline}from"../Inline/Inline";import{Image}from"../Image/Image";let mediaSize={xs:80,s:88,m:110,l:128,xl:204},StyledTextClamped=styled(TextClamped,{target:"e18hf5dc0",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 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\nconst 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};\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  position: \"absolute\",\n  left: 0,\n  bottom: 0,\n  top: 0,\n  right: 0,\n}));\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width }) => ({\n    padding: 0,\n    backgroundColor: \" transparent\",\n    border: \"none\",\n    cursor: \"pointer\",\n    width: mediaSize[size] || width || \"100%\",\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  })\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    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.ReactElement | 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      ...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 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        {...rest}\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={size === \"xs\" || size === \"s\" ? \"xs\" : \"s\"}\n                  color=\"secondary\"\n                  lines={2}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAoD0B"} */"),StyledMedia=styled("div",{target:"e18hf5dc1",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 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\nconst 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};\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  position: \"absolute\",\n  left: 0,\n  bottom: 0,\n  top: 0,\n  right: 0,\n}));\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width }) => ({\n    padding: 0,\n    backgroundColor: \" transparent\",\n    border: \"none\",\n    cursor: \"pointer\",\n    width: mediaSize[size] || width || \"100%\",\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  })\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    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.ReactElement | 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      ...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 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        {...rest}\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={size === \"xs\" || size === \"s\" ? \"xs\" : \"s\"}\n                  color=\"secondary\"\n                  lines={2}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAsDoB"} */"),StyledOverlay=styled("div",{target:"e18hf5dc2",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 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\nconst 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};\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  position: \"absolute\",\n  left: 0,\n  bottom: 0,\n  top: 0,\n  right: 0,\n}));\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width }) => ({\n    padding: 0,\n    backgroundColor: \" transparent\",\n    border: \"none\",\n    cursor: \"pointer\",\n    width: mediaSize[size] || width || \"100%\",\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  })\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    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.ReactElement | 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      ...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 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        {...rest}\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={size === \"xs\" || size === \"s\" ? \"xs\" : \"s\"}\n                  color=\"secondary\"\n                  lines={2}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAwEsB"} */"),StyledButton=styled("button",{target:"e18hf5dc3",label:"StyledButton"})(({theme,size,width})=>({padding:0,backgroundColor:" transparent",border:"none",cursor:"pointer",width:mediaSize[size]||width||"100%",[`&: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}}),"/*# 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 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\nconst 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};\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  position: \"absolute\",\n  left: 0,\n  bottom: 0,\n  top: 0,\n  right: 0,\n}));\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width }) => ({\n    padding: 0,\n    backgroundColor: \" transparent\",\n    border: \"none\",\n    cursor: \"pointer\",\n    width: mediaSize[size] || width || \"100%\",\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  })\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    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.ReactElement | 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      ...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 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        {...rest}\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={size === \"xs\" || size === \"s\" ? \"xs\" : \"s\"}\n                  color=\"secondary\"\n                  lines={2}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAgFqB"} */"),StyledMediaContainer=styled("div",{target:"e18hf5dc4",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 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\nconst 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};\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  position: \"absolute\",\n  left: 0,\n  bottom: 0,\n  top: 0,\n  right: 0,\n}));\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width }) => ({\n    padding: 0,\n    backgroundColor: \" transparent\",\n    border: \"none\",\n    cursor: \"pointer\",\n    width: mediaSize[size] || width || \"100%\",\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  })\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    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.ReactElement | 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      ...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 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        {...rest}\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={size === \"xs\" || size === \"s\" ? \"xs\" : \"s\"}\n                  color=\"secondary\"\n                  lines={2}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAmG6B"} */"),StyledIconContainer=styled("div",{target:"e18hf5dc5",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 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\nconst 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};\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  position: \"absolute\",\n  left: 0,\n  bottom: 0,\n  top: 0,\n  right: 0,\n}));\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width }) => ({\n    padding: 0,\n    backgroundColor: \" transparent\",\n    border: \"none\",\n    cursor: \"pointer\",\n    width: mediaSize[size] || width || \"100%\",\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  })\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    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.ReactElement | 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      ...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 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        {...rest}\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={size === \"xs\" || size === \"s\" ? \"xs\" : \"s\"}\n                  color=\"secondary\"\n                  lines={2}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAoH4B"} */");export const MediaItem=React.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,...rest},ref)=>{let[srcError,setSrcError]=useState(!1),showCategoryOver=categoryIcon&&(!size&&"inside"===categoryPlacement||"xs"===size||"s"===size||"m"===size),showCategoryUnder=categoryIcon&&categoryLabel&&(!size&&"outside"===categoryPlacement||"l"===size||"xl"===size);return React.createElement(StyledButton,{"data-ds-id":"MediaItem","data-e2e-test-id":dataE2eTestId,as:as,ref:ref,size:size,width:width,...rest},React.createElement(Stack,{space:"xs"},React.createElement(StyledMediaContainer,{size:size,height:height,backgroundColor:backgroundColor,squareByWidth:squareByWidth,srcError:srcError},React.createElement(StyledMedia,{squareByWidth:squareByWidth,srcError:srcError},srcError?React.createElement(Icon,{name:"image-broken",color:"tertiary"}):React.createElement(Image,{src:src,fit:fit,title:title,alt:title,width:"100%",height:"100%","aria-hidden":"true",onError:()=>{setSrcError(!0)}})),React.createElement(StyledOverlay,null),showCategoryOver&&React.createElement(StyledIconContainer,null,React.createElement(Icon,{name:categoryIcon,size:"s",color:"inherit"}))),(showCategoryUnder||showTitle)&&React.createElement(Stack,{space:"xxs"},showCategoryUnder&&React.createElement(Inline,{space:"xxs",vAlignItems:"center"},React.createElement(Icon,{name:categoryIcon,color:"quaternary",size:"s"}),React.createElement(Text,{color:"tertiary",size:"xs",transform:"uppercase",weight:"bold"},categoryLabel)),showTitle&&React.createElement(StyledTextClamped,{size:"xs"===size||"s"===size?"xs":"s",color:"secondary",lines:2,hyphens:hyphens},title))))});
|
|
1
|
+
import React,{useState}from"react";import styled from"@emotion/styled";import{Icon}from"../Icon/Icon";import{Stack}from"../Stack/Stack";import{TextClamped}from"../Typography/TextClamped/TextClamped";import{Text}from"../Typography/Text/Text";import{Inline}from"../Inline/Inline";import{Image}from"../Image/Image";let mediaSize={xs:80,s:88,m:110,l:128,xl:204},StyledTextClamped=styled(TextClamped,{target:"e1w4yvl10",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 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\nconst 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};\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  position: \"absolute\",\n  left: 0,\n  bottom: 0,\n  top: 0,\n  right: 0,\n}));\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    width: mediaSize[size] || width || \"100%\",\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  })\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    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.ReactElement | 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      ...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 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        {...rest}\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={size === \"xs\" || size === \"s\" ? \"xs\" : \"s\"}\n                  color=\"secondary\"\n                  lines={2}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAoD0B"} */"),StyledMedia=styled("div",{target:"e1w4yvl11",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 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\nconst 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};\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  position: \"absolute\",\n  left: 0,\n  bottom: 0,\n  top: 0,\n  right: 0,\n}));\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    width: mediaSize[size] || width || \"100%\",\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  })\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    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.ReactElement | 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      ...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 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        {...rest}\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={size === \"xs\" || size === \"s\" ? \"xs\" : \"s\"}\n                  color=\"secondary\"\n                  lines={2}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAsDoB"} */"),StyledOverlay=styled("div",{target:"e1w4yvl12",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 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\nconst 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};\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  position: \"absolute\",\n  left: 0,\n  bottom: 0,\n  top: 0,\n  right: 0,\n}));\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    width: mediaSize[size] || width || \"100%\",\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  })\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    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.ReactElement | 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      ...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 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        {...rest}\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={size === \"xs\" || size === \"s\" ? \"xs\" : \"s\"}\n                  color=\"secondary\"\n                  lines={2}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAwEsB"} */"),StyledButton=styled("button",{target:"e1w4yvl13",label:"StyledButton"})(({theme,size,width})=>({padding:0,backgroundColor:theme.values.color.background.transparent.default,border:"none",cursor:"pointer",width:mediaSize[size]||width||"100%",[`&: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}}),"/*# 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 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\nconst 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};\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  position: \"absolute\",\n  left: 0,\n  bottom: 0,\n  top: 0,\n  right: 0,\n}));\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    width: mediaSize[size] || width || \"100%\",\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  })\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    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.ReactElement | 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      ...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 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        {...rest}\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={size === \"xs\" || size === \"s\" ? \"xs\" : \"s\"}\n                  color=\"secondary\"\n                  lines={2}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAgFqB"} */"),StyledMediaContainer=styled("div",{target:"e1w4yvl14",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 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\nconst 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};\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  position: \"absolute\",\n  left: 0,\n  bottom: 0,\n  top: 0,\n  right: 0,\n}));\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    width: mediaSize[size] || width || \"100%\",\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  })\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    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.ReactElement | 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      ...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 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        {...rest}\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={size === \"xs\" || size === \"s\" ? \"xs\" : \"s\"}\n                  color=\"secondary\"\n                  lines={2}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAmG6B"} */"),StyledIconContainer=styled("div",{target:"e1w4yvl15",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 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\nconst 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};\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  position: \"absolute\",\n  left: 0,\n  bottom: 0,\n  top: 0,\n  right: 0,\n}));\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    width: mediaSize[size] || width || \"100%\",\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  })\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    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.ReactElement | 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      ...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 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        {...rest}\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={size === \"xs\" || size === \"s\" ? \"xs\" : \"s\"}\n                  color=\"secondary\"\n                  lines={2}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAoH4B"} */");export const MediaItem=React.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,...rest},ref)=>{let[srcError,setSrcError]=useState(!1),showCategoryOver=categoryIcon&&(!size&&"inside"===categoryPlacement||"xs"===size||"s"===size||"m"===size),showCategoryUnder=categoryIcon&&categoryLabel&&(!size&&"outside"===categoryPlacement||"l"===size||"xl"===size);return React.createElement(StyledButton,{"data-ds-id":"MediaItem","data-e2e-test-id":dataE2eTestId,as:as,ref:ref,size:size,width:width,...rest},React.createElement(Stack,{space:"xs"},React.createElement(StyledMediaContainer,{size:size,height:height,backgroundColor:backgroundColor,squareByWidth:squareByWidth,srcError:srcError},React.createElement(StyledMedia,{squareByWidth:squareByWidth,srcError:srcError},srcError?React.createElement(Icon,{name:"image-broken",color:"tertiary"}):React.createElement(Image,{src:src,fit:fit,title:title,alt:title,width:"100%",height:"100%","aria-hidden":"true",onError:()=>{setSrcError(!0)}})),React.createElement(StyledOverlay,null),showCategoryOver&&React.createElement(StyledIconContainer,null,React.createElement(Icon,{name:categoryIcon,size:"s",color:"inherit"}))),(showCategoryUnder||showTitle)&&React.createElement(Stack,{space:"xxs"},showCategoryUnder&&React.createElement(Inline,{space:"xxs",vAlignItems:"center"},React.createElement(Icon,{name:categoryIcon,color:"quaternary",size:"s"}),React.createElement(Text,{color:"tertiary",size:"xs",transform:"uppercase",weight:"bold"},categoryLabel)),showTitle&&React.createElement(StyledTextClamped,{size:"xs"===size||"s"===size?"xs":"s",color:"secondary",lines:2,hyphens:hyphens},title))))});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import React from"react";import styled from"@emotion/styled";import{PictogramButton}from"../PictogramButton/PictogramButton";export const MAX_TAG_WIDTH=200;let TagContainer=styled("span",{target:"e2kqscs0",label:"TagContainer"})(({theme,colorVariant,isRemovable})=>({display:"inline-flex",alignItems:"center",maxWidth:"200px",paddingLeft:theme.variables.size.spacing.xs,paddingRight:isRemovable?theme.variables.size.spacing.zero:theme.variables.size.spacing.xs,borderRadius:theme.variables.size.borderRadius.xs,backgroundColor:theme.values.color.tag.background[colorVariant],color:theme.values.color.tag.text[colorVariant],fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.s,lineHeight:theme.variables.size.lineHeight.xs}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvVGFnL1RhZy50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1RhZy9UYWcudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgUGljdG9ncmFtQnV0dG9uIH0gZnJvbSBcIi4uL1BpY3RvZ3JhbUJ1dHRvbi9QaWN0b2dyYW1CdXR0b25cIjtcblxuZXhwb3J0IGNvbnN0IE1BWF9UQUdfV0lEVEggPSAyMDA7XG5cbnR5cGUgQmFzZVRhZ1Byb3BzID0ge1xuICBsYWJlbDogc3RyaW5nO1xuICBjb2xvclZhcmlhbnQ/OiBcImdyYXlcIiB8IFwiYmx1ZVwiO1xuICBcImRhdGEtZTJlLXRlc3QtaWRcIj86IHN0cmluZztcbn07XG50eXBlIENvbmRpdGlvbmFsVGFnUHJvcHMgPVxuICB8IHtcbiAgICAgIGlzUmVtb3ZhYmxlPzogZmFsc2U7XG4gICAgICBvbkNsZWFyPzogbmV2ZXI7XG4gICAgICBjbGVhckJ0bkFyaWFMYWJlbD86IG5ldmVyO1xuICAgIH1cbiAgfCB7XG4gICAgICBpc1JlbW92YWJsZTogdHJ1ZTtcbiAgICAgIG9uQ2xlYXI6IChlOiBSZWFjdC5Nb3VzZUV2ZW50KSA9PiB2b2lkO1xuICAgICAgY2xlYXJCdG5BcmlhTGFiZWw/OiBzdHJpbmc7XG4gICAgfTtcblxuZXhwb3J0IHR5cGUgVGFnUHJvcHMgPSBCYXNlVGFnUHJvcHMgJiBDb25kaXRpb25hbFRhZ1Byb3BzO1xuXG5jb25zdCBUYWdDb250YWluZXIgPSBzdHlsZWQuc3BhbjxQYXJ0aWFsPFRhZ1Byb3BzPj4oXG4gICh7IHRoZW1lLCBjb2xvclZhcmlhbnQsIGlzUmVtb3ZhYmxlIH0pID0+ICh7XG4gICAgZGlzcGxheTogXCJpbmxpbmUtZmxleFwiLFxuICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgbWF4V2lkdGg6IGAke01BWF9UQUdfV0lEVEh9cHhgLFxuICAgIHBhZGRpbmdMZWZ0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzLFxuICAgIHBhZGRpbmdSaWdodDogaXNSZW1vdmFibGVcbiAgICAgID8gdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy56ZXJvXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGFnLmJhY2tncm91bmRbY29sb3JWYXJpYW50XSxcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRhZy50ZXh0W2NvbG9yVmFyaWFudF0sXG4gICAgZm9udEZhbWlseTogdGhlbWUudmFyaWFibGVzLmZvbnRGYW1pbHkubGF0byxcbiAgICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC5zLFxuICAgIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQueHMsXG4gIH0pXG4pO1xuXG5jb25zdCBUYWdMYWJlbCA9IHN0eWxlZC5zcGFuKCgpID0+ICh7XG4gIG92ZXJmbG93OiBcImhpZGRlblwiLFxuICB0ZXh0T3ZlcmZsb3c6IFwiZWxsaXBzaXNcIixcbiAgd2hpdGVTcGFjZTogXCJub3dyYXBcIixcbiAgLy8gVGV4dCB0b3AgaGFzIDFweCBzcGFjaW5nIGdyZWF0ZXIgdGhhbiBib3R0b20sIGFkZGluZyBjdXN0b20gc3BhY2luZyB0byBjZW50ZXIgdGV4dFxuICBwYWRkaW5nVG9wOiBcIjNweFwiLFxuICBwYWRkaW5nQm90dG9tOiBcIjVweFwiLFxufSkpO1xuXG5jb25zdCBDbGVhckJ1dHRvbiA9IHN0eWxlZChQaWN0b2dyYW1CdXR0b24pPFBhcnRpYWw8VGFnUHJvcHM+PihcbiAgKHsgdGhlbWUsIGNvbG9yVmFyaWFudCB9KSA9PiAoe1xuICAgIGJhY2tncm91bmRDb2xvcjogXCJ0cmFuc3BhcmVudFwiLFxuICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGFnLnRleHRbY29sb3JWYXJpYW50XSxcbiAgICBcIiY6aG92ZXJcIjoge1xuICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50YWcudGV4dFtjb2xvclZhcmlhbnRdLFxuICAgIH0sXG4gIH0pXG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gVGFnKHtcbiAgbGFiZWwsXG4gIGNvbG9yVmFyaWFudCA9IFwiZ3JheVwiLFxuICBpc1JlbW92YWJsZSA9IGZhbHNlLFxuICBvbkNsZWFyLFxuICBjbGVhckJ0bkFyaWFMYWJlbCxcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IGRhdGFFMmVUZXN0SWQsXG59OiBUYWdQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFRhZ0NvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJUYWdcIlxuICAgICAgY29sb3JWYXJpYW50PXtjb2xvclZhcmlhbnR9XG4gICAgICBpc1JlbW92YWJsZT17aXNSZW1vdmFibGV9XG4gICAgPlxuICAgICAgPFRhZ0xhYmVsPntsYWJlbH08L1RhZ0xhYmVsPlxuXG4gICAgICB7aXNSZW1vdmFibGUgJiYgKFxuICAgICAgICA8Q2xlYXJCdXR0b25cbiAgICAgICAgICBpY29uPVwieFwiXG4gICAgICAgICAgc2l6ZT1cInhzXCJcbiAgICAgICAgICBhcmlhLWxhYmVsPXtjbGVhckJ0bkFyaWFMYWJlbH1cbiAgICAgICAgICBvbkNsaWNrPXtvbkNsZWFyfVxuICAgICAgICAgIGNvbG9yVmFyaWFudD17Y29sb3JWYXJpYW50fVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L1RhZ0NvbnRhaW5lcj5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5QnFCIn0= */"),TagLabel=styled("span",{target:"e2kqscs1",label:"TagLabel"})(()=>({overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",paddingTop:"3px",paddingBottom:"5px"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvVGFnL1RhZy50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1RhZy9UYWcudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgUGljdG9ncmFtQnV0dG9uIH0gZnJvbSBcIi4uL1BpY3RvZ3JhbUJ1dHRvbi9QaWN0b2dyYW1CdXR0b25cIjtcblxuZXhwb3J0IGNvbnN0IE1BWF9UQUdfV0lEVEggPSAyMDA7XG5cbnR5cGUgQmFzZVRhZ1Byb3BzID0ge1xuICBsYWJlbDogc3RyaW5nO1xuICBjb2xvclZhcmlhbnQ/OiBcImdyYXlcIiB8IFwiYmx1ZVwiO1xuICBcImRhdGEtZTJlLXRlc3QtaWRcIj86IHN0cmluZztcbn07XG50eXBlIENvbmRpdGlvbmFsVGFnUHJvcHMgPVxuICB8IHtcbiAgICAgIGlzUmVtb3ZhYmxlPzogZmFsc2U7XG4gICAgICBvbkNsZWFyPzogbmV2ZXI7XG4gICAgICBjbGVhckJ0bkFyaWFMYWJlbD86IG5ldmVyO1xuICAgIH1cbiAgfCB7XG4gICAgICBpc1JlbW92YWJsZTogdHJ1ZTtcbiAgICAgIG9uQ2xlYXI6IChlOiBSZWFjdC5Nb3VzZUV2ZW50KSA9PiB2b2lkO1xuICAgICAgY2xlYXJCdG5BcmlhTGFiZWw/OiBzdHJpbmc7XG4gICAgfTtcblxuZXhwb3J0IHR5cGUgVGFnUHJvcHMgPSBCYXNlVGFnUHJvcHMgJiBDb25kaXRpb25hbFRhZ1Byb3BzO1xuXG5jb25zdCBUYWdDb250YWluZXIgPSBzdHlsZWQuc3BhbjxQYXJ0aWFsPFRhZ1Byb3BzPj4oXG4gICh7IHRoZW1lLCBjb2xvclZhcmlhbnQsIGlzUmVtb3ZhYmxlIH0pID0+ICh7XG4gICAgZGlzcGxheTogXCJpbmxpbmUtZmxleFwiLFxuICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgbWF4V2lkdGg6IGAke01BWF9UQUdfV0lEVEh9cHhgLFxuICAgIHBhZGRpbmdMZWZ0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzLFxuICAgIHBhZGRpbmdSaWdodDogaXNSZW1vdmFibGVcbiAgICAgID8gdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy56ZXJvXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGFnLmJhY2tncm91bmRbY29sb3JWYXJpYW50XSxcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRhZy50ZXh0W2NvbG9yVmFyaWFudF0sXG4gICAgZm9udEZhbWlseTogdGhlbWUudmFyaWFibGVzLmZvbnRGYW1pbHkubGF0byxcbiAgICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC5zLFxuICAgIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQueHMsXG4gIH0pXG4pO1xuXG5jb25zdCBUYWdMYWJlbCA9IHN0eWxlZC5zcGFuKCgpID0+ICh7XG4gIG92ZXJmbG93OiBcImhpZGRlblwiLFxuICB0ZXh0T3ZlcmZsb3c6IFwiZWxsaXBzaXNcIixcbiAgd2hpdGVTcGFjZTogXCJub3dyYXBcIixcbiAgLy8gVGV4dCB0b3AgaGFzIDFweCBzcGFjaW5nIGdyZWF0ZXIgdGhhbiBib3R0b20sIGFkZGluZyBjdXN0b20gc3BhY2luZyB0byBjZW50ZXIgdGV4dFxuICBwYWRkaW5nVG9wOiBcIjNweFwiLFxuICBwYWRkaW5nQm90dG9tOiBcIjVweFwiLFxufSkpO1xuXG5jb25zdCBDbGVhckJ1dHRvbiA9IHN0eWxlZChQaWN0b2dyYW1CdXR0b24pPFBhcnRpYWw8VGFnUHJvcHM+PihcbiAgKHsgdGhlbWUsIGNvbG9yVmFyaWFudCB9KSA9PiAoe1xuICAgIGJhY2tncm91bmRDb2xvcjogXCJ0cmFuc3BhcmVudFwiLFxuICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGFnLnRleHRbY29sb3JWYXJpYW50XSxcbiAgICBcIiY6aG92ZXJcIjoge1xuICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50YWcudGV4dFtjb2xvclZhcmlhbnRdLFxuICAgIH0sXG4gIH0pXG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gVGFnKHtcbiAgbGFiZWwsXG4gIGNvbG9yVmFyaWFudCA9IFwiZ3JheVwiLFxuICBpc1JlbW92YWJsZSA9IGZhbHNlLFxuICBvbkNsZWFyLFxuICBjbGVhckJ0bkFyaWFMYWJlbCxcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IGRhdGFFMmVUZXN0SWQsXG59OiBUYWdQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFRhZ0NvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJUYWdcIlxuICAgICAgY29sb3JWYXJpYW50PXtjb2xvclZhcmlhbnR9XG4gICAgICBpc1JlbW92YWJsZT17aXNSZW1vdmFibGV9XG4gICAgPlxuICAgICAgPFRhZ0xhYmVsPntsYWJlbH08L1RhZ0xhYmVsPlxuXG4gICAgICB7aXNSZW1vdmFibGUgJiYgKFxuICAgICAgICA8Q2xlYXJCdXR0b25cbiAgICAgICAgICBpY29uPVwieFwiXG4gICAgICAgICAgc2l6ZT1cInhzXCJcbiAgICAgICAgICBhcmlhLWxhYmVsPXtjbGVhckJ0bkFyaWFMYWJlbH1cbiAgICAgICAgICBvbkNsaWNrPXtvbkNsZWFyfVxuICAgICAgICAgIGNvbG9yVmFyaWFudD17Y29sb3JWYXJpYW50fVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L1RhZ0NvbnRhaW5lcj5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQ2lCIn0= */"),ClearButton=styled(PictogramButton,{target:"e2kqscs2",label:"ClearButton"})(({theme,colorVariant})=>({backgroundColor:"transparent",color:theme.values.color.tag.text[colorVariant],"&:hover":{color:theme.values.color.tag.text[colorVariant]}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvVGFnL1RhZy50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1RhZy9UYWcudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgUGljdG9ncmFtQnV0dG9uIH0gZnJvbSBcIi4uL1BpY3RvZ3JhbUJ1dHRvbi9QaWN0b2dyYW1CdXR0b25cIjtcblxuZXhwb3J0IGNvbnN0IE1BWF9UQUdfV0lEVEggPSAyMDA7XG5cbnR5cGUgQmFzZVRhZ1Byb3BzID0ge1xuICBsYWJlbDogc3RyaW5nO1xuICBjb2xvclZhcmlhbnQ/OiBcImdyYXlcIiB8IFwiYmx1ZVwiO1xuICBcImRhdGEtZTJlLXRlc3QtaWRcIj86IHN0cmluZztcbn07XG50eXBlIENvbmRpdGlvbmFsVGFnUHJvcHMgPVxuICB8IHtcbiAgICAgIGlzUmVtb3ZhYmxlPzogZmFsc2U7XG4gICAgICBvbkNsZWFyPzogbmV2ZXI7XG4gICAgICBjbGVhckJ0bkFyaWFMYWJlbD86IG5ldmVyO1xuICAgIH1cbiAgfCB7XG4gICAgICBpc1JlbW92YWJsZTogdHJ1ZTtcbiAgICAgIG9uQ2xlYXI6IChlOiBSZWFjdC5Nb3VzZUV2ZW50KSA9PiB2b2lkO1xuICAgICAgY2xlYXJCdG5BcmlhTGFiZWw/OiBzdHJpbmc7XG4gICAgfTtcblxuZXhwb3J0IHR5cGUgVGFnUHJvcHMgPSBCYXNlVGFnUHJvcHMgJiBDb25kaXRpb25hbFRhZ1Byb3BzO1xuXG5jb25zdCBUYWdDb250YWluZXIgPSBzdHlsZWQuc3BhbjxQYXJ0aWFsPFRhZ1Byb3BzPj4oXG4gICh7IHRoZW1lLCBjb2xvclZhcmlhbnQsIGlzUmVtb3ZhYmxlIH0pID0+ICh7XG4gICAgZGlzcGxheTogXCJpbmxpbmUtZmxleFwiLFxuICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgbWF4V2lkdGg6IGAke01BWF9UQUdfV0lEVEh9cHhgLFxuICAgIHBhZGRpbmdMZWZ0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzLFxuICAgIHBhZGRpbmdSaWdodDogaXNSZW1vdmFibGVcbiAgICAgID8gdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy56ZXJvXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGFnLmJhY2tncm91bmRbY29sb3JWYXJpYW50XSxcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRhZy50ZXh0W2NvbG9yVmFyaWFudF0sXG4gICAgZm9udEZhbWlseTogdGhlbWUudmFyaWFibGVzLmZvbnRGYW1pbHkubGF0byxcbiAgICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC5zLFxuICAgIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQueHMsXG4gIH0pXG4pO1xuXG5jb25zdCBUYWdMYWJlbCA9IHN0eWxlZC5zcGFuKCgpID0+ICh7XG4gIG92ZXJmbG93OiBcImhpZGRlblwiLFxuICB0ZXh0T3ZlcmZsb3c6IFwiZWxsaXBzaXNcIixcbiAgd2hpdGVTcGFjZTogXCJub3dyYXBcIixcbiAgLy8gVGV4dCB0b3AgaGFzIDFweCBzcGFjaW5nIGdyZWF0ZXIgdGhhbiBib3R0b20sIGFkZGluZyBjdXN0b20gc3BhY2luZyB0byBjZW50ZXIgdGV4dFxuICBwYWRkaW5nVG9wOiBcIjNweFwiLFxuICBwYWRkaW5nQm90dG9tOiBcIjVweFwiLFxufSkpO1xuXG5jb25zdCBDbGVhckJ1dHRvbiA9IHN0eWxlZChQaWN0b2dyYW1CdXR0b24pPFBhcnRpYWw8VGFnUHJvcHM+PihcbiAgKHsgdGhlbWUsIGNvbG9yVmFyaWFudCB9KSA9PiAoe1xuICAgIGJhY2tncm91bmRDb2xvcjogXCJ0cmFuc3BhcmVudFwiLFxuICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGFnLnRleHRbY29sb3JWYXJpYW50XSxcbiAgICBcIiY6aG92ZXJcIjoge1xuICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50YWcudGV4dFtjb2xvclZhcmlhbnRdLFxuICAgIH0sXG4gIH0pXG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gVGFnKHtcbiAgbGFiZWwsXG4gIGNvbG9yVmFyaWFudCA9IFwiZ3JheVwiLFxuICBpc1JlbW92YWJsZSA9IGZhbHNlLFxuICBvbkNsZWFyLFxuICBjbGVhckJ0bkFyaWFMYWJlbCxcbiAgXCJkYXRhLWUyZS10ZXN0LWlkXCI6IGRhdGFFMmVUZXN0SWQsXG59OiBUYWdQcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFRhZ0NvbnRhaW5lclxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJUYWdcIlxuICAgICAgY29sb3JWYXJpYW50PXtjb2xvclZhcmlhbnR9XG4gICAgICBpc1JlbW92YWJsZT17aXNSZW1vdmFibGV9XG4gICAgPlxuICAgICAgPFRhZ0xhYmVsPntsYWJlbH08L1RhZ0xhYmVsPlxuXG4gICAgICB7aXNSZW1vdmFibGUgJiYgKFxuICAgICAgICA8Q2xlYXJCdXR0b25cbiAgICAgICAgICBpY29uPVwieFwiXG4gICAgICAgICAgc2l6ZT1cInhzXCJcbiAgICAgICAgICBhcmlhLWxhYmVsPXtjbGVhckJ0bkFyaWFMYWJlbH1cbiAgICAgICAgICBvbkNsaWNrPXtvbkNsZWFyfVxuICAgICAgICAgIGNvbG9yVmFyaWFudD17Y29sb3JWYXJpYW50fVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L1RhZ0NvbnRhaW5lcj5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRG9CIn0= */");export function Tag({label,colorVariant="gray",isRemovable=!1,onClear,clearBtnAriaLabel,"data-e2e-test-id":dataE2eTestId}){return React.createElement(TagContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Tag",colorVariant:colorVariant,isRemovable:isRemovable},React.createElement(TagLabel,null,label),isRemovable&&React.createElement(ClearButton,{icon:"x",size:"xs","aria-label":clearBtnAriaLabel,onClick:onClear,colorVariant:colorVariant}))}
|
|
1
|
+
import React from"react";import styled from"@emotion/styled";import{PictogramButton}from"../PictogramButton/PictogramButton";export const MAX_TAG_WIDTH=200;let TagContainer=styled("span",{target:"ezxwf6f0",label:"TagContainer"})(({theme,colorVariant,isRemovable})=>({display:"inline-flex",alignItems:"center",maxWidth:"200px",paddingLeft:theme.variables.size.spacing.xs,paddingRight:isRemovable?theme.variables.size.spacing.zero:theme.variables.size.spacing.xs,borderRadius:theme.variables.size.borderRadius.xs,backgroundColor:theme.values.color.tag.background[colorVariant],color:theme.values.color.tag.text[colorVariant],fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.s,lineHeight:theme.variables.size.lineHeight.xs}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvVGFnL1RhZy50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1RhZy9UYWcudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgUGljdG9ncmFtQnV0dG9uIH0gZnJvbSBcIi4uL1BpY3RvZ3JhbUJ1dHRvbi9QaWN0b2dyYW1CdXR0b25cIjtcblxuZXhwb3J0IGNvbnN0IE1BWF9UQUdfV0lEVEggPSAyMDA7XG5cbnR5cGUgQmFzZVRhZ1Byb3BzID0ge1xuICBsYWJlbDogc3RyaW5nO1xuICBjb2xvclZhcmlhbnQ/OiBcImdyYXlcIiB8IFwiYmx1ZVwiO1xuICBcImRhdGEtZTJlLXRlc3QtaWRcIj86IHN0cmluZztcbn07XG50eXBlIENvbmRpdGlvbmFsVGFnUHJvcHMgPVxuICB8IHtcbiAgICAgIGlzUmVtb3ZhYmxlPzogZmFsc2U7XG4gICAgICBvbkNsZWFyPzogbmV2ZXI7XG4gICAgICBjbGVhckJ0bkFyaWFMYWJlbD86IG5ldmVyO1xuICAgIH1cbiAgfCB7XG4gICAgICBpc1JlbW92YWJsZTogdHJ1ZTtcbiAgICAgIG9uQ2xlYXI6IChlOiBSZWFjdC5Nb3VzZUV2ZW50KSA9PiB2b2lkO1xuICAgICAgY2xlYXJCdG5BcmlhTGFiZWw/OiBzdHJpbmc7XG4gICAgfTtcblxuZXhwb3J0IHR5cGUgVGFnUHJvcHMgPSBCYXNlVGFnUHJvcHMgJiBDb25kaXRpb25hbFRhZ1Byb3BzO1xuXG5jb25zdCBUYWdDb250YWluZXIgPSBzdHlsZWQuc3BhbjxQYXJ0aWFsPFRhZ1Byb3BzPj4oXG4gICh7IHRoZW1lLCBjb2xvclZhcmlhbnQsIGlzUmVtb3ZhYmxlIH0pID0+ICh7XG4gICAgZGlzcGxheTogXCJpbmxpbmUtZmxleFwiLFxuICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgbWF4V2lkdGg6IGAke01BWF9UQUdfV0lEVEh9cHhgLFxuICAgIHBhZGRpbmdMZWZ0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzLFxuICAgIHBhZGRpbmdSaWdodDogaXNSZW1vdmFibGVcbiAgICAgID8gdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy56ZXJvXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGFnLmJhY2tncm91bmRbY29sb3JWYXJpYW50XSxcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRhZy50ZXh0W2NvbG9yVmFyaWFudF0sXG4gICAgZm9udEZhbWlseTogdGhlbWUudmFyaWFibGVzLmZvbnRGYW1pbHkubGF0byxcbiAgICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC5zLFxuICAgIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQueHMsXG4gIH0pXG4pO1xuXG5jb25zdCBUYWdMYWJlbCA9IHN0eWxlZC5zcGFuKCgpID0+ICh7XG4gIG92ZXJmbG93OiBcImhpZGRlblwiLFxuICB0ZXh0T3ZlcmZsb3c6IFwiZWxsaXBzaXNcIixcbiAgd2hpdGVTcGFjZTogXCJub3dyYXBcIixcbiAgLy8gVGV4dCB0b3AgaGFzIDFweCBzcGFjaW5nIGdyZWF0ZXIgdGhhbiBib3R0b20sIGFkZGluZyBjdXN0b20gc3BhY2luZyB0byBjZW50ZXIgdGV4dFxuICBwYWRkaW5nVG9wOiBcIjNweFwiLFxuICBwYWRkaW5nQm90dG9tOiBcIjVweFwiLFxufSkpO1xuXG5jb25zdCBDbGVhckJ1dHRvbiA9IHN0eWxlZChQaWN0b2dyYW1CdXR0b24pPFBhcnRpYWw8VGFnUHJvcHM+PihcbiAgKHsgdGhlbWUsIGNvbG9yVmFyaWFudCB9KSA9PiAoe1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuZGVmYXVsdCxcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRhZy50ZXh0W2NvbG9yVmFyaWFudF0sXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGFnLnRleHRbY29sb3JWYXJpYW50XSxcbiAgICB9LFxuICB9KVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFRhZyh7XG4gIGxhYmVsLFxuICBjb2xvclZhcmlhbnQgPSBcImdyYXlcIixcbiAgaXNSZW1vdmFibGUgPSBmYWxzZSxcbiAgb25DbGVhcixcbiAgY2xlYXJCdG5BcmlhTGFiZWwsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxufTogVGFnUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICByZXR1cm4gKFxuICAgIDxUYWdDb250YWluZXJcbiAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICBkYXRhLWRzLWlkPVwiVGFnXCJcbiAgICAgIGNvbG9yVmFyaWFudD17Y29sb3JWYXJpYW50fVxuICAgICAgaXNSZW1vdmFibGU9e2lzUmVtb3ZhYmxlfVxuICAgID5cbiAgICAgIDxUYWdMYWJlbD57bGFiZWx9PC9UYWdMYWJlbD5cblxuICAgICAge2lzUmVtb3ZhYmxlICYmIChcbiAgICAgICAgPENsZWFyQnV0dG9uXG4gICAgICAgICAgaWNvbj1cInhcIlxuICAgICAgICAgIHNpemU9XCJ4c1wiXG4gICAgICAgICAgYXJpYS1sYWJlbD17Y2xlYXJCdG5BcmlhTGFiZWx9XG4gICAgICAgICAgb25DbGljaz17b25DbGVhcn1cbiAgICAgICAgICBjb2xvclZhcmlhbnQ9e2NvbG9yVmFyaWFudH1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC9UYWdDb250YWluZXI+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUJxQiJ9 */"),TagLabel=styled("span",{target:"ezxwf6f1",label:"TagLabel"})(()=>({overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",paddingTop:"3px",paddingBottom:"5px"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvVGFnL1RhZy50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1RhZy9UYWcudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgUGljdG9ncmFtQnV0dG9uIH0gZnJvbSBcIi4uL1BpY3RvZ3JhbUJ1dHRvbi9QaWN0b2dyYW1CdXR0b25cIjtcblxuZXhwb3J0IGNvbnN0IE1BWF9UQUdfV0lEVEggPSAyMDA7XG5cbnR5cGUgQmFzZVRhZ1Byb3BzID0ge1xuICBsYWJlbDogc3RyaW5nO1xuICBjb2xvclZhcmlhbnQ/OiBcImdyYXlcIiB8IFwiYmx1ZVwiO1xuICBcImRhdGEtZTJlLXRlc3QtaWRcIj86IHN0cmluZztcbn07XG50eXBlIENvbmRpdGlvbmFsVGFnUHJvcHMgPVxuICB8IHtcbiAgICAgIGlzUmVtb3ZhYmxlPzogZmFsc2U7XG4gICAgICBvbkNsZWFyPzogbmV2ZXI7XG4gICAgICBjbGVhckJ0bkFyaWFMYWJlbD86IG5ldmVyO1xuICAgIH1cbiAgfCB7XG4gICAgICBpc1JlbW92YWJsZTogdHJ1ZTtcbiAgICAgIG9uQ2xlYXI6IChlOiBSZWFjdC5Nb3VzZUV2ZW50KSA9PiB2b2lkO1xuICAgICAgY2xlYXJCdG5BcmlhTGFiZWw/OiBzdHJpbmc7XG4gICAgfTtcblxuZXhwb3J0IHR5cGUgVGFnUHJvcHMgPSBCYXNlVGFnUHJvcHMgJiBDb25kaXRpb25hbFRhZ1Byb3BzO1xuXG5jb25zdCBUYWdDb250YWluZXIgPSBzdHlsZWQuc3BhbjxQYXJ0aWFsPFRhZ1Byb3BzPj4oXG4gICh7IHRoZW1lLCBjb2xvclZhcmlhbnQsIGlzUmVtb3ZhYmxlIH0pID0+ICh7XG4gICAgZGlzcGxheTogXCJpbmxpbmUtZmxleFwiLFxuICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgbWF4V2lkdGg6IGAke01BWF9UQUdfV0lEVEh9cHhgLFxuICAgIHBhZGRpbmdMZWZ0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzLFxuICAgIHBhZGRpbmdSaWdodDogaXNSZW1vdmFibGVcbiAgICAgID8gdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy56ZXJvXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGFnLmJhY2tncm91bmRbY29sb3JWYXJpYW50XSxcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRhZy50ZXh0W2NvbG9yVmFyaWFudF0sXG4gICAgZm9udEZhbWlseTogdGhlbWUudmFyaWFibGVzLmZvbnRGYW1pbHkubGF0byxcbiAgICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC5zLFxuICAgIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQueHMsXG4gIH0pXG4pO1xuXG5jb25zdCBUYWdMYWJlbCA9IHN0eWxlZC5zcGFuKCgpID0+ICh7XG4gIG92ZXJmbG93OiBcImhpZGRlblwiLFxuICB0ZXh0T3ZlcmZsb3c6IFwiZWxsaXBzaXNcIixcbiAgd2hpdGVTcGFjZTogXCJub3dyYXBcIixcbiAgLy8gVGV4dCB0b3AgaGFzIDFweCBzcGFjaW5nIGdyZWF0ZXIgdGhhbiBib3R0b20sIGFkZGluZyBjdXN0b20gc3BhY2luZyB0byBjZW50ZXIgdGV4dFxuICBwYWRkaW5nVG9wOiBcIjNweFwiLFxuICBwYWRkaW5nQm90dG9tOiBcIjVweFwiLFxufSkpO1xuXG5jb25zdCBDbGVhckJ1dHRvbiA9IHN0eWxlZChQaWN0b2dyYW1CdXR0b24pPFBhcnRpYWw8VGFnUHJvcHM+PihcbiAgKHsgdGhlbWUsIGNvbG9yVmFyaWFudCB9KSA9PiAoe1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuZGVmYXVsdCxcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRhZy50ZXh0W2NvbG9yVmFyaWFudF0sXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGFnLnRleHRbY29sb3JWYXJpYW50XSxcbiAgICB9LFxuICB9KVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFRhZyh7XG4gIGxhYmVsLFxuICBjb2xvclZhcmlhbnQgPSBcImdyYXlcIixcbiAgaXNSZW1vdmFibGUgPSBmYWxzZSxcbiAgb25DbGVhcixcbiAgY2xlYXJCdG5BcmlhTGFiZWwsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxufTogVGFnUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICByZXR1cm4gKFxuICAgIDxUYWdDb250YWluZXJcbiAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICBkYXRhLWRzLWlkPVwiVGFnXCJcbiAgICAgIGNvbG9yVmFyaWFudD17Y29sb3JWYXJpYW50fVxuICAgICAgaXNSZW1vdmFibGU9e2lzUmVtb3ZhYmxlfVxuICAgID5cbiAgICAgIDxUYWdMYWJlbD57bGFiZWx9PC9UYWdMYWJlbD5cblxuICAgICAge2lzUmVtb3ZhYmxlICYmIChcbiAgICAgICAgPENsZWFyQnV0dG9uXG4gICAgICAgICAgaWNvbj1cInhcIlxuICAgICAgICAgIHNpemU9XCJ4c1wiXG4gICAgICAgICAgYXJpYS1sYWJlbD17Y2xlYXJCdG5BcmlhTGFiZWx9XG4gICAgICAgICAgb25DbGljaz17b25DbGVhcn1cbiAgICAgICAgICBjb2xvclZhcmlhbnQ9e2NvbG9yVmFyaWFudH1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC9UYWdDb250YWluZXI+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkNpQiJ9 */"),ClearButton=styled(PictogramButton,{target:"ezxwf6f2",label:"ClearButton"})(({theme,colorVariant})=>({backgroundColor:theme.values.color.background.transparent.default,color:theme.values.color.tag.text[colorVariant],"&:hover":{color:theme.values.color.tag.text[colorVariant]}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvVGFnL1RhZy50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL1RhZy9UYWcudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHsgUGljdG9ncmFtQnV0dG9uIH0gZnJvbSBcIi4uL1BpY3RvZ3JhbUJ1dHRvbi9QaWN0b2dyYW1CdXR0b25cIjtcblxuZXhwb3J0IGNvbnN0IE1BWF9UQUdfV0lEVEggPSAyMDA7XG5cbnR5cGUgQmFzZVRhZ1Byb3BzID0ge1xuICBsYWJlbDogc3RyaW5nO1xuICBjb2xvclZhcmlhbnQ/OiBcImdyYXlcIiB8IFwiYmx1ZVwiO1xuICBcImRhdGEtZTJlLXRlc3QtaWRcIj86IHN0cmluZztcbn07XG50eXBlIENvbmRpdGlvbmFsVGFnUHJvcHMgPVxuICB8IHtcbiAgICAgIGlzUmVtb3ZhYmxlPzogZmFsc2U7XG4gICAgICBvbkNsZWFyPzogbmV2ZXI7XG4gICAgICBjbGVhckJ0bkFyaWFMYWJlbD86IG5ldmVyO1xuICAgIH1cbiAgfCB7XG4gICAgICBpc1JlbW92YWJsZTogdHJ1ZTtcbiAgICAgIG9uQ2xlYXI6IChlOiBSZWFjdC5Nb3VzZUV2ZW50KSA9PiB2b2lkO1xuICAgICAgY2xlYXJCdG5BcmlhTGFiZWw/OiBzdHJpbmc7XG4gICAgfTtcblxuZXhwb3J0IHR5cGUgVGFnUHJvcHMgPSBCYXNlVGFnUHJvcHMgJiBDb25kaXRpb25hbFRhZ1Byb3BzO1xuXG5jb25zdCBUYWdDb250YWluZXIgPSBzdHlsZWQuc3BhbjxQYXJ0aWFsPFRhZ1Byb3BzPj4oXG4gICh7IHRoZW1lLCBjb2xvclZhcmlhbnQsIGlzUmVtb3ZhYmxlIH0pID0+ICh7XG4gICAgZGlzcGxheTogXCJpbmxpbmUtZmxleFwiLFxuICAgIGFsaWduSXRlbXM6IFwiY2VudGVyXCIsXG4gICAgbWF4V2lkdGg6IGAke01BWF9UQUdfV0lEVEh9cHhgLFxuICAgIHBhZGRpbmdMZWZ0OiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzLFxuICAgIHBhZGRpbmdSaWdodDogaXNSZW1vdmFibGVcbiAgICAgID8gdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy56ZXJvXG4gICAgICA6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGFnLmJhY2tncm91bmRbY29sb3JWYXJpYW50XSxcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRhZy50ZXh0W2NvbG9yVmFyaWFudF0sXG4gICAgZm9udEZhbWlseTogdGhlbWUudmFyaWFibGVzLmZvbnRGYW1pbHkubGF0byxcbiAgICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC5zLFxuICAgIGxpbmVIZWlnaHQ6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxpbmVIZWlnaHQueHMsXG4gIH0pXG4pO1xuXG5jb25zdCBUYWdMYWJlbCA9IHN0eWxlZC5zcGFuKCgpID0+ICh7XG4gIG92ZXJmbG93OiBcImhpZGRlblwiLFxuICB0ZXh0T3ZlcmZsb3c6IFwiZWxsaXBzaXNcIixcbiAgd2hpdGVTcGFjZTogXCJub3dyYXBcIixcbiAgLy8gVGV4dCB0b3AgaGFzIDFweCBzcGFjaW5nIGdyZWF0ZXIgdGhhbiBib3R0b20sIGFkZGluZyBjdXN0b20gc3BhY2luZyB0byBjZW50ZXIgdGV4dFxuICBwYWRkaW5nVG9wOiBcIjNweFwiLFxuICBwYWRkaW5nQm90dG9tOiBcIjVweFwiLFxufSkpO1xuXG5jb25zdCBDbGVhckJ1dHRvbiA9IHN0eWxlZChQaWN0b2dyYW1CdXR0b24pPFBhcnRpYWw8VGFnUHJvcHM+PihcbiAgKHsgdGhlbWUsIGNvbG9yVmFyaWFudCB9KSA9PiAoe1xuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQudHJhbnNwYXJlbnQuZGVmYXVsdCxcbiAgICBjb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLnRhZy50ZXh0W2NvbG9yVmFyaWFudF0sXG4gICAgXCImOmhvdmVyXCI6IHtcbiAgICAgIGNvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IudGFnLnRleHRbY29sb3JWYXJpYW50XSxcbiAgICB9LFxuICB9KVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFRhZyh7XG4gIGxhYmVsLFxuICBjb2xvclZhcmlhbnQgPSBcImdyYXlcIixcbiAgaXNSZW1vdmFibGUgPSBmYWxzZSxcbiAgb25DbGVhcixcbiAgY2xlYXJCdG5BcmlhTGFiZWwsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxufTogVGFnUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICByZXR1cm4gKFxuICAgIDxUYWdDb250YWluZXJcbiAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICBkYXRhLWRzLWlkPVwiVGFnXCJcbiAgICAgIGNvbG9yVmFyaWFudD17Y29sb3JWYXJpYW50fVxuICAgICAgaXNSZW1vdmFibGU9e2lzUmVtb3ZhYmxlfVxuICAgID5cbiAgICAgIDxUYWdMYWJlbD57bGFiZWx9PC9UYWdMYWJlbD5cblxuICAgICAge2lzUmVtb3ZhYmxlICYmIChcbiAgICAgICAgPENsZWFyQnV0dG9uXG4gICAgICAgICAgaWNvbj1cInhcIlxuICAgICAgICAgIHNpemU9XCJ4c1wiXG4gICAgICAgICAgYXJpYS1sYWJlbD17Y2xlYXJCdG5BcmlhTGFiZWx9XG4gICAgICAgICAgb25DbGljaz17b25DbGVhcn1cbiAgICAgICAgICBjb2xvclZhcmlhbnQ9e2NvbG9yVmFyaWFudH1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC9UYWdDb250YWluZXI+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0RvQiJ9 */");export function Tag({label,colorVariant="gray",isRemovable=!1,onClear,clearBtnAriaLabel,"data-e2e-test-id":dataE2eTestId}){return React.createElement(TagContainer,{"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Tag",colorVariant:colorVariant,isRemovable:isRemovable},React.createElement(TagLabel,null,label),isRemovable&&React.createElement(ClearButton,{icon:"x",size:"xs","aria-label":clearBtnAriaLabel,onClick:onClear,colorVariant:colorVariant}))}
|