@dxos/ui-theme 0.8.4-main.40e3dcdf1b → 0.8.4-main.422d1c7879

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 (134) hide show
  1. package/dist/lib/browser/index.mjs +395 -458
  2. package/dist/lib/browser/index.mjs.map +4 -4
  3. package/dist/lib/browser/meta.json +1 -1
  4. package/dist/lib/node-esm/index.mjs +395 -458
  5. package/dist/lib/node-esm/index.mjs.map +4 -4
  6. package/dist/lib/node-esm/meta.json +1 -1
  7. package/dist/plugin/node-cjs/{theme.css → main.css} +109 -55
  8. package/dist/plugin/node-cjs/main.css.map +7 -0
  9. package/dist/plugin/node-cjs/meta.json +1 -1
  10. package/dist/plugin/node-cjs/plugins/ThemePlugin.cjs +8 -15
  11. package/dist/plugin/node-cjs/plugins/ThemePlugin.cjs.map +3 -3
  12. package/dist/plugin/node-esm/{theme.css → main.css} +109 -55
  13. package/dist/plugin/node-esm/main.css.map +7 -0
  14. package/dist/plugin/node-esm/meta.json +1 -1
  15. package/dist/plugin/node-esm/plugins/ThemePlugin.mjs +8 -15
  16. package/dist/plugin/node-esm/plugins/ThemePlugin.mjs.map +3 -3
  17. package/dist/types/src/fragments/density.d.ts +2 -5
  18. package/dist/types/src/fragments/density.d.ts.map +1 -1
  19. package/dist/types/src/fragments/index.d.ts +0 -4
  20. package/dist/types/src/fragments/index.d.ts.map +1 -1
  21. package/dist/types/src/fragments/text.d.ts +0 -5
  22. package/dist/types/src/fragments/text.d.ts.map +1 -1
  23. package/dist/types/src/index.d.ts +1 -1
  24. package/dist/types/src/index.d.ts.map +1 -1
  25. package/dist/types/src/plugins/ThemePlugin.d.ts.map +1 -1
  26. package/dist/types/src/theme/components/avatar.d.ts.map +1 -1
  27. package/dist/types/src/theme/components/card.d.ts +3 -2
  28. package/dist/types/src/theme/components/card.d.ts.map +1 -1
  29. package/dist/types/src/theme/components/dialog.d.ts.map +1 -1
  30. package/dist/types/src/theme/components/focus.d.ts +6 -0
  31. package/dist/types/src/theme/components/focus.d.ts.map +1 -0
  32. package/dist/types/src/theme/components/icon-button.d.ts.map +1 -1
  33. package/dist/types/src/theme/components/icon.d.ts +3 -0
  34. package/dist/types/src/theme/components/icon.d.ts.map +1 -1
  35. package/dist/types/src/theme/components/index.d.ts +1 -0
  36. package/dist/types/src/theme/components/index.d.ts.map +1 -1
  37. package/dist/types/src/theme/components/input.d.ts.map +1 -1
  38. package/dist/types/src/theme/components/link.d.ts.map +1 -1
  39. package/dist/types/src/theme/components/list.d.ts.map +1 -1
  40. package/dist/types/src/theme/components/message.d.ts.map +1 -1
  41. package/dist/types/src/theme/components/popover.d.ts.map +1 -1
  42. package/dist/types/src/theme/components/scroll-area.d.ts +12 -2
  43. package/dist/types/src/theme/components/scroll-area.d.ts.map +1 -1
  44. package/dist/types/src/theme/components/select.d.ts.map +1 -1
  45. package/dist/types/src/theme/components/status.d.ts +1 -1
  46. package/dist/types/src/theme/components/status.d.ts.map +1 -1
  47. package/dist/types/src/theme/components/toast.d.ts.map +1 -1
  48. package/dist/types/src/theme/components/toolbar.d.ts +0 -1
  49. package/dist/types/src/theme/components/toolbar.d.ts.map +1 -1
  50. package/dist/types/src/theme/components/tooltip.d.ts.map +1 -1
  51. package/dist/types/src/theme/components/treegrid.d.ts.map +1 -1
  52. package/dist/types/src/theme/index.d.ts +1 -0
  53. package/dist/types/src/theme/index.d.ts.map +1 -1
  54. package/dist/types/src/theme/primitives/column.d.ts +25 -3
  55. package/dist/types/src/theme/primitives/column.d.ts.map +1 -1
  56. package/dist/types/src/theme/primitives/panel.d.ts +9 -5
  57. package/dist/types/src/theme/primitives/panel.d.ts.map +1 -1
  58. package/dist/types/src/theme/theme.d.ts.map +1 -1
  59. package/dist/types/src/util/elevation.d.ts.map +1 -0
  60. package/dist/types/src/util/index.d.ts +3 -0
  61. package/dist/types/src/util/index.d.ts.map +1 -1
  62. package/dist/types/src/util/mx.d.ts +49 -284
  63. package/dist/types/src/util/mx.d.ts.map +1 -1
  64. package/dist/types/src/util/size.d.ts +27 -0
  65. package/dist/types/src/util/size.d.ts.map +1 -0
  66. package/dist/types/src/util/valence.d.ts.map +1 -0
  67. package/dist/types/tsconfig.tsbuildinfo +1 -1
  68. package/package.json +8 -11
  69. package/src/css/components/button.css +2 -1
  70. package/src/css/components/{focus-ring.css → focus.css} +15 -1
  71. package/src/css/components/icon.css +9 -0
  72. package/src/css/components/panel.css +22 -22
  73. package/src/css/components/selected.css +13 -2
  74. package/src/css/components/tag.css +3 -1
  75. package/src/css/integrations/codemirror.css +5 -3
  76. package/src/css/integrations/tldraw.css +1 -0
  77. package/src/css/layout/main.css +0 -7
  78. package/src/css/layout/size.css +8 -31
  79. package/src/css/theme/animation.css +31 -0
  80. package/src/css/theme/palette.css +8 -0
  81. package/src/css/theme/semantic.css +16 -11
  82. package/src/css/theme/spacing.css +36 -19
  83. package/src/css/utilities.css +114 -3
  84. package/src/fragments/AUDIT.md +57 -0
  85. package/src/fragments/density.ts +8 -5
  86. package/src/fragments/index.ts +1 -5
  87. package/src/fragments/text.ts +1 -6
  88. package/src/index.ts +1 -1
  89. package/src/{theme.css → main.css} +9 -6
  90. package/src/plugins/ThemePlugin.ts +12 -24
  91. package/src/plugins/main.css +45 -0
  92. package/src/theme/components/avatar.ts +3 -4
  93. package/src/theme/components/button.ts +1 -1
  94. package/src/theme/components/card.ts +19 -11
  95. package/src/theme/components/dialog.ts +4 -3
  96. package/src/theme/components/focus.ts +33 -0
  97. package/src/theme/components/icon-button.ts +1 -3
  98. package/src/theme/components/icon.ts +13 -4
  99. package/src/theme/components/index.ts +1 -0
  100. package/src/theme/components/input.ts +15 -30
  101. package/src/theme/components/link.ts +1 -2
  102. package/src/theme/components/list.ts +4 -4
  103. package/src/theme/components/menu.ts +4 -4
  104. package/src/theme/components/message.ts +2 -3
  105. package/src/theme/components/popover.ts +4 -5
  106. package/src/theme/components/scroll-area.ts +58 -46
  107. package/src/theme/components/select.ts +1 -2
  108. package/src/theme/components/status.ts +5 -5
  109. package/src/theme/components/toast.ts +2 -3
  110. package/src/theme/components/toolbar.ts +1 -7
  111. package/src/theme/components/tooltip.ts +1 -2
  112. package/src/theme/components/treegrid.ts +1 -1
  113. package/src/theme/index.ts +1 -0
  114. package/src/theme/primitives/column.ts +49 -8
  115. package/src/theme/primitives/panel.ts +18 -25
  116. package/src/theme/theme.ts +2 -0
  117. package/src/typings.d.ts +3 -0
  118. package/src/util/index.ts +3 -0
  119. package/src/util/mx.ts +112 -7
  120. package/src/util/size.ts +103 -0
  121. package/dist/plugin/node-cjs/theme.css.map +0 -7
  122. package/dist/plugin/node-esm/theme.css.map +0 -7
  123. package/dist/types/src/fragments/elevation.d.ts.map +0 -1
  124. package/dist/types/src/fragments/focus.d.ts +0 -4
  125. package/dist/types/src/fragments/focus.d.ts.map +0 -1
  126. package/dist/types/src/fragments/size.d.ts +0 -7
  127. package/dist/types/src/fragments/size.d.ts.map +0 -1
  128. package/dist/types/src/fragments/valence.d.ts.map +0 -1
  129. package/src/fragments/focus.ts +0 -11
  130. package/src/fragments/size.ts +0 -117
  131. /package/dist/types/src/{fragments → util}/elevation.d.ts +0 -0
  132. /package/dist/types/src/{fragments → util}/valence.d.ts +0 -0
  133. /package/src/{fragments → util}/elevation.ts +0 -0
  134. /package/src/{fragments → util}/valence.ts +0 -0
@@ -46,17 +46,32 @@ var cardMinBlockSize = 18;
46
46
  var cardMaxBlockSize = 30;
47
47
 
48
48
  // src/fragments/density.ts
49
- var coarseBlockSize = "min-h-[2.5rem]";
50
- var coarseDimensions = `${coarseBlockSize} px-3`;
51
49
  var fineBlockSize = "min-h-[2.5rem] pointer-fine:min-h-[2rem]";
50
+ var coarseBlockSize = "min-h-[2.5rem]";
52
51
  var fineDimensions = `${fineBlockSize} px-2`;
53
- var densityBlockSize = (density = "coarse") => density === "fine" ? fineBlockSize : coarseBlockSize;
52
+ var coarseDimensions = `${coarseBlockSize} px-3`;
53
+ var densityDimensions = (density = "fine") => density === "fine" ? fineDimensions : coarseDimensions;
54
+ var densityBlockSize = (density = "fine") => density === "fine" ? fineBlockSize : coarseBlockSize;
54
55
 
55
56
  // src/fragments/disabled.ts
56
57
  var staticDisabled = "opacity-40 cursor-not-allowed shadow-none";
57
58
  var dataDisabled = "data-[disabled]:opacity-40 data-[disabled]:cursor-not-allowed";
58
59
 
59
- // src/fragments/elevation.ts
60
+ // src/fragments/hover.ts
61
+ var subtleHover = "hover:bg-hover-overlay";
62
+ var ghostHover = "hover:bg-hover-surface";
63
+ var ghostFocusWithin = "focus-within:bg-hover-surface";
64
+ var hoverableControls = "[--controls-opacity:1] hover-hover:[--controls-opacity:0] hover-hover:hover:[--controls-opacity:1]";
65
+ var groupHoverControlItemWithTransition = "transition-opacity duration-200 opacity-0 group-hover:opacity-100";
66
+ var hoverableFocusedKeyboardControls = "focus-visible:[--controls-opacity:1]";
67
+ var hoverableFocusedWithinControls = "focus-within:[--controls-opacity:1]";
68
+ var hoverableOpenControlItem = "hover-hover:aria-[expanded=true]:[--controls-opacity:1]";
69
+ var hoverableControlItem = "opacity-(--controls-opacity)";
70
+
71
+ // src/fragments/text.ts
72
+ var descriptionMessage = "text-description border border-dashed border-separator rounded-sm p-4";
73
+
74
+ // src/util/elevation.ts
60
75
  var surfaceShadow = ({ elevation }) => [
61
76
  elevation === "positioned" ? "shadow-sm" : elevation === "dialog" || elevation === "toast" ? "shadow-md" : "shadow-none"
62
77
  ];
@@ -89,22 +104,6 @@ var surfaceZIndex = ({ level, elevation }) => {
89
104
  }
90
105
  };
91
106
 
92
- // src/fragments/focus.ts
93
- var focusRing = "dx-focus-ring";
94
- var subduedFocus = "focus:outline-hidden focus-visible:outline-hidden focus:ring-0 ring-0 focus:border-0 border-0";
95
- var staticFocusRing = "ring-2 ring-offset-0 ring-primary-350 ring-offset-white dark:ring-primary-450 dark:ring-offset-black";
96
-
97
- // src/fragments/hover.ts
98
- var subtleHover = "hover:bg-hover-overlay";
99
- var ghostHover = "hover:bg-hover-surface";
100
- var ghostFocusWithin = "focus-within:bg-hover-surface";
101
- var hoverableControls = "[--controls-opacity:1] hover-hover:[--controls-opacity:0] hover-hover:hover:[--controls-opacity:1]";
102
- var groupHoverControlItemWithTransition = "transition-opacity duration-200 opacity-0 group-hover:opacity-100";
103
- var hoverableFocusedKeyboardControls = "focus-visible:[--controls-opacity:1]";
104
- var hoverableFocusedWithinControls = "focus-within:[--controls-opacity:1]";
105
- var hoverableOpenControlItem = "hover-hover:aria-[expanded=true]:[--controls-opacity:1]";
106
- var hoverableControlItem = "opacity-(--controls-opacity)";
107
-
108
107
  // src/util/hash-styles.ts
109
108
  var neutral = {
110
109
  hue: "neutral",
@@ -268,7 +267,10 @@ var getHashHue = (id) => {
268
267
  var getHash = (id) => id.split("").reduce((acc, char) => acc + char.charCodeAt(0), 0);
269
268
 
270
269
  // src/util/mx.ts
270
+ import { Children, createElement, forwardRef, isValidElement } from "react";
271
271
  import { extendTailwindMerge, validators } from "tailwind-merge";
272
+ import { log } from "@dxos/log";
273
+ var __dxlog_file = "/__w/dxos/dxos/packages/ui/ui-theme/src/util/mx.ts";
272
274
  var mx = extendTailwindMerge({
273
275
  extend: {
274
276
  classGroups: {
@@ -313,334 +315,240 @@ var mx = extendTailwindMerge({
313
315
  }
314
316
  }
315
317
  });
316
- var composableProps = ({ className, classNames, ...props }, { className: defaultClassNames, ...defaults } = {}) => ({
318
+ var composableProps = ({ className, classNames, role, style, ...props }, { classNames: defaultClassNames, ...defaults } = {}) => ({
319
+ // Default props.
317
320
  ...defaults,
321
+ // Spread supplied props.
318
322
  ...props,
323
+ // Prefer explicit role, then defaults role, then 'none'.
324
+ role: role ?? defaults.role ?? "none",
325
+ // Merge styles.
326
+ style: {
327
+ ...defaults.style,
328
+ ...style
329
+ },
330
+ // Compose classnames.
319
331
  className: mx(defaultClassNames, className, classNames)
320
332
  });
333
+ var COMPOSABLE = /* @__PURE__ */ Symbol.for("dxos.composable");
334
+ function slottable(render) {
335
+ const wrapped = (props, forwardedRef) => {
336
+ let warn = false;
337
+ if (props.asChild) {
338
+ try {
339
+ const child = Children.only(props.children);
340
+ if (isValidElement(child) && typeof child.type !== "string" && !child.type[COMPOSABLE]) {
341
+ warn = true;
342
+ log.warn("slot child is not composable; create it with composable() or slottable()", {
343
+ child: child.type.displayName ?? child.type.name
344
+ }, {
345
+ F: __dxlog_file,
346
+ L: 125,
347
+ S: this,
348
+ C: (f, a) => f(...a)
349
+ });
350
+ }
351
+ } catch {
352
+ }
353
+ }
354
+ const result = render(props, forwardedRef);
355
+ if (warn) {
356
+ return createElement("div", {
357
+ role: "none",
358
+ className: "dx-slot-warning"
359
+ }, result);
360
+ }
361
+ return result;
362
+ };
363
+ const component = forwardRef(wrapped);
364
+ component[COMPOSABLE] = true;
365
+ return component;
366
+ }
367
+ function composable(render) {
368
+ const component = forwardRef(render);
369
+ component[COMPOSABLE] = true;
370
+ return component;
371
+ }
321
372
 
322
- // src/fragments/size.ts
323
- var sizeWidthMap = /* @__PURE__ */ new Map([
324
- [
325
- 0,
326
- "w-0"
327
- ],
328
- [
329
- "px",
330
- "w-px"
331
- ],
332
- [
333
- 0.5,
334
- "w-0.5"
335
- ],
336
- [
337
- 1,
338
- "w-1"
339
- ],
340
- [
341
- 1.5,
342
- "w-1.5"
343
- ],
344
- [
345
- 2,
346
- "w-2"
347
- ],
348
- [
349
- 2.5,
350
- "w-2.5"
351
- ],
352
- [
353
- 3,
354
- "w-3"
355
- ],
356
- [
357
- 3.5,
358
- "w-3.5"
359
- ],
360
- [
361
- 4,
362
- "w-4"
363
- ],
364
- [
365
- 5,
366
- "w-5"
367
- ],
368
- [
369
- 6,
370
- "w-6"
371
- ],
372
- [
373
- 7,
374
- "w-7"
375
- ],
376
- [
377
- 8,
378
- "w-8"
379
- ],
380
- [
381
- 9,
382
- "w-9"
383
- ],
384
- [
385
- 10,
386
- "w-10"
387
- ],
388
- [
389
- 11,
390
- "w-11"
391
- ],
392
- [
393
- 12,
394
- "w-12"
395
- ],
396
- [
397
- 14,
398
- "w-14"
399
- ],
400
- [
401
- 16,
402
- "w-16"
403
- ],
404
- [
405
- 20,
406
- "w-20"
407
- ],
408
- [
409
- 24,
410
- "w-24"
411
- ],
412
- [
413
- 28,
414
- "w-28"
415
- ],
416
- [
417
- 32,
418
- "w-32"
419
- ],
420
- [
421
- 36,
422
- "w-36"
423
- ],
424
- [
425
- 40,
426
- "w-40"
427
- ],
428
- [
429
- 44,
430
- "w-44"
431
- ],
432
- [
433
- 48,
434
- "w-48"
435
- ],
436
- [
437
- 52,
438
- "w-52"
439
- ],
440
- [
441
- 56,
442
- "w-56"
443
- ],
444
- [
445
- 60,
446
- "w-60"
447
- ],
448
- [
449
- 64,
450
- "w-64"
451
- ],
452
- [
453
- 72,
454
- "w-72"
455
- ],
456
- [
457
- 80,
458
- "w-80"
459
- ],
460
- [
461
- 96,
462
- "w-96"
463
- ]
464
- ]);
465
- var sizeHeightMap = /* @__PURE__ */ new Map([
466
- [
467
- 0,
468
- "h-0"
469
- ],
470
- [
471
- "px",
472
- "h-px"
473
- ],
474
- [
475
- 0.5,
476
- "h-0.5"
477
- ],
478
- [
479
- 1,
480
- "h-1"
481
- ],
482
- [
483
- 1.5,
484
- "h-1.5"
485
- ],
486
- [
487
- 2,
488
- "h-2"
489
- ],
490
- [
491
- 2.5,
492
- "h-2.5"
493
- ],
494
- [
495
- 3,
496
- "h-3"
497
- ],
498
- [
499
- 3.5,
500
- "h-3.5"
501
- ],
502
- [
503
- 4,
504
- "h-4"
505
- ],
506
- [
507
- 5,
508
- "h-5"
509
- ],
510
- [
511
- 6,
512
- "h-6"
513
- ],
514
- [
515
- 7,
516
- "h-7"
517
- ],
518
- [
519
- 8,
520
- "h-8"
521
- ],
522
- [
523
- 9,
524
- "h-9"
525
- ],
526
- [
527
- 10,
528
- "h-10"
529
- ],
530
- [
531
- 11,
532
- "h-11"
533
- ],
534
- [
535
- 12,
536
- "h-12"
537
- ],
538
- [
539
- 14,
540
- "h-14"
541
- ],
542
- [
543
- 16,
544
- "h-16"
545
- ],
546
- [
547
- 20,
548
- "h-20"
549
- ],
550
- [
551
- 24,
552
- "h-24"
553
- ],
554
- [
555
- 28,
556
- "h-28"
557
- ],
558
- [
559
- 32,
560
- "h-32"
561
- ],
562
- [
563
- 36,
564
- "h-36"
565
- ],
566
- [
567
- 40,
568
- "h-40"
569
- ],
570
- [
571
- 44,
572
- "h-44"
573
- ],
574
- [
575
- 48,
576
- "h-48"
577
- ],
578
- [
579
- 52,
580
- "h-52"
581
- ],
582
- [
583
- 56,
584
- "h-56"
585
- ],
586
- [
587
- 60,
588
- "h-60"
589
- ],
590
- [
591
- 64,
592
- "h-64"
593
- ],
594
- [
595
- 72,
596
- "h-72"
597
- ],
598
- [
599
- 80,
600
- "h-80"
601
- ],
602
- [
603
- 96,
604
- "h-96"
605
- ]
606
- ]);
607
- var sizes = new Set(sizeWidthMap.keys());
608
- var getSizeHeight = sizeHeightMap.get.bind(sizeHeightMap);
609
- var getSizeWidth = sizeWidthMap.get.bind(sizeWidthMap);
610
- var getSize = (size) => mx(getSizeHeight(size), getSizeWidth(size));
611
- var computeSize = (value, defaultSize) => {
612
- if (sizes.has(value)) {
373
+ // src/util/size.ts
374
+ var sizeMap = {
375
+ 0: {
376
+ w: "w-0",
377
+ h: "h-0"
378
+ },
379
+ px: {
380
+ w: "w-px",
381
+ h: "h-px"
382
+ },
383
+ 0.5: {
384
+ w: "w-0.5",
385
+ h: "h-0.5"
386
+ },
387
+ 1: {
388
+ w: "w-1",
389
+ h: "h-1"
390
+ },
391
+ 1.5: {
392
+ w: "w-1.5",
393
+ h: "h-1.5"
394
+ },
395
+ 2: {
396
+ w: "w-2",
397
+ h: "h-2"
398
+ },
399
+ 2.5: {
400
+ w: "w-2.5",
401
+ h: "h-2.5"
402
+ },
403
+ 3: {
404
+ w: "w-3",
405
+ h: "h-3"
406
+ },
407
+ 3.5: {
408
+ w: "w-3.5",
409
+ h: "h-3.5"
410
+ },
411
+ 4: {
412
+ w: "w-4",
413
+ h: "h-4"
414
+ },
415
+ 5: {
416
+ w: "w-5",
417
+ h: "h-5"
418
+ },
419
+ 6: {
420
+ w: "w-6",
421
+ h: "h-6"
422
+ },
423
+ 7: {
424
+ w: "w-7",
425
+ h: "h-7"
426
+ },
427
+ 8: {
428
+ w: "w-8",
429
+ h: "h-8"
430
+ },
431
+ 9: {
432
+ w: "w-9",
433
+ h: "h-9"
434
+ },
435
+ 10: {
436
+ w: "w-10",
437
+ h: "h-10"
438
+ },
439
+ 11: {
440
+ w: "w-11",
441
+ h: "h-11"
442
+ },
443
+ 12: {
444
+ w: "w-12",
445
+ h: "h-12"
446
+ },
447
+ 14: {
448
+ w: "w-14",
449
+ h: "h-14"
450
+ },
451
+ 16: {
452
+ w: "w-16",
453
+ h: "h-16"
454
+ },
455
+ 20: {
456
+ w: "w-20",
457
+ h: "h-20"
458
+ },
459
+ 24: {
460
+ w: "w-24",
461
+ h: "h-24"
462
+ },
463
+ 28: {
464
+ w: "w-28",
465
+ h: "h-28"
466
+ },
467
+ 32: {
468
+ w: "w-32",
469
+ h: "h-32"
470
+ },
471
+ 36: {
472
+ w: "w-36",
473
+ h: "h-36"
474
+ },
475
+ 40: {
476
+ w: "w-40",
477
+ h: "h-40"
478
+ },
479
+ 44: {
480
+ w: "w-44",
481
+ h: "h-44"
482
+ },
483
+ 48: {
484
+ w: "w-48",
485
+ h: "h-48"
486
+ },
487
+ 52: {
488
+ w: "w-52",
489
+ h: "h-52"
490
+ },
491
+ 56: {
492
+ w: "w-56",
493
+ h: "h-56"
494
+ },
495
+ 60: {
496
+ w: "w-60",
497
+ h: "h-60"
498
+ },
499
+ 64: {
500
+ w: "w-64",
501
+ h: "h-64"
502
+ },
503
+ 72: {
504
+ w: "w-72",
505
+ h: "h-72"
506
+ },
507
+ 80: {
508
+ w: "w-80",
509
+ h: "h-80"
510
+ },
511
+ 96: {
512
+ w: "w-96",
513
+ h: "h-96"
514
+ }
515
+ };
516
+ var SIZE_VALUES = Object.keys(sizeMap).map((key) => key === "px" ? "px" : Number(key));
517
+ var getHeight = (size) => sizeMap[size]?.h;
518
+ var getWidth = (size) => sizeMap[size]?.w;
519
+ var getSize = (size) => mx(getHeight(size), getWidth(size));
520
+ var sizeValue = (size) => size === "px" ? 1 : size;
521
+ var sizeToRem = (size) => size === "px" ? "1px" : `${size * 0.25}rem`;
522
+ var iconSize = (size) => ({
523
+ "--icon-size": size ? sizeToRem(size) : "initial"
524
+ });
525
+ var snapSize = (value, defaultSize) => {
526
+ if (SIZE_VALUES.includes(value)) {
613
527
  return value;
614
528
  } else if (value <= 0) {
615
529
  return 0;
616
- } else if (value === 1) {
530
+ } else if (value < 0.5) {
617
531
  return "px";
618
532
  } else {
619
533
  const wholeSeries = Math.floor(value);
620
534
  const halfSeries = Math.floor(value * 2) / 2;
621
535
  const doubleSeries = Math.floor(value / 2) * 2;
622
536
  const quadrupleSeries = Math.floor(value / 4) * 4;
623
- if (sizes.has(halfSeries)) {
537
+ if (SIZE_VALUES.includes(halfSeries)) {
624
538
  return halfSeries;
625
- } else if (sizes.has(wholeSeries)) {
539
+ } else if (SIZE_VALUES.includes(wholeSeries)) {
626
540
  return wholeSeries;
627
- } else if (sizes.has(doubleSeries)) {
541
+ } else if (SIZE_VALUES.includes(doubleSeries)) {
628
542
  return doubleSeries;
629
- } else if (sizes.has(quadrupleSeries)) {
543
+ } else if (SIZE_VALUES.includes(quadrupleSeries)) {
630
544
  return quadrupleSeries;
631
545
  } else {
632
546
  return defaultSize;
633
547
  }
634
548
  }
635
549
  };
636
- var sizeValue = (size) => size === "px" ? 1 : size;
637
-
638
- // src/fragments/text.ts
639
- var textBlockWidth = "w-full max-w-text-content mx-auto";
640
- var descriptionTextPrimary = "text-sm font-normal text-base-surface-text";
641
- var descriptionMessage = "text-description border border-dashed border-separator rounded-sm p-4";
642
550
 
643
- // src/fragments/valence.ts
551
+ // src/util/valence.ts
644
552
  var textValence = (valence) => {
645
553
  switch (valence) {
646
554
  case "success":
@@ -672,12 +580,12 @@ var messageValence = (valence) => {
672
580
  var avatarRoot = ({ size = 10, inGroup }, ...etc) => mx("relative inline-flex shrink-0", getSize(size), inGroup && (size === "px" || size <= 3 ? "-mr-1" : "-mr-2"), ...etc);
673
581
  var avatarLabel = ({ srOnly }, ...etc) => mx(srOnly && "sr-only", ...etc);
674
582
  var avatarDescription = ({ srOnly }, ...etc) => mx("text-description", srOnly && "sr-only", ...etc);
675
- var avatarFrame = ({ variant }, ...etc) => mx("w-full h-full bg-(--surface-bg)", variant === "circle" ? "rounded-full" : "rounded-sm", ...etc);
583
+ var avatarFrame = ({ variant }, ...etc) => mx("h-full w-full bg-(--surface-bg)", variant === "circle" ? "rounded-full" : "rounded-sm", ...etc);
676
584
  var avatarStatusIcon = ({ status, size = 3 }, ...etc) => mx("absolute bottom-0 end-0", getSize(size), status === "inactive" ? "text-amber-400 dark:text-amber-300" : status === "active" ? "text-emerald-400 dark:text-emerald-300" : "text-neutral-400 dark:text-neutral-300", ...etc);
677
585
  var avatarRing = ({ status, variant, animation }, ...etc) => mx("absolute inset-0 border-2", variant === "circle" ? "rounded-full" : "rounded-sm", status === "current" ? "border-primary-400 dark:border-primary-500" : status === "active" ? "border-emerald-400 dark:border-emerald-400" : status === "error" ? "border-rose-400 dark:border-rose-500" : status === "warning" ? "border-amber-400 dark:border-amber-500" : status === "inactive" ? "border-separator" : status === "internal" ? "border-fuchsia-600" : "border-[color:var(--surface-bg)]", animation === "pulse" ? "animate-halo-pulse" : "", ...etc);
678
586
  var avatarFallbackText = (_props, ...etc) => mx("fill-white", ...etc);
679
587
  var avatarGroup = (_props, ...etc) => mx("inline-flex items-center", ...etc);
680
- var avatarGroupLabel = ({ size, srOnly }, ...etc) => mx(srOnly ? "sr-only" : "rounded-full truncate text-sm leading-none py-1 px-2 relative z-[1] flex items-center justify-center", size && getSizeHeight(size), ...etc);
588
+ var avatarGroupLabel = ({ size, srOnly }, ...etc) => mx(srOnly ? "sr-only" : "rounded-full truncate text-sm leading-none py-1 px-2 relative z-[1] flex items-center justify-center", size && getHeight(size), ...etc);
681
589
  var avatarGroupDescription = ({ srOnly }, ...etc) => mx(srOnly ? "sr-only" : "text-description", ...etc);
682
590
  var avatarTheme = {
683
591
  root: avatarRoot,
@@ -707,12 +615,12 @@ var breadcrumbTheme = {
707
615
  };
708
616
 
709
617
  // src/theme/components/card.ts
710
- var cardRoot = ({ border, fullWidth }, ...etc) => mx("dx-card group/card relative flex flex-col w-full min-h-(--dx-rail-item) dx-card-min-width overflow-hidden", border && "bg-card-surface border border-separator dark:border-subdued-separator rounded-xs dx-focus-ring-group-y-indicator", fullWidth && "max-w-none!", ...etc);
711
- var cardToolbar = ({ coarse }, ...etc) => mx("dx-card__toolbar dx-density-fine bg-transparent col-span-3 !grid grid-cols-subgrid [contain:none]", coarse && "grid-cols-[var(--dx-l0-avatar-size)_minmax(0,1fr)_var(--dx-rail-item)]", ...etc);
618
+ var cardRoot = ({ border, fullWidth }, ...etc) => mx("dx-card dx-card-min-width dx-card-max-width min-h-(--dx-rail-item) group/card relative overflow-hidden", border && "bg-card-surface border border-separator dark:border-subdued-separator rounded-xs dx-focus-ring-group-y-indicator", fullWidth && "max-w-none!", ...etc);
619
+ var cardToolbar = (_, ...etc) => mx("dx-card__toolbar dx-density-fine bg-transparent p-0! gap-0! col-span-3 grid! grid-cols-subgrid! [contain:none]", ...etc);
712
620
  var cardTitle = (_props, ...etc) => mx("dx-card__title grow truncate", ...etc);
713
- var cardContent = (_props, ...etc) => mx("dx-card__content contents [&>:last-child]:pb-1", ...etc);
621
+ var cardContent = (_props, ...etc) => mx("dx-card__content contents pb-1 last:pb-0", ...etc);
714
622
  var cardHeading = ({ variant = "default" }, ...etc) => mx("dx-card__heading", variant === "default" && "py-1", variant === "subtitle" && "py-2 text-xs text-description font-medium uppercase", ...etc);
715
- var cardText = ({ variant = "default", truncate: _truncate }, ...etc) => mx("dx-card__text flex overflow-hidden", variant === "default" && "py-1", variant === "description" && "py-1.5", ...etc);
623
+ var cardText = ({ variant = "default", truncate: _truncate }, ...etc) => mx("dx-card__text items-center overflow-hidden", variant === "default" && "py-1", variant === "description" && "py-1.5 text-description", ...etc);
716
624
  var cardTextSpan = ({ variant = "default", truncate }, ...etc) => mx(variant === "description" && "text-sm text-description line-clamp-3", truncate && "truncate", ...etc);
717
625
  var cardPoster = (_props, ...etc) => mx("dx-card__poster col-span-3 max-h-[200px]", ...etc);
718
626
  var cardPosterIcon = (_props, ...etc) => mx("dx-card__poster-icon col-span-3 grid place-items-center bg-input-surface text-subdued max-h-[200px]", ...etc);
@@ -720,12 +628,14 @@ var cardAction = (_props, ...etc) => mx("dx-card__acztion col-span-3 !grid grid-
720
628
  var cardActionLabel = (_props, ...etc) => mx("dx-card__action-label min-w-0 flex-1 truncate", ...etc);
721
629
  var cardLink = (_props, ...etc) => mx("dx-card__link col-span-3 !grid grid-cols-subgrid group p-0! dx-button dx-focus-ring min-h-1!", ...etc);
722
630
  var cardLinkLabel = (_props, ...etc) => mx("dx-card__link-label min-w-0 flex-1 truncate", ...etc);
723
- var cardIconBlock = (_props, ...etc) => mx("dx-card__icon-block grid h-[var(--dx-rail-item)] w-[var(--dx-rail-item)] place-items-center", ...etc);
631
+ var cardRow = (_, ...etc) => mx("dx-card__row col-span-3 grid grid-cols-subgrid", ...etc);
632
+ var cardIconBlock = ({ padding }, ...etc) => mx("dx-card__icon-block grid h-[var(--dx-rail-item)] w-[var(--dx-rail-item)] place-items-center", padding && "[&>*]:p-1", ...etc);
724
633
  var cardTheme = {
725
634
  root: cardRoot,
726
635
  toolbar: cardToolbar,
727
636
  title: cardTitle,
728
637
  content: cardContent,
638
+ row: cardRow,
729
639
  heading: cardHeading,
730
640
  text: cardText,
731
641
  "text-span": cardTextSpan,
@@ -744,7 +654,7 @@ var staticDefaultButtonColors = "bg-input-surface text-input-surface-text";
744
654
  var defaultButtonColors = mx(staticDefaultButtonColors, "data-[state=open]:bg-input-surface aria-pressed:text-accent-text aria-pressed:bg-base-surface aria-checked:text-accent-text aria-checked:bg-base-surface");
745
655
  var ghostButtonColors = mx(ghostHover, "hover:text-inherit data-[state=open]:bg-input-surface aria-pressed:text-accent-text aria-pressed:bg-base-surface aria-checked:text-accent-text aria-checked:bg-base-surface");
746
656
  var buttonRoot = (_props, ...etc) => {
747
- return mx("dx-button dx-focus-ring group max-w-full [&_span]:truncate", ...etc);
657
+ return mx("dx-button dx-focus-ring group [&_span]:truncate", ...etc);
748
658
  };
749
659
  var buttonGroup = (_props, ...etc) => {
750
660
  return mx("inline-flex rounded-xs [&>:first-child]:rounded-w-sm [&>:last-child]:rounded-ie-sm [&>button]:relative", ...etc);
@@ -754,8 +664,37 @@ var buttonTheme = {
754
664
  group: buttonGroup
755
665
  };
756
666
 
667
+ // src/theme/primitives/column.ts
668
+ var withColumn = {
669
+ /** Centers element in the Column grid via --dx-col. No-op outside Column or inside ScrollArea. */
670
+ center: () => "[grid-column:var(--dx-col,auto)]",
671
+ /** Propagates the Column grid to children via subgrid. No-op outside Column.
672
+ * Direct children default to center column unless they are a dx-container (ScrollArea). */
673
+ propagate: () => "[.dx-column-root_&]:col-span-full [.dx-column-root_&]:grid [.dx-column-root_&]:grid-cols-subgrid [.dx-column-root_&]:[&>*:not(.dx-container)]:[grid-column:var(--dx-col,auto)]",
674
+ /** Resets --dx-col after consuming --gutter. Applied by ScrollArea.Viewport. */
675
+ consumed: () => "[--dx-col:auto]"
676
+ };
677
+ var columnRoot = (_, ...etc) => {
678
+ return mx("dx-column-root grid", ...etc);
679
+ };
680
+ var columnRow = (_, ...etc) => {
681
+ return mx("col-span-3 grid grid-cols-subgrid", ...etc);
682
+ };
683
+ var columnBleed = (_, ...etc) => {
684
+ return mx("col-span-full grid grid-cols-subgrid min-h-0", ...etc);
685
+ };
686
+ var columnCenter = (_, ...etc) => {
687
+ return mx(withColumn.center(), "min-h-0", ...etc);
688
+ };
689
+ var columnTheme = {
690
+ root: columnRoot,
691
+ row: columnRow,
692
+ bleed: columnBleed,
693
+ center: columnCenter
694
+ };
695
+
757
696
  // src/theme/components/dialog.ts
758
- var sizeMap = {
697
+ var sizeMap2 = {
759
698
  sm: "md:max-w-[24rem]",
760
699
  md: "md:max-w-[32rem]!",
761
700
  lg: "md:max-w-[40rem]!",
@@ -763,11 +702,11 @@ var sizeMap = {
763
702
  };
764
703
  var dialogOverlay = (_props, ...etc) => mx("dx-dialog__overlay", ...etc);
765
704
  var dialogContent = ({ inOverlayLayout, size = "md" }, ...etc) => {
766
- return mx("@container", "dx-dialog__content dx-focus-ring dx-modal-surface dx-density-coarse py-4", !inOverlayLayout && "fixed z-50 top-[50%] left-[50%] -translate-x-[50%] -translate-y-[50%]", sizeMap[size], ...etc);
705
+ return mx("@container", "dx-dialog__content dx-focus-ring dx-modal-surface dx-density-coarse py-4", !inOverlayLayout && "fixed z-50 top-[50%] left-[50%] -translate-x-[50%] -translate-y-[50%]", sizeMap2[size], ...etc);
767
706
  };
768
- var dialogHeader = (_props, ...etc) => mx("dx-dialog__header flex pb-4 items-center justify-between", ...etc);
769
- var dialogBody = (_props, ...etc) => mx("dx-dialog__body flex flex-col h-full py-2 gap-2", ...etc);
770
- var dialogActionBar = (_props, ...etc) => mx("dx-dialog__actionbar flex items-center pt-4 gap-2 dx-density-coarse", ...etc);
707
+ var dialogHeader = (_props, ...etc) => mx("dx-dialog__header flex pb-4 items-center justify-between", withColumn.center(), ...etc);
708
+ var dialogBody = (_props, ...etc) => mx("dx-dialog__body dx-expander", withColumn.propagate(), ...etc);
709
+ var dialogActionBar = (_props, ...etc) => mx("dx-dialog__actionbar flex items-center pt-4 gap-2 dx-density-coarse", withColumn.center(), ...etc);
771
710
  var dialogTitle = ({ srOnly }, ...etc) => mx("dx-dialog__title", srOnly && "sr-only", ...etc);
772
711
  var dialogDescription = ({ srOnly }, ...etc) => mx("dx-dialog__description", "text-description", srOnly && "sr-only", ...etc);
773
712
  var dialogTheme = {
@@ -780,15 +719,24 @@ var dialogTheme = {
780
719
  description: dialogDescription
781
720
  };
782
721
 
722
+ // src/theme/components/focus.ts
723
+ var focusRing = ({ border }, ...etc) => mx("dx-ring-pseudo outline-hidden", "focus:after:ring-neutral-focus-indicator", "data-[focus-state=active]:after:ring-neutral-focus-indicator", "data-[focus-state=error]:after:ring-rose-500", border && "border border-separator", ...etc);
724
+ var focusTheme = {
725
+ group: focusRing,
726
+ item: focusRing
727
+ };
728
+
783
729
  // src/theme/components/icon.ts
784
- var iconRoot = ({ size }, etc) => mx("shrink-0 h-[1em] w-[1em] text-[var(--icons-color,currentColor)]", size && getSize(size), etc);
730
+ var iconRoot = ({ size }, etc) => {
731
+ return mx("shrink-0 text-[var(--icons-color,currentColor)]", size ? getSize(size) : "[width:var(--icon-size,var(--dx-default-icons-size))] [height:var(--icon-size,var(--dx-default-icons-size))]", etc);
732
+ };
785
733
  var iconTheme = {
786
734
  root: iconRoot
787
735
  };
788
736
 
789
737
  // src/theme/components/icon-button.ts
790
738
  var iconButtonRoot = ({ iconOnly }, ...etc) => {
791
- return mx("gap-2", iconOnly && "p-icon-button-padding min-h-0", ...etc);
739
+ return mx("px-1.5", !iconOnly && "gap-2", ...etc);
792
740
  };
793
741
  var iconButtonTheme = {
794
742
  root: iconButtonRoot
@@ -813,44 +761,41 @@ var inputValence = (valence) => {
813
761
  }
814
762
  };
815
763
  var sharedSubduedInputStyles = (props) => [
816
- "py-0 w-full bg-transparent text-current placeholder-placeholder",
817
764
  '[[data-drag-autoscroll="active"]_&]:pointer-events-none',
818
- props.density === "fine" ? fineBlockSize : coarseBlockSize,
819
- subduedFocus,
765
+ "py-0 w-full bg-transparent text-current placeholder-placeholder",
766
+ "dx-focus-subdued",
767
+ densityDimensions(props.density),
820
768
  props.disabled && staticDisabled
821
769
  ];
822
770
  var sharedDefaultInputStyles = (props) => [
823
- "py-0 w-full text-base-surface-text rounded-xs placeholder-placeholder",
824
771
  '[[data-drag-autoscroll="active"]_&]:pointer-events-none',
772
+ "py-0 w-full text-base-surface-text rounded-xs placeholder-placeholder",
825
773
  textInputSurfaceFocus,
826
- props.density === "fine" ? fineDimensions : coarseDimensions,
774
+ densityDimensions(props.density),
827
775
  props.disabled ? staticDisabled : textInputSurfaceHover
828
776
  ];
829
777
  var sharedStaticInputStyles = (props) => [
830
- "py-0 w-full text-base-surface-text rounded-xs placeholder-placeholder",
831
778
  '[[data-drag-autoscroll="active"]_&]:pointer-events-none',
779
+ "py-0 w-full text-base-surface-text rounded-xs placeholder-placeholder",
832
780
  textInputSurfaceFocus,
833
781
  textInputSurfaceHover,
834
782
  props.focused && "bg-attention-surface",
835
783
  inputValence(props.validationValence),
836
784
  props.disabled && staticDisabled,
837
- props.focused && staticFocusRing
785
+ props.focused && "dx-focus-static"
838
786
  ];
839
- var inputInput = (props, ...etc) => props.variant === "subdued" ? mx(...sharedSubduedInputStyles(props), ...etc) : props.variant === "static" ? mx(...sharedStaticInputStyles(props), ...etc) : mx(...sharedDefaultInputStyles(props), !props.disabled && focusRing, inputValence(props.validationValence), ...etc);
840
- var inputTextArea = (props, ...etc) => inputInput(props, ...[
841
- "-mb-1.5",
842
- ...etc
843
- ]);
787
+ var inputInput = (props, ...etc) => props.variant === "subdued" ? mx(...sharedSubduedInputStyles(props), ...etc) : props.variant === "static" ? mx(...sharedStaticInputStyles(props), ...etc) : mx(...sharedDefaultInputStyles(props), !props.disabled && "dx-focus-ring", inputValence(props.validationValence), ...etc);
788
+ var inputTextArea = (props, ...etc) => inputInput(props, ...etc);
844
789
  var inputCheckbox = ({ size = 5 }, ...etc) => mx("dx-checkbox dx-focus-ring", getSize(size), ...etc);
845
- var inputCheckboxIndicator = ({ size = 5, checked }, ...etc) => mx(getSize(computeSize(sizeValue(size) * 0.65, 4)), !checked && "invisible", ...etc);
790
+ var inputCheckboxIndicator = ({ size = 5, checked }, ...etc) => mx(getSize(snapSize(sizeValue(size) * 0.65, 4)), !checked && "invisible", ...etc);
846
791
  var inputSwitch = ({ size = 5, disabled }, ...etc) => mx(
847
- getSizeHeight(size),
848
- getSizeWidth(computeSize(sizeValue(size) * 1.75, 9)),
792
+ getHeight(size),
793
+ getWidth(snapSize(sizeValue(size) * 1.75, 9)),
849
794
  booleanInputSurface,
850
795
  !disabled && booleanInputSurfaceHover,
851
796
  // TODO(burdon): Added m-1 margin to make 40px width to align with 40px icon button.
852
797
  "cursor-pointer shrink-0 rounded-full px-1 mx-1 relative",
853
- focusRing,
798
+ "dx-focus-ring",
854
799
  ...etc
855
800
  );
856
801
  var inputSwitchThumb = ({ size = 5 }, ...etc) => mx(getSize(size === "px" ? "px" : size - 2), "block bg-white rounded-full transition-transform duration-100 will-change-transform data-[state=checked]:translate-x-[100%]", ...etc);
@@ -876,7 +821,7 @@ var inputTheme = {
876
821
  };
877
822
 
878
823
  // src/theme/components/link.ts
879
- var linkRoot = ({ variant }, ...etc) => mx("underline decoration-1 underline-offset-2 transition-color rounded-xs", variant === "neutral" ? "text-inherit hover:opacity-90 visited:text-inherit visited:hover:opacity-90" : "text-accent-text hover:text-accent-text-hover visited:text-accent-text visited:hover:text-accent-text-hover", focusRing, ...etc);
824
+ var linkRoot = ({ variant }, ...etc) => mx("underline decoration-1 underline-offset-2 transition-color rounded-xs", variant === "neutral" ? "text-inherit hover:opacity-90 visited:text-inherit visited:hover:opacity-90" : "text-accent-text hover:text-accent-text-hover visited:text-accent-text visited:hover:text-accent-text-hover", "dx-focus-ring", ...etc);
880
825
  var linkTheme = {
881
826
  root: linkRoot
882
827
  };
@@ -885,9 +830,9 @@ var linkTheme = {
885
830
  var listRoot = (_, ...etc) => mx(...etc);
886
831
  var listItem = ({ collapsible }, ...etc) => mx(!collapsible && "flex", ...etc);
887
832
  var listItemEndcap = ({ density }, ...etc) => mx(density === "fine" ? getSize(8) : getSize(10), "shrink-0 flex items-center justify-center", ...etc);
888
- var listItemHeading = ({ density }, ...etc) => mx(densityBlockSize(density), "flex items-center", ...etc);
833
+ var listItemHeading = ({ density }, ...etc) => mx(densityBlockSize(density), "flex items-center overflow-hidden [&>span]:truncate", ...etc);
889
834
  var listItemDragHandleIcon = (_props, ...etc) => mx(getSize(5), "mt-2.5", ...etc);
890
- var listItemOpenTrigger = ({ density }, ...etc) => mx("w-5 rounded-sm flex justify-center items-center", densityBlockSize(density), ghostHover, focusRing, ...etc);
835
+ var listItemOpenTrigger = ({ density }, ...etc) => mx("w-5 rounded-sm flex justify-center items-center", densityBlockSize(density), ghostHover, "dx-focus-ring", ...etc);
891
836
  var listItemOpenTriggerIcon = (_props, ...etc) => {
892
837
  return mx(getSize(5), ...etc);
893
838
  };
@@ -926,7 +871,7 @@ var menuContent = ({ elevation }, ...etc) => mx("dx-modal-surface w-48 rounded-s
926
871
  elevation: "positioned"
927
872
  }), ...etc);
928
873
  var menuViewport = (_props, ...etc) => mx("rounded-sm p-1 max-h-[var(--radix-dropdown-menu-content-available-height)] overflow-y-auto", ...etc);
929
- var menuItem = (_props, ...etc) => mx("flex cursor-pointer select-none items-center gap-2 rounded-xs px-2 py-2 text-sm", "data-[highlighted]:bg-hover-surface", subduedFocus, dataDisabled, ...etc);
874
+ var menuItem = (_props, ...etc) => mx("flex cursor-pointer select-none items-center gap-2 rounded-xs px-2 py-2 text-sm", "hover:bg-hover-surface data-[highlighted]:bg-hover-surface", "dx-focus-subdued", dataDisabled, ...etc);
930
875
  var menuSeparator = (_props, ...etc) => mx("my-1 mx-2 h-px bg-separator", ...etc);
931
876
  var menuGroupLabel = (_props, ...etc) => mx("text-description", "select-none px-2 py-2", ...etc);
932
877
  var menuArrow = (_props, ...etc) => mx("fill-separator", ...etc);
@@ -947,7 +892,7 @@ var messageHeader = (_, etc) => {
947
892
  return mx("col-span-2 grid grid-cols-subgrid items-center", etc);
948
893
  };
949
894
  var messageTitle = (_, etc) => {
950
- return mx("col-start-2 text-lg gap-trim-sm [&>svg]:inline-block", etc);
895
+ return mx("col-start-2 gap-trim-sm [&>svg]:inline-block", etc);
951
896
  };
952
897
  var messageIcon = (_, etc) => {
953
898
  return mx("col-start-1", etc);
@@ -969,15 +914,8 @@ var popoverContent = ({ elevation }, ...etc) => mx("dx-modal-surface border bord
969
914
  }), surfaceZIndex({
970
915
  elevation,
971
916
  level: "menu"
972
- }), focusRing, ...etc);
973
- var popoverViewport = ({ constrainBlock, constrainInline }, ...etc) => mx(
974
- "flex flex-col min-h-0 min-w-popover-min-width",
975
- (constrainBlock || constrainInline) && "overflow-hidden",
976
- // Ensures it respects available height from Radix (or 100dvh).
977
- constrainBlock && "max-h-[min(var(--radix-popover-content-available-height),calc(100dvh-var(--spacing-screen-border)*2))]",
978
- constrainInline && "max-w-(--radix-popover-content-available-width)",
979
- ...etc
980
- );
917
+ }), "dx-focus-ring", ...etc);
918
+ var popoverViewport = ({ constrainBlock, constrainInline }, ...etc) => mx("grid grid-rows-[1fr] min-h-0 min-w-popover-min-width", (constrainBlock || constrainInline) && "overflow-hidden", constrainBlock && "max-h-(--radix-popover-content-available-height)", constrainBlock && "max-h-[min(var(--radix-popover-content-available-height),calc(100dvh-var(--spacing-screen-border)*2))]", constrainInline && "max-w-(--radix-popover-content-available-width)", ...etc);
981
919
  var popoverArrow = (_props, ...etc) => mx("fill-separator", ...etc);
982
920
  var popoverTheme = {
983
921
  content: popoverContent,
@@ -986,40 +924,66 @@ var popoverTheme = {
986
924
  };
987
925
 
988
926
  // src/theme/components/scroll-area.ts
989
- var scrollAreaRoot = ({ orientation, margin, thin }, ...etc) => mx(
990
- "overflow-hidden",
991
- orientation === "vertical" && "group/scroll-v dx-container",
992
- orientation === "horizontal" && "group/scroll-h dx-container",
993
- orientation === "all" && "group/scroll-all dx-container",
994
- // TODO(burdon): Audit composition.
995
- // Apply col-span-full only when inside a Column.Root grid (detected via dx-column marker).
996
- "[.dx-column_&]:col-span-full",
997
- // NOTE: Uses --gutter CSS variable
998
- // If contained within Column.Root grid, the gutter is set by that component.
999
- margin && [
1000
- orientation === "vertical" && (thin ? "pl-[var(--gutter,4px)] pr-[calc(var(--gutter,4px)-4px)]" : "pl-[var(--gutter,8px)] pr-[calc(var(--gutter,8px)-8px)]"),
1001
- orientation === "horizontal" && (thin ? "py-[var(--gutter,4px)]" : "py-[var(--gutter,8px)]"),
1002
- orientation === "all" && (thin ? "pl-[var(--gutter,4px)] py-[var(--gutter,8px)]" : "pl-[var(--gutter,8px)] py-[var(--gutter,8px)]")
1003
- ],
927
+ var scrollbar = {
928
+ thin: {
929
+ size: 4,
930
+ padding: 4
931
+ },
932
+ coarse: {
933
+ size: 8,
934
+ padding: 8
935
+ }
936
+ };
937
+ var scrollAreaRoot = ({ orientation }, ...etc) => mx(
938
+ // Expand
939
+ "dx-container",
940
+ orientation === "vertical" && "group/scroll-v flex flex-col",
941
+ orientation === "horizontal" && "group/scroll-h flex",
942
+ orientation === "all" && "group/scroll-all",
943
+ // Apply col-span-full only when inside a Column.Root grid (detected via dx-column-root marker).
944
+ "[.dx-column-root_&]:col-span-full",
1004
945
  ...etc
1005
946
  );
1006
- var scrollAreaViewport = ({ orientation, autoHide, padding, snap, thin }, ...etc) => mx("h-full w-full", orientation === "vertical" && "flex flex-col overflow-y-scroll", orientation === "horizontal" && "flex overflow-x-scroll", orientation === "all" && "overflow-scroll", thin ? "[&::-webkit-scrollbar]:w-[4px] [&::-webkit-scrollbar]:h-[4px]" : "[&::-webkit-scrollbar]:w-[8px] [&::-webkit-scrollbar]:h-[8px]", "[&::-webkit-scrollbar-corner]:bg-transparent", "[&::-webkit-scrollbar-track]:bg-transparent", "[&::-webkit-scrollbar-thumb]:rounded-none", autoHide ? [
1007
- orientation === "vertical" && "group-hover/scroll-v:[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb",
1008
- orientation === "horizontal" && "group-hover/scroll-h:[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb",
1009
- orientation === "all" && "group-hover/scroll-all:[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb"
1010
- ] : [
1011
- orientation === "vertical" && "[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb",
1012
- orientation === "horizontal" && "[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb",
1013
- orientation === "all" && "[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb"
1014
- ], padding && [
1015
- orientation === "vertical" && "px-[4px]",
1016
- orientation === "horizontal" && "pb-[4px]",
1017
- orientation === "all" && "pl-[4px] pb-[4px]"
1018
- ], snap && [
1019
- orientation === "vertical" && "snap-y snap-mandatory",
1020
- orientation === "horizontal" && "snap-x snap-mandatory",
1021
- orientation === "all" && "snap-both snap-mandatory"
1022
- ], ...etc);
947
+ var scrollAreaViewport = ({ orientation, centered, padding, snap, autoHide }, ...etc) => {
948
+ return mx(
949
+ "flex-1 min-h-0 w-full",
950
+ // Reset --dx-col so nested components don't try to grid-position themselves.
951
+ // ScrollArea has already consumed --gutter for padding.
952
+ withColumn.consumed(),
953
+ orientation === "vertical" && "overflow-y-scroll",
954
+ orientation === "horizontal" && "flex overflow-x-scroll overscroll-x-contain",
955
+ orientation === "all" && "overflow-scroll",
956
+ "[&::-webkit-scrollbar-corner]:bg-transparent",
957
+ "[&::-webkit-scrollbar-track]:bg-transparent",
958
+ "[&::-webkit-scrollbar-thumb]:rounded-none",
959
+ "[&::-webkit-scrollbar]:w-[var(--scroll-width)] [&::-webkit-scrollbar]:h-[var(--scroll-width)]",
960
+ // If contained within Column.Root grid the gutter is set by that component (--gutter CSS variable).
961
+ // If centered, left padding compensates for scrollbar width so content is visually centered.
962
+ (orientation === "vertical" || orientation === "all") && (padding ? [
963
+ centered ? "pl-[var(--gutter,calc(var(--scroll-width)+var(--scroll-padding)))]" : "pl-[var(--gutter,0)]",
964
+ "pr-[calc(var(--gutter,calc(var(--scroll-width)+var(--scroll-padding)))-var(--scroll-width))]"
965
+ ] : centered && "pl-[var(--scroll-width)]"),
966
+ (orientation === "horizontal" || orientation === "all") && (padding ? [
967
+ centered && "pt-[calc(var(--scroll-width)+var(--scroll-padding))]",
968
+ "pb-[var(--scroll-padding)]"
969
+ ] : centered && "pt-[var(--scroll-width)]"),
970
+ snap && [
971
+ orientation === "vertical" && "snap-y snap-mandatory",
972
+ orientation === "horizontal" && "snap-x snap-mandatory",
973
+ orientation === "all" && "snap-both snap-mandatory"
974
+ ],
975
+ autoHide ? [
976
+ orientation === "vertical" && "group-hover/scroll-v:[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb",
977
+ orientation === "horizontal" && "group-hover/scroll-h:[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb",
978
+ orientation === "all" && "group-hover/scroll-all:[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb"
979
+ ] : [
980
+ orientation === "vertical" && "[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb",
981
+ orientation === "horizontal" && "[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb",
982
+ orientation === "all" && "[&::-webkit-scrollbar-thumb]:bg-scrollbar-thumb"
983
+ ],
984
+ ...etc
985
+ );
986
+ };
1023
987
  var scrollAreaTheme = {
1024
988
  root: scrollAreaRoot,
1025
989
  viewport: scrollAreaViewport
@@ -1071,8 +1035,8 @@ var skeletonTheme = {
1071
1035
  };
1072
1036
 
1073
1037
  // src/theme/components/status.ts
1074
- var statusRoot = ({ variant = "default" }, ...etc) => mx("h-1 relative bg-hover-overlay rounded-full overflow-hidden", variant === "main-bottom" ? "w-full block" : "inline-20 inline-block", ...etc);
1075
- var statusBar = ({ indeterminate, variant = "default" }, ...etc) => mx("absolute inset-y-0 block rounded-full", variant === "main-bottom" ? "bg-accent-surface" : "bg-un-accent", indeterminate ? "animate-progress-indeterminate" : "start-0", ...etc);
1038
+ var statusRoot = ({ variant = "default" }, ...etc) => mx("h-1 relative rounded-full overflow-hidden", variant === "main-bottom" ? "w-full block" : "inline-20 inline-block bg-base-surface", ...etc);
1039
+ var statusBar = ({ variant = "default", indeterminate }, ...etc) => mx("absolute inset-y-0 block rounded-full", variant === "main-bottom" ? "bg-composer-300" : "bg-un-accent", indeterminate ? "animate-progress-indeterminate" : "start-0", ...etc);
1076
1040
  var statusTheme = {
1077
1041
  root: statusRoot,
1078
1042
  bar: statusBar
@@ -1093,7 +1057,7 @@ var toastViewport = (_props, ...etc) => mx(
1093
1057
  );
1094
1058
  var toastRoot = (_props, ...etc) => mx("dx-modal-surface rounded-md flex p-2 gap-2", surfaceShadow({
1095
1059
  elevation: "toast"
1096
- }), "radix-state-open:animate-toast-slide-in-bottom md:radix-state-open:animate-toast-slide-in-right", "radix-state-closed:animate-toast-hide", "radix-swipe-end:animate-toast-swipe-out", "translate-x-radix-toast-swipe-move-x", "radix-swipe-cancel:translate-x-0 radix-swipe-cancel:duration-200 radix-swipe-cancel:ease-[ease]", focusRing, ...etc);
1060
+ }), "radix-state-open:animate-toast-slide-in-bottom md:radix-state-open:animate-toast-slide-in-right", "radix-state-closed:animate-toast-hide", "radix-swipe-end:animate-toast-swipe-out", "translate-x-radix-toast-swipe-move-x", "radix-swipe-cancel:translate-x-0 radix-swipe-cancel:duration-200 radix-swipe-cancel:ease-[ease]", "dx-focus-ring", ...etc);
1097
1061
  var toastBody = (_props, ...etc) => mx("grow flex flex-col gap-1 justify-center pl-2", ...etc);
1098
1062
  var toastActions = (_props, ...etc) => mx("shrink-0 flex flex-col gap-1 justify-center", ...etc);
1099
1063
  var toastTitle = ({ srOnly }, ...etc) => mx("shrink-0 font-medium", srOnly && "sr-only", ...etc);
@@ -1112,18 +1076,11 @@ var toolbarLayout = "w-full shrink-0 flex flex-nowrap p-1 gap-1 items-center ove
1112
1076
  var toolbarRoot = ({ density, disabled, layoutManaged }, ...etc) => {
1113
1077
  return mx("bg-toolbar-surface dx-toolbar", density === "coarse" && "h-(--dx-rail-size) px-3!", disabled && "*:opacity-20", !layoutManaged && toolbarLayout, ...etc);
1114
1078
  };
1115
- var toolbarInner = ({ layoutManaged }, ...etc) => {
1116
- return mx(!layoutManaged && [
1117
- "flex gap-1",
1118
- textBlockWidth
1119
- ], ...etc);
1120
- };
1121
1079
  var toolbarText = (_, ...etc) => {
1122
- return mx("grow truncate items-center", textBlockWidth, ...etc);
1080
+ return mx("px-2 grow truncate items-center", ...etc);
1123
1081
  };
1124
1082
  var toolbarTheme = {
1125
1083
  root: toolbarRoot,
1126
- inner: toolbarInner,
1127
1084
  text: toolbarText
1128
1085
  };
1129
1086
 
@@ -1176,7 +1133,7 @@ var levelStyles = /* @__PURE__ */ new Map([
1176
1133
  ]
1177
1134
  ]);
1178
1135
  var treegridRoot = (_, ...etc) => mx("grid", ...etc);
1179
- var treegridRow = ({ level = 1 }, ...etc) => mx("contents", levelStyles.get(Math.min(Math.max(Math.round(level), 1), 8)), ...etc);
1136
+ var treegridRow = ({ level = 1 }, ...etc) => mx(levelStyles.get(Math.min(Math.max(Math.round(level), 1), 8)), ...etc);
1180
1137
  var treegridCell = ({ indent }, ...etc) => mx(indent && "indent", ...etc);
1181
1138
  var treegridTheme = {
1182
1139
  root: treegridRoot,
@@ -1184,44 +1141,22 @@ var treegridTheme = {
1184
1141
  cell: treegridCell
1185
1142
  };
1186
1143
 
1187
- // src/theme/theme.ts
1188
- import { getDeep } from "@dxos/util";
1189
-
1190
- // src/theme/primitives/column.ts
1191
- var columnRoot = (_, ...etc) => mx("dx-column w-full min-w-0 grid", ...etc);
1192
- var columnRow = (_, ...etc) => mx("col-span-3 grid grid-cols-subgrid", ...etc);
1193
- var columnSegment = (_, ...etc) => mx("col-start-2 col-span-1 min-w-0", ...etc);
1194
- var columnTheme = {
1195
- root: columnRoot,
1196
- row: columnRow,
1197
- segment: columnSegment
1198
- };
1199
-
1200
1144
  // src/theme/primitives/panel.ts
1145
+ var sizes = {
1146
+ lg: "h-(--dx-topbar-size)",
1147
+ md: "h-(--dx-toolbar-size)",
1148
+ sm: "h-(--dx-statusbar-size)"
1149
+ };
1201
1150
  var panelRoot = (_, ...etc) => mx(
1202
1151
  // prettier-ignore
1203
- "h-full w-full grid grid-cols-[100%] overflow-hidden",
1152
+ "dx-container grid grid-cols-[100%] overflow-hidden",
1204
1153
  // Add uncategorized children to content slot.
1205
1154
  "[&>*:not([data-slot])]:[grid-area:content]",
1206
1155
  ...etc
1207
1156
  );
1208
- var panelToolbar = (_, ...etc) => mx(
1209
- // prettier-ignore
1210
- "[grid-area:toolbar]",
1211
- "border-b border-subdued-separator relative",
1212
- "[.dx-main-mobile-layout_&]:px-3",
1213
- ...etc
1214
- );
1215
- var panelContent = (_, ...etc) => mx(
1216
- // prettier-ignore
1217
- "[grid-area:content] overflow-hidden min-h-0",
1218
- ...etc
1219
- );
1220
- var panelStatusbar = (_, ...etc) => mx(
1221
- // prettier-ignore
1222
- "[grid-area:statusbar]",
1223
- ...etc
1224
- );
1157
+ var panelToolbar = ({ size = "md" }, ...etc) => mx("[grid-area:toolbar]", "shrink-0", sizes[size], ...etc);
1158
+ var panelContent = (_, ...etc) => mx("[grid-area:content] min-h-0", ...etc);
1159
+ var panelStatusbar = ({ size = "md" }, ...etc) => mx("[grid-area:statusbar]", "shrink-0", sizes[size], ...etc);
1225
1160
  var panelTheme = {
1226
1161
  root: panelRoot,
1227
1162
  toolbar: panelToolbar,
@@ -1230,6 +1165,7 @@ var panelTheme = {
1230
1165
  };
1231
1166
 
1232
1167
  // src/theme/theme.ts
1168
+ import { getDeep } from "@dxos/util";
1233
1169
  var defaultTheme = {
1234
1170
  themeName: () => "default",
1235
1171
  //
@@ -1245,6 +1181,7 @@ var defaultTheme = {
1245
1181
  button: buttonTheme,
1246
1182
  card: cardTheme,
1247
1183
  dialog: dialogTheme,
1184
+ focus: focusTheme,
1248
1185
  icon: iconTheme,
1249
1186
  iconButton: iconButtonTheme,
1250
1187
  input: inputTheme,
@@ -1300,17 +1237,16 @@ export {
1300
1237
  cardMinBlockSize,
1301
1238
  cardMinInlineSize,
1302
1239
  cardTheme,
1303
- coarseBlockSize,
1304
- coarseDimensions,
1240
+ columnTheme,
1241
+ composable,
1305
1242
  composableProps,
1306
- computeSize,
1307
1243
  dataDisabled,
1308
1244
  defaultButtonColors,
1309
1245
  defaultTheme,
1310
1246
  defaultTx,
1311
1247
  densityBlockSize,
1248
+ densityDimensions,
1312
1249
  descriptionMessage,
1313
- descriptionTextPrimary,
1314
1250
  dialogActionBar,
1315
1251
  dialogBody,
1316
1252
  dialogContent,
@@ -1319,15 +1255,13 @@ export {
1319
1255
  dialogOverlay,
1320
1256
  dialogTheme,
1321
1257
  dialogTitle,
1322
- fineBlockSize,
1323
- fineDimensions,
1324
- focusRing,
1258
+ focusTheme,
1325
1259
  getHashHue,
1326
1260
  getHashStyles,
1261
+ getHeight,
1327
1262
  getSize,
1328
- getSizeHeight,
1329
- getSizeWidth,
1330
1263
  getStyles,
1264
+ getWidth,
1331
1265
  ghostButtonColors,
1332
1266
  ghostFocusWithin,
1333
1267
  ghostHover,
@@ -1342,6 +1276,7 @@ export {
1342
1276
  iconButtonRoot,
1343
1277
  iconButtonTheme,
1344
1278
  iconRoot,
1279
+ iconSize,
1345
1280
  iconTheme,
1346
1281
  inputTextLabel,
1347
1282
  inputTheme,
@@ -1379,6 +1314,7 @@ export {
1379
1314
  mx,
1380
1315
  osTranslations,
1381
1316
  palette,
1317
+ panelTheme,
1382
1318
  popoverArrow,
1383
1319
  popoverContent,
1384
1320
  popoverTheme,
@@ -1388,6 +1324,7 @@ export {
1388
1324
  scrollAreaRoot,
1389
1325
  scrollAreaTheme,
1390
1326
  scrollAreaViewport,
1327
+ scrollbar,
1391
1328
  selectArrow,
1392
1329
  selectContent,
1393
1330
  selectItem,
@@ -1398,23 +1335,23 @@ export {
1398
1335
  selectViewport,
1399
1336
  separatorRoot,
1400
1337
  separatorTheme,
1338
+ sizeToRem,
1401
1339
  sizeValue,
1402
1340
  skeletonRoot,
1403
1341
  skeletonTheme,
1342
+ slottable,
1343
+ snapSize,
1404
1344
  splitterTheme,
1405
1345
  staticDefaultButtonColors,
1406
1346
  staticDisabled,
1407
- staticFocusRing,
1408
1347
  statusBar,
1409
1348
  statusRoot,
1410
1349
  statusTheme,
1411
- subduedFocus,
1412
1350
  subtleHover,
1413
1351
  surfaceShadow,
1414
1352
  surfaceZIndex,
1415
1353
  tagRoot,
1416
1354
  tagTheme,
1417
- textBlockWidth,
1418
1355
  textValence,
1419
1356
  toastActions,
1420
1357
  toastBody,
@@ -1423,7 +1360,6 @@ export {
1423
1360
  toastTheme,
1424
1361
  toastTitle,
1425
1362
  toastViewport,
1426
- toolbarInner,
1427
1363
  toolbarLayout,
1428
1364
  toolbarRoot,
1429
1365
  toolbarText,
@@ -1435,6 +1371,7 @@ export {
1435
1371
  treegridCell,
1436
1372
  treegridRoot,
1437
1373
  treegridRow,
1438
- treegridTheme
1374
+ treegridTheme,
1375
+ withColumn
1439
1376
  };
1440
1377
  //# sourceMappingURL=index.mjs.map