@amboss/design-system 3.37.3 → 3.38.0

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.
@@ -0,0 +1,14 @@
1
+ import React from "react";
2
+ import { type IconProps } from "../Icon/Icon";
3
+ import { type ImageProps } from "../Image/Image";
4
+ import { type CardButtonProps } from "../Internal/InteractiveCard/InteractiveCard";
5
+ export type SplashCardMediaProps = {
6
+ title: string;
7
+ description?: string;
8
+ variant?: "standard" | "bold";
9
+ isPressed?: boolean;
10
+ hasShadow?: boolean;
11
+ imageProps: Pick<ImageProps, "src" | "alt" | "placeholderSrc" | "fallbackSrc" | "sources">;
12
+ iconProps?: IconProps;
13
+ } & CardButtonProps;
14
+ export declare function SplashCardMedia({ isPressed, disabled, title, description, variant, iconProps, imageProps, hasShadow, ...rest }: SplashCardMediaProps): React.ReactElement;
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"SplashCardMedia",{enumerable:!0,get:function(){return SplashCardMedia}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_breakpointsjson=/*#__PURE__*/_interop_require_default._(require("../../web-tokens/_breakpoints.json")),_useHover=require("../../shared/useHover"),_Header=require("../Typography/Header/Header"),_Text=require("../Typography/Text/Text"),_Stack=require("../Stack/Stack"),_Container=require("../Container/Container"),_useFocusWithin=require("../../shared/useFocusWithin"),_Icon=require("../Icon/Icon"),_Image=require("../Image/Image"),_Box=require("../Box/Box"),_mixins=require("../../shared/mixins"),_useBreakpoints=require("../../shared/useBreakpoints"),CustomContainer=(0,_styled.default)(_Container.Container,{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"isActive"!==prop&&"hasShadow"!==prop,target:"ekger5h0",label:"CustomContainer"})(({theme,isActive,hasShadow})=>({...hasShadow&&{borderBottom:"4px solid rgba(138, 97, 241, 0.20)"},backgroundColor:isActive?theme.values.color.background.accent.default:theme.values.color.background.accentSubtle.default,transitionProperty:"background-color",transitionDuration:theme.variables.animation.duration.medium,transitionTimingFunction:theme.variables.animation.timingFunction,width:"100%",height:"100%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/SplashCardMedia/SplashCardMedia.tsx","sources":["src/components/SplashCardMedia/SplashCardMedia.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport type { BorderRadius } from \"src/types\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport { useHover } from \"../../shared/useHover\";\nimport { H4, H5, H6 } from \"../Typography/Header/Header\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Container } from \"../Container/Container\";\nimport { useFocusWithin } from \"../../shared/useFocusWithin\";\nimport { Icon, type IconProps } from \"../Icon/Icon\";\nimport { Image, type ImageProps } from \"../Image/Image\";\nimport { StyledBox } from \"../Box/Box\";\nimport {\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getFocusStyles,\n  getDisabledStyles,\n} from \"../../shared/mixins\";\nimport { type CardButtonProps } from \"../Internal/InteractiveCard/InteractiveCard\";\nimport { useBreakpoints } from \"../../shared/useBreakpoints\";\n\nexport type SplashCardMediaProps = {\n  title: string;\n  description?: string;\n  variant?: \"standard\" | \"bold\";\n  isPressed?: boolean;\n  hasShadow?: boolean;\n  imageProps: Pick<\n    ImageProps,\n    \"src\" | \"alt\" | \"placeholderSrc\" | \"fallbackSrc\" | \"sources\"\n  >;\n  iconProps?: IconProps;\n} & CardButtonProps;\n\nconst CustomContainer = styled(Container, {\n  shouldForwardProp: (prop) =>\n    isPropValid(prop) && prop !== \"isActive\" && prop !== \"hasShadow\",\n})<{ isActive: boolean; hasShadow?: boolean }>(\n  ({ theme, isActive, hasShadow }) => ({\n    ...(hasShadow && {\n      // TODO: Replace with theme token\n      borderBottom: `4px solid rgba(138, 97, 241, 0.20)`,\n    }),\n    backgroundColor: isActive\n      ? theme.values.color.background.accent.default\n      : theme.values.color.background.accentSubtle.default,\n    transitionProperty: \"background-color\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n    width: \"100%\",\n    height: \"100%\",\n  })\n);\n\nconst StyledButton = styled.button<{ disabled?: boolean }>(\n  ({ theme, disabled }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme }),\n    ...getFocusStyles(),\n    ...(disabled && {\n      ...getDisabledStyles({ theme }),\n      cursor: \"not-allowed\",\n    }),\n    position: \"relative\",\n    width: \"100%\",\n    height: \"100%\",\n    display: \"flex\",\n    flexDirection: \"row\",\n    textAlign: \"left\",\n    alignItems: \"center\",\n    padding: 0,\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      flexDirection: \"column\",\n      alignItems: \"start\",\n    },\n  })\n);\n\nconst ImageWrapper = styled.div<{ borderRadius: BorderRadius }>(\n  ({ theme, borderRadius }) => ({\n    width: 179,\n    flexShrink: 0,\n    overflow: \"hidden\",\n    borderBottomLeftRadius: theme.variables.size.borderRadius[borderRadius],\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      width: `calc(100% - 40px)`,\n    },\n  })\n);\n\nconst StyledImage = styled(Image)({\n  width: \"100%\",\n  height: \"100%\",\n  display: \"block\",\n});\n\n// Each icon layer fades in/out independently for the cross-fade effect.\nconst FadingIconLayer = styled.div<{ isVisible: boolean }>(\n  ({ theme, isVisible }) => ({\n    position: \"absolute\",\n    top: theme.variables.size.spacing.l,\n    right: theme.variables.size.spacing.l,\n    opacity: isVisible ? 1 : 0,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nconst LabelWrapper = styled.div<{ isActive: boolean }>(\n  ({ theme, isActive }) => ({\n    opacity: isActive ? 0.6 : 1,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nexport function SplashCardMedia({\n  isPressed,\n  disabled,\n  title,\n  description,\n  variant = \"standard\",\n  iconProps,\n  imageProps,\n  hasShadow,\n  ...rest\n}: SplashCardMediaProps): React.ReactElement {\n  const ref = useRef<HTMLButtonElement>(null);\n  const isHovered = useHover(ref);\n  const isFocused = useFocusWithin(ref);\n  const isActive = !disabled && (isHovered || isFocused || isPressed);\n\n  const activeColor = \"onAccent\" as const;\n  const mainTextColor = isActive ? activeColor : \"accent\";\n  const descriptionColor = isActive ? activeColor : \"secondary\";\n  const labelColor = isActive ? activeColor : \"tertiary\";\n\n  const { isMobile, isSmallMobile } = useBreakpoints();\n  const showImage = !isSmallMobile;\n  const showIcons = !isMobile;\n\n  const DescriptionHeading = isMobile ? H5 : H4;\n  const borderRadius = \"m\";\n\n  return (\n    <CustomContainer\n      hasShadow={hasShadow}\n      isActive={isActive}\n      elevation={0}\n      overflow=\"hidden\"\n      borderRadius={borderRadius}\n    >\n      <StyledButton\n        ref={ref}\n        disabled={disabled}\n        aria-pressed={isPressed ?? undefined}\n        {...rest}\n      >\n        {showImage && (\n          <ImageWrapper borderRadius={borderRadius}>\n            <StyledImage {...imageProps} fit=\"contain\" />\n          </ImageWrapper>\n        )}\n        {iconProps && showIcons && (\n          <FadingIconLayer isVisible={!isActive}>\n            <Icon size=\"m\" {...iconProps} color={mainTextColor} />\n          </FadingIconLayer>\n        )}\n        {showIcons && (\n          <FadingIconLayer isVisible={isActive}>\n            <Icon size=\"m\" name=\"arrow-right\" color={activeColor} />\n          </FadingIconLayer>\n        )}\n        <StyledBox space={[\"m\", \"l\"]} lSpace={isSmallMobile ? \"m\" : \"l\"}>\n          <Stack space=\"xxs\">\n            {variant === \"bold\" ? (\n              <>\n                <LabelWrapper isActive={isActive}>\n                  <H6 as=\"div\" color={labelColor}>\n                    {title}\n                  </H6>\n                </LabelWrapper>\n                {description && (\n                  <DescriptionHeading as=\"div\" color={mainTextColor}>\n                    {description}\n                  </DescriptionHeading>\n                )}\n              </>\n            ) : (\n              <>\n                <H4 as=\"div\" color={mainTextColor}>\n                  {title}\n                </H4>\n                {description && (\n                  <Text size={isMobile ? \"s\" : \"m\"} color={descriptionColor}>\n                    {description}\n                  </Text>\n                )}\n              </>\n            )}\n          </Stack>\n        </StyledBox>\n      </StyledButton>\n    </CustomContainer>\n  );\n}\n"],"names":[],"mappings":"AAqCwB"} */"),StyledButton=(0,_styled.default)("button",{target:"ekger5h1",label:"StyledButton"})(({theme,disabled})=>({...(0,_mixins.getButtonAppearanceReset)(),...(0,_mixins.getBaseButtonStyles)({theme}),...(0,_mixins.getFocusStyles)(),...disabled&&{...(0,_mixins.getDisabledStyles)({theme}),cursor:"not-allowed"},position:"relative",width:"100%",height:"100%",display:"flex",flexDirection:"row",textAlign:"left",alignItems:"center",padding:0,[`@media (min-width: ${_breakpointsjson.default.m.value}px)`]:{flexDirection:"column",alignItems:"start"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/SplashCardMedia/SplashCardMedia.tsx","sources":["src/components/SplashCardMedia/SplashCardMedia.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport type { BorderRadius } from \"src/types\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport { useHover } from \"../../shared/useHover\";\nimport { H4, H5, H6 } from \"../Typography/Header/Header\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Container } from \"../Container/Container\";\nimport { useFocusWithin } from \"../../shared/useFocusWithin\";\nimport { Icon, type IconProps } from \"../Icon/Icon\";\nimport { Image, type ImageProps } from \"../Image/Image\";\nimport { StyledBox } from \"../Box/Box\";\nimport {\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getFocusStyles,\n  getDisabledStyles,\n} from \"../../shared/mixins\";\nimport { type CardButtonProps } from \"../Internal/InteractiveCard/InteractiveCard\";\nimport { useBreakpoints } from \"../../shared/useBreakpoints\";\n\nexport type SplashCardMediaProps = {\n  title: string;\n  description?: string;\n  variant?: \"standard\" | \"bold\";\n  isPressed?: boolean;\n  hasShadow?: boolean;\n  imageProps: Pick<\n    ImageProps,\n    \"src\" | \"alt\" | \"placeholderSrc\" | \"fallbackSrc\" | \"sources\"\n  >;\n  iconProps?: IconProps;\n} & CardButtonProps;\n\nconst CustomContainer = styled(Container, {\n  shouldForwardProp: (prop) =>\n    isPropValid(prop) && prop !== \"isActive\" && prop !== \"hasShadow\",\n})<{ isActive: boolean; hasShadow?: boolean }>(\n  ({ theme, isActive, hasShadow }) => ({\n    ...(hasShadow && {\n      // TODO: Replace with theme token\n      borderBottom: `4px solid rgba(138, 97, 241, 0.20)`,\n    }),\n    backgroundColor: isActive\n      ? theme.values.color.background.accent.default\n      : theme.values.color.background.accentSubtle.default,\n    transitionProperty: \"background-color\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n    width: \"100%\",\n    height: \"100%\",\n  })\n);\n\nconst StyledButton = styled.button<{ disabled?: boolean }>(\n  ({ theme, disabled }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme }),\n    ...getFocusStyles(),\n    ...(disabled && {\n      ...getDisabledStyles({ theme }),\n      cursor: \"not-allowed\",\n    }),\n    position: \"relative\",\n    width: \"100%\",\n    height: \"100%\",\n    display: \"flex\",\n    flexDirection: \"row\",\n    textAlign: \"left\",\n    alignItems: \"center\",\n    padding: 0,\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      flexDirection: \"column\",\n      alignItems: \"start\",\n    },\n  })\n);\n\nconst ImageWrapper = styled.div<{ borderRadius: BorderRadius }>(\n  ({ theme, borderRadius }) => ({\n    width: 179,\n    flexShrink: 0,\n    overflow: \"hidden\",\n    borderBottomLeftRadius: theme.variables.size.borderRadius[borderRadius],\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      width: `calc(100% - 40px)`,\n    },\n  })\n);\n\nconst StyledImage = styled(Image)({\n  width: \"100%\",\n  height: \"100%\",\n  display: \"block\",\n});\n\n// Each icon layer fades in/out independently for the cross-fade effect.\nconst FadingIconLayer = styled.div<{ isVisible: boolean }>(\n  ({ theme, isVisible }) => ({\n    position: \"absolute\",\n    top: theme.variables.size.spacing.l,\n    right: theme.variables.size.spacing.l,\n    opacity: isVisible ? 1 : 0,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nconst LabelWrapper = styled.div<{ isActive: boolean }>(\n  ({ theme, isActive }) => ({\n    opacity: isActive ? 0.6 : 1,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nexport function SplashCardMedia({\n  isPressed,\n  disabled,\n  title,\n  description,\n  variant = \"standard\",\n  iconProps,\n  imageProps,\n  hasShadow,\n  ...rest\n}: SplashCardMediaProps): React.ReactElement {\n  const ref = useRef<HTMLButtonElement>(null);\n  const isHovered = useHover(ref);\n  const isFocused = useFocusWithin(ref);\n  const isActive = !disabled && (isHovered || isFocused || isPressed);\n\n  const activeColor = \"onAccent\" as const;\n  const mainTextColor = isActive ? activeColor : \"accent\";\n  const descriptionColor = isActive ? activeColor : \"secondary\";\n  const labelColor = isActive ? activeColor : \"tertiary\";\n\n  const { isMobile, isSmallMobile } = useBreakpoints();\n  const showImage = !isSmallMobile;\n  const showIcons = !isMobile;\n\n  const DescriptionHeading = isMobile ? H5 : H4;\n  const borderRadius = \"m\";\n\n  return (\n    <CustomContainer\n      hasShadow={hasShadow}\n      isActive={isActive}\n      elevation={0}\n      overflow=\"hidden\"\n      borderRadius={borderRadius}\n    >\n      <StyledButton\n        ref={ref}\n        disabled={disabled}\n        aria-pressed={isPressed ?? undefined}\n        {...rest}\n      >\n        {showImage && (\n          <ImageWrapper borderRadius={borderRadius}>\n            <StyledImage {...imageProps} fit=\"contain\" />\n          </ImageWrapper>\n        )}\n        {iconProps && showIcons && (\n          <FadingIconLayer isVisible={!isActive}>\n            <Icon size=\"m\" {...iconProps} color={mainTextColor} />\n          </FadingIconLayer>\n        )}\n        {showIcons && (\n          <FadingIconLayer isVisible={isActive}>\n            <Icon size=\"m\" name=\"arrow-right\" color={activeColor} />\n          </FadingIconLayer>\n        )}\n        <StyledBox space={[\"m\", \"l\"]} lSpace={isSmallMobile ? \"m\" : \"l\"}>\n          <Stack space=\"xxs\">\n            {variant === \"bold\" ? (\n              <>\n                <LabelWrapper isActive={isActive}>\n                  <H6 as=\"div\" color={labelColor}>\n                    {title}\n                  </H6>\n                </LabelWrapper>\n                {description && (\n                  <DescriptionHeading as=\"div\" color={mainTextColor}>\n                    {description}\n                  </DescriptionHeading>\n                )}\n              </>\n            ) : (\n              <>\n                <H4 as=\"div\" color={mainTextColor}>\n                  {title}\n                </H4>\n                {description && (\n                  <Text size={isMobile ? \"s\" : \"m\"} color={descriptionColor}>\n                    {description}\n                  </Text>\n                )}\n              </>\n            )}\n          </Stack>\n        </StyledBox>\n      </StyledButton>\n    </CustomContainer>\n  );\n}\n"],"names":[],"mappings":"AAyDqB"} */"),ImageWrapper=(0,_styled.default)("div",{target:"ekger5h2",label:"ImageWrapper"})(({theme,borderRadius})=>({width:179,flexShrink:0,overflow:"hidden",borderBottomLeftRadius:theme.variables.size.borderRadius[borderRadius],[`@media (min-width: ${_breakpointsjson.default.m.value}px)`]:{width:"calc(100% - 40px)"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/SplashCardMedia/SplashCardMedia.tsx","sources":["src/components/SplashCardMedia/SplashCardMedia.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport type { BorderRadius } from \"src/types\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport { useHover } from \"../../shared/useHover\";\nimport { H4, H5, H6 } from \"../Typography/Header/Header\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Container } from \"../Container/Container\";\nimport { useFocusWithin } from \"../../shared/useFocusWithin\";\nimport { Icon, type IconProps } from \"../Icon/Icon\";\nimport { Image, type ImageProps } from \"../Image/Image\";\nimport { StyledBox } from \"../Box/Box\";\nimport {\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getFocusStyles,\n  getDisabledStyles,\n} from \"../../shared/mixins\";\nimport { type CardButtonProps } from \"../Internal/InteractiveCard/InteractiveCard\";\nimport { useBreakpoints } from \"../../shared/useBreakpoints\";\n\nexport type SplashCardMediaProps = {\n  title: string;\n  description?: string;\n  variant?: \"standard\" | \"bold\";\n  isPressed?: boolean;\n  hasShadow?: boolean;\n  imageProps: Pick<\n    ImageProps,\n    \"src\" | \"alt\" | \"placeholderSrc\" | \"fallbackSrc\" | \"sources\"\n  >;\n  iconProps?: IconProps;\n} & CardButtonProps;\n\nconst CustomContainer = styled(Container, {\n  shouldForwardProp: (prop) =>\n    isPropValid(prop) && prop !== \"isActive\" && prop !== \"hasShadow\",\n})<{ isActive: boolean; hasShadow?: boolean }>(\n  ({ theme, isActive, hasShadow }) => ({\n    ...(hasShadow && {\n      // TODO: Replace with theme token\n      borderBottom: `4px solid rgba(138, 97, 241, 0.20)`,\n    }),\n    backgroundColor: isActive\n      ? theme.values.color.background.accent.default\n      : theme.values.color.background.accentSubtle.default,\n    transitionProperty: \"background-color\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n    width: \"100%\",\n    height: \"100%\",\n  })\n);\n\nconst StyledButton = styled.button<{ disabled?: boolean }>(\n  ({ theme, disabled }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme }),\n    ...getFocusStyles(),\n    ...(disabled && {\n      ...getDisabledStyles({ theme }),\n      cursor: \"not-allowed\",\n    }),\n    position: \"relative\",\n    width: \"100%\",\n    height: \"100%\",\n    display: \"flex\",\n    flexDirection: \"row\",\n    textAlign: \"left\",\n    alignItems: \"center\",\n    padding: 0,\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      flexDirection: \"column\",\n      alignItems: \"start\",\n    },\n  })\n);\n\nconst ImageWrapper = styled.div<{ borderRadius: BorderRadius }>(\n  ({ theme, borderRadius }) => ({\n    width: 179,\n    flexShrink: 0,\n    overflow: \"hidden\",\n    borderBottomLeftRadius: theme.variables.size.borderRadius[borderRadius],\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      width: `calc(100% - 40px)`,\n    },\n  })\n);\n\nconst StyledImage = styled(Image)({\n  width: \"100%\",\n  height: \"100%\",\n  display: \"block\",\n});\n\n// Each icon layer fades in/out independently for the cross-fade effect.\nconst FadingIconLayer = styled.div<{ isVisible: boolean }>(\n  ({ theme, isVisible }) => ({\n    position: \"absolute\",\n    top: theme.variables.size.spacing.l,\n    right: theme.variables.size.spacing.l,\n    opacity: isVisible ? 1 : 0,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nconst LabelWrapper = styled.div<{ isActive: boolean }>(\n  ({ theme, isActive }) => ({\n    opacity: isActive ? 0.6 : 1,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nexport function SplashCardMedia({\n  isPressed,\n  disabled,\n  title,\n  description,\n  variant = \"standard\",\n  iconProps,\n  imageProps,\n  hasShadow,\n  ...rest\n}: SplashCardMediaProps): React.ReactElement {\n  const ref = useRef<HTMLButtonElement>(null);\n  const isHovered = useHover(ref);\n  const isFocused = useFocusWithin(ref);\n  const isActive = !disabled && (isHovered || isFocused || isPressed);\n\n  const activeColor = \"onAccent\" as const;\n  const mainTextColor = isActive ? activeColor : \"accent\";\n  const descriptionColor = isActive ? activeColor : \"secondary\";\n  const labelColor = isActive ? activeColor : \"tertiary\";\n\n  const { isMobile, isSmallMobile } = useBreakpoints();\n  const showImage = !isSmallMobile;\n  const showIcons = !isMobile;\n\n  const DescriptionHeading = isMobile ? H5 : H4;\n  const borderRadius = \"m\";\n\n  return (\n    <CustomContainer\n      hasShadow={hasShadow}\n      isActive={isActive}\n      elevation={0}\n      overflow=\"hidden\"\n      borderRadius={borderRadius}\n    >\n      <StyledButton\n        ref={ref}\n        disabled={disabled}\n        aria-pressed={isPressed ?? undefined}\n        {...rest}\n      >\n        {showImage && (\n          <ImageWrapper borderRadius={borderRadius}>\n            <StyledImage {...imageProps} fit=\"contain\" />\n          </ImageWrapper>\n        )}\n        {iconProps && showIcons && (\n          <FadingIconLayer isVisible={!isActive}>\n            <Icon size=\"m\" {...iconProps} color={mainTextColor} />\n          </FadingIconLayer>\n        )}\n        {showIcons && (\n          <FadingIconLayer isVisible={isActive}>\n            <Icon size=\"m\" name=\"arrow-right\" color={activeColor} />\n          </FadingIconLayer>\n        )}\n        <StyledBox space={[\"m\", \"l\"]} lSpace={isSmallMobile ? \"m\" : \"l\"}>\n          <Stack space=\"xxs\">\n            {variant === \"bold\" ? (\n              <>\n                <LabelWrapper isActive={isActive}>\n                  <H6 as=\"div\" color={labelColor}>\n                    {title}\n                  </H6>\n                </LabelWrapper>\n                {description && (\n                  <DescriptionHeading as=\"div\" color={mainTextColor}>\n                    {description}\n                  </DescriptionHeading>\n                )}\n              </>\n            ) : (\n              <>\n                <H4 as=\"div\" color={mainTextColor}>\n                  {title}\n                </H4>\n                {description && (\n                  <Text size={isMobile ? \"s\" : \"m\"} color={descriptionColor}>\n                    {description}\n                  </Text>\n                )}\n              </>\n            )}\n          </Stack>\n        </StyledBox>\n      </StyledButton>\n    </CustomContainer>\n  );\n}\n"],"names":[],"mappings":"AAiFqB"} */"),StyledImage=(0,_styled.default)(_Image.Image,{target:"ekger5h3",label:"StyledImage"})({width:"100%",height:"100%",display:"block"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/SplashCardMedia/SplashCardMedia.tsx","sources":["src/components/SplashCardMedia/SplashCardMedia.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport type { BorderRadius } from \"src/types\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport { useHover } from \"../../shared/useHover\";\nimport { H4, H5, H6 } from \"../Typography/Header/Header\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Container } from \"../Container/Container\";\nimport { useFocusWithin } from \"../../shared/useFocusWithin\";\nimport { Icon, type IconProps } from \"../Icon/Icon\";\nimport { Image, type ImageProps } from \"../Image/Image\";\nimport { StyledBox } from \"../Box/Box\";\nimport {\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getFocusStyles,\n  getDisabledStyles,\n} from \"../../shared/mixins\";\nimport { type CardButtonProps } from \"../Internal/InteractiveCard/InteractiveCard\";\nimport { useBreakpoints } from \"../../shared/useBreakpoints\";\n\nexport type SplashCardMediaProps = {\n  title: string;\n  description?: string;\n  variant?: \"standard\" | \"bold\";\n  isPressed?: boolean;\n  hasShadow?: boolean;\n  imageProps: Pick<\n    ImageProps,\n    \"src\" | \"alt\" | \"placeholderSrc\" | \"fallbackSrc\" | \"sources\"\n  >;\n  iconProps?: IconProps;\n} & CardButtonProps;\n\nconst CustomContainer = styled(Container, {\n  shouldForwardProp: (prop) =>\n    isPropValid(prop) && prop !== \"isActive\" && prop !== \"hasShadow\",\n})<{ isActive: boolean; hasShadow?: boolean }>(\n  ({ theme, isActive, hasShadow }) => ({\n    ...(hasShadow && {\n      // TODO: Replace with theme token\n      borderBottom: `4px solid rgba(138, 97, 241, 0.20)`,\n    }),\n    backgroundColor: isActive\n      ? theme.values.color.background.accent.default\n      : theme.values.color.background.accentSubtle.default,\n    transitionProperty: \"background-color\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n    width: \"100%\",\n    height: \"100%\",\n  })\n);\n\nconst StyledButton = styled.button<{ disabled?: boolean }>(\n  ({ theme, disabled }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme }),\n    ...getFocusStyles(),\n    ...(disabled && {\n      ...getDisabledStyles({ theme }),\n      cursor: \"not-allowed\",\n    }),\n    position: \"relative\",\n    width: \"100%\",\n    height: \"100%\",\n    display: \"flex\",\n    flexDirection: \"row\",\n    textAlign: \"left\",\n    alignItems: \"center\",\n    padding: 0,\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      flexDirection: \"column\",\n      alignItems: \"start\",\n    },\n  })\n);\n\nconst ImageWrapper = styled.div<{ borderRadius: BorderRadius }>(\n  ({ theme, borderRadius }) => ({\n    width: 179,\n    flexShrink: 0,\n    overflow: \"hidden\",\n    borderBottomLeftRadius: theme.variables.size.borderRadius[borderRadius],\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      width: `calc(100% - 40px)`,\n    },\n  })\n);\n\nconst StyledImage = styled(Image)({\n  width: \"100%\",\n  height: \"100%\",\n  display: \"block\",\n});\n\n// Each icon layer fades in/out independently for the cross-fade effect.\nconst FadingIconLayer = styled.div<{ isVisible: boolean }>(\n  ({ theme, isVisible }) => ({\n    position: \"absolute\",\n    top: theme.variables.size.spacing.l,\n    right: theme.variables.size.spacing.l,\n    opacity: isVisible ? 1 : 0,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nconst LabelWrapper = styled.div<{ isActive: boolean }>(\n  ({ theme, isActive }) => ({\n    opacity: isActive ? 0.6 : 1,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nexport function SplashCardMedia({\n  isPressed,\n  disabled,\n  title,\n  description,\n  variant = \"standard\",\n  iconProps,\n  imageProps,\n  hasShadow,\n  ...rest\n}: SplashCardMediaProps): React.ReactElement {\n  const ref = useRef<HTMLButtonElement>(null);\n  const isHovered = useHover(ref);\n  const isFocused = useFocusWithin(ref);\n  const isActive = !disabled && (isHovered || isFocused || isPressed);\n\n  const activeColor = \"onAccent\" as const;\n  const mainTextColor = isActive ? activeColor : \"accent\";\n  const descriptionColor = isActive ? activeColor : \"secondary\";\n  const labelColor = isActive ? activeColor : \"tertiary\";\n\n  const { isMobile, isSmallMobile } = useBreakpoints();\n  const showImage = !isSmallMobile;\n  const showIcons = !isMobile;\n\n  const DescriptionHeading = isMobile ? H5 : H4;\n  const borderRadius = \"m\";\n\n  return (\n    <CustomContainer\n      hasShadow={hasShadow}\n      isActive={isActive}\n      elevation={0}\n      overflow=\"hidden\"\n      borderRadius={borderRadius}\n    >\n      <StyledButton\n        ref={ref}\n        disabled={disabled}\n        aria-pressed={isPressed ?? undefined}\n        {...rest}\n      >\n        {showImage && (\n          <ImageWrapper borderRadius={borderRadius}>\n            <StyledImage {...imageProps} fit=\"contain\" />\n          </ImageWrapper>\n        )}\n        {iconProps && showIcons && (\n          <FadingIconLayer isVisible={!isActive}>\n            <Icon size=\"m\" {...iconProps} color={mainTextColor} />\n          </FadingIconLayer>\n        )}\n        {showIcons && (\n          <FadingIconLayer isVisible={isActive}>\n            <Icon size=\"m\" name=\"arrow-right\" color={activeColor} />\n          </FadingIconLayer>\n        )}\n        <StyledBox space={[\"m\", \"l\"]} lSpace={isSmallMobile ? \"m\" : \"l\"}>\n          <Stack space=\"xxs\">\n            {variant === \"bold\" ? (\n              <>\n                <LabelWrapper isActive={isActive}>\n                  <H6 as=\"div\" color={labelColor}>\n                    {title}\n                  </H6>\n                </LabelWrapper>\n                {description && (\n                  <DescriptionHeading as=\"div\" color={mainTextColor}>\n                    {description}\n                  </DescriptionHeading>\n                )}\n              </>\n            ) : (\n              <>\n                <H4 as=\"div\" color={mainTextColor}>\n                  {title}\n                </H4>\n                {description && (\n                  <Text size={isMobile ? \"s\" : \"m\"} color={descriptionColor}>\n                    {description}\n                  </Text>\n                )}\n              </>\n            )}\n          </Stack>\n        </StyledBox>\n      </StyledButton>\n    </CustomContainer>\n  );\n}\n"],"names":[],"mappings":"AA6FoB"} */"),FadingIconLayer=(0,_styled.default)("div",{target:"ekger5h4",label:"FadingIconLayer"})(({theme,isVisible})=>({position:"absolute",top:theme.variables.size.spacing.l,right:theme.variables.size.spacing.l,opacity:+!!isVisible,transitionProperty:"opacity",transitionDuration:theme.variables.animation.duration.medium,transitionTimingFunction:theme.variables.animation.timingFunction}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/SplashCardMedia/SplashCardMedia.tsx","sources":["src/components/SplashCardMedia/SplashCardMedia.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport type { BorderRadius } from \"src/types\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport { useHover } from \"../../shared/useHover\";\nimport { H4, H5, H6 } from \"../Typography/Header/Header\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Container } from \"../Container/Container\";\nimport { useFocusWithin } from \"../../shared/useFocusWithin\";\nimport { Icon, type IconProps } from \"../Icon/Icon\";\nimport { Image, type ImageProps } from \"../Image/Image\";\nimport { StyledBox } from \"../Box/Box\";\nimport {\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getFocusStyles,\n  getDisabledStyles,\n} from \"../../shared/mixins\";\nimport { type CardButtonProps } from \"../Internal/InteractiveCard/InteractiveCard\";\nimport { useBreakpoints } from \"../../shared/useBreakpoints\";\n\nexport type SplashCardMediaProps = {\n  title: string;\n  description?: string;\n  variant?: \"standard\" | \"bold\";\n  isPressed?: boolean;\n  hasShadow?: boolean;\n  imageProps: Pick<\n    ImageProps,\n    \"src\" | \"alt\" | \"placeholderSrc\" | \"fallbackSrc\" | \"sources\"\n  >;\n  iconProps?: IconProps;\n} & CardButtonProps;\n\nconst CustomContainer = styled(Container, {\n  shouldForwardProp: (prop) =>\n    isPropValid(prop) && prop !== \"isActive\" && prop !== \"hasShadow\",\n})<{ isActive: boolean; hasShadow?: boolean }>(\n  ({ theme, isActive, hasShadow }) => ({\n    ...(hasShadow && {\n      // TODO: Replace with theme token\n      borderBottom: `4px solid rgba(138, 97, 241, 0.20)`,\n    }),\n    backgroundColor: isActive\n      ? theme.values.color.background.accent.default\n      : theme.values.color.background.accentSubtle.default,\n    transitionProperty: \"background-color\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n    width: \"100%\",\n    height: \"100%\",\n  })\n);\n\nconst StyledButton = styled.button<{ disabled?: boolean }>(\n  ({ theme, disabled }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme }),\n    ...getFocusStyles(),\n    ...(disabled && {\n      ...getDisabledStyles({ theme }),\n      cursor: \"not-allowed\",\n    }),\n    position: \"relative\",\n    width: \"100%\",\n    height: \"100%\",\n    display: \"flex\",\n    flexDirection: \"row\",\n    textAlign: \"left\",\n    alignItems: \"center\",\n    padding: 0,\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      flexDirection: \"column\",\n      alignItems: \"start\",\n    },\n  })\n);\n\nconst ImageWrapper = styled.div<{ borderRadius: BorderRadius }>(\n  ({ theme, borderRadius }) => ({\n    width: 179,\n    flexShrink: 0,\n    overflow: \"hidden\",\n    borderBottomLeftRadius: theme.variables.size.borderRadius[borderRadius],\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      width: `calc(100% - 40px)`,\n    },\n  })\n);\n\nconst StyledImage = styled(Image)({\n  width: \"100%\",\n  height: \"100%\",\n  display: \"block\",\n});\n\n// Each icon layer fades in/out independently for the cross-fade effect.\nconst FadingIconLayer = styled.div<{ isVisible: boolean }>(\n  ({ theme, isVisible }) => ({\n    position: \"absolute\",\n    top: theme.variables.size.spacing.l,\n    right: theme.variables.size.spacing.l,\n    opacity: isVisible ? 1 : 0,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nconst LabelWrapper = styled.div<{ isActive: boolean }>(\n  ({ theme, isActive }) => ({\n    opacity: isActive ? 0.6 : 1,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nexport function SplashCardMedia({\n  isPressed,\n  disabled,\n  title,\n  description,\n  variant = \"standard\",\n  iconProps,\n  imageProps,\n  hasShadow,\n  ...rest\n}: SplashCardMediaProps): React.ReactElement {\n  const ref = useRef<HTMLButtonElement>(null);\n  const isHovered = useHover(ref);\n  const isFocused = useFocusWithin(ref);\n  const isActive = !disabled && (isHovered || isFocused || isPressed);\n\n  const activeColor = \"onAccent\" as const;\n  const mainTextColor = isActive ? activeColor : \"accent\";\n  const descriptionColor = isActive ? activeColor : \"secondary\";\n  const labelColor = isActive ? activeColor : \"tertiary\";\n\n  const { isMobile, isSmallMobile } = useBreakpoints();\n  const showImage = !isSmallMobile;\n  const showIcons = !isMobile;\n\n  const DescriptionHeading = isMobile ? H5 : H4;\n  const borderRadius = \"m\";\n\n  return (\n    <CustomContainer\n      hasShadow={hasShadow}\n      isActive={isActive}\n      elevation={0}\n      overflow=\"hidden\"\n      borderRadius={borderRadius}\n    >\n      <StyledButton\n        ref={ref}\n        disabled={disabled}\n        aria-pressed={isPressed ?? undefined}\n        {...rest}\n      >\n        {showImage && (\n          <ImageWrapper borderRadius={borderRadius}>\n            <StyledImage {...imageProps} fit=\"contain\" />\n          </ImageWrapper>\n        )}\n        {iconProps && showIcons && (\n          <FadingIconLayer isVisible={!isActive}>\n            <Icon size=\"m\" {...iconProps} color={mainTextColor} />\n          </FadingIconLayer>\n        )}\n        {showIcons && (\n          <FadingIconLayer isVisible={isActive}>\n            <Icon size=\"m\" name=\"arrow-right\" color={activeColor} />\n          </FadingIconLayer>\n        )}\n        <StyledBox space={[\"m\", \"l\"]} lSpace={isSmallMobile ? \"m\" : \"l\"}>\n          <Stack space=\"xxs\">\n            {variant === \"bold\" ? (\n              <>\n                <LabelWrapper isActive={isActive}>\n                  <H6 as=\"div\" color={labelColor}>\n                    {title}\n                  </H6>\n                </LabelWrapper>\n                {description && (\n                  <DescriptionHeading as=\"div\" color={mainTextColor}>\n                    {description}\n                  </DescriptionHeading>\n                )}\n              </>\n            ) : (\n              <>\n                <H4 as=\"div\" color={mainTextColor}>\n                  {title}\n                </H4>\n                {description && (\n                  <Text size={isMobile ? \"s\" : \"m\"} color={descriptionColor}>\n                    {description}\n                  </Text>\n                )}\n              </>\n            )}\n          </Stack>\n        </StyledBox>\n      </StyledButton>\n    </CustomContainer>\n  );\n}\n"],"names":[],"mappings":"AAoGwB"} */"),LabelWrapper=(0,_styled.default)("div",{target:"ekger5h5",label:"LabelWrapper"})(({theme,isActive})=>({opacity:isActive?.6:1,transitionProperty:"opacity",transitionDuration:theme.variables.animation.duration.medium,transitionTimingFunction:theme.variables.animation.timingFunction}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/SplashCardMedia/SplashCardMedia.tsx","sources":["src/components/SplashCardMedia/SplashCardMedia.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport type { BorderRadius } from \"src/types\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport { useHover } from \"../../shared/useHover\";\nimport { H4, H5, H6 } from \"../Typography/Header/Header\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Container } from \"../Container/Container\";\nimport { useFocusWithin } from \"../../shared/useFocusWithin\";\nimport { Icon, type IconProps } from \"../Icon/Icon\";\nimport { Image, type ImageProps } from \"../Image/Image\";\nimport { StyledBox } from \"../Box/Box\";\nimport {\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getFocusStyles,\n  getDisabledStyles,\n} from \"../../shared/mixins\";\nimport { type CardButtonProps } from \"../Internal/InteractiveCard/InteractiveCard\";\nimport { useBreakpoints } from \"../../shared/useBreakpoints\";\n\nexport type SplashCardMediaProps = {\n  title: string;\n  description?: string;\n  variant?: \"standard\" | \"bold\";\n  isPressed?: boolean;\n  hasShadow?: boolean;\n  imageProps: Pick<\n    ImageProps,\n    \"src\" | \"alt\" | \"placeholderSrc\" | \"fallbackSrc\" | \"sources\"\n  >;\n  iconProps?: IconProps;\n} & CardButtonProps;\n\nconst CustomContainer = styled(Container, {\n  shouldForwardProp: (prop) =>\n    isPropValid(prop) && prop !== \"isActive\" && prop !== \"hasShadow\",\n})<{ isActive: boolean; hasShadow?: boolean }>(\n  ({ theme, isActive, hasShadow }) => ({\n    ...(hasShadow && {\n      // TODO: Replace with theme token\n      borderBottom: `4px solid rgba(138, 97, 241, 0.20)`,\n    }),\n    backgroundColor: isActive\n      ? theme.values.color.background.accent.default\n      : theme.values.color.background.accentSubtle.default,\n    transitionProperty: \"background-color\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n    width: \"100%\",\n    height: \"100%\",\n  })\n);\n\nconst StyledButton = styled.button<{ disabled?: boolean }>(\n  ({ theme, disabled }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme }),\n    ...getFocusStyles(),\n    ...(disabled && {\n      ...getDisabledStyles({ theme }),\n      cursor: \"not-allowed\",\n    }),\n    position: \"relative\",\n    width: \"100%\",\n    height: \"100%\",\n    display: \"flex\",\n    flexDirection: \"row\",\n    textAlign: \"left\",\n    alignItems: \"center\",\n    padding: 0,\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      flexDirection: \"column\",\n      alignItems: \"start\",\n    },\n  })\n);\n\nconst ImageWrapper = styled.div<{ borderRadius: BorderRadius }>(\n  ({ theme, borderRadius }) => ({\n    width: 179,\n    flexShrink: 0,\n    overflow: \"hidden\",\n    borderBottomLeftRadius: theme.variables.size.borderRadius[borderRadius],\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      width: `calc(100% - 40px)`,\n    },\n  })\n);\n\nconst StyledImage = styled(Image)({\n  width: \"100%\",\n  height: \"100%\",\n  display: \"block\",\n});\n\n// Each icon layer fades in/out independently for the cross-fade effect.\nconst FadingIconLayer = styled.div<{ isVisible: boolean }>(\n  ({ theme, isVisible }) => ({\n    position: \"absolute\",\n    top: theme.variables.size.spacing.l,\n    right: theme.variables.size.spacing.l,\n    opacity: isVisible ? 1 : 0,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nconst LabelWrapper = styled.div<{ isActive: boolean }>(\n  ({ theme, isActive }) => ({\n    opacity: isActive ? 0.6 : 1,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nexport function SplashCardMedia({\n  isPressed,\n  disabled,\n  title,\n  description,\n  variant = \"standard\",\n  iconProps,\n  imageProps,\n  hasShadow,\n  ...rest\n}: SplashCardMediaProps): React.ReactElement {\n  const ref = useRef<HTMLButtonElement>(null);\n  const isHovered = useHover(ref);\n  const isFocused = useFocusWithin(ref);\n  const isActive = !disabled && (isHovered || isFocused || isPressed);\n\n  const activeColor = \"onAccent\" as const;\n  const mainTextColor = isActive ? activeColor : \"accent\";\n  const descriptionColor = isActive ? activeColor : \"secondary\";\n  const labelColor = isActive ? activeColor : \"tertiary\";\n\n  const { isMobile, isSmallMobile } = useBreakpoints();\n  const showImage = !isSmallMobile;\n  const showIcons = !isMobile;\n\n  const DescriptionHeading = isMobile ? H5 : H4;\n  const borderRadius = \"m\";\n\n  return (\n    <CustomContainer\n      hasShadow={hasShadow}\n      isActive={isActive}\n      elevation={0}\n      overflow=\"hidden\"\n      borderRadius={borderRadius}\n    >\n      <StyledButton\n        ref={ref}\n        disabled={disabled}\n        aria-pressed={isPressed ?? undefined}\n        {...rest}\n      >\n        {showImage && (\n          <ImageWrapper borderRadius={borderRadius}>\n            <StyledImage {...imageProps} fit=\"contain\" />\n          </ImageWrapper>\n        )}\n        {iconProps && showIcons && (\n          <FadingIconLayer isVisible={!isActive}>\n            <Icon size=\"m\" {...iconProps} color={mainTextColor} />\n          </FadingIconLayer>\n        )}\n        {showIcons && (\n          <FadingIconLayer isVisible={isActive}>\n            <Icon size=\"m\" name=\"arrow-right\" color={activeColor} />\n          </FadingIconLayer>\n        )}\n        <StyledBox space={[\"m\", \"l\"]} lSpace={isSmallMobile ? \"m\" : \"l\"}>\n          <Stack space=\"xxs\">\n            {variant === \"bold\" ? (\n              <>\n                <LabelWrapper isActive={isActive}>\n                  <H6 as=\"div\" color={labelColor}>\n                    {title}\n                  </H6>\n                </LabelWrapper>\n                {description && (\n                  <DescriptionHeading as=\"div\" color={mainTextColor}>\n                    {description}\n                  </DescriptionHeading>\n                )}\n              </>\n            ) : (\n              <>\n                <H4 as=\"div\" color={mainTextColor}>\n                  {title}\n                </H4>\n                {description && (\n                  <Text size={isMobile ? \"s\" : \"m\"} color={descriptionColor}>\n                    {description}\n                  </Text>\n                )}\n              </>\n            )}\n          </Stack>\n        </StyledBox>\n      </StyledButton>\n    </CustomContainer>\n  );\n}\n"],"names":[],"mappings":"AAgHqB"} */");function SplashCardMedia({isPressed,disabled,title,description,variant="standard",iconProps,imageProps,hasShadow,...rest}){let ref=(0,_react.useRef)(null),isHovered=(0,_useHover.useHover)(ref),isFocused=(0,_useFocusWithin.useFocusWithin)(ref),isActive=!disabled&&(isHovered||isFocused||isPressed),activeColor="onAccent",mainTextColor=isActive?activeColor:"accent",descriptionColor=isActive?activeColor:"secondary",labelColor=isActive?activeColor:"tertiary",{isMobile,isSmallMobile}=(0,_useBreakpoints.useBreakpoints)(),showIcons=!isMobile,DescriptionHeading=isMobile?_Header.H5:_Header.H4;return _react.default.createElement(CustomContainer,{hasShadow:hasShadow,isActive:isActive,elevation:0,overflow:"hidden",borderRadius:"m"},_react.default.createElement(StyledButton,{ref:ref,disabled:disabled,"aria-pressed":isPressed??void 0,...rest},!isSmallMobile&&_react.default.createElement(ImageWrapper,{borderRadius:"m"},_react.default.createElement(StyledImage,{...imageProps,fit:"contain"})),iconProps&&showIcons&&_react.default.createElement(FadingIconLayer,{isVisible:!isActive},_react.default.createElement(_Icon.Icon,{size:"m",...iconProps,color:mainTextColor})),showIcons&&_react.default.createElement(FadingIconLayer,{isVisible:isActive},_react.default.createElement(_Icon.Icon,{size:"m",name:"arrow-right",color:activeColor})),_react.default.createElement(_Box.StyledBox,{space:["m","l"],lSpace:isSmallMobile?"m":"l"},_react.default.createElement(_Stack.Stack,{space:"xxs"},"bold"===variant?_react.default.createElement(_react.default.Fragment,null,_react.default.createElement(LabelWrapper,{isActive:isActive},_react.default.createElement(_Header.H6,{as:"div",color:labelColor},title)),description&&_react.default.createElement(DescriptionHeading,{as:"div",color:mainTextColor},description)):_react.default.createElement(_react.default.Fragment,null,_react.default.createElement(_Header.H4,{as:"div",color:mainTextColor},title),description&&_react.default.createElement(_Text.Text,{size:isMobile?"s":"m",color:descriptionColor},description))))))}
@@ -68,6 +68,7 @@ export * from "./components/Popover/Popover";
68
68
  export * from "./components/ProgressBar/ProgressBar";
69
69
  export * from "./components/PromptInput/PromptInput";
70
70
  export * from "./components/SplashCard/SplashCard";
71
+ export * from "./components/SplashCardMedia/SplashCardMedia";
71
72
  export * from "./components/QBankRichText/QBankRichText";
72
73
  export * from "./components/RadioCard/RadioCard";
73
74
  export * from "./components/RoundButton/RoundButton";
@@ -97,6 +98,7 @@ export * from "./components/Content/ContentBox/ContentBox";
97
98
  export * from "./components/Content/ContentFontResizer";
98
99
  export * from "./components/Content/ContentHeading/ContentHeading";
99
100
  export * from "./components/Content/ContentLink/ContentLink";
101
+ export * from "./components/Content/ContentPictogramButton/ContentPictogramButton";
100
102
  export * from "./components/Content/ContentText/ContentText";
101
103
  export * from "./components/Content/ContentList";
102
104
  export * from "./components/Content/ContentTable";
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get CacheProvider(){return _react.CacheProvider},get ThemeProvider(){return _react.ThemeProvider},get createCache(){return _cache.default},get dark(){return dark},get light(){return light}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _export_star=require("@swc/helpers/_/_export_star"),_interop_require_default=require("@swc/helpers/_/_interop_require_default"),_visualConfig=require("./web-tokens/visualConfig"),_react=require("@emotion/react"),_cache=/*#__PURE__*/_interop_require_default._(require("@emotion/cache"));_export_star._(require("./components/AccessCardItem/AccessCardItem"),exports),_export_star._(require("./components/Avatar/Avatar"),exports),_export_star._(require("./components/AvatarGroup/AvatarGroup"),exports),_export_star._(require("./components/Badge/Badge"),exports),_export_star._(require("./components/BinaryFeedback/BinaryFeedback"),exports),_export_star._(require("./components/Box/Box"),exports),_export_star._(require("./components/BulkActionsToolbar/BulkActionsToolbar"),exports),_export_star._(require("./components/Button/Button"),exports),_export_star._(require("./components/Callout/Callout"),exports),_export_star._(require("./components/Card/Card"),exports),_export_star._(require("./components/Card/CardBox"),exports),_export_star._(require("./components/CatalogCard/CatalogCard"),exports),_export_star._(require("./components/CheckboxCard/CheckboxCard"),exports),_export_star._(require("./components/Collapsible/Collapsible"),exports),_export_star._(require("./components/ColorIndicator/ColorIndicator"),exports),_export_star._(require("./components/ColorPicker/ColorPicker"),exports),_export_star._(require("./components/Column/Columns"),exports),_export_star._(require("./components/Container"),exports),_export_star._(require("./components/CountButton/CountButton"),exports),_export_star._(require("./components/DataTable"),exports),_export_star._(require("./components/Divider/Divider"),exports),_export_star._(require("./components/DropdownMenu/DropdownMenu"),exports),_export_star._(require("./components/EntityList"),exports),_export_star._(require("./components/EntityTree"),exports),_export_star._(require("./components/Composite/FilterDialog/FilterDialog"),exports),_export_star._(require("./components/Form/Checkbox/Checkbox"),exports),_export_star._(require("./components/Form/Combobox/Combobox"),exports),_export_star._(require("./components/Form/DateInput/DateInput"),exports),_export_star._(require("./components/Form/FormFieldGroup/FormFieldGroup"),exports),_export_star._(require("./components/Form/Input"),exports),_export_star._(require("./components/Form/MaskedInput/MaskedInput"),exports),_export_star._(require("./components/Form/PasswordInput"),exports),_export_star._(require("./components/Form/Radio/Radio"),exports),_export_star._(require("./components/Form/RadioButton/RadioButton"),exports),_export_star._(require("./components/Form/RangeInput/RangeInput"),exports),_export_star._(require("./components/Form/SearchInput/SearchInput"),exports),_export_star._(require("./components/Form/SegmentedControl/SegmentedControl"),exports),_export_star._(require("./components/Form/Select"),exports),_export_star._(require("./components/Form/Textarea/Textarea"),exports),_export_star._(require("./components/Form/Toggle/Toggle"),exports),_export_star._(require("./components/Form/ToggleButton/ToggleButton"),exports),_export_star._(require("./components/Grid/Grid"),exports),_export_star._(require("./components/Icon/Icon"),exports),_export_star._(require("./components/IconTile/IconTile"),exports),_export_star._(require("./components/Image/Image"),exports),_export_star._(require("./components/Inline/Inline"),exports),_export_star._(require("./components/InteractiveBox/InteractiveBox"),exports),_export_star._(require("./components/Lightbox/Lightbox"),exports),_export_star._(require("./components/Link/Link"),exports),_export_star._(require("./components/LoadingSpinner/LoadingSpinner"),exports),_export_star._(require("./components/Logo/Logo"),exports),_export_star._(require("./components/MediaItem"),exports),_export_star._(require("./components/MediaViewerBar/MediaViewerBar"),exports),_export_star._(require("./components/MediaViewerCarousel/MediaViewerCarousel"),exports),_export_star._(require("./components/NavBar"),exports),_export_star._(require("./components/Notification/Notification"),exports),_export_star._(require("./components/Pagination/Pagination"),exports),_export_star._(require("./components/Patterns/ButtonGroup/ButtonGroup"),exports),_export_star._(require("./components/Patterns/Modal/Modal"),exports),_export_star._(require("./components/PictogramButton/PictogramButton"),exports),_export_star._(require("./components/Popover/Popover"),exports),_export_star._(require("./components/ProgressBar/ProgressBar"),exports),_export_star._(require("./components/PromptInput/PromptInput"),exports),_export_star._(require("./components/SplashCard/SplashCard"),exports),_export_star._(require("./components/QBankRichText/QBankRichText"),exports),_export_star._(require("./components/RadioCard/RadioCard"),exports),_export_star._(require("./components/RoundButton/RoundButton"),exports),_export_star._(require("./components/SearchResult/SearchResult"),exports),_export_star._(require("./components/SegmentedProgressBar/SegmentedProgressBar"),exports),_export_star._(require("./components/Sheet/Sheet"),exports),_export_star._(require("./components/Stack/Stack"),exports),_export_star._(require("./components/SubThemeProvider/SubThemeProvider"),exports),_export_star._(require("./components/Tabs/Tabs"),exports),_export_star._(require("./components/Tag/Tag"),exports),_export_star._(require("./components/TagGroup/TagGroup"),exports),_export_star._(require("./components/Toast"),exports),_export_star._(require("./components/Toggletip/Toggletip"),exports),_export_star._(require("./components/Tooltip/Tooltip"),exports),_export_star._(require("./components/Tutorialtip/Tutorialtip"),exports),_export_star._(require("./components/Typography/Header"),exports),_export_star._(require("./components/Typography/StyledText/StyledText"),exports),_export_star._(require("./components/Typography/Text"),exports),_export_star._(require("./components/Typography/TextClamped/TextClamped"),exports),_export_star._(require("./components/UserHighlightTooltip/UserHighlightTooltip"),exports),_export_star._(require("./components/Utilities/AnimatedBorder/AnimatedBorder"),exports),_export_star._(require("./components/Utilities/ContainerQuery/ContainerQuery"),exports),_export_star._(require("./components/Utilities/Expandable/Expandable"),exports),_export_star._(require("./components/Utilities/ScreenReaderText/ScreenReaderText"),exports),_export_star._(require("./components/Patterns/EmptyState/EmptyState"),exports),_export_star._(require("./components/Content/ContentBox/ContentBox"),exports),_export_star._(require("./components/Content/ContentFontResizer"),exports),_export_star._(require("./components/Content/ContentHeading/ContentHeading"),exports),_export_star._(require("./components/Content/ContentLink/ContentLink"),exports),_export_star._(require("./components/Content/ContentText/ContentText"),exports),_export_star._(require("./components/Content/ContentList"),exports),_export_star._(require("./components/Content/ContentTable"),exports),_export_star._(require("./components/Content/ReferenceButton"),exports);const{dark,light}=_visualConfig.ambossVisualConfiguration;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get CacheProvider(){return _react.CacheProvider},get ThemeProvider(){return _react.ThemeProvider},get createCache(){return _cache.default},get dark(){return dark},get light(){return light}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _export_star=require("@swc/helpers/_/_export_star"),_interop_require_default=require("@swc/helpers/_/_interop_require_default"),_visualConfig=require("./web-tokens/visualConfig"),_react=require("@emotion/react"),_cache=/*#__PURE__*/_interop_require_default._(require("@emotion/cache"));_export_star._(require("./components/AccessCardItem/AccessCardItem"),exports),_export_star._(require("./components/Avatar/Avatar"),exports),_export_star._(require("./components/AvatarGroup/AvatarGroup"),exports),_export_star._(require("./components/Badge/Badge"),exports),_export_star._(require("./components/BinaryFeedback/BinaryFeedback"),exports),_export_star._(require("./components/Box/Box"),exports),_export_star._(require("./components/BulkActionsToolbar/BulkActionsToolbar"),exports),_export_star._(require("./components/Button/Button"),exports),_export_star._(require("./components/Callout/Callout"),exports),_export_star._(require("./components/Card/Card"),exports),_export_star._(require("./components/Card/CardBox"),exports),_export_star._(require("./components/CatalogCard/CatalogCard"),exports),_export_star._(require("./components/CheckboxCard/CheckboxCard"),exports),_export_star._(require("./components/Collapsible/Collapsible"),exports),_export_star._(require("./components/ColorIndicator/ColorIndicator"),exports),_export_star._(require("./components/ColorPicker/ColorPicker"),exports),_export_star._(require("./components/Column/Columns"),exports),_export_star._(require("./components/Container"),exports),_export_star._(require("./components/CountButton/CountButton"),exports),_export_star._(require("./components/DataTable"),exports),_export_star._(require("./components/Divider/Divider"),exports),_export_star._(require("./components/DropdownMenu/DropdownMenu"),exports),_export_star._(require("./components/EntityList"),exports),_export_star._(require("./components/EntityTree"),exports),_export_star._(require("./components/Composite/FilterDialog/FilterDialog"),exports),_export_star._(require("./components/Form/Checkbox/Checkbox"),exports),_export_star._(require("./components/Form/Combobox/Combobox"),exports),_export_star._(require("./components/Form/DateInput/DateInput"),exports),_export_star._(require("./components/Form/FormFieldGroup/FormFieldGroup"),exports),_export_star._(require("./components/Form/Input"),exports),_export_star._(require("./components/Form/MaskedInput/MaskedInput"),exports),_export_star._(require("./components/Form/PasswordInput"),exports),_export_star._(require("./components/Form/Radio/Radio"),exports),_export_star._(require("./components/Form/RadioButton/RadioButton"),exports),_export_star._(require("./components/Form/RangeInput/RangeInput"),exports),_export_star._(require("./components/Form/SearchInput/SearchInput"),exports),_export_star._(require("./components/Form/SegmentedControl/SegmentedControl"),exports),_export_star._(require("./components/Form/Select"),exports),_export_star._(require("./components/Form/Textarea/Textarea"),exports),_export_star._(require("./components/Form/Toggle/Toggle"),exports),_export_star._(require("./components/Form/ToggleButton/ToggleButton"),exports),_export_star._(require("./components/Grid/Grid"),exports),_export_star._(require("./components/Icon/Icon"),exports),_export_star._(require("./components/IconTile/IconTile"),exports),_export_star._(require("./components/Image/Image"),exports),_export_star._(require("./components/Inline/Inline"),exports),_export_star._(require("./components/InteractiveBox/InteractiveBox"),exports),_export_star._(require("./components/Lightbox/Lightbox"),exports),_export_star._(require("./components/Link/Link"),exports),_export_star._(require("./components/LoadingSpinner/LoadingSpinner"),exports),_export_star._(require("./components/Logo/Logo"),exports),_export_star._(require("./components/MediaItem"),exports),_export_star._(require("./components/MediaViewerBar/MediaViewerBar"),exports),_export_star._(require("./components/MediaViewerCarousel/MediaViewerCarousel"),exports),_export_star._(require("./components/NavBar"),exports),_export_star._(require("./components/Notification/Notification"),exports),_export_star._(require("./components/Pagination/Pagination"),exports),_export_star._(require("./components/Patterns/ButtonGroup/ButtonGroup"),exports),_export_star._(require("./components/Patterns/Modal/Modal"),exports),_export_star._(require("./components/PictogramButton/PictogramButton"),exports),_export_star._(require("./components/Popover/Popover"),exports),_export_star._(require("./components/ProgressBar/ProgressBar"),exports),_export_star._(require("./components/PromptInput/PromptInput"),exports),_export_star._(require("./components/SplashCard/SplashCard"),exports),_export_star._(require("./components/SplashCardMedia/SplashCardMedia"),exports),_export_star._(require("./components/QBankRichText/QBankRichText"),exports),_export_star._(require("./components/RadioCard/RadioCard"),exports),_export_star._(require("./components/RoundButton/RoundButton"),exports),_export_star._(require("./components/SearchResult/SearchResult"),exports),_export_star._(require("./components/SegmentedProgressBar/SegmentedProgressBar"),exports),_export_star._(require("./components/Sheet/Sheet"),exports),_export_star._(require("./components/Stack/Stack"),exports),_export_star._(require("./components/SubThemeProvider/SubThemeProvider"),exports),_export_star._(require("./components/Tabs/Tabs"),exports),_export_star._(require("./components/Tag/Tag"),exports),_export_star._(require("./components/TagGroup/TagGroup"),exports),_export_star._(require("./components/Toast"),exports),_export_star._(require("./components/Toggletip/Toggletip"),exports),_export_star._(require("./components/Tooltip/Tooltip"),exports),_export_star._(require("./components/Tutorialtip/Tutorialtip"),exports),_export_star._(require("./components/Typography/Header"),exports),_export_star._(require("./components/Typography/StyledText/StyledText"),exports),_export_star._(require("./components/Typography/Text"),exports),_export_star._(require("./components/Typography/TextClamped/TextClamped"),exports),_export_star._(require("./components/UserHighlightTooltip/UserHighlightTooltip"),exports),_export_star._(require("./components/Utilities/AnimatedBorder/AnimatedBorder"),exports),_export_star._(require("./components/Utilities/ContainerQuery/ContainerQuery"),exports),_export_star._(require("./components/Utilities/Expandable/Expandable"),exports),_export_star._(require("./components/Utilities/ScreenReaderText/ScreenReaderText"),exports),_export_star._(require("./components/Patterns/EmptyState/EmptyState"),exports),_export_star._(require("./components/Content/ContentBox/ContentBox"),exports),_export_star._(require("./components/Content/ContentFontResizer"),exports),_export_star._(require("./components/Content/ContentHeading/ContentHeading"),exports),_export_star._(require("./components/Content/ContentLink/ContentLink"),exports),_export_star._(require("./components/Content/ContentPictogramButton/ContentPictogramButton"),exports),_export_star._(require("./components/Content/ContentText/ContentText"),exports),_export_star._(require("./components/Content/ContentList"),exports),_export_star._(require("./components/Content/ContentTable"),exports),_export_star._(require("./components/Content/ReferenceButton"),exports);const{dark,light}=_visualConfig.ambossVisualConfiguration;
@@ -0,0 +1,14 @@
1
+ import React from "react";
2
+ import { type IconProps } from "../Icon/Icon";
3
+ import { type ImageProps } from "../Image/Image";
4
+ import { type CardButtonProps } from "../Internal/InteractiveCard/InteractiveCard";
5
+ export type SplashCardMediaProps = {
6
+ title: string;
7
+ description?: string;
8
+ variant?: "standard" | "bold";
9
+ isPressed?: boolean;
10
+ hasShadow?: boolean;
11
+ imageProps: Pick<ImageProps, "src" | "alt" | "placeholderSrc" | "fallbackSrc" | "sources">;
12
+ iconProps?: IconProps;
13
+ } & CardButtonProps;
14
+ export declare function SplashCardMedia({ isPressed, disabled, title, description, variant, iconProps, imageProps, hasShadow, ...rest }: SplashCardMediaProps): React.ReactElement;
@@ -0,0 +1 @@
1
+ import React,{useRef}from"react";import styled from"@emotion/styled";import isPropValid from"@emotion/is-prop-valid";import breakpoints from"../../web-tokens/_breakpoints.json";import{useHover}from"../../shared/useHover";import{H4,H5,H6}from"../Typography/Header/Header";import{Text}from"../Typography/Text/Text";import{Stack}from"../Stack/Stack";import{Container}from"../Container/Container";import{useFocusWithin}from"../../shared/useFocusWithin";import{Icon}from"../Icon/Icon";import{Image}from"../Image/Image";import{StyledBox}from"../Box/Box";import{getButtonAppearanceReset,getBaseButtonStyles,getFocusStyles,getDisabledStyles}from"../../shared/mixins";import{useBreakpoints}from"../../shared/useBreakpoints";let CustomContainer=styled(Container,{shouldForwardProp:prop=>isPropValid(prop)&&"isActive"!==prop&&"hasShadow"!==prop,target:"ekger5h0",label:"CustomContainer"})(({theme,isActive,hasShadow})=>({...hasShadow&&{borderBottom:"4px solid rgba(138, 97, 241, 0.20)"},backgroundColor:isActive?theme.values.color.background.accent.default:theme.values.color.background.accentSubtle.default,transitionProperty:"background-color",transitionDuration:theme.variables.animation.duration.medium,transitionTimingFunction:theme.variables.animation.timingFunction,width:"100%",height:"100%"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/SplashCardMedia/SplashCardMedia.tsx","sources":["src/components/SplashCardMedia/SplashCardMedia.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport type { BorderRadius } from \"src/types\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport { useHover } from \"../../shared/useHover\";\nimport { H4, H5, H6 } from \"../Typography/Header/Header\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Container } from \"../Container/Container\";\nimport { useFocusWithin } from \"../../shared/useFocusWithin\";\nimport { Icon, type IconProps } from \"../Icon/Icon\";\nimport { Image, type ImageProps } from \"../Image/Image\";\nimport { StyledBox } from \"../Box/Box\";\nimport {\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getFocusStyles,\n  getDisabledStyles,\n} from \"../../shared/mixins\";\nimport { type CardButtonProps } from \"../Internal/InteractiveCard/InteractiveCard\";\nimport { useBreakpoints } from \"../../shared/useBreakpoints\";\n\nexport type SplashCardMediaProps = {\n  title: string;\n  description?: string;\n  variant?: \"standard\" | \"bold\";\n  isPressed?: boolean;\n  hasShadow?: boolean;\n  imageProps: Pick<\n    ImageProps,\n    \"src\" | \"alt\" | \"placeholderSrc\" | \"fallbackSrc\" | \"sources\"\n  >;\n  iconProps?: IconProps;\n} & CardButtonProps;\n\nconst CustomContainer = styled(Container, {\n  shouldForwardProp: (prop) =>\n    isPropValid(prop) && prop !== \"isActive\" && prop !== \"hasShadow\",\n})<{ isActive: boolean; hasShadow?: boolean }>(\n  ({ theme, isActive, hasShadow }) => ({\n    ...(hasShadow && {\n      // TODO: Replace with theme token\n      borderBottom: `4px solid rgba(138, 97, 241, 0.20)`,\n    }),\n    backgroundColor: isActive\n      ? theme.values.color.background.accent.default\n      : theme.values.color.background.accentSubtle.default,\n    transitionProperty: \"background-color\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n    width: \"100%\",\n    height: \"100%\",\n  })\n);\n\nconst StyledButton = styled.button<{ disabled?: boolean }>(\n  ({ theme, disabled }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme }),\n    ...getFocusStyles(),\n    ...(disabled && {\n      ...getDisabledStyles({ theme }),\n      cursor: \"not-allowed\",\n    }),\n    position: \"relative\",\n    width: \"100%\",\n    height: \"100%\",\n    display: \"flex\",\n    flexDirection: \"row\",\n    textAlign: \"left\",\n    alignItems: \"center\",\n    padding: 0,\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      flexDirection: \"column\",\n      alignItems: \"start\",\n    },\n  })\n);\n\nconst ImageWrapper = styled.div<{ borderRadius: BorderRadius }>(\n  ({ theme, borderRadius }) => ({\n    width: 179,\n    flexShrink: 0,\n    overflow: \"hidden\",\n    borderBottomLeftRadius: theme.variables.size.borderRadius[borderRadius],\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      width: `calc(100% - 40px)`,\n    },\n  })\n);\n\nconst StyledImage = styled(Image)({\n  width: \"100%\",\n  height: \"100%\",\n  display: \"block\",\n});\n\n// Each icon layer fades in/out independently for the cross-fade effect.\nconst FadingIconLayer = styled.div<{ isVisible: boolean }>(\n  ({ theme, isVisible }) => ({\n    position: \"absolute\",\n    top: theme.variables.size.spacing.l,\n    right: theme.variables.size.spacing.l,\n    opacity: isVisible ? 1 : 0,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nconst LabelWrapper = styled.div<{ isActive: boolean }>(\n  ({ theme, isActive }) => ({\n    opacity: isActive ? 0.6 : 1,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nexport function SplashCardMedia({\n  isPressed,\n  disabled,\n  title,\n  description,\n  variant = \"standard\",\n  iconProps,\n  imageProps,\n  hasShadow,\n  ...rest\n}: SplashCardMediaProps): React.ReactElement {\n  const ref = useRef<HTMLButtonElement>(null);\n  const isHovered = useHover(ref);\n  const isFocused = useFocusWithin(ref);\n  const isActive = !disabled && (isHovered || isFocused || isPressed);\n\n  const activeColor = \"onAccent\" as const;\n  const mainTextColor = isActive ? activeColor : \"accent\";\n  const descriptionColor = isActive ? activeColor : \"secondary\";\n  const labelColor = isActive ? activeColor : \"tertiary\";\n\n  const { isMobile, isSmallMobile } = useBreakpoints();\n  const showImage = !isSmallMobile;\n  const showIcons = !isMobile;\n\n  const DescriptionHeading = isMobile ? H5 : H4;\n  const borderRadius = \"m\";\n\n  return (\n    <CustomContainer\n      hasShadow={hasShadow}\n      isActive={isActive}\n      elevation={0}\n      overflow=\"hidden\"\n      borderRadius={borderRadius}\n    >\n      <StyledButton\n        ref={ref}\n        disabled={disabled}\n        aria-pressed={isPressed ?? undefined}\n        {...rest}\n      >\n        {showImage && (\n          <ImageWrapper borderRadius={borderRadius}>\n            <StyledImage {...imageProps} fit=\"contain\" />\n          </ImageWrapper>\n        )}\n        {iconProps && showIcons && (\n          <FadingIconLayer isVisible={!isActive}>\n            <Icon size=\"m\" {...iconProps} color={mainTextColor} />\n          </FadingIconLayer>\n        )}\n        {showIcons && (\n          <FadingIconLayer isVisible={isActive}>\n            <Icon size=\"m\" name=\"arrow-right\" color={activeColor} />\n          </FadingIconLayer>\n        )}\n        <StyledBox space={[\"m\", \"l\"]} lSpace={isSmallMobile ? \"m\" : \"l\"}>\n          <Stack space=\"xxs\">\n            {variant === \"bold\" ? (\n              <>\n                <LabelWrapper isActive={isActive}>\n                  <H6 as=\"div\" color={labelColor}>\n                    {title}\n                  </H6>\n                </LabelWrapper>\n                {description && (\n                  <DescriptionHeading as=\"div\" color={mainTextColor}>\n                    {description}\n                  </DescriptionHeading>\n                )}\n              </>\n            ) : (\n              <>\n                <H4 as=\"div\" color={mainTextColor}>\n                  {title}\n                </H4>\n                {description && (\n                  <Text size={isMobile ? \"s\" : \"m\"} color={descriptionColor}>\n                    {description}\n                  </Text>\n                )}\n              </>\n            )}\n          </Stack>\n        </StyledBox>\n      </StyledButton>\n    </CustomContainer>\n  );\n}\n"],"names":[],"mappings":"AAqCwB"} */"),StyledButton=styled("button",{target:"ekger5h1",label:"StyledButton"})(({theme,disabled})=>({...getButtonAppearanceReset(),...getBaseButtonStyles({theme}),...getFocusStyles(),...disabled&&{...getDisabledStyles({theme}),cursor:"not-allowed"},position:"relative",width:"100%",height:"100%",display:"flex",flexDirection:"row",textAlign:"left",alignItems:"center",padding:0,[`@media (min-width: ${breakpoints.m.value}px)`]:{flexDirection:"column",alignItems:"start"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/SplashCardMedia/SplashCardMedia.tsx","sources":["src/components/SplashCardMedia/SplashCardMedia.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport type { BorderRadius } from \"src/types\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport { useHover } from \"../../shared/useHover\";\nimport { H4, H5, H6 } from \"../Typography/Header/Header\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Container } from \"../Container/Container\";\nimport { useFocusWithin } from \"../../shared/useFocusWithin\";\nimport { Icon, type IconProps } from \"../Icon/Icon\";\nimport { Image, type ImageProps } from \"../Image/Image\";\nimport { StyledBox } from \"../Box/Box\";\nimport {\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getFocusStyles,\n  getDisabledStyles,\n} from \"../../shared/mixins\";\nimport { type CardButtonProps } from \"../Internal/InteractiveCard/InteractiveCard\";\nimport { useBreakpoints } from \"../../shared/useBreakpoints\";\n\nexport type SplashCardMediaProps = {\n  title: string;\n  description?: string;\n  variant?: \"standard\" | \"bold\";\n  isPressed?: boolean;\n  hasShadow?: boolean;\n  imageProps: Pick<\n    ImageProps,\n    \"src\" | \"alt\" | \"placeholderSrc\" | \"fallbackSrc\" | \"sources\"\n  >;\n  iconProps?: IconProps;\n} & CardButtonProps;\n\nconst CustomContainer = styled(Container, {\n  shouldForwardProp: (prop) =>\n    isPropValid(prop) && prop !== \"isActive\" && prop !== \"hasShadow\",\n})<{ isActive: boolean; hasShadow?: boolean }>(\n  ({ theme, isActive, hasShadow }) => ({\n    ...(hasShadow && {\n      // TODO: Replace with theme token\n      borderBottom: `4px solid rgba(138, 97, 241, 0.20)`,\n    }),\n    backgroundColor: isActive\n      ? theme.values.color.background.accent.default\n      : theme.values.color.background.accentSubtle.default,\n    transitionProperty: \"background-color\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n    width: \"100%\",\n    height: \"100%\",\n  })\n);\n\nconst StyledButton = styled.button<{ disabled?: boolean }>(\n  ({ theme, disabled }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme }),\n    ...getFocusStyles(),\n    ...(disabled && {\n      ...getDisabledStyles({ theme }),\n      cursor: \"not-allowed\",\n    }),\n    position: \"relative\",\n    width: \"100%\",\n    height: \"100%\",\n    display: \"flex\",\n    flexDirection: \"row\",\n    textAlign: \"left\",\n    alignItems: \"center\",\n    padding: 0,\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      flexDirection: \"column\",\n      alignItems: \"start\",\n    },\n  })\n);\n\nconst ImageWrapper = styled.div<{ borderRadius: BorderRadius }>(\n  ({ theme, borderRadius }) => ({\n    width: 179,\n    flexShrink: 0,\n    overflow: \"hidden\",\n    borderBottomLeftRadius: theme.variables.size.borderRadius[borderRadius],\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      width: `calc(100% - 40px)`,\n    },\n  })\n);\n\nconst StyledImage = styled(Image)({\n  width: \"100%\",\n  height: \"100%\",\n  display: \"block\",\n});\n\n// Each icon layer fades in/out independently for the cross-fade effect.\nconst FadingIconLayer = styled.div<{ isVisible: boolean }>(\n  ({ theme, isVisible }) => ({\n    position: \"absolute\",\n    top: theme.variables.size.spacing.l,\n    right: theme.variables.size.spacing.l,\n    opacity: isVisible ? 1 : 0,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nconst LabelWrapper = styled.div<{ isActive: boolean }>(\n  ({ theme, isActive }) => ({\n    opacity: isActive ? 0.6 : 1,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nexport function SplashCardMedia({\n  isPressed,\n  disabled,\n  title,\n  description,\n  variant = \"standard\",\n  iconProps,\n  imageProps,\n  hasShadow,\n  ...rest\n}: SplashCardMediaProps): React.ReactElement {\n  const ref = useRef<HTMLButtonElement>(null);\n  const isHovered = useHover(ref);\n  const isFocused = useFocusWithin(ref);\n  const isActive = !disabled && (isHovered || isFocused || isPressed);\n\n  const activeColor = \"onAccent\" as const;\n  const mainTextColor = isActive ? activeColor : \"accent\";\n  const descriptionColor = isActive ? activeColor : \"secondary\";\n  const labelColor = isActive ? activeColor : \"tertiary\";\n\n  const { isMobile, isSmallMobile } = useBreakpoints();\n  const showImage = !isSmallMobile;\n  const showIcons = !isMobile;\n\n  const DescriptionHeading = isMobile ? H5 : H4;\n  const borderRadius = \"m\";\n\n  return (\n    <CustomContainer\n      hasShadow={hasShadow}\n      isActive={isActive}\n      elevation={0}\n      overflow=\"hidden\"\n      borderRadius={borderRadius}\n    >\n      <StyledButton\n        ref={ref}\n        disabled={disabled}\n        aria-pressed={isPressed ?? undefined}\n        {...rest}\n      >\n        {showImage && (\n          <ImageWrapper borderRadius={borderRadius}>\n            <StyledImage {...imageProps} fit=\"contain\" />\n          </ImageWrapper>\n        )}\n        {iconProps && showIcons && (\n          <FadingIconLayer isVisible={!isActive}>\n            <Icon size=\"m\" {...iconProps} color={mainTextColor} />\n          </FadingIconLayer>\n        )}\n        {showIcons && (\n          <FadingIconLayer isVisible={isActive}>\n            <Icon size=\"m\" name=\"arrow-right\" color={activeColor} />\n          </FadingIconLayer>\n        )}\n        <StyledBox space={[\"m\", \"l\"]} lSpace={isSmallMobile ? \"m\" : \"l\"}>\n          <Stack space=\"xxs\">\n            {variant === \"bold\" ? (\n              <>\n                <LabelWrapper isActive={isActive}>\n                  <H6 as=\"div\" color={labelColor}>\n                    {title}\n                  </H6>\n                </LabelWrapper>\n                {description && (\n                  <DescriptionHeading as=\"div\" color={mainTextColor}>\n                    {description}\n                  </DescriptionHeading>\n                )}\n              </>\n            ) : (\n              <>\n                <H4 as=\"div\" color={mainTextColor}>\n                  {title}\n                </H4>\n                {description && (\n                  <Text size={isMobile ? \"s\" : \"m\"} color={descriptionColor}>\n                    {description}\n                  </Text>\n                )}\n              </>\n            )}\n          </Stack>\n        </StyledBox>\n      </StyledButton>\n    </CustomContainer>\n  );\n}\n"],"names":[],"mappings":"AAyDqB"} */"),ImageWrapper=styled("div",{target:"ekger5h2",label:"ImageWrapper"})(({theme,borderRadius})=>({width:179,flexShrink:0,overflow:"hidden",borderBottomLeftRadius:theme.variables.size.borderRadius[borderRadius],[`@media (min-width: ${breakpoints.m.value}px)`]:{width:"calc(100% - 40px)"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/SplashCardMedia/SplashCardMedia.tsx","sources":["src/components/SplashCardMedia/SplashCardMedia.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport type { BorderRadius } from \"src/types\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport { useHover } from \"../../shared/useHover\";\nimport { H4, H5, H6 } from \"../Typography/Header/Header\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Container } from \"../Container/Container\";\nimport { useFocusWithin } from \"../../shared/useFocusWithin\";\nimport { Icon, type IconProps } from \"../Icon/Icon\";\nimport { Image, type ImageProps } from \"../Image/Image\";\nimport { StyledBox } from \"../Box/Box\";\nimport {\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getFocusStyles,\n  getDisabledStyles,\n} from \"../../shared/mixins\";\nimport { type CardButtonProps } from \"../Internal/InteractiveCard/InteractiveCard\";\nimport { useBreakpoints } from \"../../shared/useBreakpoints\";\n\nexport type SplashCardMediaProps = {\n  title: string;\n  description?: string;\n  variant?: \"standard\" | \"bold\";\n  isPressed?: boolean;\n  hasShadow?: boolean;\n  imageProps: Pick<\n    ImageProps,\n    \"src\" | \"alt\" | \"placeholderSrc\" | \"fallbackSrc\" | \"sources\"\n  >;\n  iconProps?: IconProps;\n} & CardButtonProps;\n\nconst CustomContainer = styled(Container, {\n  shouldForwardProp: (prop) =>\n    isPropValid(prop) && prop !== \"isActive\" && prop !== \"hasShadow\",\n})<{ isActive: boolean; hasShadow?: boolean }>(\n  ({ theme, isActive, hasShadow }) => ({\n    ...(hasShadow && {\n      // TODO: Replace with theme token\n      borderBottom: `4px solid rgba(138, 97, 241, 0.20)`,\n    }),\n    backgroundColor: isActive\n      ? theme.values.color.background.accent.default\n      : theme.values.color.background.accentSubtle.default,\n    transitionProperty: \"background-color\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n    width: \"100%\",\n    height: \"100%\",\n  })\n);\n\nconst StyledButton = styled.button<{ disabled?: boolean }>(\n  ({ theme, disabled }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme }),\n    ...getFocusStyles(),\n    ...(disabled && {\n      ...getDisabledStyles({ theme }),\n      cursor: \"not-allowed\",\n    }),\n    position: \"relative\",\n    width: \"100%\",\n    height: \"100%\",\n    display: \"flex\",\n    flexDirection: \"row\",\n    textAlign: \"left\",\n    alignItems: \"center\",\n    padding: 0,\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      flexDirection: \"column\",\n      alignItems: \"start\",\n    },\n  })\n);\n\nconst ImageWrapper = styled.div<{ borderRadius: BorderRadius }>(\n  ({ theme, borderRadius }) => ({\n    width: 179,\n    flexShrink: 0,\n    overflow: \"hidden\",\n    borderBottomLeftRadius: theme.variables.size.borderRadius[borderRadius],\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      width: `calc(100% - 40px)`,\n    },\n  })\n);\n\nconst StyledImage = styled(Image)({\n  width: \"100%\",\n  height: \"100%\",\n  display: \"block\",\n});\n\n// Each icon layer fades in/out independently for the cross-fade effect.\nconst FadingIconLayer = styled.div<{ isVisible: boolean }>(\n  ({ theme, isVisible }) => ({\n    position: \"absolute\",\n    top: theme.variables.size.spacing.l,\n    right: theme.variables.size.spacing.l,\n    opacity: isVisible ? 1 : 0,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nconst LabelWrapper = styled.div<{ isActive: boolean }>(\n  ({ theme, isActive }) => ({\n    opacity: isActive ? 0.6 : 1,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nexport function SplashCardMedia({\n  isPressed,\n  disabled,\n  title,\n  description,\n  variant = \"standard\",\n  iconProps,\n  imageProps,\n  hasShadow,\n  ...rest\n}: SplashCardMediaProps): React.ReactElement {\n  const ref = useRef<HTMLButtonElement>(null);\n  const isHovered = useHover(ref);\n  const isFocused = useFocusWithin(ref);\n  const isActive = !disabled && (isHovered || isFocused || isPressed);\n\n  const activeColor = \"onAccent\" as const;\n  const mainTextColor = isActive ? activeColor : \"accent\";\n  const descriptionColor = isActive ? activeColor : \"secondary\";\n  const labelColor = isActive ? activeColor : \"tertiary\";\n\n  const { isMobile, isSmallMobile } = useBreakpoints();\n  const showImage = !isSmallMobile;\n  const showIcons = !isMobile;\n\n  const DescriptionHeading = isMobile ? H5 : H4;\n  const borderRadius = \"m\";\n\n  return (\n    <CustomContainer\n      hasShadow={hasShadow}\n      isActive={isActive}\n      elevation={0}\n      overflow=\"hidden\"\n      borderRadius={borderRadius}\n    >\n      <StyledButton\n        ref={ref}\n        disabled={disabled}\n        aria-pressed={isPressed ?? undefined}\n        {...rest}\n      >\n        {showImage && (\n          <ImageWrapper borderRadius={borderRadius}>\n            <StyledImage {...imageProps} fit=\"contain\" />\n          </ImageWrapper>\n        )}\n        {iconProps && showIcons && (\n          <FadingIconLayer isVisible={!isActive}>\n            <Icon size=\"m\" {...iconProps} color={mainTextColor} />\n          </FadingIconLayer>\n        )}\n        {showIcons && (\n          <FadingIconLayer isVisible={isActive}>\n            <Icon size=\"m\" name=\"arrow-right\" color={activeColor} />\n          </FadingIconLayer>\n        )}\n        <StyledBox space={[\"m\", \"l\"]} lSpace={isSmallMobile ? \"m\" : \"l\"}>\n          <Stack space=\"xxs\">\n            {variant === \"bold\" ? (\n              <>\n                <LabelWrapper isActive={isActive}>\n                  <H6 as=\"div\" color={labelColor}>\n                    {title}\n                  </H6>\n                </LabelWrapper>\n                {description && (\n                  <DescriptionHeading as=\"div\" color={mainTextColor}>\n                    {description}\n                  </DescriptionHeading>\n                )}\n              </>\n            ) : (\n              <>\n                <H4 as=\"div\" color={mainTextColor}>\n                  {title}\n                </H4>\n                {description && (\n                  <Text size={isMobile ? \"s\" : \"m\"} color={descriptionColor}>\n                    {description}\n                  </Text>\n                )}\n              </>\n            )}\n          </Stack>\n        </StyledBox>\n      </StyledButton>\n    </CustomContainer>\n  );\n}\n"],"names":[],"mappings":"AAiFqB"} */"),StyledImage=styled(Image,{target:"ekger5h3",label:"StyledImage"})({width:"100%",height:"100%",display:"block"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/SplashCardMedia/SplashCardMedia.tsx","sources":["src/components/SplashCardMedia/SplashCardMedia.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport type { BorderRadius } from \"src/types\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport { useHover } from \"../../shared/useHover\";\nimport { H4, H5, H6 } from \"../Typography/Header/Header\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Container } from \"../Container/Container\";\nimport { useFocusWithin } from \"../../shared/useFocusWithin\";\nimport { Icon, type IconProps } from \"../Icon/Icon\";\nimport { Image, type ImageProps } from \"../Image/Image\";\nimport { StyledBox } from \"../Box/Box\";\nimport {\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getFocusStyles,\n  getDisabledStyles,\n} from \"../../shared/mixins\";\nimport { type CardButtonProps } from \"../Internal/InteractiveCard/InteractiveCard\";\nimport { useBreakpoints } from \"../../shared/useBreakpoints\";\n\nexport type SplashCardMediaProps = {\n  title: string;\n  description?: string;\n  variant?: \"standard\" | \"bold\";\n  isPressed?: boolean;\n  hasShadow?: boolean;\n  imageProps: Pick<\n    ImageProps,\n    \"src\" | \"alt\" | \"placeholderSrc\" | \"fallbackSrc\" | \"sources\"\n  >;\n  iconProps?: IconProps;\n} & CardButtonProps;\n\nconst CustomContainer = styled(Container, {\n  shouldForwardProp: (prop) =>\n    isPropValid(prop) && prop !== \"isActive\" && prop !== \"hasShadow\",\n})<{ isActive: boolean; hasShadow?: boolean }>(\n  ({ theme, isActive, hasShadow }) => ({\n    ...(hasShadow && {\n      // TODO: Replace with theme token\n      borderBottom: `4px solid rgba(138, 97, 241, 0.20)`,\n    }),\n    backgroundColor: isActive\n      ? theme.values.color.background.accent.default\n      : theme.values.color.background.accentSubtle.default,\n    transitionProperty: \"background-color\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n    width: \"100%\",\n    height: \"100%\",\n  })\n);\n\nconst StyledButton = styled.button<{ disabled?: boolean }>(\n  ({ theme, disabled }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme }),\n    ...getFocusStyles(),\n    ...(disabled && {\n      ...getDisabledStyles({ theme }),\n      cursor: \"not-allowed\",\n    }),\n    position: \"relative\",\n    width: \"100%\",\n    height: \"100%\",\n    display: \"flex\",\n    flexDirection: \"row\",\n    textAlign: \"left\",\n    alignItems: \"center\",\n    padding: 0,\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      flexDirection: \"column\",\n      alignItems: \"start\",\n    },\n  })\n);\n\nconst ImageWrapper = styled.div<{ borderRadius: BorderRadius }>(\n  ({ theme, borderRadius }) => ({\n    width: 179,\n    flexShrink: 0,\n    overflow: \"hidden\",\n    borderBottomLeftRadius: theme.variables.size.borderRadius[borderRadius],\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      width: `calc(100% - 40px)`,\n    },\n  })\n);\n\nconst StyledImage = styled(Image)({\n  width: \"100%\",\n  height: \"100%\",\n  display: \"block\",\n});\n\n// Each icon layer fades in/out independently for the cross-fade effect.\nconst FadingIconLayer = styled.div<{ isVisible: boolean }>(\n  ({ theme, isVisible }) => ({\n    position: \"absolute\",\n    top: theme.variables.size.spacing.l,\n    right: theme.variables.size.spacing.l,\n    opacity: isVisible ? 1 : 0,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nconst LabelWrapper = styled.div<{ isActive: boolean }>(\n  ({ theme, isActive }) => ({\n    opacity: isActive ? 0.6 : 1,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nexport function SplashCardMedia({\n  isPressed,\n  disabled,\n  title,\n  description,\n  variant = \"standard\",\n  iconProps,\n  imageProps,\n  hasShadow,\n  ...rest\n}: SplashCardMediaProps): React.ReactElement {\n  const ref = useRef<HTMLButtonElement>(null);\n  const isHovered = useHover(ref);\n  const isFocused = useFocusWithin(ref);\n  const isActive = !disabled && (isHovered || isFocused || isPressed);\n\n  const activeColor = \"onAccent\" as const;\n  const mainTextColor = isActive ? activeColor : \"accent\";\n  const descriptionColor = isActive ? activeColor : \"secondary\";\n  const labelColor = isActive ? activeColor : \"tertiary\";\n\n  const { isMobile, isSmallMobile } = useBreakpoints();\n  const showImage = !isSmallMobile;\n  const showIcons = !isMobile;\n\n  const DescriptionHeading = isMobile ? H5 : H4;\n  const borderRadius = \"m\";\n\n  return (\n    <CustomContainer\n      hasShadow={hasShadow}\n      isActive={isActive}\n      elevation={0}\n      overflow=\"hidden\"\n      borderRadius={borderRadius}\n    >\n      <StyledButton\n        ref={ref}\n        disabled={disabled}\n        aria-pressed={isPressed ?? undefined}\n        {...rest}\n      >\n        {showImage && (\n          <ImageWrapper borderRadius={borderRadius}>\n            <StyledImage {...imageProps} fit=\"contain\" />\n          </ImageWrapper>\n        )}\n        {iconProps && showIcons && (\n          <FadingIconLayer isVisible={!isActive}>\n            <Icon size=\"m\" {...iconProps} color={mainTextColor} />\n          </FadingIconLayer>\n        )}\n        {showIcons && (\n          <FadingIconLayer isVisible={isActive}>\n            <Icon size=\"m\" name=\"arrow-right\" color={activeColor} />\n          </FadingIconLayer>\n        )}\n        <StyledBox space={[\"m\", \"l\"]} lSpace={isSmallMobile ? \"m\" : \"l\"}>\n          <Stack space=\"xxs\">\n            {variant === \"bold\" ? (\n              <>\n                <LabelWrapper isActive={isActive}>\n                  <H6 as=\"div\" color={labelColor}>\n                    {title}\n                  </H6>\n                </LabelWrapper>\n                {description && (\n                  <DescriptionHeading as=\"div\" color={mainTextColor}>\n                    {description}\n                  </DescriptionHeading>\n                )}\n              </>\n            ) : (\n              <>\n                <H4 as=\"div\" color={mainTextColor}>\n                  {title}\n                </H4>\n                {description && (\n                  <Text size={isMobile ? \"s\" : \"m\"} color={descriptionColor}>\n                    {description}\n                  </Text>\n                )}\n              </>\n            )}\n          </Stack>\n        </StyledBox>\n      </StyledButton>\n    </CustomContainer>\n  );\n}\n"],"names":[],"mappings":"AA6FoB"} */"),FadingIconLayer=styled("div",{target:"ekger5h4",label:"FadingIconLayer"})(({theme,isVisible})=>({position:"absolute",top:theme.variables.size.spacing.l,right:theme.variables.size.spacing.l,opacity:+!!isVisible,transitionProperty:"opacity",transitionDuration:theme.variables.animation.duration.medium,transitionTimingFunction:theme.variables.animation.timingFunction}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/SplashCardMedia/SplashCardMedia.tsx","sources":["src/components/SplashCardMedia/SplashCardMedia.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport type { BorderRadius } from \"src/types\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport { useHover } from \"../../shared/useHover\";\nimport { H4, H5, H6 } from \"../Typography/Header/Header\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Container } from \"../Container/Container\";\nimport { useFocusWithin } from \"../../shared/useFocusWithin\";\nimport { Icon, type IconProps } from \"../Icon/Icon\";\nimport { Image, type ImageProps } from \"../Image/Image\";\nimport { StyledBox } from \"../Box/Box\";\nimport {\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getFocusStyles,\n  getDisabledStyles,\n} from \"../../shared/mixins\";\nimport { type CardButtonProps } from \"../Internal/InteractiveCard/InteractiveCard\";\nimport { useBreakpoints } from \"../../shared/useBreakpoints\";\n\nexport type SplashCardMediaProps = {\n  title: string;\n  description?: string;\n  variant?: \"standard\" | \"bold\";\n  isPressed?: boolean;\n  hasShadow?: boolean;\n  imageProps: Pick<\n    ImageProps,\n    \"src\" | \"alt\" | \"placeholderSrc\" | \"fallbackSrc\" | \"sources\"\n  >;\n  iconProps?: IconProps;\n} & CardButtonProps;\n\nconst CustomContainer = styled(Container, {\n  shouldForwardProp: (prop) =>\n    isPropValid(prop) && prop !== \"isActive\" && prop !== \"hasShadow\",\n})<{ isActive: boolean; hasShadow?: boolean }>(\n  ({ theme, isActive, hasShadow }) => ({\n    ...(hasShadow && {\n      // TODO: Replace with theme token\n      borderBottom: `4px solid rgba(138, 97, 241, 0.20)`,\n    }),\n    backgroundColor: isActive\n      ? theme.values.color.background.accent.default\n      : theme.values.color.background.accentSubtle.default,\n    transitionProperty: \"background-color\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n    width: \"100%\",\n    height: \"100%\",\n  })\n);\n\nconst StyledButton = styled.button<{ disabled?: boolean }>(\n  ({ theme, disabled }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme }),\n    ...getFocusStyles(),\n    ...(disabled && {\n      ...getDisabledStyles({ theme }),\n      cursor: \"not-allowed\",\n    }),\n    position: \"relative\",\n    width: \"100%\",\n    height: \"100%\",\n    display: \"flex\",\n    flexDirection: \"row\",\n    textAlign: \"left\",\n    alignItems: \"center\",\n    padding: 0,\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      flexDirection: \"column\",\n      alignItems: \"start\",\n    },\n  })\n);\n\nconst ImageWrapper = styled.div<{ borderRadius: BorderRadius }>(\n  ({ theme, borderRadius }) => ({\n    width: 179,\n    flexShrink: 0,\n    overflow: \"hidden\",\n    borderBottomLeftRadius: theme.variables.size.borderRadius[borderRadius],\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      width: `calc(100% - 40px)`,\n    },\n  })\n);\n\nconst StyledImage = styled(Image)({\n  width: \"100%\",\n  height: \"100%\",\n  display: \"block\",\n});\n\n// Each icon layer fades in/out independently for the cross-fade effect.\nconst FadingIconLayer = styled.div<{ isVisible: boolean }>(\n  ({ theme, isVisible }) => ({\n    position: \"absolute\",\n    top: theme.variables.size.spacing.l,\n    right: theme.variables.size.spacing.l,\n    opacity: isVisible ? 1 : 0,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nconst LabelWrapper = styled.div<{ isActive: boolean }>(\n  ({ theme, isActive }) => ({\n    opacity: isActive ? 0.6 : 1,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nexport function SplashCardMedia({\n  isPressed,\n  disabled,\n  title,\n  description,\n  variant = \"standard\",\n  iconProps,\n  imageProps,\n  hasShadow,\n  ...rest\n}: SplashCardMediaProps): React.ReactElement {\n  const ref = useRef<HTMLButtonElement>(null);\n  const isHovered = useHover(ref);\n  const isFocused = useFocusWithin(ref);\n  const isActive = !disabled && (isHovered || isFocused || isPressed);\n\n  const activeColor = \"onAccent\" as const;\n  const mainTextColor = isActive ? activeColor : \"accent\";\n  const descriptionColor = isActive ? activeColor : \"secondary\";\n  const labelColor = isActive ? activeColor : \"tertiary\";\n\n  const { isMobile, isSmallMobile } = useBreakpoints();\n  const showImage = !isSmallMobile;\n  const showIcons = !isMobile;\n\n  const DescriptionHeading = isMobile ? H5 : H4;\n  const borderRadius = \"m\";\n\n  return (\n    <CustomContainer\n      hasShadow={hasShadow}\n      isActive={isActive}\n      elevation={0}\n      overflow=\"hidden\"\n      borderRadius={borderRadius}\n    >\n      <StyledButton\n        ref={ref}\n        disabled={disabled}\n        aria-pressed={isPressed ?? undefined}\n        {...rest}\n      >\n        {showImage && (\n          <ImageWrapper borderRadius={borderRadius}>\n            <StyledImage {...imageProps} fit=\"contain\" />\n          </ImageWrapper>\n        )}\n        {iconProps && showIcons && (\n          <FadingIconLayer isVisible={!isActive}>\n            <Icon size=\"m\" {...iconProps} color={mainTextColor} />\n          </FadingIconLayer>\n        )}\n        {showIcons && (\n          <FadingIconLayer isVisible={isActive}>\n            <Icon size=\"m\" name=\"arrow-right\" color={activeColor} />\n          </FadingIconLayer>\n        )}\n        <StyledBox space={[\"m\", \"l\"]} lSpace={isSmallMobile ? \"m\" : \"l\"}>\n          <Stack space=\"xxs\">\n            {variant === \"bold\" ? (\n              <>\n                <LabelWrapper isActive={isActive}>\n                  <H6 as=\"div\" color={labelColor}>\n                    {title}\n                  </H6>\n                </LabelWrapper>\n                {description && (\n                  <DescriptionHeading as=\"div\" color={mainTextColor}>\n                    {description}\n                  </DescriptionHeading>\n                )}\n              </>\n            ) : (\n              <>\n                <H4 as=\"div\" color={mainTextColor}>\n                  {title}\n                </H4>\n                {description && (\n                  <Text size={isMobile ? \"s\" : \"m\"} color={descriptionColor}>\n                    {description}\n                  </Text>\n                )}\n              </>\n            )}\n          </Stack>\n        </StyledBox>\n      </StyledButton>\n    </CustomContainer>\n  );\n}\n"],"names":[],"mappings":"AAoGwB"} */"),LabelWrapper=styled("div",{target:"ekger5h5",label:"LabelWrapper"})(({theme,isActive})=>({opacity:isActive?.6:1,transitionProperty:"opacity",transitionDuration:theme.variables.animation.duration.medium,transitionTimingFunction:theme.variables.animation.timingFunction}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/SplashCardMedia/SplashCardMedia.tsx","sources":["src/components/SplashCardMedia/SplashCardMedia.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport type { BorderRadius } from \"src/types\";\nimport breakpoints from \"../../web-tokens/_breakpoints.json\";\nimport { useHover } from \"../../shared/useHover\";\nimport { H4, H5, H6 } from \"../Typography/Header/Header\";\nimport { Text } from \"../Typography/Text/Text\";\nimport { Stack } from \"../Stack/Stack\";\nimport { Container } from \"../Container/Container\";\nimport { useFocusWithin } from \"../../shared/useFocusWithin\";\nimport { Icon, type IconProps } from \"../Icon/Icon\";\nimport { Image, type ImageProps } from \"../Image/Image\";\nimport { StyledBox } from \"../Box/Box\";\nimport {\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getFocusStyles,\n  getDisabledStyles,\n} from \"../../shared/mixins\";\nimport { type CardButtonProps } from \"../Internal/InteractiveCard/InteractiveCard\";\nimport { useBreakpoints } from \"../../shared/useBreakpoints\";\n\nexport type SplashCardMediaProps = {\n  title: string;\n  description?: string;\n  variant?: \"standard\" | \"bold\";\n  isPressed?: boolean;\n  hasShadow?: boolean;\n  imageProps: Pick<\n    ImageProps,\n    \"src\" | \"alt\" | \"placeholderSrc\" | \"fallbackSrc\" | \"sources\"\n  >;\n  iconProps?: IconProps;\n} & CardButtonProps;\n\nconst CustomContainer = styled(Container, {\n  shouldForwardProp: (prop) =>\n    isPropValid(prop) && prop !== \"isActive\" && prop !== \"hasShadow\",\n})<{ isActive: boolean; hasShadow?: boolean }>(\n  ({ theme, isActive, hasShadow }) => ({\n    ...(hasShadow && {\n      // TODO: Replace with theme token\n      borderBottom: `4px solid rgba(138, 97, 241, 0.20)`,\n    }),\n    backgroundColor: isActive\n      ? theme.values.color.background.accent.default\n      : theme.values.color.background.accentSubtle.default,\n    transitionProperty: \"background-color\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n    width: \"100%\",\n    height: \"100%\",\n  })\n);\n\nconst StyledButton = styled.button<{ disabled?: boolean }>(\n  ({ theme, disabled }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme }),\n    ...getFocusStyles(),\n    ...(disabled && {\n      ...getDisabledStyles({ theme }),\n      cursor: \"not-allowed\",\n    }),\n    position: \"relative\",\n    width: \"100%\",\n    height: \"100%\",\n    display: \"flex\",\n    flexDirection: \"row\",\n    textAlign: \"left\",\n    alignItems: \"center\",\n    padding: 0,\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      flexDirection: \"column\",\n      alignItems: \"start\",\n    },\n  })\n);\n\nconst ImageWrapper = styled.div<{ borderRadius: BorderRadius }>(\n  ({ theme, borderRadius }) => ({\n    width: 179,\n    flexShrink: 0,\n    overflow: \"hidden\",\n    borderBottomLeftRadius: theme.variables.size.borderRadius[borderRadius],\n    [`@media (min-width: ${breakpoints.m.value}px)`]: {\n      width: `calc(100% - 40px)`,\n    },\n  })\n);\n\nconst StyledImage = styled(Image)({\n  width: \"100%\",\n  height: \"100%\",\n  display: \"block\",\n});\n\n// Each icon layer fades in/out independently for the cross-fade effect.\nconst FadingIconLayer = styled.div<{ isVisible: boolean }>(\n  ({ theme, isVisible }) => ({\n    position: \"absolute\",\n    top: theme.variables.size.spacing.l,\n    right: theme.variables.size.spacing.l,\n    opacity: isVisible ? 1 : 0,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nconst LabelWrapper = styled.div<{ isActive: boolean }>(\n  ({ theme, isActive }) => ({\n    opacity: isActive ? 0.6 : 1,\n    transitionProperty: \"opacity\",\n    transitionDuration: theme.variables.animation.duration.medium,\n    transitionTimingFunction: theme.variables.animation.timingFunction,\n  })\n);\n\nexport function SplashCardMedia({\n  isPressed,\n  disabled,\n  title,\n  description,\n  variant = \"standard\",\n  iconProps,\n  imageProps,\n  hasShadow,\n  ...rest\n}: SplashCardMediaProps): React.ReactElement {\n  const ref = useRef<HTMLButtonElement>(null);\n  const isHovered = useHover(ref);\n  const isFocused = useFocusWithin(ref);\n  const isActive = !disabled && (isHovered || isFocused || isPressed);\n\n  const activeColor = \"onAccent\" as const;\n  const mainTextColor = isActive ? activeColor : \"accent\";\n  const descriptionColor = isActive ? activeColor : \"secondary\";\n  const labelColor = isActive ? activeColor : \"tertiary\";\n\n  const { isMobile, isSmallMobile } = useBreakpoints();\n  const showImage = !isSmallMobile;\n  const showIcons = !isMobile;\n\n  const DescriptionHeading = isMobile ? H5 : H4;\n  const borderRadius = \"m\";\n\n  return (\n    <CustomContainer\n      hasShadow={hasShadow}\n      isActive={isActive}\n      elevation={0}\n      overflow=\"hidden\"\n      borderRadius={borderRadius}\n    >\n      <StyledButton\n        ref={ref}\n        disabled={disabled}\n        aria-pressed={isPressed ?? undefined}\n        {...rest}\n      >\n        {showImage && (\n          <ImageWrapper borderRadius={borderRadius}>\n            <StyledImage {...imageProps} fit=\"contain\" />\n          </ImageWrapper>\n        )}\n        {iconProps && showIcons && (\n          <FadingIconLayer isVisible={!isActive}>\n            <Icon size=\"m\" {...iconProps} color={mainTextColor} />\n          </FadingIconLayer>\n        )}\n        {showIcons && (\n          <FadingIconLayer isVisible={isActive}>\n            <Icon size=\"m\" name=\"arrow-right\" color={activeColor} />\n          </FadingIconLayer>\n        )}\n        <StyledBox space={[\"m\", \"l\"]} lSpace={isSmallMobile ? \"m\" : \"l\"}>\n          <Stack space=\"xxs\">\n            {variant === \"bold\" ? (\n              <>\n                <LabelWrapper isActive={isActive}>\n                  <H6 as=\"div\" color={labelColor}>\n                    {title}\n                  </H6>\n                </LabelWrapper>\n                {description && (\n                  <DescriptionHeading as=\"div\" color={mainTextColor}>\n                    {description}\n                  </DescriptionHeading>\n                )}\n              </>\n            ) : (\n              <>\n                <H4 as=\"div\" color={mainTextColor}>\n                  {title}\n                </H4>\n                {description && (\n                  <Text size={isMobile ? \"s\" : \"m\"} color={descriptionColor}>\n                    {description}\n                  </Text>\n                )}\n              </>\n            )}\n          </Stack>\n        </StyledBox>\n      </StyledButton>\n    </CustomContainer>\n  );\n}\n"],"names":[],"mappings":"AAgHqB"} */");export function SplashCardMedia({isPressed,disabled,title,description,variant="standard",iconProps,imageProps,hasShadow,...rest}){let ref=useRef(null),isHovered=useHover(ref),isFocused=useFocusWithin(ref),isActive=!disabled&&(isHovered||isFocused||isPressed),activeColor="onAccent",mainTextColor=isActive?activeColor:"accent",descriptionColor=isActive?activeColor:"secondary",labelColor=isActive?activeColor:"tertiary",{isMobile,isSmallMobile}=useBreakpoints(),showIcons=!isMobile,DescriptionHeading=isMobile?H5:H4;return React.createElement(CustomContainer,{hasShadow:hasShadow,isActive:isActive,elevation:0,overflow:"hidden",borderRadius:"m"},React.createElement(StyledButton,{ref:ref,disabled:disabled,"aria-pressed":isPressed??void 0,...rest},!isSmallMobile&&React.createElement(ImageWrapper,{borderRadius:"m"},React.createElement(StyledImage,{...imageProps,fit:"contain"})),iconProps&&showIcons&&React.createElement(FadingIconLayer,{isVisible:!isActive},React.createElement(Icon,{size:"m",...iconProps,color:mainTextColor})),showIcons&&React.createElement(FadingIconLayer,{isVisible:isActive},React.createElement(Icon,{size:"m",name:"arrow-right",color:activeColor})),React.createElement(StyledBox,{space:["m","l"],lSpace:isSmallMobile?"m":"l"},React.createElement(Stack,{space:"xxs"},"bold"===variant?React.createElement(React.Fragment,null,React.createElement(LabelWrapper,{isActive:isActive},React.createElement(H6,{as:"div",color:labelColor},title)),description&&React.createElement(DescriptionHeading,{as:"div",color:mainTextColor},description)):React.createElement(React.Fragment,null,React.createElement(H4,{as:"div",color:mainTextColor},title),description&&React.createElement(Text,{size:isMobile?"s":"m",color:descriptionColor},description))))))}
@@ -68,6 +68,7 @@ export * from "./components/Popover/Popover";
68
68
  export * from "./components/ProgressBar/ProgressBar";
69
69
  export * from "./components/PromptInput/PromptInput";
70
70
  export * from "./components/SplashCard/SplashCard";
71
+ export * from "./components/SplashCardMedia/SplashCardMedia";
71
72
  export * from "./components/QBankRichText/QBankRichText";
72
73
  export * from "./components/RadioCard/RadioCard";
73
74
  export * from "./components/RoundButton/RoundButton";
@@ -97,6 +98,7 @@ export * from "./components/Content/ContentBox/ContentBox";
97
98
  export * from "./components/Content/ContentFontResizer";
98
99
  export * from "./components/Content/ContentHeading/ContentHeading";
99
100
  export * from "./components/Content/ContentLink/ContentLink";
101
+ export * from "./components/Content/ContentPictogramButton/ContentPictogramButton";
100
102
  export * from "./components/Content/ContentText/ContentText";
101
103
  export * from "./components/Content/ContentList";
102
104
  export * from "./components/Content/ContentTable";
@@ -1 +1 @@
1
- import{ambossVisualConfiguration}from"./web-tokens/visualConfig";export const{dark,light}=ambossVisualConfiguration;export{ThemeProvider,CacheProvider}from"@emotion/react";export{default as createCache}from"@emotion/cache";export*from"./components/AccessCardItem/AccessCardItem";export*from"./components/Avatar/Avatar";export*from"./components/AvatarGroup/AvatarGroup";export*from"./components/Badge/Badge";export*from"./components/BinaryFeedback/BinaryFeedback";export*from"./components/Box/Box";export*from"./components/BulkActionsToolbar/BulkActionsToolbar";export*from"./components/Button/Button";export*from"./components/Callout/Callout";export*from"./components/Card/Card";export*from"./components/Card/CardBox";export*from"./components/CatalogCard/CatalogCard";export*from"./components/CheckboxCard/CheckboxCard";export*from"./components/Collapsible/Collapsible";export*from"./components/ColorIndicator/ColorIndicator";export*from"./components/ColorPicker/ColorPicker";export*from"./components/Column/Columns";export*from"./components/Container";export*from"./components/CountButton/CountButton";export*from"./components/DataTable";export*from"./components/Divider/Divider";export*from"./components/DropdownMenu/DropdownMenu";export*from"./components/EntityList";export*from"./components/EntityTree";export*from"./components/Composite/FilterDialog/FilterDialog";export*from"./components/Form/Checkbox/Checkbox";export*from"./components/Form/Combobox/Combobox";export*from"./components/Form/DateInput/DateInput";export*from"./components/Form/FormFieldGroup/FormFieldGroup";export*from"./components/Form/Input";export*from"./components/Form/MaskedInput/MaskedInput";export*from"./components/Form/PasswordInput";export*from"./components/Form/Radio/Radio";export*from"./components/Form/RadioButton/RadioButton";export*from"./components/Form/RangeInput/RangeInput";export*from"./components/Form/SearchInput/SearchInput";export*from"./components/Form/SegmentedControl/SegmentedControl";export*from"./components/Form/Select";export*from"./components/Form/Textarea/Textarea";export*from"./components/Form/Toggle/Toggle";export*from"./components/Form/ToggleButton/ToggleButton";export*from"./components/Grid/Grid";export*from"./components/Icon/Icon";export*from"./components/IconTile/IconTile";export*from"./components/Image/Image";export*from"./components/Inline/Inline";export*from"./components/InteractiveBox/InteractiveBox";export*from"./components/Lightbox/Lightbox";export*from"./components/Link/Link";export*from"./components/LoadingSpinner/LoadingSpinner";export*from"./components/Logo/Logo";export*from"./components/MediaItem";export*from"./components/MediaViewerBar/MediaViewerBar";export*from"./components/MediaViewerCarousel/MediaViewerCarousel";export*from"./components/NavBar";export*from"./components/Notification/Notification";export*from"./components/Pagination/Pagination";export*from"./components/Patterns/ButtonGroup/ButtonGroup";export*from"./components/Patterns/Modal/Modal";export*from"./components/PictogramButton/PictogramButton";export*from"./components/Popover/Popover";export*from"./components/ProgressBar/ProgressBar";export*from"./components/PromptInput/PromptInput";export*from"./components/SplashCard/SplashCard";export*from"./components/QBankRichText/QBankRichText";export*from"./components/RadioCard/RadioCard";export*from"./components/RoundButton/RoundButton";export*from"./components/SearchResult/SearchResult";export*from"./components/SegmentedProgressBar/SegmentedProgressBar";export*from"./components/Sheet/Sheet";export*from"./components/Stack/Stack";export*from"./components/SubThemeProvider/SubThemeProvider";export*from"./components/Tabs/Tabs";export*from"./components/Tag/Tag";export*from"./components/TagGroup/TagGroup";export*from"./components/Toast";export*from"./components/Toggletip/Toggletip";export*from"./components/Tooltip/Tooltip";export*from"./components/Tutorialtip/Tutorialtip";export*from"./components/Typography/Header";export*from"./components/Typography/StyledText/StyledText";export*from"./components/Typography/Text";export*from"./components/Typography/TextClamped/TextClamped";export*from"./components/UserHighlightTooltip/UserHighlightTooltip";export*from"./components/Utilities/AnimatedBorder/AnimatedBorder";export*from"./components/Utilities/ContainerQuery/ContainerQuery";export*from"./components/Utilities/Expandable/Expandable";export*from"./components/Utilities/ScreenReaderText/ScreenReaderText";export*from"./components/Patterns/EmptyState/EmptyState";export*from"./components/Content/ContentBox/ContentBox";export*from"./components/Content/ContentFontResizer";export*from"./components/Content/ContentHeading/ContentHeading";export*from"./components/Content/ContentLink/ContentLink";export*from"./components/Content/ContentText/ContentText";export*from"./components/Content/ContentList";export*from"./components/Content/ContentTable";export*from"./components/Content/ReferenceButton";
1
+ import{ambossVisualConfiguration}from"./web-tokens/visualConfig";export const{dark,light}=ambossVisualConfiguration;export{ThemeProvider,CacheProvider}from"@emotion/react";export{default as createCache}from"@emotion/cache";export*from"./components/AccessCardItem/AccessCardItem";export*from"./components/Avatar/Avatar";export*from"./components/AvatarGroup/AvatarGroup";export*from"./components/Badge/Badge";export*from"./components/BinaryFeedback/BinaryFeedback";export*from"./components/Box/Box";export*from"./components/BulkActionsToolbar/BulkActionsToolbar";export*from"./components/Button/Button";export*from"./components/Callout/Callout";export*from"./components/Card/Card";export*from"./components/Card/CardBox";export*from"./components/CatalogCard/CatalogCard";export*from"./components/CheckboxCard/CheckboxCard";export*from"./components/Collapsible/Collapsible";export*from"./components/ColorIndicator/ColorIndicator";export*from"./components/ColorPicker/ColorPicker";export*from"./components/Column/Columns";export*from"./components/Container";export*from"./components/CountButton/CountButton";export*from"./components/DataTable";export*from"./components/Divider/Divider";export*from"./components/DropdownMenu/DropdownMenu";export*from"./components/EntityList";export*from"./components/EntityTree";export*from"./components/Composite/FilterDialog/FilterDialog";export*from"./components/Form/Checkbox/Checkbox";export*from"./components/Form/Combobox/Combobox";export*from"./components/Form/DateInput/DateInput";export*from"./components/Form/FormFieldGroup/FormFieldGroup";export*from"./components/Form/Input";export*from"./components/Form/MaskedInput/MaskedInput";export*from"./components/Form/PasswordInput";export*from"./components/Form/Radio/Radio";export*from"./components/Form/RadioButton/RadioButton";export*from"./components/Form/RangeInput/RangeInput";export*from"./components/Form/SearchInput/SearchInput";export*from"./components/Form/SegmentedControl/SegmentedControl";export*from"./components/Form/Select";export*from"./components/Form/Textarea/Textarea";export*from"./components/Form/Toggle/Toggle";export*from"./components/Form/ToggleButton/ToggleButton";export*from"./components/Grid/Grid";export*from"./components/Icon/Icon";export*from"./components/IconTile/IconTile";export*from"./components/Image/Image";export*from"./components/Inline/Inline";export*from"./components/InteractiveBox/InteractiveBox";export*from"./components/Lightbox/Lightbox";export*from"./components/Link/Link";export*from"./components/LoadingSpinner/LoadingSpinner";export*from"./components/Logo/Logo";export*from"./components/MediaItem";export*from"./components/MediaViewerBar/MediaViewerBar";export*from"./components/MediaViewerCarousel/MediaViewerCarousel";export*from"./components/NavBar";export*from"./components/Notification/Notification";export*from"./components/Pagination/Pagination";export*from"./components/Patterns/ButtonGroup/ButtonGroup";export*from"./components/Patterns/Modal/Modal";export*from"./components/PictogramButton/PictogramButton";export*from"./components/Popover/Popover";export*from"./components/ProgressBar/ProgressBar";export*from"./components/PromptInput/PromptInput";export*from"./components/SplashCard/SplashCard";export*from"./components/SplashCardMedia/SplashCardMedia";export*from"./components/QBankRichText/QBankRichText";export*from"./components/RadioCard/RadioCard";export*from"./components/RoundButton/RoundButton";export*from"./components/SearchResult/SearchResult";export*from"./components/SegmentedProgressBar/SegmentedProgressBar";export*from"./components/Sheet/Sheet";export*from"./components/Stack/Stack";export*from"./components/SubThemeProvider/SubThemeProvider";export*from"./components/Tabs/Tabs";export*from"./components/Tag/Tag";export*from"./components/TagGroup/TagGroup";export*from"./components/Toast";export*from"./components/Toggletip/Toggletip";export*from"./components/Tooltip/Tooltip";export*from"./components/Tutorialtip/Tutorialtip";export*from"./components/Typography/Header";export*from"./components/Typography/StyledText/StyledText";export*from"./components/Typography/Text";export*from"./components/Typography/TextClamped/TextClamped";export*from"./components/UserHighlightTooltip/UserHighlightTooltip";export*from"./components/Utilities/AnimatedBorder/AnimatedBorder";export*from"./components/Utilities/ContainerQuery/ContainerQuery";export*from"./components/Utilities/Expandable/Expandable";export*from"./components/Utilities/ScreenReaderText/ScreenReaderText";export*from"./components/Patterns/EmptyState/EmptyState";export*from"./components/Content/ContentBox/ContentBox";export*from"./components/Content/ContentFontResizer";export*from"./components/Content/ContentHeading/ContentHeading";export*from"./components/Content/ContentLink/ContentLink";export*from"./components/Content/ContentPictogramButton/ContentPictogramButton";export*from"./components/Content/ContentText/ContentText";export*from"./components/Content/ContentList";export*from"./components/Content/ContentTable";export*from"./components/Content/ReferenceButton";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@amboss/design-system",
3
- "version": "3.37.3",
3
+ "version": "3.38.0",
4
4
  "description": "the design system for AMBOSS products",
5
5
  "author": "AMBOSS",
6
6
  "license": "ISC",