@amboss/design-system 3.42.3 → 3.43.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.
Files changed (50) hide show
  1. package/build/cjs/components/Content/ContentTableModal/ContentTableModal.d.ts +16 -0
  2. package/build/cjs/components/Content/ContentTableModal/ContentTableModal.js +10 -0
  3. package/build/cjs/components/Content/ContentTableModal/ContentTableModal.mocks.d.ts +3 -0
  4. package/build/cjs/components/Content/ContentTableModal/ContentTableModal.mocks.js +1 -0
  5. package/build/cjs/components/NavBar/NavBar.d.ts +1 -0
  6. package/build/cjs/components/NavBar/NavBar.js +1 -1
  7. package/build/cjs/components/NavBar/NavBarPrimaryNavLinkItem.d.ts +2 -0
  8. package/build/cjs/components/NavBar/NavBarPrimaryNavLinkItem.js +1 -1
  9. package/build/cjs/components/NavBar/constants.d.ts +6 -0
  10. package/build/cjs/components/NavBar/constants.js +1 -1
  11. package/build/cjs/components/PromptInput/PromptInput.d.ts +2 -2
  12. package/build/cjs/components/PromptInput/PromptInput.js +1 -1
  13. package/build/cjs/components/PromptInput/PromptTextArea.d.ts +0 -6
  14. package/build/cjs/components/PromptInput/PromptTextArea.js +1 -1
  15. package/build/cjs/components/RoundButton/RoundButton.d.ts +4 -2
  16. package/build/cjs/components/RoundButton/RoundButton.js +1 -1
  17. package/build/cjs/components/Utilities/AnimatedBorder/useAnimatedBorder.d.ts +13 -0
  18. package/build/cjs/components/Utilities/AnimatedBorder/useAnimatedBorder.js +79 -0
  19. package/build/cjs/index.d.ts +2 -1
  20. package/build/cjs/index.js +1 -1
  21. package/build/cjs/web-tokens/visualConfig.d.ts +8 -0
  22. package/build/cjs/web-tokens/visualConfig.js +1 -1
  23. package/build/esm/components/Content/ContentTableModal/ContentTableModal.d.ts +16 -0
  24. package/build/esm/components/Content/ContentTableModal/ContentTableModal.js +10 -0
  25. package/build/esm/components/Content/ContentTableModal/ContentTableModal.mocks.d.ts +3 -0
  26. package/build/esm/components/Content/ContentTableModal/ContentTableModal.mocks.js +1 -0
  27. package/build/esm/components/NavBar/NavBar.d.ts +1 -0
  28. package/build/esm/components/NavBar/NavBar.js +1 -1
  29. package/build/esm/components/NavBar/NavBarPrimaryNavLinkItem.d.ts +2 -0
  30. package/build/esm/components/NavBar/NavBarPrimaryNavLinkItem.js +1 -1
  31. package/build/esm/components/NavBar/constants.d.ts +6 -0
  32. package/build/esm/components/NavBar/constants.js +1 -1
  33. package/build/esm/components/PromptInput/PromptInput.d.ts +2 -2
  34. package/build/esm/components/PromptInput/PromptInput.js +1 -1
  35. package/build/esm/components/PromptInput/PromptTextArea.d.ts +0 -6
  36. package/build/esm/components/PromptInput/PromptTextArea.js +1 -1
  37. package/build/esm/components/RoundButton/RoundButton.d.ts +4 -2
  38. package/build/esm/components/RoundButton/RoundButton.js +1 -1
  39. package/build/esm/components/Utilities/AnimatedBorder/useAnimatedBorder.d.ts +13 -0
  40. package/build/esm/components/Utilities/AnimatedBorder/useAnimatedBorder.js +79 -0
  41. package/build/esm/index.d.ts +2 -1
  42. package/build/esm/index.js +1 -1
  43. package/build/esm/web-tokens/visualConfig.d.ts +8 -0
  44. package/build/esm/web-tokens/visualConfig.js +1 -1
  45. package/build/scss/_variables.scss +7 -3
  46. package/package.json +1 -1
  47. package/build/cjs/components/Utilities/AnimatedBorder/AnimatedBorder.d.ts +0 -24
  48. package/build/cjs/components/Utilities/AnimatedBorder/AnimatedBorder.js +0 -4
  49. package/build/esm/components/Utilities/AnimatedBorder/AnimatedBorder.d.ts +0 -24
  50. package/build/esm/components/Utilities/AnimatedBorder/AnimatedBorder.js +0 -4
@@ -3,9 +3,11 @@ export type PrimaryNavLinkItemProps = {
3
3
  label: string;
4
4
  isActive?: boolean;
5
5
  as?: React.ElementType;
6
+ to?: string;
6
7
  } & Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, "children">;
7
8
  export declare const PrimaryNavLinkItem: React.ForwardRefExoticComponent<{
8
9
  label: string;
9
10
  isActive?: boolean;
10
11
  as?: React.ElementType;
12
+ to?: string;
11
13
  } & Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, "children"> & React.RefAttributes<HTMLAnchorElement>>;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"PrimaryNavLinkItem",{enumerable:!0,get:function(){return PrimaryNavLinkItem}});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")),_SubThemeProvider=require("../SubThemeProvider/SubThemeProvider"),_NavBarContext=require("./NavBarContext"),StyledNavLink=(0,_styled.default)("a",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"isActive"!==prop&&"isCompact"!==prop&&"shouldAnimate"!==prop,target:"eg5higu0",label:"StyledNavLink"})(({theme,isActive,isCompact,shouldAnimate})=>{let{duration,delay,timingFunction}=theme.variables.animation.navBarTabButton.open,expanded=isActive&&!isCompact,size=theme.variables.size.spacing.s,shadowOffset=theme.variables.size.spacing.xxs,borderBottomRadius=`calc(${size} - ${shadowOffset})`,compactMarginBottom=theme.variables.size.spacing.xs,compactBottomRadius=theme.variables.size.borderRadius.xs,transitionsEnabled=!!shouldAnimate,baseTransitionDuration=transitionsEnabled?duration:"0ms",baseTransitionDelay="0ms",pseudoTransitionDelay="0ms";return transitionsEnabled&&(baseTransitionDelay=expanded?"unset":delay,pseudoTransitionDelay=expanded?delay:"unset"),{display:"inline-block",border:0,textTransform:"none",textDecoration:"none",position:"relative",zIndex:1,fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.s,lineHeight:theme.variables.size.lineHeight.xs,fontWeight:theme.variables.weight.bold,cursor:"pointer",background:"none",borderRadius:theme.variables.size.borderRadius.xs,padding:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,margin:`0 ${theme.variables.size.spacing.xxs}`,color:theme.values.color.text.tertiary.default,...!isActive&&{"&:hover":{backgroundColor:theme.values.color.background.transparent.hover},"&:active":{color:theme.values.color.text.primary.default,backgroundColor:theme.values.color.background.transparent.active}},marginBottom:compactMarginBottom,borderBottomLeftRadius:compactBottomRadius,borderBottomRightRadius:compactBottomRadius,transitionProperty:"margin-bottom, padding-bottom, border-bottom-left-radius, border-bottom-right-radius",transitionDuration:baseTransitionDuration,transitionTimingFunction:timingFunction,transitionDelay:baseTransitionDelay,"&:before, &:after":{content:'""',position:"absolute",bottom:0,zIndex:1,width:size,height:size,opacity:+!!expanded,transitionProperty:"opacity, transform, border-radius",transitionDuration:baseTransitionDuration,transitionTimingFunction:timingFunction,transitionDelay:pseudoTransitionDelay},"&:before":{transform:expanded?"scale(1) translate(-28px, 0)":"scale(0.5) translate(0px, -4px)",transformOrigin:"100% 100%",boxShadow:`${shadowOffset} ${shadowOffset} 0 ${theme.values.color.background.accentSubtle.default}`,borderBottomRightRadius:expanded?borderBottomRadius:0},"&:after":{transform:expanded?"scale(1) translate(16px, 0)":"scale(0.5) translate(0px, -4px)",transformOrigin:"100% 100%",boxShadow:`-${shadowOffset} ${shadowOffset} 0 ${theme.values.color.background.accentSubtle.default}`,borderBottomLeftRadius:expanded?borderBottomRadius:0},...isActive&&{zIndex:0,color:theme.values.color.text.accent.default,backgroundColor:theme.values.color.background.accentSubtle.default},...expanded&&{marginBottom:0,paddingBottom:`calc(${theme.variables.size.spacing.m} + ${shadowOffset})`,borderBottomLeftRadius:0,borderBottomRightRadius:0}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/NavBar/NavBarPrimaryNavLinkItem.tsx","sources":["src/components/NavBar/NavBarPrimaryNavLinkItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { useEffect, useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport { SubThemeProvider } from \"../SubThemeProvider/SubThemeProvider\";\nimport { useNavBarContext } from \"./NavBarContext\";\nimport type { NavBarName } from \"./types\";\n\nconst shouldForwardPropToLink = (prop: string) =>\n  isPropValid(prop) &&\n  prop !== \"isActive\" &&\n  prop !== \"isCompact\" &&\n  prop !== \"shouldAnimate\";\n\ntype StyledLinkTransientProps = {\n  isActive?: boolean;\n  isCompact?: boolean;\n  shouldAnimate?: boolean;\n};\n\nconst StyledNavLink = styled(\"a\", {\n  shouldForwardProp: shouldForwardPropToLink,\n})<StyledLinkTransientProps>(\n  ({ theme, isActive, isCompact, shouldAnimate }) => {\n    const { duration, delay, timingFunction } =\n      theme.variables.animation.navBarTabButton.open;\n    const expanded = isActive && !isCompact;\n    const size = theme.variables.size.spacing.s;\n    const shadowOffset = theme.variables.size.spacing.xxs;\n    const borderBottomRadius = `calc(${size} - ${shadowOffset})`;\n\n    const compactMarginBottom = theme.variables.size.spacing.xs;\n    const compactBottomRadius = theme.variables.size.borderRadius.xs;\n    const transitionsEnabled = Boolean(shouldAnimate);\n\n    const baseTransitionDuration = transitionsEnabled ? duration : \"0ms\";\n\n    let baseTransitionDelay = \"0ms\";\n    let pseudoTransitionDelay = \"0ms\";\n\n    if (transitionsEnabled) {\n      baseTransitionDelay = expanded ? \"unset\" : delay;\n      pseudoTransitionDelay = expanded ? delay : \"unset\";\n    }\n\n    return {\n      display: \"inline-block\",\n      border: 0,\n      textTransform: \"none\" as const,\n      textDecoration: \"none\",\n\n      position: \"relative\" as const,\n      zIndex: 1,\n\n      fontFamily: theme.variables.fontFamily.lato,\n      fontSize: theme.variables.size.font.s,\n      lineHeight: theme.variables.size.lineHeight.xs,\n      fontWeight: theme.variables.weight.bold,\n      cursor: \"pointer\",\n\n      background: \"none\",\n      borderRadius: theme.variables.size.borderRadius.xs,\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n      margin: `0 ${theme.variables.size.spacing.xxs}`,\n\n      color: theme.values.color.text.tertiary.default,\n\n      ...(!isActive && {\n        \"&:hover\": {\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: theme.values.color.text.primary.default,\n          backgroundColor: theme.values.color.background.transparent.active,\n        },\n      }),\n\n      marginBottom: compactMarginBottom,\n      borderBottomLeftRadius: compactBottomRadius,\n      borderBottomRightRadius: compactBottomRadius,\n\n      transitionProperty:\n        \"margin-bottom, padding-bottom, border-bottom-left-radius, border-bottom-right-radius\",\n      transitionDuration: baseTransitionDuration,\n      transitionTimingFunction: timingFunction,\n      transitionDelay: baseTransitionDelay,\n\n      \"&:before, &:after\": {\n        content: '\"\"',\n        position: \"absolute\" as const,\n        bottom: 0,\n        zIndex: 1,\n        width: size,\n        height: size,\n\n        opacity: expanded ? 1 : 0,\n\n        transitionProperty: \"opacity, transform, border-radius\",\n        transitionDuration: baseTransitionDuration,\n        transitionTimingFunction: timingFunction,\n        transitionDelay: pseudoTransitionDelay,\n      },\n\n      \"&:before\": {\n        transform: expanded\n          ? `scale(1) translate(-28px, 0)`\n          : `scale(0.5) translate(0px, -4px)`,\n        transformOrigin: \"100% 100%\",\n        boxShadow: `${shadowOffset} ${shadowOffset} 0 ${theme.values.color.background.accentSubtle.default}`,\n        borderBottomRightRadius: expanded ? borderBottomRadius : 0,\n      },\n\n      \"&:after\": {\n        transform: expanded\n          ? `scale(1) translate(16px, 0)`\n          : `scale(0.5) translate(0px, -4px)`,\n        transformOrigin: \"100% 100%\",\n        boxShadow: `-${shadowOffset} ${shadowOffset} 0 ${theme.values.color.background.accentSubtle.default}`,\n        borderBottomLeftRadius: expanded ? borderBottomRadius : 0,\n      },\n\n      ...(isActive && {\n        zIndex: 0,\n        color: theme.values.color.text.accent.default,\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n      }),\n\n      ...(expanded && {\n        marginBottom: 0,\n        paddingBottom: `calc(${theme.variables.size.spacing.m} + ${shadowOffset})`,\n        borderBottomLeftRadius: 0,\n        borderBottomRightRadius: 0,\n      }),\n    };\n  }\n);\n\nconst subThemeToActiveSubTheme: Record<\n  NavBarName,\n  \"brandSubtle\" | \"dimmedSubtle\" | undefined\n> = {\n  learning: \"brandSubtle\",\n  teaching: \"dimmedSubtle\",\n  clinicalCare: undefined,\n  unset: undefined,\n};\n\nexport type PrimaryNavLinkItemProps = {\n  label: string;\n  isActive?: boolean;\n  as?: React.ElementType;\n} & Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, \"children\">;\n\nexport const PrimaryNavLinkItem = React.forwardRef<\n  HTMLAnchorElement,\n  PrimaryNavLinkItemProps\n>(({ label, isActive, as: Component, ...rest }, ref) => {\n  const { subTheme, isCompact } = useNavBarContext();\n  const activeSubTheme = subThemeToActiveSubTheme[subTheme];\n  const tabIndex = isActive ? 0 : -1;\n\n  const previousIsCompactRef = useRef(isCompact);\n  const previousIsActiveRef = useRef(isActive);\n  const becameInactive =\n    previousIsActiveRef.current === true && isActive === false;\n  const shouldAnimate =\n    !becameInactive && previousIsCompactRef.current !== isCompact;\n\n  useEffect(() => {\n    previousIsCompactRef.current = isCompact;\n  }, [isCompact]);\n\n  useEffect(() => {\n    previousIsActiveRef.current = isActive;\n  }, [isActive]);\n\n  const resolvedSubTheme = isActive ? activeSubTheme : undefined;\n\n  return (\n    <SubThemeProvider name={resolvedSubTheme}>\n      <StyledNavLink\n        ref={ref}\n        as={Component}\n        data-ds-id=\"PrimaryNavLink\"\n        isActive={isActive}\n        isCompact={isCompact}\n        shouldAnimate={shouldAnimate}\n        aria-current={isActive ? \"page\" : undefined}\n        tabIndex={tabIndex}\n        {...rest}\n      >\n        {label}\n      </StyledNavLink>\n    </SubThemeProvider>\n  );\n});\n"],"names":[],"mappings":"AAoBsB"} */"),subThemeToActiveSubTheme={learning:"brandSubtle",teaching:"dimmedSubtle",clinicalCare:void 0,unset:void 0},PrimaryNavLinkItem=_react.default.forwardRef(({label,isActive,as:Component,...rest},ref)=>{let{subTheme,isCompact}=(0,_NavBarContext.useNavBarContext)(),activeSubTheme=subThemeToActiveSubTheme[subTheme],tabIndex=isActive?0:-1,previousIsCompactRef=(0,_react.useRef)(isCompact),previousIsActiveRef=(0,_react.useRef)(isActive),shouldAnimate=(!0!==previousIsActiveRef.current||!1!==isActive)&&previousIsCompactRef.current!==isCompact;(0,_react.useEffect)(()=>{previousIsCompactRef.current=isCompact},[isCompact]),(0,_react.useEffect)(()=>{previousIsActiveRef.current=isActive},[isActive]);let resolvedSubTheme=isActive?activeSubTheme:void 0;return _react.default.createElement(_SubThemeProvider.SubThemeProvider,{name:resolvedSubTheme},_react.default.createElement(StyledNavLink,{ref:ref,as:Component,"data-ds-id":"PrimaryNavLink",isActive:isActive,isCompact:isCompact,shouldAnimate:shouldAnimate,"aria-current":isActive?"page":void 0,tabIndex:tabIndex,...rest},label))});
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"PrimaryNavLinkItem",{enumerable:!0,get:function(){return PrimaryNavLinkItem}});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")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_SubThemeProvider=require("../SubThemeProvider/SubThemeProvider"),_NavBarContext=require("./NavBarContext"),_constants=require("./constants"),StyledNavLink=(0,_styled.default)("a",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"isActive"!==prop,target:"espdxys0",label:"StyledNavLink"})(({theme,isActive})=>{let{duration,delay,timingFunction}=theme.variables.animation.navBarTabButton.open,{timingFunction:closeTimingFunction}=theme.variables.animation.navBarTabButton.close,size=theme.variables.size.spacing.s,shadowOffset=theme.variables.size.spacing.xxs,borderBottomRadius=`calc(${size} - ${shadowOffset})`,compactMarginBottom=theme.variables.size.spacing.xs,compactBottomRadius=theme.variables.size.borderRadius.xs;return{display:"inline-block",border:0,textTransform:"none",textDecoration:"none",position:"relative",zIndex:1,fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.s,lineHeight:theme.variables.size.lineHeight.xs,fontWeight:theme.variables.weight.bold,cursor:"pointer",background:"none",borderRadius:theme.variables.size.borderRadius.xs,padding:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,margin:`0 ${theme.variables.size.spacing.xxs}`,color:theme.values.color.text.tertiary.default,marginBottom:compactMarginBottom,borderBottomLeftRadius:compactBottomRadius,borderBottomRightRadius:compactBottomRadius,transitionProperty:"margin-bottom, padding-bottom, border-bottom-left-radius, border-bottom-right-radius",transitionDuration:"0ms",transitionTimingFunction:timingFunction,transitionDelay:"0ms",...!isActive&&{"&:hover":{backgroundColor:theme.values.color.background.transparent.hover},"&:active":{color:theme.values.color.text.primary.default,backgroundColor:theme.values.color.background.transparent.active}},"&:before, &:after":{content:'""',position:"absolute",bottom:0,zIndex:1,width:size,height:size,opacity:0,transitionProperty:"opacity, transform, border-radius",transitionDuration:"0ms",transitionTimingFunction:timingFunction,transitionDelay:"0ms"},"&:before":{transform:"scale(0.5) translate(0px, -4px)",transformOrigin:"100% 100%",boxShadow:`${shadowOffset} ${shadowOffset} 0 ${theme.values.color.background.accentSubtle.default}`,borderBottomRightRadius:0},"&:after":{transform:"scale(0.5) translate(0px, -4px)",transformOrigin:"100% 100%",boxShadow:`-${shadowOffset} ${shadowOffset} 0 ${theme.values.color.background.accentSubtle.default}`,borderBottomLeftRadius:0},...isActive&&{zIndex:0,color:theme.values.color.text.accent.default,backgroundColor:theme.values.color.background.accentSubtle.default},[`${_constants.whenExpandedAncestor}[aria-current="page"]`]:{marginBottom:0,paddingBottom:`calc(${theme.variables.size.spacing.m} + ${shadowOffset})`,borderBottomLeftRadius:0,borderBottomRightRadius:0,"&:before, &:after":{opacity:1},"&:before":{transform:"scale(1) translate(-28px, 0)",borderBottomRightRadius:borderBottomRadius},"&:after":{transform:"scale(1) translate(16px, 0)",borderBottomLeftRadius:borderBottomRadius}},[`${_constants.whenTransitioningAndExpanded}[aria-current="page"]`]:{transitionDuration:duration,transitionDelay:"0ms","&:before, &:after":{transitionDuration:duration,transitionDelay:delay}},[`${_constants.whenTransitioningAndCompact}[aria-current="page"]`]:{transitionDuration:duration,transitionDelay:delay,transitionTimingFunction:closeTimingFunction,"&:before, &:after":{transitionDuration:duration,transitionDelay:"0ms",transitionTimingFunction:closeTimingFunction}}}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/NavBar/NavBarPrimaryNavLinkItem.tsx","sources":["src/components/NavBar/NavBarPrimaryNavLinkItem.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport isPropValid from \"@emotion/is-prop-valid\";\nimport { SubThemeProvider } from \"../SubThemeProvider/SubThemeProvider\";\nimport { useNavBarContext } from \"./NavBarContext\";\nimport {\n  whenExpandedAncestor,\n  whenTransitioningAndCompact,\n  whenTransitioningAndExpanded,\n} from \"./constants\";\nimport type { NavBarName } from \"./types\";\n\nconst shouldForwardPropToLink = (prop: string) =>\n  isPropValid(prop) && prop !== \"isActive\";\n\ntype StyledLinkTransientProps = {\n  isActive?: boolean;\n};\n\nconst StyledNavLink = styled(\"a\", {\n  shouldForwardProp: shouldForwardPropToLink,\n})<StyledLinkTransientProps>(({ theme, isActive }) => {\n  const { duration, delay, timingFunction } =\n    theme.variables.animation.navBarTabButton.open;\n  const { timingFunction: closeTimingFunction } =\n    theme.variables.animation.navBarTabButton.close;\n  const size = theme.variables.size.spacing.s;\n  const shadowOffset = theme.variables.size.spacing.xxs;\n  const borderBottomRadius = `calc(${size} - ${shadowOffset})`;\n  const compactMarginBottom = theme.variables.size.spacing.xs;\n  const compactBottomRadius = theme.variables.size.borderRadius.xs;\n\n  return {\n    display: \"inline-block\",\n    border: 0,\n    textTransform: \"none\" as const,\n    textDecoration: \"none\",\n\n    position: \"relative\" as const,\n    zIndex: 1,\n\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n\n    background: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.m}`,\n    margin: `0 ${theme.variables.size.spacing.xxs}`,\n\n    color: theme.values.color.text.tertiary.default,\n\n    marginBottom: compactMarginBottom,\n    borderBottomLeftRadius: compactBottomRadius,\n    borderBottomRightRadius: compactBottomRadius,\n\n    transitionProperty:\n      \"margin-bottom, padding-bottom, border-bottom-left-radius, border-bottom-right-radius\",\n    transitionDuration: \"0ms\",\n    transitionTimingFunction: timingFunction,\n    transitionDelay: \"0ms\",\n\n    ...(!isActive && {\n      \"&:hover\": {\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \"&:active\": {\n        color: theme.values.color.text.primary.default,\n        backgroundColor: theme.values.color.background.transparent.active,\n      },\n    }),\n\n    \"&:before, &:after\": {\n      content: '\"\"',\n      position: \"absolute\" as const,\n      bottom: 0,\n      zIndex: 1,\n      width: size,\n      height: size,\n      opacity: 0,\n      transitionProperty: \"opacity, transform, border-radius\",\n      transitionDuration: \"0ms\",\n      transitionTimingFunction: timingFunction,\n      transitionDelay: \"0ms\",\n    },\n\n    \"&:before\": {\n      transform: `scale(0.5) translate(0px, -4px)`,\n      transformOrigin: \"100% 100%\",\n      boxShadow: `${shadowOffset} ${shadowOffset} 0 ${theme.values.color.background.accentSubtle.default}`,\n      borderBottomRightRadius: 0,\n    },\n\n    \"&:after\": {\n      transform: `scale(0.5) translate(0px, -4px)`,\n      transformOrigin: \"100% 100%\",\n      boxShadow: `-${shadowOffset} ${shadowOffset} 0 ${theme.values.color.background.accentSubtle.default}`,\n      borderBottomLeftRadius: 0,\n    },\n\n    ...(isActive && {\n      zIndex: 0,\n      color: theme.values.color.text.accent.default,\n      backgroundColor: theme.values.color.background.accentSubtle.default,\n    }),\n\n    // Expanded = ancestor NavBar is not compact AND this is the active tab.\n    // Styles are driven by CSS selectors on ancestor/self attributes — no\n    // React re-render needed when `isCompact` flips.\n    [`${whenExpandedAncestor}[aria-current=\"page\"]`]: {\n      marginBottom: 0,\n      paddingBottom: `calc(${theme.variables.size.spacing.m} + ${shadowOffset})`,\n      borderBottomLeftRadius: 0,\n      borderBottomRightRadius: 0,\n\n      \"&:before, &:after\": {\n        opacity: 1,\n      },\n      \"&:before\": {\n        transform: `scale(1) translate(-28px, 0)`,\n        borderBottomRightRadius: borderBottomRadius,\n      },\n      \"&:after\": {\n        transform: `scale(1) translate(16px, 0)`,\n        borderBottomLeftRadius: borderBottomRadius,\n      },\n    },\n\n    // Expanding (compact -> expanded): base no delay, pseudo-elements delayed.\n    // Only applied on the active tab and only while NavBar sets data-transitioning.\n    // Tab switches do not set data-transitioning, so they snap instantly.\n    [`${whenTransitioningAndExpanded}[aria-current=\"page\"]`]: {\n      transitionDuration: duration,\n      transitionDelay: \"0ms\",\n      \"&:before, &:after\": {\n        transitionDuration: duration,\n        transitionDelay: delay,\n      },\n    },\n\n    // Collapsing (expanded -> compact): base delayed, pseudo-elements no delay.\n    // Uses the `close` timing function (ease-in) so the motion feels like a\n    // reversed version of the open ease-out — leaves rest, accelerates away.\n    [`${whenTransitioningAndCompact}[aria-current=\"page\"]`]: {\n      transitionDuration: duration,\n      transitionDelay: delay,\n      transitionTimingFunction: closeTimingFunction,\n      \"&:before, &:after\": {\n        transitionDuration: duration,\n        transitionDelay: \"0ms\",\n        transitionTimingFunction: closeTimingFunction,\n      },\n    },\n  };\n});\n\nconst subThemeToActiveSubTheme: Record<\n  NavBarName,\n  \"brandSubtle\" | \"dimmedSubtle\" | undefined\n> = {\n  learning: \"brandSubtle\",\n  teaching: \"dimmedSubtle\",\n  clinicalCare: undefined,\n  unset: undefined,\n};\n\nexport type PrimaryNavLinkItemProps = {\n  label: string;\n  isActive?: boolean;\n  as?: React.ElementType;\n  to?: string;\n} & Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, \"children\">;\n\nexport const PrimaryNavLinkItem = React.forwardRef<\n  HTMLAnchorElement,\n  PrimaryNavLinkItemProps\n>(({ label, isActive, as: Component, ...rest }, ref) => {\n  const { subTheme } = useNavBarContext();\n  const activeSubTheme = subThemeToActiveSubTheme[subTheme];\n  const tabIndex = isActive ? 0 : -1;\n  const resolvedSubTheme = isActive ? activeSubTheme : undefined;\n\n  return (\n    <SubThemeProvider name={resolvedSubTheme}>\n      <StyledNavLink\n        ref={ref}\n        as={Component}\n        data-ds-id=\"PrimaryNavLink\"\n        isActive={isActive}\n        aria-current={isActive ? \"page\" : undefined}\n        tabIndex={tabIndex}\n        {...rest}\n      >\n        {label}\n      </StyledNavLink>\n    </SubThemeProvider>\n  );\n});\n"],"names":[],"mappings":"AAoBsB"} */"),subThemeToActiveSubTheme={learning:"brandSubtle",teaching:"dimmedSubtle",clinicalCare:void 0,unset:void 0},PrimaryNavLinkItem=_react.default.forwardRef(({label,isActive,as:Component,...rest},ref)=>{let{subTheme}=(0,_NavBarContext.useNavBarContext)(),activeSubTheme=subThemeToActiveSubTheme[subTheme];return _react.default.createElement(_SubThemeProvider.SubThemeProvider,{name:isActive?activeSubTheme:void 0},_react.default.createElement(StyledNavLink,{ref:ref,as:Component,"data-ds-id":"PrimaryNavLink",isActive:isActive,"aria-current":isActive?"page":void 0,tabIndex:isActive?0:-1,...rest},label))});
@@ -3,3 +3,9 @@ export declare const NAV_BAR_Z_INDEX: {
3
3
  overlay: number;
4
4
  overlayContent: number;
5
5
  };
6
+ export declare const COMPACT_ATTR = "data-compact";
7
+ export declare const TRANSITIONING_ATTR = "data-transitioning";
8
+ export declare const TRANSITIONING_DATASET_KEY = "transitioning";
9
+ export declare const whenExpandedAncestor = "[data-compact=\"false\"] &";
10
+ export declare const whenTransitioningAndCompact = "[data-transitioning][data-compact=\"true\"] &";
11
+ export declare const whenTransitioningAndExpanded = "[data-transitioning][data-compact=\"false\"] &";
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"NAV_BAR_Z_INDEX",{enumerable:!0,get:function(){return NAV_BAR_Z_INDEX}});const NAV_BAR_Z_INDEX={primary:1,overlay:2,overlayContent:3};
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get COMPACT_ATTR(){return COMPACT_ATTR},get NAV_BAR_Z_INDEX(){return NAV_BAR_Z_INDEX},get TRANSITIONING_ATTR(){return TRANSITIONING_ATTR},get TRANSITIONING_DATASET_KEY(){return TRANSITIONING_DATASET_KEY},get whenExpandedAncestor(){return whenExpandedAncestor},get whenTransitioningAndCompact(){return whenTransitioningAndCompact},get whenTransitioningAndExpanded(){return whenTransitioningAndExpanded}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const NAV_BAR_Z_INDEX={primary:1,overlay:2,overlayContent:3},COMPACT_ATTR="data-compact",TRANSITIONING_ATTR="data-transitioning",TRANSITIONING_DATASET_KEY="transitioning",whenExpandedAncestor=`[${COMPACT_ATTR}="false"] &`,whenTransitioningAndCompact=`[${TRANSITIONING_ATTR}][${COMPACT_ATTR}="true"] &`,whenTransitioningAndExpanded=`[${TRANSITIONING_ATTR}][${COMPACT_ATTR}="false"] &`;
@@ -41,7 +41,7 @@ export type PromptInputProps = {
41
41
  onEnterKey: () => void;
42
42
  /** Renders an icon to the left inside the textarea */
43
43
  leftIcon?: IconName;
44
- } & Omit<PromptTextAreaProps, "isCollapsed" | "isAutocompleteListOpen" | "selectedListItem" | "hasLeftIcon"> & Pick<AutocompleteListProps, "autocompleteListItems" | "autocompleteListFooter" | "portalContainer">;
44
+ } & Omit<PromptTextAreaProps, "isAutocompleteListOpen" | "selectedListItem" | "hasLeftIcon"> & Pick<AutocompleteListProps, "autocompleteListItems" | "autocompleteListFooter" | "portalContainer">;
45
45
  declare const PromptInputComponent: React.ForwardRefExoticComponent<{
46
46
  "data-e2e-test-id"?: string;
47
47
  header?: BasePromptInputHeaderProps;
@@ -67,7 +67,7 @@ declare const PromptInputComponent: React.ForwardRefExoticComponent<{
67
67
  onEnterKey: () => void;
68
68
  /** Renders an icon to the left inside the textarea */
69
69
  leftIcon?: IconName;
70
- } & Omit<PromptTextAreaProps, "selectedListItem" | "isAutocompleteListOpen" | "isCollapsed" | "hasLeftIcon"> & Pick<AutocompleteListProps, "portalContainer" | "autocompleteListItems" | "autocompleteListFooter"> & React.RefAttributes<HTMLTextAreaElement>>;
70
+ } & Omit<PromptTextAreaProps, "selectedListItem" | "isAutocompleteListOpen" | "hasLeftIcon"> & Pick<AutocompleteListProps, "portalContainer" | "autocompleteListItems" | "autocompleteListFooter"> & React.RefAttributes<HTMLTextAreaElement>>;
71
71
  declare const SuggestionButton: React.ForwardRefExoticComponent<Omit<PolymorphicComponentPropsWithRef<React.ElementType<any, keyof React.JSX.IntrinsicElements>, Omit<ButtonProps, "ref" | "size" | "variant">>, "ref"> & React.RefAttributes<unknown>>;
72
72
  export declare const PromptInput: typeof PromptInputComponent & {
73
73
  SuggestionButton: typeof SuggestionButton;