@amboss/design-system 3.29.2 → 3.29.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cjs/components/DataTable/DataTable.d.ts +1 -0
- package/build/cjs/components/DataTable/DataTable.js +1 -1
- package/build/cjs/components/DataTable/header/DataTableHeaderToggletip.d.ts +6 -0
- package/build/cjs/components/DataTable/header/DataTableHeaderToggletip.js +1 -0
- package/build/cjs/components/DataTable/header/SortableCellContent.d.ts +2 -1
- package/build/cjs/components/DataTable/header/SortableCellContent.js +1 -1
- package/build/cjs/components/DataTable/header/TableHeader.js +1 -1
- package/build/cjs/components/DataTable/types.d.ts +2 -0
- package/build/cjs/components/MediaItem/MediaItem.js +1 -1
- package/build/cjs/components/PromptInput/PromptInputHeader.js +1 -1
- package/build/cjs/components/PromptInput/PromptTextArea.js +1 -1
- package/build/cjs/shared/mixins/TextInput/getInputTextPlaceholder.js +1 -1
- package/build/esm/components/DataTable/DataTable.d.ts +1 -0
- package/build/esm/components/DataTable/DataTable.js +1 -1
- package/build/esm/components/DataTable/header/DataTableHeaderToggletip.d.ts +6 -0
- package/build/esm/components/DataTable/header/DataTableHeaderToggletip.js +1 -0
- package/build/esm/components/DataTable/header/SortableCellContent.d.ts +2 -1
- package/build/esm/components/DataTable/header/SortableCellContent.js +1 -1
- package/build/esm/components/DataTable/header/TableHeader.js +1 -1
- package/build/esm/components/DataTable/types.d.ts +2 -0
- package/build/esm/components/MediaItem/MediaItem.js +1 -1
- package/build/esm/components/PromptInput/PromptInputHeader.js +1 -1
- package/build/esm/components/PromptInput/PromptTextArea.js +1 -1
- package/build/esm/shared/mixins/TextInput/getInputTextPlaceholder.js +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get MediaItem(){return MediaItem},get mediaSize(){return mediaSize}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Icon=require("../Icon/Icon"),_Stack=require("../Stack/Stack"),_TextClamped=require("../Typography/TextClamped/TextClamped"),_Text=require("../Typography/Text/Text"),_Inline=require("../Inline/Inline"),_Image=require("../Image/Image"),mediaSize={xs:80,s:88,m:110,l:128,xl:204},StyledTextClamped=(0,_styled.default)(_TextClamped.TextClamped,{target:"e18vxvyw0",label:"StyledTextClamped"})("/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        aria-label={title}\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={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAwD0B"} */"),StyledMedia=(0,_styled.default)("div",{target:"e18vxvyw1",label:"StyledMedia"})(({squareByWidth,srcError})=>({height:"100%",...squareByWidth&&{position:"absolute",left:0,bottom:0,top:0,right:0},...srcError&&{display:"flex",alignItems:"center",justifyContent:"center"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        aria-label={title}\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={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AA0DoB"} */"),StyledOverlay=(0,_styled.default)("div",{target:"e18vxvyw2",label:"StyledOverlay"})(()=>({position:"absolute",left:0,bottom:0,top:0,right:0}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        aria-label={title}\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={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AA4EsB"} */"),StyledButton=(0,_styled.default)("button",{target:"e18vxvyw3",label:"StyledButton"})(({theme,size,width,isActive})=>({padding:0,backgroundColor:theme.values.color.background.transparent.default,border:"none",cursor:"pointer",borderRadius:theme.variables.size.borderRadius.s,width:mediaSize[size]||width||"100%",outlineOffset:"1px",outline:`solid 2px ${theme.values.color.background.transparent.default}`,transition:"all 0.3s ease",[`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]:{color:theme.values.color.text.primary.default},[`&:hover ${StyledOverlay}`]:{backgroundColor:theme.values.color.mediaItem.overlay.hover},[`&:active ${StyledOverlay}`]:{backgroundColor:theme.values.color.mediaItem.overlay.active},...!isActive&&{"&:focus-visible":{outlineWidth:"2px",outlineStyle:"solid",outlineColor:"Highlight"},"@media (-webkit-min-device-pixel-ratio:0)":{"&:focus-visible":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"auto"}}},...isActive&&{outlineColor:theme.values.color.border.secondary.active}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        aria-label={title}\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={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAuFqB"} */"),StyledMediaContainer=(0,_styled.default)("div",{target:"e18vxvyw4",label:"StyledMediaContainer"})(({theme,size,height,backgroundColor,squareByWidth,srcError})=>({overflow:"hidden",border:"1px solid",borderColor:theme.values.color.border.secondary.default,borderRadius:theme.variables.size.borderRadius.s,position:"relative",backgroundClip:"padding-box",backgroundColor:theme.values.color.mediaItem.background[backgroundColor],height:mediaSize[size]||height||"auto",...squareByWidth&&{paddingTop:"calc(100% - 2px)",height:"auto"},...srcError&&{backgroundColor:theme.values.color.background.transparent.active}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        aria-label={title}\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={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAgI6B"} */"),StyledIconContainer=(0,_styled.default)("div",{target:"e18vxvyw5",label:"StyledIconContainer"})(({theme})=>({position:"absolute",left:theme.variables.size.spacing.xxs,bottom:theme.variables.size.spacing.xxs,overflow:"hidden",borderRadius:theme.variables.size.borderRadius.xs,backgroundColor:theme.values.color.mediaItem.categoryIcon.background.default,padding:theme.variables.size.spacing.xxs,color:theme.values.color.text.onAccent.default}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        aria-label={title}\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={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAiJ4B"} */"),MediaItem=_react.default.forwardRef(({"data-e2e-test-id":dataE2eTestId,as,src,title,showTitle=!0,fit="cover",categoryIcon,categoryLabel,categoryPlacement="outside",size,width,height,backgroundColor="transparent",hyphens="none",squareByWidth=!1,isActive,...rest},ref)=>{let[srcError,setSrcError]=(0,_react.useState)(!1),showCategoryOver=categoryIcon&&(!size&&"inside"===categoryPlacement||"xs"===size||"s"===size||"m"===size),showCategoryUnder=categoryIcon&&categoryLabel&&(!size&&"outside"===categoryPlacement||"l"===size||"xl"===size),textSize=["xs","s","m"].includes(size)?"xs":"s";return _react.default.createElement(StyledButton,{"data-ds-id":"MediaItem","data-e2e-test-id":dataE2eTestId,as:as,ref:ref,size:size,width:width,isActive:isActive,"aria-label":title,...rest},_react.default.createElement(_Stack.Stack,{space:"xs"},_react.default.createElement(StyledMediaContainer,{size:size,height:height,backgroundColor:backgroundColor,squareByWidth:squareByWidth,srcError:srcError},_react.default.createElement(StyledMedia,{squareByWidth:squareByWidth,srcError:srcError},srcError?_react.default.createElement(_Icon.Icon,{name:"image-broken",color:"tertiary"}):_react.default.createElement(_Image.Image,{src:src,fit:fit,title:title,alt:title,width:"100%",height:"100%","aria-hidden":"true",onError:()=>{setSrcError(!0)}})),_react.default.createElement(StyledOverlay,null),showCategoryOver&&_react.default.createElement(StyledIconContainer,null,_react.default.createElement(_Icon.Icon,{name:categoryIcon,size:"s",color:"inherit"}))),(showCategoryUnder||showTitle)&&_react.default.createElement(_Stack.Stack,{space:"xxs"},showCategoryUnder&&_react.default.createElement(_Inline.Inline,{space:"xxs",vAlignItems:"center"},_react.default.createElement(_Icon.Icon,{name:categoryIcon,color:"quaternary",size:"s"}),_react.default.createElement(_Text.Text,{color:"tertiary",size:"xs",transform:"uppercase",weight:"bold"},categoryLabel)),showTitle&&_react.default.createElement(StyledTextClamped,{size:textSize,color:"secondary",lines:3,hyphens:hyphens},title))))});
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get MediaItem(){return MediaItem},get mediaSize(){return mediaSize}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Icon=require("../Icon/Icon"),_Stack=require("../Stack/Stack"),_TextClamped=require("../Typography/TextClamped/TextClamped"),_Text=require("../Typography/Text/Text"),_Inline=require("../Inline/Inline"),_Image=require("../Image/Image"),mediaSize={xs:80,s:88,m:110,l:128,xl:204},StyledTextClamped=(0,_styled.default)(_TextClamped.TextClamped,{target:"e1ft3gpp0",label:"StyledTextClamped"})("/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        aria-label={title}\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={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAwD0B"} */"),StyledMedia=(0,_styled.default)("div",{target:"e1ft3gpp1",label:"StyledMedia"})(({squareByWidth,srcError})=>({height:"100%",...squareByWidth&&{position:"absolute",left:0,bottom:0,top:0,right:0},...srcError&&{display:"flex",alignItems:"center",justifyContent:"center"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        aria-label={title}\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={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AA0DoB"} */"),StyledOverlay=(0,_styled.default)("div",{target:"e1ft3gpp2",label:"StyledOverlay"})(()=>({position:"absolute",left:0,bottom:0,top:0,right:0}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        aria-label={title}\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={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AA4EsB"} */"),StyledButton=(0,_styled.default)("button",{target:"e1ft3gpp3",label:"StyledButton"})(({theme,size,width,isActive})=>({padding:0,backgroundColor:theme.values.color.background.transparent.default,border:"none",cursor:"pointer",borderRadius:theme.variables.size.borderRadius.s,width:mediaSize[size]||width||"100%",outlineOffset:"1px",outline:`solid 2px ${theme.values.color.background.transparent.default}`,transition:"all 0.3s ease",[`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]:{color:theme.values.color.text.primary.default},[`&:hover ${StyledOverlay}`]:{backgroundColor:theme.values.color.mediaItem.overlay.hover},[`&:active ${StyledOverlay}`]:{backgroundColor:theme.values.color.mediaItem.overlay.active},...!isActive&&{"&:focus-visible":{outlineWidth:"2px",outlineStyle:"solid",outlineColor:"Highlight"},"@media (-webkit-min-device-pixel-ratio:0)":{"&:focus-visible":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"auto"}}},...isActive&&{outlineColor:theme.values.color.border.secondary.active}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        aria-label={title}\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={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAuFqB"} */"),StyledMediaContainer=(0,_styled.default)("div",{target:"e1ft3gpp4",label:"StyledMediaContainer"})(({theme,size,height,backgroundColor,squareByWidth,srcError})=>({overflow:"hidden",border:"1px solid",borderColor:theme.values.color.border.secondary.default,borderRadius:theme.variables.size.borderRadius.s,position:"relative",backgroundClip:"padding-box",backgroundColor:theme.values.color.mediaItem.background[backgroundColor],height:mediaSize[size]||height||"auto",...squareByWidth&&{paddingTop:"calc(100% - 2px)",height:"auto"},...srcError&&{backgroundColor:theme.values.color.background.transparent.active}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        aria-label={title}\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={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAgI6B"} */"),StyledIconContainer=(0,_styled.default)("div",{target:"e1ft3gpp5",label:"StyledIconContainer"})(({theme})=>({position:"absolute",left:theme.variables.size.spacing.xxs,bottom:theme.variables.size.spacing.xxs,overflow:"hidden",borderRadius:theme.variables.size.borderRadius.xs,backgroundColor:theme.values.color.mediaItem.categoryIcon.background.default,padding:theme.variables.size.spacing.xxs,color:theme.values.color.text.onAccent.default}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/MediaItem/MediaItem.tsx","sources":["src/components/MediaItem/MediaItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useState } from \"react\";\nimport type { CSSObject } from \"@emotion/styled\";\nimport styled from \"@emotion/styled\";\nimport type { Property } from \"csstype\";\nimport type {\n  Hyphens,\n  MediaItemSize,\n  PolymorphicComponentPropsWithRef,\n  PolymorphicRef,\n} from \"../../types\";\nimport { Icon, type IconName } from \"../Icon/Icon\";\nimport { Stack } from \"../Stack/Stack\";\nimport { TextClamped } from \"../Typography/TextClamped/TextClamped\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Inline } from \"../Inline/Inline\";\nimport { Image } from \"../Image/Image\";\n\nexport const mediaSize: Record<MediaItemSize, number> = {\n  xs: 80,\n  s: 88,\n  m: 110,\n  l: 128,\n  xl: 204,\n};\n\nexport type MediaItemProps = {\n  src: string;\n  title: string;\n  /** Display or hide the title underneath the media. */\n  showTitle?: boolean;\n  /** Pre-defined media sizes. */\n  size?: MediaItemSize;\n  /** Sets the width of the media if the size is not set. */\n  width?: Property.Width;\n  /** Sets the height of the media if the size is not set. */\n  height?: Property.Height;\n  /** Sets the height of the media to equal the width to make it a square. */\n  squareByWidth?: boolean;\n  /** Sets the object-fit value of the image. */\n  fit?: \"cover\" | \"contain\";\n  categoryLabel?: string;\n  categoryIcon?: IconName;\n  /** Sets the placement of the category relative to the image.<br/>\n   * \"inside\": only the category icon is required<br/>\n   * \"outside\": both category icon and label are required */\n  categoryPlacement?: \"inside\" | \"outside\";\n  /** Sets the background color behind the media that is visible if the fit is \"contain\". */\n  backgroundColor?: \"white\" | \"black\" | \"transparent\";\n  /** Sets the hyphens of the title text. */\n  hyphens?: Hyphens;\n  /** Sets the active state of the media item. */\n  isActive?: boolean;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledTextClamped = styled(TextClamped)();\n\nconst StyledMedia = styled.div<Partial<MediaItemProps> & { srcError: boolean }>(\n  ({ squareByWidth, srcError }) => ({\n    height: \"100%\",\n    ...(squareByWidth && {\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    }),\n    ...(srcError && {\n      display: \"flex\",\n      alignItems: \"center\",\n      justifyContent: \"center\",\n    }),\n  })\n);\n\nconst StyledOverlay = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      left: 0,\n      bottom: 0,\n      top: 0,\n      right: 0,\n    } as CSSObject)\n);\n\nconst StyledButton = styled.button<Partial<MediaItemProps>>(\n  ({ theme, size, width, isActive }) => ({\n    padding: 0,\n    backgroundColor: theme.values.color.background.transparent.default,\n    border: \"none\",\n    cursor: \"pointer\",\n    borderRadius: theme.variables.size.borderRadius.s,\n    width: mediaSize[size] || width || \"100%\",\n    outlineOffset: \"1px\",\n    outline: `solid 2px ${theme.values.color.background.transparent.default}`,\n    transition: \"all 0.3s ease\",\n\n    [`&:hover ${StyledTextClamped}, &:active ${StyledTextClamped}`]: {\n      color: theme.values.color.text.primary.default,\n    },\n    [`&:hover ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.hover,\n    },\n    [`&:active ${StyledOverlay}`]: {\n      backgroundColor: theme.values.color.mediaItem.overlay.active,\n    },\n    ...(!isActive && {\n      \"&:focus-visible\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-visible\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    }),\n\n    ...(isActive && {\n      outlineColor: theme.values.color.border.secondary.active,\n    }),\n  })\n);\n\nconst StyledMediaContainer = styled.div<\n  Partial<MediaItemProps> & { srcError: boolean }\n>(({ theme, size, height, backgroundColor, squareByWidth, srcError }) => ({\n  overflow: \"hidden\",\n  border: `1px solid`,\n  borderColor: theme.values.color.border.secondary.default,\n  borderRadius: theme.variables.size.borderRadius.s,\n  position: \"relative\",\n  backgroundClip: \"padding-box\", // Needed because border color is transparent and the background color is visible through the border without it.\n  backgroundColor: theme.values.color.mediaItem.background[backgroundColor],\n  height: mediaSize[size] || height || \"auto\",\n  ...(squareByWidth && { paddingTop: \"calc(100% - 2px)\", height: \"auto\" }),\n  ...(srcError && {\n    backgroundColor: theme.values.color.background.transparent.active,\n  }),\n}));\n\nconst StyledIconContainer = styled.div<Partial<MediaItemProps>>(\n  ({ theme }) => ({\n    position: \"absolute\",\n    left: theme.variables.size.spacing.xxs,\n    bottom: theme.variables.size.spacing.xxs,\n    overflow: \"hidden\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n\n    backgroundColor:\n      theme.values.color.mediaItem.categoryIcon.background.default,\n    padding: theme.variables.size.spacing.xxs,\n    color: theme.values.color.text.onAccent.default,\n  })\n);\n\ntype MediaItemComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, MediaItemProps>\n) => React.ReactNode | null;\n\nexport const MediaItem: MediaItemComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      as,\n      src,\n      title,\n      showTitle = true,\n      fit = \"cover\",\n      categoryIcon,\n      categoryLabel,\n      categoryPlacement = \"outside\",\n      size,\n      width,\n      height,\n      backgroundColor = \"transparent\",\n      hyphens = \"none\",\n      squareByWidth = false,\n      isActive,\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, MediaItemProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const [srcError, setSrcError] = useState(false);\n\n    const showCategoryOver =\n      categoryIcon &&\n      ((!size && categoryPlacement === \"inside\") ||\n        size === \"xs\" ||\n        size === \"s\" ||\n        size === \"m\");\n\n    const showCategoryUnder =\n      categoryIcon &&\n      categoryLabel &&\n      ((!size && categoryPlacement === \"outside\") ||\n        size === \"l\" ||\n        size === \"xl\");\n\n    const textSize = [\"xs\", \"s\", \"m\"].includes(size) ? \"xs\" : \"s\";\n\n    const onError = () => {\n      setSrcError(true);\n    };\n\n    return (\n      <StyledButton\n        data-ds-id=\"MediaItem\"\n        data-e2e-test-id={dataE2eTestId}\n        as={as}\n        ref={ref}\n        size={size}\n        width={width}\n        isActive={isActive}\n        aria-label={title}\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={textSize}\n                  color=\"secondary\"\n                  lines={3}\n                  hyphens={hyphens}\n                  overflowWrap=\"break-word\"\n                >\n                  {title}\n                </StyledTextClamped>\n              )}\n            </Stack>\n          )}\n        </Stack>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAiJ4B"} */"),MediaItem=_react.default.forwardRef(({"data-e2e-test-id":dataE2eTestId,as,src,title,showTitle=!0,fit="cover",categoryIcon,categoryLabel,categoryPlacement="outside",size,width,height,backgroundColor="transparent",hyphens="none",squareByWidth=!1,isActive,...rest},ref)=>{let[srcError,setSrcError]=(0,_react.useState)(!1),showCategoryOver=categoryIcon&&(!size&&"inside"===categoryPlacement||"xs"===size||"s"===size||"m"===size),showCategoryUnder=categoryIcon&&categoryLabel&&(!size&&"outside"===categoryPlacement||"l"===size||"xl"===size),textSize=["xs","s","m"].includes(size)?"xs":"s";return _react.default.createElement(StyledButton,{"data-ds-id":"MediaItem","data-e2e-test-id":dataE2eTestId,as:as,ref:ref,size:size,width:width,isActive:isActive,"aria-label":title,...rest},_react.default.createElement(_Stack.Stack,{space:"xs"},_react.default.createElement(StyledMediaContainer,{size:size,height:height,backgroundColor:backgroundColor,squareByWidth:squareByWidth,srcError:srcError},_react.default.createElement(StyledMedia,{squareByWidth:squareByWidth,srcError:srcError},srcError?_react.default.createElement(_Icon.Icon,{name:"image-broken",color:"tertiary"}):_react.default.createElement(_Image.Image,{src:src,fit:fit,title:title,alt:title,width:"100%",height:"100%","aria-hidden":"true",onError:()=>{setSrcError(!0)}})),_react.default.createElement(StyledOverlay,null),showCategoryOver&&_react.default.createElement(StyledIconContainer,null,_react.default.createElement(_Icon.Icon,{name:categoryIcon,size:"s",color:"inherit"}))),(showCategoryUnder||showTitle)&&_react.default.createElement(_Stack.Stack,{space:"xxs"},showCategoryUnder&&_react.default.createElement(_Inline.Inline,{space:"xxs",vAlignItems:"center"},_react.default.createElement(_Icon.Icon,{name:categoryIcon,color:"quaternary",size:"s"}),_react.default.createElement(_Text.Text,{color:"tertiary",size:"xs",transform:"uppercase",weight:"bold"},categoryLabel)),showTitle&&_react.default.createElement(StyledTextClamped,{size:textSize,color:"secondary",lines:3,hyphens:hyphens,overflowWrap:"break-word"},title))))});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"PromptInputHeader",{enumerable:!0,get:function(){return PromptInputHeader}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_SubThemeProvider=require("../SubThemeProvider/SubThemeProvider"),_Box=require("../Box/Box"),_Divider=require("../Divider/Divider"),_Inline=require("../Inline/Inline"),_Text=require("../Typography/Text"),StyledHeaderContainer=(0,_styled.default)("div",{target:"
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"PromptInputHeader",{enumerable:!0,get:function(){return PromptInputHeader}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_SubThemeProvider=require("../SubThemeProvider/SubThemeProvider"),_Box=require("../Box/Box"),_Divider=require("../Divider/Divider"),_Inline=require("../Inline/Inline"),_Text=require("../Typography/Text"),StyledHeaderContainer=(0,_styled.default)("div",{target:"e1lnkzkd0",label:"StyledHeaderContainer"})(({theme,borderRadiusSize})=>({backgroundColor:theme.values.color.background.primary.default,width:"100%",cursor:"auto",borderTopLeftRadius:`calc(${theme.variables.size.borderRadius[borderRadiusSize]} - 1px)`,borderTopRightRadius:`calc(${theme.variables.size.borderRadius[borderRadiusSize]} - 1px)`}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvUHJvbXB0SW5wdXRIZWFkZXIudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Qcm9tcHRJbnB1dC9Qcm9tcHRJbnB1dEhlYWRlci50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBSZWFjdEVsZW1lbnQgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHtcbiAgU3ViVGhlbWVQcm92aWRlcixcbiAgdHlwZSBTdWJUaGVtZU5hbWUsXG59IGZyb20gXCIuLi9TdWJUaGVtZVByb3ZpZGVyL1N1YlRoZW1lUHJvdmlkZXJcIjtcbmltcG9ydCB7IEJveCB9IGZyb20gXCIuLi9Cb3gvQm94XCI7XG5pbXBvcnQgeyBEaXZpZGVyIH0gZnJvbSBcIi4uL0RpdmlkZXIvRGl2aWRlclwiO1xuaW1wb3J0IHsgSW5saW5lIH0gZnJvbSBcIi4uL0lubGluZS9JbmxpbmVcIjtcbmltcG9ydCB7IFRleHQgfSBmcm9tIFwiLi4vVHlwb2dyYXBoeS9UZXh0XCI7XG5pbXBvcnQgdHlwZSB7IEJvcmRlclJhZGl1cyB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuXG50eXBlIFN1YnRoZW1lTmFtZVByb3AgPSBFeHRyYWN0PFN1YlRoZW1lTmFtZSwgXCJicmFuZFwiIHwgXCJkaW1tZWRcIj47XG5cbmV4cG9ydCB0eXBlIEJhc2VQcm9tcHRJbnB1dEhlYWRlclByb3BzID0ge1xuICB0aXRsZTogc3RyaW5nO1xuICByaWdodENvbnRlbnQ/OiBSZWFjdEVsZW1lbnQ7XG4gIHN1YnRoZW1lTmFtZT86IFN1YnRoZW1lTmFtZVByb3A7XG59O1xuXG50eXBlIFByb21wdElucHV0SGVhZGVyUHJvcHMgPSBPbWl0PFxuICBCYXNlUHJvbXB0SW5wdXRIZWFkZXJQcm9wcyxcbiAgXCJzdWJ0aGVtZU5hbWVcIlxuPiAmIHtcbiAgc3VidGhlbWVOYW1lPzogU3VidGhlbWVOYW1lUHJvcCB8IEV4dHJhY3Q8U3ViVGhlbWVOYW1lLCBcInVuc2V0XCI+O1xuICBib3JkZXJSYWRpdXNTaXplOiBCb3JkZXJSYWRpdXM7XG59O1xuXG4vLyAtMXB4IGJlY2F1c2Ugd2UgaGF2ZSBhIGJvcmRlciBvZiBjb250YWluZXIgaW4gdGhlIHBhcmVudFxuY29uc3QgU3R5bGVkSGVhZGVyQ29udGFpbmVyID0gc3R5bGVkLmRpdjxcbiAgUGljazxQcm9tcHRJbnB1dEhlYWRlclByb3BzLCBcImJvcmRlclJhZGl1c1NpemVcIj5cbj4oKHsgdGhlbWUsIGJvcmRlclJhZGl1c1NpemUgfSkgPT4gKHtcbiAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gIHdpZHRoOiBcIjEwMCVcIixcbiAgY3Vyc29yOiBcImF1dG9cIixcbiAgYm9yZGVyVG9wTGVmdFJhZGl1czogYGNhbGMoJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXNbYm9yZGVyUmFkaXVzU2l6ZV19IC0gMXB4KWAsXG4gIGJvcmRlclRvcFJpZ2h0UmFkaXVzOiBgY2FsYygke3RoZW1lLnZhcmlhYmxlcy5zaXplLmJvcmRlclJhZGl1c1tib3JkZXJSYWRpdXNTaXplXX0gLSAxcHgpYCxcbn0pKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFByb21wdElucHV0SGVhZGVyKHtcbiAgdGl0bGUsXG4gIHJpZ2h0Q29udGVudCxcbiAgYm9yZGVyUmFkaXVzU2l6ZSxcbiAgc3VidGhlbWVOYW1lID0gXCJ1bnNldFwiLFxufTogUHJvbXB0SW5wdXRIZWFkZXJQcm9wcyk6IFJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN1YlRoZW1lUHJvdmlkZXIgbmFtZT17c3VidGhlbWVOYW1lfT5cbiAgICAgIDxTdHlsZWRIZWFkZXJDb250YWluZXJcbiAgICAgICAgZGF0YS1lMmUtdGVzdC1pZD1cInByb21wdC1pbnB1dC1oZWFkZXJcIlxuICAgICAgICBib3JkZXJSYWRpdXNTaXplPXtib3JkZXJSYWRpdXNTaXplfVxuICAgICAgPlxuICAgICAgICA8Qm94IHNwYWNlPVwic1wiIGxTcGFjZT1cIm1cIiB2U3BhY2U9XCJ6ZXJvXCI+XG4gICAgICAgICAgPElubGluZSBhbGlnbkl0ZW1zPVwic3BhY2VCZXR3ZWVuXCIgdkFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICAgIDxCb3ggdlNwYWNlPVwic1wiIHNwYWNlPVwiemVyb1wiPlxuICAgICAgICAgICAgICA8VGV4dCBjb2xvcj1cImFjY2VudFwiIHdlaWdodD1cImJvbGRcIj5cbiAgICAgICAgICAgICAgICB7dGl0bGV9XG4gICAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgIDwvQm94PlxuICAgICAgICAgICAge3JpZ2h0Q29udGVudH1cbiAgICAgICAgICA8L0lubGluZT5cbiAgICAgICAgPC9Cb3g+XG4gICAgICAgIDxEaXZpZGVyIC8+XG4gICAgICA8L1N0eWxlZEhlYWRlckNvbnRhaW5lcj5cbiAgICA8L1N1YlRoZW1lUHJvdmlkZXI+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOEI4QiJ9 */");function PromptInputHeader({title,rightContent,borderRadiusSize,subthemeName="unset"}){return _react.default.createElement(_SubThemeProvider.SubThemeProvider,{name:subthemeName},_react.default.createElement(StyledHeaderContainer,{"data-e2e-test-id":"prompt-input-header",borderRadiusSize:borderRadiusSize},_react.default.createElement(_Box.Box,{space:"s",lSpace:"m",vSpace:"zero"},_react.default.createElement(_Inline.Inline,{alignItems:"spaceBetween",vAlignItems:"center"},_react.default.createElement(_Box.Box,{vSpace:"s",space:"zero"},_react.default.createElement(_Text.Text,{color:"accent",weight:"bold"},title)),rightContent)),_react.default.createElement(_Divider.Divider,null)))}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get PromptTextArea(){return PromptTextArea},get getPaddingHorizontal(){return getPaddingHorizontal},get getPaddingVertical(){return getPaddingVertical}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_getInputTextPlaceholder=require("../../shared/mixins/TextInput/getInputTextPlaceholder"),_ScreenReaderText=require("../Utilities/ScreenReaderText/ScreenReaderText"),_AutocompleteList=require("./AutocompleteList"),getPaddingHorizontal=theme=>theme.variables.size.spacing.m,getPaddingVertical=theme=>theme.variables.size.spacing.m,StyledTextAreaContainer=(0,_styled.default)("label",{target:"ebkahvl0",label:"StyledTextAreaContainer"})(({theme,maxTextAreaHeight,isCollapsed,isNavBarVariant,hasLeftIcon})=>{let paddingTop=isNavBarVariant?theme.variables.size.spacing.xxs:getPaddingVertical(theme),paddingBottom=isNavBarVariant?theme.variables.size.spacing.xxs:getPaddingVertical(theme),paddingRight=theme.variables.size.spacing.xxl,basePaddingLeft=getPaddingHorizontal(theme),paddingLeft=hasLeftIcon?`calc(${basePaddingLeft} + ${theme.variables.size.dimension.icon.m} + ${theme.variables.size.spacing.xs})`:basePaddingLeft;return{display:"grid",verticalAlign:"top",alignItems:"stretch",width:"100%",borderRadius:"inherit",position:"relative",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,lineHeight:theme.variables.size.lineHeight.xl,...isCollapsed&&{backgroundColor:theme.values.color.canvas},"&::after":{content:"attr(data-value) ' '",boxSizing:"border-box",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,gridArea:"1 / 1",whiteSpace:"pre-wrap",visibility:"hidden",maxHeight:maxTextAreaHeight},textarea:{all:"unset",resize:"none",gridArea:"1 / 1",cursor:"text",color:theme.values.color.text.primary.default,...isCollapsed&&{overflow:"hidden"},...(0,_getInputTextPlaceholder.getInputTextPlaceholder)({theme})},"&::after, textarea":{minWidth:"0",overflowWrap:"break-word",padding:`${paddingTop} ${paddingRight} ${paddingBottom} ${paddingLeft}`,...!isCollapsed&&{paddingBottom:getPaddingVertical(theme)}}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvUHJvbXB0VGV4dEFyZWEudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Qcm9tcHRJbnB1dC9Qcm9tcHRUZXh0QXJlYS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBSZWZPYmplY3QsIFRleHRhcmVhSFRNTEF0dHJpYnV0ZXMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmLCB1c2VFZmZlY3QgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBQcm9wZXJ0eSB9IGZyb20gXCJjc3N0eXBlXCI7XG5pbXBvcnQgeyBnZXRJbnB1dFRleHRQbGFjZWhvbGRlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWl4aW5zL1RleHRJbnB1dC9nZXRJbnB1dFRleHRQbGFjZWhvbGRlclwiO1xuaW1wb3J0IHsgU2NyZWVuUmVhZGVyVGV4dCB9IGZyb20gXCIuLi9VdGlsaXRpZXMvU2NyZWVuUmVhZGVyVGV4dC9TY3JlZW5SZWFkZXJUZXh0XCI7XG5pbXBvcnQgeyBnZXRBdXRvY29tcGxldGVMaXN0SWQgfSBmcm9tIFwiLi9BdXRvY29tcGxldGVMaXN0XCI7XG5pbXBvcnQgdHlwZSB7IEZsYXR0ZW5lZExpc3RJdGVtIH0gZnJvbSBcIi4vQ2F0ZWdvcnlMaXN0XCI7XG5cbmV4cG9ydCBjb25zdCBnZXRQYWRkaW5nSG9yaXpvbnRhbCA9ICh0aGVtZTogVGhlbWUpOiBzdHJpbmcgPT5cbiAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tO1xuZXhwb3J0IGNvbnN0IGdldFBhZGRpbmdWZXJ0aWNhbCA9ICh0aGVtZTogVGhlbWUpOiBzdHJpbmcgPT5cbiAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tO1xuXG5leHBvcnQgdHlwZSBQcm9tcHRUZXh0QXJlYVByb3BzID1cbiAgVGV4dGFyZWFIVE1MQXR0cmlidXRlczxIVE1MVGV4dEFyZWFFbGVtZW50PiAmIHtcbiAgICBkYXRhRTJlVGVzdElkPzogc3RyaW5nO1xuICAgIGxhYmVsOiBzdHJpbmc7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIHZhbHVlOiBzdHJpbmc7XG4gICAgbWF4VGV4dEFyZWFIZWlnaHQ/OiBQcm9wZXJ0eS5IZWlnaHQ7XG4gICAgc2VsZWN0ZWRMaXN0SXRlbT86IEZsYXR0ZW5lZExpc3RJdGVtO1xuICAgIGlzQXV0b2NvbXBsZXRlTGlzdE9wZW4/OiBib29sZWFuO1xuICAgIGlzQ29sbGFwc2VkPzogYm9vbGVhbjtcbiAgICAvKiogQ29sbGFwc2VkIHZhcmlhbnQgc2hvd2luZyBvbmx5IHNpbmdsZSByb3cgdGV4dCBhcmVhICovXG4gICAgaXNOYXZCYXJWYXJpYW50PzogYm9vbGVhbjtcbiAgICBoYXNMZWZ0SWNvbj86IGJvb2xlYW47XG4gIH07XG5cbnR5cGUgU3R5bGVkVGV4dEFyZWFDb250YWluZXJQcm9wcyA9IFBpY2s8XG4gIFByb21wdFRleHRBcmVhUHJvcHMsXG4gIFwibWF4VGV4dEFyZWFIZWlnaHRcIiB8IFwiaXNDb2xsYXBzZWRcIiB8IFwiaXNOYXZCYXJWYXJpYW50XCIgfCBcImhhc0xlZnRJY29uXCJcbj47XG5cbi8vIFRleHRhcmVhIGF1dG8gZ3JvdyBpbXBsZW1lbnRlZCBhY2NvcmRpbmcgdG8gaHR0cHM6Ly9jc3MtdHJpY2tzLmNvbS90aGUtY2xlYW5lc3QtdHJpY2stZm9yLWF1dG9ncm93aW5nLXRleHRhcmVhcy9cblxuY29uc3QgU3R5bGVkVGV4dEFyZWFDb250YWluZXIgPSBzdHlsZWQubGFiZWw8U3R5bGVkVGV4dEFyZWFDb250YWluZXJQcm9wcz4oXG4gICh7IHRoZW1lLCBtYXhUZXh0QXJlYUhlaWdodCwgaXNDb2xsYXBzZWQsIGlzTmF2QmFyVmFyaWFudCwgaGFzTGVmdEljb24gfSkgPT4ge1xuICAgIGNvbnN0IHBhZGRpbmdUb3AgPSBpc05hdkJhclZhcmlhbnRcbiAgICAgID8gdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHNcbiAgICAgIDogZ2V0UGFkZGluZ1ZlcnRpY2FsKHRoZW1lKTtcbiAgICBjb25zdCBwYWRkaW5nQm90dG9tID0gaXNOYXZCYXJWYXJpYW50XG4gICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICA6IGdldFBhZGRpbmdWZXJ0aWNhbCh0aGVtZSk7XG4gICAgY29uc3QgcGFkZGluZ1JpZ2h0ID0gdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eGw7XG4gICAgY29uc3QgYmFzZVBhZGRpbmdMZWZ0ID0gZ2V0UGFkZGluZ0hvcml6b250YWwodGhlbWUpO1xuICAgIGNvbnN0IHBhZGRpbmdMZWZ0ID0gaGFzTGVmdEljb25cbiAgICAgID8gYGNhbGMoJHtiYXNlUGFkZGluZ0xlZnR9ICsgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5kaW1lbnNpb24uaWNvbi5tfSArICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30pYFxuICAgICAgOiBiYXNlUGFkZGluZ0xlZnQ7XG5cbiAgICByZXR1cm4ge1xuICAgICAgZGlzcGxheTogXCJncmlkXCIsXG4gICAgICB2ZXJ0aWNhbEFsaWduOiBcInRvcFwiLFxuICAgICAgYWxpZ25JdGVtczogXCJzdHJldGNoXCIsXG4gICAgICB3aWR0aDogXCIxMDAlXCIsXG4gICAgICBib3JkZXJSYWRpdXM6IFwiaW5oZXJpdFwiLFxuICAgICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICAgIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gICAgICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC5tLFxuICAgICAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC54bCxcblxuICAgICAgLi4uKGlzQ29sbGFwc2VkICYmIHtcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuY2FudmFzLFxuICAgICAgfSksXG5cbiAgICAgIC8vIFRleHRhcmVhIGdyb3dzIGR1ZSB0byA6OmFmdGVyIGdyb3dzXG4gICAgICAvLyBpZiB5b3UgbmVlZCB0byBtYW5pcHVsYXRlIHdpdGggc2l6ZSBvZiB0ZXh0YXJlYSwgeW91IG5lZWQgdG8gbWFuaXB1bGF0ZSB3aXRoIDo6YWZ0ZXIgYWxzb1xuICAgICAgXCImOjphZnRlclwiOiB7XG4gICAgICAgIGNvbnRlbnQ6IFwiYXR0cihkYXRhLXZhbHVlKSAnICdcIiwgLy8gdGhlIGVtcHR5IHNwYWNlIHByZXZlbnRzIHRleHRhcmVhIGp1bXAgb24gZ3Jvd1xuICAgICAgICBib3hTaXppbmc6IFwiYm9yZGVyLWJveFwiLFxuICAgICAgICBmb250RmFtaWx5OiB0aGVtZS52YXJpYWJsZXMuZm9udEZhbWlseS5sYXRvLFxuICAgICAgICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC5tLFxuICAgICAgICBncmlkQXJlYTogXCIxIC8gMVwiLFxuICAgICAgICB3aGl0ZVNwYWNlOiBcInByZS13cmFwXCIsXG4gICAgICAgIHZpc2liaWxpdHk6IFwiaGlkZGVuXCIsXG4gICAgICAgIG1heEhlaWdodDogbWF4VGV4dEFyZWFIZWlnaHQsXG4gICAgICB9LFxuXG4gICAgICB0ZXh0YXJlYToge1xuICAgICAgICBhbGw6IFwidW5zZXRcIixcbiAgICAgICAgcmVzaXplOiBcIm5vbmVcIixcbiAgICAgICAgZ3JpZEFyZWE6IFwiMSAvIDFcIixcbiAgICAgICAgY3Vyc29yOiBcInRleHRcIixcbiAgICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnByaW1hcnkuZGVmYXVsdCxcbiAgICAgICAgLi4uKGlzQ29sbGFwc2VkICYmIHtcbiAgICAgICAgICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgICAgICAgfSksXG4gICAgICAgIC4uLmdldElucHV0VGV4dFBsYWNlaG9sZGVyKHsgdGhlbWUgfSksXG4gICAgICB9LFxuXG4gICAgICBcIiY6OmFmdGVyLCB0ZXh0YXJlYVwiOiB7XG4gICAgICAgIC8vIG1pbldpZHRoIGNvbWVzIHRvZ2V0aGVyIHdpdGggb3ZlcmZsb3dXcmFwIHRvIGFjaGlldmUgYnJlYWstd29yZFxuICAgICAgICAvLyBpdCBzaG91bGQgYmUgYXBwbGllZCBmb3IgOjphZnRlciBhbmQgdGV4dGFyZWFcbiAgICAgICAgbWluV2lkdGg6IFwiMFwiLFxuICAgICAgICBvdmVyZmxvd1dyYXA6IFwiYnJlYWstd29yZFwiLFxuICAgICAgICBwYWRkaW5nOiBgJHtwYWRkaW5nVG9wfSAke3BhZGRpbmdSaWdodH0gJHtwYWRkaW5nQm90dG9tfSAke3BhZGRpbmdMZWZ0fWAsXG5cbiAgICAgICAgLi4uKCFpc0NvbGxhcHNlZCAmJiB7XG4gICAgICAgICAgcGFkZGluZ0JvdHRvbTogZ2V0UGFkZGluZ1ZlcnRpY2FsKHRoZW1lKSxcbiAgICAgICAgfSksXG4gICAgICB9LFxuICAgIH07XG4gIH1cbik7XG5cbmV4cG9ydCBjb25zdCBQcm9tcHRUZXh0QXJlYSA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBkYXRhRTJlVGVzdElkLFxuICAgICAgbGFiZWwsXG4gICAgICBuYW1lLFxuICAgICAgdmFsdWUsXG4gICAgICBwbGFjZWhvbGRlcixcbiAgICAgIG1heFRleHRBcmVhSGVpZ2h0ID0gXCIyMDBweFwiLFxuICAgICAgc2VsZWN0ZWRMaXN0SXRlbSxcbiAgICAgIGlzQXV0b2NvbXBsZXRlTGlzdE9wZW4sXG4gICAgICBpc0NvbGxhcHNlZCxcbiAgICAgIGlzTmF2QmFyVmFyaWFudCxcbiAgICAgIGhhc0xlZnRJY29uLFxuICAgICAgb25DaGFuZ2UsXG4gICAgICAuLi5yZXN0XG4gICAgfTogUHJvbXB0VGV4dEFyZWFQcm9wcyxcbiAgICByZWY6IFJlZk9iamVjdDxIVE1MVGV4dEFyZWFFbGVtZW50PlxuICApID0+IHtcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgICAgY29uc3QgdGV4dEFyZWEgPSByZWYuY3VycmVudDtcblxuICAgICAgaWYgKGlzQ29sbGFwc2VkKSB7XG4gICAgICAgICh0ZXh0QXJlYS5wYXJlbnROb2RlIGFzIEhUTUxFbGVtZW50KS5kYXRhc2V0LnZhbHVlID0gXCJcIjtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIC8vIFNldCB0aGUgdmFsdWUgb2YgdGhlIDo6YWZ0ZXIgcHN1ZWRvIGVsZW1lbnQgc28gdGhhdCB0aGUgVGV4dEFyZWEgcmVzaXplcyBhY2NvcmRpbmdseSBhcyB0aGUgZ3JpZCBzdHJldGNoZXMuXG4gICAgICAgICh0ZXh0QXJlYS5wYXJlbnROb2RlIGFzIEhUTUxFbGVtZW50KS5kYXRhc2V0LnZhbHVlID0gdmFsdWU7XG4gICAgICB9XG4gICAgfSwgW3ZhbHVlLCByZWYsIGlzQ29sbGFwc2VkXSk7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPFN0eWxlZFRleHRBcmVhQ29udGFpbmVyXG4gICAgICAgIG1heFRleHRBcmVhSGVpZ2h0PXttYXhUZXh0QXJlYUhlaWdodH1cbiAgICAgICAgaXNDb2xsYXBzZWQ9e2lzQ29sbGFwc2VkfVxuICAgICAgICBpc05hdkJhclZhcmlhbnQ9e2lzTmF2QmFyVmFyaWFudH1cbiAgICAgICAgaGFzTGVmdEljb249e2hhc0xlZnRJY29ufVxuICAgICAgPlxuICAgICAgICA8U2NyZWVuUmVhZGVyVGV4dD57bGFiZWx9PC9TY3JlZW5SZWFkZXJUZXh0PlxuICAgICAgICA8dGV4dGFyZWFcbiAgICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIHBsYWNlaG9sZGVyPXtwbGFjZWhvbGRlcn1cbiAgICAgICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICAgICAgcm93cz17MX1cbiAgICAgICAgICByb2xlPVwiY29tYm9ib3hcIlxuICAgICAgICAgIGFyaWEtYXV0b2NvbXBsZXRlPVwibGlzdFwiXG4gICAgICAgICAgYXJpYS1jb250cm9scz17XG4gICAgICAgICAgICBpc0F1dG9jb21wbGV0ZUxpc3RPcGVuID8gZ2V0QXV0b2NvbXBsZXRlTGlzdElkKG5hbWUpIDogXCJcIlxuICAgICAgICAgIH1cbiAgICAgICAgICBhcmlhLWFjdGl2ZWRlc2NlbmRhbnQ9e3NlbGVjdGVkTGlzdEl0ZW0gPyBzZWxlY3RlZExpc3RJdGVtLmlkIDogXCJcIn1cbiAgICAgICAgICBhcmlhLWV4cGFuZGVkPXtpc0F1dG9jb21wbGV0ZUxpc3RPcGVufVxuICAgICAgICAvPlxuICAgICAgPC9TdHlsZWRUZXh0QXJlYUNvbnRhaW5lcj5cbiAgICApO1xuICB9XG4pO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFDZ0MifQ== */"),PromptTextArea=(0,_react.forwardRef)(({dataE2eTestId,label,name,value,placeholder,maxTextAreaHeight="200px",selectedListItem,isAutocompleteListOpen,isCollapsed,isNavBarVariant,hasLeftIcon,onChange,...rest},ref)=>((0,_react.useEffect)(()=>{let textArea=ref.current;isCollapsed?textArea.parentNode.dataset.value="":textArea.parentNode.dataset.value=value},[value,ref,isCollapsed]),_react.default.createElement(StyledTextAreaContainer,{maxTextAreaHeight:maxTextAreaHeight,isCollapsed:isCollapsed,isNavBarVariant:isNavBarVariant,hasLeftIcon:hasLeftIcon},_react.default.createElement(_ScreenReaderText.ScreenReaderText,null,label),_react.default.createElement("textarea",{...rest,"data-e2e-test-id":dataE2eTestId,ref:ref,name:name,value:value,placeholder:placeholder,onChange:onChange,rows:1,role:"combobox","aria-autocomplete":"list","aria-controls":isAutocompleteListOpen?(0,_AutocompleteList.getAutocompleteListId)(name):"","aria-activedescendant":selectedListItem?selectedListItem.id:"","aria-expanded":isAutocompleteListOpen}))));
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get PromptTextArea(){return PromptTextArea},get getPaddingHorizontal(){return getPaddingHorizontal},get getPaddingVertical(){return getPaddingVertical}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_getInputTextPlaceholder=require("../../shared/mixins/TextInput/getInputTextPlaceholder"),_ScreenReaderText=require("../Utilities/ScreenReaderText/ScreenReaderText"),_AutocompleteList=require("./AutocompleteList"),getPaddingHorizontal=theme=>theme.variables.size.spacing.m,getPaddingVertical=theme=>theme.variables.size.spacing.m,StyledTextAreaContainer=(0,_styled.default)("label",{target:"e1kr3gwl0",label:"StyledTextAreaContainer"})(({theme,maxTextAreaHeight,isCollapsed,isNavBarVariant,hasLeftIcon})=>{let paddingTop=isNavBarVariant?theme.variables.size.spacing.xxs:getPaddingVertical(theme),paddingBottom=isNavBarVariant?theme.variables.size.spacing.xxs:getPaddingVertical(theme),paddingRight=theme.variables.size.spacing.xxl,basePaddingLeft=getPaddingHorizontal(theme),paddingLeft=hasLeftIcon?`calc(${basePaddingLeft} + ${theme.variables.size.dimension.icon.m} + ${theme.variables.size.spacing.xs})`:basePaddingLeft;return{display:"grid",verticalAlign:"top",alignItems:"stretch",width:"100%",borderRadius:"inherit",position:"relative",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,lineHeight:theme.variables.size.lineHeight.xl,...isCollapsed&&{backgroundColor:theme.values.color.canvas},"&::after":{content:"attr(data-value) ' '",boxSizing:"border-box",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.m,gridArea:"1 / 1",whiteSpace:"pre-wrap",visibility:"hidden",maxHeight:maxTextAreaHeight},textarea:{all:"unset",resize:"none",gridArea:"1 / 1",cursor:"text",color:theme.values.color.text.primary.default,...isCollapsed&&{overflow:"hidden"},...(0,_getInputTextPlaceholder.getInputTextPlaceholder)({theme})},"textarea::placeholder":{whiteSpace:"nowrap",textOverflow:"ellipsis",overflow:"hidden"},"&::after, textarea":{minWidth:"0",overflowWrap:"break-word",padding:`${paddingTop} ${paddingRight} ${paddingBottom} ${paddingLeft}`,...!isCollapsed&&{paddingBottom:getPaddingVertical(theme)}}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvUHJvbXB0SW5wdXQvUHJvbXB0VGV4dEFyZWEudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Qcm9tcHRJbnB1dC9Qcm9tcHRUZXh0QXJlYS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBSZWZPYmplY3QsIFRleHRhcmVhSFRNTEF0dHJpYnV0ZXMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmLCB1c2VFZmZlY3QgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB0eXBlIHsgVGhlbWUgfSBmcm9tIFwiQGVtb3Rpb24vcmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBQcm9wZXJ0eSB9IGZyb20gXCJjc3N0eXBlXCI7XG5pbXBvcnQgeyBnZXRJbnB1dFRleHRQbGFjZWhvbGRlciB9IGZyb20gXCIuLi8uLi9zaGFyZWQvbWl4aW5zL1RleHRJbnB1dC9nZXRJbnB1dFRleHRQbGFjZWhvbGRlclwiO1xuaW1wb3J0IHsgU2NyZWVuUmVhZGVyVGV4dCB9IGZyb20gXCIuLi9VdGlsaXRpZXMvU2NyZWVuUmVhZGVyVGV4dC9TY3JlZW5SZWFkZXJUZXh0XCI7XG5pbXBvcnQgeyBnZXRBdXRvY29tcGxldGVMaXN0SWQgfSBmcm9tIFwiLi9BdXRvY29tcGxldGVMaXN0XCI7XG5pbXBvcnQgdHlwZSB7IEZsYXR0ZW5lZExpc3RJdGVtIH0gZnJvbSBcIi4vQ2F0ZWdvcnlMaXN0XCI7XG5cbmV4cG9ydCBjb25zdCBnZXRQYWRkaW5nSG9yaXpvbnRhbCA9ICh0aGVtZTogVGhlbWUpOiBzdHJpbmcgPT5cbiAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tO1xuZXhwb3J0IGNvbnN0IGdldFBhZGRpbmdWZXJ0aWNhbCA9ICh0aGVtZTogVGhlbWUpOiBzdHJpbmcgPT5cbiAgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tO1xuXG5leHBvcnQgdHlwZSBQcm9tcHRUZXh0QXJlYVByb3BzID1cbiAgVGV4dGFyZWFIVE1MQXR0cmlidXRlczxIVE1MVGV4dEFyZWFFbGVtZW50PiAmIHtcbiAgICBkYXRhRTJlVGVzdElkPzogc3RyaW5nO1xuICAgIGxhYmVsOiBzdHJpbmc7XG4gICAgbmFtZTogc3RyaW5nO1xuICAgIHZhbHVlOiBzdHJpbmc7XG4gICAgbWF4VGV4dEFyZWFIZWlnaHQ/OiBQcm9wZXJ0eS5IZWlnaHQ7XG4gICAgc2VsZWN0ZWRMaXN0SXRlbT86IEZsYXR0ZW5lZExpc3RJdGVtO1xuICAgIGlzQXV0b2NvbXBsZXRlTGlzdE9wZW4/OiBib29sZWFuO1xuICAgIGlzQ29sbGFwc2VkPzogYm9vbGVhbjtcbiAgICAvKiogQ29sbGFwc2VkIHZhcmlhbnQgc2hvd2luZyBvbmx5IHNpbmdsZSByb3cgdGV4dCBhcmVhICovXG4gICAgaXNOYXZCYXJWYXJpYW50PzogYm9vbGVhbjtcbiAgICBoYXNMZWZ0SWNvbj86IGJvb2xlYW47XG4gIH07XG5cbnR5cGUgU3R5bGVkVGV4dEFyZWFDb250YWluZXJQcm9wcyA9IFBpY2s8XG4gIFByb21wdFRleHRBcmVhUHJvcHMsXG4gIFwibWF4VGV4dEFyZWFIZWlnaHRcIiB8IFwiaXNDb2xsYXBzZWRcIiB8IFwiaXNOYXZCYXJWYXJpYW50XCIgfCBcImhhc0xlZnRJY29uXCJcbj47XG5cbi8vIFRleHRhcmVhIGF1dG8gZ3JvdyBpbXBsZW1lbnRlZCBhY2NvcmRpbmcgdG8gaHR0cHM6Ly9jc3MtdHJpY2tzLmNvbS90aGUtY2xlYW5lc3QtdHJpY2stZm9yLWF1dG9ncm93aW5nLXRleHRhcmVhcy9cblxuY29uc3QgU3R5bGVkVGV4dEFyZWFDb250YWluZXIgPSBzdHlsZWQubGFiZWw8U3R5bGVkVGV4dEFyZWFDb250YWluZXJQcm9wcz4oXG4gICh7IHRoZW1lLCBtYXhUZXh0QXJlYUhlaWdodCwgaXNDb2xsYXBzZWQsIGlzTmF2QmFyVmFyaWFudCwgaGFzTGVmdEljb24gfSkgPT4ge1xuICAgIGNvbnN0IHBhZGRpbmdUb3AgPSBpc05hdkJhclZhcmlhbnRcbiAgICAgID8gdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eHNcbiAgICAgIDogZ2V0UGFkZGluZ1ZlcnRpY2FsKHRoZW1lKTtcbiAgICBjb25zdCBwYWRkaW5nQm90dG9tID0gaXNOYXZCYXJWYXJpYW50XG4gICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICA6IGdldFBhZGRpbmdWZXJ0aWNhbCh0aGVtZSk7XG4gICAgY29uc3QgcGFkZGluZ1JpZ2h0ID0gdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54eGw7XG4gICAgY29uc3QgYmFzZVBhZGRpbmdMZWZ0ID0gZ2V0UGFkZGluZ0hvcml6b250YWwodGhlbWUpO1xuICAgIGNvbnN0IHBhZGRpbmdMZWZ0ID0gaGFzTGVmdEljb25cbiAgICAgID8gYGNhbGMoJHtiYXNlUGFkZGluZ0xlZnR9ICsgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5kaW1lbnNpb24uaWNvbi5tfSArICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy54c30pYFxuICAgICAgOiBiYXNlUGFkZGluZ0xlZnQ7XG5cbiAgICByZXR1cm4ge1xuICAgICAgZGlzcGxheTogXCJncmlkXCIsXG4gICAgICB2ZXJ0aWNhbEFsaWduOiBcInRvcFwiLFxuICAgICAgYWxpZ25JdGVtczogXCJzdHJldGNoXCIsXG4gICAgICB3aWR0aDogXCIxMDAlXCIsXG4gICAgICBib3JkZXJSYWRpdXM6IFwiaW5oZXJpdFwiLFxuICAgICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICAgIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gICAgICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC5tLFxuICAgICAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC54bCxcblxuICAgICAgLi4uKGlzQ29sbGFwc2VkICYmIHtcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuY2FudmFzLFxuICAgICAgfSksXG5cbiAgICAgIC8vIFRleHRhcmVhIGdyb3dzIGR1ZSB0byA6OmFmdGVyIGdyb3dzXG4gICAgICAvLyBpZiB5b3UgbmVlZCB0byBtYW5pcHVsYXRlIHdpdGggc2l6ZSBvZiB0ZXh0YXJlYSwgeW91IG5lZWQgdG8gbWFuaXB1bGF0ZSB3aXRoIDo6YWZ0ZXIgYWxzb1xuICAgICAgXCImOjphZnRlclwiOiB7XG4gICAgICAgIGNvbnRlbnQ6IFwiYXR0cihkYXRhLXZhbHVlKSAnICdcIiwgLy8gdGhlIGVtcHR5IHNwYWNlIHByZXZlbnRzIHRleHRhcmVhIGp1bXAgb24gZ3Jvd1xuICAgICAgICBib3hTaXppbmc6IFwiYm9yZGVyLWJveFwiLFxuICAgICAgICBmb250RmFtaWx5OiB0aGVtZS52YXJpYWJsZXMuZm9udEZhbWlseS5sYXRvLFxuICAgICAgICBmb250U2l6ZTogdGhlbWUudmFyaWFibGVzLnNpemUuZm9udC5tLFxuICAgICAgICBncmlkQXJlYTogXCIxIC8gMVwiLFxuICAgICAgICB3aGl0ZVNwYWNlOiBcInByZS13cmFwXCIsXG4gICAgICAgIHZpc2liaWxpdHk6IFwiaGlkZGVuXCIsXG4gICAgICAgIG1heEhlaWdodDogbWF4VGV4dEFyZWFIZWlnaHQsXG4gICAgICB9LFxuXG4gICAgICB0ZXh0YXJlYToge1xuICAgICAgICBhbGw6IFwidW5zZXRcIixcbiAgICAgICAgcmVzaXplOiBcIm5vbmVcIixcbiAgICAgICAgZ3JpZEFyZWE6IFwiMSAvIDFcIixcbiAgICAgICAgY3Vyc29yOiBcInRleHRcIixcbiAgICAgICAgY29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnByaW1hcnkuZGVmYXVsdCxcbiAgICAgICAgLi4uKGlzQ29sbGFwc2VkICYmIHtcbiAgICAgICAgICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgICAgICAgfSksXG4gICAgICAgIC4uLmdldElucHV0VGV4dFBsYWNlaG9sZGVyKHsgdGhlbWUgfSksXG4gICAgICB9LFxuICAgICAgXCJ0ZXh0YXJlYTo6cGxhY2Vob2xkZXJcIjoge1xuICAgICAgICB3aGl0ZVNwYWNlOiBcIm5vd3JhcFwiLFxuICAgICAgICB0ZXh0T3ZlcmZsb3c6IFwiZWxsaXBzaXNcIixcbiAgICAgICAgb3ZlcmZsb3c6IFwiaGlkZGVuXCIsXG4gICAgICB9LFxuXG4gICAgICBcIiY6OmFmdGVyLCB0ZXh0YXJlYVwiOiB7XG4gICAgICAgIC8vIG1pbldpZHRoIGNvbWVzIHRvZ2V0aGVyIHdpdGggb3ZlcmZsb3dXcmFwIHRvIGFjaGlldmUgYnJlYWstd29yZFxuICAgICAgICAvLyBpdCBzaG91bGQgYmUgYXBwbGllZCBmb3IgOjphZnRlciBhbmQgdGV4dGFyZWFcbiAgICAgICAgbWluV2lkdGg6IFwiMFwiLFxuICAgICAgICBvdmVyZmxvd1dyYXA6IFwiYnJlYWstd29yZFwiLFxuICAgICAgICBwYWRkaW5nOiBgJHtwYWRkaW5nVG9wfSAke3BhZGRpbmdSaWdodH0gJHtwYWRkaW5nQm90dG9tfSAke3BhZGRpbmdMZWZ0fWAsXG5cbiAgICAgICAgLi4uKCFpc0NvbGxhcHNlZCAmJiB7XG4gICAgICAgICAgcGFkZGluZ0JvdHRvbTogZ2V0UGFkZGluZ1ZlcnRpY2FsKHRoZW1lKSxcbiAgICAgICAgfSksXG4gICAgICB9LFxuICAgIH07XG4gIH1cbik7XG5cbmV4cG9ydCBjb25zdCBQcm9tcHRUZXh0QXJlYSA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBkYXRhRTJlVGVzdElkLFxuICAgICAgbGFiZWwsXG4gICAgICBuYW1lLFxuICAgICAgdmFsdWUsXG4gICAgICBwbGFjZWhvbGRlcixcbiAgICAgIG1heFRleHRBcmVhSGVpZ2h0ID0gXCIyMDBweFwiLFxuICAgICAgc2VsZWN0ZWRMaXN0SXRlbSxcbiAgICAgIGlzQXV0b2NvbXBsZXRlTGlzdE9wZW4sXG4gICAgICBpc0NvbGxhcHNlZCxcbiAgICAgIGlzTmF2QmFyVmFyaWFudCxcbiAgICAgIGhhc0xlZnRJY29uLFxuICAgICAgb25DaGFuZ2UsXG4gICAgICAuLi5yZXN0XG4gICAgfTogUHJvbXB0VGV4dEFyZWFQcm9wcyxcbiAgICByZWY6IFJlZk9iamVjdDxIVE1MVGV4dEFyZWFFbGVtZW50PlxuICApID0+IHtcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgICAgY29uc3QgdGV4dEFyZWEgPSByZWYuY3VycmVudDtcblxuICAgICAgaWYgKGlzQ29sbGFwc2VkKSB7XG4gICAgICAgICh0ZXh0QXJlYS5wYXJlbnROb2RlIGFzIEhUTUxFbGVtZW50KS5kYXRhc2V0LnZhbHVlID0gXCJcIjtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIC8vIFNldCB0aGUgdmFsdWUgb2YgdGhlIDo6YWZ0ZXIgcHN1ZWRvIGVsZW1lbnQgc28gdGhhdCB0aGUgVGV4dEFyZWEgcmVzaXplcyBhY2NvcmRpbmdseSBhcyB0aGUgZ3JpZCBzdHJldGNoZXMuXG4gICAgICAgICh0ZXh0QXJlYS5wYXJlbnROb2RlIGFzIEhUTUxFbGVtZW50KS5kYXRhc2V0LnZhbHVlID0gdmFsdWU7XG4gICAgICB9XG4gICAgfSwgW3ZhbHVlLCByZWYsIGlzQ29sbGFwc2VkXSk7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPFN0eWxlZFRleHRBcmVhQ29udGFpbmVyXG4gICAgICAgIG1heFRleHRBcmVhSGVpZ2h0PXttYXhUZXh0QXJlYUhlaWdodH1cbiAgICAgICAgaXNDb2xsYXBzZWQ9e2lzQ29sbGFwc2VkfVxuICAgICAgICBpc05hdkJhclZhcmlhbnQ9e2lzTmF2QmFyVmFyaWFudH1cbiAgICAgICAgaGFzTGVmdEljb249e2hhc0xlZnRJY29ufVxuICAgICAgPlxuICAgICAgICA8U2NyZWVuUmVhZGVyVGV4dD57bGFiZWx9PC9TY3JlZW5SZWFkZXJUZXh0PlxuICAgICAgICA8dGV4dGFyZWFcbiAgICAgICAgICB7Li4ucmVzdH1cbiAgICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgIG5hbWU9e25hbWV9XG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIHBsYWNlaG9sZGVyPXtwbGFjZWhvbGRlcn1cbiAgICAgICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICAgICAgcm93cz17MX1cbiAgICAgICAgICByb2xlPVwiY29tYm9ib3hcIlxuICAgICAgICAgIGFyaWEtYXV0b2NvbXBsZXRlPVwibGlzdFwiXG4gICAgICAgICAgYXJpYS1jb250cm9scz17XG4gICAgICAgICAgICBpc0F1dG9jb21wbGV0ZUxpc3RPcGVuID8gZ2V0QXV0b2NvbXBsZXRlTGlzdElkKG5hbWUpIDogXCJcIlxuICAgICAgICAgIH1cbiAgICAgICAgICBhcmlhLWFjdGl2ZWRlc2NlbmRhbnQ9e3NlbGVjdGVkTGlzdEl0ZW0gPyBzZWxlY3RlZExpc3RJdGVtLmlkIDogXCJcIn1cbiAgICAgICAgICBhcmlhLWV4cGFuZGVkPXtpc0F1dG9jb21wbGV0ZUxpc3RPcGVufVxuICAgICAgICAvPlxuICAgICAgPC9TdHlsZWRUZXh0QXJlYUNvbnRhaW5lcj5cbiAgICApO1xuICB9XG4pO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFDZ0MifQ== */"),PromptTextArea=(0,_react.forwardRef)(({dataE2eTestId,label,name,value,placeholder,maxTextAreaHeight="200px",selectedListItem,isAutocompleteListOpen,isCollapsed,isNavBarVariant,hasLeftIcon,onChange,...rest},ref)=>((0,_react.useEffect)(()=>{let textArea=ref.current;isCollapsed?textArea.parentNode.dataset.value="":textArea.parentNode.dataset.value=value},[value,ref,isCollapsed]),_react.default.createElement(StyledTextAreaContainer,{maxTextAreaHeight:maxTextAreaHeight,isCollapsed:isCollapsed,isNavBarVariant:isNavBarVariant,hasLeftIcon:hasLeftIcon},_react.default.createElement(_ScreenReaderText.ScreenReaderText,null,label),_react.default.createElement("textarea",{...rest,"data-e2e-test-id":dataE2eTestId,ref:ref,name:name,value:value,placeholder:placeholder,onChange:onChange,rows:1,role:"combobox","aria-autocomplete":"list","aria-controls":isAutocompleteListOpen?(0,_AutocompleteList.getAutocompleteListId)(name):"","aria-activedescendant":selectedListItem?selectedListItem.id:"","aria-expanded":isAutocompleteListOpen}))));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"getInputTextPlaceholder",{enumerable:!0,get:function(){return getInputTextPlaceholder}});const getInputTextPlaceholder=({theme})=>({"&::placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default,opacity:theme.variables.opacity.visible
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"getInputTextPlaceholder",{enumerable:!0,get:function(){return getInputTextPlaceholder}});const getInputTextPlaceholder=({theme})=>({"&::placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default,opacity:theme.variables.opacity.visible},"&:-ms-input-placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default},"&::-ms-input-placeholder":{fontStyle:"italic",color:theme.values.color.text.tertiary.default},"&:placeholder-shown":{textOverflow:"ellipsis"}});
|
|
@@ -20,6 +20,7 @@ export type DataTableProps = {
|
|
|
20
20
|
* @param DataTableColumn[].label - Column label for display
|
|
21
21
|
* @param DataTableColumn[].align - Align cell content, 'left' | 'right' | 'center'
|
|
22
22
|
* @param DataTableColumn[].width - Column width
|
|
23
|
+
* @param DataTableColumn[].toggletipContent - Content of right toggletip
|
|
23
24
|
* @param DataTableColumn[].renderCell - Callback to render custom cell content.
|
|
24
25
|
* @param DataTableColumn[].isSortable - Is table sortable by column
|
|
25
26
|
* @param DataTableColumn[].sortDirection - Sorted as 'asc' | 'desc'
|