@razorpay/blade 11.19.1 → 11.21.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/lib/native/components/Accordion/AccordionItem.js +1 -1
- package/build/lib/native/components/Accordion/AccordionItem.js.map +1 -1
- package/build/lib/native/components/Collapsible/Collapsible.js +1 -1
- package/build/lib/native/components/Collapsible/Collapsible.js.map +1 -1
- package/build/lib/native/components/Collapsible/CollapsibleBody.js +1 -1
- package/build/lib/native/components/Collapsible/CollapsibleBody.js.map +1 -1
- package/build/lib/native/components/Collapsible/CollapsibleBodyContent.native.js +1 -1
- package/build/lib/native/components/Collapsible/CollapsibleBodyContent.native.js.map +1 -1
- package/build/lib/native/components/Collapsible/CollapsibleLink.js +8 -1
- package/build/lib/native/components/Collapsible/CollapsibleLink.js.map +1 -1
- package/build/lib/native/components/Collapsible/commonStyles.js +1 -1
- package/build/lib/native/components/Collapsible/commonStyles.js.map +1 -1
- package/build/lib/native/components/ProgressBar/CircularProgressBar.native.js +1 -1
- package/build/lib/native/components/ProgressBar/CircularProgressBar.native.js.map +1 -1
- package/build/lib/native/components/SideNav/SideNav.native.js +17 -0
- package/build/lib/native/components/SideNav/SideNav.native.js.map +1 -0
- package/build/lib/native/components/SideNav/SideNavBody.native.js +17 -0
- package/build/lib/native/components/SideNav/SideNavBody.native.js.map +1 -0
- package/build/lib/native/components/SideNav/SideNavFooter.native.js +17 -0
- package/build/lib/native/components/SideNav/SideNavFooter.native.js.map +1 -0
- package/build/lib/native/components/SideNav/SideNavItems/SideNavItem.native.js +17 -0
- package/build/lib/native/components/SideNav/SideNavItems/SideNavItem.native.js.map +1 -0
- package/build/lib/native/components/SideNav/SideNavItems/SideNavLink.native.js +17 -0
- package/build/lib/native/components/SideNav/SideNavItems/SideNavLink.native.js.map +1 -0
- package/build/lib/native/components/SideNav/SideNavLevel.native.js +17 -0
- package/build/lib/native/components/SideNav/SideNavLevel.native.js.map +1 -0
- package/build/lib/native/components/SideNav/SideNavSection.native.js +17 -0
- package/build/lib/native/components/SideNav/SideNavSection.native.js.map +1 -0
- package/build/lib/native/components/Typography/BaseText/getBaseTextStyles.js +1 -1
- package/build/lib/native/components/Typography/BaseText/getBaseTextStyles.js.map +1 -1
- package/build/lib/native/components/index.js +7 -0
- package/build/lib/native/components/index.js.map +1 -1
- package/build/lib/native/tokens/global/size.js +1 -1
- package/build/lib/native/tokens/global/size.js.map +1 -1
- package/build/lib/native/utils/metaAttribute/metaConstants.js +1 -1
- package/build/lib/native/utils/metaAttribute/metaConstants.js.map +1 -1
- package/build/lib/web/development/components/Accordion/AccordionItem.js +1 -0
- package/build/lib/web/development/components/Accordion/AccordionItem.js.map +1 -1
- package/build/lib/web/development/components/Collapsible/Collapsible.js +4 -2
- package/build/lib/web/development/components/Collapsible/Collapsible.js.map +1 -1
- package/build/lib/web/development/components/Collapsible/CollapsibleBody.js +4 -1
- package/build/lib/web/development/components/Collapsible/CollapsibleBody.js.map +1 -1
- package/build/lib/web/development/components/Collapsible/CollapsibleBodyContent.web.js +4 -2
- package/build/lib/web/development/components/Collapsible/CollapsibleBodyContent.web.js.map +1 -1
- package/build/lib/web/development/components/Collapsible/CollapsibleLink.js +16 -4
- package/build/lib/web/development/components/Collapsible/CollapsibleLink.js.map +1 -1
- package/build/lib/web/development/components/Collapsible/commonStyles.js +5 -1
- package/build/lib/web/development/components/Collapsible/commonStyles.js.map +1 -1
- package/build/lib/web/development/components/DatePicker/Calendar.web.js +9 -5
- package/build/lib/web/development/components/DatePicker/Calendar.web.js.map +1 -1
- package/build/lib/web/development/components/DatePicker/CalendarStyles.web.js +40 -33
- package/build/lib/web/development/components/DatePicker/CalendarStyles.web.js.map +1 -1
- package/build/lib/web/development/components/DatePicker/DateInput.web.js +2 -1
- package/build/lib/web/development/components/DatePicker/DateInput.web.js.map +1 -1
- package/build/lib/web/development/components/DatePicker/DatePicker.web.js +5 -5
- package/build/lib/web/development/components/DatePicker/DatePicker.web.js.map +1 -1
- package/build/lib/web/development/components/DatePicker/shiftTimezone.js +39 -0
- package/build/lib/web/development/components/DatePicker/shiftTimezone.js.map +1 -0
- package/build/lib/web/development/components/DatePicker/useControlledDates.js +5 -8
- package/build/lib/web/development/components/DatePicker/useControlledDates.js.map +1 -1
- package/build/lib/web/development/components/DatePicker/utils.js +33 -1
- package/build/lib/web/development/components/DatePicker/utils.js.map +1 -1
- package/build/lib/web/development/components/Drawer/Drawer.web.js +25 -10
- package/build/lib/web/development/components/Drawer/Drawer.web.js.map +1 -1
- package/build/lib/web/development/components/Drawer/DrawerContext.js +3 -1
- package/build/lib/web/development/components/Drawer/DrawerContext.js.map +1 -1
- package/build/lib/web/development/components/Drawer/DrawerSubcomponents.web.js +26 -4
- package/build/lib/web/development/components/Drawer/DrawerSubcomponents.web.js.map +1 -1
- package/build/lib/web/development/components/Drawer/StackProvider.js +21 -12
- package/build/lib/web/development/components/Drawer/StackProvider.js.map +1 -1
- package/build/lib/web/development/components/Drawer/index.js +1 -1
- package/build/lib/web/development/components/FileUpload/FileUpload.web.js +3 -0
- package/build/lib/web/development/components/FileUpload/FileUpload.web.js.map +1 -1
- package/build/lib/web/development/components/SideNav/SideNav.web.js +360 -0
- package/build/lib/web/development/components/SideNav/SideNav.web.js.map +1 -0
- package/build/lib/web/development/components/SideNav/SideNavBody.web.js +17 -0
- package/build/lib/web/development/components/SideNav/SideNavBody.web.js.map +1 -0
- package/build/lib/web/development/components/SideNav/SideNavContext.js +23 -0
- package/build/lib/web/development/components/SideNav/SideNavContext.js.map +1 -0
- package/build/lib/web/development/components/SideNav/SideNavFooter.web.js +55 -0
- package/build/lib/web/development/components/SideNav/SideNavFooter.web.js.map +1 -0
- package/build/lib/web/development/components/SideNav/SideNavItems/SideNavItem.web.js +66 -0
- package/build/lib/web/development/components/SideNav/SideNavItems/SideNavItem.web.js.map +1 -0
- package/build/lib/web/development/components/SideNav/SideNavItems/SideNavLink.web.js +348 -0
- package/build/lib/web/development/components/SideNav/SideNavItems/SideNavLink.web.js.map +1 -0
- package/build/lib/web/development/components/SideNav/SideNavItems/TooltipifyNavItem.js +22 -0
- package/build/lib/web/development/components/SideNav/SideNavItems/TooltipifyNavItem.js.map +1 -0
- package/build/lib/web/development/components/SideNav/SideNavLevel.web.js +65 -0
- package/build/lib/web/development/components/SideNav/SideNavLevel.web.js.map +1 -0
- package/build/lib/web/development/components/SideNav/SideNavSection.web.js +141 -0
- package/build/lib/web/development/components/SideNav/SideNavSection.web.js.map +1 -0
- package/build/lib/web/development/components/SideNav/index.js +8 -0
- package/build/lib/web/development/components/SideNav/index.js.map +1 -0
- package/build/lib/web/development/components/SideNav/tokens.js +33 -0
- package/build/lib/web/development/components/SideNav/tokens.js.map +1 -0
- package/build/lib/web/development/components/SkipNav/SkipNav.web.js +11 -3
- package/build/lib/web/development/components/SkipNav/SkipNav.web.js.map +1 -1
- package/build/lib/web/development/components/Typography/BaseText/getBaseTextStyles.js +1 -1
- package/build/lib/web/development/components/Typography/BaseText/getBaseTextStyles.js.map +1 -1
- package/build/lib/web/development/components/index.js +9 -1
- package/build/lib/web/development/components/index.js.map +1 -1
- package/build/lib/web/development/tokens/global/size.js +6 -0
- package/build/lib/web/development/tokens/global/size.js.map +1 -1
- package/build/lib/web/development/utils/metaAttribute/metaConstants.js +1 -0
- package/build/lib/web/development/utils/metaAttribute/metaConstants.js.map +1 -1
- package/build/lib/web/production/components/Accordion/AccordionItem.js +1 -0
- package/build/lib/web/production/components/Accordion/AccordionItem.js.map +1 -1
- package/build/lib/web/production/components/Collapsible/Collapsible.js +4 -2
- package/build/lib/web/production/components/Collapsible/Collapsible.js.map +1 -1
- package/build/lib/web/production/components/Collapsible/CollapsibleBody.js +4 -1
- package/build/lib/web/production/components/Collapsible/CollapsibleBody.js.map +1 -1
- package/build/lib/web/production/components/Collapsible/CollapsibleBodyContent.web.js +4 -2
- package/build/lib/web/production/components/Collapsible/CollapsibleBodyContent.web.js.map +1 -1
- package/build/lib/web/production/components/Collapsible/CollapsibleLink.js +16 -4
- package/build/lib/web/production/components/Collapsible/CollapsibleLink.js.map +1 -1
- package/build/lib/web/production/components/Collapsible/commonStyles.js +5 -1
- package/build/lib/web/production/components/Collapsible/commonStyles.js.map +1 -1
- package/build/lib/web/production/components/DatePicker/Calendar.web.js +9 -5
- package/build/lib/web/production/components/DatePicker/Calendar.web.js.map +1 -1
- package/build/lib/web/production/components/DatePicker/CalendarStyles.web.js +40 -33
- package/build/lib/web/production/components/DatePicker/CalendarStyles.web.js.map +1 -1
- package/build/lib/web/production/components/DatePicker/DateInput.web.js +2 -1
- package/build/lib/web/production/components/DatePicker/DateInput.web.js.map +1 -1
- package/build/lib/web/production/components/DatePicker/DatePicker.web.js +5 -5
- package/build/lib/web/production/components/DatePicker/DatePicker.web.js.map +1 -1
- package/build/lib/web/production/components/DatePicker/shiftTimezone.js +39 -0
- package/build/lib/web/production/components/DatePicker/shiftTimezone.js.map +1 -0
- package/build/lib/web/production/components/DatePicker/useControlledDates.js +5 -8
- package/build/lib/web/production/components/DatePicker/useControlledDates.js.map +1 -1
- package/build/lib/web/production/components/DatePicker/utils.js +33 -1
- package/build/lib/web/production/components/DatePicker/utils.js.map +1 -1
- package/build/lib/web/production/components/Drawer/Drawer.web.js +25 -10
- package/build/lib/web/production/components/Drawer/Drawer.web.js.map +1 -1
- package/build/lib/web/production/components/Drawer/DrawerContext.js +3 -1
- package/build/lib/web/production/components/Drawer/DrawerContext.js.map +1 -1
- package/build/lib/web/production/components/Drawer/DrawerSubcomponents.web.js +26 -4
- package/build/lib/web/production/components/Drawer/DrawerSubcomponents.web.js.map +1 -1
- package/build/lib/web/production/components/Drawer/StackProvider.js +21 -12
- package/build/lib/web/production/components/Drawer/StackProvider.js.map +1 -1
- package/build/lib/web/production/components/Drawer/index.js +1 -1
- package/build/lib/web/production/components/FileUpload/FileUpload.web.js +3 -0
- package/build/lib/web/production/components/FileUpload/FileUpload.web.js.map +1 -1
- package/build/lib/web/production/components/SideNav/SideNav.web.js +360 -0
- package/build/lib/web/production/components/SideNav/SideNav.web.js.map +1 -0
- package/build/lib/web/production/components/SideNav/SideNavBody.web.js +17 -0
- package/build/lib/web/production/components/SideNav/SideNavBody.web.js.map +1 -0
- package/build/lib/web/production/components/SideNav/SideNavContext.js +23 -0
- package/build/lib/web/production/components/SideNav/SideNavContext.js.map +1 -0
- package/build/lib/web/production/components/SideNav/SideNavFooter.web.js +55 -0
- package/build/lib/web/production/components/SideNav/SideNavFooter.web.js.map +1 -0
- package/build/lib/web/production/components/SideNav/SideNavItems/SideNavItem.web.js +66 -0
- package/build/lib/web/production/components/SideNav/SideNavItems/SideNavItem.web.js.map +1 -0
- package/build/lib/web/production/components/SideNav/SideNavItems/SideNavLink.web.js +348 -0
- package/build/lib/web/production/components/SideNav/SideNavItems/SideNavLink.web.js.map +1 -0
- package/build/lib/web/production/components/SideNav/SideNavItems/TooltipifyNavItem.js +22 -0
- package/build/lib/web/production/components/SideNav/SideNavItems/TooltipifyNavItem.js.map +1 -0
- package/build/lib/web/production/components/SideNav/SideNavLevel.web.js +65 -0
- package/build/lib/web/production/components/SideNav/SideNavLevel.web.js.map +1 -0
- package/build/lib/web/production/components/SideNav/SideNavSection.web.js +141 -0
- package/build/lib/web/production/components/SideNav/SideNavSection.web.js.map +1 -0
- package/build/lib/web/production/components/SideNav/index.js +8 -0
- package/build/lib/web/production/components/SideNav/index.js.map +1 -0
- package/build/lib/web/production/components/SideNav/tokens.js +33 -0
- package/build/lib/web/production/components/SideNav/tokens.js.map +1 -0
- package/build/lib/web/production/components/SkipNav/SkipNav.web.js +11 -3
- package/build/lib/web/production/components/SkipNav/SkipNav.web.js.map +1 -1
- package/build/lib/web/production/components/Typography/BaseText/getBaseTextStyles.js +1 -1
- package/build/lib/web/production/components/Typography/BaseText/getBaseTextStyles.js.map +1 -1
- package/build/lib/web/production/components/index.js +9 -1
- package/build/lib/web/production/components/index.js.map +1 -1
- package/build/lib/web/production/tokens/global/size.js +6 -0
- package/build/lib/web/production/tokens/global/size.js.map +1 -1
- package/build/lib/web/production/utils/metaAttribute/metaConstants.js +1 -0
- package/build/lib/web/production/utils/metaAttribute/metaConstants.js.map +1 -1
- package/build/types/components/index.d.ts +1455 -1227
- package/build/types/components/index.native.d.ts +245 -36
- package/build/types/tokens/index.d.ts +6 -0
- package/build/types/tokens/index.native.d.ts +6 -0
- package/package.json +4 -4
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SideNavContext.js","sources":["../../../../../../src/components/SideNav/SideNavContext.ts"],"sourcesContent":["import React from 'react';\nimport type { NavLinkContextType, SideNavContextType } from './types';\nimport { throwBladeError } from '~utils/logger';\n\nconst SideNavContext = React.createContext<SideNavContextType>({});\n\nconst useSideNav = (): SideNavContextType => {\n const value = React.useContext(SideNavContext);\n if (!value) {\n throwBladeError({\n moduleName: 'SideNavContext',\n message: 'SideNav* components cannot be used outside SideNav',\n });\n }\n return value;\n};\n\nconst NavLinkContext = React.createContext<NavLinkContextType>({});\nconst useNavLink = (): NavLinkContextType => {\n const value = React.useContext(NavLinkContext);\n return value;\n};\n\nexport { SideNavContext, useSideNav, NavLinkContext, useNavLink };\n"],"names":["SideNavContext","React","createContext","useSideNav","value","useContext","throwBladeError","moduleName","message","NavLinkContext","useNavLink"],"mappings":";;;;AAIMA,IAAAA,cAAc,gBAAGC,cAAK,CAACC,aAAa,CAAqB,EAAE,EAAC;AAElE,IAAMC,UAAU,GAAG,SAAbA,UAAUA,GAA6B;AAC3C,EAAA,IAAMC,KAAK,GAAGH,cAAK,CAACI,UAAU,CAACL,cAAc,CAAC,CAAA;EAC9C,IAAI,CAACI,KAAK,EAAE;AACVE,IAAAA,eAAe,CAAC;AACdC,MAAAA,UAAU,EAAE,gBAAgB;AAC5BC,MAAAA,OAAO,EAAE,oDAAA;AACX,KAAC,CAAC,CAAA;AACJ,GAAA;AACA,EAAA,OAAOJ,KAAK,CAAA;AACd,EAAC;AAEKK,IAAAA,cAAc,gBAAGR,cAAK,CAACC,aAAa,CAAqB,EAAE,EAAC;AAClE,IAAMQ,UAAU,GAAG,SAAbA,UAAUA,GAA6B;AAC3C,EAAA,IAAMN,KAAK,GAAGH,cAAK,CAACI,UAAU,CAACI,cAAc,CAAC,CAAA;AAC9C,EAAA,OAAOL,KAAK,CAAA;AACd;;;;"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import 'react';
|
|
2
|
+
import { classes } from './tokens.js';
|
|
3
|
+
import '../Box/BaseBox/index.js';
|
|
4
|
+
import '../Drawer/index.js';
|
|
5
|
+
import getIn from '../../utils/lodashButBetter/get.js';
|
|
6
|
+
import '../../utils/index.js';
|
|
7
|
+
import { jsx } from 'react/jsx-runtime';
|
|
8
|
+
import { drawerPadding } from '../Drawer/DrawerSubcomponents.web.js';
|
|
9
|
+
import { makeSpace } from '../../utils/makeSpace/makeSpace.js';
|
|
10
|
+
import useTheme from '../BladeProvider/useTheme.js';
|
|
11
|
+
import { BaseBox } from '../Box/BaseBox/BaseBox.web.js';
|
|
12
|
+
|
|
13
|
+
var getDrawerPadding = function getDrawerPadding(theme) {
|
|
14
|
+
var negativePaddingValue = getIn(theme, drawerPadding);
|
|
15
|
+
return makeSpace(negativePaddingValue);
|
|
16
|
+
};
|
|
17
|
+
var SideNavFooter = function SideNavFooter(_ref) {
|
|
18
|
+
var children = _ref.children;
|
|
19
|
+
var _useTheme = useTheme(),
|
|
20
|
+
theme = _useTheme.theme;
|
|
21
|
+
return /*#__PURE__*/jsx(BaseBox, {
|
|
22
|
+
className: classes.L1_ITEM_WRAPPER,
|
|
23
|
+
width: {
|
|
24
|
+
base: "calc(100% + ".concat(getDrawerPadding(theme), " + ").concat(getDrawerPadding(theme), ")"),
|
|
25
|
+
m: '100%'
|
|
26
|
+
},
|
|
27
|
+
borderTopWidth: "thin",
|
|
28
|
+
borderTopColor: "surface.border.gray.muted",
|
|
29
|
+
backgroundColor: "surface.background.gray.moderate",
|
|
30
|
+
position: "relative",
|
|
31
|
+
elevation: "lowRaised",
|
|
32
|
+
bottom: {
|
|
33
|
+
base: "-".concat(getDrawerPadding(theme)),
|
|
34
|
+
m: 'spacing.0'
|
|
35
|
+
},
|
|
36
|
+
left: {
|
|
37
|
+
base: "-".concat(getDrawerPadding(theme)),
|
|
38
|
+
m: 'spacing.0'
|
|
39
|
+
},
|
|
40
|
+
right: {
|
|
41
|
+
base: "-".concat(getDrawerPadding(theme)),
|
|
42
|
+
m: 'spacing.0'
|
|
43
|
+
}
|
|
44
|
+
// in Desktop, padding is set on SideNav component
|
|
45
|
+
,
|
|
46
|
+
padding: {
|
|
47
|
+
base: 'spacing.4',
|
|
48
|
+
m: undefined
|
|
49
|
+
},
|
|
50
|
+
children: children
|
|
51
|
+
});
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
export { SideNavFooter };
|
|
55
|
+
//# sourceMappingURL=SideNavFooter.web.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SideNavFooter.web.js","sources":["../../../../../../src/components/SideNav/SideNavFooter.web.tsx"],"sourcesContent":["import React from 'react';\nimport type { SideNavFooterProps } from './types';\nimport { classes } from './tokens';\nimport BaseBox from '~components/Box/BaseBox';\nimport { drawerPadding } from '~components/Drawer';\nimport getIn from '~utils/lodashButBetter/get';\nimport type { Theme } from '~components/BladeProvider';\nimport { makeSpace, useTheme } from '~utils';\n\nconst getDrawerPadding = (theme: Theme): `${number}px` => {\n const negativePaddingValue = getIn(theme, drawerPadding);\n return makeSpace(negativePaddingValue);\n};\n\nconst SideNavFooter = ({ children }: SideNavFooterProps): React.ReactElement => {\n const { theme } = useTheme();\n return (\n <BaseBox\n className={classes.L1_ITEM_WRAPPER}\n width={{\n base: `calc(100% + ${getDrawerPadding(theme)} + ${getDrawerPadding(theme)})`,\n m: '100%',\n }}\n borderTopWidth=\"thin\"\n borderTopColor=\"surface.border.gray.muted\"\n backgroundColor=\"surface.background.gray.moderate\"\n position=\"relative\"\n elevation=\"lowRaised\"\n bottom={{ base: `-${getDrawerPadding(theme)}`, m: 'spacing.0' }}\n left={{ base: `-${getDrawerPadding(theme)}`, m: 'spacing.0' }}\n right={{ base: `-${getDrawerPadding(theme)}`, m: 'spacing.0' }}\n // in Desktop, padding is set on SideNav component\n padding={{ base: 'spacing.4', m: undefined }}\n >\n {children}\n </BaseBox>\n );\n};\n\nexport { SideNavFooter };\n"],"names":["getDrawerPadding","theme","negativePaddingValue","getIn","drawerPadding","makeSpace","SideNavFooter","_ref","children","_useTheme","useTheme","_jsx","BaseBox","className","classes","L1_ITEM_WRAPPER","width","base","concat","m","borderTopWidth","borderTopColor","backgroundColor","position","elevation","bottom","left","right","padding","undefined"],"mappings":";;;;;;;;;;;;AASA,IAAMA,gBAAgB,GAAG,SAAnBA,gBAAgBA,CAAIC,KAAY,EAAoB;AACxD,EAAA,IAAMC,oBAAoB,GAAGC,KAAK,CAACF,KAAK,EAAEG,aAAa,CAAC,CAAA;EACxD,OAAOC,SAAS,CAACH,oBAAoB,CAAC,CAAA;AACxC,CAAC,CAAA;AAED,IAAMI,aAAa,GAAG,SAAhBA,aAAaA,CAAAC,IAAA,EAA6D;AAAA,EAAA,IAAvDC,QAAQ,GAAAD,IAAA,CAARC,QAAQ,CAAA;AAC/B,EAAA,IAAAC,SAAA,GAAkBC,QAAQ,EAAE;IAApBT,KAAK,GAAAQ,SAAA,CAALR,KAAK,CAAA;EACb,oBACEU,GAAA,CAACC,OAAO,EAAA;IACNC,SAAS,EAAEC,OAAO,CAACC,eAAgB;AACnCC,IAAAA,KAAK,EAAE;AACLC,MAAAA,IAAI,EAAAC,cAAAA,CAAAA,MAAA,CAAiBlB,gBAAgB,CAACC,KAAK,CAAC,EAAAiB,KAAAA,CAAAA,CAAAA,MAAA,CAAMlB,gBAAgB,CAACC,KAAK,CAAC,EAAG,GAAA,CAAA;AAC5EkB,MAAAA,CAAC,EAAE,MAAA;KACH;AACFC,IAAAA,cAAc,EAAC,MAAM;AACrBC,IAAAA,cAAc,EAAC,2BAA2B;AAC1CC,IAAAA,eAAe,EAAC,kCAAkC;AAClDC,IAAAA,QAAQ,EAAC,UAAU;AACnBC,IAAAA,SAAS,EAAC,WAAW;AACrBC,IAAAA,MAAM,EAAE;AAAER,MAAAA,IAAI,MAAAC,MAAA,CAAMlB,gBAAgB,CAACC,KAAK,CAAC,CAAE;AAAEkB,MAAAA,CAAC,EAAE,WAAA;KAAc;AAChEO,IAAAA,IAAI,EAAE;AAAET,MAAAA,IAAI,MAAAC,MAAA,CAAMlB,gBAAgB,CAACC,KAAK,CAAC,CAAE;AAAEkB,MAAAA,CAAC,EAAE,WAAA;KAAc;AAC9DQ,IAAAA,KAAK,EAAE;AAAEV,MAAAA,IAAI,MAAAC,MAAA,CAAMlB,gBAAgB,CAACC,KAAK,CAAC,CAAE;AAAEkB,MAAAA,CAAC,EAAE,WAAA;AAAY,KAAA;AAC7D;AAAA;AACAS,IAAAA,OAAO,EAAE;AAAEX,MAAAA,IAAI,EAAE,WAAW;AAAEE,MAAAA,CAAC,EAAEU,SAAAA;KAAY;AAAArB,IAAAA,QAAA,EAE5CA,QAAAA;AAAQ,GACF,CAAC,CAAA;AAEd;;;;"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import styled from 'styled-components';
|
|
2
|
+
import { getNavItemTransition, NAV_ITEM_HEIGHT, classes } from '../tokens.js';
|
|
3
|
+
import { TooltipifyNavItem } from './TooltipifyNavItem.js';
|
|
4
|
+
import '../../Box/index.js';
|
|
5
|
+
import '../../Box/BaseBox/index.js';
|
|
6
|
+
import '../../Typography/index.js';
|
|
7
|
+
import '../../../utils/index.js';
|
|
8
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
9
|
+
import { BaseBox } from '../../Box/BaseBox/BaseBox.web.js';
|
|
10
|
+
import { makeSize } from '../../../utils/makeSize/makeSize.js';
|
|
11
|
+
import { Box } from '../../Box/Box.js';
|
|
12
|
+
import { Text } from '../../Typography/Text/Text.js';
|
|
13
|
+
|
|
14
|
+
var SideNavItemContainer = /*#__PURE__*/styled(BaseBox).withConfig({
|
|
15
|
+
displayName: "SideNavItemweb__SideNavItemContainer",
|
|
16
|
+
componentId: "nb93ri-0"
|
|
17
|
+
})(function (props) {
|
|
18
|
+
return {
|
|
19
|
+
transition: getNavItemTransition(props.theme)
|
|
20
|
+
};
|
|
21
|
+
});
|
|
22
|
+
var SideNavItem = function SideNavItem(_ref) {
|
|
23
|
+
var leading = _ref.leading,
|
|
24
|
+
trailing = _ref.trailing,
|
|
25
|
+
title = _ref.title,
|
|
26
|
+
backgroundColor = _ref.backgroundColor,
|
|
27
|
+
tooltip = _ref.tooltip,
|
|
28
|
+
_ref$as = _ref.as,
|
|
29
|
+
as = _ref$as === void 0 ? 'div' : _ref$as;
|
|
30
|
+
return /*#__PURE__*/jsx(TooltipifyNavItem, {
|
|
31
|
+
tooltip: tooltip,
|
|
32
|
+
children: /*#__PURE__*/jsxs(SideNavItemContainer, {
|
|
33
|
+
display: "flex",
|
|
34
|
+
flexDirection: "row",
|
|
35
|
+
justifyContent: "space-between",
|
|
36
|
+
alignItems: "center",
|
|
37
|
+
paddingX: "spacing.3",
|
|
38
|
+
height: makeSize(NAV_ITEM_HEIGHT),
|
|
39
|
+
backgroundColor: backgroundColor,
|
|
40
|
+
borderRadius: "medium",
|
|
41
|
+
as: as,
|
|
42
|
+
cursor: as === 'label' ? 'pointer' : undefined,
|
|
43
|
+
children: [/*#__PURE__*/jsxs(Box, {
|
|
44
|
+
display: "inline-flex",
|
|
45
|
+
alignItems: "center",
|
|
46
|
+
gap: "spacing.3",
|
|
47
|
+
children: [leading, /*#__PURE__*/jsx(BaseBox, {
|
|
48
|
+
className: classes.HIDE_WHEN_COLLAPSED,
|
|
49
|
+
children: /*#__PURE__*/jsx(Text, {
|
|
50
|
+
truncateAfterLines: 1,
|
|
51
|
+
weight: "medium",
|
|
52
|
+
size: "medium",
|
|
53
|
+
color: "surface.text.gray.subtle",
|
|
54
|
+
children: title
|
|
55
|
+
})
|
|
56
|
+
})]
|
|
57
|
+
}), /*#__PURE__*/jsx(BaseBox, {
|
|
58
|
+
className: classes.HIDE_WHEN_COLLAPSED,
|
|
59
|
+
children: trailing
|
|
60
|
+
})]
|
|
61
|
+
})
|
|
62
|
+
});
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
export { SideNavItem };
|
|
66
|
+
//# sourceMappingURL=SideNavItem.web.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SideNavItem.web.js","sources":["../../../../../../../src/components/SideNav/SideNavItems/SideNavItem.web.tsx"],"sourcesContent":["import styled from 'styled-components';\nimport { classes, getNavItemTransition, NAV_ITEM_HEIGHT } from '../tokens';\nimport type { SideNavItemProps } from '../types';\nimport { TooltipifyNavItem } from './TooltipifyNavItem';\nimport { Box } from '~components/Box';\nimport BaseBox from '~components/Box/BaseBox';\nimport { Text } from '~components/Typography';\nimport { makeSize } from '~utils';\n\nconst SideNavItemContainer = styled(BaseBox)((props) => {\n return {\n transition: getNavItemTransition(props.theme),\n };\n});\n\nconst SideNavItem = ({\n leading,\n trailing,\n title,\n backgroundColor,\n tooltip,\n as = 'div',\n}: SideNavItemProps): React.ReactElement => {\n return (\n <TooltipifyNavItem tooltip={tooltip}>\n <SideNavItemContainer\n display=\"flex\"\n flexDirection=\"row\"\n justifyContent=\"space-between\"\n alignItems=\"center\"\n paddingX=\"spacing.3\"\n height={makeSize(NAV_ITEM_HEIGHT)}\n backgroundColor={backgroundColor}\n borderRadius=\"medium\"\n as={as}\n cursor={as === 'label' ? 'pointer' : undefined}\n >\n <Box display=\"inline-flex\" alignItems=\"center\" gap=\"spacing.3\">\n {leading}\n <BaseBox className={classes.HIDE_WHEN_COLLAPSED}>\n <Text\n truncateAfterLines={1}\n weight=\"medium\"\n size=\"medium\"\n color=\"surface.text.gray.subtle\"\n >\n {title}\n </Text>\n </BaseBox>\n </Box>\n <BaseBox className={classes.HIDE_WHEN_COLLAPSED}>{trailing}</BaseBox>\n </SideNavItemContainer>\n </TooltipifyNavItem>\n );\n};\n\nexport { SideNavItem };\n"],"names":["SideNavItemContainer","styled","BaseBox","withConfig","displayName","componentId","props","transition","getNavItemTransition","theme","SideNavItem","_ref","leading","trailing","title","backgroundColor","tooltip","_ref$as","as","_jsx","TooltipifyNavItem","children","_jsxs","display","flexDirection","justifyContent","alignItems","paddingX","height","makeSize","NAV_ITEM_HEIGHT","borderRadius","cursor","undefined","Box","gap","className","classes","HIDE_WHEN_COLLAPSED","Text","truncateAfterLines","weight","size","color"],"mappings":";;;;;;;;;;;;;AASA,IAAMA,oBAAoB,gBAAGC,MAAM,CAACC,OAAO,CAAC,CAAAC,UAAA,CAAA;EAAAC,WAAA,EAAA,sCAAA;EAAAC,WAAA,EAAA,UAAA;AAAA,CAAC,CAAA,CAAA,UAACC,KAAK,EAAK;EACtD,OAAO;AACLC,IAAAA,UAAU,EAAEC,oBAAoB,CAACF,KAAK,CAACG,KAAK,CAAA;GAC7C,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,IAAMC,WAAW,GAAG,SAAdA,WAAWA,CAAAC,IAAA,EAO2B;AAAA,EAAA,IAN1CC,OAAO,GAAAD,IAAA,CAAPC,OAAO;IACPC,QAAQ,GAAAF,IAAA,CAARE,QAAQ;IACRC,KAAK,GAAAH,IAAA,CAALG,KAAK;IACLC,eAAe,GAAAJ,IAAA,CAAfI,eAAe;IACfC,OAAO,GAAAL,IAAA,CAAPK,OAAO;IAAAC,OAAA,GAAAN,IAAA,CACPO,EAAE;AAAFA,IAAAA,EAAE,GAAAD,OAAA,KAAG,KAAA,CAAA,GAAA,KAAK,GAAAA,OAAA,CAAA;EAEV,oBACEE,GAAA,CAACC,iBAAiB,EAAA;AAACJ,IAAAA,OAAO,EAAEA,OAAQ;IAAAK,QAAA,eAClCC,IAAA,CAACtB,oBAAoB,EAAA;AACnBuB,MAAAA,OAAO,EAAC,MAAM;AACdC,MAAAA,aAAa,EAAC,KAAK;AACnBC,MAAAA,cAAc,EAAC,eAAe;AAC9BC,MAAAA,UAAU,EAAC,QAAQ;AACnBC,MAAAA,QAAQ,EAAC,WAAW;AACpBC,MAAAA,MAAM,EAAEC,QAAQ,CAACC,eAAe,CAAE;AAClCf,MAAAA,eAAe,EAAEA,eAAgB;AACjCgB,MAAAA,YAAY,EAAC,QAAQ;AACrBb,MAAAA,EAAE,EAAEA,EAAG;AACPc,MAAAA,MAAM,EAAEd,EAAE,KAAK,OAAO,GAAG,SAAS,GAAGe,SAAU;MAAAZ,QAAA,EAAA,cAE/CC,IAAA,CAACY,GAAG,EAAA;AAACX,QAAAA,OAAO,EAAC,aAAa;AAACG,QAAAA,UAAU,EAAC,QAAQ;AAACS,QAAAA,GAAG,EAAC,WAAW;AAAAd,QAAAA,QAAA,EAC3DT,CAAAA,OAAO,eACRO,GAAA,CAACjB,OAAO,EAAA;UAACkC,SAAS,EAAEC,OAAO,CAACC,mBAAoB;UAAAjB,QAAA,eAC9CF,GAAA,CAACoB,IAAI,EAAA;AACHC,YAAAA,kBAAkB,EAAE,CAAE;AACtBC,YAAAA,MAAM,EAAC,QAAQ;AACfC,YAAAA,IAAI,EAAC,QAAQ;AACbC,YAAAA,KAAK,EAAC,0BAA0B;AAAAtB,YAAAA,QAAA,EAE/BP,KAAAA;WACG,CAAA;AAAC,SACA,CAAC,CAAA;AAAA,OACP,CAAC,eACNK,GAAA,CAACjB,OAAO,EAAA;QAACkC,SAAS,EAAEC,OAAO,CAACC,mBAAoB;AAAAjB,QAAAA,QAAA,EAAER,QAAAA;AAAQ,OAAU,CAAC,CAAA;KACjD,CAAA;AAAC,GACN,CAAC,CAAA;AAExB;;;;"}
|
|
@@ -0,0 +1,348 @@
|
|
|
1
|
+
import _defineProperty from '@babel/runtime/helpers/defineProperty';
|
|
2
|
+
import 'react';
|
|
3
|
+
import styled from 'styled-components';
|
|
4
|
+
import { useFloating, FloatingPortal, FloatingFocusManager } from '@floating-ui/react';
|
|
5
|
+
import { useSideNav, useNavLink, NavLinkContext } from '../SideNavContext.js';
|
|
6
|
+
import { classes, NAV_ITEM_HEIGHT, getNavItemTransition } from '../tokens.js';
|
|
7
|
+
import { TooltipifyNavItem } from './TooltipifyNavItem.js';
|
|
8
|
+
import '../../Box/index.js';
|
|
9
|
+
import '../../../utils/index.js';
|
|
10
|
+
import '../../Typography/BaseText/index.js';
|
|
11
|
+
import '../../Icons/index.js';
|
|
12
|
+
import '../../Box/BaseBox/index.js';
|
|
13
|
+
import { useCollapsible } from '../../Collapsible/CollapsibleContext.js';
|
|
14
|
+
import '../../Collapsible/index.js';
|
|
15
|
+
import '../../../utils/makeAccessible/index.js';
|
|
16
|
+
import { useFirstRender } from '../../../utils/useFirstRender.js';
|
|
17
|
+
import '../../../utils/getFocusRingStyles/index.js';
|
|
18
|
+
import { useIsomorphicLayoutEffect } from '../../../utils/useIsomorphicLayoutEffect.js';
|
|
19
|
+
import '../../../utils/logger/index.js';
|
|
20
|
+
import { jsxs, jsx, Fragment } from 'react/jsx-runtime';
|
|
21
|
+
import { BaseBox } from '../../Box/BaseBox/BaseBox.web.js';
|
|
22
|
+
import { makeSize } from '../../../utils/makeSize/makeSize.js';
|
|
23
|
+
import { makeSpace } from '../../../utils/makeSpace/makeSpace.js';
|
|
24
|
+
import { makeBorderSize } from '../../../utils/makeBorderSize/makeBorderSize.js';
|
|
25
|
+
import { getFocusRingStyles } from '../../../utils/getFocusRingStyles/getFocusRingStyles.web.js';
|
|
26
|
+
import { Box } from '../../Box/Box.js';
|
|
27
|
+
import { BaseText } from '../../Typography/BaseText/BaseText.web.js';
|
|
28
|
+
import { makeAccessible } from '../../../utils/makeAccessible/makeAccessible.web.js';
|
|
29
|
+
import ChevronUpIcon from '../../Icons/ChevronUpIcon/ChevronUpIcon.js';
|
|
30
|
+
import ChevronDownIcon from '../../Icons/ChevronDownIcon/ChevronDownIcon.js';
|
|
31
|
+
import { throwBladeError } from '../../../utils/logger/logger.js';
|
|
32
|
+
import { Collapsible } from '../../Collapsible/Collapsible.js';
|
|
33
|
+
import { CollapsibleBody } from '../../Collapsible/CollapsibleBody.js';
|
|
34
|
+
import ChevronRightIcon from '../../Icons/ChevronRightIcon/ChevronRightIcon.js';
|
|
35
|
+
|
|
36
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
37
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
38
|
+
var SHOW_ON_LINK_HOVER = classes.SHOW_ON_LINK_HOVER,
|
|
39
|
+
HIDE_WHEN_COLLAPSED = classes.HIDE_WHEN_COLLAPSED,
|
|
40
|
+
STYLED_NAV_LINK = classes.STYLED_NAV_LINK;
|
|
41
|
+
var StyledNavLinkContainer = /*#__PURE__*/styled(BaseBox).withConfig({
|
|
42
|
+
displayName: "SideNavLinkweb__StyledNavLinkContainer",
|
|
43
|
+
componentId: "sc-1ypwkeo-0"
|
|
44
|
+
})(function (props) {
|
|
45
|
+
return _defineProperty(_defineProperty(_defineProperty({
|
|
46
|
+
width: '100%'
|
|
47
|
+
}, ".".concat(SHOW_ON_LINK_HOVER), {
|
|
48
|
+
opacity: 0,
|
|
49
|
+
'&:focus-within, &:focus-visible': {
|
|
50
|
+
opacity: 1
|
|
51
|
+
}
|
|
52
|
+
}), '&:hover', _defineProperty(_defineProperty({}, ".".concat(SHOW_ON_LINK_HOVER), {
|
|
53
|
+
opacity: 1
|
|
54
|
+
}), ".".concat(STYLED_NAV_LINK), {
|
|
55
|
+
color: props.theme.colors.interactive.text.gray.normal,
|
|
56
|
+
backgroundColor: props.theme.colors.interactive.background.gray["default"]
|
|
57
|
+
})), ".".concat(STYLED_NAV_LINK), {
|
|
58
|
+
position: 'relative',
|
|
59
|
+
display: 'flex',
|
|
60
|
+
flexDirection: 'row',
|
|
61
|
+
alignItems: 'center',
|
|
62
|
+
justifyContent: 'space-between',
|
|
63
|
+
height: makeSize(NAV_ITEM_HEIGHT),
|
|
64
|
+
width: '100%',
|
|
65
|
+
textDecoration: 'none',
|
|
66
|
+
overflow: 'hidden',
|
|
67
|
+
flexWrap: 'nowrap',
|
|
68
|
+
cursor: 'pointer',
|
|
69
|
+
padding: "".concat(makeSpace(props.theme.spacing[0]), " ").concat(makeSpace(props.theme.spacing[4])),
|
|
70
|
+
margin: "".concat(makeSpace(props.theme.spacing[1]), " ").concat(makeSpace(props.theme.spacing[0])),
|
|
71
|
+
color: props.theme.colors.interactive.text.gray.subtle,
|
|
72
|
+
borderRadius: props.theme.border.radius.medium,
|
|
73
|
+
borderWidth: makeBorderSize(props.theme.border.width.none),
|
|
74
|
+
backgroundColor: props.theme.colors.transparent,
|
|
75
|
+
transition: getNavItemTransition(props.theme),
|
|
76
|
+
'&[aria-current]': {
|
|
77
|
+
color: props.theme.colors.interactive.text.primary.subtle,
|
|
78
|
+
backgroundColor: props.theme.colors.interactive.background.primary.faded
|
|
79
|
+
},
|
|
80
|
+
'&[aria-current]:hover': {
|
|
81
|
+
color: props.theme.colors.interactive.text.primary.normal,
|
|
82
|
+
backgroundColor: props.theme.colors.interactive.background.primary.fadedHighlighted
|
|
83
|
+
},
|
|
84
|
+
'&:focus-visible': _objectSpread({}, getFocusRingStyles({
|
|
85
|
+
theme: props.theme
|
|
86
|
+
}))
|
|
87
|
+
});
|
|
88
|
+
});
|
|
89
|
+
var NavLinkIconTitle = function NavLinkIconTitle(_ref2) {
|
|
90
|
+
var Icon = _ref2.icon,
|
|
91
|
+
title = _ref2.title,
|
|
92
|
+
titleSuffix = _ref2.titleSuffix,
|
|
93
|
+
isL1Item = _ref2.isL1Item;
|
|
94
|
+
return /*#__PURE__*/jsxs(Box, {
|
|
95
|
+
display: "flex",
|
|
96
|
+
flexDirection: "row",
|
|
97
|
+
gap: "spacing.3",
|
|
98
|
+
children: [Icon ? /*#__PURE__*/jsx(BaseBox, {
|
|
99
|
+
display: "flex",
|
|
100
|
+
flexDirection: "row",
|
|
101
|
+
alignItems: "center",
|
|
102
|
+
justifyContent: "center",
|
|
103
|
+
children: /*#__PURE__*/jsx(Icon, {
|
|
104
|
+
size: "medium",
|
|
105
|
+
color: "currentColor"
|
|
106
|
+
})
|
|
107
|
+
}) : null, /*#__PURE__*/jsx(BaseText, {
|
|
108
|
+
truncateAfterLines: 1,
|
|
109
|
+
color: "currentColor",
|
|
110
|
+
fontWeight: "medium",
|
|
111
|
+
fontSize: 100,
|
|
112
|
+
lineHeight: 100,
|
|
113
|
+
as: "p",
|
|
114
|
+
className: isL1Item ? HIDE_WHEN_COLLAPSED : '',
|
|
115
|
+
children: title
|
|
116
|
+
}), titleSuffix ? /*#__PURE__*/jsx(BaseBox, {
|
|
117
|
+
display: "flex",
|
|
118
|
+
alignItems: "center",
|
|
119
|
+
children: titleSuffix
|
|
120
|
+
}) : null]
|
|
121
|
+
});
|
|
122
|
+
};
|
|
123
|
+
var L3Trigger = function L3Trigger(_ref3) {
|
|
124
|
+
var title = _ref3.title,
|
|
125
|
+
icon = _ref3.icon,
|
|
126
|
+
as = _ref3.as,
|
|
127
|
+
href = _ref3.href,
|
|
128
|
+
target = _ref3.target,
|
|
129
|
+
titleSuffix = _ref3.titleSuffix,
|
|
130
|
+
tooltip = _ref3.tooltip;
|
|
131
|
+
var _useCollapsible = useCollapsible(),
|
|
132
|
+
onExpandChange = _useCollapsible.onExpandChange,
|
|
133
|
+
isExpanded = _useCollapsible.isExpanded,
|
|
134
|
+
collapsibleBodyId = _useCollapsible.collapsibleBodyId;
|
|
135
|
+
var toggleCollapse = function toggleCollapse() {
|
|
136
|
+
return onExpandChange(!isExpanded);
|
|
137
|
+
};
|
|
138
|
+
var iconProps = {
|
|
139
|
+
size: 'medium',
|
|
140
|
+
color: 'currentColor'
|
|
141
|
+
};
|
|
142
|
+
return /*#__PURE__*/jsx(TooltipifyNavItem, {
|
|
143
|
+
tooltip: tooltip,
|
|
144
|
+
children: /*#__PURE__*/jsx(StyledNavLinkContainer, {
|
|
145
|
+
children: /*#__PURE__*/jsxs(BaseBox, _objectSpread(_objectSpread({
|
|
146
|
+
className: STYLED_NAV_LINK,
|
|
147
|
+
as: href ? as : 'button',
|
|
148
|
+
to: href,
|
|
149
|
+
target: target,
|
|
150
|
+
onClick: toggleCollapse
|
|
151
|
+
}, makeAccessible({
|
|
152
|
+
expanded: isExpanded,
|
|
153
|
+
controls: collapsibleBodyId
|
|
154
|
+
})), {}, {
|
|
155
|
+
children: [/*#__PURE__*/jsx(NavLinkIconTitle, {
|
|
156
|
+
title: title,
|
|
157
|
+
icon: icon,
|
|
158
|
+
isL1Item: false,
|
|
159
|
+
titleSuffix: titleSuffix
|
|
160
|
+
}), /*#__PURE__*/jsx(BaseBox, {
|
|
161
|
+
display: "flex",
|
|
162
|
+
alignItems: "center",
|
|
163
|
+
children: isExpanded ? /*#__PURE__*/jsx(ChevronUpIcon, _objectSpread({}, iconProps)) : /*#__PURE__*/jsx(ChevronDownIcon, _objectSpread({}, iconProps))
|
|
164
|
+
})]
|
|
165
|
+
}))
|
|
166
|
+
})
|
|
167
|
+
});
|
|
168
|
+
};
|
|
169
|
+
|
|
170
|
+
/**
|
|
171
|
+
* This is the curved line that appears when you select L3 item
|
|
172
|
+
*/
|
|
173
|
+
var CurvedVerticalLine = /*#__PURE__*/styled(BaseBox).withConfig({
|
|
174
|
+
displayName: "SideNavLinkweb__CurvedVerticalLine",
|
|
175
|
+
componentId: "sc-1ypwkeo-1"
|
|
176
|
+
})(function (props) {
|
|
177
|
+
var _props$theme = props.theme,
|
|
178
|
+
colors = _props$theme.colors,
|
|
179
|
+
border = _props$theme.border,
|
|
180
|
+
spacing = _props$theme.spacing;
|
|
181
|
+
return {
|
|
182
|
+
borderWidth: makeBorderSize(props.theme.border.width.thin),
|
|
183
|
+
borderColor: "".concat(colors.transparent, " ").concat(colors.transparent, " ").concat(colors.surface.border.primary.muted, " ").concat(colors.surface.border.primary.muted),
|
|
184
|
+
borderStyle: 'solid',
|
|
185
|
+
borderRadius: "".concat(makeBorderSize(border.radius.none), " ").concat(makeBorderSize(border.radius.none), " ").concat(makeBorderSize(border.radius.none), " ").concat(makeBorderSize(border.radius.medium)),
|
|
186
|
+
// We set veritical line infinitely tall (full size of screen) and then hide the overflowing part from top
|
|
187
|
+
height: '100vh',
|
|
188
|
+
position: 'absolute',
|
|
189
|
+
// We want the active line to be positioned in the middle of item's height thus divide by 2
|
|
190
|
+
top: "calc(-100vh + ".concat(makeSize(NAV_ITEM_HEIGHT / 2), ")"),
|
|
191
|
+
width: makeSpace(spacing[3]),
|
|
192
|
+
left: makeSpace(-spacing[3])
|
|
193
|
+
};
|
|
194
|
+
});
|
|
195
|
+
var SideNavLink = function SideNavLink(_ref4) {
|
|
196
|
+
var title = _ref4.title,
|
|
197
|
+
href = _ref4.href,
|
|
198
|
+
children = _ref4.children,
|
|
199
|
+
titleSuffix = _ref4.titleSuffix,
|
|
200
|
+
trailing = _ref4.trailing,
|
|
201
|
+
isActive = _ref4.isActive,
|
|
202
|
+
icon = _ref4.icon,
|
|
203
|
+
tooltip = _ref4.tooltip,
|
|
204
|
+
as = _ref4.as,
|
|
205
|
+
target = _ref4.target;
|
|
206
|
+
var _useSideNav = useSideNav(),
|
|
207
|
+
l2PortalContainerRef = _useSideNav.l2PortalContainerRef,
|
|
208
|
+
onLinkActiveChange = _useSideNav.onLinkActiveChange,
|
|
209
|
+
closeMobileNav = _useSideNav.closeMobileNav,
|
|
210
|
+
isL1Collapsed = _useSideNav.isL1Collapsed,
|
|
211
|
+
setIsL1Collapsed = _useSideNav.setIsL1Collapsed;
|
|
212
|
+
var _useNavLink = useNavLink(),
|
|
213
|
+
_prevLevel = _useNavLink.level;
|
|
214
|
+
var prevLevel = _prevLevel !== null && _prevLevel !== void 0 ? _prevLevel : 0;
|
|
215
|
+
var currentLevel = prevLevel + 1;
|
|
216
|
+
var isL2Trigger = Boolean(children) && currentLevel === 1;
|
|
217
|
+
var isL3Trigger = Boolean(children) && currentLevel === 2;
|
|
218
|
+
if (true) {
|
|
219
|
+
if (Boolean(children) && currentLevel >= 3) {
|
|
220
|
+
throwBladeError({
|
|
221
|
+
message: 'SideNav only supports nesting upto L3 but L4 nesting was found. Check the nesting of your SideNavLevel items',
|
|
222
|
+
moduleName: 'SideNavLink'
|
|
223
|
+
});
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
var isFirstRender = useFirstRender();
|
|
227
|
+
var _useFloating = useFloating({
|
|
228
|
+
open: isActive
|
|
229
|
+
}),
|
|
230
|
+
refs = _useFloating.refs,
|
|
231
|
+
context = _useFloating.context;
|
|
232
|
+
useIsomorphicLayoutEffect(function () {
|
|
233
|
+
onLinkActiveChange === null || onLinkActiveChange === void 0 ? void 0 : onLinkActiveChange({
|
|
234
|
+
level: currentLevel,
|
|
235
|
+
title: title,
|
|
236
|
+
isActive: Boolean(isActive),
|
|
237
|
+
isL2Trigger: isL2Trigger,
|
|
238
|
+
isFirstRender: isFirstRender
|
|
239
|
+
});
|
|
240
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
241
|
+
}, [isActive]);
|
|
242
|
+
return /*#__PURE__*/jsx(NavLinkContext.Provider, {
|
|
243
|
+
value: {
|
|
244
|
+
level: currentLevel,
|
|
245
|
+
title: title
|
|
246
|
+
},
|
|
247
|
+
children: isL3Trigger ? /*#__PURE__*/jsxs(Collapsible, {
|
|
248
|
+
defaultIsExpanded: isActive,
|
|
249
|
+
_dangerouslyDisableValidations: true,
|
|
250
|
+
_shouldApplyWidthRestrictions: false,
|
|
251
|
+
children: [/*#__PURE__*/jsx(L3Trigger, {
|
|
252
|
+
title: title,
|
|
253
|
+
icon: icon,
|
|
254
|
+
as: as,
|
|
255
|
+
href: href,
|
|
256
|
+
titleSuffix: titleSuffix
|
|
257
|
+
}), /*#__PURE__*/jsx(CollapsibleBody, {
|
|
258
|
+
width: "100%",
|
|
259
|
+
_hasMargin: false,
|
|
260
|
+
children: /*#__PURE__*/jsx(Box, {
|
|
261
|
+
position: "relative",
|
|
262
|
+
children: children
|
|
263
|
+
})
|
|
264
|
+
})]
|
|
265
|
+
}) : /*#__PURE__*/jsxs(Fragment, {
|
|
266
|
+
children: [/*#__PURE__*/jsxs(StyledNavLinkContainer, {
|
|
267
|
+
position: "relative",
|
|
268
|
+
children: [/*#__PURE__*/jsx(TooltipifyNavItem, {
|
|
269
|
+
tooltip: tooltip,
|
|
270
|
+
children: /*#__PURE__*/jsxs(BaseBox, {
|
|
271
|
+
className: STYLED_NAV_LINK,
|
|
272
|
+
as: as !== null && as !== void 0 ? as : 'a',
|
|
273
|
+
to: href,
|
|
274
|
+
href: as ? undefined : href,
|
|
275
|
+
target: target,
|
|
276
|
+
ref: refs.setReference,
|
|
277
|
+
onClick: function onClick() {
|
|
278
|
+
// Close the mobile nav when item is clicked and its not trigger for next menu
|
|
279
|
+
if (!isL2Trigger) {
|
|
280
|
+
closeMobileNav === null || closeMobileNav === void 0 ? void 0 : closeMobileNav();
|
|
281
|
+
}
|
|
282
|
+
if (isActive) {
|
|
283
|
+
onLinkActiveChange === null || onLinkActiveChange === void 0 ? void 0 : onLinkActiveChange({
|
|
284
|
+
level: currentLevel,
|
|
285
|
+
title: title,
|
|
286
|
+
isActive: Boolean(isActive),
|
|
287
|
+
isL2Trigger: isL2Trigger,
|
|
288
|
+
isFirstRender: false
|
|
289
|
+
});
|
|
290
|
+
}
|
|
291
|
+
},
|
|
292
|
+
onFocus: function onFocus(e) {
|
|
293
|
+
var _e$target;
|
|
294
|
+
// FloatinFocusManager by default focusses on last clicked element when you move to different tab and come back to the original tab
|
|
295
|
+
// Which can make L1 to expand when tabs / windows are changed
|
|
296
|
+
// Adding focus-visible check ensures this behaviour of closing menus is only applicable when there is visible focus ring on it (while tabbing)
|
|
297
|
+
var hasFocusRing = (_e$target = e.target) === null || _e$target === void 0 ? void 0 : _e$target.matches(':focus-visible');
|
|
298
|
+
if (isL1Collapsed && currentLevel === 1 && hasFocusRing) {
|
|
299
|
+
setIsL1Collapsed === null || setIsL1Collapsed === void 0 ? void 0 : setIsL1Collapsed(false);
|
|
300
|
+
}
|
|
301
|
+
},
|
|
302
|
+
"aria-current": isActive ? 'page' : undefined,
|
|
303
|
+
"data-level": currentLevel,
|
|
304
|
+
"data-l2trigger": isL2Trigger,
|
|
305
|
+
children: [/*#__PURE__*/jsx(NavLinkIconTitle, {
|
|
306
|
+
icon: icon,
|
|
307
|
+
title: title,
|
|
308
|
+
isL1Item: currentLevel === 1,
|
|
309
|
+
titleSuffix: titleSuffix
|
|
310
|
+
}), isL2Trigger ? /*#__PURE__*/jsx(BaseBox, {
|
|
311
|
+
className: HIDE_WHEN_COLLAPSED,
|
|
312
|
+
display: "flex",
|
|
313
|
+
alignItems: "center",
|
|
314
|
+
children: /*#__PURE__*/jsx(ChevronRightIcon, {
|
|
315
|
+
size: "medium",
|
|
316
|
+
color: "currentColor"
|
|
317
|
+
})
|
|
318
|
+
}) : null]
|
|
319
|
+
})
|
|
320
|
+
}), trailing && !isL2Trigger ? /*#__PURE__*/jsx(BaseBox, {
|
|
321
|
+
position: "absolute",
|
|
322
|
+
top: "spacing.0",
|
|
323
|
+
right: "spacing.2",
|
|
324
|
+
height: "100%",
|
|
325
|
+
display: "flex",
|
|
326
|
+
alignItems: "center",
|
|
327
|
+
className: "".concat(HIDE_WHEN_COLLAPSED, " ").concat(SHOW_ON_LINK_HOVER),
|
|
328
|
+
children: trailing
|
|
329
|
+
}) : null, currentLevel === 3 && isActive ? /*#__PURE__*/jsx(CurvedVerticalLine, {}) : null]
|
|
330
|
+
}), children ? /*#__PURE__*/jsx(FloatingPortal, {
|
|
331
|
+
root: l2PortalContainerRef,
|
|
332
|
+
children: isActive && isL1Collapsed ? /*#__PURE__*/jsx(FloatingFocusManager, {
|
|
333
|
+
modal: false,
|
|
334
|
+
context: context,
|
|
335
|
+
initialFocus: -1,
|
|
336
|
+
returnFocus: true,
|
|
337
|
+
children: /*#__PURE__*/jsx(BaseBox, {
|
|
338
|
+
ref: refs.setFloating,
|
|
339
|
+
children: children
|
|
340
|
+
})
|
|
341
|
+
}) : null
|
|
342
|
+
}) : null]
|
|
343
|
+
})
|
|
344
|
+
});
|
|
345
|
+
};
|
|
346
|
+
|
|
347
|
+
export { SideNavLink };
|
|
348
|
+
//# sourceMappingURL=SideNavLink.web.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SideNavLink.web.js","sources":["../../../../../../../src/components/SideNav/SideNavItems/SideNavLink.web.tsx"],"sourcesContent":["import React from 'react';\nimport styled from 'styled-components';\nimport { FloatingFocusManager, FloatingPortal, useFloating } from '@floating-ui/react';\nimport { NavLinkContext, useNavLink, useSideNav } from '../SideNavContext';\nimport type { SideNavLinkProps } from '../types';\nimport { classes, getNavItemTransition, NAV_ITEM_HEIGHT } from '../tokens';\nimport { TooltipifyNavItem } from './TooltipifyNavItem';\nimport { Box } from '~components/Box';\nimport { makeBorderSize, makeSize, makeSpace } from '~utils';\nimport { BaseText } from '~components/Typography/BaseText';\nimport { ChevronDownIcon, ChevronRightIcon, ChevronUpIcon } from '~components/Icons';\nimport BaseBox from '~components/Box/BaseBox';\nimport { useCollapsible } from '~components/Collapsible/CollapsibleContext';\nimport { Collapsible, CollapsibleBody } from '~components/Collapsible';\nimport { makeAccessible } from '~utils/makeAccessible';\nimport { useFirstRender } from '~utils/useFirstRender';\nimport { getFocusRingStyles } from '~utils/getFocusRingStyles';\nimport { useIsomorphicLayoutEffect } from '~utils/useIsomorphicLayoutEffect';\nimport { throwBladeError } from '~utils/logger';\n\nconst { SHOW_ON_LINK_HOVER, HIDE_WHEN_COLLAPSED, STYLED_NAV_LINK } = classes;\n\nconst StyledNavLinkContainer = styled(BaseBox)((props) => {\n return {\n width: '100%',\n [`.${SHOW_ON_LINK_HOVER}`]: {\n opacity: 0,\n '&:focus-within, &:focus-visible': {\n opacity: 1,\n },\n },\n '&:hover': {\n [`.${SHOW_ON_LINK_HOVER}`]: {\n opacity: 1,\n },\n\n [`.${STYLED_NAV_LINK}`]: {\n color: props.theme.colors.interactive.text.gray.normal,\n backgroundColor: props.theme.colors.interactive.background.gray.default,\n },\n },\n [`.${STYLED_NAV_LINK}`]: {\n position: 'relative',\n display: 'flex',\n flexDirection: 'row',\n alignItems: 'center',\n justifyContent: 'space-between',\n height: makeSize(NAV_ITEM_HEIGHT),\n width: '100%',\n textDecoration: 'none',\n overflow: 'hidden',\n flexWrap: 'nowrap',\n cursor: 'pointer',\n padding: `${makeSpace(props.theme.spacing[0])} ${makeSpace(props.theme.spacing[4])}`,\n margin: `${makeSpace(props.theme.spacing[1])} ${makeSpace(props.theme.spacing[0])}`,\n color: props.theme.colors.interactive.text.gray.subtle,\n borderRadius: props.theme.border.radius.medium,\n borderWidth: makeBorderSize(props.theme.border.width.none),\n backgroundColor: props.theme.colors.transparent,\n transition: getNavItemTransition(props.theme),\n '&[aria-current]': {\n color: props.theme.colors.interactive.text.primary.subtle,\n backgroundColor: props.theme.colors.interactive.background.primary.faded,\n },\n '&[aria-current]:hover': {\n color: props.theme.colors.interactive.text.primary.normal,\n backgroundColor: props.theme.colors.interactive.background.primary.fadedHighlighted,\n },\n '&:focus-visible': {\n ...getFocusRingStyles({ theme: props.theme }),\n },\n },\n };\n});\n\nconst NavLinkIconTitle = ({\n icon: Icon,\n title,\n titleSuffix,\n isL1Item,\n}: Pick<SideNavLinkProps, 'title' | 'icon' | 'titleSuffix'> & {\n isL1Item: boolean;\n}): React.ReactElement => {\n return (\n <Box display=\"flex\" flexDirection=\"row\" gap=\"spacing.3\">\n {Icon ? (\n <BaseBox display=\"flex\" flexDirection=\"row\" alignItems=\"center\" justifyContent=\"center\">\n <Icon size=\"medium\" color=\"currentColor\" />\n </BaseBox>\n ) : null}\n <BaseText\n truncateAfterLines={1}\n color=\"currentColor\"\n fontWeight=\"medium\"\n fontSize={100}\n lineHeight={100}\n as=\"p\"\n className={isL1Item ? HIDE_WHEN_COLLAPSED : ''}\n >\n {title}\n </BaseText>\n {titleSuffix ? (\n <BaseBox display=\"flex\" alignItems=\"center\">\n {titleSuffix}\n </BaseBox>\n ) : null}\n </Box>\n );\n};\n\nconst L3Trigger = ({\n title,\n icon,\n as,\n href,\n target,\n titleSuffix,\n tooltip,\n}: Pick<\n SideNavLinkProps,\n 'title' | 'icon' | 'as' | 'href' | 'titleSuffix' | 'tooltip' | 'target'\n>): React.ReactElement => {\n const { onExpandChange, isExpanded, collapsibleBodyId } = useCollapsible();\n\n const toggleCollapse = (): void => onExpandChange(!isExpanded);\n const iconProps = {\n size: 'medium',\n color: 'currentColor',\n } as const;\n\n return (\n <TooltipifyNavItem tooltip={tooltip}>\n <StyledNavLinkContainer>\n <BaseBox\n className={STYLED_NAV_LINK}\n as={href ? as : 'button'}\n to={href}\n target={target}\n onClick={toggleCollapse}\n {...makeAccessible({ expanded: isExpanded, controls: collapsibleBodyId })}\n >\n <NavLinkIconTitle title={title} icon={icon} isL1Item={false} titleSuffix={titleSuffix} />\n <BaseBox display=\"flex\" alignItems=\"center\">\n {isExpanded ? <ChevronUpIcon {...iconProps} /> : <ChevronDownIcon {...iconProps} />}\n </BaseBox>\n </BaseBox>\n </StyledNavLinkContainer>\n </TooltipifyNavItem>\n );\n};\n\n/**\n * This is the curved line that appears when you select L3 item\n */\nconst CurvedVerticalLine = styled(BaseBox)((props) => {\n const { colors, border, spacing } = props.theme;\n return {\n borderWidth: makeBorderSize(props.theme.border.width.thin),\n borderColor: `${colors.transparent} ${colors.transparent} ${colors.surface.border.primary.muted} ${colors.surface.border.primary.muted}`,\n borderStyle: 'solid',\n borderRadius: `${makeBorderSize(border.radius.none)} ${makeBorderSize(\n border.radius.none,\n )} ${makeBorderSize(border.radius.none)} ${makeBorderSize(border.radius.medium)}`,\n // We set veritical line infinitely tall (full size of screen) and then hide the overflowing part from top\n height: '100vh',\n position: 'absolute',\n // We want the active line to be positioned in the middle of item's height thus divide by 2\n top: `calc(-100vh + ${makeSize(NAV_ITEM_HEIGHT / 2)})`,\n width: makeSpace(spacing[3]),\n left: makeSpace(-spacing[3]),\n };\n});\n\nconst SideNavLink = ({\n title,\n href,\n children,\n titleSuffix,\n trailing,\n isActive,\n icon,\n tooltip,\n as,\n target,\n}: SideNavLinkProps): React.ReactElement => {\n const {\n l2PortalContainerRef,\n onLinkActiveChange,\n closeMobileNav,\n isL1Collapsed,\n setIsL1Collapsed,\n } = useSideNav();\n const { level: _prevLevel } = useNavLink();\n const prevLevel = _prevLevel ?? 0;\n const currentLevel = prevLevel + 1;\n const isL2Trigger = Boolean(children) && currentLevel === 1;\n const isL3Trigger = Boolean(children) && currentLevel === 2;\n\n if (__DEV__) {\n if (Boolean(children) && currentLevel >= 3) {\n throwBladeError({\n message:\n 'SideNav only supports nesting upto L3 but L4 nesting was found. Check the nesting of your SideNavLevel items',\n moduleName: 'SideNavLink',\n });\n }\n }\n\n const isFirstRender = useFirstRender();\n\n const { refs, context } = useFloating({\n open: isActive,\n });\n\n useIsomorphicLayoutEffect(() => {\n onLinkActiveChange?.({\n level: currentLevel,\n title,\n isActive: Boolean(isActive),\n isL2Trigger,\n isFirstRender,\n });\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isActive]);\n\n return (\n <NavLinkContext.Provider value={{ level: currentLevel, title }}>\n {isL3Trigger ? (\n <Collapsible\n defaultIsExpanded={isActive}\n _dangerouslyDisableValidations={true}\n _shouldApplyWidthRestrictions={false}\n >\n <L3Trigger title={title} icon={icon} as={as} href={href} titleSuffix={titleSuffix} />\n <CollapsibleBody width=\"100%\" _hasMargin={false}>\n <Box position=\"relative\">{children}</Box>\n </CollapsibleBody>\n </Collapsible>\n ) : (\n <>\n <StyledNavLinkContainer position=\"relative\">\n <TooltipifyNavItem tooltip={tooltip}>\n <BaseBox\n className={STYLED_NAV_LINK}\n as={as ?? 'a'}\n to={href}\n href={as ? undefined : href}\n target={target}\n ref={refs.setReference}\n onClick={() => {\n // Close the mobile nav when item is clicked and its not trigger for next menu\n if (!isL2Trigger) {\n closeMobileNav?.();\n }\n\n if (isActive) {\n onLinkActiveChange?.({\n level: currentLevel,\n title,\n isActive: Boolean(isActive),\n isL2Trigger,\n isFirstRender: false,\n });\n }\n }}\n onFocus={(e: { target: HTMLDivElement }) => {\n // FloatinFocusManager by default focusses on last clicked element when you move to different tab and come back to the original tab\n // Which can make L1 to expand when tabs / windows are changed\n // Adding focus-visible check ensures this behaviour of closing menus is only applicable when there is visible focus ring on it (while tabbing)\n const hasFocusRing = e.target?.matches(':focus-visible');\n if (isL1Collapsed && currentLevel === 1 && hasFocusRing) {\n setIsL1Collapsed?.(false);\n }\n }}\n aria-current={isActive ? 'page' : undefined}\n data-level={currentLevel}\n data-l2trigger={isL2Trigger}\n >\n <NavLinkIconTitle\n icon={icon}\n title={title}\n isL1Item={currentLevel === 1}\n titleSuffix={titleSuffix}\n />\n {isL2Trigger ? (\n <BaseBox className={HIDE_WHEN_COLLAPSED} display=\"flex\" alignItems=\"center\">\n <ChevronRightIcon size=\"medium\" color=\"currentColor\" />\n </BaseBox>\n ) : null}\n </BaseBox>\n </TooltipifyNavItem>\n {trailing && !isL2Trigger ? (\n <BaseBox\n position=\"absolute\"\n top=\"spacing.0\"\n right=\"spacing.2\"\n height=\"100%\"\n display=\"flex\"\n alignItems=\"center\"\n className={`${HIDE_WHEN_COLLAPSED} ${SHOW_ON_LINK_HOVER}`}\n >\n {trailing}\n </BaseBox>\n ) : null}\n {currentLevel === 3 && isActive ? <CurvedVerticalLine /> : null}\n </StyledNavLinkContainer>\n\n {children ? (\n <FloatingPortal root={l2PortalContainerRef}>\n {isActive && isL1Collapsed ? (\n <FloatingFocusManager modal={false} context={context} initialFocus={-1} returnFocus>\n <BaseBox ref={refs.setFloating}>{children}</BaseBox>\n </FloatingFocusManager>\n ) : null}\n </FloatingPortal>\n ) : null}\n </>\n )}\n </NavLinkContext.Provider>\n );\n};\n\nexport { SideNavLink };\n"],"names":["SHOW_ON_LINK_HOVER","classes","HIDE_WHEN_COLLAPSED","STYLED_NAV_LINK","StyledNavLinkContainer","styled","BaseBox","withConfig","displayName","componentId","props","_defineProperty","width","concat","opacity","color","theme","colors","interactive","text","gray","normal","backgroundColor","background","position","display","flexDirection","alignItems","justifyContent","height","makeSize","NAV_ITEM_HEIGHT","textDecoration","overflow","flexWrap","cursor","padding","makeSpace","spacing","margin","subtle","borderRadius","border","radius","medium","borderWidth","makeBorderSize","none","transparent","transition","getNavItemTransition","primary","faded","fadedHighlighted","_objectSpread","getFocusRingStyles","NavLinkIconTitle","_ref2","Icon","icon","title","titleSuffix","isL1Item","_jsxs","Box","gap","children","_jsx","size","BaseText","truncateAfterLines","fontWeight","fontSize","lineHeight","as","className","L3Trigger","_ref3","href","target","tooltip","_useCollapsible","useCollapsible","onExpandChange","isExpanded","collapsibleBodyId","toggleCollapse","iconProps","TooltipifyNavItem","to","onClick","makeAccessible","expanded","controls","ChevronUpIcon","ChevronDownIcon","CurvedVerticalLine","_props$theme","thin","borderColor","surface","muted","borderStyle","top","left","SideNavLink","_ref4","trailing","isActive","_useSideNav","useSideNav","l2PortalContainerRef","onLinkActiveChange","closeMobileNav","isL1Collapsed","setIsL1Collapsed","_useNavLink","useNavLink","_prevLevel","level","prevLevel","currentLevel","isL2Trigger","Boolean","isL3Trigger","throwBladeError","message","moduleName","isFirstRender","useFirstRender","_useFloating","useFloating","open","refs","context","useIsomorphicLayoutEffect","NavLinkContext","Provider","value","Collapsible","defaultIsExpanded","_dangerouslyDisableValidations","_shouldApplyWidthRestrictions","CollapsibleBody","_hasMargin","_Fragment","undefined","ref","setReference","onFocus","e","_e$target","hasFocusRing","matches","ChevronRightIcon","right","FloatingPortal","root","FloatingFocusManager","modal","initialFocus","returnFocus","setFloating"],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import _defineProperty from '@babel/runtime/helpers/defineProperty';
|
|
2
|
+
import 'react';
|
|
3
|
+
import '../../Tooltip/index.js';
|
|
4
|
+
import { jsx } from 'react/jsx-runtime';
|
|
5
|
+
import { Tooltip } from '../../Tooltip/Tooltip.web.js';
|
|
6
|
+
|
|
7
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
8
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
9
|
+
var TooltipifyNavItem = function TooltipifyNavItem(_ref) {
|
|
10
|
+
var children = _ref.children,
|
|
11
|
+
tooltip = _ref.tooltip;
|
|
12
|
+
if (!tooltip) {
|
|
13
|
+
return children;
|
|
14
|
+
}
|
|
15
|
+
return /*#__PURE__*/jsx(Tooltip, _objectSpread(_objectSpread({}, tooltip), {}, {
|
|
16
|
+
placement: "top",
|
|
17
|
+
children: children
|
|
18
|
+
}));
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
export { TooltipifyNavItem };
|
|
22
|
+
//# sourceMappingURL=TooltipifyNavItem.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TooltipifyNavItem.js","sources":["../../../../../../../src/components/SideNav/SideNavItems/TooltipifyNavItem.tsx"],"sourcesContent":["import React from 'react';\nimport type { SideNavLinkProps } from '../types';\nimport { Tooltip } from '~components/Tooltip';\n\nconst TooltipifyNavItem = ({\n children,\n tooltip,\n}: {\n children: React.ReactElement;\n tooltip: SideNavLinkProps['tooltip'];\n}): React.ReactElement => {\n if (!tooltip) {\n return children;\n }\n\n return (\n <Tooltip {...tooltip} placement=\"top\">\n {children}\n </Tooltip>\n );\n};\n\nexport { TooltipifyNavItem };\n"],"names":["TooltipifyNavItem","_ref","children","tooltip","_jsx","Tooltip","_objectSpread","placement"],"mappings":";;;;;;;;AAIA,IAAMA,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAAC,IAAA,EAMG;AAAA,EAAA,IALxBC,QAAQ,GAAAD,IAAA,CAARC,QAAQ;IACRC,OAAO,GAAAF,IAAA,CAAPE,OAAO,CAAA;EAKP,IAAI,CAACA,OAAO,EAAE;AACZ,IAAA,OAAOD,QAAQ,CAAA;AACjB,GAAA;EAEA,oBACEE,GAAA,CAACC,OAAO,EAAAC,aAAA,CAAAA,aAAA,KAAKH,OAAO,CAAA,EAAA,EAAA,EAAA;AAAEI,IAAAA,SAAS,EAAC,KAAK;AAAAL,IAAAA,QAAA,EAClCA,QAAAA;AAAQ,GAAA,CACF,CAAC,CAAA;AAEd;;;;"}
|