@servicetitan/navigation 11.0.0 → 11.1.1

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 (179) hide show
  1. package/dist/components/badge-tag.js +7 -2
  2. package/dist/components/badge-tag.js.map +1 -1
  3. package/dist/components/counter-tag.js +10 -2
  4. package/dist/components/counter-tag.js.map +1 -1
  5. package/dist/components/header-navigation/header-navigation-content.js +44 -8
  6. package/dist/components/header-navigation/header-navigation-content.js.map +1 -1
  7. package/dist/components/header-navigation/header-navigation-links.js +49 -13
  8. package/dist/components/header-navigation/header-navigation-links.js.map +1 -1
  9. package/dist/components/header-navigation/header-navigation-stories.module.less.d.ts +3 -0
  10. package/dist/components/header-navigation/header-navigation.js +178 -46
  11. package/dist/components/header-navigation/header-navigation.js.map +1 -1
  12. package/dist/components/header-navigation/header-navigation.module.less.d.ts +22 -0
  13. package/dist/components/header-navigation/index.js +1 -0
  14. package/dist/components/header-navigation/index.js.map +1 -1
  15. package/dist/components/header-navigation/with-tooltip.js +7 -1
  16. package/dist/components/header-navigation/with-tooltip.js.map +1 -1
  17. package/dist/components/left-navigation/header-navigation-tiny-links.js +62 -15
  18. package/dist/components/left-navigation/header-navigation-tiny-links.js.map +1 -1
  19. package/dist/components/left-navigation/header-navigation-tiny.js +27 -2
  20. package/dist/components/left-navigation/header-navigation-tiny.js.map +1 -1
  21. package/dist/components/left-navigation/header-navigation-tiny.module.less.d.ts +15 -0
  22. package/dist/components/left-navigation/index.d.ts +1 -1
  23. package/dist/components/left-navigation/index.d.ts.map +1 -1
  24. package/dist/components/left-navigation/index.js +1 -1
  25. package/dist/components/left-navigation/index.js.map +1 -1
  26. package/dist/components/left-navigation/interface-internal.js +2 -1
  27. package/dist/components/left-navigation/interface-internal.js.map +1 -1
  28. package/dist/components/left-navigation/interface.js +2 -1
  29. package/dist/components/left-navigation/interface.js.map +1 -1
  30. package/dist/components/left-navigation/side-navigation-context.js +4 -3
  31. package/dist/components/left-navigation/side-navigation-context.js.map +1 -1
  32. package/dist/components/left-navigation/side-navigation-links-internal.js +76 -16
  33. package/dist/components/left-navigation/side-navigation-links-internal.js.map +1 -1
  34. package/dist/components/left-navigation/side-navigation-links.js +34 -13
  35. package/dist/components/left-navigation/side-navigation-links.js.map +1 -1
  36. package/dist/components/left-navigation/side-navigation.js +314 -85
  37. package/dist/components/left-navigation/side-navigation.js.map +1 -1
  38. package/dist/components/left-navigation/side-navigation.module.less.d.ts +48 -0
  39. package/dist/components/left-navigation/with-tooltip.js +12 -1
  40. package/dist/components/left-navigation/with-tooltip.js.map +1 -1
  41. package/dist/components/links.js +28 -7
  42. package/dist/components/links.js.map +1 -1
  43. package/dist/components/logo/logo-company-title.js +19 -3
  44. package/dist/components/logo/logo-company-title.js.map +1 -1
  45. package/dist/components/logo/logo-titan-text.js +50 -6
  46. package/dist/components/logo/logo-titan-text.js.map +1 -1
  47. package/dist/components/logo/logo-titan-text.module.less.d.ts +6 -0
  48. package/dist/components/logo/logo-titan.d.ts +1 -0
  49. package/dist/components/logo/logo-titan.d.ts.map +1 -1
  50. package/dist/components/logo/logo-titan.js +53 -8
  51. package/dist/components/logo/logo-titan.js.map +1 -1
  52. package/dist/components/profile-dropdown/profile-dropdown.d.ts.map +1 -1
  53. package/dist/components/profile-dropdown/profile-dropdown.js +174 -33
  54. package/dist/components/profile-dropdown/profile-dropdown.js.map +1 -1
  55. package/dist/components/profile-dropdown/profile-dropdown.module.less.d.ts +23 -0
  56. package/dist/components/profile-dropdown/profile-icon.js +49 -3
  57. package/dist/components/profile-dropdown/profile-icon.js.map +1 -1
  58. package/dist/components/titan-layout/index.d.ts +2 -2
  59. package/dist/components/titan-layout/index.d.ts.map +1 -1
  60. package/dist/components/titan-layout/index.js +1 -2
  61. package/dist/components/titan-layout/index.js.map +1 -1
  62. package/dist/components/titan-layout/interface-internal.js +2 -1
  63. package/dist/components/titan-layout/interface-internal.js.map +1 -1
  64. package/dist/components/titan-layout/interface.js +2 -1
  65. package/dist/components/titan-layout/interface.js.map +1 -1
  66. package/dist/components/titan-layout/layout-context.js +15 -6
  67. package/dist/components/titan-layout/layout-context.js.map +1 -1
  68. package/dist/components/titan-layout/layout-header-dark.d.ts +10 -0
  69. package/dist/components/titan-layout/layout-header-dark.d.ts.map +1 -0
  70. package/dist/components/titan-layout/layout-header-dark.js +146 -0
  71. package/dist/components/titan-layout/layout-header-dark.js.map +1 -0
  72. package/dist/components/titan-layout/layout-header-links.js +61 -15
  73. package/dist/components/titan-layout/layout-header-links.js.map +1 -1
  74. package/dist/components/titan-layout/layout-header.d.ts +2 -6
  75. package/dist/components/titan-layout/layout-header.d.ts.map +1 -1
  76. package/dist/components/titan-layout/layout-header.js +46 -2
  77. package/dist/components/titan-layout/layout-header.js.map +1 -1
  78. package/dist/components/titan-layout/layout-header.module.less +337 -83
  79. package/dist/components/titan-layout/layout-header.module.less.d.ts +35 -0
  80. package/dist/components/titan-layout/layout-logo.d.ts +5 -3
  81. package/dist/components/titan-layout/layout-logo.d.ts.map +1 -1
  82. package/dist/components/titan-layout/layout-logo.js +47 -9
  83. package/dist/components/titan-layout/layout-logo.js.map +1 -1
  84. package/dist/components/titan-layout/layout-logo.stories.d.ts +15 -4
  85. package/dist/components/titan-layout/layout-logo.stories.d.ts.map +1 -1
  86. package/dist/components/titan-layout/layout-profile.js +75 -23
  87. package/dist/components/titan-layout/layout-profile.js.map +1 -1
  88. package/dist/components/titan-layout/layout-sidebar-links-internal.js +162 -36
  89. package/dist/components/titan-layout/layout-sidebar-links-internal.js.map +1 -1
  90. package/dist/components/titan-layout/layout-sidebar-links.js +33 -13
  91. package/dist/components/titan-layout/layout-sidebar-links.js.map +1 -1
  92. package/dist/components/titan-layout/layout-sidebar.js +198 -34
  93. package/dist/components/titan-layout/layout-sidebar.js.map +1 -1
  94. package/dist/components/titan-layout/layout-sidebar.module.less +6 -2
  95. package/dist/components/titan-layout/layout-sidebar.module.less.d.ts +49 -0
  96. package/dist/components/titan-layout/notifications-context.js +20 -10
  97. package/dist/components/titan-layout/notifications-context.js.map +1 -1
  98. package/dist/components/titan-layout/titan-layout.d.ts +7 -8
  99. package/dist/components/titan-layout/titan-layout.d.ts.map +1 -1
  100. package/dist/components/titan-layout/titan-layout.js +271 -117
  101. package/dist/components/titan-layout/titan-layout.js.map +1 -1
  102. package/dist/components/titan-layout/titan-layout.module.less +7 -2
  103. package/dist/components/titan-layout/titan-layout.module.less.d.ts +17 -0
  104. package/dist/components/titan-layout/titan-layout.stories.d.ts +6 -0
  105. package/dist/components/titan-layout/titan-layout.stories.d.ts.map +1 -1
  106. package/dist/components/titan-layout/with-tooltip.d.ts +4 -1
  107. package/dist/components/titan-layout/with-tooltip.d.ts.map +1 -1
  108. package/dist/components/titan-layout/with-tooltip.js +13 -1
  109. package/dist/components/titan-layout/with-tooltip.js.map +1 -1
  110. package/dist/index.d.ts +4 -3
  111. package/dist/index.d.ts.map +1 -1
  112. package/dist/index.js +2 -3
  113. package/dist/index.js.map +1 -1
  114. package/dist/test/data-stories.module.less.d.ts +3 -0
  115. package/dist/test/data.js +223 -90
  116. package/dist/test/data.js.map +1 -1
  117. package/dist/utils/counter-tag.js +2 -1
  118. package/dist/utils/counter-tag.js.map +1 -1
  119. package/dist/utils/navigation-context.js +12 -6
  120. package/dist/utils/navigation-context.js.map +1 -1
  121. package/dist/utils/navigation-legacy.js +2 -1
  122. package/dist/utils/navigation-legacy.js.map +1 -1
  123. package/dist/utils/navigation.js +2 -1
  124. package/dist/utils/navigation.js.map +1 -1
  125. package/dist/utils/side-nav.js +9 -6
  126. package/dist/utils/side-nav.js.map +1 -1
  127. package/dist/utils/use-breakpoint.js +11 -8
  128. package/dist/utils/use-breakpoint.js.map +1 -1
  129. package/package.json +4 -4
  130. package/src/components/left-navigation/index.ts +1 -1
  131. package/src/components/logo/logo-titan.tsx +3 -1
  132. package/src/components/profile-dropdown/profile-dropdown.tsx +8 -4
  133. package/src/components/titan-layout/index.ts +2 -2
  134. package/src/components/titan-layout/layout-header-dark.tsx +186 -0
  135. package/src/components/titan-layout/layout-header-links.tsx +1 -1
  136. package/src/components/titan-layout/layout-header.module.less +337 -83
  137. package/src/components/titan-layout/layout-header.module.less.d.ts +19 -2
  138. package/src/components/titan-layout/layout-header.tsx +13 -16
  139. package/src/components/titan-layout/layout-logo.stories.tsx +103 -15
  140. package/src/components/titan-layout/layout-logo.tsx +33 -36
  141. package/src/components/titan-layout/layout-profile.stories.tsx +1 -1
  142. package/src/components/titan-layout/layout-sidebar.module.less +6 -2
  143. package/src/components/titan-layout/layout-sidebar.tsx +1 -1
  144. package/src/components/titan-layout/titan-layout.module.less +7 -2
  145. package/src/components/titan-layout/titan-layout.module.less.d.ts +2 -1
  146. package/src/components/titan-layout/titan-layout.stories.tsx +80 -23
  147. package/src/components/titan-layout/titan-layout.tsx +96 -85
  148. package/src/components/titan-layout/with-tooltip.tsx +5 -2
  149. package/src/index.ts +4 -5
  150. package/dist/components/header-navigation/header-navigation-extra-stacked.stories.js +0 -13
  151. package/dist/components/header-navigation/header-navigation-extra-stacked.stories.js.map +0 -1
  152. package/dist/components/header-navigation/header-navigation-extra.stories.js +0 -29
  153. package/dist/components/header-navigation/header-navigation-extra.stories.js.map +0 -1
  154. package/dist/components/header-navigation/header-navigation-stacked.stories.js +0 -50
  155. package/dist/components/header-navigation/header-navigation-stacked.stories.js.map +0 -1
  156. package/dist/components/header-navigation/header-navigation.stories.js +0 -54
  157. package/dist/components/header-navigation/header-navigation.stories.js.map +0 -1
  158. package/dist/components/layout.stories.js +0 -29
  159. package/dist/components/layout.stories.js.map +0 -1
  160. package/dist/components/left-navigation/header-navigation-extra-tiny.stories.js +0 -13
  161. package/dist/components/left-navigation/header-navigation-extra-tiny.stories.js.map +0 -1
  162. package/dist/components/left-navigation/header-navigation-tiny.stories.js +0 -30
  163. package/dist/components/left-navigation/header-navigation-tiny.stories.js.map +0 -1
  164. package/dist/components/left-navigation/side-navigation.stories.js +0 -115
  165. package/dist/components/left-navigation/side-navigation.stories.js.map +0 -1
  166. package/dist/components/logo/logo.stories.js +0 -20
  167. package/dist/components/logo/logo.stories.js.map +0 -1
  168. package/dist/components/profile-dropdown/profile-dropdown-stacked.stories.js +0 -13
  169. package/dist/components/profile-dropdown/profile-dropdown-stacked.stories.js.map +0 -1
  170. package/dist/components/profile-dropdown/profile-dropdown-tiny.stories.js +0 -13
  171. package/dist/components/profile-dropdown/profile-dropdown-tiny.stories.js.map +0 -1
  172. package/dist/components/profile-dropdown/profile-dropdown.stories.js +0 -51
  173. package/dist/components/profile-dropdown/profile-dropdown.stories.js.map +0 -1
  174. package/dist/components/titan-layout/layout-logo.stories.js +0 -17
  175. package/dist/components/titan-layout/layout-logo.stories.js.map +0 -1
  176. package/dist/components/titan-layout/layout-profile.stories.js +0 -13
  177. package/dist/components/titan-layout/layout-profile.stories.js.map +0 -1
  178. package/dist/components/titan-layout/titan-layout.stories.js +0 -83
  179. package/dist/components/titan-layout/titan-layout.stories.js.map +0 -1
@@ -1,25 +1,39 @@
1
1
  /* stylelint-disable no-descending-specificity */
2
+ /* stylelint-disable no-duplicate-selectors */
2
3
  @import (reference) '@servicetitan/tokens/core/tokens.less';
3
4
 
4
5
  @size-links-tiny: 24px;
6
+ @bg-light: @color-white;
7
+ @bg-dark: @color-neutral-300;
8
+
9
+ @c-light: @color-black;
10
+ @c-dark: @color-white;
5
11
 
6
12
  .header {
7
13
  --nav-top-content-height: 32px;
14
+
15
+ height: var(--nav-offset-top);
8
16
  display: flex;
9
17
  justify-content: space-between;
10
18
 
11
- background-color: @color-white;
12
- color: @color-black;
19
+ color: var(--nav-top-text-color);
13
20
  box-sizing: border-box;
14
- outline: 1px solid @color-neutral-60;
15
21
 
16
- & > * {
17
- overflow-y: hidden;
22
+ &.header-light {
23
+ background-color: @bg-light;
24
+ outline: 1px solid @color-neutral-60;
25
+
26
+ --nav-top-text-color: @c-light;
18
27
  }
19
28
 
20
- .he-top-left {
21
- display: flex;
22
- align-items: center;
29
+ &.header-dark {
30
+ background-color: @bg-dark;
31
+
32
+ --nav-top-text-color: @c-dark;
33
+ }
34
+
35
+ & > * {
36
+ overflow-y: hidden;
23
37
  }
24
38
 
25
39
  .he-top-center {
@@ -28,7 +42,7 @@
28
42
 
29
43
  .he-top-right {
30
44
  & > * {
31
- color: @color-black;
45
+ color: var(--nav-top-text-color);
32
46
  }
33
47
 
34
48
  .he-top-right-text {
@@ -48,58 +62,11 @@
48
62
  height: 32px;
49
63
  font-size: @size-links-tiny;
50
64
  }
51
-
52
- .navigation-link {
53
- border-radius: 12px;
54
- font-size: @size-links-tiny;
55
- color: inherit;
56
-
57
- &.navigation-item-active:not(.navigation-item-overflow) {
58
- background-color: @color-blue-100 !important;
59
- color: @color-blue-500 !important;
60
- }
61
- &:hover:not(.navigation-item-active):not(.navigation-item-overflow) {
62
- background-color: rgba(0, 0, 0, 0.12) !important;
63
- }
64
-
65
- &.navigation-item-icon-state.navigation-item-active {
66
- .navigation-icon[data-anv][data-anv]:not(.navigation-icon-active) {
67
- display: none;
68
- }
69
-
70
- .navigation-icon.navigation-icon-active[data-anv][data-anv] {
71
- display: block;
72
- }
73
- }
74
- }
75
-
76
- .navigation-icon[data-anv][data-anv] {
77
- display: inline-block;
78
- color: inherit;
79
- height: 24px;
80
- width: 24px;
81
-
82
- > svg {
83
- height: @size-links-tiny;
84
- width: @size-links-tiny;
85
- }
86
-
87
- &.navigation-icon-active {
88
- display: none;
89
- }
90
- }
91
65
  }
92
66
 
93
67
  .header-mobile {
94
- padding: @spacing-2 @spacing-0;
95
- height: var(--nav-offset-top);
96
-
97
68
  --nav-top-content-height: 40px;
98
69
 
99
- .navigation-link {
100
- padding: 10px;
101
- }
102
-
103
70
  .he-top-center {
104
71
  max-width: unset;
105
72
  flex: 1;
@@ -107,31 +74,26 @@
107
74
  margin-right: @spacing-3;
108
75
  }
109
76
 
110
- .he-top-left {
111
- margin-left: @spacing-half;
77
+ .he-top-right {
78
+ margin-right: @spacing-half;
112
79
  }
113
80
 
81
+ .he-top-center,
114
82
  .he-top-right {
115
- margin-right: @spacing-half;
83
+ margin-top: @spacing-2;
84
+ margin-bottom: @spacing-2;
85
+ }
86
+
87
+ .burger {
88
+ padding-top: @spacing-2;
89
+ padding-right: @spacing-half;
90
+ padding-bottom: @spacing-2;
91
+ padding-left: @spacing-0;
116
92
  }
117
93
  }
118
94
 
119
95
  // desktop
120
96
  .header-desktop {
121
- height: var(--nav-offset-top);
122
- .navigation-link {
123
- margin: 6px 2px;
124
- padding: 6px 6px;
125
-
126
- .navigation-item-counter {
127
- min-width: 12px !important;
128
- height: 12px !important;
129
- }
130
- }
131
-
132
- .he-top-left {
133
- padding-left: @spacing-1;
134
- }
135
97
  .he-top-center {
136
98
  flex: 1;
137
99
  margin-left: @spacing-2;
@@ -140,14 +102,54 @@
140
102
  }
141
103
  }
142
104
 
105
+ // desktop stacked header
106
+ .header-stacked {
107
+ display: flex;
108
+ flex-direction: column;
109
+
110
+ .header-desktop {
111
+ height: 44px;
112
+ }
113
+
114
+ .header-stacked-nav {
115
+ height: 36px;
116
+ background-color: @bg-dark;
117
+ border-top: 1px solid @color-neutral-200;
118
+ box-sizing: border-box;
119
+ }
120
+ }
121
+ .header-navigation-wrapper {
122
+ min-width: 0;
123
+ overflow-x: auto;
124
+ overflow-y: hidden;
125
+
126
+ display: flex;
127
+ justify-content: center;
128
+ align-items: center;
129
+
130
+ &.calculating {
131
+ .header-navigation {
132
+ opacity: 0;
133
+ }
134
+ }
135
+
136
+ &.minimized {
137
+ display: flex;
138
+ }
139
+
140
+ .header-navigation {
141
+ display: inline-flex;
142
+ }
143
+ }
144
+
143
145
  // desktop wide
144
146
  @media only screen and (min-width: 1200px) {
145
- .header-desktop {
147
+ .header-desktop:not(.header-desktop-nav) {
146
148
  display: grid;
147
149
  grid-template-columns: repeat(3, 1fr);
148
150
  grid-template-rows: 48px;
149
151
 
150
- .he-top-left,
152
+ .logo,
151
153
  .he-top-center,
152
154
  .he-top-right {
153
155
  grid-column: span 1;
@@ -157,16 +159,124 @@
157
159
  max-width: unset;
158
160
  }
159
161
  }
162
+
163
+ .header-desktop-nav {
164
+ .he-top-center {
165
+ max-width: unset;
166
+ }
167
+ }
160
168
  }
161
169
 
162
- .navigation-link {
163
- // styles specific to extra nav links
164
- color: @color-black;
165
- position: relative;
170
+ //!!!!!!!!!!!!!!! logo styles !!!!!!!!!!!!!!!//
171
+ .logo {
172
+ color: var(--nav-top-text-color);
173
+ height: 100%;
174
+
166
175
  display: flex;
167
176
  align-items: center;
168
- flex-wrap: nowrap;
169
- text-wrap: nowrap;
177
+
178
+ .logo-short-wrapper {
179
+ display: flex;
180
+ align-items: center;
181
+ height: 100%;
182
+ padding-left: 10px;
183
+ padding-right: 10px;
184
+
185
+ svg,
186
+ .logo-link {
187
+ height: 28px;
188
+ }
189
+ }
190
+ svg {
191
+ max-height: 100%;
192
+ width: auto;
193
+ }
194
+ .logo-link {
195
+ color: inherit;
196
+ text-decoration: none;
197
+ outline: none;
198
+
199
+ &:active,
200
+ &:hover {
201
+ color: inherit;
202
+ text-decoration: none;
203
+ }
204
+ }
205
+ }
206
+
207
+ .header-desktop {
208
+ .logo-company-wrapper {
209
+ height: 41px;
210
+ padding-left: 6px;
211
+
212
+ .logo-link {
213
+ height: 41px;
214
+ }
215
+ }
216
+ .logo-postfix {
217
+ margin-left: @spacing-1;
218
+ }
219
+ .logo-title {
220
+ margin-left: @spacing-0;
221
+ }
222
+ }
223
+
224
+ .header-dark.header-logo-custom {
225
+ .logo-short-wrapper,
226
+ .burger {
227
+ background-color: @color-white;
228
+ color: @c-light;
229
+ }
230
+
231
+ .burger .navigation-link {
232
+ color: inherit !important;
233
+ }
234
+ .logo-title {
235
+ margin-left: @spacing-1;
236
+ }
237
+ }
238
+
239
+ //!!!!!!!!!!!!!!! nav links styles !!!!!!!!!!!!!!!//
240
+ .navigation-link {
241
+ &.navigation-item-icon-state.navigation-item-active {
242
+ .navigation-icon[data-anv][data-anv]:not(.navigation-icon-active) {
243
+ display: none;
244
+ }
245
+
246
+ .navigation-icon.navigation-icon-active[data-anv][data-anv] {
247
+ display: block;
248
+ }
249
+ }
250
+
251
+ .navigation-icon[data-anv][data-anv] {
252
+ display: inline-block;
253
+ color: inherit;
254
+
255
+ & > svg {
256
+ height: 1em;
257
+ width: 1em;
258
+ font-size: 1em;
259
+ }
260
+
261
+ &.navigation-icon-active {
262
+ display: none;
263
+ }
264
+ }
265
+ }
266
+
267
+ // extra nav links styles
268
+ .header {
269
+ .navigation-link {
270
+ color: var(--nav-top-text-color);
271
+ position: relative;
272
+ display: flex;
273
+ align-items: center;
274
+ flex-wrap: nowrap;
275
+ text-wrap: nowrap;
276
+
277
+ border-radius: 12px;
278
+ font-size: @size-links-tiny;
279
+ }
170
280
 
171
281
  .navigation-item-counter {
172
282
  color: @color-white;
@@ -177,6 +287,10 @@
177
287
  position: absolute;
178
288
  top: 4px;
179
289
  right: -2px;
290
+
291
+ &.navigation-item-counter-long {
292
+ right: -8px;
293
+ }
180
294
  }
181
295
 
182
296
  .navigation-item-label {
@@ -187,7 +301,147 @@
187
301
  margin-left: @spacing-half;
188
302
  }
189
303
 
190
- &.navigation-item-counter-long {
191
- right: -8px;
304
+ .navigation-icon[data-anv][data-anv] {
305
+ height: 24px;
306
+ width: 24px;
307
+ }
308
+
309
+ &.header-desktop {
310
+ .navigation-link {
311
+ margin: 6px 2px;
312
+ padding: 6px 6px;
313
+
314
+ .navigation-item-counter {
315
+ min-width: 12px !important;
316
+ height: 12px !important;
317
+ }
318
+ }
319
+ }
320
+
321
+ &.header-mobile {
322
+ .navigation-link {
323
+ padding: 10px;
324
+ }
325
+ }
326
+
327
+ &.header-light {
328
+ .navigation-link {
329
+ &.navigation-item-active {
330
+ background-color: @color-blue-100 !important;
331
+ color: @color-blue-500 !important;
332
+ }
333
+
334
+ &:hover:not(.navigation-item-active) {
335
+ background-color: rgba(0, 0, 0, 0.12) !important;
336
+ }
337
+ }
338
+ }
339
+ }
340
+
341
+ .header-dark .navigation-link,
342
+ .header-navigation > .navigation-link {
343
+ &.navigation-item-active {
344
+ color: @color-blue-200 !important;
345
+ }
346
+
347
+ &:hover:not(.navigation-item-active) {
348
+ opacity: 0.7 !important;
349
+ }
350
+ }
351
+
352
+ // styles specific to main nav links
353
+ .header-navigation .navigation-link {
354
+ font-family: @base-font-family;
355
+ color: @c-dark;
356
+ position: relative;
357
+ display: flex;
358
+ align-items: center;
359
+ flex-wrap: nowrap;
360
+ text-wrap: nowrap;
361
+ padding: 7px 10px;
362
+
363
+ .navigation-item-counter {
364
+ color: @color-white;
365
+ font-weight: @font-weight-semibold;
366
+ font-size: 8px !important;
367
+ min-width: 16px !important;
368
+ height: 12px !important;
369
+ position: absolute;
370
+ top: 4px;
371
+ right: -2px;
372
+
373
+ &.navigation-item-counter-long {
374
+ right: -8px;
375
+ }
376
+ }
377
+ .navigation-item-label {
378
+ font-family: @base-font-family;
379
+ font-size: @typescale-2;
380
+ margin-left: @spacing-half;
381
+ }
382
+ .navigation-icon[data-anv][data-anv] {
383
+ height: 20px;
384
+ width: 20px;
385
+ font-size: @typescale-4;
386
+ }
387
+ }
388
+
389
+ .header-navigation-overflow-trigger[data-anv][data-anv] {
390
+ padding: @spacing-half !important;
391
+
392
+ > span[data-anv][data-anv] {
393
+ color: @c-dark !important;
394
+ height: 24px !important;
395
+ width: 24px !important;
396
+ font-size: 24px !important;
397
+
398
+ display: flex !important;
399
+ align-items: center !important;
400
+ justify-content: center !important;
401
+ }
402
+ }
403
+
404
+ .header-navigation-overflow .navigation-link {
405
+ display: inline-flex;
406
+ color: @color-black;
407
+ padding: @spacing-1 12px;
408
+ cursor: pointer;
409
+
410
+ font-family: @base-font-family;
411
+ font-size: @typescale-4;
412
+ position: relative;
413
+ align-items: center;
414
+ flex-wrap: nowrap;
415
+ text-wrap: nowrap;
416
+
417
+ margin-left: -0.5rem;
418
+ margin-right: -0.5rem;
419
+
420
+ &:hover {
421
+ background-color: @color-blue-500;
422
+ color: @color-white;
423
+ }
424
+
425
+ &.navigation-item-active:not(:hover) {
426
+ color: @color-blue;
427
+ }
428
+
429
+ .navigation-item-label {
430
+ font-family: @base-font-family;
431
+ font-size: @typescale-2;
432
+ margin-left: @spacing-half;
433
+ }
434
+ .navigation-item-counter {
435
+ color: @color-white;
436
+ font-weight: @font-weight-semibold;
437
+ font-size: 8px !important;
438
+
439
+ min-width: 12px !important;
440
+ height: 12px !important;
441
+ margin-left: @spacing-half;
442
+ margin-top: -@spacing-1;
443
+ }
444
+ .navigation-icon[data-anv][data-anv] {
445
+ height: 20px;
192
446
  }
193
447
  }
@@ -0,0 +1,35 @@
1
+ export const __esModule: true;
2
+ export const burger: string;
3
+ export const calculating: string;
4
+ export const heTopCenter: string;
5
+ export const heTopRight: string;
6
+ export const heTopRightText: string;
7
+ export const header: string;
8
+ export const headerDark: string;
9
+ export const headerDesktop: string;
10
+ export const headerDesktopNav: string;
11
+ export const headerLight: string;
12
+ export const headerLogoCustom: string;
13
+ export const headerMobile: string;
14
+ export const headerNavigation: string;
15
+ export const headerNavigationOverflow: string;
16
+ export const headerNavigationOverflowTrigger: string;
17
+ export const headerNavigationWrapper: string;
18
+ export const headerStacked: string;
19
+ export const headerStackedNav: string;
20
+ export const logo: string;
21
+ export const logoCompanyWrapper: string;
22
+ export const logoLink: string;
23
+ export const logoPostfix: string;
24
+ export const logoShortWrapper: string;
25
+ export const logoTitle: string;
26
+ export const minimized: string;
27
+ export const navigationIcon: string;
28
+ export const navigationIconActive: string;
29
+ export const navigationItemActive: string;
30
+ export const navigationItemCounter: string;
31
+ export const navigationItemCounterLong: string;
32
+ export const navigationItemIconState: string;
33
+ export const navigationItemLabel: string;
34
+ export const navigationLink: string;
35
+
@@ -1,12 +1,14 @@
1
1
  import { FC, ReactNode } from 'react';
2
2
  import { WrapperProps } from '../logo/logo-titan-text';
3
3
  export interface TitanLayoutLogoProps {
4
- /** container class name */
5
- className?: string;
6
4
  title?: string | boolean;
7
5
  postfix?: ReactNode;
8
6
  logoWrapper?: WrapperProps;
9
7
  mantleFill?: string;
8
+ to?: string;
10
9
  }
11
- export declare const TitanLayoutLogo: FC<TitanLayoutLogoProps>;
10
+ export declare const isLogoCompany: (props: TitanLayoutLogoProps | undefined, isMobile: boolean) => boolean;
11
+ export declare const isLogoCustom: (props: TitanLayoutLogoProps | undefined, isMobile: boolean) => boolean;
12
+ export declare const isLogoText: (props: TitanLayoutLogoProps | undefined, isMobile: boolean) => boolean;
13
+ export declare const LayoutLogo: FC<TitanLayoutLogoProps>;
12
14
  //# sourceMappingURL=layout-logo.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"layout-logo.d.ts","sourceRoot":"","sources":["../../../src/components/titan-layout/layout-logo.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,EAAE,EAAY,SAAS,EAAE,MAAM,OAAO,CAAC;AAEhD,OAAO,EAA6B,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAGlF,MAAM,WAAW,oBAAoB;IACjC,2BAA2B;IAC3B,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,KAAK,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IAEzB,OAAO,CAAC,EAAE,SAAS,CAAC;IAEpB,WAAW,CAAC,EAAE,YAAY,CAAC;IAE3B,UAAU,CAAC,EAAE,MAAM,CAAC;CACvB;AAID,eAAO,MAAM,eAAe,EAAE,EAAE,CAAC,oBAAoB,CA0CpD,CAAC"}
1
+ {"version":3,"file":"layout-logo.d.ts","sourceRoot":"","sources":["../../../src/components/titan-layout/layout-logo.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,EAAE,EAAY,SAAS,EAAE,MAAM,OAAO,CAAC;AAGhD,OAAO,EAAkB,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAIvE,MAAM,WAAW,oBAAoB;IACjC,KAAK,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IACzB,OAAO,CAAC,EAAE,SAAS,CAAC;IACpB,WAAW,CAAC,EAAE,YAAY,CAAC;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,EAAE,CAAC,EAAE,MAAM,CAAC;CACf;AAID,eAAO,MAAM,aAAa,GAAI,OAAO,oBAAoB,GAAG,SAAS,EAAE,UAAU,OAAO,YAClD,CAAC;AACvC,eAAO,MAAM,YAAY,GAAI,OAAO,oBAAoB,GAAG,SAAS,EAAE,UAAU,OAAO,YAC7B,CAAC;AAC3D,eAAO,MAAM,UAAU,GAAI,OAAO,oBAAoB,GAAG,SAAS,EAAE,UAAU,OAAO,YACpC,CAAC;AAElD,eAAO,MAAM,UAAU,EAAE,EAAE,CAAC,oBAAoB,CAmC/C,CAAC"}
@@ -2,15 +2,53 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import classNames from 'classnames';
3
3
  import { Fragment } from 'react';
4
4
  import { LogoCompanyTitle } from '../logo/logo-company-title';
5
- import { LogoTitan, LogoTitanTitle } from '../logo/logo-titan-text';
5
+ import { LogoTitanSvg } from '../logo/logo-titan';
6
+ import { LogoTitanTitle } from '../logo/logo-titan-text';
6
7
  import { useTitanLayoutContext } from './layout-context';
7
- const EmptyWrapper = ({ children }) => children;
8
- export const TitanLayoutLogo = ({ className, mantleFill, postfix, title, logoWrapper = EmptyWrapper, }) => {
9
- const { breakpoint: { isMobile }, } = useTitanLayoutContext();
10
- const Wrapper = logoWrapper;
11
- const logoSize = isMobile ? 44 : 56;
12
- const logoCompanySize = 48;
13
- const showCompanyTitle = title === true && !isMobile;
14
- return (_jsxs("div", { className: classNames('d-f align-items-center', { 'p-t-half': showCompanyTitle }, className), children: [showCompanyTitle ? (_jsx(Wrapper, { children: _jsx(LogoCompanyTitle, { height: logoCompanySize }) })) : typeof title === 'string' ? (_jsxs(Fragment, { children: [_jsx(LogoTitan, { size: logoSize, mantleFill: mantleFill, logoWrapper: Wrapper }), !isMobile && (_jsx(LogoTitanTitle, { className: "c-inherit m-l-1", children: title }))] })) : (_jsx(LogoTitan, { size: logoSize, mantleFill: mantleFill, logoWrapper: Wrapper })), !isMobile && postfix] }));
8
+ import * as Styles from './layout-header.module.less';
9
+ const EmptyWrapper = ({ children })=>children;
10
+ export const isLogoCompany = (props, isMobile)=>(props === null || props === void 0 ? void 0 : props.title) === true && !isMobile;
11
+ export const isLogoCustom = (props, isMobile)=>!isLogoCompany(props, isMobile) && !!(props === null || props === void 0 ? void 0 : props.mantleFill);
12
+ export const isLogoText = (props, isMobile)=>typeof (props === null || props === void 0 ? void 0 : props.title) === 'string' && !isMobile;
13
+ export const LayoutLogo = (props)=>{
14
+ const { NavigationComponent, breakpoint: { isMobile } } = useTitanLayoutContext();
15
+ const Wrapper = props.to ? NavigationComponent : EmptyWrapper;
16
+ const showCompanyTitle = isLogoCompany(props, isMobile);
17
+ return /*#__PURE__*/ _jsxs("div", {
18
+ className: classNames(Styles.logo),
19
+ "data-cy": "navigation-left",
20
+ children: [
21
+ showCompanyTitle ? /*#__PURE__*/ _jsx("div", {
22
+ className: Styles.logoCompanyWrapper,
23
+ children: /*#__PURE__*/ _jsx(Wrapper, {
24
+ to: props.to,
25
+ className: Styles.logoLink,
26
+ children: /*#__PURE__*/ _jsx(LogoCompanyTitle, {})
27
+ })
28
+ }) : /*#__PURE__*/ _jsxs(Fragment, {
29
+ children: [
30
+ /*#__PURE__*/ _jsx("div", {
31
+ className: Styles.logoShortWrapper,
32
+ children: /*#__PURE__*/ _jsx(Wrapper, {
33
+ to: props.to,
34
+ className: Styles.logoLink,
35
+ children: /*#__PURE__*/ _jsx(LogoTitanSvg, {
36
+ mantleFill: props.mantleFill
37
+ })
38
+ })
39
+ }),
40
+ isLogoText(props, isMobile) && /*#__PURE__*/ _jsx(LogoTitanTitle, {
41
+ className: Styles.logoTitle,
42
+ children: props.title
43
+ })
44
+ ]
45
+ }),
46
+ !isMobile && props.postfix && /*#__PURE__*/ _jsx("div", {
47
+ className: Styles.logoPostfix,
48
+ children: props.postfix
49
+ })
50
+ ]
51
+ });
15
52
  };
53
+
16
54
  //# sourceMappingURL=layout-logo.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"layout-logo.js","sourceRoot":"","sources":["../../../src/components/titan-layout/layout-logo.tsx"],"names":[],"mappings":";AAAA,OAAO,UAAU,MAAM,YAAY,CAAC;AACpC,OAAO,EAAM,QAAQ,EAAa,MAAM,OAAO,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,SAAS,EAAE,cAAc,EAAgB,MAAM,yBAAyB,CAAC;AAClF,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAezD,MAAM,YAAY,GAAY,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,QAAQ,CAAC;AAEzD,MAAM,CAAC,MAAM,eAAe,GAA6B,CAAC,EACtD,SAAS,EACT,UAAU,EACV,OAAO,EACP,KAAK,EACL,WAAW,GAAG,YAAY,GAC7B,EAAE,EAAE;IACD,MAAM,EACF,UAAU,EAAE,EAAE,QAAQ,EAAE,GAC3B,GAAG,qBAAqB,EAAE,CAAC;IAE5B,MAAM,OAAO,GAAG,WAAW,CAAC;IAC5B,MAAM,QAAQ,GAAG,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IACpC,MAAM,eAAe,GAAG,EAAE,CAAC;IAC3B,MAAM,gBAAgB,GAAG,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC;IAErD,OAAO,CACH,eACI,SAAS,EAAE,UAAU,CACjB,wBAAwB,EACxB,EAAE,UAAU,EAAE,gBAAgB,EAAE,EAChC,SAAS,CACZ,aAEA,gBAAgB,CAAC,CAAC,CAAC,CAChB,KAAC,OAAO,cACJ,KAAC,gBAAgB,IAAC,MAAM,EAAE,eAAe,GAAI,GACvC,CACb,CAAC,CAAC,CAAC,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,CAC5B,MAAC,QAAQ,eACL,KAAC,SAAS,IAAC,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,OAAO,GAAI,EAC1E,CAAC,QAAQ,IAAI,CACV,KAAC,cAAc,IAAC,SAAS,EAAC,iBAAiB,YAAE,KAAK,GAAkB,CACvE,IACM,CACd,CAAC,CAAC,CAAC,CACA,KAAC,SAAS,IAAC,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,WAAW,EAAE,OAAO,GAAI,CAC9E,EAEA,CAAC,QAAQ,IAAI,OAAO,IACnB,CACT,CAAC;AACN,CAAC,CAAC"}
1
+ {"version":3,"sources":["../../../src/components/titan-layout/layout-logo.tsx"],"sourcesContent":["import classNames from 'classnames';\nimport { FC, Fragment, ReactNode } from 'react';\nimport { LogoCompanyTitle } from '../logo/logo-company-title';\nimport { LogoTitanSvg } from '../logo/logo-titan';\nimport { LogoTitanTitle, WrapperProps } from '../logo/logo-titan-text';\nimport { useTitanLayoutContext } from './layout-context';\nimport * as Styles from './layout-header.module.less';\n\nexport interface TitanLayoutLogoProps {\n title?: string | boolean;\n postfix?: ReactNode;\n logoWrapper?: WrapperProps;\n mantleFill?: string;\n to?: string;\n}\n\nconst EmptyWrapper: FC<any> = ({ children }) => children;\n\nexport const isLogoCompany = (props: TitanLayoutLogoProps | undefined, isMobile: boolean) =>\n props?.title === true && !isMobile;\nexport const isLogoCustom = (props: TitanLayoutLogoProps | undefined, isMobile: boolean) =>\n !isLogoCompany(props, isMobile) && !!props?.mantleFill;\nexport const isLogoText = (props: TitanLayoutLogoProps | undefined, isMobile: boolean) =>\n typeof props?.title === 'string' && !isMobile;\n\nexport const LayoutLogo: FC<TitanLayoutLogoProps> = props => {\n const {\n NavigationComponent,\n breakpoint: { isMobile },\n } = useTitanLayoutContext();\n const Wrapper: FC<any> = props.to ? NavigationComponent : EmptyWrapper;\n const showCompanyTitle = isLogoCompany(props, isMobile);\n\n return (\n <div className={classNames(Styles.logo)} data-cy=\"navigation-left\">\n {showCompanyTitle ? (\n <div className={Styles.logoCompanyWrapper}>\n <Wrapper to={props.to} className={Styles.logoLink}>\n <LogoCompanyTitle />\n </Wrapper>\n </div>\n ) : (\n <Fragment>\n <div className={Styles.logoShortWrapper}>\n <Wrapper to={props.to} className={Styles.logoLink}>\n <LogoTitanSvg mantleFill={props.mantleFill} />\n </Wrapper>\n </div>\n\n {isLogoText(props, isMobile) && (\n <LogoTitanTitle className={Styles.logoTitle}>{props.title}</LogoTitanTitle>\n )}\n </Fragment>\n )}\n\n {!isMobile && props.postfix && (\n <div className={Styles.logoPostfix}>{props.postfix}</div>\n )}\n </div>\n );\n};\n"],"names":["classNames","Fragment","LogoCompanyTitle","LogoTitanSvg","LogoTitanTitle","useTitanLayoutContext","Styles","EmptyWrapper","children","isLogoCompany","props","isMobile","title","isLogoCustom","mantleFill","isLogoText","LayoutLogo","NavigationComponent","breakpoint","Wrapper","to","showCompanyTitle","div","className","logo","data-cy","logoCompanyWrapper","logoLink","logoShortWrapper","logoTitle","postfix","logoPostfix"],"mappings":";AAAA,OAAOA,gBAAgB,aAAa;AACpC,SAAaC,QAAQ,QAAmB,QAAQ;AAChD,SAASC,gBAAgB,QAAQ,6BAA6B;AAC9D,SAASC,YAAY,QAAQ,qBAAqB;AAClD,SAASC,cAAc,QAAsB,0BAA0B;AACvE,SAASC,qBAAqB,QAAQ,mBAAmB;AACzD,YAAYC,YAAY,8BAA8B;AAUtD,MAAMC,eAAwB,CAAC,EAAEC,QAAQ,EAAE,GAAKA;AAEhD,OAAO,MAAMC,gBAAgB,CAACC,OAAyCC,WACnED,CAAAA,kBAAAA,4BAAAA,MAAOE,KAAK,MAAK,QAAQ,CAACD,SAAS;AACvC,OAAO,MAAME,eAAe,CAACH,OAAyCC,WAClE,CAACF,cAAcC,OAAOC,aAAa,CAAC,EAACD,kBAAAA,4BAAAA,MAAOI,UAAU,EAAC;AAC3D,OAAO,MAAMC,aAAa,CAACL,OAAyCC,WAChE,QAAOD,kBAAAA,4BAAAA,MAAOE,KAAK,MAAK,YAAY,CAACD,SAAS;AAElD,OAAO,MAAMK,aAAuCN,CAAAA;IAChD,MAAM,EACFO,mBAAmB,EACnBC,YAAY,EAAEP,QAAQ,EAAE,EAC3B,GAAGN;IACJ,MAAMc,UAAmBT,MAAMU,EAAE,GAAGH,sBAAsBV;IAC1D,MAAMc,mBAAmBZ,cAAcC,OAAOC;IAE9C,qBACI,MAACW;QAAIC,WAAWvB,WAAWM,OAAOkB,IAAI;QAAGC,WAAQ;;YAC5CJ,iCACG,KAACC;gBAAIC,WAAWjB,OAAOoB,kBAAkB;0BACrC,cAAA,KAACP;oBAAQC,IAAIV,MAAMU,EAAE;oBAAEG,WAAWjB,OAAOqB,QAAQ;8BAC7C,cAAA,KAACzB;;+BAIT,MAACD;;kCACG,KAACqB;wBAAIC,WAAWjB,OAAOsB,gBAAgB;kCACnC,cAAA,KAACT;4BAAQC,IAAIV,MAAMU,EAAE;4BAAEG,WAAWjB,OAAOqB,QAAQ;sCAC7C,cAAA,KAACxB;gCAAaW,YAAYJ,MAAMI,UAAU;;;;oBAIjDC,WAAWL,OAAOC,2BACf,KAACP;wBAAemB,WAAWjB,OAAOuB,SAAS;kCAAGnB,MAAME,KAAK;;;;YAKpE,CAACD,YAAYD,MAAMoB,OAAO,kBACvB,KAACR;gBAAIC,WAAWjB,OAAOyB,WAAW;0BAAGrB,MAAMoB,OAAO;;;;AAIlE,EAAE"}
@@ -6,8 +6,19 @@ declare const _default: {
6
6
  parameters: {};
7
7
  };
8
8
  export default _default;
9
- export declare const LogoDefault: () => import("react/jsx-runtime").JSX.Element;
10
- export declare const LogoCompanyTitle: () => import("react/jsx-runtime").JSX.Element;
11
- export declare const LogoCommercial: () => import("react/jsx-runtime").JSX.Element;
12
- export declare const LogoWithPostfix: () => import("react/jsx-runtime").JSX.Element;
9
+ export declare const LogoTinyDefault: () => import("react/jsx-runtime").JSX.Element;
10
+ export declare const LogoTinyCompanyTitle: () => import("react/jsx-runtime").JSX.Element;
11
+ export declare const LogoTinyCommercial: () => import("react/jsx-runtime").JSX.Element;
12
+ export declare const LogoTinyWithPostfix: () => import("react/jsx-runtime").JSX.Element;
13
+ export declare const LogoTinyCommercialWithPostfix: () => import("react/jsx-runtime").JSX.Element;
14
+ export declare const LogoStackedDefault: () => import("react/jsx-runtime").JSX.Element;
15
+ export declare const LogoStackedCompanyTitle: () => import("react/jsx-runtime").JSX.Element;
16
+ export declare const LogoStackedCommercial: () => import("react/jsx-runtime").JSX.Element;
17
+ export declare const LogoStackedWithPostfix: () => import("react/jsx-runtime").JSX.Element;
18
+ export declare const LogoStackedCommercialWithPostfix: () => import("react/jsx-runtime").JSX.Element;
19
+ export declare const LogoDarkDefault: () => import("react/jsx-runtime").JSX.Element;
20
+ export declare const LogoDarkCompanyTitle: () => import("react/jsx-runtime").JSX.Element;
21
+ export declare const LogoDarkCommercial: () => import("react/jsx-runtime").JSX.Element;
22
+ export declare const LogoDarkWithPostfix: () => import("react/jsx-runtime").JSX.Element;
23
+ export declare const LogoDarkCommercialWithPostfix: () => import("react/jsx-runtime").JSX.Element;
13
24
  //# sourceMappingURL=layout-logo.stories.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"layout-logo.stories.d.ts","sourceRoot":"","sources":["../../../src/components/titan-layout/layout-logo.stories.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAmB,oBAAoB,EAAE,MAAM,eAAe,CAAC;;;;;;;AAUtE,wBAKE;AAEF,eAAO,MAAM,WAAW,+CAAuC,CAAC;AAEhE,eAAO,MAAM,gBAAgB,+CAA6C,CAAC;AAE3E,eAAO,MAAM,cAAc,+CAE1B,CAAC;AAEF,eAAO,MAAM,eAAe,+CAE3B,CAAC"}
1
+ {"version":3,"file":"layout-logo.stories.d.ts","sourceRoot":"","sources":["../../../src/components/titan-layout/layout-logo.stories.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAc,oBAAoB,EAAE,MAAM,eAAe,CAAC;;;;;;;AAOjE,wBAKE;AAEF,eAAO,MAAM,eAAe,+CAAsB,CAAC;AAEnD,eAAO,MAAM,oBAAoB,+CAAmC,CAAC;AAErE,eAAO,MAAM,kBAAkB,+CAAkE,CAAC;AAElG,eAAO,MAAM,mBAAmB,+CAG9B,CAAC;AAEH,eAAO,MAAM,6BAA6B,+CAIxC,CAAC;AAEH,eAAO,MAAM,kBAAkB,+CAM9B,CAAC;AACF,eAAO,MAAM,uBAAuB,+CAMnC,CAAC;AAEF,eAAO,MAAM,qBAAqB,+CAMjC,CAAC;AAEF,eAAO,MAAM,sBAAsB,+CASlC,CAAC;AAEF,eAAO,MAAM,gCAAgC,+CAU5C,CAAC;AAEF,eAAO,MAAM,eAAe,+CAK3B,CAAC;AACF,eAAO,MAAM,oBAAoB,+CAKhC,CAAC;AAEF,eAAO,MAAM,kBAAkB,+CAK9B,CAAC;AAEF,eAAO,MAAM,mBAAmB,+CAQ/B,CAAC;AAEF,eAAO,MAAM,6BAA6B,+CASzC,CAAC"}