@tanstack/router-devtools-core 1.132.47 → 1.132.51

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 (79) hide show
  1. package/dist/BaseTanStackRouterDevtoolsPanel-CaAQWNvS.js +1817 -0
  2. package/dist/BaseTanStackRouterDevtoolsPanel-CaAQWNvS.js.map +1 -0
  3. package/dist/BaseTanStackRouterDevtoolsPanel-CbH9Ihs_.cjs +1833 -0
  4. package/dist/BaseTanStackRouterDevtoolsPanel-CbH9Ihs_.cjs.map +1 -0
  5. package/dist/FloatingTanStackRouterDevtools-0xtXUOcx.cjs +283 -0
  6. package/dist/FloatingTanStackRouterDevtools-0xtXUOcx.cjs.map +1 -0
  7. package/dist/FloatingTanStackRouterDevtools-DdHNTjWg.js +283 -0
  8. package/dist/FloatingTanStackRouterDevtools-DdHNTjWg.js.map +1 -0
  9. package/dist/cjs/index.cjs +6 -0
  10. package/dist/cjs/{packages/router-devtools-core/src/index.cjs.map → index.cjs.map} +1 -1
  11. package/dist/esm/index.js +6 -0
  12. package/dist/esm/{packages/router-devtools-core/src/index.js.map → index.js.map} +1 -1
  13. package/dist/index-BiZF0hsR.js +222 -0
  14. package/dist/index-BiZF0hsR.js.map +1 -0
  15. package/dist/index-CHaaetqh.cjs +221 -0
  16. package/dist/index-CHaaetqh.cjs.map +1 -0
  17. package/package.json +6 -5
  18. package/dist/cjs/node_modules/.pnpm/solid-js@1.9.5/node_modules/solid-js/dist/solid.cjs +0 -792
  19. package/dist/cjs/node_modules/.pnpm/solid-js@1.9.5/node_modules/solid-js/dist/solid.cjs.map +0 -1
  20. package/dist/cjs/node_modules/.pnpm/solid-js@1.9.5/node_modules/solid-js/web/dist/web.cjs +0 -675
  21. package/dist/cjs/node_modules/.pnpm/solid-js@1.9.5/node_modules/solid-js/web/dist/web.cjs.map +0 -1
  22. package/dist/cjs/packages/router-devtools-core/src/AgeTicker.cjs +0 -48
  23. package/dist/cjs/packages/router-devtools-core/src/AgeTicker.cjs.map +0 -1
  24. package/dist/cjs/packages/router-devtools-core/src/BaseTanStackRouterDevtoolsPanel.cjs +0 -604
  25. package/dist/cjs/packages/router-devtools-core/src/BaseTanStackRouterDevtoolsPanel.cjs.map +0 -1
  26. package/dist/cjs/packages/router-devtools-core/src/Explorer.cjs +0 -307
  27. package/dist/cjs/packages/router-devtools-core/src/Explorer.cjs.map +0 -1
  28. package/dist/cjs/packages/router-devtools-core/src/FloatingTanStackRouterDevtools.cjs +0 -201
  29. package/dist/cjs/packages/router-devtools-core/src/FloatingTanStackRouterDevtools.cjs.map +0 -1
  30. package/dist/cjs/packages/router-devtools-core/src/NavigateButton.cjs +0 -31
  31. package/dist/cjs/packages/router-devtools-core/src/NavigateButton.cjs.map +0 -1
  32. package/dist/cjs/packages/router-devtools-core/src/TanStackRouterDevtoolsCore.cjs +0 -100
  33. package/dist/cjs/packages/router-devtools-core/src/TanStackRouterDevtoolsCore.cjs.map +0 -1
  34. package/dist/cjs/packages/router-devtools-core/src/TanStackRouterDevtoolsPanelCore.cjs +0 -113
  35. package/dist/cjs/packages/router-devtools-core/src/TanStackRouterDevtoolsPanelCore.cjs.map +0 -1
  36. package/dist/cjs/packages/router-devtools-core/src/context.cjs +0 -20
  37. package/dist/cjs/packages/router-devtools-core/src/context.cjs.map +0 -1
  38. package/dist/cjs/packages/router-devtools-core/src/index.cjs +0 -7
  39. package/dist/cjs/packages/router-devtools-core/src/logo.cjs +0 -92
  40. package/dist/cjs/packages/router-devtools-core/src/logo.cjs.map +0 -1
  41. package/dist/cjs/packages/router-devtools-core/src/tokens.cjs +0 -201
  42. package/dist/cjs/packages/router-devtools-core/src/tokens.cjs.map +0 -1
  43. package/dist/cjs/packages/router-devtools-core/src/useLocalStorage.cjs +0 -42
  44. package/dist/cjs/packages/router-devtools-core/src/useLocalStorage.cjs.map +0 -1
  45. package/dist/cjs/packages/router-devtools-core/src/useStyles.cjs +0 -607
  46. package/dist/cjs/packages/router-devtools-core/src/useStyles.cjs.map +0 -1
  47. package/dist/cjs/packages/router-devtools-core/src/utils.cjs +0 -62
  48. package/dist/cjs/packages/router-devtools-core/src/utils.cjs.map +0 -1
  49. package/dist/esm/node_modules/.pnpm/solid-js@1.9.5/node_modules/solid-js/dist/solid.js +0 -792
  50. package/dist/esm/node_modules/.pnpm/solid-js@1.9.5/node_modules/solid-js/dist/solid.js.map +0 -1
  51. package/dist/esm/node_modules/.pnpm/solid-js@1.9.5/node_modules/solid-js/web/dist/web.js +0 -676
  52. package/dist/esm/node_modules/.pnpm/solid-js@1.9.5/node_modules/solid-js/web/dist/web.js.map +0 -1
  53. package/dist/esm/packages/router-devtools-core/src/AgeTicker.js +0 -48
  54. package/dist/esm/packages/router-devtools-core/src/AgeTicker.js.map +0 -1
  55. package/dist/esm/packages/router-devtools-core/src/BaseTanStackRouterDevtoolsPanel.js +0 -604
  56. package/dist/esm/packages/router-devtools-core/src/BaseTanStackRouterDevtoolsPanel.js.map +0 -1
  57. package/dist/esm/packages/router-devtools-core/src/Explorer.js +0 -290
  58. package/dist/esm/packages/router-devtools-core/src/Explorer.js.map +0 -1
  59. package/dist/esm/packages/router-devtools-core/src/FloatingTanStackRouterDevtools.js +0 -201
  60. package/dist/esm/packages/router-devtools-core/src/FloatingTanStackRouterDevtools.js.map +0 -1
  61. package/dist/esm/packages/router-devtools-core/src/NavigateButton.js +0 -31
  62. package/dist/esm/packages/router-devtools-core/src/NavigateButton.js.map +0 -1
  63. package/dist/esm/packages/router-devtools-core/src/TanStackRouterDevtoolsCore.js +0 -100
  64. package/dist/esm/packages/router-devtools-core/src/TanStackRouterDevtoolsCore.js.map +0 -1
  65. package/dist/esm/packages/router-devtools-core/src/TanStackRouterDevtoolsPanelCore.js +0 -113
  66. package/dist/esm/packages/router-devtools-core/src/TanStackRouterDevtoolsPanelCore.js.map +0 -1
  67. package/dist/esm/packages/router-devtools-core/src/context.js +0 -20
  68. package/dist/esm/packages/router-devtools-core/src/context.js.map +0 -1
  69. package/dist/esm/packages/router-devtools-core/src/index.js +0 -7
  70. package/dist/esm/packages/router-devtools-core/src/logo.js +0 -92
  71. package/dist/esm/packages/router-devtools-core/src/logo.js.map +0 -1
  72. package/dist/esm/packages/router-devtools-core/src/tokens.js +0 -201
  73. package/dist/esm/packages/router-devtools-core/src/tokens.js.map +0 -1
  74. package/dist/esm/packages/router-devtools-core/src/useLocalStorage.js +0 -43
  75. package/dist/esm/packages/router-devtools-core/src/useLocalStorage.js.map +0 -1
  76. package/dist/esm/packages/router-devtools-core/src/useStyles.js +0 -590
  77. package/dist/esm/packages/router-devtools-core/src/useStyles.js.map +0 -1
  78. package/dist/esm/packages/router-devtools-core/src/utils.js +0 -62
  79. package/dist/esm/packages/router-devtools-core/src/utils.js.map +0 -1
@@ -1,590 +0,0 @@
1
- import * as goober from "goober";
2
- import { useContext, createSignal } from "../../../node_modules/.pnpm/solid-js@1.9.5/node_modules/solid-js/dist/solid.js";
3
- import { tokens } from "./tokens.js";
4
- import { ShadowDomTargetContext } from "./context.js";
5
- const stylesFactory = (shadowDOMTarget) => {
6
- const {
7
- colors,
8
- font,
9
- size,
10
- alpha,
11
- border
12
- } = tokens;
13
- const {
14
- fontFamily,
15
- lineHeight,
16
- size: fontSize
17
- } = font;
18
- const css = shadowDOMTarget ? goober.css.bind({
19
- target: shadowDOMTarget
20
- }) : goober.css;
21
- return {
22
- devtoolsPanelContainer: css`
23
- direction: ltr;
24
- position: fixed;
25
- bottom: 0;
26
- right: 0;
27
- z-index: 99999;
28
- width: 100%;
29
- max-height: 90%;
30
- border-top: 1px solid ${colors.gray[700]};
31
- transform-origin: top;
32
- `,
33
- devtoolsPanelContainerVisibility: (isOpen) => {
34
- return css`
35
- visibility: ${isOpen ? "visible" : "hidden"};
36
- `;
37
- },
38
- devtoolsPanelContainerResizing: (isResizing) => {
39
- if (isResizing()) {
40
- return css`
41
- transition: none;
42
- `;
43
- }
44
- return css`
45
- transition: all 0.4s ease;
46
- `;
47
- },
48
- devtoolsPanelContainerAnimation: (isOpen, height) => {
49
- if (isOpen) {
50
- return css`
51
- pointer-events: auto;
52
- transform: translateY(0);
53
- `;
54
- }
55
- return css`
56
- pointer-events: none;
57
- transform: translateY(${height}px);
58
- `;
59
- },
60
- logo: css`
61
- cursor: pointer;
62
- display: flex;
63
- flex-direction: column;
64
- background-color: transparent;
65
- border: none;
66
- font-family: ${fontFamily.sans};
67
- gap: ${tokens.size[0.5]};
68
- padding: 0px;
69
- &:hover {
70
- opacity: 0.7;
71
- }
72
- &:focus-visible {
73
- outline-offset: 4px;
74
- border-radius: ${border.radius.xs};
75
- outline: 2px solid ${colors.blue[800]};
76
- }
77
- `,
78
- tanstackLogo: css`
79
- font-size: ${font.size.md};
80
- font-weight: ${font.weight.bold};
81
- line-height: ${font.lineHeight.xs};
82
- white-space: nowrap;
83
- color: ${colors.gray[300]};
84
- `,
85
- routerLogo: css`
86
- font-weight: ${font.weight.semibold};
87
- font-size: ${font.size.xs};
88
- background: linear-gradient(to right, #84cc16, #10b981);
89
- background-clip: text;
90
- -webkit-background-clip: text;
91
- line-height: 1;
92
- -webkit-text-fill-color: transparent;
93
- white-space: nowrap;
94
- `,
95
- devtoolsPanel: css`
96
- display: flex;
97
- font-size: ${fontSize.sm};
98
- font-family: ${fontFamily.sans};
99
- background-color: ${colors.darkGray[700]};
100
- color: ${colors.gray[300]};
101
-
102
- @media (max-width: 700px) {
103
- flex-direction: column;
104
- }
105
- @media (max-width: 600px) {
106
- font-size: ${fontSize.xs};
107
- }
108
- `,
109
- dragHandle: css`
110
- position: absolute;
111
- left: 0;
112
- top: 0;
113
- width: 100%;
114
- height: 4px;
115
- cursor: row-resize;
116
- z-index: 100000;
117
- &:hover {
118
- background-color: ${colors.purple[400]}${alpha[90]};
119
- }
120
- `,
121
- firstContainer: css`
122
- flex: 1 1 500px;
123
- min-height: 40%;
124
- max-height: 100%;
125
- overflow: auto;
126
- border-right: 1px solid ${colors.gray[700]};
127
- display: flex;
128
- flex-direction: column;
129
- `,
130
- routerExplorerContainer: css`
131
- overflow-y: auto;
132
- flex: 1;
133
- `,
134
- routerExplorer: css`
135
- padding: ${tokens.size[2]};
136
- `,
137
- row: css`
138
- display: flex;
139
- align-items: center;
140
- padding: ${tokens.size[2]} ${tokens.size[2.5]};
141
- gap: ${tokens.size[2.5]};
142
- border-bottom: ${colors.darkGray[500]} 1px solid;
143
- align-items: center;
144
- `,
145
- detailsHeader: css`
146
- font-family: ui-sans-serif, Inter, system-ui, sans-serif, sans-serif;
147
- position: sticky;
148
- top: 0;
149
- z-index: 2;
150
- background-color: ${colors.darkGray[600]};
151
- padding: 0px ${tokens.size[2]};
152
- font-weight: ${font.weight.medium};
153
- font-size: ${font.size.xs};
154
- min-height: ${tokens.size[8]};
155
- line-height: ${font.lineHeight.xs};
156
- text-align: left;
157
- display: flex;
158
- align-items: center;
159
- `,
160
- maskedBadge: css`
161
- background: ${colors.yellow[900]}${alpha[70]};
162
- color: ${colors.yellow[300]};
163
- display: inline-block;
164
- padding: ${tokens.size[0]} ${tokens.size[2.5]};
165
- border-radius: ${border.radius.full};
166
- font-size: ${font.size.xs};
167
- font-weight: ${font.weight.normal};
168
- border: 1px solid ${colors.yellow[300]};
169
- `,
170
- maskedLocation: css`
171
- color: ${colors.yellow[300]};
172
- `,
173
- detailsContent: css`
174
- padding: ${tokens.size[1.5]} ${tokens.size[2]};
175
- display: flex;
176
- align-items: center;
177
- justify-content: space-between;
178
- font-size: ${font.size.xs};
179
- `,
180
- routeMatchesToggle: css`
181
- display: flex;
182
- align-items: center;
183
- border: 1px solid ${colors.gray[500]};
184
- border-radius: ${border.radius.sm};
185
- overflow: hidden;
186
- `,
187
- routeMatchesToggleBtn: (active, showBorder) => {
188
- const base = css`
189
- appearance: none;
190
- border: none;
191
- font-size: 12px;
192
- padding: 4px 8px;
193
- background: transparent;
194
- cursor: pointer;
195
- font-family: ${fontFamily.sans};
196
- font-weight: ${font.weight.medium};
197
- `;
198
- const classes = [base];
199
- if (active) {
200
- const activeStyles = css`
201
- background: ${colors.darkGray[400]};
202
- color: ${colors.gray[300]};
203
- `;
204
- classes.push(activeStyles);
205
- } else {
206
- const inactiveStyles = css`
207
- color: ${colors.gray[500]};
208
- background: ${colors.darkGray[800]}${alpha[20]};
209
- `;
210
- classes.push(inactiveStyles);
211
- }
212
- if (showBorder) {
213
- classes.push(css`
214
- border-right: 1px solid ${tokens.colors.gray[500]};
215
- `);
216
- }
217
- return classes;
218
- },
219
- detailsHeaderInfo: css`
220
- flex: 1;
221
- justify-content: flex-end;
222
- display: flex;
223
- align-items: center;
224
- font-weight: ${font.weight.normal};
225
- color: ${colors.gray[400]};
226
- `,
227
- matchRow: (active) => {
228
- const base = css`
229
- display: flex;
230
- border-bottom: 1px solid ${colors.darkGray[400]};
231
- cursor: pointer;
232
- align-items: center;
233
- padding: ${size[1]} ${size[2]};
234
- gap: ${size[2]};
235
- font-size: ${fontSize.xs};
236
- color: ${colors.gray[300]};
237
- `;
238
- const classes = [base];
239
- if (active) {
240
- const activeStyles = css`
241
- background: ${colors.darkGray[500]};
242
- `;
243
- classes.push(activeStyles);
244
- }
245
- return classes;
246
- },
247
- matchIndicator: (color) => {
248
- const base = css`
249
- flex: 0 0 auto;
250
- width: ${size[3]};
251
- height: ${size[3]};
252
- background: ${colors[color][900]};
253
- border: 1px solid ${colors[color][500]};
254
- border-radius: ${border.radius.full};
255
- transition: all 0.25s ease-out;
256
- box-sizing: border-box;
257
- `;
258
- const classes = [base];
259
- if (color === "gray") {
260
- const grayStyles = css`
261
- background: ${colors.gray[700]};
262
- border-color: ${colors.gray[400]};
263
- `;
264
- classes.push(grayStyles);
265
- }
266
- return classes;
267
- },
268
- matchID: css`
269
- flex: 1;
270
- line-height: ${lineHeight["xs"]};
271
- `,
272
- ageTicker: (showWarning) => {
273
- const base = css`
274
- display: flex;
275
- gap: ${size[1]};
276
- font-size: ${fontSize.xs};
277
- color: ${colors.gray[400]};
278
- font-variant-numeric: tabular-nums;
279
- line-height: ${lineHeight["xs"]};
280
- `;
281
- const classes = [base];
282
- if (showWarning) {
283
- const warningStyles = css`
284
- color: ${colors.yellow[400]};
285
- `;
286
- classes.push(warningStyles);
287
- }
288
- return classes;
289
- },
290
- secondContainer: css`
291
- flex: 1 1 500px;
292
- min-height: 40%;
293
- max-height: 100%;
294
- overflow: auto;
295
- border-right: 1px solid ${colors.gray[700]};
296
- display: flex;
297
- flex-direction: column;
298
- `,
299
- thirdContainer: css`
300
- flex: 1 1 500px;
301
- overflow: auto;
302
- display: flex;
303
- flex-direction: column;
304
- height: 100%;
305
- border-right: 1px solid ${colors.gray[700]};
306
-
307
- @media (max-width: 700px) {
308
- border-top: 2px solid ${colors.gray[700]};
309
- }
310
- `,
311
- fourthContainer: css`
312
- flex: 1 1 500px;
313
- min-height: 40%;
314
- max-height: 100%;
315
- overflow: auto;
316
- display: flex;
317
- flex-direction: column;
318
- `,
319
- routesContainer: css`
320
- overflow-x: auto;
321
- overflow-y: visible;
322
- `,
323
- routesRowContainer: (active, isMatch) => {
324
- const base = css`
325
- display: flex;
326
- border-bottom: 1px solid ${colors.darkGray[400]};
327
- align-items: center;
328
- padding: ${size[1]} ${size[2]};
329
- gap: ${size[2]};
330
- font-size: ${fontSize.xs};
331
- color: ${colors.gray[300]};
332
- cursor: ${isMatch ? "pointer" : "default"};
333
- line-height: ${lineHeight["xs"]};
334
- `;
335
- const classes = [base];
336
- if (active) {
337
- const activeStyles = css`
338
- background: ${colors.darkGray[500]};
339
- `;
340
- classes.push(activeStyles);
341
- }
342
- return classes;
343
- },
344
- routesRow: (isMatch) => {
345
- const base = css`
346
- flex: 1 0 auto;
347
- display: flex;
348
- justify-content: space-between;
349
- align-items: center;
350
- font-size: ${fontSize.xs};
351
- line-height: ${lineHeight["xs"]};
352
- `;
353
- const classes = [base];
354
- if (!isMatch) {
355
- const matchStyles = css`
356
- color: ${colors.gray[400]};
357
- `;
358
- classes.push(matchStyles);
359
- }
360
- return classes;
361
- },
362
- routesRowInner: css`
363
- display: 'flex';
364
- align-items: 'center';
365
- flex-grow: 1;
366
- min-width: 0;
367
- `,
368
- routeParamInfo: css`
369
- color: ${colors.gray[400]};
370
- font-size: ${fontSize.xs};
371
- line-height: ${lineHeight["xs"]};
372
- `,
373
- nestedRouteRow: (isRoot) => {
374
- const base = css`
375
- margin-left: ${isRoot ? 0 : size[3.5]};
376
- border-left: ${isRoot ? "" : `solid 1px ${colors.gray[700]}`};
377
- `;
378
- return base;
379
- },
380
- code: css`
381
- font-size: ${fontSize.xs};
382
- line-height: ${lineHeight["xs"]};
383
- white-space: nowrap;
384
- overflow: hidden;
385
- text-overflow: ellipsis;
386
- `,
387
- matchesContainer: css`
388
- flex: 1 1 auto;
389
- overflow-y: auto;
390
- `,
391
- cachedMatchesContainer: css`
392
- flex: 1 1 auto;
393
- overflow-y: auto;
394
- max-height: 50%;
395
- `,
396
- maskedBadgeContainer: css`
397
- flex: 1;
398
- justify-content: flex-end;
399
- display: flex;
400
- `,
401
- matchDetails: css`
402
- display: flex;
403
- flex-direction: column;
404
- padding: ${tokens.size[2]};
405
- font-size: ${tokens.font.size.xs};
406
- color: ${tokens.colors.gray[300]};
407
- line-height: ${tokens.font.lineHeight.sm};
408
- `,
409
- matchStatus: (status, isFetching) => {
410
- const colorMap = {
411
- pending: "yellow",
412
- success: "green",
413
- error: "red",
414
- notFound: "purple",
415
- redirected: "gray"
416
- };
417
- const color = isFetching && status === "success" ? isFetching === "beforeLoad" ? "purple" : "blue" : colorMap[status];
418
- return css`
419
- display: flex;
420
- justify-content: center;
421
- align-items: center;
422
- height: 40px;
423
- border-radius: ${tokens.border.radius.sm};
424
- font-weight: ${tokens.font.weight.normal};
425
- background-color: ${tokens.colors[color][900]}${tokens.alpha[90]};
426
- color: ${tokens.colors[color][300]};
427
- border: 1px solid ${tokens.colors[color][600]};
428
- margin-bottom: ${tokens.size[2]};
429
- transition: all 0.25s ease-out;
430
- `;
431
- },
432
- matchDetailsInfo: css`
433
- display: flex;
434
- justify-content: flex-end;
435
- flex: 1;
436
- `,
437
- matchDetailsInfoLabel: css`
438
- display: flex;
439
- `,
440
- mainCloseBtn: css`
441
- background: ${colors.darkGray[700]};
442
- padding: ${size[1]} ${size[2]} ${size[1]} ${size[1.5]};
443
- border-radius: ${border.radius.md};
444
- position: fixed;
445
- z-index: 99999;
446
- display: inline-flex;
447
- width: fit-content;
448
- cursor: pointer;
449
- appearance: none;
450
- border: 0;
451
- gap: 8px;
452
- align-items: center;
453
- border: 1px solid ${colors.gray[500]};
454
- font-size: ${font.size.xs};
455
- cursor: pointer;
456
- transition: all 0.25s ease-out;
457
-
458
- &:hover {
459
- background: ${colors.darkGray[500]};
460
- }
461
- `,
462
- mainCloseBtnPosition: (position) => {
463
- const base = css`
464
- ${position === "top-left" ? `top: ${size[2]}; left: ${size[2]};` : ""}
465
- ${position === "top-right" ? `top: ${size[2]}; right: ${size[2]};` : ""}
466
- ${position === "bottom-left" ? `bottom: ${size[2]}; left: ${size[2]};` : ""}
467
- ${position === "bottom-right" ? `bottom: ${size[2]}; right: ${size[2]};` : ""}
468
- `;
469
- return base;
470
- },
471
- mainCloseBtnAnimation: (isOpen) => {
472
- if (!isOpen) {
473
- return css`
474
- opacity: 1;
475
- pointer-events: auto;
476
- visibility: visible;
477
- `;
478
- }
479
- return css`
480
- opacity: 0;
481
- pointer-events: none;
482
- visibility: hidden;
483
- `;
484
- },
485
- routerLogoCloseButton: css`
486
- font-weight: ${font.weight.semibold};
487
- font-size: ${font.size.xs};
488
- background: linear-gradient(to right, #98f30c, #00f4a3);
489
- background-clip: text;
490
- -webkit-background-clip: text;
491
- line-height: 1;
492
- -webkit-text-fill-color: transparent;
493
- white-space: nowrap;
494
- `,
495
- mainCloseBtnDivider: css`
496
- width: 1px;
497
- background: ${tokens.colors.gray[600]};
498
- height: 100%;
499
- border-radius: 999999px;
500
- color: transparent;
501
- `,
502
- mainCloseBtnIconContainer: css`
503
- position: relative;
504
- width: ${size[5]};
505
- height: ${size[5]};
506
- background: pink;
507
- border-radius: 999999px;
508
- overflow: hidden;
509
- `,
510
- mainCloseBtnIconOuter: css`
511
- width: ${size[5]};
512
- height: ${size[5]};
513
- position: absolute;
514
- top: 50%;
515
- left: 50%;
516
- transform: translate(-50%, -50%);
517
- filter: blur(3px) saturate(1.8) contrast(2);
518
- `,
519
- mainCloseBtnIconInner: css`
520
- width: ${size[4]};
521
- height: ${size[4]};
522
- position: absolute;
523
- top: 50%;
524
- left: 50%;
525
- transform: translate(-50%, -50%);
526
- `,
527
- panelCloseBtn: css`
528
- position: absolute;
529
- cursor: pointer;
530
- z-index: 100001;
531
- display: flex;
532
- align-items: center;
533
- justify-content: center;
534
- outline: none;
535
- background-color: ${colors.darkGray[700]};
536
- &:hover {
537
- background-color: ${colors.darkGray[500]};
538
- }
539
-
540
- top: 0;
541
- right: ${size[2]};
542
- transform: translate(0, -100%);
543
- border-right: ${colors.darkGray[300]} 1px solid;
544
- border-left: ${colors.darkGray[300]} 1px solid;
545
- border-top: ${colors.darkGray[300]} 1px solid;
546
- border-bottom: none;
547
- border-radius: ${border.radius.sm} ${border.radius.sm} 0px 0px;
548
- padding: ${size[1]} ${size[1.5]} ${size[0.5]} ${size[1.5]};
549
-
550
- &::after {
551
- content: ' ';
552
- position: absolute;
553
- top: 100%;
554
- left: -${size[2.5]};
555
- height: ${size[1.5]};
556
- width: calc(100% + ${size[5]});
557
- }
558
- `,
559
- panelCloseBtnIcon: css`
560
- color: ${colors.gray[400]};
561
- width: ${size[2]};
562
- height: ${size[2]};
563
- `,
564
- navigateButton: css`
565
- background: none;
566
- border: none;
567
- padding: 0 0 0 4px;
568
- margin: 0;
569
- color: ${colors.gray[400]};
570
- font-size: ${fontSize.md};
571
- cursor: pointer;
572
- line-height: 1;
573
- vertical-align: middle;
574
- margin-right: 0.5ch;
575
- flex-shrink: 0;
576
- &:hover {
577
- color: ${colors.blue[300]};
578
- }
579
- `
580
- };
581
- };
582
- function useStyles() {
583
- const shadowDomTarget = useContext(ShadowDomTargetContext);
584
- const [_styles] = createSignal(stylesFactory(shadowDomTarget));
585
- return _styles;
586
- }
587
- export {
588
- useStyles
589
- };
590
- //# sourceMappingURL=useStyles.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"useStyles.js","sources":["../../../../../src/useStyles.tsx"],"sourcesContent":["import * as goober from 'goober'\nimport { createSignal, useContext } from 'solid-js'\nimport { tokens } from './tokens'\nimport { ShadowDomTargetContext } from './context'\nimport type { Accessor } from 'solid-js'\n\nconst stylesFactory = (shadowDOMTarget?: ShadowRoot) => {\n const { colors, font, size, alpha, shadow, border } = tokens\n const { fontFamily, lineHeight, size: fontSize } = font\n const css = shadowDOMTarget\n ? goober.css.bind({ target: shadowDOMTarget })\n : goober.css\n\n return {\n devtoolsPanelContainer: css`\n direction: ltr;\n position: fixed;\n bottom: 0;\n right: 0;\n z-index: 99999;\n width: 100%;\n max-height: 90%;\n border-top: 1px solid ${colors.gray[700]};\n transform-origin: top;\n `,\n devtoolsPanelContainerVisibility: (isOpen: boolean) => {\n return css`\n visibility: ${isOpen ? 'visible' : 'hidden'};\n `\n },\n devtoolsPanelContainerResizing: (isResizing: Accessor<boolean>) => {\n if (isResizing()) {\n return css`\n transition: none;\n `\n }\n\n return css`\n transition: all 0.4s ease;\n `\n },\n devtoolsPanelContainerAnimation: (isOpen: boolean, height: number) => {\n if (isOpen) {\n return css`\n pointer-events: auto;\n transform: translateY(0);\n `\n }\n return css`\n pointer-events: none;\n transform: translateY(${height}px);\n `\n },\n logo: css`\n cursor: pointer;\n display: flex;\n flex-direction: column;\n background-color: transparent;\n border: none;\n font-family: ${fontFamily.sans};\n gap: ${tokens.size[0.5]};\n padding: 0px;\n &:hover {\n opacity: 0.7;\n }\n &:focus-visible {\n outline-offset: 4px;\n border-radius: ${border.radius.xs};\n outline: 2px solid ${colors.blue[800]};\n }\n `,\n tanstackLogo: css`\n font-size: ${font.size.md};\n font-weight: ${font.weight.bold};\n line-height: ${font.lineHeight.xs};\n white-space: nowrap;\n color: ${colors.gray[300]};\n `,\n routerLogo: css`\n font-weight: ${font.weight.semibold};\n font-size: ${font.size.xs};\n background: linear-gradient(to right, #84cc16, #10b981);\n background-clip: text;\n -webkit-background-clip: text;\n line-height: 1;\n -webkit-text-fill-color: transparent;\n white-space: nowrap;\n `,\n devtoolsPanel: css`\n display: flex;\n font-size: ${fontSize.sm};\n font-family: ${fontFamily.sans};\n background-color: ${colors.darkGray[700]};\n color: ${colors.gray[300]};\n\n @media (max-width: 700px) {\n flex-direction: column;\n }\n @media (max-width: 600px) {\n font-size: ${fontSize.xs};\n }\n `,\n dragHandle: css`\n position: absolute;\n left: 0;\n top: 0;\n width: 100%;\n height: 4px;\n cursor: row-resize;\n z-index: 100000;\n &:hover {\n background-color: ${colors.purple[400]}${alpha[90]};\n }\n `,\n firstContainer: css`\n flex: 1 1 500px;\n min-height: 40%;\n max-height: 100%;\n overflow: auto;\n border-right: 1px solid ${colors.gray[700]};\n display: flex;\n flex-direction: column;\n `,\n routerExplorerContainer: css`\n overflow-y: auto;\n flex: 1;\n `,\n routerExplorer: css`\n padding: ${tokens.size[2]};\n `,\n row: css`\n display: flex;\n align-items: center;\n padding: ${tokens.size[2]} ${tokens.size[2.5]};\n gap: ${tokens.size[2.5]};\n border-bottom: ${colors.darkGray[500]} 1px solid;\n align-items: center;\n `,\n detailsHeader: css`\n font-family: ui-sans-serif, Inter, system-ui, sans-serif, sans-serif;\n position: sticky;\n top: 0;\n z-index: 2;\n background-color: ${colors.darkGray[600]};\n padding: 0px ${tokens.size[2]};\n font-weight: ${font.weight.medium};\n font-size: ${font.size.xs};\n min-height: ${tokens.size[8]};\n line-height: ${font.lineHeight.xs};\n text-align: left;\n display: flex;\n align-items: center;\n `,\n maskedBadge: css`\n background: ${colors.yellow[900]}${alpha[70]};\n color: ${colors.yellow[300]};\n display: inline-block;\n padding: ${tokens.size[0]} ${tokens.size[2.5]};\n border-radius: ${border.radius.full};\n font-size: ${font.size.xs};\n font-weight: ${font.weight.normal};\n border: 1px solid ${colors.yellow[300]};\n `,\n maskedLocation: css`\n color: ${colors.yellow[300]};\n `,\n detailsContent: css`\n padding: ${tokens.size[1.5]} ${tokens.size[2]};\n display: flex;\n align-items: center;\n justify-content: space-between;\n font-size: ${font.size.xs};\n `,\n routeMatchesToggle: css`\n display: flex;\n align-items: center;\n border: 1px solid ${colors.gray[500]};\n border-radius: ${border.radius.sm};\n overflow: hidden;\n `,\n routeMatchesToggleBtn: (active: boolean, showBorder: boolean) => {\n const base = css`\n appearance: none;\n border: none;\n font-size: 12px;\n padding: 4px 8px;\n background: transparent;\n cursor: pointer;\n font-family: ${fontFamily.sans};\n font-weight: ${font.weight.medium};\n `\n const classes = [base]\n\n if (active) {\n const activeStyles = css`\n background: ${colors.darkGray[400]};\n color: ${colors.gray[300]};\n `\n classes.push(activeStyles)\n } else {\n const inactiveStyles = css`\n color: ${colors.gray[500]};\n background: ${colors.darkGray[800]}${alpha[20]};\n `\n classes.push(inactiveStyles)\n }\n\n if (showBorder) {\n classes.push(css`\n border-right: 1px solid ${tokens.colors.gray[500]};\n `)\n }\n\n return classes\n },\n detailsHeaderInfo: css`\n flex: 1;\n justify-content: flex-end;\n display: flex;\n align-items: center;\n font-weight: ${font.weight.normal};\n color: ${colors.gray[400]};\n `,\n matchRow: (active: boolean) => {\n const base = css`\n display: flex;\n border-bottom: 1px solid ${colors.darkGray[400]};\n cursor: pointer;\n align-items: center;\n padding: ${size[1]} ${size[2]};\n gap: ${size[2]};\n font-size: ${fontSize.xs};\n color: ${colors.gray[300]};\n `\n const classes = [base]\n\n if (active) {\n const activeStyles = css`\n background: ${colors.darkGray[500]};\n `\n classes.push(activeStyles)\n }\n\n return classes\n },\n matchIndicator: (\n color: 'green' | 'red' | 'yellow' | 'gray' | 'blue' | 'purple',\n ) => {\n const base = css`\n flex: 0 0 auto;\n width: ${size[3]};\n height: ${size[3]};\n background: ${colors[color][900]};\n border: 1px solid ${colors[color][500]};\n border-radius: ${border.radius.full};\n transition: all 0.25s ease-out;\n box-sizing: border-box;\n `\n const classes = [base]\n\n if (color === 'gray') {\n const grayStyles = css`\n background: ${colors.gray[700]};\n border-color: ${colors.gray[400]};\n `\n classes.push(grayStyles)\n }\n\n return classes\n },\n matchID: css`\n flex: 1;\n line-height: ${lineHeight['xs']};\n `,\n ageTicker: (showWarning: boolean) => {\n const base = css`\n display: flex;\n gap: ${size[1]};\n font-size: ${fontSize.xs};\n color: ${colors.gray[400]};\n font-variant-numeric: tabular-nums;\n line-height: ${lineHeight['xs']};\n `\n\n const classes = [base]\n\n if (showWarning) {\n const warningStyles = css`\n color: ${colors.yellow[400]};\n `\n classes.push(warningStyles)\n }\n\n return classes\n },\n secondContainer: css`\n flex: 1 1 500px;\n min-height: 40%;\n max-height: 100%;\n overflow: auto;\n border-right: 1px solid ${colors.gray[700]};\n display: flex;\n flex-direction: column;\n `,\n thirdContainer: css`\n flex: 1 1 500px;\n overflow: auto;\n display: flex;\n flex-direction: column;\n height: 100%;\n border-right: 1px solid ${colors.gray[700]};\n\n @media (max-width: 700px) {\n border-top: 2px solid ${colors.gray[700]};\n }\n `,\n fourthContainer: css`\n flex: 1 1 500px;\n min-height: 40%;\n max-height: 100%;\n overflow: auto;\n display: flex;\n flex-direction: column;\n `,\n routesContainer: css`\n overflow-x: auto;\n overflow-y: visible;\n `,\n routesRowContainer: (active: boolean, isMatch: boolean) => {\n const base = css`\n display: flex;\n border-bottom: 1px solid ${colors.darkGray[400]};\n align-items: center;\n padding: ${size[1]} ${size[2]};\n gap: ${size[2]};\n font-size: ${fontSize.xs};\n color: ${colors.gray[300]};\n cursor: ${isMatch ? 'pointer' : 'default'};\n line-height: ${lineHeight['xs']};\n `\n const classes = [base]\n\n if (active) {\n const activeStyles = css`\n background: ${colors.darkGray[500]};\n `\n classes.push(activeStyles)\n }\n\n return classes\n },\n routesRow: (isMatch: boolean) => {\n const base = css`\n flex: 1 0 auto;\n display: flex;\n justify-content: space-between;\n align-items: center;\n font-size: ${fontSize.xs};\n line-height: ${lineHeight['xs']};\n `\n\n const classes = [base]\n\n if (!isMatch) {\n const matchStyles = css`\n color: ${colors.gray[400]};\n `\n classes.push(matchStyles)\n }\n\n return classes\n },\n routesRowInner: css`\n display: 'flex';\n align-items: 'center';\n flex-grow: 1;\n min-width: 0;\n `,\n routeParamInfo: css`\n color: ${colors.gray[400]};\n font-size: ${fontSize.xs};\n line-height: ${lineHeight['xs']};\n `,\n nestedRouteRow: (isRoot: boolean) => {\n const base = css`\n margin-left: ${isRoot ? 0 : size[3.5]};\n border-left: ${isRoot ? '' : `solid 1px ${colors.gray[700]}`};\n `\n return base\n },\n code: css`\n font-size: ${fontSize.xs};\n line-height: ${lineHeight['xs']};\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n `,\n matchesContainer: css`\n flex: 1 1 auto;\n overflow-y: auto;\n `,\n cachedMatchesContainer: css`\n flex: 1 1 auto;\n overflow-y: auto;\n max-height: 50%;\n `,\n maskedBadgeContainer: css`\n flex: 1;\n justify-content: flex-end;\n display: flex;\n `,\n matchDetails: css`\n display: flex;\n flex-direction: column;\n padding: ${tokens.size[2]};\n font-size: ${tokens.font.size.xs};\n color: ${tokens.colors.gray[300]};\n line-height: ${tokens.font.lineHeight.sm};\n `,\n matchStatus: (\n status: 'pending' | 'success' | 'error' | 'notFound' | 'redirected',\n isFetching: false | 'beforeLoad' | 'loader',\n ) => {\n const colorMap = {\n pending: 'yellow',\n success: 'green',\n error: 'red',\n notFound: 'purple',\n redirected: 'gray',\n } as const\n\n const color =\n isFetching && status === 'success'\n ? isFetching === 'beforeLoad'\n ? 'purple'\n : 'blue'\n : colorMap[status]\n\n return css`\n display: flex;\n justify-content: center;\n align-items: center;\n height: 40px;\n border-radius: ${tokens.border.radius.sm};\n font-weight: ${tokens.font.weight.normal};\n background-color: ${tokens.colors[color][900]}${tokens.alpha[90]};\n color: ${tokens.colors[color][300]};\n border: 1px solid ${tokens.colors[color][600]};\n margin-bottom: ${tokens.size[2]};\n transition: all 0.25s ease-out;\n `\n },\n matchDetailsInfo: css`\n display: flex;\n justify-content: flex-end;\n flex: 1;\n `,\n matchDetailsInfoLabel: css`\n display: flex;\n `,\n mainCloseBtn: css`\n background: ${colors.darkGray[700]};\n padding: ${size[1]} ${size[2]} ${size[1]} ${size[1.5]};\n border-radius: ${border.radius.md};\n position: fixed;\n z-index: 99999;\n display: inline-flex;\n width: fit-content;\n cursor: pointer;\n appearance: none;\n border: 0;\n gap: 8px;\n align-items: center;\n border: 1px solid ${colors.gray[500]};\n font-size: ${font.size.xs};\n cursor: pointer;\n transition: all 0.25s ease-out;\n\n &:hover {\n background: ${colors.darkGray[500]};\n }\n `,\n mainCloseBtnPosition: (\n position: 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right',\n ) => {\n const base = css`\n ${position === 'top-left' ? `top: ${size[2]}; left: ${size[2]};` : ''}\n ${position === 'top-right' ? `top: ${size[2]}; right: ${size[2]};` : ''}\n ${position === 'bottom-left'\n ? `bottom: ${size[2]}; left: ${size[2]};`\n : ''}\n ${position === 'bottom-right'\n ? `bottom: ${size[2]}; right: ${size[2]};`\n : ''}\n `\n return base\n },\n mainCloseBtnAnimation: (isOpen: boolean) => {\n if (!isOpen) {\n return css`\n opacity: 1;\n pointer-events: auto;\n visibility: visible;\n `\n }\n return css`\n opacity: 0;\n pointer-events: none;\n visibility: hidden;\n `\n },\n routerLogoCloseButton: css`\n font-weight: ${font.weight.semibold};\n font-size: ${font.size.xs};\n background: linear-gradient(to right, #98f30c, #00f4a3);\n background-clip: text;\n -webkit-background-clip: text;\n line-height: 1;\n -webkit-text-fill-color: transparent;\n white-space: nowrap;\n `,\n mainCloseBtnDivider: css`\n width: 1px;\n background: ${tokens.colors.gray[600]};\n height: 100%;\n border-radius: 999999px;\n color: transparent;\n `,\n mainCloseBtnIconContainer: css`\n position: relative;\n width: ${size[5]};\n height: ${size[5]};\n background: pink;\n border-radius: 999999px;\n overflow: hidden;\n `,\n mainCloseBtnIconOuter: css`\n width: ${size[5]};\n height: ${size[5]};\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n filter: blur(3px) saturate(1.8) contrast(2);\n `,\n mainCloseBtnIconInner: css`\n width: ${size[4]};\n height: ${size[4]};\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n `,\n panelCloseBtn: css`\n position: absolute;\n cursor: pointer;\n z-index: 100001;\n display: flex;\n align-items: center;\n justify-content: center;\n outline: none;\n background-color: ${colors.darkGray[700]};\n &:hover {\n background-color: ${colors.darkGray[500]};\n }\n\n top: 0;\n right: ${size[2]};\n transform: translate(0, -100%);\n border-right: ${colors.darkGray[300]} 1px solid;\n border-left: ${colors.darkGray[300]} 1px solid;\n border-top: ${colors.darkGray[300]} 1px solid;\n border-bottom: none;\n border-radius: ${border.radius.sm} ${border.radius.sm} 0px 0px;\n padding: ${size[1]} ${size[1.5]} ${size[0.5]} ${size[1.5]};\n\n &::after {\n content: ' ';\n position: absolute;\n top: 100%;\n left: -${size[2.5]};\n height: ${size[1.5]};\n width: calc(100% + ${size[5]});\n }\n `,\n panelCloseBtnIcon: css`\n color: ${colors.gray[400]};\n width: ${size[2]};\n height: ${size[2]};\n `,\n navigateButton: css`\n background: none;\n border: none;\n padding: 0 0 0 4px;\n margin: 0;\n color: ${colors.gray[400]};\n font-size: ${fontSize.md};\n cursor: pointer;\n line-height: 1;\n vertical-align: middle;\n margin-right: 0.5ch;\n flex-shrink: 0;\n &:hover {\n color: ${colors.blue[300]};\n }\n `,\n }\n}\n\nexport function useStyles() {\n const shadowDomTarget = useContext(ShadowDomTargetContext)\n const [_styles] = createSignal(stylesFactory(shadowDomTarget))\n return _styles\n}\n"],"names":["stylesFactory","shadowDOMTarget","colors","font","size","alpha","border","tokens","fontFamily","lineHeight","fontSize","css","goober","bind","target","devtoolsPanelContainer","gray","devtoolsPanelContainerVisibility","isOpen","devtoolsPanelContainerResizing","isResizing","devtoolsPanelContainerAnimation","height","logo","sans","radius","xs","blue","tanstackLogo","md","weight","bold","routerLogo","semibold","devtoolsPanel","sm","darkGray","dragHandle","purple","firstContainer","routerExplorerContainer","routerExplorer","row","detailsHeader","medium","maskedBadge","yellow","full","normal","maskedLocation","detailsContent","routeMatchesToggle","routeMatchesToggleBtn","active","showBorder","base","classes","activeStyles","push","inactiveStyles","detailsHeaderInfo","matchRow","matchIndicator","color","grayStyles","matchID","ageTicker","showWarning","warningStyles","secondContainer","thirdContainer","fourthContainer","routesContainer","routesRowContainer","isMatch","routesRow","matchStyles","routesRowInner","routeParamInfo","nestedRouteRow","isRoot","code","matchesContainer","cachedMatchesContainer","maskedBadgeContainer","matchDetails","matchStatus","status","isFetching","colorMap","pending","success","error","notFound","redirected","matchDetailsInfo","matchDetailsInfoLabel","mainCloseBtn","mainCloseBtnPosition","position","mainCloseBtnAnimation","routerLogoCloseButton","mainCloseBtnDivider","mainCloseBtnIconContainer","mainCloseBtnIconOuter","mainCloseBtnIconInner","panelCloseBtn","panelCloseBtnIcon","navigateButton","useStyles","shadowDomTarget","useContext","ShadowDomTargetContext","_styles","createSignal"],"mappings":";;;;AAMA,MAAMA,gBAAgBA,CAACC,oBAAiC;AACtD,QAAM;AAAA,IAAEC;AAAAA,IAAQC;AAAAA,IAAMC;AAAAA,IAAMC;AAAAA,IAAeC;AAAAA,EAAAA,IAAWC;AACtD,QAAM;AAAA,IAAEC;AAAAA,IAAYC;AAAAA,IAAYL,MAAMM;AAAAA,EAAAA,IAAaP;AACnD,QAAMQ,MAAMV,kBACRW,OAAOD,IAAIE,KAAK;AAAA,IAAEC,QAAQb;AAAAA,EAAAA,CAAiB,IAC3CW,OAAOD;AAEX,SAAO;AAAA,IACLI,wBAAwBJ;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,8BAQET,OAAOc,KAAK,GAAG,CAAC;AAAA;AAAA;AAAA,IAG1CC,kCAAkCA,CAACC,WAAoB;AACrD,aAAOP;AAAAA,sBACSO,SAAS,YAAY,QAAQ;AAAA;AAAA,IAE/C;AAAA,IACAC,gCAAgCA,CAACC,eAAkC;AACjE,UAAIA,cAAc;AAChB,eAAOT;AAAAA;AAAAA;AAAAA,MAGT;AAEA,aAAOA;AAAAA;AAAAA;AAAAA,IAGT;AAAA,IACAU,iCAAiCA,CAACH,QAAiBI,WAAmB;AACpE,UAAIJ,QAAQ;AACV,eAAOP;AAAAA;AAAAA;AAAAA;AAAAA,MAIT;AACA,aAAOA;AAAAA;AAAAA,gCAEmBW,MAAM;AAAA;AAAA,IAElC;AAAA,IACAC,MAAMZ;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,qBAMWH,WAAWgB,IAAI;AAAA,aACvBjB,OAAOH,KAAK,GAAG,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,yBAOJE,OAAOmB,OAAOC,EAAE;AAAA,6BACZxB,OAAOyB,KAAK,GAAG,CAAC;AAAA;AAAA;AAAA,IAGzCC,cAAcjB;AAAAA,mBACCR,KAAKC,KAAKyB,EAAE;AAAA,qBACV1B,KAAK2B,OAAOC,IAAI;AAAA,qBAChB5B,KAAKM,WAAWiB,EAAE;AAAA;AAAA,eAExBxB,OAAOc,KAAK,GAAG,CAAC;AAAA;AAAA,IAE3BgB,YAAYrB;AAAAA,qBACKR,KAAK2B,OAAOG,QAAQ;AAAA,mBACtB9B,KAAKC,KAAKsB,EAAE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQ3BQ,eAAevB;AAAAA;AAAAA,mBAEAD,SAASyB,EAAE;AAAA,qBACT3B,WAAWgB,IAAI;AAAA,0BACVtB,OAAOkC,SAAS,GAAG,CAAC;AAAA,eAC/BlC,OAAOc,KAAK,GAAG,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,qBAMVN,SAASgB,EAAE;AAAA;AAAA;AAAA,IAG5BW,YAAY1B;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,4BASYT,OAAOoC,OAAO,GAAG,CAAC,GAAGjC,MAAM,EAAE,CAAC;AAAA;AAAA;AAAA,IAGtDkC,gBAAgB5B;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,gCAKYT,OAAOc,KAAK,GAAG,CAAC;AAAA;AAAA;AAAA;AAAA,IAI5CwB,yBAAyB7B;AAAAA;AAAAA;AAAAA;AAAAA,IAIzB8B,gBAAgB9B;AAAAA,iBACHJ,OAAOH,KAAK,CAAC,CAAC;AAAA;AAAA,IAE3BsC,KAAK/B;AAAAA;AAAAA;AAAAA,iBAGQJ,OAAOH,KAAK,CAAC,CAAC,IAAIG,OAAOH,KAAK,GAAG,CAAC;AAAA,aACtCG,OAAOH,KAAK,GAAG,CAAC;AAAA,uBACNF,OAAOkC,SAAS,GAAG,CAAC;AAAA;AAAA;AAAA,IAGvCO,eAAehC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,0BAKOT,OAAOkC,SAAS,GAAG,CAAC;AAAA,qBACzB7B,OAAOH,KAAK,CAAC,CAAC;AAAA,qBACdD,KAAK2B,OAAOc,MAAM;AAAA,mBACpBzC,KAAKC,KAAKsB,EAAE;AAAA,oBACXnB,OAAOH,KAAK,CAAC,CAAC;AAAA,qBACbD,KAAKM,WAAWiB,EAAE;AAAA;AAAA;AAAA;AAAA;AAAA,IAKnCmB,aAAalC;AAAAA,oBACGT,OAAO4C,OAAO,GAAG,CAAC,GAAGzC,MAAM,EAAE,CAAC;AAAA,eACnCH,OAAO4C,OAAO,GAAG,CAAC;AAAA;AAAA,iBAEhBvC,OAAOH,KAAK,CAAC,CAAC,IAAIG,OAAOH,KAAK,GAAG,CAAC;AAAA,uBAC5BE,OAAOmB,OAAOsB,IAAI;AAAA,mBACtB5C,KAAKC,KAAKsB,EAAE;AAAA,qBACVvB,KAAK2B,OAAOkB,MAAM;AAAA,0BACb9C,OAAO4C,OAAO,GAAG,CAAC;AAAA;AAAA,IAExCG,gBAAgBtC;AAAAA,eACLT,OAAO4C,OAAO,GAAG,CAAC;AAAA;AAAA,IAE7BI,gBAAgBvC;AAAAA,iBACHJ,OAAOH,KAAK,GAAG,CAAC,IAAIG,OAAOH,KAAK,CAAC,CAAC;AAAA;AAAA;AAAA;AAAA,mBAIhCD,KAAKC,KAAKsB,EAAE;AAAA;AAAA,IAE3ByB,oBAAoBxC;AAAAA;AAAAA;AAAAA,0BAGET,OAAOc,KAAK,GAAG,CAAC;AAAA,uBACnBV,OAAOmB,OAAOU,EAAE;AAAA;AAAA;AAAA,IAGnCiB,uBAAuBA,CAACC,QAAiBC,eAAwB;AAC/D,YAAMC,OAAO5C;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,uBAOIH,WAAWgB,IAAI;AAAA,uBACfrB,KAAK2B,OAAOc,MAAM;AAAA;AAEnC,YAAMY,UAAU,CAACD,IAAI;AAErB,UAAIF,QAAQ;AACV,cAAMI,eAAe9C;AAAAA,wBACLT,OAAOkC,SAAS,GAAG,CAAC;AAAA,mBACzBlC,OAAOc,KAAK,GAAG,CAAC;AAAA;AAE3BwC,gBAAQE,KAAKD,YAAY;AAAA,MAC3B,OAAO;AACL,cAAME,iBAAiBhD;AAAAA,mBACZT,OAAOc,KAAK,GAAG,CAAC;AAAA,wBACXd,OAAOkC,SAAS,GAAG,CAAC,GAAG/B,MAAM,EAAE,CAAC;AAAA;AAEhDmD,gBAAQE,KAAKC,cAAc;AAAA,MAC7B;AAEA,UAAIL,YAAY;AACdE,gBAAQE,KAAK/C;AAAAA,oCACeJ,OAAOL,OAAOc,KAAK,GAAG,CAAC;AAAA,SAClD;AAAA,MACH;AAEA,aAAOwC;AAAAA,IACT;AAAA,IACAI,mBAAmBjD;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,qBAKFR,KAAK2B,OAAOkB,MAAM;AAAA,eACxB9C,OAAOc,KAAK,GAAG,CAAC;AAAA;AAAA,IAE3B6C,UAAUA,CAACR,WAAoB;AAC7B,YAAME,OAAO5C;AAAAA;AAAAA,mCAEgBT,OAAOkC,SAAS,GAAG,CAAC;AAAA;AAAA;AAAA,mBAGpChC,KAAK,CAAC,CAAC,IAAIA,KAAK,CAAC,CAAC;AAAA,eACtBA,KAAK,CAAC,CAAC;AAAA,qBACDM,SAASgB,EAAE;AAAA,iBACfxB,OAAOc,KAAK,GAAG,CAAC;AAAA;AAE3B,YAAMwC,UAAU,CAACD,IAAI;AAErB,UAAIF,QAAQ;AACV,cAAMI,eAAe9C;AAAAA,wBACLT,OAAOkC,SAAS,GAAG,CAAC;AAAA;AAEpCoB,gBAAQE,KAAKD,YAAY;AAAA,MAC3B;AAEA,aAAOD;AAAAA,IACT;AAAA,IACAM,gBAAgBA,CACdC,UACG;AACH,YAAMR,OAAO5C;AAAAA;AAAAA,iBAEFP,KAAK,CAAC,CAAC;AAAA,kBACNA,KAAK,CAAC,CAAC;AAAA,sBACHF,OAAO6D,KAAK,EAAE,GAAG,CAAC;AAAA,4BACZ7D,OAAO6D,KAAK,EAAE,GAAG,CAAC;AAAA,yBACrBzD,OAAOmB,OAAOsB,IAAI;AAAA;AAAA;AAAA;AAIrC,YAAMS,UAAU,CAACD,IAAI;AAErB,UAAIQ,UAAU,QAAQ;AACpB,cAAMC,aAAarD;AAAAA,wBACHT,OAAOc,KAAK,GAAG,CAAC;AAAA,0BACdd,OAAOc,KAAK,GAAG,CAAC;AAAA;AAElCwC,gBAAQE,KAAKM,UAAU;AAAA,MACzB;AAEA,aAAOR;AAAAA,IACT;AAAA,IACAS,SAAStD;AAAAA;AAAAA,qBAEQF,WAAW,IAAI,CAAC;AAAA;AAAA,IAEjCyD,WAAWA,CAACC,gBAAyB;AACnC,YAAMZ,OAAO5C;AAAAA;AAAAA,eAEJP,KAAK,CAAC,CAAC;AAAA,qBACDM,SAASgB,EAAE;AAAA,iBACfxB,OAAOc,KAAK,GAAG,CAAC;AAAA;AAAA,uBAEVP,WAAW,IAAI,CAAC;AAAA;AAGjC,YAAM+C,UAAU,CAACD,IAAI;AAErB,UAAIY,aAAa;AACf,cAAMC,gBAAgBzD;AAAAA,mBACXT,OAAO4C,OAAO,GAAG,CAAC;AAAA;AAE7BU,gBAAQE,KAAKU,aAAa;AAAA,MAC5B;AAEA,aAAOZ;AAAAA,IACT;AAAA,IACAa,iBAAiB1D;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,gCAKWT,OAAOc,KAAK,GAAG,CAAC;AAAA;AAAA;AAAA;AAAA,IAI5CsD,gBAAgB3D;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,gCAMYT,OAAOc,KAAK,GAAG,CAAC;AAAA;AAAA;AAAA,gCAGhBd,OAAOc,KAAK,GAAG,CAAC;AAAA;AAAA;AAAA,IAG5CuD,iBAAiB5D;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,IAQjB6D,iBAAiB7D;AAAAA;AAAAA;AAAAA;AAAAA,IAIjB8D,oBAAoBA,CAACpB,QAAiBqB,YAAqB;AACzD,YAAMnB,OAAO5C;AAAAA;AAAAA,mCAEgBT,OAAOkC,SAAS,GAAG,CAAC;AAAA;AAAA,mBAEpChC,KAAK,CAAC,CAAC,IAAIA,KAAK,CAAC,CAAC;AAAA,eACtBA,KAAK,CAAC,CAAC;AAAA,qBACDM,SAASgB,EAAE;AAAA,iBACfxB,OAAOc,KAAK,GAAG,CAAC;AAAA,kBACf0D,UAAU,YAAY,SAAS;AAAA,uBAC1BjE,WAAW,IAAI,CAAC;AAAA;AAEjC,YAAM+C,UAAU,CAACD,IAAI;AAErB,UAAIF,QAAQ;AACV,cAAMI,eAAe9C;AAAAA,wBACLT,OAAOkC,SAAS,GAAG,CAAC;AAAA;AAEpCoB,gBAAQE,KAAKD,YAAY;AAAA,MAC3B;AAEA,aAAOD;AAAAA,IACT;AAAA,IACAmB,WAAWA,CAACD,YAAqB;AAC/B,YAAMnB,OAAO5C;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,qBAKED,SAASgB,EAAE;AAAA,uBACTjB,WAAW,IAAI,CAAC;AAAA;AAGjC,YAAM+C,UAAU,CAACD,IAAI;AAErB,UAAI,CAACmB,SAAS;AACZ,cAAME,cAAcjE;AAAAA,mBACTT,OAAOc,KAAK,GAAG,CAAC;AAAA;AAE3BwC,gBAAQE,KAAKkB,WAAW;AAAA,MAC1B;AAEA,aAAOpB;AAAAA,IACT;AAAA,IACAqB,gBAAgBlE;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,IAMhBmE,gBAAgBnE;AAAAA,eACLT,OAAOc,KAAK,GAAG,CAAC;AAAA,mBACZN,SAASgB,EAAE;AAAA,qBACTjB,WAAW,IAAI,CAAC;AAAA;AAAA,IAEjCsE,gBAAgBA,CAACC,WAAoB;AACnC,YAAMzB,OAAO5C;AAAAA,uBACIqE,SAAS,IAAI5E,KAAK,GAAG,CAAC;AAAA,uBACtB4E,SAAS,KAAK,aAAa9E,OAAOc,KAAK,GAAG,CAAC,EAAE;AAAA;AAE9D,aAAOuC;AAAAA,IACT;AAAA,IACA0B,MAAMtE;AAAAA,mBACSD,SAASgB,EAAE;AAAA,qBACTjB,WAAW,IAAI,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,IAKjCyE,kBAAkBvE;AAAAA;AAAAA;AAAAA;AAAAA,IAIlBwE,wBAAwBxE;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,IAKxByE,sBAAsBzE;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,IAKtB0E,cAAc1E;AAAAA;AAAAA;AAAAA,iBAGDJ,OAAOH,KAAK,CAAC,CAAC;AAAA,mBACZG,OAAOJ,KAAKC,KAAKsB,EAAE;AAAA,eACvBnB,OAAOL,OAAOc,KAAK,GAAG,CAAC;AAAA,qBACjBT,OAAOJ,KAAKM,WAAW0B,EAAE;AAAA;AAAA,IAE1CmD,aAAaA,CACXC,QACAC,eACG;AACH,YAAMC,WAAW;AAAA,QACfC,SAAS;AAAA,QACTC,SAAS;AAAA,QACTC,OAAO;AAAA,QACPC,UAAU;AAAA,QACVC,YAAY;AAAA,MAAA;AAGd,YAAM/B,QACJyB,cAAcD,WAAW,YACrBC,eAAe,eACb,WACA,SACFC,SAASF,MAAM;AAErB,aAAO5E;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,yBAKYJ,OAAOD,OAAOmB,OAAOU,EAAE;AAAA,uBACzB5B,OAAOJ,KAAK2B,OAAOkB,MAAM;AAAA,4BACpBzC,OAAOL,OAAO6D,KAAK,EAAE,GAAG,CAAC,GAAGxD,OAAOF,MAAM,EAAE,CAAC;AAAA,iBACvDE,OAAOL,OAAO6D,KAAK,EAAE,GAAG,CAAC;AAAA,4BACdxD,OAAOL,OAAO6D,KAAK,EAAE,GAAG,CAAC;AAAA,yBAC5BxD,OAAOH,KAAK,CAAC,CAAC;AAAA;AAAA;AAAA,IAGnC;AAAA,IACA2F,kBAAkBpF;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,IAKlBqF,uBAAuBrF;AAAAA;AAAAA;AAAAA,IAGvBsF,cAActF;AAAAA,oBACET,OAAOkC,SAAS,GAAG,CAAC;AAAA,iBACvBhC,KAAK,CAAC,CAAC,IAAIA,KAAK,CAAC,CAAC,IAAIA,KAAK,CAAC,CAAC,IAAIA,KAAK,GAAG,CAAC;AAAA,uBACpCE,OAAOmB,OAAOI,EAAE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,0BAUb3B,OAAOc,KAAK,GAAG,CAAC;AAAA,mBACvBb,KAAKC,KAAKsB,EAAE;AAAA;AAAA;AAAA;AAAA;AAAA,sBAKTxB,OAAOkC,SAAS,GAAG,CAAC;AAAA;AAAA;AAAA,IAGtC8D,sBAAsBA,CACpBC,aACG;AACH,YAAM5C,OAAO5C;AAAAA,UACTwF,aAAa,aAAa,QAAQ/F,KAAK,CAAC,CAAC,WAAWA,KAAK,CAAC,CAAC,MAAM,EAAE;AAAA,UACnE+F,aAAa,cAAc,QAAQ/F,KAAK,CAAC,CAAC,YAAYA,KAAK,CAAC,CAAC,MAAM,EAAE;AAAA,UACrE+F,aAAa,gBACX,WAAW/F,KAAK,CAAC,CAAC,WAAWA,KAAK,CAAC,CAAC,MACpC,EAAE;AAAA,UACJ+F,aAAa,iBACX,WAAW/F,KAAK,CAAC,CAAC,YAAYA,KAAK,CAAC,CAAC,MACrC,EAAE;AAAA;AAER,aAAOmD;AAAAA,IACT;AAAA,IACA6C,uBAAuBA,CAAClF,WAAoB;AAC1C,UAAI,CAACA,QAAQ;AACX,eAAOP;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,MAKT;AACA,aAAOA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,IAKT;AAAA,IACA0F,uBAAuB1F;AAAAA,qBACNR,KAAK2B,OAAOG,QAAQ;AAAA,mBACtB9B,KAAKC,KAAKsB,EAAE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQ3B4E,qBAAqB3F;AAAAA;AAAAA,oBAELJ,OAAOL,OAAOc,KAAK,GAAG,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,IAKvCuF,2BAA2B5F;AAAAA;AAAAA,eAEhBP,KAAK,CAAC,CAAC;AAAA,gBACNA,KAAK,CAAC,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,IAKnBoG,uBAAuB7F;AAAAA,eACZP,KAAK,CAAC,CAAC;AAAA,gBACNA,KAAK,CAAC,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOnBqG,uBAAuB9F;AAAAA,eACZP,KAAK,CAAC,CAAC;AAAA,gBACNA,KAAK,CAAC,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMnBsG,eAAe/F;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,0BAQOT,OAAOkC,SAAS,GAAG,CAAC;AAAA;AAAA,4BAElBlC,OAAOkC,SAAS,GAAG,CAAC;AAAA;AAAA;AAAA;AAAA,eAIjChC,KAAK,CAAC,CAAC;AAAA;AAAA,sBAEAF,OAAOkC,SAAS,GAAG,CAAC;AAAA,qBACrBlC,OAAOkC,SAAS,GAAG,CAAC;AAAA,oBACrBlC,OAAOkC,SAAS,GAAG,CAAC;AAAA;AAAA,uBAEjB9B,OAAOmB,OAAOU,EAAE,IAAI7B,OAAOmB,OAAOU,EAAE;AAAA,iBAC1C/B,KAAK,CAAC,CAAC,IAAIA,KAAK,GAAG,CAAC,IAAIA,KAAK,GAAG,CAAC,IAAIA,KAAK,GAAG,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,iBAM9CA,KAAK,GAAG,CAAC;AAAA,kBACRA,KAAK,GAAG,CAAC;AAAA,6BACEA,KAAK,CAAC,CAAC;AAAA;AAAA;AAAA,IAGhCuG,mBAAmBhG;AAAAA,eACRT,OAAOc,KAAK,GAAG,CAAC;AAAA,eAChBZ,KAAK,CAAC,CAAC;AAAA,gBACNA,KAAK,CAAC,CAAC;AAAA;AAAA,IAEnBwG,gBAAgBjG;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,eAKLT,OAAOc,KAAK,GAAG,CAAC;AAAA,mBACZN,SAASmB,EAAE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,iBAOb3B,OAAOyB,KAAK,GAAG,CAAC;AAAA;AAAA;AAAA,EAAA;AAIjC;AAEO,SAASkF,YAAY;AAC1B,QAAMC,kBAAkBC,WAAWC,sBAAsB;AACzD,QAAM,CAACC,OAAO,IAAIC,aAAalH,cAAc8G,eAAe,CAAC;AAC7D,SAAOG;AACT;"}