@servicetitan/navigation 10.7.0 → 11.0.0-canary.237.4786284.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 (149) hide show
  1. package/dist/components/header-navigation/header-navigation-extra.stories.d.ts.map +1 -1
  2. package/dist/components/header-navigation/header-navigation-extra.stories.js +5 -5
  3. package/dist/components/header-navigation/header-navigation-extra.stories.js.map +1 -1
  4. package/dist/components/header-navigation/header-navigation-links.d.ts.map +1 -1
  5. package/dist/components/header-navigation/header-navigation-links.js +2 -2
  6. package/dist/components/header-navigation/header-navigation-links.js.map +1 -1
  7. package/dist/components/header-navigation/header-navigation-stacked.stories.d.ts.map +1 -1
  8. package/dist/components/header-navigation/header-navigation-stacked.stories.js +1 -1
  9. package/dist/components/header-navigation/header-navigation-stacked.stories.js.map +1 -1
  10. package/dist/components/header-navigation/header-navigation.stories.d.ts.map +1 -1
  11. package/dist/components/header-navigation/header-navigation.stories.js +2 -2
  12. package/dist/components/header-navigation/header-navigation.stories.js.map +1 -1
  13. package/dist/components/header-navigation/with-tooltip.d.ts +1 -1
  14. package/dist/components/header-navigation/with-tooltip.d.ts.map +1 -1
  15. package/dist/components/left-navigation/header-navigation-tiny.stories.d.ts.map +1 -1
  16. package/dist/components/left-navigation/header-navigation-tiny.stories.js +2 -2
  17. package/dist/components/left-navigation/header-navigation-tiny.stories.js.map +1 -1
  18. package/dist/components/links.d.ts.map +1 -1
  19. package/dist/components/links.js +7 -7
  20. package/dist/components/links.js.map +1 -1
  21. package/dist/components/logo/logo-company-title.d.ts +1 -0
  22. package/dist/components/logo/logo-company-title.d.ts.map +1 -1
  23. package/dist/components/logo/logo-company-title.js +2 -2
  24. package/dist/components/logo/logo-company-title.js.map +1 -1
  25. package/dist/components/profile-dropdown/profile-dropdown.d.ts +15 -9
  26. package/dist/components/profile-dropdown/profile-dropdown.d.ts.map +1 -1
  27. package/dist/components/profile-dropdown/profile-dropdown.js +7 -8
  28. package/dist/components/profile-dropdown/profile-dropdown.js.map +1 -1
  29. package/dist/components/profile-dropdown/profile-dropdown.module.less +4 -0
  30. package/dist/components/profile-dropdown/profile-dropdown.stories.js +2 -2
  31. package/dist/components/profile-dropdown/profile-dropdown.stories.js.map +1 -1
  32. package/dist/components/titan-layout/index.d.ts +6 -0
  33. package/dist/components/titan-layout/index.d.ts.map +1 -0
  34. package/dist/components/titan-layout/index.js +6 -0
  35. package/dist/components/titan-layout/index.js.map +1 -0
  36. package/dist/components/titan-layout/interface-internal.d.ts +6 -0
  37. package/dist/components/titan-layout/interface-internal.d.ts.map +1 -0
  38. package/dist/components/titan-layout/interface-internal.js +2 -0
  39. package/dist/components/titan-layout/interface-internal.js.map +1 -0
  40. package/dist/components/titan-layout/interface.d.ts +21 -0
  41. package/dist/components/titan-layout/interface.d.ts.map +1 -0
  42. package/dist/components/titan-layout/interface.js +2 -0
  43. package/dist/components/titan-layout/interface.js.map +1 -0
  44. package/dist/components/titan-layout/layout-context.d.ts +20 -0
  45. package/dist/components/titan-layout/layout-context.d.ts.map +1 -0
  46. package/dist/components/titan-layout/layout-context.js +12 -0
  47. package/dist/components/titan-layout/layout-context.js.map +1 -0
  48. package/dist/components/titan-layout/layout-header-links.d.ts +7 -0
  49. package/dist/components/titan-layout/layout-header-links.d.ts.map +1 -0
  50. package/dist/components/titan-layout/layout-header-links.js +32 -0
  51. package/dist/components/titan-layout/layout-header-links.js.map +1 -0
  52. package/dist/components/titan-layout/layout-header.d.ts +20 -0
  53. package/dist/components/titan-layout/layout-header.d.ts.map +1 -0
  54. package/dist/components/titan-layout/layout-header.js +11 -0
  55. package/dist/components/titan-layout/layout-header.js.map +1 -0
  56. package/dist/components/titan-layout/layout-header.module.less +174 -0
  57. package/dist/components/titan-layout/layout-logo.d.ts +12 -0
  58. package/dist/components/titan-layout/layout-logo.d.ts.map +1 -0
  59. package/dist/components/titan-layout/layout-logo.js +15 -0
  60. package/dist/components/titan-layout/layout-logo.js.map +1 -0
  61. package/dist/components/titan-layout/layout-logo.stories.d.ts +13 -0
  62. package/dist/components/titan-layout/layout-logo.stories.d.ts.map +1 -0
  63. package/dist/components/titan-layout/layout-logo.stories.js +17 -0
  64. package/dist/components/titan-layout/layout-logo.stories.js.map +1 -0
  65. package/dist/components/titan-layout/layout-profile.d.ts +9 -0
  66. package/dist/components/titan-layout/layout-profile.d.ts.map +1 -0
  67. package/dist/components/titan-layout/layout-profile.js +54 -0
  68. package/dist/components/titan-layout/layout-profile.js.map +1 -0
  69. package/dist/components/titan-layout/layout-profile.stories.d.ts +13 -0
  70. package/dist/components/titan-layout/layout-profile.stories.d.ts.map +1 -0
  71. package/dist/components/titan-layout/layout-profile.stories.js +13 -0
  72. package/dist/components/titan-layout/layout-profile.stories.js.map +1 -0
  73. package/dist/components/titan-layout/layout-sidebar-links-internal.d.ts +46 -0
  74. package/dist/components/titan-layout/layout-sidebar-links-internal.d.ts.map +1 -0
  75. package/dist/components/titan-layout/layout-sidebar-links-internal.js +61 -0
  76. package/dist/components/titan-layout/layout-sidebar-links-internal.js.map +1 -0
  77. package/dist/components/titan-layout/layout-sidebar-links.d.ts +6 -0
  78. package/dist/components/titan-layout/layout-sidebar-links.d.ts.map +1 -0
  79. package/dist/components/titan-layout/layout-sidebar-links.js +21 -0
  80. package/dist/components/titan-layout/layout-sidebar-links.js.map +1 -0
  81. package/dist/components/titan-layout/layout-sidebar.d.ts +17 -0
  82. package/dist/components/titan-layout/layout-sidebar.d.ts.map +1 -0
  83. package/dist/components/titan-layout/layout-sidebar.js +65 -0
  84. package/dist/components/titan-layout/layout-sidebar.js.map +1 -0
  85. package/dist/components/titan-layout/layout-sidebar.module.less +516 -0
  86. package/dist/components/titan-layout/titan-layout.d.ts +38 -0
  87. package/dist/components/titan-layout/titan-layout.d.ts.map +1 -0
  88. package/dist/components/titan-layout/titan-layout.js +143 -0
  89. package/dist/components/titan-layout/titan-layout.js.map +1 -0
  90. package/dist/components/titan-layout/titan-layout.module.less +116 -0
  91. package/dist/components/titan-layout/titan-layout.stories.d.ts +20 -0
  92. package/dist/components/titan-layout/titan-layout.stories.d.ts.map +1 -0
  93. package/dist/components/titan-layout/titan-layout.stories.js +80 -0
  94. package/dist/components/titan-layout/titan-layout.stories.js.map +1 -0
  95. package/dist/components/titan-layout/with-tooltip.d.ts +4 -0
  96. package/dist/components/titan-layout/with-tooltip.d.ts.map +1 -0
  97. package/dist/components/titan-layout/with-tooltip.js +4 -0
  98. package/dist/components/titan-layout/with-tooltip.js.map +1 -0
  99. package/dist/index.d.ts +2 -1
  100. package/dist/index.d.ts.map +1 -1
  101. package/dist/index.js +2 -1
  102. package/dist/index.js.map +1 -1
  103. package/dist/test/data.d.ts.map +1 -1
  104. package/dist/test/data.js +3 -3
  105. package/dist/test/data.js.map +1 -1
  106. package/dist/utils/navigation-legacy.d.ts +3 -1
  107. package/dist/utils/navigation-legacy.d.ts.map +1 -1
  108. package/dist/utils/use-breakpoint.d.ts +7 -0
  109. package/dist/utils/use-breakpoint.d.ts.map +1 -0
  110. package/dist/utils/use-breakpoint.js +13 -0
  111. package/dist/utils/use-breakpoint.js.map +1 -0
  112. package/package.json +5 -6
  113. package/src/components/header-navigation/header-navigation-extra.stories.tsx +7 -0
  114. package/src/components/header-navigation/header-navigation-links.tsx +2 -0
  115. package/src/components/header-navigation/header-navigation-stacked.stories.tsx +5 -1
  116. package/src/components/header-navigation/header-navigation.stories.tsx +6 -1
  117. package/src/components/left-navigation/header-navigation-tiny.stories.tsx +8 -2
  118. package/src/components/left-navigation/side-navigation-links.tsx +1 -1
  119. package/src/components/links.tsx +33 -13
  120. package/src/components/logo/logo-company-title.tsx +8 -6
  121. package/src/components/profile-dropdown/profile-dropdown.module.less +4 -0
  122. package/src/components/profile-dropdown/profile-dropdown.stories.tsx +4 -4
  123. package/src/components/profile-dropdown/profile-dropdown.tsx +55 -51
  124. package/src/components/titan-layout/index.ts +5 -0
  125. package/src/components/titan-layout/interface-internal.ts +6 -0
  126. package/src/components/titan-layout/interface.ts +26 -0
  127. package/src/components/titan-layout/layout-context.tsx +30 -0
  128. package/src/components/titan-layout/layout-header-links.tsx +144 -0
  129. package/src/components/titan-layout/layout-header.module.less +174 -0
  130. package/src/components/titan-layout/layout-header.module.less.d.ts +16 -0
  131. package/src/components/titan-layout/layout-header.tsx +90 -0
  132. package/src/components/titan-layout/layout-logo.stories.tsx +31 -0
  133. package/src/components/titan-layout/layout-logo.tsx +57 -0
  134. package/src/components/titan-layout/layout-profile.stories.tsx +46 -0
  135. package/src/components/titan-layout/layout-profile.tsx +132 -0
  136. package/src/components/titan-layout/layout-sidebar-links-internal.tsx +275 -0
  137. package/src/components/titan-layout/layout-sidebar-links.tsx +59 -0
  138. package/src/components/titan-layout/layout-sidebar.module.less +516 -0
  139. package/src/components/titan-layout/layout-sidebar.module.less.d.ts +48 -0
  140. package/src/components/titan-layout/layout-sidebar.tsx +295 -0
  141. package/src/components/titan-layout/titan-layout.module.less +116 -0
  142. package/src/components/titan-layout/titan-layout.module.less.d.ts +16 -0
  143. package/src/components/titan-layout/titan-layout.stories.tsx +332 -0
  144. package/src/components/titan-layout/titan-layout.tsx +355 -0
  145. package/src/components/titan-layout/with-tooltip.tsx +16 -0
  146. package/src/index.ts +2 -1
  147. package/src/test/data.tsx +3 -2
  148. package/src/utils/navigation-legacy.ts +3 -1
  149. package/src/utils/use-breakpoint.ts +19 -0
@@ -0,0 +1,275 @@
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
+ > = ({
184
+ id,
185
+ counter,
186
+ tag,
187
+ title,
188
+ to,
189
+ isActive,
190
+ navigationComponent: NavigationComponent,
191
+ ...rest
192
+ }) => {
193
+ return (
194
+ <NavigationComponent
195
+ key={id}
196
+ data-cy={`navigation-item-${id}`}
197
+ data-pendo={`navigation-item-${id}`}
198
+ {...rest}
199
+ to={to}
200
+ className={classNames(Styles.submenuItem, Styles.submenuLink, {
201
+ [Styles.submenuLinkActive]: isActive === true,
202
+ })}
203
+ isActive={typeof isActive === 'function' ? isActive : undefined}
204
+ activeClassName={Styles.submenuLinkActive}
205
+ >
206
+ <span>{title}</span>
207
+ <BadgeTag data={getCounterTag(counter, tag)} className={Styles.submenuLinkCounter} />
208
+ </NavigationComponent>
209
+ );
210
+ };
211
+
212
+ export const InternalSideNavigationGroupTrigger: FC<
213
+ Omit<NavigationSubmenuItemData, 'to'> & { onClick?: (e: MouseEvent<any>) => void }
214
+ > = ({ id, counter, onClick, tag, title, isActive }) => {
215
+ return (
216
+ <div
217
+ data-cy={`navigation-item-${id}`}
218
+ data-pendo={`navigation-item-${id}`}
219
+ key={id}
220
+ className={classNames(Styles.submenuItem, {
221
+ [Styles.submenuLink]: !!onClick,
222
+ [Styles.submenuLinkActive]: isActive === true,
223
+ })}
224
+ onClick={onClick}
225
+ >
226
+ <span>{title}</span>
227
+ <BadgeTag data={getCounterTag(counter, tag)} className={Styles.submenuLinkCounter} />
228
+ </div>
229
+ );
230
+ };
231
+
232
+ export const InternalSideNavigationGroupDivider = () => {
233
+ return <div className={Styles.divider} />;
234
+ };
235
+
236
+ export const InternalSideNavigationGroup: FC<
237
+ Omit<NavigationItemData, 'tag' | 'counter' | 'to'> &
238
+ NavigationComponentProps & {
239
+ children: ReactNode;
240
+ submenuExpanded: boolean;
241
+ onExpandToggle?: (e: MouseEvent<never>) => void;
242
+ tag: BadgeTagProps | undefined;
243
+ to: NavigationItemData['to'] | undefined;
244
+ onClick?: () => void;
245
+ }
246
+ > = ({ children, submenuExpanded, to, onExpandToggle, onClick, ...props }) => {
247
+ return (
248
+ <div className={classNames(Styles.navGroupWrapper)}>
249
+ <div className={Styles.navGroupItem}>
250
+ {to ? (
251
+ <InternalSideNavigationLink
252
+ {...props}
253
+ to={to}
254
+ submenuExpanded={submenuExpanded}
255
+ onExpandToggle={onExpandToggle}
256
+ />
257
+ ) : (
258
+ <InternalSideNavigationTrigger
259
+ {...props}
260
+ submenuExpanded={submenuExpanded}
261
+ onExpandToggle={onExpandToggle}
262
+ onClick={onClick}
263
+ />
264
+ )}
265
+ </div>
266
+ <div
267
+ className={classNames(Styles.submenuWrapper, {
268
+ [Styles.submenuWrapperCollapsed]: !submenuExpanded,
269
+ })}
270
+ >
271
+ <div className={Styles.submenu}>{children}</div>
272
+ </div>
273
+ </div>
274
+ );
275
+ };
@@ -0,0 +1,59 @@
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<any>;
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 {
21
+ NavigationComponent,
22
+ breakpoint: { isMobile },
23
+ } = useTitanLayoutContext();
24
+
25
+ const element = (
26
+ <InternalSideNavigationLink
27
+ {...props}
28
+ navigationComponent={NavigationComponent}
29
+ submenuExpanded={undefined}
30
+ dataPrefix="navigation-link"
31
+ tag={getCounterTag(props.counter, props.tag)}
32
+ />
33
+ );
34
+
35
+ return wrapper && !isMobile ? <WrappedLink wrapper={wrapper}>{element}</WrappedLink> : element;
36
+ }
37
+
38
+ /** Side Navigation menu trigger */
39
+ export function TitanLayoutSidebarTrigger({
40
+ wrapper,
41
+ onMobileClick,
42
+ onClick,
43
+ ...props
44
+ }: TitanLayoutSidebarTriggerProps) {
45
+ const {
46
+ breakpoint: { isMobile },
47
+ } = useTitanLayoutContext();
48
+
49
+ const element = (
50
+ <InternalSideNavigationTrigger
51
+ {...props}
52
+ submenuExpanded={undefined}
53
+ dataPrefix="navigation-trigger"
54
+ tag={getCounterTag(props.counter, props.tag)}
55
+ onClick={isMobile && !!onMobileClick ? onMobileClick : onClick}
56
+ />
57
+ );
58
+ return wrapper && !isMobile ? <WrappedLink wrapper={wrapper}>{element}</WrappedLink> : element;
59
+ }