@amboss/design-system 3.37.4 → 3.38.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cjs/components/DropdownMenu/MenuItem.js +1 -1
- package/build/cjs/components/SplashCardMedia/SplashCardMedia.d.ts +14 -0
- package/build/cjs/components/SplashCardMedia/SplashCardMedia.js +1 -0
- package/build/cjs/index.d.ts +1 -0
- package/build/cjs/index.js +1 -1
- package/build/esm/components/DropdownMenu/MenuItem.js +1 -1
- package/build/esm/components/SplashCardMedia/SplashCardMedia.d.ts +14 -0
- package/build/esm/components/SplashCardMedia/SplashCardMedia.js +1 -0
- package/build/esm/index.d.ts +1 -0
- package/build/esm/index.js +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"MenuItem",{enumerable:!0,get:function(){return MenuItem}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Icon=require("../Icon/Icon"),_Inline=require("../Inline/Inline"),StyledMenuItem=(0,_styled.default)("button",{target:"
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"MenuItem",{enumerable:!0,get:function(){return MenuItem}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Icon=require("../Icon/Icon"),_Inline=require("../Inline/Inline"),StyledMenuItem=(0,_styled.default)("button",{target:"e5e5fy60",label:"StyledMenuItem"})(({theme,size,textVariant,destructive,disabled})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},display:"inline-block",width:"100%",border:0,color:destructive?theme.values.color.text.error.default:theme.values.color.text.secondary.default,backgroundColor:theme.values.color.background.primary.default,textTransform:textVariant||"uppercase",textDecoration:"none",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.xs,lineHeight:theme.variables.size.lineHeight.m,letterSpacing:theme.variables.size.letterSpacing.s,fontWeight:theme.variables.weight.bold,cursor:"pointer","&:focus-visible":{outlineColor:"AccentColor",outlineStyle:"solid",outlineWidth:theme.variables.size.spacing.xxxs,outlineOffset:-2},...!disabled&&{"&:hover":{backgroundColor:destructive?theme.values.color.destructiveTertiaryButton.background.hover:theme.values.color.background.secondary.hover},"&:active":{color:destructive?theme.values.color.text.error.default:theme.values.color.text.primary.default}},...disabled&&{opacity:theme.variables.opacity.disabled,cursor:"not-allowed"},..."s"===size&&{padding:theme.variables.size.spacing.xs},..."m"===size&&{padding:theme.variables.size.spacing.s},..."l"===size&&{padding:theme.variables.size.spacing.m}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRHJvcGRvd25NZW51L01lbnVJdGVtLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRHJvcGRvd25NZW51L01lbnVJdGVtLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB0eXBlIHsgQnV0dG9uU2l6ZSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBJY29uTmFtZSB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IEljb24gfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBJbmxpbmUgfSBmcm9tIFwiLi4vSW5saW5lL0lubGluZVwiO1xuXG5leHBvcnQgdHlwZSBNZW51SXRlbVByb3BzID0ge1xuICAvKiogVGhlIHRleHQgZm9yIHRoZSBtZW51IGl0ZW0gKi9cbiAgbGFiZWw6IHN0cmluZztcbiAgLyoqIFRoZSBzaXplIG9mIHRoZSBtZW51IGl0ZW0gKi9cbiAgc2l6ZT86IEJ1dHRvblNpemU7XG4gIC8qKiBNZW51IGl0ZW0gZGlzYWJsZWQgc3RhdGUgKi9cbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICAvKiogSW5kaWNhdGVzIHdoZXRoZXIgdGhlIG1lbnUgaXRlbSBpcyBkZXN0cnVjdGl2ZS4gKi9cbiAgZGVzdHJ1Y3RpdmU/OiBib29sZWFuO1xuICAvKiogT24gc2VsZWN0IG1lbnUgaXRlbSBjYWxsYmFjayAqL1xuICBvblNlbGVjdDogKGU6IFJlYWN0Lk1vdXNlRXZlbnQpID0+IHZvaWQ7XG4gIC8qIEljb24gbmFtZSAqL1xuICBpY29uPzogSWNvbk5hbWU7XG4gIC8qIEVtcGhhc2l6ZWQgYnkgXCJkb3RcIiByaWdodCBpY29uICovXG4gIGVtcGhhc2l6ZWQ/OiBib29sZWFuO1xuICAvKiBUZXh0IHRyYW5zZm9ybSAodXBwZXJjYXNlIGFzIGRlZmF1bHQpICovXG4gIHRleHRWYXJpYW50PzogXCJ1cHBlcmNhc2VcIiB8IFwiY2FwaXRhbGl6ZVwiIHwgXCJsb3dlcmNhc2VcIiB8IFwibm9uZVwiO1xuICBvbkJsdXI/OiAoZTogUmVhY3QuRm9jdXNFdmVudCkgPT4gdm9pZDtcbn07XG5cbmNvbnN0IFN0eWxlZE1lbnVJdGVtID0gc3R5bGVkLmJ1dHRvbjxQYXJ0aWFsPE1lbnVJdGVtUHJvcHM+PihcbiAgKHsgdGhlbWUsIHNpemUsIHRleHRWYXJpYW50LCBkZXN0cnVjdGl2ZSwgZGlzYWJsZWQgfSkgPT4gKHtcbiAgICBcIiZbdHlwZT0nYnV0dG9uJ11cIjoge1xuICAgICAgYXBwZWFyYW5jZTogXCJub25lXCIsXG4gICAgICBNb3pBcHBlYXJhbmNlOiBcIm5vbmVcIixcbiAgICAgIFdlYmtpdEFwcGVhcmFuY2U6IFwibm9uZVwiLFxuICAgIH0sXG4gICAgZGlzcGxheTogXCJpbmxpbmUtYmxvY2tcIixcbiAgICB3aWR0aDogXCIxMDAlXCIsXG4gICAgYm9yZGVyOiAwLFxuICAgIGNvbG9yOiBkZXN0cnVjdGl2ZVxuICAgICAgPyB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC5lcnJvci5kZWZhdWx0XG4gICAgICA6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnNlY29uZGFyeS5kZWZhdWx0LFxuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICAgIHRleHRUcmFuc2Zvcm06IHRleHRWYXJpYW50IHx8IFwidXBwZXJjYXNlXCIsXG4gICAgdGV4dERlY29yYXRpb246IFwibm9uZVwiLFxuICAgIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gICAgZm9udFNpemU6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmZvbnQueHMsXG4gICAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC5tLFxuICAgIGxldHRlclNwYWNpbmc6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxldHRlclNwYWNpbmcucyxcbiAgICBmb250V2VpZ2h0OiB0aGVtZS52YXJpYWJsZXMud2VpZ2h0LmJvbGQsXG4gICAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgICBcIiY6Zm9jdXMtdmlzaWJsZVwiOiB7XG4gICAgICBvdXRsaW5lQ29sb3I6IFwiQWNjZW50Q29sb3JcIixcbiAgICAgIG91dGxpbmVTdHlsZTogXCJzb2xpZFwiLFxuICAgICAgb3V0bGluZVdpZHRoOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4eHMsXG4gICAgICBvdXRsaW5lT2Zmc2V0OiAtMixcbiAgICB9LFxuICAgIC4uLighZGlzYWJsZWQgJiYge1xuICAgICAgXCImOmhvdmVyXCI6IHtcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiBkZXN0cnVjdGl2ZVxuICAgICAgICAgID8gdGhlbWUudmFsdWVzLmNvbG9yLmRlc3RydWN0aXZlVGVydGlhcnlCdXR0b24uYmFja2dyb3VuZC5ob3ZlclxuICAgICAgICAgIDogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuc2Vjb25kYXJ5LmhvdmVyLFxuICAgICAgfSxcbiAgICAgIFwiJjphY3RpdmVcIjoge1xuICAgICAgICBjb2xvcjogZGVzdHJ1Y3RpdmVcbiAgICAgICAgICA/IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LmVycm9yLmRlZmF1bHRcbiAgICAgICAgICA6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnByaW1hcnkuZGVmYXVsdCxcbiAgICAgIH0sXG4gICAgfSksXG4gICAgLi4uKGRpc2FibGVkICYmIHtcbiAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmRpc2FibGVkLFxuICAgICAgY3Vyc29yOiBcIm5vdC1hbGxvd2VkXCIsXG4gICAgfSksXG4gICAgLi4uKHNpemUgPT09IFwic1wiICYmIHtcbiAgICAgIHBhZGRpbmc6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gICAgfSksXG4gICAgLi4uKHNpemUgPT09IFwibVwiICYmIHtcbiAgICAgIHBhZGRpbmc6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcucyxcbiAgICB9KSxcbiAgICAuLi4oc2l6ZSA9PT0gXCJsXCIgJiYge1xuICAgICAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICAgIH0pLFxuICB9KVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIE1lbnVJdGVtKHtcbiAgbGFiZWwsXG4gIHNpemUgPSBcIm1cIixcbiAgZGlzYWJsZWQgPSBmYWxzZSxcbiAgb25TZWxlY3QsXG4gIGljb24sXG4gIGRlc3RydWN0aXZlLFxuICBlbXBoYXNpemVkID0gZmFsc2UsXG4gIHRleHRWYXJpYW50ID0gXCJ1cHBlcmNhc2VcIixcbiAgb25CbHVyLFxufTogTWVudUl0ZW1Qcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZE1lbnVJdGVtXG4gICAgICB0YWJJbmRleD17MH0gLy8gRm9yIFNhZmFyaSwgYmVjYXVzZSBidXR0b25zIGFyZSBub3QgZm9jdXNhYmxlIGJ5IGRlZmF1bHQgb24gaXQuXG4gICAgICBzaXplPXtzaXplfVxuICAgICAgZGVzdHJ1Y3RpdmU9e2Rlc3RydWN0aXZlfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgb25DbGljaz17b25TZWxlY3R9XG4gICAgICB0ZXh0VmFyaWFudD17dGV4dFZhcmlhbnR9XG4gICAgICBvbkJsdXI9e29uQmx1cn1cbiAgICA+XG4gICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgYWxpZ25JdGVtcz1cImxlZnRcIiBzcGFjZT1cInh4c1wiIG5vV3JhcD5cbiAgICAgICAge2ljb24gJiYgKFxuICAgICAgICAgIDxJY29uXG4gICAgICAgICAgICBzaXplPVwic1wiXG4gICAgICAgICAgICBuYW1lPXtpY29ufVxuICAgICAgICAgICAgZGF0YS10ZXN0aWQ9e2BtZW51SXRlbS0ke2ljb259YH1cbiAgICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2BtZW51SXRlbS0ke2ljb259YH1cbiAgICAgICAgICAvPlxuICAgICAgICApfVxuICAgICAgICB7bGFiZWx9XG4gICAgICAgIHtlbXBoYXNpemVkICYmIChcbiAgICAgICAgICA8SWNvblxuICAgICAgICAgICAgc2l6ZT1cInNcIlxuICAgICAgICAgICAgY29sb3I9XCJlcnJvclwiXG4gICAgICAgICAgICBuYW1lPVwiZG90XCJcbiAgICAgICAgICAgIGRhdGEtdGVzdGlkPVwibWVudUl0ZW0tZW1waGFzaXplZFwiXG4gICAgICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPVwibWVudUl0ZW0tZW1waGFzaXplZFwiXG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgIDwvSW5saW5lPlxuICAgIDwvU3R5bGVkTWVudUl0ZW0+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkJ1QiJ9 */");function MenuItem({label,size="m",disabled=!1,onSelect,icon,destructive,emphasized=!1,textVariant="uppercase",onBlur}){return _react.default.createElement(StyledMenuItem,{tabIndex:0,size:size,destructive:destructive,disabled:disabled,onClick:onSelect,textVariant:textVariant,onBlur:onBlur},_react.default.createElement(_Inline.Inline,{vAlignItems:"center",alignItems:"left",space:"xxs",noWrap:!0},icon&&_react.default.createElement(_Icon.Icon,{size:"s",name:icon,"data-testid":`menuItem-${icon}`,"data-e2e-test-id":`menuItem-${icon}`}),label,emphasized&&_react.default.createElement(_Icon.Icon,{size:"s",color:"error",name:"dot","data-testid":"menuItem-emphasized","data-e2e-test-id":"menuItem-emphasized"})))}
|
|
@@ -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))))))}
|
package/build/cjs/index.d.ts
CHANGED
|
@@ -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";
|
package/build/cjs/index.js
CHANGED
|
@@ -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/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;
|
|
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;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import React from"react";import styled from"@emotion/styled";import{Icon}from"../Icon/Icon";import{Inline}from"../Inline/Inline";let StyledMenuItem=styled("button",{target:"
|
|
1
|
+
import React from"react";import styled from"@emotion/styled";import{Icon}from"../Icon/Icon";import{Inline}from"../Inline/Inline";let StyledMenuItem=styled("button",{target:"e5e5fy60",label:"StyledMenuItem"})(({theme,size,textVariant,destructive,disabled})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},display:"inline-block",width:"100%",border:0,color:destructive?theme.values.color.text.error.default:theme.values.color.text.secondary.default,backgroundColor:theme.values.color.background.primary.default,textTransform:textVariant||"uppercase",textDecoration:"none",fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.xs,lineHeight:theme.variables.size.lineHeight.m,letterSpacing:theme.variables.size.letterSpacing.s,fontWeight:theme.variables.weight.bold,cursor:"pointer","&:focus-visible":{outlineColor:"AccentColor",outlineStyle:"solid",outlineWidth:theme.variables.size.spacing.xxxs,outlineOffset:-2},...!disabled&&{"&:hover":{backgroundColor:destructive?theme.values.color.destructiveTertiaryButton.background.hover:theme.values.color.background.secondary.hover},"&:active":{color:destructive?theme.values.color.text.error.default:theme.values.color.text.primary.default}},...disabled&&{opacity:theme.variables.opacity.disabled,cursor:"not-allowed"},..."s"===size&&{padding:theme.variables.size.spacing.xs},..."m"===size&&{padding:theme.variables.size.spacing.s},..."l"===size&&{padding:theme.variables.size.spacing.m}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRHJvcGRvd25NZW51L01lbnVJdGVtLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRHJvcGRvd25NZW51L01lbnVJdGVtLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCB0eXBlIHsgQnV0dG9uU2l6ZSB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHR5cGUgeyBJY29uTmFtZSB9IGZyb20gXCIuLi9JY29uL0ljb25cIjtcbmltcG9ydCB7IEljb24gfSBmcm9tIFwiLi4vSWNvbi9JY29uXCI7XG5pbXBvcnQgeyBJbmxpbmUgfSBmcm9tIFwiLi4vSW5saW5lL0lubGluZVwiO1xuXG5leHBvcnQgdHlwZSBNZW51SXRlbVByb3BzID0ge1xuICAvKiogVGhlIHRleHQgZm9yIHRoZSBtZW51IGl0ZW0gKi9cbiAgbGFiZWw6IHN0cmluZztcbiAgLyoqIFRoZSBzaXplIG9mIHRoZSBtZW51IGl0ZW0gKi9cbiAgc2l6ZT86IEJ1dHRvblNpemU7XG4gIC8qKiBNZW51IGl0ZW0gZGlzYWJsZWQgc3RhdGUgKi9cbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICAvKiogSW5kaWNhdGVzIHdoZXRoZXIgdGhlIG1lbnUgaXRlbSBpcyBkZXN0cnVjdGl2ZS4gKi9cbiAgZGVzdHJ1Y3RpdmU/OiBib29sZWFuO1xuICAvKiogT24gc2VsZWN0IG1lbnUgaXRlbSBjYWxsYmFjayAqL1xuICBvblNlbGVjdDogKGU6IFJlYWN0Lk1vdXNlRXZlbnQpID0+IHZvaWQ7XG4gIC8qIEljb24gbmFtZSAqL1xuICBpY29uPzogSWNvbk5hbWU7XG4gIC8qIEVtcGhhc2l6ZWQgYnkgXCJkb3RcIiByaWdodCBpY29uICovXG4gIGVtcGhhc2l6ZWQ/OiBib29sZWFuO1xuICAvKiBUZXh0IHRyYW5zZm9ybSAodXBwZXJjYXNlIGFzIGRlZmF1bHQpICovXG4gIHRleHRWYXJpYW50PzogXCJ1cHBlcmNhc2VcIiB8IFwiY2FwaXRhbGl6ZVwiIHwgXCJsb3dlcmNhc2VcIiB8IFwibm9uZVwiO1xuICBvbkJsdXI/OiAoZTogUmVhY3QuRm9jdXNFdmVudCkgPT4gdm9pZDtcbn07XG5cbmNvbnN0IFN0eWxlZE1lbnVJdGVtID0gc3R5bGVkLmJ1dHRvbjxQYXJ0aWFsPE1lbnVJdGVtUHJvcHM+PihcbiAgKHsgdGhlbWUsIHNpemUsIHRleHRWYXJpYW50LCBkZXN0cnVjdGl2ZSwgZGlzYWJsZWQgfSkgPT4gKHtcbiAgICBcIiZbdHlwZT0nYnV0dG9uJ11cIjoge1xuICAgICAgYXBwZWFyYW5jZTogXCJub25lXCIsXG4gICAgICBNb3pBcHBlYXJhbmNlOiBcIm5vbmVcIixcbiAgICAgIFdlYmtpdEFwcGVhcmFuY2U6IFwibm9uZVwiLFxuICAgIH0sXG4gICAgZGlzcGxheTogXCJpbmxpbmUtYmxvY2tcIixcbiAgICB3aWR0aDogXCIxMDAlXCIsXG4gICAgYm9yZGVyOiAwLFxuICAgIGNvbG9yOiBkZXN0cnVjdGl2ZVxuICAgICAgPyB0aGVtZS52YWx1ZXMuY29sb3IudGV4dC5lcnJvci5kZWZhdWx0XG4gICAgICA6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnNlY29uZGFyeS5kZWZhdWx0LFxuICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICAgIHRleHRUcmFuc2Zvcm06IHRleHRWYXJpYW50IHx8IFwidXBwZXJjYXNlXCIsXG4gICAgdGV4dERlY29yYXRpb246IFwibm9uZVwiLFxuICAgIGZvbnRGYW1pbHk6IHRoZW1lLnZhcmlhYmxlcy5mb250RmFtaWx5LmxhdG8sXG4gICAgZm9udFNpemU6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmZvbnQueHMsXG4gICAgbGluZUhlaWdodDogdGhlbWUudmFyaWFibGVzLnNpemUubGluZUhlaWdodC5tLFxuICAgIGxldHRlclNwYWNpbmc6IHRoZW1lLnZhcmlhYmxlcy5zaXplLmxldHRlclNwYWNpbmcucyxcbiAgICBmb250V2VpZ2h0OiB0aGVtZS52YXJpYWJsZXMud2VpZ2h0LmJvbGQsXG4gICAgY3Vyc29yOiBcInBvaW50ZXJcIixcbiAgICBcIiY6Zm9jdXMtdmlzaWJsZVwiOiB7XG4gICAgICBvdXRsaW5lQ29sb3I6IFwiQWNjZW50Q29sb3JcIixcbiAgICAgIG91dGxpbmVTdHlsZTogXCJzb2xpZFwiLFxuICAgICAgb3V0bGluZVdpZHRoOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnh4eHMsXG4gICAgICBvdXRsaW5lT2Zmc2V0OiAtMixcbiAgICB9LFxuICAgIC4uLighZGlzYWJsZWQgJiYge1xuICAgICAgXCImOmhvdmVyXCI6IHtcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiBkZXN0cnVjdGl2ZVxuICAgICAgICAgID8gdGhlbWUudmFsdWVzLmNvbG9yLmRlc3RydWN0aXZlVGVydGlhcnlCdXR0b24uYmFja2dyb3VuZC5ob3ZlclxuICAgICAgICAgIDogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQuc2Vjb25kYXJ5LmhvdmVyLFxuICAgICAgfSxcbiAgICAgIFwiJjphY3RpdmVcIjoge1xuICAgICAgICBjb2xvcjogZGVzdHJ1Y3RpdmVcbiAgICAgICAgICA/IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LmVycm9yLmRlZmF1bHRcbiAgICAgICAgICA6IHRoZW1lLnZhbHVlcy5jb2xvci50ZXh0LnByaW1hcnkuZGVmYXVsdCxcbiAgICAgIH0sXG4gICAgfSksXG4gICAgLi4uKGRpc2FibGVkICYmIHtcbiAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmRpc2FibGVkLFxuICAgICAgY3Vyc29yOiBcIm5vdC1hbGxvd2VkXCIsXG4gICAgfSksXG4gICAgLi4uKHNpemUgPT09IFwic1wiICYmIHtcbiAgICAgIHBhZGRpbmc6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHMsXG4gICAgfSksXG4gICAgLi4uKHNpemUgPT09IFwibVwiICYmIHtcbiAgICAgIHBhZGRpbmc6IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcucyxcbiAgICB9KSxcbiAgICAuLi4oc2l6ZSA9PT0gXCJsXCIgJiYge1xuICAgICAgcGFkZGluZzogdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5tLFxuICAgIH0pLFxuICB9KVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIE1lbnVJdGVtKHtcbiAgbGFiZWwsXG4gIHNpemUgPSBcIm1cIixcbiAgZGlzYWJsZWQgPSBmYWxzZSxcbiAgb25TZWxlY3QsXG4gIGljb24sXG4gIGRlc3RydWN0aXZlLFxuICBlbXBoYXNpemVkID0gZmFsc2UsXG4gIHRleHRWYXJpYW50ID0gXCJ1cHBlcmNhc2VcIixcbiAgb25CbHVyLFxufTogTWVudUl0ZW1Qcm9wcyk6IFJlYWN0LlJlYWN0RWxlbWVudCB7XG4gIHJldHVybiAoXG4gICAgPFN0eWxlZE1lbnVJdGVtXG4gICAgICB0YWJJbmRleD17MH0gLy8gRm9yIFNhZmFyaSwgYmVjYXVzZSBidXR0b25zIGFyZSBub3QgZm9jdXNhYmxlIGJ5IGRlZmF1bHQgb24gaXQuXG4gICAgICBzaXplPXtzaXplfVxuICAgICAgZGVzdHJ1Y3RpdmU9e2Rlc3RydWN0aXZlfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgb25DbGljaz17b25TZWxlY3R9XG4gICAgICB0ZXh0VmFyaWFudD17dGV4dFZhcmlhbnR9XG4gICAgICBvbkJsdXI9e29uQmx1cn1cbiAgICA+XG4gICAgICA8SW5saW5lIHZBbGlnbkl0ZW1zPVwiY2VudGVyXCIgYWxpZ25JdGVtcz1cImxlZnRcIiBzcGFjZT1cInh4c1wiIG5vV3JhcD5cbiAgICAgICAge2ljb24gJiYgKFxuICAgICAgICAgIDxJY29uXG4gICAgICAgICAgICBzaXplPVwic1wiXG4gICAgICAgICAgICBuYW1lPXtpY29ufVxuICAgICAgICAgICAgZGF0YS10ZXN0aWQ9e2BtZW51SXRlbS0ke2ljb259YH1cbiAgICAgICAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2BtZW51SXRlbS0ke2ljb259YH1cbiAgICAgICAgICAvPlxuICAgICAgICApfVxuICAgICAgICB7bGFiZWx9XG4gICAgICAgIHtlbXBoYXNpemVkICYmIChcbiAgICAgICAgICA8SWNvblxuICAgICAgICAgICAgc2l6ZT1cInNcIlxuICAgICAgICAgICAgY29sb3I9XCJlcnJvclwiXG4gICAgICAgICAgICBuYW1lPVwiZG90XCJcbiAgICAgICAgICAgIGRhdGEtdGVzdGlkPVwibWVudUl0ZW0tZW1waGFzaXplZFwiXG4gICAgICAgICAgICBkYXRhLWUyZS10ZXN0LWlkPVwibWVudUl0ZW0tZW1waGFzaXplZFwiXG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgIDwvSW5saW5lPlxuICAgIDwvU3R5bGVkTWVudUl0ZW0+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkJ1QiJ9 */");export function MenuItem({label,size="m",disabled=!1,onSelect,icon,destructive,emphasized=!1,textVariant="uppercase",onBlur}){return React.createElement(StyledMenuItem,{tabIndex:0,size:size,destructive:destructive,disabled:disabled,onClick:onSelect,textVariant:textVariant,onBlur:onBlur},React.createElement(Inline,{vAlignItems:"center",alignItems:"left",space:"xxs",noWrap:!0},icon&&React.createElement(Icon,{size:"s",name:icon,"data-testid":`menuItem-${icon}`,"data-e2e-test-id":`menuItem-${icon}`}),label,emphasized&&React.createElement(Icon,{size:"s",color:"error",name:"dot","data-testid":"menuItem-emphasized","data-e2e-test-id":"menuItem-emphasized"})))}
|
|
@@ -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))))))}
|
package/build/esm/index.d.ts
CHANGED
|
@@ -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";
|
package/build/esm/index.js
CHANGED
|
@@ -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/ContentPictogramButton/ContentPictogramButton";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";
|