@proyecto-viviana/solidaria 0.2.4 → 0.2.8

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 (219) hide show
  1. package/LICENSE +21 -0
  2. package/dist/actiongroup/createActionGroup.d.ts +29 -0
  3. package/dist/actiongroup/createActionGroup.d.ts.map +1 -0
  4. package/dist/actiongroup/index.d.ts +2 -0
  5. package/dist/actiongroup/index.d.ts.map +1 -0
  6. package/dist/autocomplete/createAutocomplete.d.ts +6 -2
  7. package/dist/autocomplete/createAutocomplete.d.ts.map +1 -1
  8. package/dist/breadcrumbs/createBreadcrumbs.d.ts +2 -0
  9. package/dist/breadcrumbs/createBreadcrumbs.d.ts.map +1 -1
  10. package/dist/button/createToggleButtonGroup.d.ts +32 -0
  11. package/dist/button/createToggleButtonGroup.d.ts.map +1 -0
  12. package/dist/button/index.d.ts +2 -0
  13. package/dist/button/index.d.ts.map +1 -1
  14. package/dist/calendar/createCalendarCell.d.ts +2 -0
  15. package/dist/calendar/createCalendarCell.d.ts.map +1 -1
  16. package/dist/calendar/createCalendarGrid.d.ts.map +1 -1
  17. package/dist/calendar/createRangeCalendarCell.d.ts +3 -1
  18. package/dist/calendar/createRangeCalendarCell.d.ts.map +1 -1
  19. package/dist/checkbox/createCheckboxGroup.d.ts +5 -1
  20. package/dist/checkbox/createCheckboxGroup.d.ts.map +1 -1
  21. package/dist/collections/index.d.ts +56 -0
  22. package/dist/collections/index.d.ts.map +1 -0
  23. package/dist/color/createColorArea.d.ts.map +1 -1
  24. package/dist/color/createColorSlider.d.ts.map +1 -1
  25. package/dist/color/createColorWheel.d.ts.map +1 -1
  26. package/dist/combobox/createComboBox.d.ts +6 -0
  27. package/dist/combobox/createComboBox.d.ts.map +1 -1
  28. package/dist/datepicker/createDatePicker.d.ts +6 -0
  29. package/dist/datepicker/createDatePicker.d.ts.map +1 -1
  30. package/dist/datepicker/createDateRangePicker.d.ts +40 -0
  31. package/dist/datepicker/createDateRangePicker.d.ts.map +1 -0
  32. package/dist/datepicker/createDateSegment.d.ts +1 -1
  33. package/dist/datepicker/createDateSegment.d.ts.map +1 -1
  34. package/dist/datepicker/createTimeSegment.d.ts +29 -0
  35. package/dist/datepicker/createTimeSegment.d.ts.map +1 -0
  36. package/dist/datepicker/index.d.ts +2 -0
  37. package/dist/datepicker/index.d.ts.map +1 -1
  38. package/dist/disclosure/createDisclosureGroup.d.ts +2 -1
  39. package/dist/disclosure/createDisclosureGroup.d.ts.map +1 -1
  40. package/dist/dnd/createDrag.d.ts.map +1 -1
  41. package/dist/dnd/createDraggableCollection.d.ts +4 -0
  42. package/dist/dnd/createDraggableCollection.d.ts.map +1 -1
  43. package/dist/dnd/createDraggableItem.d.ts.map +1 -1
  44. package/dist/dnd/createDrop.d.ts.map +1 -1
  45. package/dist/dnd/createDroppableCollection.d.ts +32 -1
  46. package/dist/dnd/createDroppableCollection.d.ts.map +1 -1
  47. package/dist/dnd/createDroppableItem.d.ts.map +1 -1
  48. package/dist/dnd/index.d.ts +1 -1
  49. package/dist/dnd/index.d.ts.map +1 -1
  50. package/dist/grid/createGrid.d.ts.map +1 -1
  51. package/dist/gridlist/createGridList.d.ts.map +1 -1
  52. package/dist/index.d.ts +6 -4
  53. package/dist/index.d.ts.map +1 -1
  54. package/dist/index.js +4659 -3452
  55. package/dist/index.js.map +1 -7
  56. package/dist/index.ssr.js +4659 -3452
  57. package/dist/index.ssr.js.map +1 -7
  58. package/dist/interactions/createFocus.d.ts.map +1 -1
  59. package/dist/interactions/createFocusWithin.d.ts.map +1 -1
  60. package/dist/link/createLink.d.ts +10 -0
  61. package/dist/link/createLink.d.ts.map +1 -1
  62. package/dist/listbox/createListBox.d.ts +1 -0
  63. package/dist/listbox/createListBox.d.ts.map +1 -1
  64. package/dist/listbox/createOption.d.ts.map +1 -1
  65. package/dist/menu/createMenu.d.ts +1 -0
  66. package/dist/menu/createMenu.d.ts.map +1 -1
  67. package/dist/meter/createMeter.d.ts.map +1 -1
  68. package/dist/numberfield/createNumberField.d.ts +18 -0
  69. package/dist/numberfield/createNumberField.d.ts.map +1 -1
  70. package/dist/overlays/createModal.d.ts +16 -0
  71. package/dist/overlays/createModal.d.ts.map +1 -1
  72. package/dist/overlays/createOverlay.d.ts.map +1 -1
  73. package/dist/overlays/index.d.ts +1 -1
  74. package/dist/overlays/index.d.ts.map +1 -1
  75. package/dist/popover/createOverlayPosition.d.ts.map +1 -1
  76. package/dist/popover/createPopover.d.ts.map +1 -1
  77. package/dist/progress/createProgressBar.d.ts.map +1 -1
  78. package/dist/radio/createRadioGroup.d.ts +2 -2
  79. package/dist/radio/createRadioGroup.d.ts.map +1 -1
  80. package/dist/searchfield/createSearchField.d.ts.map +1 -1
  81. package/dist/select/createHiddenSelect.d.ts.map +1 -1
  82. package/dist/select/createSelect.d.ts.map +1 -1
  83. package/dist/slider/createSlider.d.ts.map +1 -1
  84. package/dist/table/createTable.d.ts.map +1 -1
  85. package/dist/tabs/createTabs.d.ts +1 -1
  86. package/dist/tabs/createTabs.d.ts.map +1 -1
  87. package/dist/tag/createTag.d.ts.map +1 -1
  88. package/dist/tag/createTagGroup.d.ts.map +1 -1
  89. package/dist/toast/createToast.d.ts +4 -0
  90. package/dist/toast/createToast.d.ts.map +1 -1
  91. package/dist/toast/createToastRegion.d.ts.map +1 -1
  92. package/dist/toolbar/createToolbar.d.ts.map +1 -1
  93. package/dist/tooltip/createTooltipTrigger.d.ts.map +1 -1
  94. package/dist/tree/createTree.d.ts.map +1 -1
  95. package/dist/tree/createTreeItem.d.ts.map +1 -1
  96. package/dist/tree/types.d.ts +4 -0
  97. package/dist/tree/types.d.ts.map +1 -1
  98. package/dist/utils/env.d.ts +1 -1
  99. package/dist/utils/env.d.ts.map +1 -1
  100. package/dist/utils/platform.d.ts.map +1 -1
  101. package/dist/visually-hidden/createVisuallyHidden.d.ts.map +1 -1
  102. package/package.json +8 -6
  103. package/src/actiongroup/createActionGroup.ts +324 -0
  104. package/src/actiongroup/index.ts +8 -0
  105. package/src/autocomplete/createAutocomplete.ts +32 -9
  106. package/src/breadcrumbs/createBreadcrumbs.ts +10 -15
  107. package/src/button/createButton.ts +1 -1
  108. package/src/button/createToggleButtonGroup.ts +128 -0
  109. package/src/button/index.ts +9 -0
  110. package/src/calendar/createCalendarCell.ts +6 -4
  111. package/src/calendar/createCalendarGrid.ts +27 -18
  112. package/src/calendar/createRangeCalendarCell.ts +26 -9
  113. package/src/checkbox/createCheckboxGroup.ts +21 -4
  114. package/src/collections/index.ts +242 -0
  115. package/src/color/createColorArea.ts +380 -314
  116. package/src/color/createColorField.ts +137 -137
  117. package/src/color/createColorSlider.ts +286 -197
  118. package/src/color/createColorSwatch.ts +40 -40
  119. package/src/color/createColorWheel.ts +218 -208
  120. package/src/color/index.ts +24 -24
  121. package/src/color/types.ts +116 -116
  122. package/src/combobox/createComboBox.ts +670 -647
  123. package/src/combobox/index.ts +6 -6
  124. package/src/datepicker/createDatePicker.ts +54 -16
  125. package/src/datepicker/createDateRangePicker.ts +246 -0
  126. package/src/datepicker/createDateSegment.ts +185 -31
  127. package/src/datepicker/createTimeSegment.ts +370 -0
  128. package/src/datepicker/index.ts +14 -0
  129. package/src/dialog/createDialog.ts +120 -120
  130. package/src/dialog/index.ts +2 -2
  131. package/src/dialog/types.ts +19 -19
  132. package/src/disclosure/createDisclosureGroup.ts +5 -2
  133. package/src/dnd/createDrag.ts +224 -209
  134. package/src/dnd/createDraggableCollection.ts +96 -63
  135. package/src/dnd/createDraggableItem.ts +259 -243
  136. package/src/dnd/createDrop.ts +322 -321
  137. package/src/dnd/createDroppableCollection.ts +682 -293
  138. package/src/dnd/createDroppableItem.ts +215 -213
  139. package/src/dnd/index.ts +55 -47
  140. package/src/dnd/types.ts +89 -89
  141. package/src/dnd/utils.ts +294 -294
  142. package/src/focus/createAutoFocus.ts +321 -321
  143. package/src/focus/createFocusRestore.ts +313 -313
  144. package/src/focus/createVirtualFocus.ts +396 -396
  145. package/src/form/createFormValidation.ts +224 -224
  146. package/src/form/index.ts +11 -11
  147. package/src/grid/createGrid.ts +3 -1
  148. package/src/gridlist/createGridList.ts +16 -0
  149. package/src/gridlist/createGridListItem.ts +1 -1
  150. package/src/i18n/NumberFormatter.ts +266 -266
  151. package/src/i18n/createCollator.ts +79 -79
  152. package/src/i18n/createDateFormatter.ts +83 -83
  153. package/src/i18n/createFilter.ts +131 -131
  154. package/src/i18n/createNumberFormatter.ts +52 -52
  155. package/src/i18n/index.ts +40 -40
  156. package/src/i18n/locale.tsx +188 -188
  157. package/src/i18n/utils.ts +99 -99
  158. package/src/index.ts +51 -0
  159. package/src/interactions/createFocus.ts +6 -5
  160. package/src/interactions/createFocusWithin.ts +6 -5
  161. package/src/interactions/createLongPress.ts +174 -174
  162. package/src/interactions/createMove.ts +289 -289
  163. package/src/interactions/createPress.ts +5 -5
  164. package/src/landmark/createLandmark.ts +377 -377
  165. package/src/landmark/index.ts +8 -8
  166. package/src/link/createLink.ts +23 -8
  167. package/src/listbox/createListBox.ts +308 -269
  168. package/src/listbox/createOption.ts +162 -151
  169. package/src/listbox/index.ts +12 -12
  170. package/src/live-announcer/announce.ts +322 -322
  171. package/src/live-announcer/index.ts +9 -9
  172. package/src/menu/createMenu.ts +405 -396
  173. package/src/menu/createMenuItem.ts +149 -149
  174. package/src/menu/createMenuTrigger.ts +88 -88
  175. package/src/menu/index.ts +18 -18
  176. package/src/meter/createMeter.ts +1 -6
  177. package/src/numberfield/createNumberField.ts +311 -268
  178. package/src/numberfield/index.ts +5 -5
  179. package/src/overlays/ariaHideOutside.ts +219 -219
  180. package/src/overlays/createInteractOutside.ts +149 -149
  181. package/src/overlays/createModal.tsx +238 -202
  182. package/src/overlays/createOverlay.ts +165 -155
  183. package/src/overlays/createOverlayTrigger.ts +85 -85
  184. package/src/overlays/createPreventScroll.ts +266 -266
  185. package/src/overlays/index.ts +48 -44
  186. package/src/popover/calculatePosition.ts +6 -6
  187. package/src/popover/createOverlayPosition.ts +7 -4
  188. package/src/popover/createPopover.ts +21 -7
  189. package/src/progress/createProgressBar.ts +6 -1
  190. package/src/radio/createRadioGroup.ts +88 -14
  191. package/src/searchfield/createSearchField.ts +241 -186
  192. package/src/searchfield/index.ts +2 -2
  193. package/src/select/createHiddenSelect.tsx +263 -236
  194. package/src/select/createSelect.ts +373 -395
  195. package/src/select/index.ts +14 -14
  196. package/src/slider/createSlider.ts +364 -349
  197. package/src/slider/index.ts +2 -2
  198. package/src/ssr/index.tsx +370 -370
  199. package/src/table/createTable.ts +3 -1
  200. package/src/table/createTableColumnHeader.ts +1 -1
  201. package/src/table/createTableRow.ts +1 -1
  202. package/src/tabs/createTabs.ts +80 -51
  203. package/src/tag/createTag.ts +135 -6
  204. package/src/tag/createTagGroup.ts +7 -2
  205. package/src/toast/createToast.ts +8 -2
  206. package/src/toast/createToastRegion.ts +0 -1
  207. package/src/toolbar/createToolbar.ts +75 -1
  208. package/src/tooltip/createTooltip.ts +79 -79
  209. package/src/tooltip/createTooltipTrigger.ts +226 -222
  210. package/src/tooltip/index.ts +6 -6
  211. package/src/tree/createTree.ts +261 -246
  212. package/src/tree/createTreeItem.ts +282 -233
  213. package/src/tree/createTreeSelectionCheckbox.ts +68 -68
  214. package/src/tree/index.ts +16 -16
  215. package/src/tree/types.ts +91 -87
  216. package/src/utils/env.ts +55 -54
  217. package/src/utils/platform.ts +16 -6
  218. package/src/visually-hidden/createVisuallyHidden.ts +139 -124
  219. package/src/visually-hidden/index.ts +6 -6
@@ -1,208 +1,218 @@
1
- /**
2
- * createColorWheel hook.
3
- *
4
- * Provides ARIA attributes and keyboard/pointer handling for a circular hue selector.
5
- */
6
-
7
- import { createMemo, type Accessor } from 'solid-js';
8
- import type { ColorWheelState } from '@proyecto-viviana/solid-stately';
9
- import { createId } from '../ssr';
10
- import type { AriaColorWheelOptions, ColorWheelAria } from './types';
11
-
12
- /**
13
- * Creates ARIA props for a color wheel.
14
- */
15
- export function createColorWheel(
16
- props: Accessor<AriaColorWheelOptions>,
17
- state: Accessor<ColorWheelState>,
18
- wheelRef: Accessor<HTMLDivElement | null>
19
- ): ColorWheelAria {
20
- const getProps = () => props();
21
- const getState = () => state();
22
-
23
- // Generate IDs
24
- const inputId = createId();
25
-
26
- // Calculate angle from pointer position
27
- const getAngleFromEvent = (e: MouseEvent | PointerEvent) => {
28
- const wheel = wheelRef();
29
- if (!wheel) return null;
30
-
31
- const rect = wheel.getBoundingClientRect();
32
- const centerX = rect.left + rect.width / 2;
33
- const centerY = rect.top + rect.height / 2;
34
-
35
- const dx = e.clientX - centerX;
36
- const dy = e.clientY - centerY;
37
-
38
- return Math.atan2(-dy, dx); // Negative dy because Y is inverted in screen coords
39
- };
40
-
41
- // Handle pointer down
42
- const onPointerDown = (e: PointerEvent) => {
43
- if (getProps().isDisabled || getState().isDisabled) return;
44
-
45
- const angle = getAngleFromEvent(e);
46
- if (angle === null) return;
47
-
48
- getState().setHueFromAngle(angle);
49
- getState().setDragging(true);
50
-
51
- (e.target as HTMLElement).setPointerCapture?.(e.pointerId);
52
- };
53
-
54
- // Handle pointer move
55
- const onPointerMove = (e: PointerEvent) => {
56
- if (!getState().isDragging) return;
57
-
58
- const angle = getAngleFromEvent(e);
59
- if (angle === null) return;
60
-
61
- getState().setHueFromAngle(angle);
62
- };
63
-
64
- // Handle pointer up
65
- const onPointerUp = (e: PointerEvent) => {
66
- if (getState().isDragging) {
67
- getState().setDragging(false);
68
- (e.target as HTMLElement).releasePointerCapture?.(e.pointerId);
69
- }
70
- };
71
-
72
- // Handle keyboard
73
- const onKeyDown = (e: KeyboardEvent) => {
74
- if (getProps().isDisabled || getState().isDisabled) return;
75
-
76
- const s = getState();
77
- let handled = true;
78
-
79
- switch (e.key) {
80
- case 'ArrowRight':
81
- case 'ArrowUp':
82
- s.increment();
83
- break;
84
- case 'ArrowLeft':
85
- case 'ArrowDown':
86
- s.decrement();
87
- break;
88
- case 'PageUp':
89
- s.increment(s.pageStep);
90
- break;
91
- case 'PageDown':
92
- s.decrement(s.pageStep);
93
- break;
94
- case 'Home':
95
- s.setHue(0);
96
- break;
97
- case 'End':
98
- s.setHue(359);
99
- break;
100
- default:
101
- handled = false;
102
- }
103
-
104
- if (handled) {
105
- e.preventDefault();
106
- e.stopPropagation();
107
- }
108
- };
109
-
110
- // Track props (the wheel container)
111
- const trackProps = createMemo(() => {
112
- const s = getState();
113
- const p = getProps();
114
-
115
- return {
116
- role: 'presentation' as const,
117
- onPointerDown,
118
- onPointerMove,
119
- onPointerUp,
120
- style: {
121
- position: 'relative' as const,
122
- 'touch-action': 'none',
123
- },
124
- 'data-disabled': s.isDisabled || p.isDisabled || undefined,
125
- };
126
- });
127
-
128
- // Thumb props
129
- const thumbProps = createMemo(() => {
130
- const s = getState();
131
- const p = getProps();
132
- const angle = s.getThumbAngle();
133
-
134
- // Calculate thumb position on the wheel edge
135
- // Assumes wheel is circular and thumb is at the outer edge
136
- // Angle 0 = right (3 o'clock)
137
- const thumbX = Math.cos(angle);
138
- const thumbY = -Math.sin(angle); // Negative because CSS Y is inverted
139
-
140
- return {
141
- role: 'presentation' as const,
142
- style: {
143
- position: 'absolute' as const,
144
- // Position relative to center, scaled to radius
145
- // These will be overridden by the component with actual radius
146
- left: `calc(50% + ${thumbX * 50}%)`,
147
- top: `calc(50% + ${thumbY * 50}%)`,
148
- transform: 'translate(-50%, -50%)',
149
- 'touch-action': 'none',
150
- },
151
- 'data-dragging': s.isDragging || undefined,
152
- 'data-disabled': s.isDisabled || p.isDisabled || undefined,
153
- };
154
- });
155
-
156
- // Input props (hidden, for accessibility)
157
- const inputProps = createMemo(() => {
158
- const s = getState();
159
- const p = getProps();
160
-
161
- return {
162
- type: 'range',
163
- id: inputId,
164
- min: 0,
165
- max: 360,
166
- step: s.step,
167
- value: s.getHue(),
168
- disabled: s.isDisabled || p.isDisabled,
169
- 'aria-label': p['aria-label'] ?? 'Hue',
170
- 'aria-labelledby': p['aria-labelledby'],
171
- 'aria-describedby': p['aria-describedby'],
172
- 'aria-valuetext': `${s.getHue()}°`,
173
- onKeyDown,
174
- onChange: (e: Event) => {
175
- const target = e.target as HTMLInputElement;
176
- s.setHue(parseFloat(target.value));
177
- },
178
- onBlur: () => {
179
- if (s.isDragging) {
180
- s.setDragging(false);
181
- }
182
- },
183
- style: {
184
- position: 'absolute' as const,
185
- width: '1px',
186
- height: '1px',
187
- padding: '0',
188
- margin: '-1px',
189
- overflow: 'hidden',
190
- clip: 'rect(0, 0, 0, 0)',
191
- 'white-space': 'nowrap',
192
- border: '0',
193
- },
194
- };
195
- });
196
-
197
- return {
198
- get trackProps() {
199
- return trackProps();
200
- },
201
- get thumbProps() {
202
- return thumbProps();
203
- },
204
- get inputProps() {
205
- return inputProps();
206
- },
207
- };
208
- }
1
+ /**
2
+ * createColorWheel hook.
3
+ *
4
+ * Provides ARIA attributes and keyboard/pointer handling for a circular hue selector.
5
+ */
6
+
7
+ import { createMemo, type Accessor } from 'solid-js';
8
+ import type { ColorWheelState } from '@proyecto-viviana/solid-stately';
9
+ import { createId } from '../ssr';
10
+ import type { AriaColorWheelOptions, ColorWheelAria } from './types';
11
+
12
+ /**
13
+ * Creates ARIA props for a color wheel.
14
+ */
15
+ export function createColorWheel(
16
+ props: Accessor<AriaColorWheelOptions>,
17
+ state: Accessor<ColorWheelState>,
18
+ wheelRef: Accessor<HTMLDivElement | null>
19
+ ): ColorWheelAria {
20
+ const getProps = () => props();
21
+ const getState = () => state();
22
+
23
+ // Generate IDs
24
+ const inputId = createId();
25
+
26
+ // Calculate angle from pointer position
27
+ const getAngleFromEvent = (e: MouseEvent | PointerEvent) => {
28
+ const wheel = wheelRef();
29
+ if (!wheel) return null;
30
+
31
+ const rect = wheel.getBoundingClientRect();
32
+ const centerX = rect.left + rect.width / 2;
33
+ const centerY = rect.top + rect.height / 2;
34
+
35
+ const dx = e.clientX - centerX;
36
+ const dy = e.clientY - centerY;
37
+
38
+ return Math.atan2(-dy, dx); // Negative dy because Y is inverted in screen coords
39
+ };
40
+
41
+ // Handle pointer down
42
+ const onPointerDown = (e: PointerEvent) => {
43
+ if (getProps().isDisabled || getState().isDisabled) return;
44
+
45
+ const angle = getAngleFromEvent(e);
46
+ if (angle === null) return;
47
+
48
+ getState().setHueFromAngle(angle);
49
+ getState().setDragging(true);
50
+
51
+ (e.target as HTMLElement).setPointerCapture?.(e.pointerId);
52
+ };
53
+
54
+ // Handle pointer move
55
+ const onPointerMove = (e: PointerEvent) => {
56
+ if (!getState().isDragging) return;
57
+
58
+ const angle = getAngleFromEvent(e);
59
+ if (angle === null) return;
60
+
61
+ getState().setHueFromAngle(angle);
62
+ };
63
+
64
+ // Handle pointer up
65
+ const onPointerUp = (e: PointerEvent) => {
66
+ if (getState().isDragging) {
67
+ getState().setDragging(false);
68
+ (e.target as HTMLElement).releasePointerCapture?.(e.pointerId);
69
+ }
70
+ };
71
+
72
+ // Handle keyboard
73
+ const onKeyDown = (e: KeyboardEvent) => {
74
+ if (getProps().isDisabled || getState().isDisabled) return;
75
+
76
+ const s = getState();
77
+ let handled = true;
78
+
79
+ switch (e.key) {
80
+ case 'ArrowRight':
81
+ case 'ArrowUp':
82
+ s.increment();
83
+ break;
84
+ case 'ArrowLeft':
85
+ case 'ArrowDown':
86
+ s.decrement();
87
+ break;
88
+ case 'PageUp':
89
+ s.increment(s.pageStep);
90
+ break;
91
+ case 'PageDown':
92
+ s.decrement(s.pageStep);
93
+ break;
94
+ case 'Home':
95
+ s.setHue(0);
96
+ break;
97
+ case 'End':
98
+ s.setHue(359);
99
+ break;
100
+ default:
101
+ handled = false;
102
+ }
103
+
104
+ if (handled) {
105
+ e.preventDefault();
106
+ e.stopPropagation();
107
+ }
108
+ };
109
+
110
+ // Hue spectrum conic gradient
111
+ const conicGradient = `conic-gradient(from 90deg, hsl(0, 100%, 50%), hsl(30, 100%, 50%), hsl(60, 100%, 50%), hsl(90, 100%, 50%), hsl(120, 100%, 50%), hsl(150, 100%, 50%), hsl(180, 100%, 50%), hsl(210, 100%, 50%), hsl(240, 100%, 50%), hsl(270, 100%, 50%), hsl(300, 100%, 50%), hsl(330, 100%, 50%), hsl(360, 100%, 50%))`;
112
+
113
+ // Track props (the wheel container)
114
+ const trackProps = createMemo(() => {
115
+ const s = getState();
116
+ const p = getProps();
117
+
118
+ return {
119
+ role: 'presentation' as const,
120
+ onPointerDown,
121
+ onPointerMove,
122
+ onPointerUp,
123
+ style: {
124
+ position: 'relative' as const,
125
+ 'touch-action': 'none',
126
+ 'border-radius': '50%',
127
+ background: conicGradient,
128
+ // Use radial-gradient mask to cut out center hole (creates ring shape)
129
+ // 35% inner radius leaves a nice thick ring
130
+ '-webkit-mask-image': 'radial-gradient(circle, transparent 35%, black 36%)',
131
+ 'mask-image': 'radial-gradient(circle, transparent 35%, black 36%)',
132
+ 'forced-color-adjust': 'none' as const,
133
+ },
134
+ 'data-disabled': s.isDisabled || p.isDisabled || undefined,
135
+ };
136
+ });
137
+
138
+ // Thumb props
139
+ const thumbProps = createMemo(() => {
140
+ const s = getState();
141
+ const p = getProps();
142
+ const angle = s.getThumbAngle();
143
+
144
+ // Calculate thumb position on the wheel edge
145
+ // Assumes wheel is circular and thumb is at the outer edge
146
+ // Angle 0 = right (3 o'clock)
147
+ const thumbX = Math.cos(angle);
148
+ const thumbY = -Math.sin(angle); // Negative because CSS Y is inverted
149
+
150
+ return {
151
+ role: 'presentation' as const,
152
+ style: {
153
+ position: 'absolute' as const,
154
+ // Position relative to center, scaled to radius
155
+ // These will be overridden by the component with actual radius
156
+ left: `calc(50% + ${thumbX * 50}%)`,
157
+ top: `calc(50% + ${thumbY * 50}%)`,
158
+ transform: 'translate(-50%, -50%)',
159
+ 'touch-action': 'none',
160
+ },
161
+ 'data-dragging': s.isDragging || undefined,
162
+ 'data-disabled': s.isDisabled || p.isDisabled || undefined,
163
+ };
164
+ });
165
+
166
+ // Input props (hidden, for accessibility)
167
+ const inputProps = createMemo(() => {
168
+ const s = getState();
169
+ const p = getProps();
170
+
171
+ return {
172
+ type: 'range',
173
+ id: inputId,
174
+ min: 0,
175
+ max: 360,
176
+ step: s.step,
177
+ value: s.getHue(),
178
+ disabled: s.isDisabled || p.isDisabled,
179
+ 'aria-label': p['aria-label'] ?? 'Hue',
180
+ 'aria-labelledby': p['aria-labelledby'],
181
+ 'aria-describedby': p['aria-describedby'],
182
+ 'aria-valuetext': `${s.getHue()}°`,
183
+ onKeyDown,
184
+ onChange: (e: Event) => {
185
+ const target = e.target as HTMLInputElement;
186
+ s.setHue(parseFloat(target.value));
187
+ },
188
+ onBlur: () => {
189
+ if (s.isDragging) {
190
+ s.setDragging(false);
191
+ }
192
+ },
193
+ style: {
194
+ position: 'absolute' as const,
195
+ width: '1px',
196
+ height: '1px',
197
+ padding: '0',
198
+ margin: '-1px',
199
+ overflow: 'hidden',
200
+ clip: 'rect(0, 0, 0, 0)',
201
+ 'white-space': 'nowrap',
202
+ border: '0',
203
+ },
204
+ };
205
+ });
206
+
207
+ return {
208
+ get trackProps() {
209
+ return trackProps();
210
+ },
211
+ get thumbProps() {
212
+ return thumbProps();
213
+ },
214
+ get inputProps() {
215
+ return inputProps();
216
+ },
217
+ };
218
+ }
@@ -1,24 +1,24 @@
1
- /**
2
- * Color ARIA hooks exports.
3
- */
4
-
5
- // Types
6
- export type {
7
- AriaColorSliderOptions,
8
- ColorSliderAria,
9
- AriaColorAreaOptions,
10
- ColorAreaAria,
11
- AriaColorWheelOptions,
12
- ColorWheelAria,
13
- AriaColorFieldOptions,
14
- ColorFieldAria,
15
- AriaColorSwatchOptions,
16
- ColorSwatchAria,
17
- } from './types';
18
-
19
- // Hooks
20
- export { createColorSlider } from './createColorSlider';
21
- export { createColorArea } from './createColorArea';
22
- export { createColorWheel } from './createColorWheel';
23
- export { createColorField } from './createColorField';
24
- export { createColorSwatch } from './createColorSwatch';
1
+ /**
2
+ * Color ARIA hooks exports.
3
+ */
4
+
5
+ // Types
6
+ export type {
7
+ AriaColorSliderOptions,
8
+ ColorSliderAria,
9
+ AriaColorAreaOptions,
10
+ ColorAreaAria,
11
+ AriaColorWheelOptions,
12
+ ColorWheelAria,
13
+ AriaColorFieldOptions,
14
+ ColorFieldAria,
15
+ AriaColorSwatchOptions,
16
+ ColorSwatchAria,
17
+ } from './types';
18
+
19
+ // Hooks
20
+ export { createColorSlider } from './createColorSlider';
21
+ export { createColorArea } from './createColorArea';
22
+ export { createColorWheel } from './createColorWheel';
23
+ export { createColorField } from './createColorField';
24
+ export { createColorSwatch } from './createColorSwatch';