@amboss/design-system 3.42.3 → 3.43.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cjs/components/NavBar/NavBar.d.ts +1 -0
- package/build/cjs/components/NavBar/NavBar.js +1 -1
- package/build/cjs/components/NavBar/NavBarPrimaryNavLinkItem.d.ts +2 -0
- package/build/cjs/components/NavBar/NavBarPrimaryNavLinkItem.js +1 -1
- package/build/cjs/components/NavBar/constants.d.ts +6 -0
- package/build/cjs/components/NavBar/constants.js +1 -1
- package/build/cjs/components/PromptInput/PromptInput.d.ts +2 -2
- package/build/cjs/components/PromptInput/PromptInput.js +1 -1
- package/build/cjs/components/PromptInput/PromptTextArea.d.ts +0 -6
- package/build/cjs/components/PromptInput/PromptTextArea.js +1 -1
- package/build/cjs/components/RoundButton/RoundButton.d.ts +4 -2
- package/build/cjs/components/RoundButton/RoundButton.js +1 -1
- package/build/cjs/components/Utilities/AnimatedBorder/useAnimatedBorder.d.ts +13 -0
- package/build/cjs/components/Utilities/AnimatedBorder/useAnimatedBorder.js +79 -0
- package/build/cjs/index.d.ts +1 -1
- package/build/cjs/index.js +1 -1
- package/build/cjs/web-tokens/visualConfig.d.ts +8 -0
- package/build/cjs/web-tokens/visualConfig.js +1 -1
- package/build/esm/components/NavBar/NavBar.d.ts +1 -0
- package/build/esm/components/NavBar/NavBar.js +1 -1
- package/build/esm/components/NavBar/NavBarPrimaryNavLinkItem.d.ts +2 -0
- package/build/esm/components/NavBar/NavBarPrimaryNavLinkItem.js +1 -1
- package/build/esm/components/NavBar/constants.d.ts +6 -0
- package/build/esm/components/NavBar/constants.js +1 -1
- package/build/esm/components/PromptInput/PromptInput.d.ts +2 -2
- package/build/esm/components/PromptInput/PromptInput.js +1 -1
- package/build/esm/components/PromptInput/PromptTextArea.d.ts +0 -6
- package/build/esm/components/PromptInput/PromptTextArea.js +1 -1
- package/build/esm/components/RoundButton/RoundButton.d.ts +4 -2
- package/build/esm/components/RoundButton/RoundButton.js +1 -1
- package/build/esm/components/Utilities/AnimatedBorder/useAnimatedBorder.d.ts +13 -0
- package/build/esm/components/Utilities/AnimatedBorder/useAnimatedBorder.js +79 -0
- package/build/esm/index.d.ts +1 -1
- package/build/esm/index.js +1 -1
- package/build/esm/web-tokens/visualConfig.d.ts +8 -0
- package/build/esm/web-tokens/visualConfig.js +1 -1
- package/build/scss/_variables.scss +7 -3
- package/package.json +1 -1
- package/build/cjs/components/Utilities/AnimatedBorder/AnimatedBorder.d.ts +0 -24
- package/build/cjs/components/Utilities/AnimatedBorder/AnimatedBorder.js +0 -4
- package/build/esm/components/Utilities/AnimatedBorder/AnimatedBorder.d.ts +0 -24
- package/build/esm/components/Utilities/AnimatedBorder/AnimatedBorder.js +0 -4
|
@@ -13,6 +13,7 @@ export declare namespace NavBar {
|
|
|
13
13
|
label: string;
|
|
14
14
|
isActive?: boolean;
|
|
15
15
|
as?: React.ElementType;
|
|
16
|
+
to?: string;
|
|
16
17
|
} & Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, "children"> & React.RefAttributes<HTMLAnchorElement>>;
|
|
17
18
|
var SubMenuContainer: React.ForwardRefExoticComponent<{
|
|
18
19
|
"data-e2e-test-id"?: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"NavBar",{enumerable:!0,get:function(){return NavBar}});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")),_NavBarSubMenuContainer=require("./NavBarSubMenuContainer"),_NavBarDropdownTriggerButton=require("./NavBarDropdownTriggerButton"),_NavBarSearchInput=require("./NavBarSearchInput"),_NavBarOverlayBar=require("./NavBarOverlayBar"),_NavBarPrimaryNav=require("./NavBarPrimaryNav"),_NavBarPrimaryNavLinkItem=require("./NavBarPrimaryNavLinkItem"),_NavBarSecondaryNav=require("./NavBarSecondaryNav"),_NavBarContext=require("./NavBarContext"),_types=require("./types"),_useKeyboard=require("../../shared/useKeyboard"),CustomBorderContainer=(0,_styled.default)(_NavBarSubMenuContainer.StyledBorderContainer,{target:"ekhnzl10",label:"CustomBorderContainer"})({position:"relative"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTmF2QmFyL05hdkJhci50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL05hdkJhci9OYXZCYXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VNZW1vLCB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBSZWZPYmplY3QgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHtcbiAgTmF2QmFyU3ViTWVudUNvbnRhaW5lcixcbiAgU3R5bGVkQm9yZGVyQ29udGFpbmVyLFxufSBmcm9tIFwiLi9OYXZCYXJTdWJNZW51Q29udGFpbmVyXCI7XG5pbXBvcnQgeyBOYXZCYXJEcm9wZG93blRyaWdnZXJCdXR0b24gfSBmcm9tIFwiLi9OYXZCYXJEcm9wZG93blRyaWdnZXJCdXR0b25cIjtcbmltcG9ydCB7IE5hdkJhclNlYXJjaElucHV0IH0gZnJvbSBcIi4vTmF2QmFyU2VhcmNoSW5wdXRcIjtcbmltcG9ydCB7IE5hdkJhck92ZXJsYXlCYXIgfSBmcm9tIFwiLi9OYXZCYXJPdmVybGF5QmFyXCI7XG5pbXBvcnQgeyBQcmltYXJ5TmF2Q29udGFpbmVyLCBQcmltYXJ5TmF2IH0gZnJvbSBcIi4vTmF2QmFyUHJpbWFyeU5hdlwiO1xuaW1wb3J0IHsgUHJpbWFyeU5hdkxpbmtJdGVtIH0gZnJvbSBcIi4vTmF2QmFyUHJpbWFyeU5hdkxpbmtJdGVtXCI7XG5pbXBvcnQgeyBTZWNvbmRhcnlOYXYgfSBmcm9tIFwiLi9OYXZCYXJTZWNvbmRhcnlOYXZcIjtcbmltcG9ydCB7IE5hdkJhckNvbnRleHQgfSBmcm9tIFwiLi9OYXZCYXJDb250ZXh0XCI7XG5pbXBvcnQgeyBOYXZCYXJOYW1lIH0gZnJvbSBcIi4vdHlwZXNcIjtcbmltcG9ydCB7IHVzZUtleWJvYXJkIH0gZnJvbSBcIi4uLy4uL3NoYXJlZC91c2VLZXlib2FyZFwiO1xuXG5jb25zdCBDdXN0b21Cb3JkZXJDb250YWluZXIgPSBzdHlsZWQoU3R5bGVkQm9yZGVyQ29udGFpbmVyKSh7XG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KTtcblxudHlwZSBOYXZCYXJQcm9wcyA9IFJlYWN0LlByb3BzV2l0aENoaWxkcmVuPHtcbiAgc3ViVGhlbWU6IE5hdkJhck5hbWU7XG4gIGlzQ29tcGFjdDogYm9vbGVhbjtcbn0+O1xuXG5jb25zdCBmb2N1c05hdkl0ZW0gPSAoXG4gIG5hdjogSFRNTEVsZW1lbnQgfCBudWxsLFxuICBkaXJlY3Rpb246IFwibmV4dFwiIHwgXCJwcmV2XCJcbik6IHZvaWQgPT4ge1xuICBpZiAoIW5hdikgcmV0dXJuO1xuXG4gIGNvbnN0IGl0ZW1zID0gQXJyYXkuZnJvbShuYXYucXVlcnlTZWxlY3RvckFsbDxIVE1MRWxlbWVudD4oXCJbdGFiaW5kZXhdXCIpKTtcbiAgaWYgKGl0ZW1zLmxlbmd0aCA9PT0gMCkgcmV0dXJuO1xuXG4gIGNvbnN0IGN1cnJlbnRJbmRleCA9IGl0ZW1zLmluZGV4T2YoZG9jdW1lbnQuYWN0aXZlRWxlbWVudCBhcyBIVE1MRWxlbWVudCk7XG4gIGlmIChjdXJyZW50SW5kZXggPT09IC0xKSByZXR1cm47XG5cbiAgY29uc3QgbmV4dEluZGV4ID0gZGlyZWN0aW9uID09PSBcIm5leHRcIiA/IGN1cnJlbnRJbmRleCArIDEgOiBjdXJyZW50SW5kZXggLSAxO1xuXG4gIGlmIChuZXh0SW5kZXggPCAwIHx8IG5leHRJbmRleCA+PSBpdGVtcy5sZW5ndGgpIHJldHVybjtcblxuICBpdGVtc1tjdXJyZW50SW5kZXhdLnNldEF0dHJpYnV0ZShcInRhYmluZGV4XCIsIFwiLTFcIik7XG4gIGl0ZW1zW25leHRJbmRleF0uc2V0QXR0cmlidXRlKFwidGFiaW5kZXhcIiwgXCIwXCIpO1xuICBpdGVtc1tuZXh0SW5kZXhdLmZvY3VzKCk7XG59O1xuXG5jb25zdCBmb2N1c1RhYmJhYmxlSXRlbSA9IChuYXY6IEhUTUxFbGVtZW50IHwgbnVsbCk6IHZvaWQgPT4ge1xuICBuYXY/LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KFwiW3RhYmluZGV4PScwJ11cIik/LmZvY3VzKCk7XG59O1xuXG5jb25zdCByZXNldFRhYkluZGV4ID0gKG5hdjogSFRNTEVsZW1lbnQpOiB2b2lkID0+IHtcbiAgY29uc3QgaXRlbXMgPSBBcnJheS5mcm9tKG5hdi5xdWVyeVNlbGVjdG9yQWxsPEhUTUxFbGVtZW50PihcIlt0YWJpbmRleF1cIikpO1xuICBjb25zdCBhY3RpdmVJdGVtID0gbmF2LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KFwiW2FyaWEtY3VycmVudD0ncGFnZSddXCIpO1xuICBjb25zdCB0YXJnZXQgPSBhY3RpdmVJdGVtID8/IGl0ZW1zWzBdO1xuXG4gIGZvciAoY29uc3QgaXRlbSBvZiBpdGVtcykge1xuICAgIGl0ZW0uc2V0QXR0cmlidXRlKFwidGFiaW5kZXhcIiwgaXRlbSA9PT0gdGFyZ2V0ID8gXCIwXCIgOiBcIi0xXCIpO1xuICB9XG59O1xuXG5jb25zdCB1c2VSZXNldFRhYkluZGV4T25CbHVyID0gKFxuICBuYXZSZWY6IFJlZk9iamVjdDxIVE1MRWxlbWVudCB8IG51bGw+XG4pOiB2b2lkID0+IHtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCBuYXYgPSBuYXZSZWYuY3VycmVudDtcbiAgICBpZiAoIW5hdikgcmV0dXJuIHVuZGVmaW5lZDtcblxuICAgIGNvbnN0IGhhbmRsZUZvY3VzT3V0ID0gKGU6IEZvY3VzRXZlbnQpID0+IHtcbiAgICAgIGlmICghbmF2LmNvbnRhaW5zKGUucmVsYXRlZFRhcmdldCBhcyBOb2RlKSkge1xuICAgICAgICByZXNldFRhYkluZGV4KG5hdik7XG4gICAgICB9XG4gICAgfTtcblxuICAgIG5hdi5hZGRFdmVudExpc3RlbmVyKFwiZm9jdXNvdXRcIiwgaGFuZGxlRm9jdXNPdXQpO1xuICAgIHJldHVybiAoKSA9PiBuYXYucmVtb3ZlRXZlbnRMaXN0ZW5lcihcImZvY3Vzb3V0XCIsIGhhbmRsZUZvY3VzT3V0KTtcbiAgfSwgW25hdlJlZl0pO1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIE5hdkJhcih7XG4gIGNoaWxkcmVuLFxuICBzdWJUaGVtZSA9IE5hdkJhck5hbWUuVW5zZXQsXG4gIGlzQ29tcGFjdCA9IGZhbHNlLFxufTogTmF2QmFyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwcmltYXJ5TmF2UmVmID0gdXNlUmVmPEhUTUxFbGVtZW50PihudWxsKTtcbiAgY29uc3Qgc2Vjb25kYXJ5TmF2UmVmID0gdXNlUmVmPEhUTUxFbGVtZW50PihudWxsKTtcblxuICBjb25zdCBjb250ZXh0VmFsdWUgPSB1c2VNZW1vKFxuICAgICgpID0+ICh7IHN1YlRoZW1lLCBpc0NvbXBhY3QsIHByaW1hcnlOYXZSZWYsIHNlY29uZGFyeU5hdlJlZiB9KSxcbiAgICBbc3ViVGhlbWUsIGlzQ29tcGFjdF1cbiAgKTtcblxuICB1c2VSZXNldFRhYkluZGV4T25CbHVyKHByaW1hcnlOYXZSZWYpO1xuICB1c2VSZXNldFRhYkluZGV4T25CbHVyKHNlY29uZGFyeU5hdlJlZik7XG5cbiAgdXNlS2V5Ym9hcmQoXG4gICAge1xuICAgICAgQXJyb3dSaWdodDogKCkgPT4gZm9jdXNOYXZJdGVtKHByaW1hcnlOYXZSZWYuY3VycmVudCwgXCJuZXh0XCIpLFxuICAgICAgQXJyb3dMZWZ0OiAoKSA9PiBmb2N1c05hdkl0ZW0ocHJpbWFyeU5hdlJlZi5jdXJyZW50LCBcInByZXZcIiksXG4gICAgfSxcbiAgICBwcmltYXJ5TmF2UmVmLFxuICAgIHRydWVcbiAgKTtcblxuICB1c2VLZXlib2FyZChcbiAgICB7IEFycm93RG93bjogKCkgPT4gZm9jdXNUYWJiYWJsZUl0ZW0oc2Vjb25kYXJ5TmF2UmVmLmN1cnJlbnQpIH0sXG4gICAgcHJpbWFyeU5hdlJlZixcbiAgICAhaXNDb21wYWN0XG4gICk7XG5cbiAgdXNlS2V5Ym9hcmQoXG4gICAge1xuICAgICAgQXJyb3dSaWdodDogKCkgPT4gZm9jdXNOYXZJdGVtKHNlY29uZGFyeU5hdlJlZi5jdXJyZW50LCBcIm5leHRcIiksXG4gICAgICBBcnJvd0xlZnQ6ICgpID0+IGZvY3VzTmF2SXRlbShzZWNvbmRhcnlOYXZSZWYuY3VycmVudCwgXCJwcmV2XCIpLFxuICAgICAgQXJyb3dVcDogKCkgPT4gZm9jdXNUYWJiYWJsZUl0ZW0ocHJpbWFyeU5hdlJlZi5jdXJyZW50KSxcbiAgICB9LFxuICAgIHNlY29uZGFyeU5hdlJlZixcbiAgICAhaXNDb21wYWN0XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8TmF2QmFyQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17Y29udGV4dFZhbHVlfT5cbiAgICAgIDxDdXN0b21Cb3JkZXJDb250YWluZXI+e2NoaWxkcmVufTwvQ3VzdG9tQm9yZGVyQ29udGFpbmVyPlxuICAgIDwvTmF2QmFyQ29udGV4dC5Qcm92aWRlcj5cbiAgKTtcbn1cblxuTmF2QmFyLlByaW1hcnlOYXZDb250YWluZXIgPSBQcmltYXJ5TmF2Q29udGFpbmVyO1xuTmF2QmFyLlByaW1hcnlOYXYgPSBQcmltYXJ5TmF2O1xuTmF2QmFyLlByaW1hcnlOYXZJdGVtID0gUHJpbWFyeU5hdkxpbmtJdGVtO1xuTmF2QmFyLlN1Yk1lbnVDb250YWluZXIgPSBOYXZCYXJTdWJNZW51Q29udGFpbmVyO1xuTmF2QmFyLk92ZXJsYXlCYXIgPSBOYXZCYXJPdmVybGF5QmFyO1xuTmF2QmFyLlNlY29uZGFyeU5hdiA9IFNlY29uZGFyeU5hdjtcbk5hdkJhci5Ecm9wZG93blRyaWdnZXJCdXR0b24gPSBOYXZCYXJEcm9wZG93blRyaWdnZXJCdXR0b247XG5OYXZCYXIuU2VhcmNoSW5wdXQgPSBOYXZCYXJTZWFyY2hJbnB1dDtcbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQjhCIn0= */"),focusNavItem=(nav,direction)=>{if(!nav)return;let items=Array.from(nav.querySelectorAll("[tabindex]"));if(0===items.length)return;let currentIndex=items.indexOf(document.activeElement);if(-1===currentIndex)return;let nextIndex="next"===direction?currentIndex+1:currentIndex-1;nextIndex<0||nextIndex>=items.length||(items[currentIndex].setAttribute("tabindex","-1"),items[nextIndex].setAttribute("tabindex","0"),items[nextIndex].focus())},focusTabbableItem=nav=>{nav?.querySelector("[tabindex='0']")?.focus()},resetTabIndex=nav=>{let items=Array.from(nav.querySelectorAll("[tabindex]")),target=nav.querySelector("[aria-current='page']")??items[0];for(let item of items)item.setAttribute("tabindex",item===target?"0":"-1")},useResetTabIndexOnBlur=navRef=>{(0,_react.useEffect)(()=>{let nav=navRef.current;if(!nav)return;let handleFocusOut=e=>{nav.contains(e.relatedTarget)||resetTabIndex(nav)};return nav.addEventListener("focusout",handleFocusOut),()=>nav.removeEventListener("focusout",handleFocusOut)},[navRef])};function NavBar({children,subTheme=_types.NavBarName.Unset,isCompact=!1}){let primaryNavRef=(0,_react.useRef)(null),secondaryNavRef=(0,_react.useRef)(null),contextValue=(0,_react.useMemo)(()=>({subTheme,isCompact,primaryNavRef,secondaryNavRef}),[subTheme,isCompact]);return useResetTabIndexOnBlur(primaryNavRef),useResetTabIndexOnBlur(secondaryNavRef),(0,_useKeyboard.useKeyboard)({ArrowRight:()=>focusNavItem(primaryNavRef.current,"next"),ArrowLeft:()=>focusNavItem(primaryNavRef.current,"prev")},primaryNavRef,!0),(0,_useKeyboard.useKeyboard)({ArrowDown:()=>focusTabbableItem(secondaryNavRef.current)},primaryNavRef,!isCompact),(0,_useKeyboard.useKeyboard)({ArrowRight:()=>focusNavItem(secondaryNavRef.current,"next"),ArrowLeft:()=>focusNavItem(secondaryNavRef.current,"prev"),ArrowUp:()=>focusTabbableItem(primaryNavRef.current)},secondaryNavRef,!isCompact),_react.default.createElement(_NavBarContext.NavBarContext.Provider,{value:contextValue},_react.default.createElement(CustomBorderContainer,null,children))}NavBar.PrimaryNavContainer=_NavBarPrimaryNav.PrimaryNavContainer,NavBar.PrimaryNav=_NavBarPrimaryNav.PrimaryNav,NavBar.PrimaryNavItem=_NavBarPrimaryNavLinkItem.PrimaryNavLinkItem,NavBar.SubMenuContainer=_NavBarSubMenuContainer.NavBarSubMenuContainer,NavBar.OverlayBar=_NavBarOverlayBar.NavBarOverlayBar,NavBar.SecondaryNav=_NavBarSecondaryNav.SecondaryNav,NavBar.DropdownTriggerButton=_NavBarDropdownTriggerButton.NavBarDropdownTriggerButton,NavBar.SearchInput=_NavBarSearchInput.NavBarSearchInput;
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"NavBar",{enumerable:!0,get:function(){return NavBar}});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")),_NavBarSubMenuContainer=require("./NavBarSubMenuContainer"),_NavBarDropdownTriggerButton=require("./NavBarDropdownTriggerButton"),_NavBarSearchInput=require("./NavBarSearchInput"),_NavBarOverlayBar=require("./NavBarOverlayBar"),_NavBarPrimaryNav=require("./NavBarPrimaryNav"),_NavBarPrimaryNavLinkItem=require("./NavBarPrimaryNavLinkItem"),_NavBarSecondaryNav=require("./NavBarSecondaryNav"),_NavBarContext=require("./NavBarContext"),_types=require("./types"),_constants=require("./constants"),_useKeyboard=require("../../shared/useKeyboard"),CustomBorderContainer=(0,_styled.default)(_NavBarSubMenuContainer.StyledBorderContainer,{target:"e1c296f0",label:"CustomBorderContainer"})({position:"relative"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvTmF2QmFyL05hdkJhci50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL05hdkJhci9OYXZCYXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VNZW1vLCB1c2VFZmZlY3QsIHVzZVJlZiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHR5cGUgeyBSZWZPYmplY3QgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHtcbiAgTmF2QmFyU3ViTWVudUNvbnRhaW5lcixcbiAgU3R5bGVkQm9yZGVyQ29udGFpbmVyLFxufSBmcm9tIFwiLi9OYXZCYXJTdWJNZW51Q29udGFpbmVyXCI7XG5pbXBvcnQgeyBOYXZCYXJEcm9wZG93blRyaWdnZXJCdXR0b24gfSBmcm9tIFwiLi9OYXZCYXJEcm9wZG93blRyaWdnZXJCdXR0b25cIjtcbmltcG9ydCB7IE5hdkJhclNlYXJjaElucHV0IH0gZnJvbSBcIi4vTmF2QmFyU2VhcmNoSW5wdXRcIjtcbmltcG9ydCB7IE5hdkJhck92ZXJsYXlCYXIgfSBmcm9tIFwiLi9OYXZCYXJPdmVybGF5QmFyXCI7XG5pbXBvcnQgeyBQcmltYXJ5TmF2Q29udGFpbmVyLCBQcmltYXJ5TmF2IH0gZnJvbSBcIi4vTmF2QmFyUHJpbWFyeU5hdlwiO1xuaW1wb3J0IHsgUHJpbWFyeU5hdkxpbmtJdGVtIH0gZnJvbSBcIi4vTmF2QmFyUHJpbWFyeU5hdkxpbmtJdGVtXCI7XG5pbXBvcnQgeyBTZWNvbmRhcnlOYXYgfSBmcm9tIFwiLi9OYXZCYXJTZWNvbmRhcnlOYXZcIjtcbmltcG9ydCB7IE5hdkJhckNvbnRleHQgfSBmcm9tIFwiLi9OYXZCYXJDb250ZXh0XCI7XG5pbXBvcnQgeyBOYXZCYXJOYW1lIH0gZnJvbSBcIi4vdHlwZXNcIjtcbmltcG9ydCB7IFRSQU5TSVRJT05JTkdfREFUQVNFVF9LRVkgfSBmcm9tIFwiLi9jb25zdGFudHNcIjtcbmltcG9ydCB7IHVzZUtleWJvYXJkIH0gZnJvbSBcIi4uLy4uL3NoYXJlZC91c2VLZXlib2FyZFwiO1xuXG5jb25zdCBDdXN0b21Cb3JkZXJDb250YWluZXIgPSBzdHlsZWQoU3R5bGVkQm9yZGVyQ29udGFpbmVyKSh7XG4gIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG59KTtcblxudHlwZSBOYXZCYXJQcm9wcyA9IFJlYWN0LlByb3BzV2l0aENoaWxkcmVuPHtcbiAgc3ViVGhlbWU6IE5hdkJhck5hbWU7XG4gIGlzQ29tcGFjdDogYm9vbGVhbjtcbn0+O1xuXG5jb25zdCBmb2N1c05hdkl0ZW0gPSAoXG4gIG5hdjogSFRNTEVsZW1lbnQgfCBudWxsLFxuICBkaXJlY3Rpb246IFwibmV4dFwiIHwgXCJwcmV2XCJcbik6IHZvaWQgPT4ge1xuICBpZiAoIW5hdikgcmV0dXJuO1xuXG4gIGNvbnN0IGl0ZW1zID0gQXJyYXkuZnJvbShuYXYucXVlcnlTZWxlY3RvckFsbDxIVE1MRWxlbWVudD4oXCJbdGFiaW5kZXhdXCIpKTtcbiAgaWYgKGl0ZW1zLmxlbmd0aCA9PT0gMCkgcmV0dXJuO1xuXG4gIGNvbnN0IGN1cnJlbnRJbmRleCA9IGl0ZW1zLmluZGV4T2YoZG9jdW1lbnQuYWN0aXZlRWxlbWVudCBhcyBIVE1MRWxlbWVudCk7XG4gIGlmIChjdXJyZW50SW5kZXggPT09IC0xKSByZXR1cm47XG5cbiAgY29uc3QgbmV4dEluZGV4ID0gZGlyZWN0aW9uID09PSBcIm5leHRcIiA/IGN1cnJlbnRJbmRleCArIDEgOiBjdXJyZW50SW5kZXggLSAxO1xuXG4gIGlmIChuZXh0SW5kZXggPCAwIHx8IG5leHRJbmRleCA+PSBpdGVtcy5sZW5ndGgpIHJldHVybjtcblxuICBpdGVtc1tjdXJyZW50SW5kZXhdLnNldEF0dHJpYnV0ZShcInRhYmluZGV4XCIsIFwiLTFcIik7XG4gIGl0ZW1zW25leHRJbmRleF0uc2V0QXR0cmlidXRlKFwidGFiaW5kZXhcIiwgXCIwXCIpO1xuICBpdGVtc1tuZXh0SW5kZXhdLmZvY3VzKCk7XG59O1xuXG5jb25zdCBmb2N1c1RhYmJhYmxlSXRlbSA9IChuYXY6IEhUTUxFbGVtZW50IHwgbnVsbCk6IHZvaWQgPT4ge1xuICBuYXY/LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KFwiW3RhYmluZGV4PScwJ11cIik/LmZvY3VzKCk7XG59O1xuXG5jb25zdCByZXNldFRhYkluZGV4ID0gKG5hdjogSFRNTEVsZW1lbnQpOiB2b2lkID0+IHtcbiAgY29uc3QgaXRlbXMgPSBBcnJheS5mcm9tKG5hdi5xdWVyeVNlbGVjdG9yQWxsPEhUTUxFbGVtZW50PihcIlt0YWJpbmRleF1cIikpO1xuICBjb25zdCBhY3RpdmVJdGVtID0gbmF2LnF1ZXJ5U2VsZWN0b3I8SFRNTEVsZW1lbnQ+KFwiW2FyaWEtY3VycmVudD0ncGFnZSddXCIpO1xuICBjb25zdCB0YXJnZXQgPSBhY3RpdmVJdGVtID8/IGl0ZW1zWzBdO1xuXG4gIGZvciAoY29uc3QgaXRlbSBvZiBpdGVtcykge1xuICAgIGl0ZW0uc2V0QXR0cmlidXRlKFwidGFiaW5kZXhcIiwgaXRlbSA9PT0gdGFyZ2V0ID8gXCIwXCIgOiBcIi0xXCIpO1xuICB9XG59O1xuXG5jb25zdCB1c2VSZXNldFRhYkluZGV4T25CbHVyID0gKFxuICBuYXZSZWY6IFJlZk9iamVjdDxIVE1MRWxlbWVudCB8IG51bGw+XG4pOiB2b2lkID0+IHtcbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBjb25zdCBuYXYgPSBuYXZSZWYuY3VycmVudDtcbiAgICBpZiAoIW5hdikgcmV0dXJuIHVuZGVmaW5lZDtcblxuICAgIGNvbnN0IGhhbmRsZUZvY3VzT3V0ID0gKGU6IEZvY3VzRXZlbnQpID0+IHtcbiAgICAgIGlmICghbmF2LmNvbnRhaW5zKGUucmVsYXRlZFRhcmdldCBhcyBOb2RlKSkge1xuICAgICAgICByZXNldFRhYkluZGV4KG5hdik7XG4gICAgICB9XG4gICAgfTtcblxuICAgIG5hdi5hZGRFdmVudExpc3RlbmVyKFwiZm9jdXNvdXRcIiwgaGFuZGxlRm9jdXNPdXQpO1xuICAgIHJldHVybiAoKSA9PiBuYXYucmVtb3ZlRXZlbnRMaXN0ZW5lcihcImZvY3Vzb3V0XCIsIGhhbmRsZUZvY3VzT3V0KTtcbiAgfSwgW25hdlJlZl0pO1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIE5hdkJhcih7XG4gIGNoaWxkcmVuLFxuICBzdWJUaGVtZSA9IE5hdkJhck5hbWUuVW5zZXQsXG4gIGlzQ29tcGFjdCA9IGZhbHNlLFxufTogTmF2QmFyUHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICBjb25zdCBwcmltYXJ5TmF2UmVmID0gdXNlUmVmPEhUTUxFbGVtZW50PihudWxsKTtcbiAgY29uc3Qgc2Vjb25kYXJ5TmF2UmVmID0gdXNlUmVmPEhUTUxFbGVtZW50PihudWxsKTtcblxuICBjb25zdCByb290UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcbiAgY29uc3QgcHJldkNvbXBhY3RSZWYgPSB1c2VSZWYoaXNDb21wYWN0KTtcblxuICBjb25zdCBjb250ZXh0VmFsdWUgPSB1c2VNZW1vKFxuICAgICgpID0+ICh7IHN1YlRoZW1lLCBpc0NvbXBhY3QsIHByaW1hcnlOYXZSZWYsIHNlY29uZGFyeU5hdlJlZiB9KSxcbiAgICBbc3ViVGhlbWUsIGlzQ29tcGFjdF1cbiAgKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IGVsID0gcm9vdFJlZi5jdXJyZW50O1xuICAgIGlmICghZWwgfHwgcHJldkNvbXBhY3RSZWYuY3VycmVudCA9PT0gaXNDb21wYWN0KSByZXR1cm4gdW5kZWZpbmVkO1xuICAgIHByZXZDb21wYWN0UmVmLmN1cnJlbnQgPSBpc0NvbXBhY3Q7XG4gICAgZWwuZGF0YXNldFtUUkFOU0lUSU9OSU5HX0RBVEFTRVRfS0VZXSA9IFwiXCI7XG5cbiAgICAvLyBSZW1vdmUgdGhlIGZsYWcgd2hlbiB0aGUgdHJhbnNpdGlvbiBjb21wbGV0ZXMuIFRoZSBDU1Mgc3BlYyBzdGF0ZXMgYW5cbiAgICAvLyBpbi1mbGlnaHQgdHJhbnNpdGlvbiBjb250aW51ZXMgdW5hZmZlY3RlZCB3aGVuIHRyYW5zaXRpb24tZHVyYXRpb25cbiAgICAvLyBjaGFuZ2VzIHRvIDAgbWlkLXRyYW5zaXRpb24sIHNvIHRoZSBhbmltYXRpb24gZmluaXNoZXMgY29ycmVjdGx5IGV2ZW5cbiAgICAvLyB0aG91Z2ggdGhlIHNlbGVjdG9yIGBbZGF0YS10cmFuc2l0aW9uaW5nXSAuLi5gIHN0b3BzIG1hdGNoaW5nLlxuICAgIGNvbnN0IGhhbmRsZUVuZCA9ICgpID0+IHtcbiAgICAgIGRlbGV0ZSBlbC5kYXRhc2V0W1RSQU5TSVRJT05JTkdfREFUQVNFVF9LRVldO1xuICAgIH07XG4gICAgZWwuYWRkRXZlbnRMaXN0ZW5lcihcInRyYW5zaXRpb25lbmRcIiwgaGFuZGxlRW5kLCB7IG9uY2U6IHRydWUgfSk7XG4gICAgcmV0dXJuICgpID0+IGVsLnJlbW92ZUV2ZW50TGlzdGVuZXIoXCJ0cmFuc2l0aW9uZW5kXCIsIGhhbmRsZUVuZCk7XG4gIH0sIFtpc0NvbXBhY3RdKTtcblxuICB1c2VSZXNldFRhYkluZGV4T25CbHVyKHByaW1hcnlOYXZSZWYpO1xuICB1c2VSZXNldFRhYkluZGV4T25CbHVyKHNlY29uZGFyeU5hdlJlZik7XG5cbiAgdXNlS2V5Ym9hcmQoXG4gICAge1xuICAgICAgQXJyb3dSaWdodDogKCkgPT4gZm9jdXNOYXZJdGVtKHByaW1hcnlOYXZSZWYuY3VycmVudCwgXCJuZXh0XCIpLFxuICAgICAgQXJyb3dMZWZ0OiAoKSA9PiBmb2N1c05hdkl0ZW0ocHJpbWFyeU5hdlJlZi5jdXJyZW50LCBcInByZXZcIiksXG4gICAgfSxcbiAgICBwcmltYXJ5TmF2UmVmLFxuICAgIHRydWVcbiAgKTtcblxuICB1c2VLZXlib2FyZChcbiAgICB7IEFycm93RG93bjogKCkgPT4gZm9jdXNUYWJiYWJsZUl0ZW0oc2Vjb25kYXJ5TmF2UmVmLmN1cnJlbnQpIH0sXG4gICAgcHJpbWFyeU5hdlJlZixcbiAgICAhaXNDb21wYWN0XG4gICk7XG5cbiAgdXNlS2V5Ym9hcmQoXG4gICAge1xuICAgICAgQXJyb3dSaWdodDogKCkgPT4gZm9jdXNOYXZJdGVtKHNlY29uZGFyeU5hdlJlZi5jdXJyZW50LCBcIm5leHRcIiksXG4gICAgICBBcnJvd0xlZnQ6ICgpID0+IGZvY3VzTmF2SXRlbShzZWNvbmRhcnlOYXZSZWYuY3VycmVudCwgXCJwcmV2XCIpLFxuICAgICAgQXJyb3dVcDogKCkgPT4gZm9jdXNUYWJiYWJsZUl0ZW0ocHJpbWFyeU5hdlJlZi5jdXJyZW50KSxcbiAgICB9LFxuICAgIHNlY29uZGFyeU5hdlJlZixcbiAgICAhaXNDb21wYWN0XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8TmF2QmFyQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17Y29udGV4dFZhbHVlfT5cbiAgICAgIHsvKiBkYXRhLWNvbXBhY3QgYXR0cmlidXRlIG5hbWUgaXMgZGVmaW5lZCBhcyBDT01QQUNUX0FUVFIgaW4gY29uc3RhbnRzLnRzICovfVxuICAgICAgPEN1c3RvbUJvcmRlckNvbnRhaW5lciByZWY9e3Jvb3RSZWZ9IGRhdGEtY29tcGFjdD17aXNDb21wYWN0fT5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9DdXN0b21Cb3JkZXJDb250YWluZXI+XG4gICAgPC9OYXZCYXJDb250ZXh0LlByb3ZpZGVyPlxuICApO1xufVxuXG5OYXZCYXIuUHJpbWFyeU5hdkNvbnRhaW5lciA9IFByaW1hcnlOYXZDb250YWluZXI7XG5OYXZCYXIuUHJpbWFyeU5hdiA9IFByaW1hcnlOYXY7XG5OYXZCYXIuUHJpbWFyeU5hdkl0ZW0gPSBQcmltYXJ5TmF2TGlua0l0ZW07XG5OYXZCYXIuU3ViTWVudUNvbnRhaW5lciA9IE5hdkJhclN1Yk1lbnVDb250YWluZXI7XG5OYXZCYXIuT3ZlcmxheUJhciA9IE5hdkJhck92ZXJsYXlCYXI7XG5OYXZCYXIuU2Vjb25kYXJ5TmF2ID0gU2Vjb25kYXJ5TmF2O1xuTmF2QmFyLkRyb3Bkb3duVHJpZ2dlckJ1dHRvbiA9IE5hdkJhckRyb3Bkb3duVHJpZ2dlckJ1dHRvbjtcbk5hdkJhci5TZWFyY2hJbnB1dCA9IE5hdkJhclNlYXJjaElucHV0O1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtCOEIifQ== */"),focusNavItem=(nav,direction)=>{if(!nav)return;let items=Array.from(nav.querySelectorAll("[tabindex]"));if(0===items.length)return;let currentIndex=items.indexOf(document.activeElement);if(-1===currentIndex)return;let nextIndex="next"===direction?currentIndex+1:currentIndex-1;nextIndex<0||nextIndex>=items.length||(items[currentIndex].setAttribute("tabindex","-1"),items[nextIndex].setAttribute("tabindex","0"),items[nextIndex].focus())},focusTabbableItem=nav=>{nav?.querySelector("[tabindex='0']")?.focus()},resetTabIndex=nav=>{let items=Array.from(nav.querySelectorAll("[tabindex]")),target=nav.querySelector("[aria-current='page']")??items[0];for(let item of items)item.setAttribute("tabindex",item===target?"0":"-1")},useResetTabIndexOnBlur=navRef=>{(0,_react.useEffect)(()=>{let nav=navRef.current;if(!nav)return;let handleFocusOut=e=>{nav.contains(e.relatedTarget)||resetTabIndex(nav)};return nav.addEventListener("focusout",handleFocusOut),()=>nav.removeEventListener("focusout",handleFocusOut)},[navRef])};function NavBar({children,subTheme=_types.NavBarName.Unset,isCompact=!1}){let primaryNavRef=(0,_react.useRef)(null),secondaryNavRef=(0,_react.useRef)(null),rootRef=(0,_react.useRef)(null),prevCompactRef=(0,_react.useRef)(isCompact),contextValue=(0,_react.useMemo)(()=>({subTheme,isCompact,primaryNavRef,secondaryNavRef}),[subTheme,isCompact]);return(0,_react.useEffect)(()=>{let el=rootRef.current;if(!el||prevCompactRef.current===isCompact)return;prevCompactRef.current=isCompact,el.dataset[_constants.TRANSITIONING_DATASET_KEY]="";let handleEnd=()=>{delete el.dataset[_constants.TRANSITIONING_DATASET_KEY]};return el.addEventListener("transitionend",handleEnd,{once:!0}),()=>el.removeEventListener("transitionend",handleEnd)},[isCompact]),useResetTabIndexOnBlur(primaryNavRef),useResetTabIndexOnBlur(secondaryNavRef),(0,_useKeyboard.useKeyboard)({ArrowRight:()=>focusNavItem(primaryNavRef.current,"next"),ArrowLeft:()=>focusNavItem(primaryNavRef.current,"prev")},primaryNavRef,!0),(0,_useKeyboard.useKeyboard)({ArrowDown:()=>focusTabbableItem(secondaryNavRef.current)},primaryNavRef,!isCompact),(0,_useKeyboard.useKeyboard)({ArrowRight:()=>focusNavItem(secondaryNavRef.current,"next"),ArrowLeft:()=>focusNavItem(secondaryNavRef.current,"prev"),ArrowUp:()=>focusTabbableItem(primaryNavRef.current)},secondaryNavRef,!isCompact),_react.default.createElement(_NavBarContext.NavBarContext.Provider,{value:contextValue},_react.default.createElement(CustomBorderContainer,{ref:rootRef,"data-compact":isCompact},children))}NavBar.PrimaryNavContainer=_NavBarPrimaryNav.PrimaryNavContainer,NavBar.PrimaryNav=_NavBarPrimaryNav.PrimaryNav,NavBar.PrimaryNavItem=_NavBarPrimaryNavLinkItem.PrimaryNavLinkItem,NavBar.SubMenuContainer=_NavBarSubMenuContainer.NavBarSubMenuContainer,NavBar.OverlayBar=_NavBarOverlayBar.NavBarOverlayBar,NavBar.SecondaryNav=_NavBarSecondaryNav.SecondaryNav,NavBar.DropdownTriggerButton=_NavBarDropdownTriggerButton.NavBarDropdownTriggerButton,NavBar.SearchInput=_NavBarSearchInput.NavBarSearchInput;
|
|
@@ -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(
|
|
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, "
|
|
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" | "
|
|
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;
|