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,81 +1,78 @@
1
- .group {
2
- display: flex;
3
- flex-direction: column;
4
- gap: var(--spacing-2);
5
- }
6
-
7
- .itemLabel {
8
- display: flex;
9
- align-items: center;
10
- gap: var(--spacing-3);
11
- cursor: pointer;
12
- position: relative;
13
- padding: var(--spacing-3) var(--spacing-4);
14
- border-radius: var(--radius);
15
- transition: all 0.15s ease;
16
- opacity: 1;
17
- }
18
- .itemLabel:hover:not([aria-disabled=true]) {
19
- background-color: var(--muted);
20
- background-color: color-mix(in srgb, var(--primary) 8%, transparent);
21
- }
22
- .itemLabel.disabled {
23
- cursor: not-allowed;
24
- opacity: 0.5;
25
- }
26
-
27
- .radioCircle {
28
- width: var(--spacing-6);
29
- height: var(--spacing-6);
30
- border: var(--border-width) solid var(--foreground);
31
- border-radius: 50%;
32
- background: var(--background);
33
- display: flex;
34
- align-items: center;
35
- justify-content: center;
36
- transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
37
- flex-shrink: 0;
38
- position: relative;
39
- }
40
- .radioCircle.checked {
41
- border-color: var(--primary);
42
- background: var(--primary);
43
- box-shadow: 0 0 0 var(--spacing-1) color-mix(in srgb, var(--primary) 15%, transparent);
44
- }
45
-
46
- .innerDot {
47
- width: var(--spacing-3);
48
- height: var(--spacing-3);
49
- background: var(--primary-foreground);
50
- border-radius: 50%;
51
- transform: scale(0);
52
- animation: radioScale 0.2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
53
- }
54
-
55
- @keyframes radioScale {
56
- from {
1
+ @layer doom.components {
2
+ .group {
3
+ display: flex;
4
+ flex-direction: column;
5
+ gap: var(--space-2);
6
+ }
7
+ .itemLabel {
8
+ display: flex;
9
+ align-items: center;
10
+ gap: var(--space-2);
11
+ cursor: pointer;
12
+ position: relative;
13
+ padding: var(--space-3) var(--space-4);
14
+ border-radius: var(--radius-md);
15
+ transition: all 0.15s ease;
16
+ opacity: 1;
17
+ }
18
+ .itemLabel:hover:not([aria-disabled=true]) {
19
+ background-color: var(--muted);
20
+ background-color: color-mix(in srgb, var(--primary) 8%, transparent);
21
+ }
22
+ .itemLabel.disabled {
23
+ cursor: not-allowed;
24
+ opacity: 0.5;
25
+ }
26
+ .radioCircle {
27
+ width: var(--toggle-size);
28
+ height: var(--toggle-size);
29
+ border: var(--surface-border-width) solid var(--foreground);
30
+ border-radius: 50%;
31
+ background: var(--background);
32
+ display: flex;
33
+ align-items: center;
34
+ justify-content: center;
35
+ transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
36
+ flex-shrink: 0;
37
+ position: relative;
38
+ }
39
+ .radioCircle.checked {
40
+ border-color: var(--primary);
41
+ background: var(--primary);
42
+ box-shadow: 0 0 0 var(--space-1) color-mix(in srgb, var(--primary) 15%, transparent);
43
+ }
44
+ .innerDot {
45
+ width: var(--space-3);
46
+ height: var(--space-3);
47
+ background: var(--primary-foreground);
48
+ border-radius: 50%;
57
49
  transform: scale(0);
50
+ animation: radioScale 0.2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
58
51
  }
59
- to {
60
- transform: scale(1);
52
+ @keyframes radioScale {
53
+ from {
54
+ transform: scale(0);
55
+ }
56
+ to {
57
+ transform: scale(1);
58
+ }
59
+ }
60
+ .hiddenInput {
61
+ position: absolute;
62
+ opacity: 0;
63
+ width: 1px;
64
+ height: 1px;
65
+ pointer-events: none;
66
+ }
67
+ .hiddenInput:focus-visible ~ .radioCircle {
68
+ outline: var(--outline-width) solid var(--primary);
69
+ outline-offset: var(--outline-offset);
70
+ }
71
+ .labelText {
72
+ font-family: var(--font-body);
73
+ font-weight: 500;
74
+ font-size: var(--text-base);
75
+ color: var(--foreground);
76
+ user-select: none;
61
77
  }
62
- }
63
- .hiddenInput {
64
- position: absolute;
65
- opacity: 0;
66
- width: 1px;
67
- height: 1px;
68
- pointer-events: none;
69
- }
70
- .hiddenInput:focus-visible ~ .radioCircle {
71
- outline: var(--outline-width) solid var(--primary);
72
- outline-offset: var(--outline-offset);
73
- }
74
-
75
- .labelText {
76
- font-family: var(--font-body);
77
- font-weight: 500;
78
- font-size: var(--text-base);
79
- color: var(--foreground);
80
- user-select: none;
81
78
  }
@@ -1,4 +1,5 @@
1
1
  import React from "react";
2
+ import { ControlSize } from "../../styles/types";
2
3
  interface SelectProps extends Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, "onChange" | "value" | "defaultValue"> {
3
4
  options: {
4
5
  value: string | number;
@@ -11,7 +12,7 @@ interface SelectProps extends Omit<React.ButtonHTMLAttributes<HTMLButtonElement>
11
12
  defaultValue?: string | number;
12
13
  name?: string;
13
14
  required?: boolean;
14
- size?: "sm" | "md";
15
+ size?: ControlSize;
15
16
  }
16
17
  export declare function Select({ options, className, label, style, value, defaultValue, onChange, placeholder, id, required, disabled, name, autoFocus, size, ...props }: SelectProps): import("react/jsx-runtime").JSX.Element;
17
18
  export {};
@@ -106,7 +106,7 @@ export function Select(_a) {
106
106
  return (_jsxs("li", { "aria-selected": isSelected, className: clsx(styles.optionItem, isSelected && styles.selected, isHighlighted && styles.highlighted), id: `${listboxId}-option-${index}`, role: "option", onClick: () => handleSelect(opt.value), onMouseEnter: () => setHighlightedIndex(index), children: [_jsx("span", { children: opt.label }), isSelected && (_jsx(Check, { "aria-hidden": "true", size: 14, strokeWidth: 3 }))] }, opt.value));
107
107
  }) }), isOpen: isOpen, placement: "bottom-start", trigger: _jsxs("button", Object.assign({ ref: triggerRef, "aria-controls": isOpen ? listboxId : undefined, "aria-expanded": isOpen, "aria-haspopup": "listbox", "aria-label": !label
108
108
  ? (selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.label) || placeholder || "Select option"
109
- : undefined, "aria-labelledby": label ? labelId : undefined, "aria-required": required, autoFocus: autoFocus, className: clsx(styles.trigger, size === "sm" && styles.sm), disabled: disabled, id: selectId, role: "combobox", type: "button", onClick: () => setIsOpen(!isOpen), onKeyDown: handleKeyDown }, props, { children: [_jsx("span", { children: selectedOption
109
+ : undefined, "aria-labelledby": label ? labelId : undefined, "aria-required": required, autoFocus: autoFocus, className: clsx(styles.trigger, size !== "md" && styles[size]), disabled: disabled, id: selectId, role: "combobox", type: "button", onClick: () => setIsOpen(!isOpen), onKeyDown: handleKeyDown }, props, { children: [_jsx("span", { children: selectedOption
110
110
  ? selectedOption.label
111
- : placeholder || "Select..." }), _jsx(ChevronDown, { "aria-hidden": "true", size: 16, strokeWidth: 2.5, style: { marginLeft: "var(--spacing-2)" } })] })), onClose: () => setIsOpen(false) }), _jsx("input", { "aria-hidden": "true", "aria-labelledby": label ? labelId : undefined, name: name, required: required, type: "hidden", value: currentValue })] }));
111
+ : placeholder || "Select..." }), _jsx(ChevronDown, { "aria-hidden": "true", size: 20, strokeWidth: 2.5, style: { marginLeft: "var(--space-2)" } })] })), onClose: () => setIsOpen(false) }), _jsx("input", { "aria-hidden": "true", "aria-labelledby": label ? labelId : undefined, name: name, required: required, type: "hidden", value: currentValue })] }));
112
112
  }
@@ -1,99 +1,134 @@
1
- .container {
2
- display: flex;
3
- flex-direction: column;
4
- position: relative;
5
- }
6
-
7
- .trigger {
8
- background: var(--card-bg);
9
- color: var(--foreground);
10
- padding: var(--spacing-4) var(--spacing-6);
11
- font-size: var(--text-base);
12
- cursor: pointer;
13
- display: flex;
14
- justify-content: space-between;
15
- align-items: center;
16
- font-weight: var(--font-bold);
17
- text-transform: uppercase;
18
- letter-spacing: 0.05em;
19
- min-height: var(--control-height-lg);
20
- box-sizing: border-box;
21
- width: 100%;
22
- border: var(--border-width) solid var(--card-border);
23
- border-radius: var(--radius);
24
- box-shadow: var(--shadow-hard);
25
- transition: all 0.1s ease;
26
- outline: none;
27
- }
28
- .trigger:hover {
29
- transform: translate(-2px, -2px);
30
- box-shadow: 6px 6px 0px 0px var(--shadow-base);
31
- }
32
- .trigger:focus-visible, .trigger[aria-expanded=true] {
33
- outline: none;
34
- transform: translate(-2px, -2px);
35
- box-shadow: 6px 6px 0px 0px var(--shadow-primary);
36
- border-color: var(--primary);
37
- }
38
- .trigger:focus {
39
- outline: none;
40
- }
41
- .trigger.sm {
42
- padding: var(--spacing-2) var(--spacing-4);
43
- min-height: var(--control-height-md);
44
- font-size: var(--text-xs);
45
- text-transform: uppercase;
46
- letter-spacing: 0.05em;
47
- }
48
-
49
- .optionsList {
50
- background: var(--card-bg);
51
- border: var(--border-width) solid var(--primary);
52
- border-radius: var(--radius);
53
- box-shadow: none;
54
- min-width: var(--spacing-50);
55
- max-height: var(--spacing-72);
56
- overflow-y: auto;
57
- display: flex;
58
- flex-direction: column;
59
- gap: var(--spacing-1);
60
- padding: var(--spacing-1);
61
- margin: 0;
62
- list-style: none;
63
- }
64
-
65
- .optionItem {
66
- text-align: left;
67
- padding: var(--spacing-4) var(--spacing-6);
68
- background: transparent;
69
- border: none;
70
- border-radius: calc(var(--radius) - 2px);
71
- color: var(--foreground);
72
- cursor: pointer;
73
- font-size: var(--text-base);
74
- font-weight: var(--font-regular);
75
- transition: all var(--duration-fast) var(--ease-in-out);
76
- width: 100%;
77
- display: flex;
78
- align-items: center;
79
- justify-content: space-between;
80
- user-select: none;
81
- }
82
- .optionItem:hover {
83
- background-color: color-mix(in srgb, var(--primary), transparent 85%);
84
- color: color-mix(in srgb, var(--primary), var(--foreground) 25%);
85
- }
86
- .optionItem.highlighted {
87
- background: color-mix(in srgb, var(--primary), transparent 85%);
88
- color: color-mix(in srgb, var(--primary), var(--foreground) 25%);
89
- }
90
- .optionItem.selected {
91
- background: var(--primary);
92
- color: var(--primary-foreground);
93
- font-weight: var(--font-bold);
94
- }
95
- .optionItem.selected:hover {
96
- background-color: var(--primary);
97
- color: var(--primary-foreground);
98
- filter: brightness(1.1);
1
+ @layer doom.components {
2
+ .container {
3
+ display: flex;
4
+ flex-direction: column;
5
+ position: relative;
6
+ }
7
+ .trigger {
8
+ background: var(--card-bg);
9
+ color: var(--foreground);
10
+ cursor: pointer;
11
+ display: flex;
12
+ justify-content: space-between;
13
+ align-items: center;
14
+ font-weight: var(--font-bold);
15
+ text-transform: uppercase;
16
+ letter-spacing: 0.05em;
17
+ width: 100%;
18
+ box-sizing: border-box;
19
+ height: var(--control-height);
20
+ padding: var(--control-padding-y) var(--control-padding-x);
21
+ font-size: var(--control-font-size);
22
+ border: var(--surface-border-width) solid var(--card-border);
23
+ border-radius: var(--control-radius);
24
+ box-shadow: var(--shadow-md);
25
+ transition: all var(--duration-fast) var(--ease-in-out);
26
+ outline: none;
27
+ }
28
+ .trigger:hover {
29
+ transform: translate(calc(-1 * var(--space-0\.5)), calc(-1 * var(--space-0\.5)));
30
+ box-shadow: var(--shadow-lg);
31
+ }
32
+ .trigger:focus-visible {
33
+ outline: none;
34
+ transform: translate(calc(-1 * var(--space-0\.5)), calc(-1 * var(--space-0\.5)));
35
+ box-shadow: var(--shadow-offset-xl) var(--shadow-primary);
36
+ border-color: var(--primary);
37
+ }
38
+ .trigger:focus {
39
+ outline: none;
40
+ }
41
+ .trigger[aria-expanded=true] {
42
+ outline: none;
43
+ transform: translate(calc(-1 * var(--space-0\.5)), calc(-1 * var(--space-0\.5)));
44
+ box-shadow: var(--shadow-offset-xl) var(--shadow-primary);
45
+ border-color: var(--primary);
46
+ }
47
+ .trigger:active {
48
+ transition: none;
49
+ transform: translate(var(--space-0\.5), var(--space-0\.5));
50
+ box-shadow: none;
51
+ }
52
+ .trigger:disabled {
53
+ opacity: 0.6;
54
+ cursor: not-allowed !important;
55
+ background-image: repeating-linear-gradient(45deg, transparent, transparent 10px, rgba(0, 0, 0, 0.05) 10px, rgba(0, 0, 0, 0.05) 20px) !important;
56
+ }
57
+ .trigger:disabled:hover {
58
+ transform: none !important;
59
+ filter: none !important;
60
+ }
61
+ .trigger:disabled {
62
+ transform: none;
63
+ box-shadow: var(--shadow-md);
64
+ }
65
+ /* Sizes */
66
+ .sm {
67
+ --control-height: var(--size-7);
68
+ --control-padding-x: var(--space-2);
69
+ --control-padding-y: var(--space-1);
70
+ --control-font-size: var(--text-xs);
71
+ --control-icon-size: var(--size-4);
72
+ --control-gap: var(--space-1);
73
+ --control-radius: var(--radius-sm);
74
+ }
75
+ .lg {
76
+ --control-height: var(--size-10);
77
+ --control-padding-x: var(--space-4);
78
+ --control-padding-y: var(--space-2);
79
+ --control-font-size: var(--text-base);
80
+ --control-icon-size: var(--size-5);
81
+ --control-gap: var(--space-2);
82
+ --control-radius: var(--radius-md);
83
+ }
84
+ .optionsList {
85
+ background: var(--card-bg);
86
+ border: var(--surface-border-width) solid var(--primary);
87
+ border-radius: var(--control-radius);
88
+ box-shadow: none;
89
+ min-width: 12.5rem;
90
+ max-height: 18rem;
91
+ overflow-y: auto;
92
+ display: flex;
93
+ flex-direction: column;
94
+ gap: var(--space-1);
95
+ padding: var(--space-1);
96
+ margin: 0;
97
+ list-style: none;
98
+ }
99
+ .optionItem {
100
+ text-align: left;
101
+ padding: var(--control-padding-y) var(--control-padding-x);
102
+ background: transparent;
103
+ border: none;
104
+ border-radius: calc(var(--control-radius) - var(--surface-border-width));
105
+ color: var(--foreground);
106
+ cursor: pointer;
107
+ font-size: var(--control-font-size);
108
+ font-weight: var(--font-regular);
109
+ transition: all var(--duration-fast) var(--ease-in-out);
110
+ width: 100%;
111
+ display: flex;
112
+ align-items: center;
113
+ justify-content: space-between;
114
+ user-select: none;
115
+ }
116
+ .optionItem:hover {
117
+ background-color: color-mix(in srgb, var(--primary), transparent 85%);
118
+ color: color-mix(in srgb, var(--primary), var(--foreground) 25%);
119
+ }
120
+ .optionItem.highlighted {
121
+ background: color-mix(in srgb, var(--primary), transparent 85%);
122
+ color: color-mix(in srgb, var(--primary), var(--foreground) 25%);
123
+ }
124
+ .optionItem.selected {
125
+ background: var(--primary);
126
+ color: var(--primary-foreground);
127
+ font-weight: var(--font-bold);
128
+ }
129
+ .optionItem.selected:hover {
130
+ background-color: var(--primary);
131
+ color: var(--primary-foreground);
132
+ filter: brightness(1.1);
133
+ }
99
134
  }