@servicetitan/navigation 10.7.0 → 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 (215) 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/links.tsx +33 -13
  8. package/src/components/logo/logo-company-title.tsx +8 -6
  9. package/src/components/profile-dropdown/profile-dropdown.module.less +4 -0
  10. package/src/components/profile-dropdown/profile-dropdown.stories.tsx +4 -4
  11. package/src/components/profile-dropdown/profile-dropdown.tsx +43 -46
  12. package/src/components/titan-layout/index.ts +5 -0
  13. package/src/components/titan-layout/interface-internal.ts +6 -0
  14. package/src/components/titan-layout/interface.ts +26 -0
  15. package/src/components/titan-layout/layout-context.tsx +30 -0
  16. package/src/components/titan-layout/layout-header-links.tsx +144 -0
  17. package/{dist/components/left-navigation/header-navigation-tiny.module.less → src/components/titan-layout/layout-header.module.less} +41 -5
  18. package/src/components/titan-layout/layout-header.tsx +86 -0
  19. package/src/components/titan-layout/layout-logo.stories.tsx +31 -0
  20. package/src/components/titan-layout/layout-logo.tsx +57 -0
  21. package/src/components/titan-layout/layout-profile.stories.tsx +37 -0
  22. package/src/components/titan-layout/layout-profile.tsx +116 -0
  23. package/src/components/titan-layout/layout-sidebar-links-internal.tsx +265 -0
  24. package/src/components/titan-layout/layout-sidebar-links.tsx +56 -0
  25. package/src/components/titan-layout/layout-sidebar.module.less +528 -0
  26. package/src/components/titan-layout/layout-sidebar.tsx +298 -0
  27. package/src/components/titan-layout/titan-layout.module.less +53 -0
  28. package/src/components/titan-layout/titan-layout.stories.tsx +194 -0
  29. package/src/components/titan-layout/titan-layout.tsx +270 -0
  30. package/src/components/titan-layout/with-tooltip.tsx +16 -0
  31. package/src/index.ts +2 -1
  32. package/src/test/data.tsx +3 -2
  33. package/src/utils/navigation-legacy.ts +3 -1
  34. package/src/utils/use-breakpoint.ts +19 -0
  35. package/dist/components/badge-tag.d.ts +0 -12
  36. package/dist/components/badge-tag.d.ts.map +0 -1
  37. package/dist/components/badge-tag.js +0 -8
  38. package/dist/components/badge-tag.js.map +0 -1
  39. package/dist/components/counter-tag.d.ts +0 -12
  40. package/dist/components/counter-tag.d.ts.map +0 -1
  41. package/dist/components/counter-tag.js +0 -8
  42. package/dist/components/counter-tag.js.map +0 -1
  43. package/dist/components/header-navigation/header-navigation-content.d.ts +0 -30
  44. package/dist/components/header-navigation/header-navigation-content.d.ts.map +0 -1
  45. package/dist/components/header-navigation/header-navigation-content.js +0 -22
  46. package/dist/components/header-navigation/header-navigation-content.js.map +0 -1
  47. package/dist/components/header-navigation/header-navigation-extra-stacked.stories.d.ts +0 -9
  48. package/dist/components/header-navigation/header-navigation-extra-stacked.stories.d.ts.map +0 -1
  49. package/dist/components/header-navigation/header-navigation-extra-stacked.stories.js +0 -13
  50. package/dist/components/header-navigation/header-navigation-extra-stacked.stories.js.map +0 -1
  51. package/dist/components/header-navigation/header-navigation-extra.stories.d.ts +0 -12
  52. package/dist/components/header-navigation/header-navigation-extra.stories.d.ts.map +0 -1
  53. package/dist/components/header-navigation/header-navigation-extra.stories.js +0 -29
  54. package/dist/components/header-navigation/header-navigation-extra.stories.js.map +0 -1
  55. package/dist/components/header-navigation/header-navigation-links.d.ts +0 -11
  56. package/dist/components/header-navigation/header-navigation-links.d.ts.map +0 -1
  57. package/dist/components/header-navigation/header-navigation-links.js +0 -26
  58. package/dist/components/header-navigation/header-navigation-links.js.map +0 -1
  59. package/dist/components/header-navigation/header-navigation-stacked.stories.d.ts +0 -12
  60. package/dist/components/header-navigation/header-navigation-stacked.stories.d.ts.map +0 -1
  61. package/dist/components/header-navigation/header-navigation-stacked.stories.js +0 -50
  62. package/dist/components/header-navigation/header-navigation-stacked.stories.js.map +0 -1
  63. package/dist/components/header-navigation/header-navigation-stories.module.less +0 -6
  64. package/dist/components/header-navigation/header-navigation.d.ts +0 -59
  65. package/dist/components/header-navigation/header-navigation.d.ts.map +0 -1
  66. package/dist/components/header-navigation/header-navigation.js +0 -96
  67. package/dist/components/header-navigation/header-navigation.js.map +0 -1
  68. package/dist/components/header-navigation/header-navigation.module.less +0 -260
  69. package/dist/components/header-navigation/header-navigation.stories.d.ts +0 -12
  70. package/dist/components/header-navigation/header-navigation.stories.d.ts.map +0 -1
  71. package/dist/components/header-navigation/header-navigation.stories.js +0 -54
  72. package/dist/components/header-navigation/header-navigation.stories.js.map +0 -1
  73. package/dist/components/header-navigation/index.d.ts +0 -2
  74. package/dist/components/header-navigation/index.d.ts.map +0 -1
  75. package/dist/components/header-navigation/index.js +0 -2
  76. package/dist/components/header-navigation/index.js.map +0 -1
  77. package/dist/components/header-navigation/with-tooltip.d.ts +0 -4
  78. package/dist/components/header-navigation/with-tooltip.d.ts.map +0 -1
  79. package/dist/components/header-navigation/with-tooltip.js +0 -4
  80. package/dist/components/header-navigation/with-tooltip.js.map +0 -1
  81. package/dist/components/layout.stories.d.ts +0 -13
  82. package/dist/components/layout.stories.d.ts.map +0 -1
  83. package/dist/components/layout.stories.js +0 -29
  84. package/dist/components/layout.stories.js.map +0 -1
  85. package/dist/components/left-navigation/header-navigation-extra-tiny.stories.d.ts +0 -9
  86. package/dist/components/left-navigation/header-navigation-extra-tiny.stories.d.ts.map +0 -1
  87. package/dist/components/left-navigation/header-navigation-extra-tiny.stories.js +0 -13
  88. package/dist/components/left-navigation/header-navigation-extra-tiny.stories.js.map +0 -1
  89. package/dist/components/left-navigation/header-navigation-tiny-links.d.ts +0 -18
  90. package/dist/components/left-navigation/header-navigation-tiny-links.d.ts.map +0 -1
  91. package/dist/components/left-navigation/header-navigation-tiny-links.js +0 -32
  92. package/dist/components/left-navigation/header-navigation-tiny-links.js.map +0 -1
  93. package/dist/components/left-navigation/header-navigation-tiny.d.ts +0 -23
  94. package/dist/components/left-navigation/header-navigation-tiny.d.ts.map +0 -1
  95. package/dist/components/left-navigation/header-navigation-tiny.js +0 -7
  96. package/dist/components/left-navigation/header-navigation-tiny.js.map +0 -1
  97. package/dist/components/left-navigation/header-navigation-tiny.stories.d.ts +0 -12
  98. package/dist/components/left-navigation/header-navigation-tiny.stories.d.ts.map +0 -1
  99. package/dist/components/left-navigation/header-navigation-tiny.stories.js +0 -30
  100. package/dist/components/left-navigation/header-navigation-tiny.stories.js.map +0 -1
  101. package/dist/components/left-navigation/index.d.ts +0 -5
  102. package/dist/components/left-navigation/index.d.ts.map +0 -1
  103. package/dist/components/left-navigation/index.js +0 -5
  104. package/dist/components/left-navigation/index.js.map +0 -1
  105. package/dist/components/left-navigation/interface-internal.d.ts +0 -10
  106. package/dist/components/left-navigation/interface-internal.d.ts.map +0 -1
  107. package/dist/components/left-navigation/interface-internal.js +0 -2
  108. package/dist/components/left-navigation/interface-internal.js.map +0 -1
  109. package/dist/components/left-navigation/interface.d.ts +0 -20
  110. package/dist/components/left-navigation/interface.d.ts.map +0 -1
  111. package/dist/components/left-navigation/interface.js +0 -2
  112. package/dist/components/left-navigation/interface.js.map +0 -1
  113. package/dist/components/left-navigation/side-navigation-context.d.ts +0 -8
  114. package/dist/components/left-navigation/side-navigation-context.d.ts.map +0 -1
  115. package/dist/components/left-navigation/side-navigation-context.js +0 -7
  116. package/dist/components/left-navigation/side-navigation-context.js.map +0 -1
  117. package/dist/components/left-navigation/side-navigation-links-internal.d.ts +0 -28
  118. package/dist/components/left-navigation/side-navigation-links-internal.d.ts.map +0 -1
  119. package/dist/components/left-navigation/side-navigation-links-internal.js +0 -29
  120. package/dist/components/left-navigation/side-navigation-links-internal.js.map +0 -1
  121. package/dist/components/left-navigation/side-navigation-links.d.ts +0 -6
  122. package/dist/components/left-navigation/side-navigation-links.d.ts.map +0 -1
  123. package/dist/components/left-navigation/side-navigation-links.js +0 -27
  124. package/dist/components/left-navigation/side-navigation-links.js.map +0 -1
  125. package/dist/components/left-navigation/side-navigation.d.ts +0 -29
  126. package/dist/components/left-navigation/side-navigation.d.ts.map +0 -1
  127. package/dist/components/left-navigation/side-navigation.js +0 -182
  128. package/dist/components/left-navigation/side-navigation.js.map +0 -1
  129. package/dist/components/left-navigation/side-navigation.module.less +0 -530
  130. package/dist/components/left-navigation/side-navigation.stories.d.ts +0 -17
  131. package/dist/components/left-navigation/side-navigation.stories.d.ts.map +0 -1
  132. package/dist/components/left-navigation/side-navigation.stories.js +0 -115
  133. package/dist/components/left-navigation/side-navigation.stories.js.map +0 -1
  134. package/dist/components/left-navigation/with-tooltip.d.ts +0 -4
  135. package/dist/components/left-navigation/with-tooltip.d.ts.map +0 -1
  136. package/dist/components/left-navigation/with-tooltip.js +0 -4
  137. package/dist/components/left-navigation/with-tooltip.js.map +0 -1
  138. package/dist/components/links.d.ts +0 -5
  139. package/dist/components/links.d.ts.map +0 -1
  140. package/dist/components/links.js +0 -14
  141. package/dist/components/links.js.map +0 -1
  142. package/dist/components/logo/logo-company-title.d.ts +0 -7
  143. package/dist/components/logo/logo-company-title.d.ts.map +0 -1
  144. package/dist/components/logo/logo-company-title.js +0 -6
  145. package/dist/components/logo/logo-company-title.js.map +0 -1
  146. package/dist/components/logo/logo-titan-text.d.ts +0 -29
  147. package/dist/components/logo/logo-titan-text.d.ts.map +0 -1
  148. package/dist/components/logo/logo-titan-text.js +0 -13
  149. package/dist/components/logo/logo-titan-text.js.map +0 -1
  150. package/dist/components/logo/logo-titan-text.module.less +0 -31
  151. package/dist/components/logo/logo-titan.d.ts +0 -9
  152. package/dist/components/logo/logo-titan.d.ts.map +0 -1
  153. package/dist/components/logo/logo-titan.js +0 -13
  154. package/dist/components/logo/logo-titan.js.map +0 -1
  155. package/dist/components/logo/logo.stories.d.ts +0 -14
  156. package/dist/components/logo/logo.stories.d.ts.map +0 -1
  157. package/dist/components/logo/logo.stories.js +0 -20
  158. package/dist/components/logo/logo.stories.js.map +0 -1
  159. package/dist/components/profile-dropdown/profile-dropdown-stacked.stories.d.ts +0 -9
  160. package/dist/components/profile-dropdown/profile-dropdown-stacked.stories.d.ts.map +0 -1
  161. package/dist/components/profile-dropdown/profile-dropdown-stacked.stories.js +0 -13
  162. package/dist/components/profile-dropdown/profile-dropdown-stacked.stories.js.map +0 -1
  163. package/dist/components/profile-dropdown/profile-dropdown-tiny.stories.d.ts +0 -9
  164. package/dist/components/profile-dropdown/profile-dropdown-tiny.stories.d.ts.map +0 -1
  165. package/dist/components/profile-dropdown/profile-dropdown-tiny.stories.js +0 -13
  166. package/dist/components/profile-dropdown/profile-dropdown-tiny.stories.js.map +0 -1
  167. package/dist/components/profile-dropdown/profile-dropdown.d.ts +0 -74
  168. package/dist/components/profile-dropdown/profile-dropdown.d.ts.map +0 -1
  169. package/dist/components/profile-dropdown/profile-dropdown.js +0 -86
  170. package/dist/components/profile-dropdown/profile-dropdown.js.map +0 -1
  171. package/dist/components/profile-dropdown/profile-dropdown.module.less +0 -167
  172. package/dist/components/profile-dropdown/profile-dropdown.stories.d.ts +0 -16
  173. package/dist/components/profile-dropdown/profile-dropdown.stories.d.ts.map +0 -1
  174. package/dist/components/profile-dropdown/profile-dropdown.stories.js +0 -51
  175. package/dist/components/profile-dropdown/profile-dropdown.stories.js.map +0 -1
  176. package/dist/components/profile-dropdown/profile-icon.d.ts +0 -3
  177. package/dist/components/profile-dropdown/profile-icon.d.ts.map +0 -1
  178. package/dist/components/profile-dropdown/profile-icon.js +0 -5
  179. package/dist/components/profile-dropdown/profile-icon.js.map +0 -1
  180. package/dist/index.d.ts +0 -12
  181. package/dist/index.d.ts.map +0 -1
  182. package/dist/index.js +0 -12
  183. package/dist/index.js.map +0 -1
  184. package/dist/test/data-stories.module.less +0 -8
  185. package/dist/test/data.d.ts +0 -32
  186. package/dist/test/data.d.ts.map +0 -1
  187. package/dist/test/data.js +0 -244
  188. package/dist/test/data.js.map +0 -1
  189. package/dist/utils/counter-tag.d.ts +0 -5
  190. package/dist/utils/counter-tag.d.ts.map +0 -1
  191. package/dist/utils/counter-tag.js +0 -2
  192. package/dist/utils/counter-tag.js.map +0 -1
  193. package/dist/utils/navigation-context.d.ts +0 -27
  194. package/dist/utils/navigation-context.d.ts.map +0 -1
  195. package/dist/utils/navigation-context.js +0 -10
  196. package/dist/utils/navigation-context.js.map +0 -1
  197. package/dist/utils/navigation-legacy.d.ts +0 -86
  198. package/dist/utils/navigation-legacy.d.ts.map +0 -1
  199. package/dist/utils/navigation-legacy.js +0 -2
  200. package/dist/utils/navigation-legacy.js.map +0 -1
  201. package/dist/utils/navigation.d.ts +0 -48
  202. package/dist/utils/navigation.d.ts.map +0 -1
  203. package/dist/utils/navigation.js +0 -2
  204. package/dist/utils/navigation.js.map +0 -1
  205. package/dist/utils/side-nav.d.ts +0 -6
  206. package/dist/utils/side-nav.d.ts.map +0 -1
  207. package/dist/utils/side-nav.js +0 -28
  208. package/dist/utils/side-nav.js.map +0 -1
  209. package/src/components/header-navigation/header-navigation-stories.module.less.d.ts +0 -3
  210. package/src/components/header-navigation/header-navigation.module.less.d.ts +0 -22
  211. package/src/components/left-navigation/header-navigation-tiny.module.less.d.ts +0 -15
  212. package/src/components/left-navigation/side-navigation.module.less.d.ts +0 -48
  213. package/src/components/logo/logo-titan-text.module.less.d.ts +0 -6
  214. package/src/components/profile-dropdown/profile-dropdown.module.less.d.ts +0 -21
  215. package/src/test/data-stories.module.less.d.ts +0 -3
@@ -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
+ }