@servicetitan/navigation 10.6.1 → 11.0.0-canary.237.4cefc6a.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.
Files changed (219) hide show
  1. package/package.json +4 -4
  2. package/src/components/header-navigation/header-navigation-extra.stories.tsx +7 -0
  3. package/src/components/header-navigation/header-navigation-links.tsx +2 -0
  4. package/src/components/header-navigation/header-navigation-stacked.stories.tsx +4 -0
  5. package/src/components/header-navigation/header-navigation.stories.tsx +5 -0
  6. package/src/components/left-navigation/header-navigation-tiny.stories.tsx +6 -0
  7. package/src/components/left-navigation/interface.ts +2 -2
  8. package/src/components/left-navigation/side-navigation-links-internal.tsx +21 -6
  9. package/src/components/left-navigation/side-navigation.module.less +21 -19
  10. package/src/components/left-navigation/side-navigation.tsx +15 -8
  11. package/src/components/links.tsx +33 -13
  12. package/src/components/logo/logo-company-title.tsx +8 -6
  13. package/src/components/profile-dropdown/profile-dropdown.module.less +4 -0
  14. package/src/components/profile-dropdown/profile-dropdown.stories.tsx +4 -4
  15. package/src/components/profile-dropdown/profile-dropdown.tsx +43 -46
  16. package/src/components/titan-layout/index.ts +5 -0
  17. package/src/components/titan-layout/interface-internal.ts +6 -0
  18. package/src/components/titan-layout/interface.ts +26 -0
  19. package/src/components/titan-layout/layout-context.tsx +30 -0
  20. package/src/components/titan-layout/layout-header-links.tsx +144 -0
  21. package/{dist/components/left-navigation/header-navigation-tiny.module.less → src/components/titan-layout/layout-header.module.less} +41 -5
  22. package/src/components/titan-layout/layout-header.tsx +86 -0
  23. package/src/components/titan-layout/layout-logo.stories.tsx +31 -0
  24. package/src/components/titan-layout/layout-logo.tsx +57 -0
  25. package/src/components/titan-layout/layout-profile.stories.tsx +37 -0
  26. package/src/components/titan-layout/layout-profile.tsx +116 -0
  27. package/src/components/titan-layout/layout-sidebar-links-internal.tsx +265 -0
  28. package/src/components/titan-layout/layout-sidebar-links.tsx +56 -0
  29. package/src/components/titan-layout/layout-sidebar.module.less +528 -0
  30. package/src/components/titan-layout/layout-sidebar.tsx +298 -0
  31. package/src/components/titan-layout/titan-layout.module.less +53 -0
  32. package/src/components/titan-layout/titan-layout.stories.tsx +194 -0
  33. package/src/components/titan-layout/titan-layout.tsx +270 -0
  34. package/src/components/titan-layout/with-tooltip.tsx +16 -0
  35. package/src/index.ts +2 -1
  36. package/src/test/data.tsx +3 -2
  37. package/src/utils/navigation-legacy.ts +3 -1
  38. package/src/utils/use-breakpoint.ts +19 -0
  39. package/dist/components/badge-tag.d.ts +0 -12
  40. package/dist/components/badge-tag.d.ts.map +0 -1
  41. package/dist/components/badge-tag.js +0 -8
  42. package/dist/components/badge-tag.js.map +0 -1
  43. package/dist/components/counter-tag.d.ts +0 -12
  44. package/dist/components/counter-tag.d.ts.map +0 -1
  45. package/dist/components/counter-tag.js +0 -8
  46. package/dist/components/counter-tag.js.map +0 -1
  47. package/dist/components/header-navigation/header-navigation-content.d.ts +0 -30
  48. package/dist/components/header-navigation/header-navigation-content.d.ts.map +0 -1
  49. package/dist/components/header-navigation/header-navigation-content.js +0 -22
  50. package/dist/components/header-navigation/header-navigation-content.js.map +0 -1
  51. package/dist/components/header-navigation/header-navigation-extra-stacked.stories.d.ts +0 -9
  52. package/dist/components/header-navigation/header-navigation-extra-stacked.stories.d.ts.map +0 -1
  53. package/dist/components/header-navigation/header-navigation-extra-stacked.stories.js +0 -13
  54. package/dist/components/header-navigation/header-navigation-extra-stacked.stories.js.map +0 -1
  55. package/dist/components/header-navigation/header-navigation-extra.stories.d.ts +0 -12
  56. package/dist/components/header-navigation/header-navigation-extra.stories.d.ts.map +0 -1
  57. package/dist/components/header-navigation/header-navigation-extra.stories.js +0 -29
  58. package/dist/components/header-navigation/header-navigation-extra.stories.js.map +0 -1
  59. package/dist/components/header-navigation/header-navigation-links.d.ts +0 -11
  60. package/dist/components/header-navigation/header-navigation-links.d.ts.map +0 -1
  61. package/dist/components/header-navigation/header-navigation-links.js +0 -26
  62. package/dist/components/header-navigation/header-navigation-links.js.map +0 -1
  63. package/dist/components/header-navigation/header-navigation-stacked.stories.d.ts +0 -12
  64. package/dist/components/header-navigation/header-navigation-stacked.stories.d.ts.map +0 -1
  65. package/dist/components/header-navigation/header-navigation-stacked.stories.js +0 -50
  66. package/dist/components/header-navigation/header-navigation-stacked.stories.js.map +0 -1
  67. package/dist/components/header-navigation/header-navigation-stories.module.less +0 -6
  68. package/dist/components/header-navigation/header-navigation.d.ts +0 -59
  69. package/dist/components/header-navigation/header-navigation.d.ts.map +0 -1
  70. package/dist/components/header-navigation/header-navigation.js +0 -96
  71. package/dist/components/header-navigation/header-navigation.js.map +0 -1
  72. package/dist/components/header-navigation/header-navigation.module.less +0 -260
  73. package/dist/components/header-navigation/header-navigation.stories.d.ts +0 -12
  74. package/dist/components/header-navigation/header-navigation.stories.d.ts.map +0 -1
  75. package/dist/components/header-navigation/header-navigation.stories.js +0 -54
  76. package/dist/components/header-navigation/header-navigation.stories.js.map +0 -1
  77. package/dist/components/header-navigation/index.d.ts +0 -2
  78. package/dist/components/header-navigation/index.d.ts.map +0 -1
  79. package/dist/components/header-navigation/index.js +0 -2
  80. package/dist/components/header-navigation/index.js.map +0 -1
  81. package/dist/components/header-navigation/with-tooltip.d.ts +0 -4
  82. package/dist/components/header-navigation/with-tooltip.d.ts.map +0 -1
  83. package/dist/components/header-navigation/with-tooltip.js +0 -4
  84. package/dist/components/header-navigation/with-tooltip.js.map +0 -1
  85. package/dist/components/layout.stories.d.ts +0 -13
  86. package/dist/components/layout.stories.d.ts.map +0 -1
  87. package/dist/components/layout.stories.js +0 -29
  88. package/dist/components/layout.stories.js.map +0 -1
  89. package/dist/components/left-navigation/header-navigation-extra-tiny.stories.d.ts +0 -9
  90. package/dist/components/left-navigation/header-navigation-extra-tiny.stories.d.ts.map +0 -1
  91. package/dist/components/left-navigation/header-navigation-extra-tiny.stories.js +0 -13
  92. package/dist/components/left-navigation/header-navigation-extra-tiny.stories.js.map +0 -1
  93. package/dist/components/left-navigation/header-navigation-tiny-links.d.ts +0 -18
  94. package/dist/components/left-navigation/header-navigation-tiny-links.d.ts.map +0 -1
  95. package/dist/components/left-navigation/header-navigation-tiny-links.js +0 -32
  96. package/dist/components/left-navigation/header-navigation-tiny-links.js.map +0 -1
  97. package/dist/components/left-navigation/header-navigation-tiny.d.ts +0 -23
  98. package/dist/components/left-navigation/header-navigation-tiny.d.ts.map +0 -1
  99. package/dist/components/left-navigation/header-navigation-tiny.js +0 -7
  100. package/dist/components/left-navigation/header-navigation-tiny.js.map +0 -1
  101. package/dist/components/left-navigation/header-navigation-tiny.stories.d.ts +0 -12
  102. package/dist/components/left-navigation/header-navigation-tiny.stories.d.ts.map +0 -1
  103. package/dist/components/left-navigation/header-navigation-tiny.stories.js +0 -30
  104. package/dist/components/left-navigation/header-navigation-tiny.stories.js.map +0 -1
  105. package/dist/components/left-navigation/index.d.ts +0 -5
  106. package/dist/components/left-navigation/index.d.ts.map +0 -1
  107. package/dist/components/left-navigation/index.js +0 -5
  108. package/dist/components/left-navigation/index.js.map +0 -1
  109. package/dist/components/left-navigation/interface-internal.d.ts +0 -10
  110. package/dist/components/left-navigation/interface-internal.d.ts.map +0 -1
  111. package/dist/components/left-navigation/interface-internal.js +0 -2
  112. package/dist/components/left-navigation/interface-internal.js.map +0 -1
  113. package/dist/components/left-navigation/interface.d.ts +0 -20
  114. package/dist/components/left-navigation/interface.d.ts.map +0 -1
  115. package/dist/components/left-navigation/interface.js +0 -2
  116. package/dist/components/left-navigation/interface.js.map +0 -1
  117. package/dist/components/left-navigation/side-navigation-context.d.ts +0 -8
  118. package/dist/components/left-navigation/side-navigation-context.d.ts.map +0 -1
  119. package/dist/components/left-navigation/side-navigation-context.js +0 -7
  120. package/dist/components/left-navigation/side-navigation-context.js.map +0 -1
  121. package/dist/components/left-navigation/side-navigation-links-internal.d.ts +0 -26
  122. package/dist/components/left-navigation/side-navigation-links-internal.d.ts.map +0 -1
  123. package/dist/components/left-navigation/side-navigation-links-internal.js +0 -29
  124. package/dist/components/left-navigation/side-navigation-links-internal.js.map +0 -1
  125. package/dist/components/left-navigation/side-navigation-links.d.ts +0 -6
  126. package/dist/components/left-navigation/side-navigation-links.d.ts.map +0 -1
  127. package/dist/components/left-navigation/side-navigation-links.js +0 -27
  128. package/dist/components/left-navigation/side-navigation-links.js.map +0 -1
  129. package/dist/components/left-navigation/side-navigation.d.ts +0 -29
  130. package/dist/components/left-navigation/side-navigation.d.ts.map +0 -1
  131. package/dist/components/left-navigation/side-navigation.js +0 -181
  132. package/dist/components/left-navigation/side-navigation.js.map +0 -1
  133. package/dist/components/left-navigation/side-navigation.module.less +0 -528
  134. package/dist/components/left-navigation/side-navigation.stories.d.ts +0 -17
  135. package/dist/components/left-navigation/side-navigation.stories.d.ts.map +0 -1
  136. package/dist/components/left-navigation/side-navigation.stories.js +0 -115
  137. package/dist/components/left-navigation/side-navigation.stories.js.map +0 -1
  138. package/dist/components/left-navigation/with-tooltip.d.ts +0 -4
  139. package/dist/components/left-navigation/with-tooltip.d.ts.map +0 -1
  140. package/dist/components/left-navigation/with-tooltip.js +0 -4
  141. package/dist/components/left-navigation/with-tooltip.js.map +0 -1
  142. package/dist/components/links.d.ts +0 -5
  143. package/dist/components/links.d.ts.map +0 -1
  144. package/dist/components/links.js +0 -14
  145. package/dist/components/links.js.map +0 -1
  146. package/dist/components/logo/logo-company-title.d.ts +0 -7
  147. package/dist/components/logo/logo-company-title.d.ts.map +0 -1
  148. package/dist/components/logo/logo-company-title.js +0 -6
  149. package/dist/components/logo/logo-company-title.js.map +0 -1
  150. package/dist/components/logo/logo-titan-text.d.ts +0 -29
  151. package/dist/components/logo/logo-titan-text.d.ts.map +0 -1
  152. package/dist/components/logo/logo-titan-text.js +0 -13
  153. package/dist/components/logo/logo-titan-text.js.map +0 -1
  154. package/dist/components/logo/logo-titan-text.module.less +0 -31
  155. package/dist/components/logo/logo-titan.d.ts +0 -9
  156. package/dist/components/logo/logo-titan.d.ts.map +0 -1
  157. package/dist/components/logo/logo-titan.js +0 -13
  158. package/dist/components/logo/logo-titan.js.map +0 -1
  159. package/dist/components/logo/logo.stories.d.ts +0 -14
  160. package/dist/components/logo/logo.stories.d.ts.map +0 -1
  161. package/dist/components/logo/logo.stories.js +0 -20
  162. package/dist/components/logo/logo.stories.js.map +0 -1
  163. package/dist/components/profile-dropdown/profile-dropdown-stacked.stories.d.ts +0 -9
  164. package/dist/components/profile-dropdown/profile-dropdown-stacked.stories.d.ts.map +0 -1
  165. package/dist/components/profile-dropdown/profile-dropdown-stacked.stories.js +0 -13
  166. package/dist/components/profile-dropdown/profile-dropdown-stacked.stories.js.map +0 -1
  167. package/dist/components/profile-dropdown/profile-dropdown-tiny.stories.d.ts +0 -9
  168. package/dist/components/profile-dropdown/profile-dropdown-tiny.stories.d.ts.map +0 -1
  169. package/dist/components/profile-dropdown/profile-dropdown-tiny.stories.js +0 -13
  170. package/dist/components/profile-dropdown/profile-dropdown-tiny.stories.js.map +0 -1
  171. package/dist/components/profile-dropdown/profile-dropdown.d.ts +0 -74
  172. package/dist/components/profile-dropdown/profile-dropdown.d.ts.map +0 -1
  173. package/dist/components/profile-dropdown/profile-dropdown.js +0 -86
  174. package/dist/components/profile-dropdown/profile-dropdown.js.map +0 -1
  175. package/dist/components/profile-dropdown/profile-dropdown.module.less +0 -167
  176. package/dist/components/profile-dropdown/profile-dropdown.stories.d.ts +0 -16
  177. package/dist/components/profile-dropdown/profile-dropdown.stories.d.ts.map +0 -1
  178. package/dist/components/profile-dropdown/profile-dropdown.stories.js +0 -51
  179. package/dist/components/profile-dropdown/profile-dropdown.stories.js.map +0 -1
  180. package/dist/components/profile-dropdown/profile-icon.d.ts +0 -3
  181. package/dist/components/profile-dropdown/profile-icon.d.ts.map +0 -1
  182. package/dist/components/profile-dropdown/profile-icon.js +0 -5
  183. package/dist/components/profile-dropdown/profile-icon.js.map +0 -1
  184. package/dist/index.d.ts +0 -12
  185. package/dist/index.d.ts.map +0 -1
  186. package/dist/index.js +0 -12
  187. package/dist/index.js.map +0 -1
  188. package/dist/test/data-stories.module.less +0 -8
  189. package/dist/test/data.d.ts +0 -32
  190. package/dist/test/data.d.ts.map +0 -1
  191. package/dist/test/data.js +0 -244
  192. package/dist/test/data.js.map +0 -1
  193. package/dist/utils/counter-tag.d.ts +0 -5
  194. package/dist/utils/counter-tag.d.ts.map +0 -1
  195. package/dist/utils/counter-tag.js +0 -2
  196. package/dist/utils/counter-tag.js.map +0 -1
  197. package/dist/utils/navigation-context.d.ts +0 -27
  198. package/dist/utils/navigation-context.d.ts.map +0 -1
  199. package/dist/utils/navigation-context.js +0 -10
  200. package/dist/utils/navigation-context.js.map +0 -1
  201. package/dist/utils/navigation-legacy.d.ts +0 -86
  202. package/dist/utils/navigation-legacy.d.ts.map +0 -1
  203. package/dist/utils/navigation-legacy.js +0 -2
  204. package/dist/utils/navigation-legacy.js.map +0 -1
  205. package/dist/utils/navigation.d.ts +0 -48
  206. package/dist/utils/navigation.d.ts.map +0 -1
  207. package/dist/utils/navigation.js +0 -2
  208. package/dist/utils/navigation.js.map +0 -1
  209. package/dist/utils/side-nav.d.ts +0 -6
  210. package/dist/utils/side-nav.d.ts.map +0 -1
  211. package/dist/utils/side-nav.js +0 -28
  212. package/dist/utils/side-nav.js.map +0 -1
  213. package/src/components/header-navigation/header-navigation-stories.module.less.d.ts +0 -3
  214. package/src/components/header-navigation/header-navigation.module.less.d.ts +0 -22
  215. package/src/components/left-navigation/header-navigation-tiny.module.less.d.ts +0 -15
  216. package/src/components/left-navigation/side-navigation.module.less.d.ts +0 -47
  217. package/src/components/logo/logo-titan-text.module.less.d.ts +0 -6
  218. package/src/components/profile-dropdown/profile-dropdown.module.less.d.ts +0 -21
  219. package/src/test/data-stories.module.less.d.ts +0 -3
@@ -0,0 +1,116 @@
1
+ import SvgAccountActive from '@servicetitan/anvil2/assets/icons/st/gnav_account_active.svg';
2
+ import SvgAccountInactive from '@servicetitan/anvil2/assets/icons/st/gnav_account_inactive.svg';
3
+
4
+ import { FC, useState } from 'react';
5
+ import { NavigationComponentContext } from '../../utils/navigation-context';
6
+ import {
7
+ ProfileDropdown as DesktopProfileDropdown,
8
+ ProfileDropdownLinkProps,
9
+ ProfileDropdownProps,
10
+ ProfileDropdownSectionProps,
11
+ } from '../profile-dropdown/profile-dropdown';
12
+ import { NavigationComponentProps } from './interface-internal';
13
+ import { useTitanLayoutContext } from './layout-context';
14
+ import {
15
+ InternalSideNavigationGroup,
16
+ InternalSideNavigationGroupDivider,
17
+ InternalSideNavigationGroupLink,
18
+ InternalSideNavigationGroupTrigger,
19
+ } from './layout-sidebar-links-internal';
20
+
21
+ export type {
22
+ ProfileDropdownProps,
23
+ ProfileDropdownSectionProps,
24
+ ProfileDropdownLinkProps,
25
+ } from '../profile-dropdown/profile-dropdown';
26
+
27
+ const ProfileDropdownContent: FC<ProfileDropdownProps> = props => {
28
+ const { breakpoint, NavigationComponent } = useTitanLayoutContext();
29
+ return breakpoint.isMobile ? (
30
+ <MobileProfileDropdown {...props} navigationComponent={NavigationComponent} />
31
+ ) : (
32
+ <NavigationComponentContext.Provider value={NavigationComponent}>
33
+ <DesktopProfileDropdown {...props} />
34
+ </NavigationComponentContext.Provider>
35
+ );
36
+ };
37
+ ProfileDropdownContent.displayName = 'ProfileDropdown';
38
+
39
+ const MobileProfileDropdown: FC<ProfileDropdownProps & NavigationComponentProps> = ({
40
+ children,
41
+ ...props
42
+ }) => {
43
+ const [expanded, setExpanded] = useState(false);
44
+ const onExpandToggle = () => setExpanded(!expanded);
45
+ return (
46
+ <InternalSideNavigationGroup
47
+ id="__profile"
48
+ to={undefined}
49
+ title="Profile"
50
+ icon={SvgAccountInactive}
51
+ iconActive={SvgAccountActive}
52
+ isActive={expanded}
53
+ {...props}
54
+ submenuExpanded={expanded}
55
+ onExpandToggle={onExpandToggle}
56
+ onClick={onExpandToggle}
57
+ tag={undefined}
58
+ >
59
+ {children}
60
+ </InternalSideNavigationGroup>
61
+ );
62
+ };
63
+
64
+ const ProfileDropdownDivider: FC = () => {
65
+ const { breakpoint } = useTitanLayoutContext();
66
+ return breakpoint.isMobile ? (
67
+ <InternalSideNavigationGroupDivider />
68
+ ) : (
69
+ <DesktopProfileDropdown.Divider />
70
+ );
71
+ };
72
+
73
+ const ProfileDropdownSection: FC<ProfileDropdownSectionProps> = props => {
74
+ const { breakpoint } = useTitanLayoutContext();
75
+ return breakpoint.isMobile ? (
76
+ <MobileProfileDropdownSection {...props} />
77
+ ) : (
78
+ <DesktopProfileDropdown.Section {...props} />
79
+ );
80
+ };
81
+ const MobileProfileDropdownSection: FC<ProfileDropdownSectionProps> = props => {
82
+ const title = typeof props.children === 'string' ? props.children : undefined;
83
+ return title ? (
84
+ <InternalSideNavigationGroupTrigger id={props.id} title={title} onClick={props.onClick} />
85
+ ) : null;
86
+ };
87
+
88
+ const ProfileDropdownLink: FC<ProfileDropdownLinkProps> = props => {
89
+ const { breakpoint, NavigationComponent } = useTitanLayoutContext();
90
+ return breakpoint.isMobile ? (
91
+ <MobileProfileDropdownLink {...props} navigationComponent={NavigationComponent} />
92
+ ) : (
93
+ <DesktopProfileDropdown.Link {...props} />
94
+ );
95
+ };
96
+ const MobileProfileDropdownLink: FC<ProfileDropdownLinkProps & NavigationComponentProps> = ({
97
+ to,
98
+ navigationComponent,
99
+ ...props
100
+ }) => {
101
+ const title = typeof props.children === 'string' ? props.children : undefined;
102
+ return title ? (
103
+ <InternalSideNavigationGroupLink
104
+ {...props}
105
+ to={to}
106
+ title={title}
107
+ navigationComponent={navigationComponent}
108
+ />
109
+ ) : null;
110
+ };
111
+
112
+ export const ProfileDropdown = Object.assign(ProfileDropdownContent, {
113
+ Divider: ProfileDropdownDivider,
114
+ Link: ProfileDropdownLink,
115
+ Section: ProfileDropdownSection,
116
+ });
@@ -0,0 +1,265 @@
1
+ import { Icon } from '@servicetitan/anvil2';
2
+ import SvgGroupCollapse from '@servicetitan/anvil2/assets/icons/material/round/expand_less.svg';
3
+ import SvgGroupExpand from '@servicetitan/anvil2/assets/icons/material/round/expand_more.svg';
4
+
5
+ import classNames from 'classnames';
6
+ import { FC, Fragment, MouseEvent, ReactNode } from 'react';
7
+ import { NavigationItemData, NavigationSubmenuItemData } from '../../utils/navigation';
8
+ import { getCounterTag } from '../../utils/side-nav';
9
+ import { BadgeTag, BadgeTagProps } from '../badge-tag';
10
+ import { TitanLayoutSidebarTriggerProps } from './interface';
11
+ import { NavigationComponentProps } from './interface-internal';
12
+ import * as Styles from './layout-sidebar.module.less';
13
+
14
+ export interface InternalSideNavigationItemContentProps
15
+ extends Omit<NavigationItemData, 'iconName' | 'to' | 'counter' | 'tag'> {
16
+ submenuExpanded: boolean | undefined;
17
+ tag: BadgeTagProps | undefined;
18
+ onExpandToggle?: (e: MouseEvent<never>) => void;
19
+ }
20
+
21
+ export const InternalSideNavigationItemContent: FC<InternalSideNavigationItemContentProps> = ({
22
+ icon,
23
+ iconActive,
24
+ iconClassName,
25
+ iconComponent: IconComponent,
26
+ tag,
27
+ title,
28
+ submenuExpanded,
29
+ onExpandToggle,
30
+ }) => (
31
+ <Fragment>
32
+ <div className={Styles.navItemIconWrapper}>
33
+ {IconComponent ? (
34
+ <i className={classNames(Styles.navIcon, iconClassName)}>
35
+ <IconComponent />
36
+ </i>
37
+ ) : (
38
+ <Fragment>
39
+ {icon && (
40
+ <Icon
41
+ svg={icon}
42
+ className={classNames(
43
+ Styles.navIcon,
44
+ Styles.navIconInactive,
45
+ iconClassName
46
+ )}
47
+ />
48
+ )}
49
+ {iconActive && (
50
+ <Icon
51
+ svg={iconActive}
52
+ className={classNames(
53
+ Styles.navIcon,
54
+ Styles.navIconActive,
55
+ iconClassName
56
+ )}
57
+ />
58
+ )}
59
+ </Fragment>
60
+ )}
61
+
62
+ <div className={Styles.navItemTextExpanded}>{title}</div>
63
+ {!!tag && (
64
+ <BadgeTag
65
+ data={tag}
66
+ className={Styles.navItemCounter}
67
+ longClassName={Styles.navItemCounterLong}
68
+ />
69
+ )}
70
+ {typeof submenuExpanded === 'boolean' && (
71
+ <div className={Styles.navItemGroupToggleWrapper}>
72
+ <Icon
73
+ svg={submenuExpanded ? SvgGroupCollapse : SvgGroupExpand}
74
+ className={Styles.navItemGroupToggle}
75
+ onClick={onExpandToggle}
76
+ />
77
+ <div className={Styles.navItemGroupToggleClick} onClick={onExpandToggle} />
78
+ </div>
79
+ )}
80
+ </div>
81
+
82
+ <div
83
+ className={classNames(Styles.navItemTextCollapsed, {
84
+ [Styles.navItemTextSmall]: !!title && title.length >= 10,
85
+ })}
86
+ >
87
+ {title}
88
+ </div>
89
+ </Fragment>
90
+ );
91
+
92
+ export interface InternalSideNavigationLinkProps
93
+ extends Omit<NavigationItemData, 'iconName' | 'counter' | 'tag'>,
94
+ NavigationComponentProps {
95
+ submenuExpanded: boolean | undefined;
96
+ dataPrefix?: string;
97
+ tag: BadgeTagProps | undefined;
98
+ onExpandToggle?: (e: MouseEvent<never>) => void;
99
+ }
100
+
101
+ export const internalNavigationContentContainerProps = ({
102
+ className,
103
+ icon,
104
+ iconActive,
105
+ iconComponent,
106
+ id,
107
+ isActive,
108
+ prefix,
109
+ isLink,
110
+ }: Omit<TitanLayoutSidebarTriggerProps, 'isActive' | 'tag'> & {
111
+ prefix: string;
112
+ isActive?: any;
113
+ isLink: boolean;
114
+ }) => ({
115
+ 'data-cy': `${prefix}-${id}`,
116
+ 'data-pendo': `${prefix}-${id}`,
117
+ 'className': classNames(Styles.navItem, className, {
118
+ [Styles.navLink]: isLink,
119
+ [Styles.navItemActive]: isActive === true,
120
+ [Styles.navItemIconSwitch]: !!icon && !!iconActive && !iconComponent,
121
+ }),
122
+ });
123
+
124
+ /** Side Navigation menu item (for internal usage) */
125
+ export const InternalSideNavigationLink: FC<InternalSideNavigationLinkProps> = ({
126
+ to,
127
+ className,
128
+ dataPrefix,
129
+ isActive,
130
+ navigationComponent: NavigationComponent,
131
+ submenuExpanded,
132
+ onExpandToggle,
133
+ ...props
134
+ }) => {
135
+ return (
136
+ <NavigationComponent
137
+ {...internalNavigationContentContainerProps({
138
+ ...props,
139
+ prefix: dataPrefix ?? 'navigation-item',
140
+ className,
141
+ isActive,
142
+ isLink: true,
143
+ })}
144
+ to={to}
145
+ isActive={typeof isActive === 'function' ? isActive : undefined}
146
+ activeClassName={Styles.navItemActive}
147
+ >
148
+ <InternalSideNavigationItemContent
149
+ submenuExpanded={submenuExpanded}
150
+ onExpandToggle={onExpandToggle}
151
+ {...props}
152
+ />
153
+ </NavigationComponent>
154
+ );
155
+ };
156
+
157
+ /** Side Navigation menu trigger (for internal usage) */
158
+ export const InternalSideNavigationTrigger: FC<
159
+ Omit<InternalSideNavigationLinkProps, 'to' | 'navigationComponent'> & { onClick?: () => void }
160
+ > = ({ className, dataPrefix, isActive, submenuExpanded, onExpandToggle, onClick, ...props }) => {
161
+ return (
162
+ <div
163
+ {...internalNavigationContentContainerProps({
164
+ ...props,
165
+ prefix: dataPrefix ?? 'navigation-item',
166
+ className,
167
+ isActive,
168
+ isLink: !!onClick,
169
+ })}
170
+ onClick={onClick}
171
+ >
172
+ <InternalSideNavigationItemContent
173
+ submenuExpanded={submenuExpanded}
174
+ onExpandToggle={onExpandToggle}
175
+ {...props}
176
+ />
177
+ </div>
178
+ );
179
+ };
180
+
181
+ export const InternalSideNavigationGroupLink: FC<
182
+ NavigationSubmenuItemData & NavigationComponentProps
183
+ > = ({ id, counter, tag, title, to, isActive, navigationComponent: NavigationComponent }) => {
184
+ return (
185
+ <NavigationComponent
186
+ data-cy={`navigation-item-${id}`}
187
+ data-pendo={`navigation-item-${id}`}
188
+ key={id}
189
+ to={to}
190
+ className={classNames(Styles.submenuItem, Styles.submenuLink, {
191
+ [Styles.submenuLinkActive]: isActive === true,
192
+ })}
193
+ isActive={typeof isActive === 'function' ? isActive : undefined}
194
+ activeClassName={Styles.submenuLinkActive}
195
+ >
196
+ <span>{title}</span>
197
+ <BadgeTag data={getCounterTag(counter, tag)} className={Styles.submenuLinkCounter} />
198
+ </NavigationComponent>
199
+ );
200
+ };
201
+
202
+ export const InternalSideNavigationGroupTrigger: FC<
203
+ Omit<NavigationSubmenuItemData, 'to'> & { onClick?: (e: MouseEvent<any>) => void }
204
+ > = ({ id, counter, onClick, tag, title, isActive }) => {
205
+ return (
206
+ <div
207
+ data-cy={`navigation-item-${id}`}
208
+ data-pendo={`navigation-item-${id}`}
209
+ key={id}
210
+ className={classNames(Styles.submenuItem, {
211
+ [Styles.submenuLink]: !!onClick,
212
+ [Styles.submenuLinkActive]: isActive === true,
213
+ })}
214
+ onClick={onClick}
215
+ >
216
+ <span>{title}</span>
217
+ <BadgeTag data={getCounterTag(counter, tag)} className={Styles.submenuLinkCounter} />
218
+ </div>
219
+ );
220
+ };
221
+
222
+ export const InternalSideNavigationGroupDivider = () => {
223
+ return <div className={Styles.divider} />;
224
+ };
225
+
226
+ export const InternalSideNavigationGroup: FC<
227
+ Omit<NavigationItemData, 'tag' | 'counter' | 'to'> &
228
+ NavigationComponentProps & {
229
+ children: ReactNode;
230
+ submenuExpanded: boolean;
231
+ onExpandToggle?: (e: MouseEvent<never>) => void;
232
+ tag: BadgeTagProps | undefined;
233
+ to: NavigationItemData['to'] | undefined;
234
+ onClick?: () => void;
235
+ }
236
+ > = ({ children, submenuExpanded, to, onExpandToggle, onClick, ...props }) => {
237
+ return (
238
+ <div className={classNames(Styles.navGroupWrapper)}>
239
+ <div className={Styles.navGroupItem}>
240
+ {to ? (
241
+ <InternalSideNavigationLink
242
+ {...props}
243
+ to={to}
244
+ submenuExpanded={submenuExpanded}
245
+ onExpandToggle={onExpandToggle}
246
+ />
247
+ ) : (
248
+ <InternalSideNavigationTrigger
249
+ {...props}
250
+ submenuExpanded={submenuExpanded}
251
+ onExpandToggle={onExpandToggle}
252
+ onClick={onClick}
253
+ />
254
+ )}
255
+ </div>
256
+ <div
257
+ className={classNames(Styles.submenuWrapper, {
258
+ [Styles.submenuWrapperCollapsed]: !submenuExpanded,
259
+ })}
260
+ >
261
+ <div className={Styles.submenu}>{children}</div>
262
+ </div>
263
+ </div>
264
+ );
265
+ };
@@ -0,0 +1,56 @@
1
+ import { FC, ReactElement } from 'react';
2
+ import { getCounterTag } from '../../utils/side-nav';
3
+ import { TitanLayoutSidebarLinkProps, TitanLayoutSidebarTriggerProps } from './interface';
4
+ import { useTitanLayoutContext } from './layout-context';
5
+ import {
6
+ InternalSideNavigationLink,
7
+ InternalSideNavigationTrigger,
8
+ } from './layout-sidebar-links-internal';
9
+
10
+ const WrappedLink: FC<{
11
+ children: ReactElement;
12
+ wrapper: NonNullable<TitanLayoutSidebarLinkProps['wrapper']>;
13
+ }> = ({ children, wrapper: WrapperComponent }) => {
14
+ const { sidebar } = useTitanLayoutContext();
15
+ return <WrapperComponent context={sidebar}>{children}</WrapperComponent>;
16
+ };
17
+
18
+ /** Side Navigation menu link */
19
+ export function TitanLayoutSidebarLink({ wrapper, ...props }: TitanLayoutSidebarLinkProps) {
20
+ const { NavigationComponent } = useTitanLayoutContext();
21
+
22
+ const element = (
23
+ <InternalSideNavigationLink
24
+ {...props}
25
+ navigationComponent={NavigationComponent}
26
+ submenuExpanded={undefined}
27
+ dataPrefix="navigation-link"
28
+ tag={getCounterTag(props.counter, props.tag)}
29
+ />
30
+ );
31
+
32
+ return wrapper ? <WrappedLink wrapper={wrapper}>{element}</WrappedLink> : element;
33
+ }
34
+
35
+ /** Side Navigation menu trigger */
36
+ export function TitanLayoutSidebarTrigger({
37
+ wrapper,
38
+ onMobileClick,
39
+ onClick,
40
+ ...props
41
+ }: TitanLayoutSidebarTriggerProps) {
42
+ const {
43
+ breakpoint: { isMobile },
44
+ } = useTitanLayoutContext();
45
+
46
+ const element = (
47
+ <InternalSideNavigationTrigger
48
+ {...props}
49
+ submenuExpanded={undefined}
50
+ dataPrefix="navigation-trigger"
51
+ tag={getCounterTag(props.counter, props.tag)}
52
+ onClick={isMobile && !!onMobileClick ? onMobileClick : onClick}
53
+ />
54
+ );
55
+ return wrapper && !isMobile ? <WrappedLink wrapper={wrapper}>{element}</WrappedLink> : element;
56
+ }