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,4 +1,5 @@
1
1
  import { Selection } from "d3-selection";
2
+ import { EngineEvent } from "../engine";
2
3
  import { ContextValue } from "./context";
3
4
  import { Interaction } from "./interaction";
4
5
  /**
@@ -43,23 +44,20 @@ export interface BehaviorContext<T = any> {
43
44
  */
44
45
  export type Behavior<T = any> = (context: BehaviorContext<T>) => Cleanup | void;
45
46
  /**
46
- * SensorContext provides the event backbone for sensors.
47
+ * SensorContext provides the environment for sensors to interact with the chart state.
48
+ * Refactored for Hyper-Engine: Reduced API surface.
47
49
  */
48
50
  export interface SensorContext<T = unknown> {
49
- on: (type: EventType, listener: EventListener) => void;
50
- off: (type: EventType, listener: EventListener) => void;
51
51
  getChartContext: () => ContextValue<T>;
52
52
  getInteraction: (name: string) => Interaction | null;
53
53
  upsertInteraction: (name: string, interaction: Interaction) => void;
54
54
  removeInteraction: (name: string) => void;
55
- emit: (event: ChartEvent) => void;
56
- pointerPosition: Coordinates | null;
57
- isWithinPlot: boolean;
58
55
  }
59
56
  /**
60
57
  * A Sensor is a function that detects user intent and updates the interaction store.
58
+ * Sensors receive processed EngineEvents and no longer subscribe to events themselves.
61
59
  */
62
- export type Sensor<T = unknown> = (context: SensorContext<T>) => Cleanup | void;
60
+ export type Sensor<T = unknown> = (event: EngineEvent<T>, context: SensorContext<T>) => void;
63
61
  export interface EventContextValue {
64
62
  on: (type: EventType, listener: EventListener) => void;
65
63
  off: (type: EventType, listener: EventListener) => void;
@@ -11,7 +11,8 @@ export declare enum InteractionChannel {
11
11
  SELECTION = "selection",
12
12
  CROSSHAIR = "crosshair",
13
13
  TOOLTIP_CONFIG = "tooltip-config",
14
- CURSOR_CONFIG = "cursor-config"
14
+ CURSOR_CONFIG = "cursor-config",
15
+ DRAG = "drag"
15
16
  }
16
17
  export declare enum InteractionType {
17
18
  HOVER = "hover",
@@ -47,4 +48,25 @@ export interface SelectionInteraction<T = any> {
47
48
  selection: T[];
48
49
  mode: "continuous" | "discrete";
49
50
  }
50
- export type Interaction = HoverInteraction | SelectionInteraction;
51
+ export interface DragInteraction<T = any> {
52
+ /** The data point being dragged */
53
+ target: InteractionTarget<T>;
54
+ /** Current pixel position during drag */
55
+ currentPosition: {
56
+ x: number;
57
+ y: number;
58
+ };
59
+ /** Starting pixel position when drag began */
60
+ startPosition: {
61
+ x: number;
62
+ y: number;
63
+ };
64
+ /** Current value in data domain (inverted from pixel) */
65
+ currentValue: {
66
+ x: any;
67
+ y: any;
68
+ };
69
+ /** Whether the drag is currently active */
70
+ isDragging: boolean;
71
+ }
72
+ export type Interaction = HoverInteraction | SelectionInteraction | DragInteraction;
@@ -12,6 +12,7 @@ export var InteractionChannel;
12
12
  InteractionChannel["CROSSHAIR"] = "crosshair";
13
13
  InteractionChannel["TOOLTIP_CONFIG"] = "tooltip-config";
14
14
  InteractionChannel["CURSOR_CONFIG"] = "cursor-config";
15
+ InteractionChannel["DRAG"] = "drag";
15
16
  })(InteractionChannel || (InteractionChannel = {}));
16
17
  export var InteractionType;
17
18
  (function (InteractionType) {
@@ -1,60 +1,58 @@
1
- .checkboxWrapper {
2
- display: inline-flex;
3
- align-items: center;
4
- gap: var(--spacing-2);
5
- cursor: pointer;
6
- user-select: none;
7
- }
8
- .checkboxWrapper.disabled {
9
- cursor: not-allowed;
10
- opacity: 0.6;
11
- }
12
-
13
- .checkboxInput {
14
- position: absolute;
15
- opacity: 0;
16
- width: 0;
17
- height: 0;
18
- margin: 0;
19
- }
20
- .checkboxInput:focus-visible + .checkboxDisplay:focus-visible, .checkboxInput:focus-visible + .checkboxDisplay[aria-expanded=true] {
21
- outline: none;
22
- transform: translate(-2px, -2px);
23
- box-shadow: 6px 6px 0px 0px var(--shadow-primary);
24
- border-color: var(--primary);
25
- }
26
- .checkboxInput:focus-visible + .checkboxDisplay:focus {
27
- outline: none;
28
- }
29
- .checkboxInput:focus-visible + .checkboxDisplay {
30
- outline: var(--border-width) solid var(--primary);
31
- }
32
-
33
- .checkboxDisplay {
34
- display: inline-flex;
35
- align-items: center;
36
- justify-content: center;
37
- width: var(--spacing-6);
38
- height: var(--spacing-6);
39
- background-color: var(--card-bg);
40
- color: transparent;
41
- border: var(--border-width) solid var(--muted-foreground);
42
- border-radius: var(--radius);
43
- transition: all var(--duration-fast) var(--ease-in-out);
44
- }
45
- .checkboxInput:checked + .checkboxDisplay {
46
- background-color: var(--primary);
47
- border-color: var(--card-border);
48
- color: var(--primary-foreground);
49
- }
50
-
51
- .icon {
52
- width: 80%;
53
- height: 80%;
54
- stroke-width: 3.5px;
55
- }
56
-
57
- .labelOverride {
58
- cursor: pointer;
59
- margin-left: var(--spacing-1);
1
+ @layer doom.components {
2
+ .checkboxWrapper {
3
+ display: inline-flex;
4
+ align-items: center;
5
+ gap: var(--space-2);
6
+ cursor: pointer;
7
+ user-select: none;
8
+ }
9
+ .checkboxWrapper.disabled {
10
+ cursor: not-allowed;
11
+ opacity: 0.6;
12
+ }
13
+ .checkboxInput {
14
+ position: absolute;
15
+ opacity: 0;
16
+ width: 0;
17
+ height: 0;
18
+ margin: 0;
19
+ }
20
+ .checkboxInput:focus-visible + .checkboxDisplay:focus-visible {
21
+ outline: none;
22
+ transform: translate(calc(-1 * var(--space-0\.5)), calc(-1 * var(--space-0\.5)));
23
+ box-shadow: var(--shadow-offset-xl) var(--shadow-primary);
24
+ border-color: var(--primary);
25
+ }
26
+ .checkboxInput:focus-visible + .checkboxDisplay:focus {
27
+ outline: none;
28
+ }
29
+ .checkboxInput:focus-visible + .checkboxDisplay {
30
+ outline: var(--surface-border-width) solid var(--primary);
31
+ }
32
+ .checkboxDisplay {
33
+ display: inline-flex;
34
+ align-items: center;
35
+ justify-content: center;
36
+ width: var(--toggle-size);
37
+ height: var(--toggle-size);
38
+ background-color: var(--card-bg);
39
+ color: transparent;
40
+ border: var(--surface-border-width) solid var(--muted-foreground);
41
+ border-radius: var(--radius-md);
42
+ transition: all var(--duration-fast) var(--ease-in-out);
43
+ }
44
+ .checkboxInput:checked + .checkboxDisplay {
45
+ background-color: var(--primary);
46
+ border-color: var(--card-border);
47
+ color: var(--primary-foreground);
48
+ }
49
+ .icon {
50
+ width: 80%;
51
+ height: 80%;
52
+ stroke-width: 3.5px;
53
+ }
54
+ .labelOverride {
55
+ cursor: pointer;
56
+ margin-left: var(--space-1);
57
+ }
60
58
  }
@@ -1,116 +1,106 @@
1
- .chip {
2
- display: inline-flex;
3
- align-items: center;
4
- gap: var(--spacing-1);
5
- font-family: var(--font-family);
6
- font-weight: 600;
7
- text-transform: uppercase;
8
- letter-spacing: 0.05em;
9
- border: var(--border-width) solid var(--card-border);
10
- border-radius: var(--radius);
11
- background: var(--surface-accent);
12
- color: var(--foreground);
13
- transition: all 0.1s ease;
14
- justify-content: center;
15
- white-space: nowrap;
16
- vertical-align: middle;
17
- user-select: none;
18
- }
19
- .chip.clickable {
20
- cursor: pointer;
21
- }
22
- .chip.interactive:hover:not(.disabled) {
23
- filter: brightness(1.1);
24
- }
25
- .chip.interactive:focus-visible, .chip.interactive[aria-expanded=true] {
26
- outline: none;
27
- transform: translate(-2px, -2px);
28
- box-shadow: 6px 6px 0px 0px var(--shadow-primary);
29
- border-color: var(--primary);
30
- }
31
- .chip.interactive:focus {
32
- outline: none;
33
- }
34
- .chip.disabled {
35
- opacity: 0.5;
36
- cursor: not-allowed;
37
- }
38
-
39
- .xs {
40
- padding: var(--spacing-half) var(--spacing-1);
41
- font-size: var(--text-2xs);
42
- }
43
-
44
- .sm {
45
- padding: var(--spacing-1) var(--spacing-2);
46
- font-size: var(--text-xs);
47
- }
48
-
49
- .md {
50
- padding: var(--spacing-1) var(--spacing-3);
51
- font-size: var(--text-xs);
52
- }
53
-
54
- .lg {
55
- padding: var(--spacing-2) var(--spacing-4);
56
- font-size: var(--text-sm);
57
- }
58
-
59
- .xl {
60
- padding: var(--spacing-2) var(--spacing-6);
61
- font-size: var(--text-base);
62
- }
63
-
64
- .default {
65
- background: var(--surface-accent);
66
- border-color: var(--card-border);
67
- color: var(--foreground);
68
- }
69
-
70
- .primary {
71
- background: var(--primary);
72
- color: var(--primary-foreground);
73
- }
74
-
75
- .success {
76
- background: var(--success);
77
- color: var(--success-foreground);
78
- }
79
-
80
- .warning {
81
- background: var(--warning);
82
- color: var(--warning-foreground);
83
- }
84
-
85
- .error {
86
- background: var(--error);
87
- color: var(--error-foreground);
88
- }
89
-
90
- .content {
91
- display: inline-flex;
92
- align-items: center;
93
- gap: var(--spacing-1);
94
- }
95
-
96
- .dismissButton {
97
- display: inline-flex;
98
- align-items: center;
99
- justify-content: center;
100
- padding: 0;
101
- margin-left: var(--spacing-half);
102
- background: transparent;
103
- border: none;
104
- border-radius: var(--radius);
105
- color: currentColor;
106
- opacity: 0.7;
107
- cursor: pointer;
108
- transition: opacity 0.1s ease;
109
- }
110
- .dismissButton:hover {
111
- opacity: 1;
112
- }
113
- .dismissButton:focus-visible {
114
- outline: 1px solid currentColor;
115
- outline-offset: var(--spacing-half);
1
+ @layer doom.components {
2
+ .chip {
3
+ display: inline-flex;
4
+ align-items: center;
5
+ gap: var(--space-1);
6
+ font-family: var(--font-family);
7
+ font-weight: 600;
8
+ text-transform: uppercase;
9
+ letter-spacing: 0.05em;
10
+ border: var(--surface-border-width) solid var(--card-border);
11
+ border-radius: var(--radius-md);
12
+ background: var(--surface-accent);
13
+ color: var(--foreground);
14
+ transition: all 0.1s ease;
15
+ justify-content: center;
16
+ white-space: nowrap;
17
+ vertical-align: middle;
18
+ user-select: none;
19
+ }
20
+ .chip.clickable {
21
+ cursor: pointer;
22
+ }
23
+ .chip.interactive:hover:not(.disabled) {
24
+ filter: brightness(1.1);
25
+ }
26
+ .chip.interactive:focus-visible {
27
+ outline: none;
28
+ transform: translate(calc(-1 * var(--space-0\.5)), calc(-1 * var(--space-0\.5)));
29
+ box-shadow: var(--shadow-offset-xl) var(--shadow-primary);
30
+ border-color: var(--primary);
31
+ }
32
+ .chip.interactive:focus {
33
+ outline: none;
34
+ }
35
+ .chip.disabled {
36
+ opacity: 0.5;
37
+ cursor: not-allowed;
38
+ }
39
+ .xs {
40
+ padding: var(--space-0\.5) var(--space-1);
41
+ font-size: var(--text-2xs);
42
+ }
43
+ .sm {
44
+ padding: var(--space-1) var(--space-2);
45
+ font-size: var(--text-xs);
46
+ }
47
+ .md {
48
+ padding: var(--space-1) var(--space-3);
49
+ font-size: var(--text-xs);
50
+ }
51
+ .lg {
52
+ padding: var(--space-2) var(--space-4);
53
+ font-size: var(--text-sm);
54
+ }
55
+ .xl {
56
+ padding: var(--space-2) var(--space-6);
57
+ font-size: var(--text-base);
58
+ }
59
+ .default {
60
+ background: var(--surface-accent);
61
+ border-color: var(--card-border);
62
+ color: var(--foreground);
63
+ }
64
+ .primary {
65
+ background: var(--primary);
66
+ color: var(--primary-foreground);
67
+ }
68
+ .success {
69
+ background: var(--success);
70
+ color: var(--success-foreground);
71
+ }
72
+ .warning {
73
+ background: var(--warning);
74
+ color: var(--warning-foreground);
75
+ }
76
+ .error {
77
+ background: var(--error);
78
+ color: var(--error-foreground);
79
+ }
80
+ .content {
81
+ display: inline-flex;
82
+ align-items: center;
83
+ gap: var(--space-1);
84
+ }
85
+ .dismissButton {
86
+ display: inline-flex;
87
+ align-items: center;
88
+ justify-content: center;
89
+ padding: 0;
90
+ margin-left: var(--space-0\.5);
91
+ background: transparent;
92
+ border: none;
93
+ border-radius: var(--radius-md);
94
+ color: currentColor;
95
+ opacity: 0.7;
96
+ cursor: pointer;
97
+ transition: opacity 0.1s ease;
98
+ }
99
+ .dismissButton:hover {
100
+ opacity: 1;
101
+ }
102
+ .dismissButton:focus-visible {
103
+ outline: 1px solid currentColor;
104
+ outline-offset: var(--space-0\.5);
105
+ }
116
106
  }
@@ -1,3 +1,4 @@
1
+ import { ControlSize } from "../../styles/types";
1
2
  export interface ComboboxOption {
2
3
  value: string;
3
4
  label: string;
@@ -9,7 +10,7 @@ interface ComboboxProps {
9
10
  placeholder?: string;
10
11
  multiple?: boolean;
11
12
  searchable?: boolean;
12
- size?: "sm" | "md";
13
+ size?: ControlSize;
13
14
  disabled?: boolean;
14
15
  className?: string;
15
16
  inline?: boolean;
@@ -178,7 +178,7 @@ export function Combobox({ options, value, onChange, placeholder = "Select...",
178
178
  }, [selectedValues, options, placeholder]);
179
179
  const hasValue = selectedValues.length > 0;
180
180
  const allSelected = multiple && selectedValues.length === options.length;
181
- const dropdownContent = (_jsxs(Card.Root, { className: clsx(styles.dropdown, inline && styles.inlineDropdown), onClick: (e) => e.stopPropagation(), children: [searchable && (_jsxs("div", { className: styles.searchWrapper, children: [_jsx(Search, { className: styles.searchIcon, size: 16 }), _jsx("input", { ref: inputRef, className: styles.searchInput, placeholder: "Search...", type: "text", value: searchQuery, onChange: (e) => setSearchQuery(e.target.value), onKeyDown: handleSearchKeyDown })] })), multiple && options.length > 0 && (_jsx("div", { className: styles.stickyOption, children: _jsxs("button", { className: clsx(styles.option, allSelected && styles.selected), id: selectAllId, type: "button", onClick: (e) => {
181
+ const dropdownContent = (_jsxs(Card.Root, { className: clsx(styles.dropdown, inline && styles.inlineDropdown), onClick: (e) => e.stopPropagation(), children: [searchable && (_jsxs("div", { className: styles.searchWrapper, children: [_jsx(Search, { className: styles.searchIcon, size: 20 }), _jsx("input", { ref: inputRef, className: styles.searchInput, placeholder: "Search...", type: "text", value: searchQuery, onChange: (e) => setSearchQuery(e.target.value), onKeyDown: handleSearchKeyDown })] })), multiple && options.length > 0 && (_jsx("div", { className: styles.stickyOption, children: _jsxs("button", { className: clsx(styles.option, allSelected && styles.selected), id: selectAllId, type: "button", onClick: (e) => {
182
182
  e.stopPropagation();
183
183
  handleSelectAll();
184
184
  }, onKeyDown: (e) => handleOptionKeyDown(e, -1), children: [_jsx("div", { style: { pointerEvents: "none" }, children: _jsx(Checkbox, { readOnly: true, checked: allSelected }) }), _jsx(Text, { as: "span", className: styles.optionLabel, children: "All" })] }) })), _jsx("div", { ref: optionsListRef, className: styles.optionsList, children: filteredOptions.length === 0 ? (_jsx("div", { className: styles.noResults, children: _jsx(Text, { className: styles.noResultsText, children: "No results" }) })) : (_jsx("div", { style: {
@@ -205,7 +205,7 @@ export function Combobox({ options, value, onChange, placeholder = "Select...",
205
205
  if (e.key === "Enter") {
206
206
  handleClear(e);
207
207
  }
208
- }, children: _jsx(X, { size: 12 }) })), _jsx(ChevronDown, { className: styles.chevron, size: 16 })] })] }), onClose: () => {
208
+ }, children: _jsx(X, { size: 12 }) })), _jsx(ChevronDown, { className: styles.chevron, size: 20 })] })] }), onClose: () => {
209
209
  setIsOpen(false);
210
210
  setSearchQuery("");
211
211
  } }));