doom-design-system 0.5.0 → 0.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (211) hide show
  1. package/dist/components/Accordion/Accordion.module.css +121 -124
  2. package/dist/components/ActionRow/ActionRow.module.css +25 -24
  3. package/dist/components/Alert/Alert.module.css +74 -76
  4. package/dist/components/Avatar/Avatar.module.css +66 -66
  5. package/dist/components/Badge/Badge.module.css +50 -48
  6. package/dist/components/Breadcrumbs/Breadcrumbs.module.css +32 -33
  7. package/dist/components/Button/Button.d.ts +2 -2
  8. package/dist/components/Button/Button.js +1 -1
  9. package/dist/components/Button/Button.module.css +150 -152
  10. package/dist/components/Card/Card.module.css +37 -39
  11. package/dist/components/Chart/Chart.module.css +213 -245
  12. package/dist/components/Chart/behaviors/DraggablePuck.d.ts +36 -0
  13. package/dist/components/Chart/behaviors/DraggablePuck.js +94 -0
  14. package/dist/components/Chart/behaviors/Markers.js +6 -4
  15. package/dist/components/Chart/behaviors/SelectionUpdate.js +2 -4
  16. package/dist/components/Chart/behaviors/index.d.ts +1 -1
  17. package/dist/components/Chart/behaviors/index.js +1 -1
  18. package/dist/components/Chart/engine/CoordinateSystem.d.ts +59 -0
  19. package/dist/components/Chart/engine/CoordinateSystem.js +126 -0
  20. package/dist/components/Chart/engine/Engine.d.ts +102 -0
  21. package/dist/components/Chart/engine/Engine.js +226 -0
  22. package/dist/components/Chart/engine/Scheduler.d.ts +59 -0
  23. package/dist/components/Chart/engine/Scheduler.js +139 -0
  24. package/dist/components/Chart/engine/SpatialMap.d.ts +114 -0
  25. package/dist/components/Chart/engine/SpatialMap.js +270 -0
  26. package/dist/components/Chart/engine/index.d.ts +13 -0
  27. package/dist/components/Chart/engine/index.js +9 -0
  28. package/dist/components/Chart/engine/types.d.ts +137 -0
  29. package/dist/components/Chart/engine/types.js +47 -0
  30. package/dist/components/Chart/hooks/useEngine.d.ts +43 -0
  31. package/dist/components/Chart/hooks/useEngine.js +128 -0
  32. package/dist/components/Chart/sensors/DataHoverSensor/DataHoverSensor.d.ts +17 -19
  33. package/dist/components/Chart/sensors/DataHoverSensor/DataHoverSensor.js +38 -51
  34. package/dist/components/Chart/sensors/DragSensor/DragSensor.d.ts +38 -0
  35. package/dist/components/Chart/sensors/DragSensor/DragSensor.js +105 -0
  36. package/dist/components/Chart/sensors/DragSensor/index.d.ts +2 -0
  37. package/dist/components/Chart/sensors/DragSensor/index.js +1 -0
  38. package/dist/components/Chart/sensors/{KeyboardSensor.d.ts → KeyboardSensor/KeyboardSensor.d.ts} +1 -1
  39. package/dist/components/Chart/sensors/KeyboardSensor/KeyboardSensor.js +86 -0
  40. package/dist/components/Chart/sensors/KeyboardSensor/index.d.ts +1 -0
  41. package/dist/components/Chart/sensors/KeyboardSensor/index.js +1 -0
  42. package/dist/components/Chart/sensors/{SelectionSensor.d.ts → SelectionSensor/SelectionSensor.d.ts} +2 -2
  43. package/dist/components/Chart/sensors/SelectionSensor/SelectionSensor.js +39 -0
  44. package/dist/components/Chart/sensors/SelectionSensor/index.d.ts +1 -0
  45. package/dist/components/Chart/sensors/SelectionSensor/index.js +1 -0
  46. package/dist/components/Chart/sensors/SensorManager/SensorManager.js +36 -41
  47. package/dist/components/Chart/sensors/index.d.ts +1 -0
  48. package/dist/components/Chart/sensors/index.js +3 -2
  49. package/dist/components/Chart/sensors/utils/search.d.ts +1 -1
  50. package/dist/components/Chart/sensors/utils/search.js +25 -4
  51. package/dist/components/Chart/state/store/chart.store.js +18 -0
  52. package/dist/components/Chart/state/store/slices/series.slice.d.ts +1 -0
  53. package/dist/components/Chart/state/store/slices/series.slice.js +3 -2
  54. package/dist/components/Chart/subcomponents/Axis/Axis.module.css +32 -33
  55. package/dist/components/Chart/subcomponents/BarSeries/BarSeries.js +6 -1
  56. package/dist/components/Chart/subcomponents/BarSeries/BarSeries.module.css +11 -9
  57. package/dist/components/Chart/subcomponents/Cursor/Cursor.js +8 -1
  58. package/dist/components/Chart/subcomponents/Cursor/Cursor.module.css +14 -13
  59. package/dist/components/Chart/subcomponents/CustomSeries/CustomSeries.js +4 -0
  60. package/dist/components/Chart/subcomponents/CustomSeries/CustomSeries.module.css +5 -3
  61. package/dist/components/Chart/subcomponents/Footer/Footer.module.css +5 -3
  62. package/dist/components/Chart/subcomponents/Grid/Grid.module.css +12 -11
  63. package/dist/components/Chart/subcomponents/Header/Header.module.css +8 -7
  64. package/dist/components/Chart/subcomponents/InteractionLayer/InteractionLayer.d.ts +4 -4
  65. package/dist/components/Chart/subcomponents/InteractionLayer/InteractionLayer.js +39 -76
  66. package/dist/components/Chart/subcomponents/Legend/Legend.module.css +30 -32
  67. package/dist/components/Chart/subcomponents/LineSeries/LineSeries.js +9 -3
  68. package/dist/components/Chart/subcomponents/LineSeries/LineSeries.module.css +21 -21
  69. package/dist/components/Chart/subcomponents/Root/Root.js +113 -7
  70. package/dist/components/Chart/subcomponents/Root/Root.module.css +70 -82
  71. package/dist/components/Chart/subcomponents/ScatterSeries/ScatterSeries.js +6 -1
  72. package/dist/components/Chart/subcomponents/ScatterSeries/ScatterSeries.module.css +7 -5
  73. package/dist/components/Chart/subcomponents/Series/Series.module.css +118 -128
  74. package/dist/components/Chart/subcomponents/SeriesPoint/SeriesPoint.module.css +10 -8
  75. package/dist/components/Chart/subcomponents/Tooltip/Tooltip.js +2 -3
  76. package/dist/components/Chart/subcomponents/Tooltip/Tooltip.module.css +52 -67
  77. package/dist/components/Chart/types/context.d.ts +9 -0
  78. package/dist/components/Chart/types/events.d.ts +5 -7
  79. package/dist/components/Chart/types/interaction.d.ts +24 -2
  80. package/dist/components/Chart/types/interaction.js +1 -0
  81. package/dist/components/Checkbox/Checkbox.module.css +57 -59
  82. package/dist/components/Chip/Chip.module.css +105 -115
  83. package/dist/components/Combobox/Combobox.d.ts +2 -1
  84. package/dist/components/Combobox/Combobox.js +2 -2
  85. package/dist/components/Combobox/Combobox.module.css +233 -210
  86. package/dist/components/CopyButton/CopyButton.module.css +84 -90
  87. package/dist/components/Drawer/Drawer.module.css +126 -145
  88. package/dist/components/Dropdown/Dropdown.d.ts +3 -1
  89. package/dist/components/Dropdown/Dropdown.js +3 -3
  90. package/dist/components/Dropdown/Dropdown.module.css +52 -32
  91. package/dist/components/FileUpload/FileUpload.js +24 -0
  92. package/dist/components/FileUpload/FileUpload.module.css +295 -313
  93. package/dist/components/Form/Form.module.css +35 -39
  94. package/dist/components/Image/Image.module.css +53 -54
  95. package/dist/components/Input/Input.d.ts +4 -2
  96. package/dist/components/Input/Input.js +2 -2
  97. package/dist/components/Input/Input.module.css +135 -119
  98. package/dist/components/Label/Label.module.css +17 -15
  99. package/dist/components/Layout/Layout.module.css +95 -111
  100. package/dist/components/Link/Link.module.css +67 -65
  101. package/dist/components/Modal/Modal.module.css +112 -132
  102. package/dist/components/Page/Page.module.css +21 -21
  103. package/dist/components/Pagination/Pagination.module.css +56 -56
  104. package/dist/components/Popover/Popover.module.css +17 -16
  105. package/dist/components/ProgressBar/ProgressBar.module.css +36 -37
  106. package/dist/components/RadioGroup/RadioGroup.module.css +74 -77
  107. package/dist/components/Select/Select.d.ts +2 -1
  108. package/dist/components/Select/Select.js +2 -2
  109. package/dist/components/Select/Select.module.css +133 -98
  110. package/dist/components/Sheet/Sheet.module.css +134 -154
  111. package/dist/components/Sidebar/Sidebar.module.css +72 -74
  112. package/dist/components/Sidebar/subcomponents/Footer/Footer.module.css +7 -5
  113. package/dist/components/Sidebar/subcomponents/Group/Group.module.css +80 -85
  114. package/dist/components/Sidebar/subcomponents/Header/Header.module.css +12 -10
  115. package/dist/components/Sidebar/subcomponents/Item/Item.module.css +54 -55
  116. package/dist/components/Sidebar/subcomponents/MobileOverlay/MobileOverlay.module.css +38 -38
  117. package/dist/components/Sidebar/subcomponents/MobileTrigger/MobileTrigger.module.css +5 -3
  118. package/dist/components/Sidebar/subcomponents/Nav/Nav.module.css +13 -11
  119. package/dist/components/Sidebar/subcomponents/Rail/Rail.module.css +62 -63
  120. package/dist/components/Sidebar/subcomponents/Section/Section.module.css +86 -91
  121. package/dist/components/Skeleton/Skeleton.module.css +28 -26
  122. package/dist/components/Slat/Slat.module.css +93 -94
  123. package/dist/components/Slider/Slider.module.css +116 -121
  124. package/dist/components/Spinner/Spinner.module.css +28 -27
  125. package/dist/components/SplitButton/SplitButton.d.ts +3 -1
  126. package/dist/components/SplitButton/SplitButton.js +2 -2
  127. package/dist/components/SplitButton/SplitButton.module.css +104 -87
  128. package/dist/components/Switch/Switch.module.css +64 -63
  129. package/dist/components/Table/FilterBuilder/FilterBuilder.module.css +36 -36
  130. package/dist/components/Table/FilterBuilder/FilterConditionRow.js +1 -1
  131. package/dist/components/Table/FilterBuilder/FilterConditionRow.module.css +21 -22
  132. package/dist/components/Table/FilterBuilder/FilterGroup.js +4 -4
  133. package/dist/components/Table/FilterBuilder/FilterGroup.module.css +355 -389
  134. package/dist/components/Table/FilterBuilder/FilterSheet.module.css +68 -71
  135. package/dist/components/Table/Table.d.ts +4 -2
  136. package/dist/components/Table/Table.js +50 -13
  137. package/dist/components/Table/Table.module.css +210 -188
  138. package/dist/components/Table/TableHeaderFilter.js +1 -1
  139. package/dist/components/Table/TableHeaderFilter.module.css +51 -57
  140. package/dist/components/Tabs/Tabs.module.css +79 -80
  141. package/dist/components/Text/Text.module.css +108 -131
  142. package/dist/components/Textarea/Textarea.d.ts +3 -1
  143. package/dist/components/Textarea/Textarea.js +2 -2
  144. package/dist/components/Textarea/Textarea.module.css +114 -94
  145. package/dist/components/Toast/Toast.module.css +82 -82
  146. package/dist/components/Tooltip/Tooltip.module.css +17 -16
  147. package/dist/styles/globals.css +1677 -1691
  148. package/dist/styles/palettes.d.ts +0 -5
  149. package/dist/styles/palettes.js +0 -8
  150. package/dist/styles/themes/definitions.d.ts +0 -8
  151. package/dist/styles/themes/definitions.js +117 -5
  152. package/dist/styles/types.d.ts +2 -0
  153. package/dist/styles/types.js +1 -0
  154. package/dist/tsconfig.build.tsbuildinfo +1 -1
  155. package/package.json +4 -4
  156. package/.agent/skills/doom/a2ui/a2ui-examples.md +0 -289
  157. package/.agent/skills/doom/a2ui/a2ui-principles.md +0 -49
  158. package/.agent/skills/doom/a2ui/a2ui-protocol.md +0 -191
  159. package/.agent/skills/doom/components/a2ui.md +0 -46
  160. package/.agent/skills/doom/components/accordion.md +0 -44
  161. package/.agent/skills/doom/components/actionrow.md +0 -33
  162. package/.agent/skills/doom/components/alert.md +0 -35
  163. package/.agent/skills/doom/components/avatar.md +0 -36
  164. package/.agent/skills/doom/components/badge.md +0 -29
  165. package/.agent/skills/doom/components/breadcrumbs.md +0 -33
  166. package/.agent/skills/doom/components/button.md +0 -43
  167. package/.agent/skills/doom/components/card.md +0 -41
  168. package/.agent/skills/doom/components/chart.md +0 -106
  169. package/.agent/skills/doom/components/checkbox.md +0 -38
  170. package/.agent/skills/doom/components/chip.md +0 -35
  171. package/.agent/skills/doom/components/combobox.md +0 -50
  172. package/.agent/skills/doom/components/copybutton.md +0 -41
  173. package/.agent/skills/doom/components/drawer.md +0 -69
  174. package/.agent/skills/doom/components/dropdown.md +0 -33
  175. package/.agent/skills/doom/components/fileupload.md +0 -49
  176. package/.agent/skills/doom/components/form.md +0 -55
  177. package/.agent/skills/doom/components/icon.md +0 -47
  178. package/.agent/skills/doom/components/image.md +0 -48
  179. package/.agent/skills/doom/components/input.md +0 -54
  180. package/.agent/skills/doom/components/label.md +0 -32
  181. package/.agent/skills/doom/components/layout.md +0 -92
  182. package/.agent/skills/doom/components/link.md +0 -39
  183. package/.agent/skills/doom/components/modal.md +0 -71
  184. package/.agent/skills/doom/components/page.md +0 -41
  185. package/.agent/skills/doom/components/pagination.md +0 -32
  186. package/.agent/skills/doom/components/popover.md +0 -45
  187. package/.agent/skills/doom/components/progressbar.md +0 -37
  188. package/.agent/skills/doom/components/radiogroup.md +0 -45
  189. package/.agent/skills/doom/components/select.md +0 -43
  190. package/.agent/skills/doom/components/sheet.md +0 -71
  191. package/.agent/skills/doom/components/sidebar.md +0 -92
  192. package/.agent/skills/doom/components/skeleton.md +0 -35
  193. package/.agent/skills/doom/components/slat.md +0 -46
  194. package/.agent/skills/doom/components/slider.md +0 -51
  195. package/.agent/skills/doom/components/spinner.md +0 -34
  196. package/.agent/skills/doom/components/splitbutton.md +0 -35
  197. package/.agent/skills/doom/components/switch.md +0 -40
  198. package/.agent/skills/doom/components/table.md +0 -82
  199. package/.agent/skills/doom/components/tabs.md +0 -65
  200. package/.agent/skills/doom/components/text.md +0 -42
  201. package/.agent/skills/doom/components/textarea.md +0 -46
  202. package/.agent/skills/doom/components/toast.md +0 -59
  203. package/.agent/skills/doom/components/tooltip.md +0 -35
  204. package/.agent/skills/doom/index.md +0 -167
  205. package/.agent/skills/doom/styles/aesthetic.md +0 -151
  206. package/.agent/skills/doom/styles/css-variables.md +0 -80
  207. package/.agent/skills/doom/styles/mixins.md +0 -97
  208. package/.agent/skills/doom/styles/tokens.md +0 -129
  209. package/.agent/skills/doom/styles/utilities.md +0 -84
  210. package/dist/components/Chart/sensors/KeyboardSensor.js +0 -82
  211. package/dist/components/Chart/sensors/SelectionSensor.js +0 -41
@@ -1,101 +1,100 @@
1
- .slat {
2
- background-color: var(--card-bg);
3
- border: var(--border-width) solid var(--border-strong);
4
- border-radius: var(--radius);
5
- padding: var(--spacing-2) var(--spacing-4);
6
- transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
7
- user-select: none;
8
- width: 100%;
9
- }
10
- @media (max-width: 640px) {
1
+ @layer doom.components {
11
2
  .slat {
12
- padding: var(--spacing-2);
3
+ background-color: var(--card-bg);
4
+ border: var(--surface-border-width) solid var(--border-strong);
5
+ border-radius: var(--radius-md);
6
+ padding: var(--space-2) var(--space-4);
7
+ transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
8
+ user-select: none;
9
+ width: 100%;
13
10
  }
14
- }
15
- @media (max-width: 360px) {
16
- .slat {
17
- padding: var(--spacing-2) var(--spacing-4);
11
+ @media (max-width: 640px) {
12
+ .slat {
13
+ padding: var(--space-2);
14
+ }
18
15
  }
19
- }
20
- .slat.danger {
21
- background-color: var(--error);
22
- color: var(--error-foreground);
23
- border-color: var(--border-strong);
24
- }
25
- .slat.danger > * {
26
- --primary: var(--primary-foreground);
27
- --primary-foreground: var(--primary);
28
- --foreground: var(--primary-foreground);
29
- --muted-foreground: var(--primary-foreground);
30
- }
31
- .slat.success {
32
- background-color: var(--success);
33
- color: var(--success-foreground);
34
- border-color: var(--border-strong);
35
- }
36
- .slat.success > * {
37
- --primary: var(--primary-foreground);
38
- --primary-foreground: var(--primary);
39
- --foreground: var(--primary-foreground);
40
- --muted-foreground: var(--primary-foreground);
41
- }
42
- .slat.hoverable {
43
- cursor: pointer;
44
- }
45
- .slat.hoverable:hover {
46
- background-color: var(--surface-accent);
47
- color: var(--foreground);
48
- transform: translate(calc(-1 * var(--spacing-half)), calc(-1 * var(--spacing-half)));
49
- box-shadow: var(--spacing-1) var(--spacing-1) 0px 0px var(--border-strong);
50
- }
51
- .slat.hoverable:active {
52
- transform: translate(0, 0);
53
- box-shadow: none;
54
- }
55
- .slat.hoverable.danger:hover {
56
- background-color: var(--error);
57
- filter: brightness(1.1);
58
- }
59
- .slat.hoverable.success:hover {
60
- background-color: var(--success);
61
- filter: brightness(1.1);
62
- }
63
-
64
- .label {
65
- font-weight: 500;
66
- font-family: var(--font-mono);
67
- font-size: var(--text-sm);
68
- white-space: nowrap;
69
- overflow: hidden;
70
- text-overflow: ellipsis;
71
- color: inherit;
72
- }
73
- @media (max-width: 640px) {
74
- .label {
75
- white-space: normal;
76
- word-break: break-all;
77
- display: -webkit-box;
78
- -webkit-line-clamp: 1;
79
- -webkit-box-orient: vertical;
16
+ @media (max-width: 360px) {
17
+ .slat {
18
+ padding: var(--space-2) var(--space-4);
19
+ }
20
+ }
21
+ .slat.danger {
22
+ background-color: var(--error);
23
+ color: var(--error-foreground);
24
+ border-color: var(--border-strong);
25
+ }
26
+ .slat.danger > * {
27
+ --primary: var(--primary-foreground);
28
+ --primary-foreground: var(--primary);
29
+ --foreground: var(--primary-foreground);
30
+ --muted-foreground: var(--primary-foreground);
31
+ }
32
+ .slat.success {
33
+ background-color: var(--success);
34
+ color: var(--success-foreground);
35
+ border-color: var(--border-strong);
36
+ }
37
+ .slat.success > * {
38
+ --primary: var(--primary-foreground);
39
+ --primary-foreground: var(--primary);
40
+ --foreground: var(--primary-foreground);
41
+ --muted-foreground: var(--primary-foreground);
42
+ }
43
+ .slat.hoverable {
44
+ cursor: pointer;
45
+ }
46
+ .slat.hoverable:hover {
47
+ background-color: var(--surface-accent);
48
+ color: var(--foreground);
49
+ transform: translate(calc(-1 * var(--space-0\.5)), calc(-1 * var(--space-0\.5)));
50
+ box-shadow: var(--space-1) var(--space-1) 0px 0px var(--border-strong);
51
+ }
52
+ .slat.hoverable:active {
53
+ transform: translate(0, 0);
54
+ box-shadow: none;
55
+ }
56
+ .slat.hoverable.danger:hover {
57
+ background-color: var(--error);
58
+ filter: brightness(1.1);
59
+ }
60
+ .slat.hoverable.success:hover {
61
+ background-color: var(--success);
62
+ filter: brightness(1.1);
80
63
  }
81
- }
82
- @media (max-width: 360px) {
83
64
  .label {
84
- -webkit-line-clamp: 2;
65
+ font-weight: 500;
66
+ font-family: var(--font-mono);
67
+ font-size: var(--text-sm);
68
+ white-space: nowrap;
69
+ overflow: hidden;
70
+ text-overflow: ellipsis;
71
+ color: inherit;
72
+ }
73
+ @media (max-width: 640px) {
74
+ .label {
75
+ white-space: normal;
76
+ word-break: break-all;
77
+ display: -webkit-box;
78
+ -webkit-line-clamp: 1;
79
+ -webkit-box-orient: vertical;
80
+ }
81
+ }
82
+ @media (max-width: 360px) {
83
+ .label {
84
+ -webkit-line-clamp: 2;
85
+ }
86
+ }
87
+ .secondaryLabel {
88
+ color: inherit;
89
+ opacity: 0.8;
90
+ font-size: var(--text-2xs);
91
+ font-family: var(--font-mono);
92
+ }
93
+ .prepend,
94
+ .append {
95
+ display: flex;
96
+ align-items: center;
97
+ justify-content: center;
98
+ flex-shrink: 0;
85
99
  }
86
- }
87
-
88
- .secondaryLabel {
89
- color: inherit;
90
- opacity: 0.8;
91
- font-size: var(--text-2xs);
92
- font-family: var(--font-mono);
93
- }
94
-
95
- .prepend,
96
- .append {
97
- display: flex;
98
- align-items: center;
99
- justify-content: center;
100
- flex-shrink: 0;
101
100
  }
@@ -1,122 +1,117 @@
1
- .container {
2
- display: flex;
3
- flex-direction: column;
4
- gap: var(--spacing-3);
5
- width: 100%;
6
- padding: 0 var(--spacing-3);
7
- }
8
-
9
- .labelRow {
10
- display: flex;
11
- justify-content: space-between;
12
- align-items: center;
13
- }
14
-
15
- .valueDisplay {
16
- background-color: var(--card-bg);
17
- padding: var(--spacing-half) var(--spacing-2);
18
- border: var(--border-width) solid var(--card-border);
19
- border-radius: var(--radius);
20
- display: inline-flex;
21
- align-items: center;
22
- justify-content: center;
23
- }
24
-
25
- .trackWrapper {
26
- position: relative;
27
- width: 100%;
28
- height: var(--spacing-3);
29
- overflow: visible;
30
- }
31
-
32
- .trackInner {
33
- position: absolute;
34
- inset: 0;
35
- background: var(--card-bg);
36
- border: var(--border-width) solid var(--card-border);
37
- border-radius: var(--radius);
38
- overflow: hidden;
39
- box-sizing: border-box;
40
- }
41
-
42
- .progressFill {
43
- position: absolute;
44
- top: 0;
45
- bottom: 0;
46
- background: var(--primary);
47
- z-index: 1;
48
- pointer-events: none;
49
- }
50
-
51
- .rangeInput, .multiRangeInput {
52
- appearance: none;
53
- -webkit-appearance: none;
54
- position: absolute;
55
- top: 0;
56
- left: -12px;
57
- width: calc(100% + 24px);
58
- height: 100%;
59
- background: transparent;
60
- cursor: pointer;
61
- z-index: 10;
62
- margin: 0;
63
- }
64
- .rangeInput::-webkit-slider-runnable-track, .multiRangeInput::-webkit-slider-runnable-track {
65
- width: 100%;
66
- height: 12px;
67
- background: transparent;
68
- border: none;
69
- }
70
- .rangeInput::-moz-range-track, .multiRangeInput::-moz-range-track {
71
- width: 100%;
72
- height: 12px;
73
- background: transparent;
74
- border: none;
75
- }
76
- .rangeInput::-webkit-slider-thumb, .multiRangeInput::-webkit-slider-thumb {
77
- -webkit-appearance: none;
78
- height: 24px;
79
- width: 24px;
80
- background: var(--primary);
81
- border: var(--border-width) solid var(--border-strong);
82
- border-radius: 50%;
83
- margin-top: -7px; /* Center thumb on track */
84
- position: relative;
85
- z-index: 20;
86
- }
87
- .rangeInput::-moz-range-thumb, .multiRangeInput::-moz-range-thumb {
88
- height: 24px;
89
- width: 24px;
90
- background: var(--primary);
91
- border: var(--border-width) solid var(--border-strong);
92
- border-radius: 50%;
93
- }
94
- .rangeInput:focus, .multiRangeInput:focus {
95
- outline: none;
96
- }
97
- .rangeInput:focus-visible::-webkit-slider-thumb, .multiRangeInput:focus-visible::-webkit-slider-thumb {
98
- outline: var(--border-width) solid var(--foreground);
99
- outline-offset: 4px;
100
- }
101
- .rangeInput:focus-visible::-moz-range-thumb, .multiRangeInput:focus-visible::-moz-range-thumb {
102
- outline: var(--border-width) solid var(--foreground);
103
- outline-offset: 4px;
104
- }
105
- .rangeInput:disabled, .multiRangeInput:disabled {
106
- cursor: not-allowed;
107
- opacity: 0.5;
108
- }
109
- .rangeInput:disabled::-webkit-slider-thumb, .multiRangeInput:disabled::-webkit-slider-thumb {
110
- background: var(--muted);
111
- filter: grayscale(1);
112
- }
113
-
114
- .multiRangeInput {
115
- pointer-events: none !important;
116
- }
117
- .multiRangeInput::-webkit-slider-thumb {
118
- pointer-events: auto !important;
119
- }
120
- .multiRangeInput::-moz-range-thumb {
121
- pointer-events: auto !important;
1
+ @layer doom.components {
2
+ .container {
3
+ display: flex;
4
+ flex-direction: column;
5
+ gap: var(--space-3);
6
+ width: 100%;
7
+ padding: 0 var(--space-3);
8
+ }
9
+ .labelRow {
10
+ display: flex;
11
+ justify-content: space-between;
12
+ align-items: center;
13
+ }
14
+ .valueDisplay {
15
+ background-color: var(--card-bg);
16
+ padding: var(--space-half) var(--space-2);
17
+ border: var(--surface-border-width) solid var(--card-border);
18
+ border-radius: var(--radius-md);
19
+ display: inline-flex;
20
+ align-items: center;
21
+ justify-content: center;
22
+ }
23
+ .trackWrapper {
24
+ position: relative;
25
+ width: 100%;
26
+ height: var(--space-2);
27
+ overflow: visible;
28
+ }
29
+ .trackInner {
30
+ position: absolute;
31
+ inset: 0;
32
+ background: var(--card-bg);
33
+ border: var(--surface-border-width) solid var(--card-border);
34
+ border-radius: var(--radius-md);
35
+ overflow: hidden;
36
+ box-sizing: border-box;
37
+ }
38
+ .progressFill {
39
+ position: absolute;
40
+ top: 0;
41
+ bottom: 0;
42
+ background: var(--primary);
43
+ z-index: 1;
44
+ pointer-events: none;
45
+ }
46
+ .rangeInput, .multiRangeInput {
47
+ appearance: none;
48
+ -webkit-appearance: none;
49
+ position: absolute;
50
+ top: 0;
51
+ left: -10px;
52
+ width: calc(100% + 20px);
53
+ height: 100%;
54
+ background: transparent;
55
+ cursor: pointer;
56
+ z-index: 10;
57
+ margin: 0;
58
+ }
59
+ .rangeInput::-webkit-slider-runnable-track, .multiRangeInput::-webkit-slider-runnable-track {
60
+ width: 100%;
61
+ height: var(--space-2);
62
+ background: transparent;
63
+ border: none;
64
+ }
65
+ .rangeInput::-moz-range-track, .multiRangeInput::-moz-range-track {
66
+ width: 100%;
67
+ height: var(--space-2);
68
+ background: transparent;
69
+ border: none;
70
+ }
71
+ .rangeInput::-webkit-slider-thumb, .multiRangeInput::-webkit-slider-thumb {
72
+ -webkit-appearance: none;
73
+ height: var(--toggle-size);
74
+ width: var(--toggle-size);
75
+ background: var(--primary);
76
+ border: var(--surface-border-width) solid var(--border-strong);
77
+ border-radius: 50%;
78
+ margin-top: calc(-1 * var(--space-1\.5)); /* Center thumb on track */
79
+ position: relative;
80
+ z-index: 20;
81
+ }
82
+ .rangeInput::-moz-range-thumb, .multiRangeInput::-moz-range-thumb {
83
+ height: var(--toggle-size);
84
+ width: var(--toggle-size);
85
+ background: var(--primary);
86
+ border: var(--surface-border-width) solid var(--border-strong);
87
+ border-radius: 50%;
88
+ }
89
+ .rangeInput:focus, .multiRangeInput:focus {
90
+ outline: none;
91
+ }
92
+ .rangeInput:focus-visible::-webkit-slider-thumb, .multiRangeInput:focus-visible::-webkit-slider-thumb {
93
+ outline: var(--surface-border-width) solid var(--foreground);
94
+ outline-offset: 4px;
95
+ }
96
+ .rangeInput:focus-visible::-moz-range-thumb, .multiRangeInput:focus-visible::-moz-range-thumb {
97
+ outline: var(--surface-border-width) solid var(--foreground);
98
+ outline-offset: 4px;
99
+ }
100
+ .rangeInput:disabled, .multiRangeInput:disabled {
101
+ cursor: not-allowed;
102
+ opacity: 0.5;
103
+ }
104
+ .rangeInput:disabled::-webkit-slider-thumb, .multiRangeInput:disabled::-webkit-slider-thumb {
105
+ background: var(--muted);
106
+ filter: grayscale(1);
107
+ }
108
+ .multiRangeInput {
109
+ pointer-events: none !important;
110
+ }
111
+ .multiRangeInput::-webkit-slider-thumb {
112
+ pointer-events: auto !important;
113
+ }
114
+ .multiRangeInput::-moz-range-thumb {
115
+ pointer-events: auto !important;
116
+ }
122
117
  }
@@ -1,30 +1,31 @@
1
- .spinner {
2
- display: inline-block;
3
- animation: spin 1s linear infinite;
4
- color: currentColor;
5
- }
6
- .spinner.sm {
7
- width: var(--size-icon-sm);
8
- height: var(--size-icon-sm);
9
- }
10
- .spinner.md {
11
- width: var(--size-icon-md);
12
- height: var(--size-icon-md);
13
- }
14
- .spinner.lg {
15
- width: var(--size-icon-lg);
16
- height: var(--size-icon-lg);
17
- }
18
- .spinner.xl {
19
- width: var(--size-touch-target);
20
- height: var(--size-touch-target);
21
- }
22
-
23
- @keyframes spin {
24
- 0% {
25
- transform: rotate(0deg);
1
+ @layer doom.components {
2
+ .spinner {
3
+ display: inline-block;
4
+ animation: spin 1s linear infinite;
5
+ color: currentColor;
6
+ }
7
+ .spinner.sm {
8
+ width: var(--size-icon-sm);
9
+ height: var(--size-icon-sm);
10
+ }
11
+ .spinner.md {
12
+ width: var(--size-icon-md);
13
+ height: var(--size-icon-md);
14
+ }
15
+ .spinner.lg {
16
+ width: var(--size-icon-lg);
17
+ height: var(--size-icon-lg);
18
+ }
19
+ .spinner.xl {
20
+ width: var(--size-touch-target);
21
+ height: var(--size-touch-target);
26
22
  }
27
- 100% {
28
- transform: rotate(360deg);
23
+ @keyframes spin {
24
+ 0% {
25
+ transform: rotate(0deg);
26
+ }
27
+ 100% {
28
+ transform: rotate(360deg);
29
+ }
29
30
  }
30
31
  }
@@ -1,3 +1,4 @@
1
+ import type { ControlSize } from "../../styles/types";
1
2
  interface SplitButtonItem {
2
3
  label: string;
3
4
  onClick: () => void;
@@ -7,7 +8,8 @@ interface SplitButtonProps {
7
8
  onPrimaryClick: () => void;
8
9
  items: SplitButtonItem[];
9
10
  variant?: "primary" | "secondary";
11
+ size?: ControlSize;
10
12
  className?: string;
11
13
  }
12
- export declare function SplitButton({ primaryLabel, onPrimaryClick, items, variant, className, }: SplitButtonProps): import("react/jsx-runtime").JSX.Element;
14
+ export declare function SplitButton({ primaryLabel, onPrimaryClick, items, variant, size, className, }: SplitButtonProps): import("react/jsx-runtime").JSX.Element;
13
15
  export {};
@@ -5,10 +5,10 @@ import { ChevronDown } from "lucide-react";
5
5
  import { useState } from "react";
6
6
  import { Popover } from "../Popover/Popover.js";
7
7
  import styles from "./SplitButton.module.css";
8
- export function SplitButton({ primaryLabel, onPrimaryClick, items, variant = "primary", className, }) {
8
+ export function SplitButton({ primaryLabel, onPrimaryClick, items, variant = "primary", size = "md", className, }) {
9
9
  const [isOpen, setIsOpen] = useState(false);
10
10
  return (_jsx(Popover, { content: _jsx("div", { className: styles.menu, children: items.map((item, index) => (_jsx("button", { className: styles.item, onClick: () => {
11
11
  item.onClick();
12
12
  setIsOpen(false);
13
- }, children: item.label }, index))) }), isOpen: isOpen, placement: "bottom-end", trigger: _jsxs("div", { className: clsx(styles.container, styles[variant], className), "data-state": isOpen ? "open" : "closed", children: [_jsx("button", { className: styles.mainButton, onClick: onPrimaryClick, children: primaryLabel }), _jsx("button", { "aria-expanded": isOpen, "aria-haspopup": "menu", "aria-label": `More ${primaryLabel} options`, className: styles.dropdownTrigger, onClick: () => setIsOpen(!isOpen), children: _jsx(ChevronDown, { "aria-hidden": "true", size: 16, strokeWidth: 3 }) })] }), onClose: () => setIsOpen(false) }));
13
+ }, children: item.label }, index))) }), isOpen: isOpen, placement: "bottom-end", trigger: _jsxs("div", { className: clsx(styles.container, styles[variant], size !== "md" && styles[size], className), "data-state": isOpen ? "open" : "closed", children: [_jsx("button", { className: styles.mainButton, onClick: onPrimaryClick, children: primaryLabel }), _jsx("button", { "aria-expanded": isOpen, "aria-haspopup": "menu", "aria-label": `More ${primaryLabel} options`, className: styles.dropdownTrigger, onClick: () => setIsOpen(!isOpen), children: _jsx(ChevronDown, { "aria-hidden": "true", size: 20, strokeWidth: 3 }) })] }), onClose: () => setIsOpen(false) }));
14
14
  }