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,132 +1,109 @@
1
- /* Base styles */
2
- .text {
3
- text-align: left;
4
- /* Default align */
5
- }
6
-
7
- /* Alignment */
8
- .align-left {
9
- text-align: left;
10
- }
11
-
12
- .align-center {
13
- text-align: center;
14
- }
15
-
16
- .align-right {
17
- text-align: right;
18
- }
19
-
20
- /* Variants - all headings reset margins for predictable layout */
21
- .h1,
22
- .h2,
23
- .h3,
24
- .h4,
25
- .h5,
26
- .h6 {
27
- margin: 0;
28
- }
29
-
30
- .h1 {
31
- font-size: var(--text-5xl);
32
- font-weight: var(--font-black);
33
- line-height: 1.1;
34
- letter-spacing: -0.02em;
35
- }
36
-
37
- .h2 {
38
- font-size: var(--text-4xl);
39
- font-weight: var(--font-black);
40
- line-height: 1.1;
41
- letter-spacing: -0.02em;
42
- }
43
-
44
- .h3 {
45
- font-size: var(--text-3xl);
46
- font-weight: var(--font-black);
47
- line-height: 1.1;
48
- }
49
-
50
- .h4 {
51
- font-size: var(--text-2xl);
52
- font-weight: var(--font-bold);
53
- line-height: 1.2;
54
- }
55
-
56
- .h5 {
57
- font-size: var(--text-xl);
58
- font-weight: var(--font-bold);
59
- line-height: 1.3;
60
- }
61
-
62
- .h6 {
63
- font-size: var(--text-lg);
64
- font-weight: var(--font-bold);
65
- line-height: 1.4;
66
- }
67
-
68
- .small {
69
- font-size: var(--text-xs);
70
- line-height: 1.5;
71
- }
72
-
73
- .caption {
74
- font-size: var(--text-xs);
75
- line-height: 1.5;
76
- color: var(--muted-foreground);
77
- }
78
-
79
- .body {
80
- font-size: var(--text-base);
81
- line-height: 1.6;
82
- }
83
-
84
- /* Weights */
85
- .weight-normal {
86
- font-weight: var(--font-regular);
87
- }
88
-
89
- .weight-medium {
90
- font-weight: var(--font-medium);
91
- }
92
-
93
- .weight-semibold {
94
- font-weight: var(--font-bold);
95
- }
96
-
97
- .weight-bold {
98
- font-weight: var(--font-bold);
99
- }
100
-
101
- .weight-black {
102
- font-weight: var(--font-black);
103
- }
104
-
105
- /* Colors */
106
- .color-primary {
107
- color: var(--primary);
108
- }
109
-
110
- .color-secondary {
111
- color: var(--secondary);
112
- }
113
-
114
- .color-muted {
115
- color: var(--muted-foreground);
116
- }
117
-
118
- .color-error {
119
- color: var(--error);
120
- }
121
-
122
- .color-success {
123
- color: var(--success);
124
- }
125
-
126
- .color-warning {
127
- color: var(--warning);
128
- }
129
-
130
- .color-foreground {
131
- color: var(--foreground);
1
+ @layer doom.components {
2
+ /* Base styles */
3
+ .text {
4
+ text-align: left;
5
+ /* Default align */
6
+ }
7
+ /* Alignment */
8
+ .align-left {
9
+ text-align: left;
10
+ }
11
+ .align-center {
12
+ text-align: center;
13
+ }
14
+ .align-right {
15
+ text-align: right;
16
+ }
17
+ /* Variants - all headings reset margins for predictable layout */
18
+ .h1,
19
+ .h2,
20
+ .h3,
21
+ .h4,
22
+ .h5,
23
+ .h6 {
24
+ margin: 0;
25
+ }
26
+ .h1 {
27
+ font-size: var(--text-5xl);
28
+ font-weight: var(--font-black);
29
+ line-height: 1.1;
30
+ letter-spacing: -0.02em;
31
+ }
32
+ .h2 {
33
+ font-size: var(--text-4xl);
34
+ font-weight: var(--font-black);
35
+ line-height: 1.1;
36
+ letter-spacing: -0.02em;
37
+ }
38
+ .h3 {
39
+ font-size: var(--text-3xl);
40
+ font-weight: var(--font-black);
41
+ line-height: 1.1;
42
+ }
43
+ .h4 {
44
+ font-size: var(--text-2xl);
45
+ font-weight: var(--font-bold);
46
+ line-height: 1.2;
47
+ }
48
+ .h5 {
49
+ font-size: var(--text-xl);
50
+ font-weight: var(--font-bold);
51
+ line-height: 1.3;
52
+ }
53
+ .h6 {
54
+ font-size: var(--text-lg);
55
+ font-weight: var(--font-bold);
56
+ line-height: 1.4;
57
+ }
58
+ .small {
59
+ font-size: var(--text-xs);
60
+ line-height: 1.5;
61
+ }
62
+ .caption {
63
+ font-size: var(--text-xs);
64
+ line-height: 1.5;
65
+ color: var(--muted-foreground);
66
+ }
67
+ .body {
68
+ font-size: var(--text-base);
69
+ line-height: 1.6;
70
+ }
71
+ /* Weights */
72
+ .weight-normal {
73
+ font-weight: var(--font-regular);
74
+ }
75
+ .weight-medium {
76
+ font-weight: var(--font-medium);
77
+ }
78
+ .weight-semibold {
79
+ font-weight: var(--font-bold);
80
+ }
81
+ .weight-bold {
82
+ font-weight: var(--font-bold);
83
+ }
84
+ .weight-black {
85
+ font-weight: var(--font-black);
86
+ }
87
+ /* Colors */
88
+ .color-primary {
89
+ color: var(--primary);
90
+ }
91
+ .color-secondary {
92
+ color: var(--secondary);
93
+ }
94
+ .color-muted {
95
+ color: var(--muted-foreground);
96
+ }
97
+ .color-error {
98
+ color: var(--error);
99
+ }
100
+ .color-success {
101
+ color: var(--success);
102
+ }
103
+ .color-warning {
104
+ color: var(--warning);
105
+ }
106
+ .color-foreground {
107
+ color: var(--foreground);
108
+ }
132
109
  }
@@ -1,8 +1,10 @@
1
1
  import React from "react";
2
+ import type { ControlSize } from "../../styles/types";
2
3
  export interface TextareaProps extends React.TextareaHTMLAttributes<HTMLTextAreaElement> {
3
4
  label?: string;
4
5
  error?: string;
5
6
  helperText?: string;
6
7
  showCount?: boolean;
8
+ size?: ControlSize;
7
9
  }
8
- export declare function Textarea({ label, error, helperText, showCount, className, style, id, required, maxLength, value, defaultValue, onChange, ...props }: TextareaProps): import("react/jsx-runtime").JSX.Element;
10
+ export declare function Textarea({ label, error, helperText, showCount, size, className, style, id, required, maxLength, value, defaultValue, onChange, ...props }: TextareaProps): import("react/jsx-runtime").JSX.Element;
@@ -16,7 +16,7 @@ import React, { useId, useState } from "react";
16
16
  import { Label } from "../Label/Label.js";
17
17
  import styles from "./Textarea.module.css";
18
18
  export function Textarea(_a) {
19
- var { label, error, helperText, showCount, className, style, id, required, maxLength, value, defaultValue, onChange } = _a, props = __rest(_a, ["label", "error", "helperText", "showCount", "className", "style", "id", "required", "maxLength", "value", "defaultValue", "onChange"]);
19
+ var { label, error, helperText, showCount, size = "md", className, style, id, required, maxLength, value, defaultValue, onChange } = _a, props = __rest(_a, ["label", "error", "helperText", "showCount", "size", "className", "style", "id", "required", "maxLength", "value", "defaultValue", "onChange"]);
20
20
  const reactId = useId();
21
21
  const textareaId = id || `textarea-${reactId}`;
22
22
  const helperId = `${textareaId}-helper`;
@@ -35,5 +35,5 @@ export function Textarea(_a) {
35
35
  }
36
36
  }, [value]);
37
37
  const describedBy = clsx(helperText && helperId, error && errorId) || undefined;
38
- return (_jsxs("div", { className: clsx(styles.container, className), style: style, children: [label && (_jsx(Label, { htmlFor: textareaId, required: required, children: label })), _jsx("textarea", Object.assign({ "aria-describedby": describedBy, "aria-invalid": !!error, className: clsx(styles.textarea, error && styles.error), defaultValue: defaultValue, id: textareaId, maxLength: maxLength, required: required, value: value, onChange: handleChange }, props)), (error || helperText || (showCount !== null && showCount !== void 0 ? showCount : maxLength !== undefined)) && (_jsxs("div", { className: styles.bottomRow, children: [_jsx("div", { className: styles.messageArea, children: error ? (_jsx("span", { className: clsx(styles.helperText, styles.error), id: errorId, role: "alert", children: error })) : (helperText && (_jsx("span", { className: styles.helperText, id: helperId, children: helperText }))) }), (showCount !== null && showCount !== void 0 ? showCount : maxLength !== undefined) && (_jsxs("span", { className: styles.counter, children: [charCount, maxLength !== undefined ? ` / ${maxLength}` : ""] }))] }))] }));
38
+ return (_jsxs("div", { className: clsx(styles.container, size !== "md" && styles[size], className), style: style, children: [label && (_jsx(Label, { htmlFor: textareaId, required: required, children: label })), _jsx("textarea", Object.assign({ "aria-describedby": describedBy, "aria-invalid": !!error, className: clsx(styles.textarea, error && styles.error), defaultValue: defaultValue, id: textareaId, maxLength: maxLength, required: required, value: value, onChange: handleChange }, props)), (error || helperText || (showCount !== null && showCount !== void 0 ? showCount : maxLength !== undefined)) && (_jsxs("div", { className: styles.bottomRow, children: [_jsx("div", { className: styles.messageArea, children: error ? (_jsx("span", { className: clsx(styles.helperText, styles.error), id: errorId, role: "alert", children: error })) : (helperText && (_jsx("span", { className: styles.helperText, id: helperId, children: helperText }))) }), (showCount !== null && showCount !== void 0 ? showCount : maxLength !== undefined) && (_jsxs("span", { className: styles.counter, children: [charCount, maxLength !== undefined ? ` / ${maxLength}` : ""] }))] }))] }));
39
39
  }
@@ -1,98 +1,118 @@
1
- .container {
2
- display: flex;
3
- flex-direction: column;
4
- gap: var(--spacing-2);
5
- width: 100%;
6
- }
7
-
8
- .textarea {
9
- width: 100%;
10
- padding: var(--spacing-4) var(--spacing-6);
11
- font-size: var(--text-base);
12
- background: var(--card-bg);
13
- color: var(--foreground);
14
- font-family: inherit;
15
- resize: vertical;
16
- min-height: var(--spacing-24);
17
- box-sizing: border-box;
18
- border: var(--border-width) solid var(--card-border);
19
- border-radius: var(--radius);
20
- box-shadow: var(--shadow-hard);
21
- transition: all 0.1s ease;
22
- outline: none;
23
- }
24
- .textarea:focus-visible, .textarea[aria-expanded=true] {
25
- outline: none;
26
- transform: translate(-2px, -2px);
27
- box-shadow: 6px 6px 0px 0px var(--shadow-primary);
28
- border-color: var(--primary);
29
- }
30
- .textarea:focus {
31
- outline: none;
32
- }
33
- .textarea::placeholder {
34
- color: var(--muted);
35
- }
36
- .textarea.error {
37
- border-color: var(--error);
38
- box-shadow: 5px 5px 0px 0px var(--shadow-error);
39
- }
40
- .textarea.error:focus, .textarea.error:focus-visible {
41
- border-color: var(--error);
42
- box-shadow: 6px 6px 0px 0px var(--shadow-error);
43
- }
44
- .textarea:disabled {
45
- cursor: not-allowed;
46
- opacity: 0.7;
47
- background-color: var(--muted);
48
- background-image: linear-gradient(45deg, transparent 25%, rgba(0, 0, 0, 0.05) 25%, rgba(0, 0, 0, 0.05) 50%, transparent 50%, transparent 75%, rgba(0, 0, 0, 0.05) 75%, rgba(0, 0, 0, 0.05));
49
- background-size: 20px 20px;
50
- box-shadow: none;
51
- transform: none;
52
- color: var(--muted-foreground);
53
- }
54
- .textarea:disabled::placeholder {
55
- color: var(--muted-foreground);
56
- }
57
-
58
- .bottomRow {
59
- display: flex;
60
- justify-content: space-between;
61
- align-items: flex-start;
62
- gap: var(--spacing-4);
63
- }
64
-
65
- .messageArea {
66
- flex: 1;
67
- }
68
-
69
- .helperText {
70
- font-size: var(--text-xs);
71
- font-weight: var(--font-medium);
72
- color: var(--muted-foreground);
73
- display: block;
74
- }
75
- .helperText.error {
76
- color: var(--error);
77
- font-weight: var(--font-bold);
78
- text-transform: uppercase;
79
- animation: textarea-shake 0.3s ease-in-out;
80
- }
81
- @keyframes textarea-shake {
82
- 0%, 100% {
83
- transform: translateX(0);
1
+ @layer doom.components {
2
+ .container {
3
+ display: flex;
4
+ flex-direction: column;
5
+ gap: var(--space-2);
6
+ width: 100%;
84
7
  }
85
- 25% {
86
- transform: translateX(-4px);
8
+ .textarea {
9
+ width: 100%;
10
+ padding: var(--control-padding-y) var(--control-padding-x);
11
+ font-size: var(--control-font-size);
12
+ background: var(--card-bg);
13
+ color: var(--foreground);
14
+ font-family: inherit;
15
+ resize: vertical;
16
+ min-height: 120px;
17
+ box-sizing: border-box;
18
+ border: var(--surface-border-width) solid var(--card-border);
19
+ border-radius: var(--control-radius);
20
+ box-shadow: var(--shadow-md);
21
+ transition: all var(--duration-fast) var(--ease-in-out);
22
+ outline: none;
87
23
  }
88
- 75% {
89
- transform: translateX(4px);
24
+ .textarea:focus-visible {
25
+ outline: none;
26
+ transform: translate(calc(-1 * var(--space-0\.5)), calc(-1 * var(--space-0\.5)));
27
+ box-shadow: var(--shadow-offset-xl) var(--shadow-primary);
28
+ border-color: var(--primary);
29
+ }
30
+ .textarea:focus {
31
+ outline: none;
32
+ }
33
+ .textarea::placeholder {
34
+ color: var(--muted);
35
+ }
36
+ .textarea.error {
37
+ border-color: var(--error);
38
+ box-shadow: var(--shadow-offset-lg) var(--shadow-error);
39
+ }
40
+ .textarea.error:focus, .textarea.error:focus-visible {
41
+ border-color: var(--error);
42
+ box-shadow: var(--shadow-offset-xl) var(--shadow-error);
43
+ }
44
+ .textarea:disabled {
45
+ opacity: 0.6;
46
+ cursor: not-allowed !important;
47
+ background-image: repeating-linear-gradient(45deg, transparent, transparent 10px, rgba(0, 0, 0, 0.05) 10px, rgba(0, 0, 0, 0.05) 20px) !important;
48
+ }
49
+ .textarea:disabled:hover {
50
+ transform: none !important;
51
+ filter: none !important;
52
+ }
53
+ .textarea:disabled {
54
+ box-shadow: none;
55
+ transform: none;
56
+ color: var(--muted-foreground);
57
+ }
58
+ .textarea:disabled::placeholder {
59
+ color: var(--muted-foreground);
60
+ }
61
+ /* Sizes */
62
+ .sm {
63
+ --control-height: var(--size-7);
64
+ --control-padding-x: var(--space-2);
65
+ --control-padding-y: var(--space-1);
66
+ --control-font-size: var(--text-xs);
67
+ --control-icon-size: var(--size-4);
68
+ --control-gap: var(--space-1);
69
+ --control-radius: var(--radius-sm);
70
+ }
71
+ .lg {
72
+ --control-height: var(--size-10);
73
+ --control-padding-x: var(--space-4);
74
+ --control-padding-y: var(--space-2);
75
+ --control-font-size: var(--text-base);
76
+ --control-icon-size: var(--size-5);
77
+ --control-gap: var(--space-2);
78
+ --control-radius: var(--radius-md);
79
+ }
80
+ .bottomRow {
81
+ display: flex;
82
+ justify-content: space-between;
83
+ align-items: flex-start;
84
+ gap: var(--space-3);
85
+ }
86
+ .messageArea {
87
+ flex: 1;
88
+ }
89
+ .helperText {
90
+ font-size: var(--text-xs);
91
+ font-weight: var(--font-medium);
92
+ color: var(--muted-foreground);
93
+ display: block;
94
+ }
95
+ .helperText.error {
96
+ color: var(--error);
97
+ font-weight: var(--font-bold);
98
+ text-transform: uppercase;
99
+ animation: textarea-shake 0.3s ease-in-out;
100
+ }
101
+ @keyframes textarea-shake {
102
+ 0%, 100% {
103
+ transform: translateX(0);
104
+ }
105
+ 25% {
106
+ transform: translateX(calc(-1 * var(--space-1)));
107
+ }
108
+ 75% {
109
+ transform: translateX(var(--space-1));
110
+ }
111
+ }
112
+ .counter {
113
+ font-size: var(--text-xs);
114
+ font-weight: var(--font-medium);
115
+ color: var(--muted-foreground);
116
+ white-space: nowrap;
90
117
  }
91
- }
92
-
93
- .counter {
94
- font-size: var(--text-xs);
95
- font-weight: var(--font-medium);
96
- color: var(--muted-foreground);
97
- white-space: nowrap;
98
118
  }
@@ -1,87 +1,87 @@
1
- @keyframes slideIn {
2
- from {
3
- transform: translateX(100%);
4
- opacity: 0;
1
+ @layer doom.components {
2
+ @keyframes slideIn {
3
+ from {
4
+ transform: translateX(100%);
5
+ opacity: 0;
6
+ }
7
+ to {
8
+ transform: translateX(0);
9
+ opacity: 1;
10
+ }
5
11
  }
6
- to {
7
- transform: translateX(0);
8
- opacity: 1;
12
+ @keyframes slideOut {
13
+ from {
14
+ transform: translateX(0);
15
+ opacity: 1;
16
+ }
17
+ to {
18
+ transform: translateX(100%);
19
+ opacity: 0;
20
+ }
9
21
  }
10
- }
11
- @keyframes slideOut {
12
- from {
13
- transform: translateX(0);
14
- opacity: 1;
22
+ .container {
23
+ position: fixed;
24
+ bottom: var(--space-8);
25
+ right: var(--space-8);
26
+ display: flex;
27
+ flex-direction: column;
28
+ gap: var(--space-4);
29
+ z-index: var(--z-tooltip);
30
+ pointer-events: none; /* Allow clicking through the container area */
15
31
  }
16
- to {
17
- transform: translateX(100%);
18
- opacity: 0;
32
+ .toast {
33
+ min-width: 288px;
34
+ background: var(--card-bg);
35
+ border: var(--surface-border-width) solid var(--card-border);
36
+ color: var(--foreground);
37
+ box-shadow: var(--shadow-md);
38
+ padding: var(--space-4);
39
+ display: flex;
40
+ align-items: center;
41
+ gap: var(--space-3);
42
+ animation: slideIn var(--duration-slow) var(--ease-out) forwards;
43
+ position: relative;
44
+ overflow: hidden;
45
+ pointer-events: auto; /* Re-enable pointer events for the toast itself */
46
+ border-radius: var(--radius-md);
47
+ }
48
+ .toast.exiting {
49
+ animation: slideOut var(--duration-slow) var(--ease-in) forwards;
50
+ }
51
+ .toast {
52
+ /* Left Accent Bar */
53
+ }
54
+ .toast::before {
55
+ content: "";
56
+ position: absolute;
57
+ left: 0;
58
+ top: 0;
59
+ bottom: 0;
60
+ width: var(--space-1);
61
+ }
62
+ .toast.success::before {
63
+ background-color: var(--success);
64
+ }
65
+ .toast.error::before {
66
+ background-color: var(--error);
67
+ }
68
+ .toast.warning::before {
69
+ background-color: var(--warning);
70
+ }
71
+ .toast.info::before {
72
+ background-color: var(--primary);
73
+ }
74
+ .closeButton {
75
+ background: none;
76
+ border: none;
77
+ margin-left: auto;
78
+ cursor: pointer;
79
+ font-size: var(--text-xl);
80
+ color: var(--foreground);
81
+ opacity: 0.5;
82
+ transition: opacity var(--duration-fast);
83
+ }
84
+ .closeButton:hover {
85
+ opacity: 1;
19
86
  }
20
- }
21
- .container {
22
- position: fixed;
23
- bottom: var(--spacing-8);
24
- right: var(--spacing-8);
25
- display: flex;
26
- flex-direction: column;
27
- gap: var(--spacing-4);
28
- z-index: var(--z-tooltip);
29
- pointer-events: none; /* Allow clicking through the container area */
30
- }
31
-
32
- .toast {
33
- min-width: var(--spacing-72);
34
- background: var(--card-bg);
35
- border: var(--border-width) solid var(--card-border);
36
- color: var(--foreground);
37
- box-shadow: var(--shadow-hard);
38
- padding: var(--spacing-4);
39
- display: flex;
40
- align-items: center;
41
- gap: var(--spacing-3);
42
- animation: slideIn var(--duration-slow) var(--ease-out) forwards;
43
- position: relative;
44
- overflow: hidden;
45
- pointer-events: auto; /* Re-enable pointer events for the toast itself */
46
- border-radius: var(--radius);
47
- }
48
- .toast.exiting {
49
- animation: slideOut var(--duration-slow) var(--ease-in) forwards;
50
- }
51
- .toast {
52
- /* Left Accent Bar */
53
- }
54
- .toast::before {
55
- content: "";
56
- position: absolute;
57
- left: 0;
58
- top: 0;
59
- bottom: 0;
60
- width: var(--spacing-1);
61
- }
62
- .toast.success::before {
63
- background-color: var(--success);
64
- }
65
- .toast.error::before {
66
- background-color: var(--error);
67
- }
68
- .toast.warning::before {
69
- background-color: var(--warning);
70
- }
71
- .toast.info::before {
72
- background-color: var(--primary);
73
- }
74
-
75
- .closeButton {
76
- background: none;
77
- border: none;
78
- margin-left: auto;
79
- cursor: pointer;
80
- font-size: var(--text-xl);
81
- color: var(--foreground);
82
- opacity: 0.5;
83
- transition: opacity var(--duration-fast);
84
- }
85
- .closeButton:hover {
86
- opacity: 1;
87
87
  }
@@ -1,17 +1,18 @@
1
- .triggerWrapper {
2
- display: inline-block;
3
- cursor: help;
4
- }
5
-
6
- .tooltipBody {
7
- padding: 0.5rem 0.75rem;
8
- background-color: var(--foreground);
9
- color: var(--background);
10
- font-size: var(--text-sm);
11
- font-weight: 500;
12
- white-space: nowrap;
13
- border-radius: var(--radius);
14
- border: var(--border-width) solid var(--card-border);
15
- box-shadow: var(--shadow-sm);
16
- z-index: var(--z-tooltip);
1
+ @layer doom.components {
2
+ .triggerWrapper {
3
+ display: inline-block;
4
+ cursor: help;
5
+ }
6
+ .tooltipBody {
7
+ padding: var(--space-2) var(--space-3);
8
+ background-color: var(--foreground);
9
+ color: var(--background);
10
+ font-size: var(--text-sm);
11
+ font-weight: 500;
12
+ white-space: nowrap;
13
+ border-radius: var(--radius-md);
14
+ border: var(--surface-border-width) solid var(--card-border);
15
+ box-shadow: var(--shadow-sm);
16
+ z-index: var(--z-tooltip);
17
+ }
17
18
  }