@servicetitan/navigation 12.0.3 → 13.0.0-canary.256.44cf055.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 (252) hide show
  1. package/dist/components/counter-tag.d.ts +1 -1
  2. package/dist/components/counter-tag.d.ts.map +1 -1
  3. package/dist/components/counter-tag.js.map +1 -1
  4. package/dist/components/profile-dropdown/interface.d.ts +55 -0
  5. package/dist/components/profile-dropdown/interface.d.ts.map +1 -0
  6. package/dist/components/profile-dropdown/interface.js.map +1 -0
  7. package/dist/components/profile-dropdown/profile-dropdown-legacy.stories.d.ts +13 -0
  8. package/dist/components/profile-dropdown/profile-dropdown-legacy.stories.d.ts.map +1 -0
  9. package/dist/components/profile-dropdown/profile-dropdown-stacked.stories.d.ts +5 -1
  10. package/dist/components/profile-dropdown/profile-dropdown-stacked.stories.d.ts.map +1 -1
  11. package/dist/components/profile-dropdown/profile-dropdown.d.ts +9 -79
  12. package/dist/components/profile-dropdown/profile-dropdown.d.ts.map +1 -1
  13. package/dist/components/profile-dropdown/profile-dropdown.js +22 -22
  14. package/dist/components/profile-dropdown/profile-dropdown.js.map +1 -1
  15. package/dist/components/profile-dropdown/profile-dropdown.stories.d.ts +5 -1
  16. package/dist/components/profile-dropdown/profile-dropdown.stories.d.ts.map +1 -1
  17. package/dist/components/titan-layout/interface-internal.d.ts +12 -0
  18. package/dist/components/titan-layout/interface-internal.d.ts.map +1 -1
  19. package/dist/components/titan-layout/interface-internal.js.map +1 -1
  20. package/dist/components/titan-layout/interface.d.ts +67 -14
  21. package/dist/components/titan-layout/interface.d.ts.map +1 -1
  22. package/dist/components/titan-layout/interface.js.map +1 -1
  23. package/dist/components/titan-layout/layout-header-dark.d.ts.map +1 -1
  24. package/dist/components/titan-layout/layout-header-dark.js +24 -12
  25. package/dist/components/titan-layout/layout-header-dark.js.map +1 -1
  26. package/dist/components/titan-layout/layout-header-links-internal.d.ts +22 -3
  27. package/dist/components/titan-layout/layout-header-links-internal.d.ts.map +1 -1
  28. package/dist/components/titan-layout/layout-header-links-internal.js +15 -18
  29. package/dist/components/titan-layout/layout-header-links-internal.js.map +1 -1
  30. package/dist/components/titan-layout/layout-header-links.d.ts +3 -4
  31. package/dist/components/titan-layout/layout-header-links.d.ts.map +1 -1
  32. package/dist/components/titan-layout/layout-header-links.js +25 -5
  33. package/dist/components/titan-layout/layout-header-links.js.map +1 -1
  34. package/dist/components/titan-layout/layout-header.d.ts +4 -2
  35. package/dist/components/titan-layout/layout-header.d.ts.map +1 -1
  36. package/dist/components/titan-layout/layout-header.js +25 -16
  37. package/dist/components/titan-layout/layout-header.js.map +1 -1
  38. package/dist/components/titan-layout/layout-header.module.less +37 -1
  39. package/dist/components/titan-layout/layout-header.module.less.d.ts +3 -0
  40. package/dist/components/titan-layout/layout-profile.d.ts +8 -5
  41. package/dist/components/titan-layout/layout-profile.d.ts.map +1 -1
  42. package/dist/components/titan-layout/layout-profile.js +30 -28
  43. package/dist/components/titan-layout/layout-profile.js.map +1 -1
  44. package/dist/components/titan-layout/layout-sidebar-links-internal.d.ts +48 -31
  45. package/dist/components/titan-layout/layout-sidebar-links-internal.d.ts.map +1 -1
  46. package/dist/components/titan-layout/layout-sidebar-links-internal.js +87 -83
  47. package/dist/components/titan-layout/layout-sidebar-links-internal.js.map +1 -1
  48. package/dist/components/titan-layout/layout-sidebar-links.d.ts +3 -3
  49. package/dist/components/titan-layout/layout-sidebar-links.d.ts.map +1 -1
  50. package/dist/components/titan-layout/layout-sidebar-links.js +32 -19
  51. package/dist/components/titan-layout/layout-sidebar-links.js.map +1 -1
  52. package/dist/components/titan-layout/layout-sidebar.d.ts +1 -1
  53. package/dist/components/titan-layout/layout-sidebar.d.ts.map +1 -1
  54. package/dist/components/titan-layout/layout-sidebar.js +81 -102
  55. package/dist/components/titan-layout/layout-sidebar.js.map +1 -1
  56. package/dist/components/titan-layout/layout-sidebar.module.less +74 -22
  57. package/dist/components/titan-layout/titan-layout-default.stories.d.ts +16 -0
  58. package/dist/components/titan-layout/titan-layout-default.stories.d.ts.map +1 -0
  59. package/dist/components/titan-layout/titan-layout-legacy.stories.d.ts +10 -0
  60. package/dist/components/titan-layout/titan-layout-legacy.stories.d.ts.map +1 -0
  61. package/dist/components/titan-layout/titan-layout-links.d.ts +5 -0
  62. package/dist/components/titan-layout/titan-layout-links.d.ts.map +1 -0
  63. package/dist/components/titan-layout/titan-layout-links.js +34 -0
  64. package/dist/components/titan-layout/titan-layout-links.js.map +1 -0
  65. package/dist/components/titan-layout/titan-layout-stacked.stories.d.ts +10 -0
  66. package/dist/components/titan-layout/titan-layout-stacked.stories.d.ts.map +1 -0
  67. package/dist/components/titan-layout/titan-layout.d.ts +5 -4
  68. package/dist/components/titan-layout/titan-layout.d.ts.map +1 -1
  69. package/dist/components/titan-layout/titan-layout.js +33 -14
  70. package/dist/components/titan-layout/titan-layout.js.map +1 -1
  71. package/dist/index.d.ts +1 -6
  72. package/dist/index.d.ts.map +1 -1
  73. package/dist/index.js +0 -4
  74. package/dist/index.js.map +1 -1
  75. package/dist/test/data.d.ts +26 -23
  76. package/dist/test/data.d.ts.map +1 -1
  77. package/dist/test/data.js +26 -69
  78. package/dist/test/data.js.map +1 -1
  79. package/dist/test/titan-layout.d.ts +16 -0
  80. package/dist/test/titan-layout.d.ts.map +1 -0
  81. package/dist/test/titan-layout.js +21 -0
  82. package/dist/test/titan-layout.js.map +1 -0
  83. package/dist/utils/navigation-context.d.ts +3 -22
  84. package/dist/utils/navigation-context.d.ts.map +1 -1
  85. package/dist/utils/navigation-context.js +2 -10
  86. package/dist/utils/navigation-context.js.map +1 -1
  87. package/dist/utils/navigation.d.ts +2 -7
  88. package/dist/utils/navigation.d.ts.map +1 -1
  89. package/dist/utils/navigation.js.map +1 -1
  90. package/package.json +4 -4
  91. package/src/components/counter-tag.tsx +1 -1
  92. package/src/components/profile-dropdown/interface.ts +47 -0
  93. package/src/components/profile-dropdown/profile-dropdown-legacy.stories.tsx +25 -0
  94. package/src/components/profile-dropdown/profile-dropdown-stacked.stories.tsx +15 -7
  95. package/src/components/profile-dropdown/profile-dropdown.stories.tsx +50 -43
  96. package/src/components/profile-dropdown/profile-dropdown.tsx +39 -115
  97. package/src/components/titan-layout/interface-internal.ts +13 -0
  98. package/src/components/titan-layout/interface.ts +73 -17
  99. package/src/components/titan-layout/layout-header-dark.tsx +21 -5
  100. package/src/components/titan-layout/layout-header-links-internal.tsx +41 -54
  101. package/src/components/titan-layout/layout-header-links.tsx +65 -12
  102. package/src/components/titan-layout/layout-header.module.less +37 -1
  103. package/src/components/titan-layout/layout-header.module.less.d.ts +3 -0
  104. package/src/components/titan-layout/layout-header.tsx +28 -15
  105. package/src/components/titan-layout/layout-profile.tsx +53 -34
  106. package/src/components/titan-layout/layout-sidebar-links-internal.tsx +188 -147
  107. package/src/components/titan-layout/layout-sidebar-links.tsx +73 -26
  108. package/src/components/titan-layout/layout-sidebar.module.less +74 -22
  109. package/src/components/titan-layout/layout-sidebar.tsx +55 -80
  110. package/src/components/titan-layout/{titan-layout.stories.tsx → titan-layout-default.stories.tsx} +131 -114
  111. package/src/components/titan-layout/titan-layout-legacy.stories.tsx +24 -0
  112. package/src/components/titan-layout/titan-layout-links.tsx +34 -0
  113. package/src/components/titan-layout/titan-layout-stacked.stories.tsx +30 -0
  114. package/src/components/titan-layout/titan-layout.tsx +39 -15
  115. package/src/index.ts +1 -12
  116. package/src/test/data.tsx +31 -83
  117. package/src/test/titan-layout.tsx +34 -0
  118. package/src/utils/navigation-context.tsx +9 -35
  119. package/src/utils/navigation.ts +3 -10
  120. package/dist/components/header-navigation/header-navigation-content.d.ts +0 -30
  121. package/dist/components/header-navigation/header-navigation-content.d.ts.map +0 -1
  122. package/dist/components/header-navigation/header-navigation-content.js +0 -58
  123. package/dist/components/header-navigation/header-navigation-content.js.map +0 -1
  124. package/dist/components/header-navigation/header-navigation-extra-stacked.stories.d.ts +0 -9
  125. package/dist/components/header-navigation/header-navigation-extra-stacked.stories.d.ts.map +0 -1
  126. package/dist/components/header-navigation/header-navigation-extra.stories.d.ts +0 -12
  127. package/dist/components/header-navigation/header-navigation-extra.stories.d.ts.map +0 -1
  128. package/dist/components/header-navigation/header-navigation-links.d.ts +0 -11
  129. package/dist/components/header-navigation/header-navigation-links.d.ts.map +0 -1
  130. package/dist/components/header-navigation/header-navigation-links.js +0 -62
  131. package/dist/components/header-navigation/header-navigation-links.js.map +0 -1
  132. package/dist/components/header-navigation/header-navigation-stacked.stories.d.ts +0 -12
  133. package/dist/components/header-navigation/header-navigation-stacked.stories.d.ts.map +0 -1
  134. package/dist/components/header-navigation/header-navigation-stories.module.less +0 -6
  135. package/dist/components/header-navigation/header-navigation-stories.module.less.d.ts +0 -3
  136. package/dist/components/header-navigation/header-navigation.d.ts +0 -59
  137. package/dist/components/header-navigation/header-navigation.d.ts.map +0 -1
  138. package/dist/components/header-navigation/header-navigation.js +0 -228
  139. package/dist/components/header-navigation/header-navigation.js.map +0 -1
  140. package/dist/components/header-navigation/header-navigation.module.less +0 -260
  141. package/dist/components/header-navigation/header-navigation.module.less.d.ts +0 -22
  142. package/dist/components/header-navigation/header-navigation.stories.d.ts +0 -12
  143. package/dist/components/header-navigation/header-navigation.stories.d.ts.map +0 -1
  144. package/dist/components/header-navigation/index.d.ts +0 -2
  145. package/dist/components/header-navigation/index.d.ts.map +0 -1
  146. package/dist/components/header-navigation/index.js +0 -3
  147. package/dist/components/header-navigation/index.js.map +0 -1
  148. package/dist/components/header-navigation/with-tooltip.d.ts +0 -4
  149. package/dist/components/header-navigation/with-tooltip.d.ts.map +0 -1
  150. package/dist/components/header-navigation/with-tooltip.js +0 -10
  151. package/dist/components/header-navigation/with-tooltip.js.map +0 -1
  152. package/dist/components/layout.stories.d.ts +0 -13
  153. package/dist/components/layout.stories.d.ts.map +0 -1
  154. package/dist/components/left-navigation/header-navigation-extra-tiny.stories.d.ts +0 -9
  155. package/dist/components/left-navigation/header-navigation-extra-tiny.stories.d.ts.map +0 -1
  156. package/dist/components/left-navigation/header-navigation-tiny-links.d.ts +0 -18
  157. package/dist/components/left-navigation/header-navigation-tiny-links.d.ts.map +0 -1
  158. package/dist/components/left-navigation/header-navigation-tiny-links.js +0 -79
  159. package/dist/components/left-navigation/header-navigation-tiny-links.js.map +0 -1
  160. package/dist/components/left-navigation/header-navigation-tiny.d.ts +0 -23
  161. package/dist/components/left-navigation/header-navigation-tiny.d.ts.map +0 -1
  162. package/dist/components/left-navigation/header-navigation-tiny.js +0 -32
  163. package/dist/components/left-navigation/header-navigation-tiny.js.map +0 -1
  164. package/dist/components/left-navigation/header-navigation-tiny.module.less +0 -117
  165. package/dist/components/left-navigation/header-navigation-tiny.module.less.d.ts +0 -15
  166. package/dist/components/left-navigation/header-navigation-tiny.stories.d.ts +0 -12
  167. package/dist/components/left-navigation/header-navigation-tiny.stories.d.ts.map +0 -1
  168. package/dist/components/left-navigation/index.d.ts +0 -5
  169. package/dist/components/left-navigation/index.d.ts.map +0 -1
  170. package/dist/components/left-navigation/index.js +0 -5
  171. package/dist/components/left-navigation/index.js.map +0 -1
  172. package/dist/components/left-navigation/interface-internal.d.ts +0 -10
  173. package/dist/components/left-navigation/interface-internal.d.ts.map +0 -1
  174. package/dist/components/left-navigation/interface-internal.js +0 -3
  175. package/dist/components/left-navigation/interface-internal.js.map +0 -1
  176. package/dist/components/left-navigation/interface.d.ts +0 -20
  177. package/dist/components/left-navigation/interface.d.ts.map +0 -1
  178. package/dist/components/left-navigation/interface.js.map +0 -1
  179. package/dist/components/left-navigation/side-navigation-context.d.ts +0 -8
  180. package/dist/components/left-navigation/side-navigation-context.d.ts.map +0 -1
  181. package/dist/components/left-navigation/side-navigation-context.js +0 -8
  182. package/dist/components/left-navigation/side-navigation-context.js.map +0 -1
  183. package/dist/components/left-navigation/side-navigation-links-internal.d.ts +0 -28
  184. package/dist/components/left-navigation/side-navigation-links-internal.d.ts.map +0 -1
  185. package/dist/components/left-navigation/side-navigation-links-internal.js +0 -89
  186. package/dist/components/left-navigation/side-navigation-links-internal.js.map +0 -1
  187. package/dist/components/left-navigation/side-navigation-links.d.ts +0 -6
  188. package/dist/components/left-navigation/side-navigation-links.d.ts.map +0 -1
  189. package/dist/components/left-navigation/side-navigation-links.js +0 -48
  190. package/dist/components/left-navigation/side-navigation-links.js.map +0 -1
  191. package/dist/components/left-navigation/side-navigation.d.ts +0 -29
  192. package/dist/components/left-navigation/side-navigation.d.ts.map +0 -1
  193. package/dist/components/left-navigation/side-navigation.js +0 -411
  194. package/dist/components/left-navigation/side-navigation.js.map +0 -1
  195. package/dist/components/left-navigation/side-navigation.module.less +0 -530
  196. package/dist/components/left-navigation/side-navigation.module.less.d.ts +0 -48
  197. package/dist/components/left-navigation/side-navigation.stories.d.ts +0 -17
  198. package/dist/components/left-navigation/side-navigation.stories.d.ts.map +0 -1
  199. package/dist/components/left-navigation/with-tooltip.d.ts +0 -4
  200. package/dist/components/left-navigation/with-tooltip.d.ts.map +0 -1
  201. package/dist/components/left-navigation/with-tooltip.js +0 -15
  202. package/dist/components/left-navigation/with-tooltip.js.map +0 -1
  203. package/dist/components/links.d.ts +0 -5
  204. package/dist/components/links.d.ts.map +0 -1
  205. package/dist/components/links.js +0 -35
  206. package/dist/components/links.js.map +0 -1
  207. package/dist/components/profile-dropdown/profile-dropdown-tiny.stories.d.ts +0 -9
  208. package/dist/components/profile-dropdown/profile-dropdown-tiny.stories.d.ts.map +0 -1
  209. package/dist/components/titan-layout/layout-profile.stories.d.ts +0 -13
  210. package/dist/components/titan-layout/layout-profile.stories.d.ts.map +0 -1
  211. package/dist/components/titan-layout/titan-layout.stories.d.ts +0 -29
  212. package/dist/components/titan-layout/titan-layout.stories.d.ts.map +0 -1
  213. package/dist/utils/navigation-legacy.d.ts +0 -88
  214. package/dist/utils/navigation-legacy.d.ts.map +0 -1
  215. package/dist/utils/navigation-legacy.js +0 -3
  216. package/dist/utils/navigation-legacy.js.map +0 -1
  217. package/src/components/header-navigation/header-navigation-content.tsx +0 -120
  218. package/src/components/header-navigation/header-navigation-extra-stacked.stories.tsx +0 -19
  219. package/src/components/header-navigation/header-navigation-extra.stories.tsx +0 -142
  220. package/src/components/header-navigation/header-navigation-links.tsx +0 -141
  221. package/src/components/header-navigation/header-navigation-stacked.stories.tsx +0 -146
  222. package/src/components/header-navigation/header-navigation-stories.module.less +0 -6
  223. package/src/components/header-navigation/header-navigation-stories.module.less.d.ts +0 -3
  224. package/src/components/header-navigation/header-navigation.module.less +0 -260
  225. package/src/components/header-navigation/header-navigation.module.less.d.ts +0 -22
  226. package/src/components/header-navigation/header-navigation.stories.tsx +0 -165
  227. package/src/components/header-navigation/header-navigation.tsx +0 -327
  228. package/src/components/header-navigation/index.ts +0 -1
  229. package/src/components/header-navigation/with-tooltip.tsx +0 -15
  230. package/src/components/layout.stories.tsx +0 -103
  231. package/src/components/left-navigation/header-navigation-extra-tiny.stories.tsx +0 -21
  232. package/src/components/left-navigation/header-navigation-tiny-links.tsx +0 -145
  233. package/src/components/left-navigation/header-navigation-tiny.module.less +0 -117
  234. package/src/components/left-navigation/header-navigation-tiny.module.less.d.ts +0 -15
  235. package/src/components/left-navigation/header-navigation-tiny.stories.tsx +0 -178
  236. package/src/components/left-navigation/header-navigation-tiny.tsx +0 -65
  237. package/src/components/left-navigation/index.ts +0 -4
  238. package/src/components/left-navigation/interface-internal.ts +0 -11
  239. package/src/components/left-navigation/interface.ts +0 -26
  240. package/src/components/left-navigation/side-navigation-context.tsx +0 -13
  241. package/src/components/left-navigation/side-navigation-links-internal.tsx +0 -151
  242. package/src/components/left-navigation/side-navigation-links.tsx +0 -57
  243. package/src/components/left-navigation/side-navigation.module.less +0 -530
  244. package/src/components/left-navigation/side-navigation.module.less.d.ts +0 -48
  245. package/src/components/left-navigation/side-navigation.stories.tsx +0 -226
  246. package/src/components/left-navigation/side-navigation.tsx +0 -543
  247. package/src/components/left-navigation/with-tooltip.tsx +0 -16
  248. package/src/components/links.tsx +0 -54
  249. package/src/components/profile-dropdown/profile-dropdown-tiny.stories.tsx +0 -25
  250. package/src/components/titan-layout/layout-profile.stories.tsx +0 -46
  251. package/src/utils/navigation-legacy.ts +0 -106
  252. /package/dist/components/{left-navigation → profile-dropdown}/interface.js +0 -0
@@ -1,59 +0,0 @@
1
- import { PopoverPropsStrict } from '@servicetitan/design-system';
2
- import { FC, ReactElement, ReactNode } from 'react';
3
- import { HeaderNavigationItemData } from '../../utils/navigation-legacy';
4
- export interface HeaderNavigationOverflowProps {
5
- direction: PopoverPropsStrict['direction'];
6
- width: PopoverPropsStrict['width'];
7
- portal?: boolean;
8
- }
9
- export interface HeaderNavigationProps {
10
- /** extra navigation */
11
- children?: ReactNode;
12
- /** container class name */
13
- className?: string;
14
- /** extra navigation container class name */
15
- rightClassName?: string;
16
- /** container id */
17
- id?: string;
18
- /** left content (usually used for logo) */
19
- left?: ReactElement;
20
- /** left container class name */
21
- leftClassName?: string;
22
- /** minimal width for navigation bar */
23
- minWidth?: number;
24
- /** main navigation items */
25
- items?: HeaderNavigationItemData[];
26
- /** main navigation overflow items */
27
- itemsOverflow?: HeaderNavigationItemData[];
28
- /** props for main items overflow component */
29
- overflow?: HeaderNavigationOverflowProps;
30
- }
31
- export declare const HeaderNavigation: FC<HeaderNavigationProps>;
32
- export interface HeaderNavigationStackedProps {
33
- /** container class name */
34
- className?: string;
35
- /** extra navigation */
36
- right?: ReactNode;
37
- /** extra navigation container class name */
38
- rightClassName?: string;
39
- /** container id */
40
- id?: string;
41
- /** left content (usually used for logo) */
42
- left?: ReactElement;
43
- /** left container class name */
44
- leftClassName?: string;
45
- /** center content */
46
- center?: ReactElement;
47
- /** center container class name */
48
- centerClassName?: string;
49
- /** minimal width for navigation bar */
50
- minWidth?: number;
51
- /** main navigation items */
52
- items?: HeaderNavigationItemData[];
53
- /** main navigation overflow items */
54
- itemsOverflow?: HeaderNavigationItemData[];
55
- /** props for main items overflow component */
56
- overflow?: HeaderNavigationOverflowProps;
57
- }
58
- export declare const HeaderNavigationStacked: FC<HeaderNavigationStackedProps>;
59
- //# sourceMappingURL=header-navigation.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"header-navigation.d.ts","sourceRoot":"","sources":["../../../src/components/header-navigation/header-navigation.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAiB,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AAEhF,OAAO,EAAE,EAAE,EAAE,YAAY,EAAE,SAAS,EAA4C,MAAM,OAAO,CAAC;AAE9F,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;AAWzE,MAAM,WAAW,6BAA6B;IAC1C,SAAS,EAAE,kBAAkB,CAAC,WAAW,CAAC,CAAC;IAC3C,KAAK,EAAE,kBAAkB,CAAC,OAAO,CAAC,CAAC;IACnC,MAAM,CAAC,EAAE,OAAO,CAAC;CACpB;AA0CD,MAAM,WAAW,qBAAqB;IAClC,uBAAuB;IACvB,QAAQ,CAAC,EAAE,SAAS,CAAC;IACrB,2BAA2B;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,4CAA4C;IAC5C,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,mBAAmB;IACnB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,2CAA2C;IAC3C,IAAI,CAAC,EAAE,YAAY,CAAC;IACpB,gCAAgC;IAChC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,uCAAuC;IACvC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,4BAA4B;IAC5B,KAAK,CAAC,EAAE,wBAAwB,EAAE,CAAC;IACnC,qCAAqC;IACrC,aAAa,CAAC,EAAE,wBAAwB,EAAE,CAAC;IAC3C,8CAA8C;IAC9C,QAAQ,CAAC,EAAE,6BAA6B,CAAC;CAC5C;AAQD,eAAO,MAAM,gBAAgB,EAAE,EAAE,CAAC,qBAAqB,CAiGtD,CAAC;AAEF,MAAM,WAAW,4BAA4B;IACzC,2BAA2B;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,uBAAuB;IACvB,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,4CAA4C;IAC5C,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,mBAAmB;IACnB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,2CAA2C;IAC3C,IAAI,CAAC,EAAE,YAAY,CAAC;IACpB,gCAAgC;IAChC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,qBAAqB;IACrB,MAAM,CAAC,EAAE,YAAY,CAAC;IACtB,kCAAkC;IAClC,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,uCAAuC;IACvC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,4BAA4B;IAC5B,KAAK,CAAC,EAAE,wBAAwB,EAAE,CAAC;IACnC,qCAAqC;IACrC,aAAa,CAAC,EAAE,wBAAwB,EAAE,CAAC;IAC3C,8CAA8C;IAC9C,QAAQ,CAAC,EAAE,6BAA6B,CAAC;CAC5C;AAED,eAAO,MAAM,uBAAuB,EAAE,EAAE,CAAC,4BAA4B,CA8GpE,CAAC"}
@@ -1,228 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { createElement as _createElement } from "react";
3
- import { Icon, Popover } from '@servicetitan/design-system';
4
- import classNames from 'classnames';
5
- import { useCallback, useEffect, useRef, useState } from 'react';
6
- import { NavigationLegacyContext } from '../../utils/navigation-context';
7
- import { HeaderNavigationItem } from './header-navigation-content';
8
- import * as Styles from './header-navigation.module.less';
9
- function useForceUpdate() {
10
- const [, setTick] = useState(0);
11
- return useCallback(()=>{
12
- setTick((tick)=>tick + 1);
13
- }, []);
14
- }
15
- const HeaderNavigationOverflow = ({ items, overflow })=>{
16
- const [isOpen, setIsOpen] = useState(false);
17
- var _overflow_direction, _overflow_width;
18
- return /*#__PURE__*/ _jsx(Popover, {
19
- open: isOpen,
20
- trigger: /*#__PURE__*/ _jsx(Icon, {
21
- name: "more_vert",
22
- size: "24px",
23
- className: "c-pointer",
24
- onClick: ()=>setIsOpen(true),
25
- color: "white",
26
- "data-cy": "navigation-overflow-trigger",
27
- "data-pendo": "navigation-overflow-trigger"
28
- }),
29
- direction: (_overflow_direction = overflow === null || overflow === void 0 ? void 0 : overflow.direction) !== null && _overflow_direction !== void 0 ? _overflow_direction : 'bl',
30
- width: (_overflow_width = overflow === null || overflow === void 0 ? void 0 : overflow.width) !== null && _overflow_width !== void 0 ? _overflow_width : 'xs',
31
- portal: overflow === null || overflow === void 0 ? void 0 : overflow.portal,
32
- onClickOutside: ()=>setIsOpen(false),
33
- wrapperClassName: "d-if-i align-items-center",
34
- popoverContentClassName: Styles.overflowPopover,
35
- children: /*#__PURE__*/ _jsx("div", {
36
- onClick: ()=>setIsOpen(false),
37
- className: Styles.navigationOverflow,
38
- "data-cy": "navigation-overflow-content",
39
- children: items.map((item)=>/*#__PURE__*/ _createElement(HeaderNavigationItem, {
40
- ...item,
41
- key: item.id,
42
- minimized: false,
43
- main: false
44
- }))
45
- })
46
- });
47
- };
48
- var MinimizedState = /*#__PURE__*/ function(MinimizedState) {
49
- MinimizedState[MinimizedState["Calculating"] = 0] = "Calculating";
50
- MinimizedState[MinimizedState["Minimized"] = 1] = "Minimized";
51
- MinimizedState[MinimizedState["Full"] = 2] = "Full";
52
- return MinimizedState;
53
- }(MinimizedState || {});
54
- export const HeaderNavigation = ({ children, className, id, items, itemsOverflow, left, leftClassName, rightClassName, minWidth = 800, overflow })=>{
55
- const leftRef = useRef(null);
56
- const rightRef = useRef(null);
57
- const centerRef = useRef(null);
58
- const navigationRef = useRef(null);
59
- const forceUpdate = useForceUpdate();
60
- const [minimized, setMinimized] = useState(0);
61
- useEffect(()=>{
62
- const handleResize = ()=>{
63
- setMinimized(0);
64
- forceUpdate();
65
- };
66
- window.addEventListener('resize', handleResize);
67
- return ()=>window.removeEventListener('resize', handleResize);
68
- }, [
69
- forceUpdate
70
- ]);
71
- useEffect(()=>{
72
- setMinimized(0);
73
- forceUpdate();
74
- }, [
75
- items,
76
- itemsOverflow,
77
- forceUpdate
78
- ]);
79
- const updateIsMinimized = ()=>{
80
- if (centerRef.current && navigationRef.current) {
81
- if (navigationRef.current.clientWidth > centerRef.current.clientWidth) {
82
- setMinimized(1);
83
- } else if (minimized === 0) {
84
- setMinimized(2);
85
- }
86
- }
87
- };
88
- useEffect(()=>{
89
- updateIsMinimized();
90
- });
91
- return /*#__PURE__*/ _jsx(NavigationLegacyContext.Provider, {
92
- value: true,
93
- children: /*#__PURE__*/ _jsxs("div", {
94
- className: classNames(Styles.header, className, {
95
- [Styles.calculating]: minimized === 0
96
- }),
97
- style: {
98
- minWidth: `${minWidth}px`
99
- },
100
- id: id,
101
- "data-cy": "header-navigation",
102
- children: [
103
- /*#__PURE__*/ _jsx("div", {
104
- className: leftClassName,
105
- ref: leftRef,
106
- "data-cy": "navigation-left",
107
- children: left
108
- }),
109
- /*#__PURE__*/ _jsx("div", {
110
- ref: centerRef,
111
- className: classNames('d-if flex-grow-1 flex-basis-0 justify-content-center', Styles.center),
112
- "data-cy": "navigation-items",
113
- children: /*#__PURE__*/ _jsxs("div", {
114
- ref: navigationRef,
115
- className: classNames('d-if'),
116
- children: [
117
- items === null || items === void 0 ? void 0 : items.map((item)=>/*#__PURE__*/ _createElement(HeaderNavigationItem, {
118
- ...item,
119
- minimized: minimized === 1,
120
- main: true,
121
- key: item.id
122
- })),
123
- !!(itemsOverflow === null || itemsOverflow === void 0 ? void 0 : itemsOverflow.length) && /*#__PURE__*/ _jsx(HeaderNavigationOverflow, {
124
- items: itemsOverflow,
125
- overflow: overflow
126
- })
127
- ]
128
- })
129
- }),
130
- /*#__PURE__*/ _jsx("div", {
131
- className: classNames('d-f flex-row justify-content-end align-items-center', Styles.right, rightClassName),
132
- ref: rightRef,
133
- "data-cy": "navigation-right",
134
- children: children
135
- })
136
- ]
137
- })
138
- });
139
- };
140
- export const HeaderNavigationStacked = ({ className, id, items, itemsOverflow, left, leftClassName, right, rightClassName, center, centerClassName, minWidth = 800, overflow })=>{
141
- const bottomRef = useRef(null);
142
- const navigationRef = useRef(null);
143
- const forceUpdate = useForceUpdate();
144
- const [minimized, setMinimized] = useState(0);
145
- useEffect(()=>{
146
- const handleResize = ()=>{
147
- setMinimized(0);
148
- forceUpdate();
149
- };
150
- window.addEventListener('resize', handleResize);
151
- return ()=>window.removeEventListener('resize', handleResize);
152
- }, [
153
- forceUpdate
154
- ]);
155
- useEffect(()=>{
156
- setMinimized(0);
157
- forceUpdate();
158
- }, [
159
- items,
160
- itemsOverflow,
161
- forceUpdate
162
- ]);
163
- const updateIsMinimized = ()=>{
164
- if (bottomRef.current && navigationRef.current) {
165
- if (navigationRef.current.clientWidth + 16 > bottomRef.current.clientWidth) {
166
- setMinimized(1);
167
- } else if (minimized === 0) {
168
- setMinimized(2);
169
- }
170
- }
171
- };
172
- useEffect(()=>{
173
- updateIsMinimized();
174
- });
175
- return /*#__PURE__*/ _jsx(NavigationLegacyContext.Provider, {
176
- value: true,
177
- children: /*#__PURE__*/ _jsxs("div", {
178
- className: classNames(Styles.headerStacked, {
179
- [Styles.calculating]: minimized === 0
180
- }, className),
181
- style: {
182
- minWidth: `${minWidth}px`
183
- },
184
- id: id,
185
- "data-cy": "header-navigation",
186
- children: [
187
- /*#__PURE__*/ _jsx("div", {
188
- className: classNames(Styles.heTopLeft, leftClassName),
189
- "data-cy": "navigation-left",
190
- children: left
191
- }),
192
- /*#__PURE__*/ _jsx("div", {
193
- className: classNames(Styles.heTopCenter, centerClassName),
194
- "data-cy": "navigation-center",
195
- children: center
196
- }),
197
- /*#__PURE__*/ _jsx("div", {
198
- className: classNames('d-f flex-row justify-content-end align-items-center', Styles.heTopRight, rightClassName),
199
- "data-cy": "navigation-right",
200
- children: right
201
- }),
202
- /*#__PURE__*/ _jsx("div", {
203
- ref: bottomRef,
204
- className: classNames(Styles.heBottom, 'd-if flex-grow-1 flex-basis-0 justify-content-center', Styles.center),
205
- "data-cy": "navigation-items",
206
- children: /*#__PURE__*/ _jsxs("div", {
207
- ref: navigationRef,
208
- className: classNames('d-if'),
209
- children: [
210
- items === null || items === void 0 ? void 0 : items.map((item)=>/*#__PURE__*/ _createElement(HeaderNavigationItem, {
211
- ...item,
212
- minimized: minimized === 1,
213
- main: true,
214
- key: item.id
215
- })),
216
- !!(itemsOverflow === null || itemsOverflow === void 0 ? void 0 : itemsOverflow.length) && /*#__PURE__*/ _jsx(HeaderNavigationOverflow, {
217
- items: itemsOverflow,
218
- overflow: overflow
219
- })
220
- ]
221
- })
222
- })
223
- ]
224
- })
225
- });
226
- };
227
-
228
- //# sourceMappingURL=header-navigation.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/components/header-navigation/header-navigation.tsx"],"sourcesContent":["import { Icon, Popover, PopoverPropsStrict } from '@servicetitan/design-system';\nimport classNames from 'classnames';\nimport { FC, ReactElement, ReactNode, useCallback, useEffect, useRef, useState } from 'react';\nimport { NavigationLegacyContext } from '../../utils/navigation-context';\nimport { HeaderNavigationItemData } from '../../utils/navigation-legacy';\nimport { HeaderNavigationItem } from './header-navigation-content';\nimport * as Styles from './header-navigation.module.less';\n\nfunction useForceUpdate() {\n const [, setTick] = useState(0);\n return useCallback(() => {\n setTick(tick => tick + 1);\n }, []);\n}\n\nexport interface HeaderNavigationOverflowProps {\n direction: PopoverPropsStrict['direction'];\n width: PopoverPropsStrict['width'];\n portal?: boolean;\n}\n\nconst HeaderNavigationOverflow: FC<{\n items: HeaderNavigationItemData[];\n overflow?: HeaderNavigationOverflowProps;\n}> = ({ items, overflow }) => {\n const [isOpen, setIsOpen] = useState(false);\n\n return (\n <Popover\n open={isOpen}\n trigger={\n <Icon\n name=\"more_vert\"\n size=\"24px\"\n className=\"c-pointer\"\n onClick={() => setIsOpen(true)}\n color=\"white\"\n data-cy=\"navigation-overflow-trigger\"\n data-pendo=\"navigation-overflow-trigger\"\n />\n }\n direction={overflow?.direction ?? 'bl'}\n width={overflow?.width ?? 'xs'}\n portal={overflow?.portal}\n onClickOutside={() => setIsOpen(false)}\n wrapperClassName=\"d-if-i align-items-center\"\n popoverContentClassName={Styles.overflowPopover}\n >\n <div\n onClick={() => setIsOpen(false)}\n className={Styles.navigationOverflow}\n data-cy=\"navigation-overflow-content\"\n >\n {items.map(item => (\n <HeaderNavigationItem {...item} key={item.id} minimized={false} main={false} />\n ))}\n </div>\n </Popover>\n );\n};\n\nexport interface HeaderNavigationProps {\n /** extra navigation */\n children?: ReactNode;\n /** container class name */\n className?: string;\n /** extra navigation container class name */\n rightClassName?: string;\n /** container id */\n id?: string;\n /** left content (usually used for logo) */\n left?: ReactElement;\n /** left container class name */\n leftClassName?: string;\n /** minimal width for navigation bar */\n minWidth?: number;\n /** main navigation items */\n items?: HeaderNavigationItemData[];\n /** main navigation overflow items */\n itemsOverflow?: HeaderNavigationItemData[];\n /** props for main items overflow component */\n overflow?: HeaderNavigationOverflowProps;\n}\n\nenum MinimizedState {\n Calculating,\n Minimized,\n Full,\n}\n\nexport const HeaderNavigation: FC<HeaderNavigationProps> = ({\n children,\n className,\n id,\n items,\n itemsOverflow,\n left,\n leftClassName,\n rightClassName,\n minWidth = 800,\n overflow,\n}) => {\n const leftRef = useRef<HTMLDivElement>(null);\n const rightRef = useRef<HTMLDivElement>(null);\n const centerRef = useRef<HTMLDivElement>(null);\n const navigationRef = useRef<HTMLDivElement>(null);\n const forceUpdate = useForceUpdate();\n const [minimized, setMinimized] = useState(MinimizedState.Calculating);\n\n useEffect(() => {\n const handleResize = () => {\n setMinimized(MinimizedState.Calculating);\n forceUpdate();\n };\n\n window.addEventListener('resize', handleResize);\n return () => window.removeEventListener('resize', handleResize);\n }, [forceUpdate]);\n\n useEffect(() => {\n setMinimized(MinimizedState.Calculating);\n forceUpdate();\n }, [items, itemsOverflow, forceUpdate]);\n\n const updateIsMinimized = () => {\n if (centerRef.current && navigationRef.current) {\n if (navigationRef.current.clientWidth > centerRef.current.clientWidth) {\n setMinimized(MinimizedState.Minimized);\n } else if (minimized === MinimizedState.Calculating) {\n setMinimized(MinimizedState.Full);\n }\n }\n };\n\n useEffect(() => {\n updateIsMinimized();\n });\n\n return (\n <NavigationLegacyContext.Provider value>\n <div\n className={classNames(Styles.header, className, {\n [Styles.calculating]: minimized === MinimizedState.Calculating,\n })}\n style={{ minWidth: `${minWidth}px` }}\n id={id}\n data-cy=\"header-navigation\"\n >\n <div className={leftClassName} ref={leftRef} data-cy=\"navigation-left\">\n {left}\n </div>\n <div\n ref={centerRef}\n className={classNames(\n 'd-if flex-grow-1 flex-basis-0 justify-content-center',\n Styles.center\n )}\n data-cy=\"navigation-items\"\n >\n <div ref={navigationRef} className={classNames('d-if')}>\n {items?.map(item => (\n <HeaderNavigationItem\n {...item}\n minimized={minimized === MinimizedState.Minimized}\n main\n key={item.id}\n />\n ))}\n {!!itemsOverflow?.length && (\n <HeaderNavigationOverflow items={itemsOverflow} overflow={overflow} />\n )}\n </div>\n </div>\n <div\n className={classNames(\n 'd-f flex-row justify-content-end align-items-center',\n Styles.right,\n rightClassName\n )}\n ref={rightRef}\n data-cy=\"navigation-right\"\n >\n {children}\n </div>\n </div>\n </NavigationLegacyContext.Provider>\n );\n};\n\nexport interface HeaderNavigationStackedProps {\n /** container class name */\n className?: string;\n /** extra navigation */\n right?: ReactNode;\n /** extra navigation container class name */\n rightClassName?: string;\n /** container id */\n id?: string;\n /** left content (usually used for logo) */\n left?: ReactElement;\n /** left container class name */\n leftClassName?: string;\n /** center content */\n center?: ReactElement;\n /** center container class name */\n centerClassName?: string;\n /** minimal width for navigation bar */\n minWidth?: number;\n /** main navigation items */\n items?: HeaderNavigationItemData[];\n /** main navigation overflow items */\n itemsOverflow?: HeaderNavigationItemData[];\n /** props for main items overflow component */\n overflow?: HeaderNavigationOverflowProps;\n}\n\nexport const HeaderNavigationStacked: FC<HeaderNavigationStackedProps> = ({\n className,\n id,\n items,\n itemsOverflow,\n left,\n leftClassName,\n right,\n rightClassName,\n center,\n centerClassName,\n minWidth = 800,\n overflow,\n}) => {\n const bottomRef = useRef<HTMLDivElement>(null);\n const navigationRef = useRef<HTMLDivElement>(null);\n const forceUpdate = useForceUpdate();\n const [minimized, setMinimized] = useState(MinimizedState.Calculating);\n\n useEffect(() => {\n const handleResize = () => {\n setMinimized(MinimizedState.Calculating);\n forceUpdate();\n };\n\n window.addEventListener('resize', handleResize);\n return () => window.removeEventListener('resize', handleResize);\n }, [forceUpdate]);\n\n useEffect(() => {\n setMinimized(MinimizedState.Calculating);\n forceUpdate();\n }, [items, itemsOverflow, forceUpdate]);\n\n const updateIsMinimized = () => {\n if (bottomRef.current && navigationRef.current) {\n if (navigationRef.current.clientWidth + 16 > bottomRef.current.clientWidth) {\n setMinimized(MinimizedState.Minimized);\n } else if (minimized === MinimizedState.Calculating) {\n setMinimized(MinimizedState.Full);\n }\n }\n };\n\n useEffect(() => {\n updateIsMinimized();\n });\n\n return (\n <NavigationLegacyContext.Provider value>\n <div\n className={classNames(\n Styles.headerStacked,\n {\n [Styles.calculating]: minimized === MinimizedState.Calculating,\n },\n className\n )}\n style={{ minWidth: `${minWidth}px` }}\n id={id}\n data-cy=\"header-navigation\"\n >\n <div\n className={classNames(Styles.heTopLeft, leftClassName)}\n data-cy=\"navigation-left\"\n >\n {left}\n </div>\n <div\n className={classNames(Styles.heTopCenter, centerClassName)}\n data-cy=\"navigation-center\"\n >\n {center}\n </div>\n <div\n className={classNames(\n 'd-f flex-row justify-content-end align-items-center',\n Styles.heTopRight,\n rightClassName\n )}\n data-cy=\"navigation-right\"\n >\n {right}\n </div>\n <div\n ref={bottomRef}\n className={classNames(\n Styles.heBottom,\n 'd-if flex-grow-1 flex-basis-0 justify-content-center',\n Styles.center\n )}\n data-cy=\"navigation-items\"\n >\n <div ref={navigationRef} className={classNames('d-if')}>\n {items?.map(item => (\n <HeaderNavigationItem\n {...item}\n minimized={minimized === MinimizedState.Minimized}\n main\n key={item.id}\n />\n ))}\n {!!itemsOverflow?.length && (\n <HeaderNavigationOverflow items={itemsOverflow} overflow={overflow} />\n )}\n </div>\n </div>\n </div>\n </NavigationLegacyContext.Provider>\n );\n};\n"],"names":["Icon","Popover","classNames","useCallback","useEffect","useRef","useState","NavigationLegacyContext","HeaderNavigationItem","Styles","useForceUpdate","setTick","tick","HeaderNavigationOverflow","items","overflow","isOpen","setIsOpen","open","trigger","name","size","className","onClick","color","data-cy","data-pendo","direction","width","portal","onClickOutside","wrapperClassName","popoverContentClassName","overflowPopover","div","navigationOverflow","map","item","key","id","minimized","main","MinimizedState","HeaderNavigation","children","itemsOverflow","left","leftClassName","rightClassName","minWidth","leftRef","rightRef","centerRef","navigationRef","forceUpdate","setMinimized","handleResize","window","addEventListener","removeEventListener","updateIsMinimized","current","clientWidth","Provider","value","header","calculating","style","ref","center","length","right","HeaderNavigationStacked","centerClassName","bottomRef","headerStacked","heTopLeft","heTopCenter","heTopRight","heBottom"],"mappings":"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"}
@@ -1,260 +0,0 @@
1
- /* stylelint-disable no-descending-specificity */
2
- @import (reference) '@servicetitan/tokens/core/tokens.less';
3
-
4
- .header {
5
- height: 56px;
6
- display: flex;
7
- flex-direction: row;
8
- align-items: center;
9
-
10
- background-color: @color-neutral-300;
11
- box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.25);
12
-
13
- .right > * {
14
- color: @color-white;
15
- }
16
-
17
- .right {
18
- .navigation-icon {
19
- height: 24px;
20
- width: 24px;
21
- font-size: 24px;
22
- }
23
- }
24
-
25
- .center {
26
- min-width: 0;
27
- overflow-x: hidden;
28
- overflow-y: hidden;
29
-
30
- .navigation-icon {
31
- height: 20px;
32
- width: 20px;
33
- font-size: @typescale-4;
34
- }
35
- }
36
-
37
- &.calculating {
38
- .center {
39
- opacity: 0;
40
- }
41
- }
42
-
43
- :global(.profile-dropdown-image) {
44
- height: 32px;
45
- width: 32px;
46
- }
47
-
48
- :global(.profile-dropdown-trigger) {
49
- height: 40px;
50
- font-size: 24px;
51
- }
52
-
53
- .navigation-item-counter {
54
- font-size: @typescale-0 !important;
55
- }
56
-
57
- .navigation-item-main .navigation-item-counter {
58
- top: 8px;
59
- right: -4px;
60
-
61
- &.navigation-item-counter-long {
62
- right: -8px;
63
- }
64
- }
65
-
66
- .navigation-link {
67
- padding: @spacing-2 @spacing-1;
68
- font-size: 24px;
69
-
70
- .navigation-item-counter {
71
- top: 8px;
72
- right: -4px;
73
- }
74
- }
75
-
76
- .navigation-item-main {
77
- // styles specific to main nav links
78
- padding: 18px 10px;
79
- }
80
-
81
- .navigation-item {
82
- &.navigation-item-active:not(.navigation-item-overflow) {
83
- color: @color-blue-200 !important;
84
- }
85
- &:hover:not(.navigation-item-active):not(.navigation-item-overflow) {
86
- opacity: 0.7;
87
- }
88
- }
89
- }
90
-
91
- .overflow-popover {
92
- padding: @spacing-1 @spacing-0 !important;
93
-
94
- .navigation-overflow {
95
- display: flex;
96
- flex-direction: column;
97
- }
98
- }
99
-
100
- .header-stacked {
101
- display: grid;
102
- grid-template-columns: repeat(3, 1fr);
103
- grid-template-rows: 44px 36px;
104
-
105
- background-color: @color-neutral-500;
106
-
107
- & > * {
108
- overflow-y: hidden;
109
- }
110
-
111
- .he-top-left {
112
- grid-column: span 1;
113
- }
114
-
115
- .he-top-center {
116
- grid-column: span 1;
117
- }
118
-
119
- .he-top-right {
120
- grid-column: span 1;
121
-
122
- .navigation-icon {
123
- height: 20px;
124
- width: 20px;
125
- font-size: @typescale-4;
126
- }
127
-
128
- & > * {
129
- color: @color-white;
130
- }
131
- }
132
-
133
- .he-bottom {
134
- grid-column: span 3;
135
- border-top: 1px solid @color-neutral-200;
136
-
137
- .navigation-icon {
138
- height: 20px;
139
- width: 20px;
140
- font-size: @typescale-4;
141
- }
142
- }
143
-
144
- &.calculating {
145
- .he-bottom {
146
- opacity: 0;
147
- }
148
- }
149
-
150
- :global(.profile-dropdown-image) {
151
- height: 24px;
152
- width: 24px;
153
- }
154
-
155
- :global(.profile-dropdown-trigger) {
156
- height: 30px;
157
- font-size: @typescale-4;
158
- }
159
-
160
- .navigation-item-counter {
161
- font-size: 8px !important;
162
- }
163
-
164
- .navigation-item-main .navigation-item-counter {
165
- top: 4px;
166
- right: -4px;
167
-
168
- &.navigation-item-counter-long {
169
- right: -8px;
170
- }
171
- }
172
-
173
- .navigation-link {
174
- padding: 12px @spacing-1;
175
- font-size: @typescale-4;
176
-
177
- .navigation-item-counter {
178
- top: 8px;
179
- right: 0;
180
- }
181
- }
182
-
183
- .navigation-item-main {
184
- // styles specific to main nav links
185
- padding: 7px 10px;
186
- }
187
-
188
- .navigation-item {
189
- &.navigation-item-active:not(.navigation-item-overflow) {
190
- color: @color-blue-200 !important;
191
- }
192
- &:hover:not(.navigation-item-active):not(.navigation-item-overflow) {
193
- opacity: 0.7;
194
- }
195
- }
196
- }
197
-
198
- .navigation-icon {
199
- display: inline-block;
200
- color: inherit;
201
-
202
- & > svg {
203
- height: 1em;
204
- width: 1em;
205
- font-size: 1em;
206
- }
207
- }
208
-
209
- .navigation-item {
210
- // styles specific to main nav links and extra nav links
211
- font-family: @base-font-family;
212
- color: @color-white;
213
- position: relative;
214
- display: flex;
215
- align-items: center;
216
- flex-wrap: nowrap;
217
- text-wrap: nowrap;
218
-
219
- .navigation-item-counter {
220
- color: @color-white;
221
- font-weight: @font-weight-semibold;
222
- min-width: 12px !important;
223
- min-height: 12px !important;
224
- }
225
-
226
- &:not(.navigation-item-overflow) .navigation-item-counter {
227
- position: absolute;
228
- }
229
-
230
- .navigation-item-title {
231
- font-family: @base-font-family;
232
- font-size: @typescale-2;
233
- margin-left: @spacing-half;
234
- }
235
- }
236
-
237
- .navigation-item-overflow {
238
- // styles specific to overflow links
239
- display: inline-flex;
240
- color: @color-black;
241
- padding: @spacing-1 12px;
242
-
243
- &.navigation-item-active:not(:hover) {
244
- color: @color-blue-500;
245
- }
246
-
247
- &:hover {
248
- background-color: @color-blue-500;
249
- color: @color-white;
250
- }
251
-
252
- .navigation-item-counter {
253
- margin-left: @spacing-half;
254
- margin-top: -@spacing-1;
255
- }
256
- }
257
-
258
- .navigation-link {
259
- color: inherit;
260
- }
@@ -1,22 +0,0 @@
1
- export const __esModule: true;
2
- export const calculating: string;
3
- export const center: string;
4
- export const heBottom: string;
5
- export const heTopCenter: string;
6
- export const heTopLeft: string;
7
- export const heTopRight: string;
8
- export const header: string;
9
- export const headerStacked: string;
10
- export const navigationIcon: string;
11
- export const navigationItem: string;
12
- export const navigationItemActive: string;
13
- export const navigationItemCounter: string;
14
- export const navigationItemCounterLong: string;
15
- export const navigationItemMain: string;
16
- export const navigationItemOverflow: string;
17
- export const navigationItemTitle: string;
18
- export const navigationLink: string;
19
- export const navigationOverflow: string;
20
- export const overflowPopover: string;
21
- export const right: string;
22
-
@@ -1,12 +0,0 @@
1
- import { FC } from 'react';
2
- declare const _default: {
3
- title: string;
4
- component: FC<import("./header-navigation").HeaderNavigationProps>;
5
- parameters: {};
6
- decorators: ((Story: any) => import("react/jsx-runtime").JSX.Element)[];
7
- };
8
- export default _default;
9
- export declare const DefaultNavigation: () => import("react/jsx-runtime").JSX.Element;
10
- export declare const WithLogoTextAndOverflow: () => import("react/jsx-runtime").JSX.Element;
11
- export declare const WithAllMonolithData: () => import("react/jsx-runtime").JSX.Element;
12
- //# sourceMappingURL=header-navigation.stories.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"header-navigation.stories.d.ts","sourceRoot":"","sources":["../../../src/components/header-navigation/header-navigation.stories.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,EAAE,EAAY,MAAM,OAAO,CAAC;;;;;;;AASrC,wBAKE;AAGF,eAAO,MAAM,iBAAiB,+CAY7B,CAAC;AAEF,eAAO,MAAM,uBAAuB,+CAoBnC,CAAC;AAkCF,eAAO,MAAM,mBAAmB,+CA8E/B,CAAC"}
@@ -1,2 +0,0 @@
1
- export * from './header-navigation';
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/header-navigation/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC"}
@@ -1,3 +0,0 @@
1
- export * from './header-navigation';
2
-
3
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/components/header-navigation/index.ts"],"sourcesContent":["export * from './header-navigation';\n"],"names":[],"mappings":"AAAA,cAAc,sBAAsB"}
@@ -1,4 +0,0 @@
1
- import { TooltipPropsStrict } from '@servicetitan/design-system';
2
- import { ReactNode } from 'react';
3
- export declare const withTooltip: (element: ReactNode, tooltip: string | undefined, direction?: TooltipPropsStrict["direction"]) => string | number | bigint | boolean | Iterable<ReactNode> | Promise<string | number | bigint | boolean | import("react").ReactPortal | import("react").ReactElement<unknown, string | import("react").JSXElementConstructor<any>> | Iterable<ReactNode> | null | undefined> | import("react/jsx-runtime").JSX.Element | null | undefined;
4
- //# sourceMappingURL=with-tooltip.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"with-tooltip.d.ts","sourceRoot":"","sources":["../../../src/components/header-navigation/with-tooltip.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAW,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AAC1E,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAElC,eAAO,MAAM,WAAW,GACpB,SAAS,SAAS,EAClB,SAAS,MAAM,GAAG,SAAS,EAC3B,YAAW,kBAAkB,CAAC,WAAW,CAAO,4UAQ/C,CAAC"}
@@ -1,10 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { Tooltip } from '@servicetitan/design-system';
3
- export const withTooltip = (element, tooltip, direction = 'b')=>tooltip ? /*#__PURE__*/ _jsx(Tooltip, {
4
- el: "div",
5
- direction: direction,
6
- text: tooltip,
7
- children: element
8
- }) : element;
9
-
10
- //# sourceMappingURL=with-tooltip.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/components/header-navigation/with-tooltip.tsx"],"sourcesContent":["import { Tooltip, TooltipPropsStrict } from '@servicetitan/design-system';\nimport { ReactNode } from 'react';\n\nexport const withTooltip = (\n element: ReactNode,\n tooltip: string | undefined,\n direction: TooltipPropsStrict['direction'] = 'b'\n) =>\n tooltip ? (\n <Tooltip el=\"div\" direction={direction} text={tooltip}>\n {element}\n </Tooltip>\n ) : (\n element\n );\n"],"names":["Tooltip","withTooltip","element","tooltip","direction","el","text"],"mappings":";AAAA,SAASA,OAAO,QAA4B,8BAA8B;AAG1E,OAAO,MAAMC,cAAc,CACvBC,SACAC,SACAC,YAA6C,GAAG,GAEhDD,wBACI,KAACH;QAAQK,IAAG;QAAMD,WAAWA;QAAWE,MAAMH;kBACzCD;SAGLA,QACF"}