@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,197 +1,286 @@
1
- /**
2
- * createColorSlider hook.
3
- *
4
- * Provides ARIA attributes and keyboard handling for a color slider.
5
- */
6
-
7
- import { createMemo, type Accessor } from 'solid-js';
8
- import type { ColorSliderState } from '@proyecto-viviana/solid-stately';
9
- import { createId } from '../ssr';
10
- import type { AriaColorSliderOptions, ColorSliderAria } from './types';
11
-
12
- /**
13
- * Creates ARIA props for a color slider.
14
- */
15
- export function createColorSlider(
16
- props: Accessor<AriaColorSliderOptions>,
17
- state: Accessor<ColorSliderState>,
18
- trackRef: Accessor<HTMLDivElement | null>
19
- ): ColorSliderAria {
20
- const getProps = () => props();
21
- const getState = () => state();
22
-
23
- // Generate IDs
24
- const inputId = createId();
25
- const labelId = createId();
26
-
27
- // Get channel name for ARIA label
28
- const channelName = createMemo(() => {
29
- const p = getProps();
30
- if (p.channelName) return p.channelName;
31
- const s = getState();
32
- return s.value.getChannelName(s.channel, 'en-US');
33
- });
34
-
35
- // Handle track click
36
- const onTrackMouseDown = (e: MouseEvent) => {
37
- if (getProps().isDisabled || getState().isDisabled) return;
38
-
39
- const track = trackRef();
40
- if (!track) return;
41
-
42
- const rect = track.getBoundingClientRect();
43
- const percent = (e.clientX - rect.left) / rect.width;
44
- getState().setThumbPercent(Math.max(0, Math.min(1, percent)));
45
- getState().setDragging(true);
46
- };
47
-
48
- // Handle keyboard
49
- const onKeyDown = (e: KeyboardEvent) => {
50
- if (getProps().isDisabled || getState().isDisabled) return;
51
-
52
- const s = getState();
53
- let handled = true;
54
-
55
- switch (e.key) {
56
- case 'ArrowRight':
57
- case 'ArrowUp':
58
- s.incrementThumb();
59
- break;
60
- case 'ArrowLeft':
61
- case 'ArrowDown':
62
- s.decrementThumb();
63
- break;
64
- case 'PageUp':
65
- s.incrementThumb(s.pageSize);
66
- break;
67
- case 'PageDown':
68
- s.decrementThumb(s.pageSize);
69
- break;
70
- case 'Home':
71
- s.setThumbValue(s.minValue);
72
- break;
73
- case 'End':
74
- s.setThumbValue(s.maxValue);
75
- break;
76
- default:
77
- handled = false;
78
- }
79
-
80
- if (handled) {
81
- e.preventDefault();
82
- e.stopPropagation();
83
- }
84
- };
85
-
86
- // Track props
87
- const trackProps = createMemo(() => {
88
- const s = getState();
89
- return {
90
- role: 'presentation' as const,
91
- onMouseDown: onTrackMouseDown,
92
- style: {
93
- position: 'relative' as const,
94
- 'touch-action': 'none',
95
- },
96
- 'data-disabled': s.isDisabled || undefined,
97
- };
98
- });
99
-
100
- // Thumb props
101
- const thumbProps = createMemo(() => {
102
- const s = getState();
103
- const p = getProps();
104
- const percent = s.getThumbPercent();
105
-
106
- return {
107
- role: 'presentation' as const,
108
- style: {
109
- position: 'absolute' as const,
110
- left: `${percent * 100}%`,
111
- top: '50%',
112
- transform: 'translate(-50%, -50%)',
113
- 'touch-action': 'none',
114
- },
115
- 'data-dragging': s.isDragging || undefined,
116
- 'data-disabled': s.isDisabled || p.isDisabled || undefined,
117
- };
118
- });
119
-
120
- // Input props (hidden, for accessibility)
121
- const inputProps = createMemo(() => {
122
- const s = getState();
123
- const p = getProps();
124
-
125
- return {
126
- type: 'range',
127
- id: inputId,
128
- min: s.minValue,
129
- max: s.maxValue,
130
- step: s.step,
131
- value: s.getThumbValue(),
132
- disabled: s.isDisabled || p.isDisabled,
133
- 'aria-label': p['aria-label'] ?? channelName(),
134
- 'aria-labelledby': p['aria-labelledby'],
135
- 'aria-describedby': p['aria-describedby'],
136
- 'aria-valuetext': s.getThumbValueLabel(),
137
- onKeyDown,
138
- onChange: (e: Event) => {
139
- const target = e.target as HTMLInputElement;
140
- s.setThumbValue(parseFloat(target.value));
141
- },
142
- onFocus: () => {
143
- // Focus handling
144
- },
145
- onBlur: () => {
146
- if (s.isDragging) {
147
- s.setDragging(false);
148
- }
149
- },
150
- style: {
151
- position: 'absolute' as const,
152
- width: '1px',
153
- height: '1px',
154
- padding: '0',
155
- margin: '-1px',
156
- overflow: 'hidden',
157
- clip: 'rect(0, 0, 0, 0)',
158
- 'white-space': 'nowrap',
159
- border: '0',
160
- },
161
- };
162
- });
163
-
164
- // Output props
165
- const outputProps = createMemo(() => {
166
- return {
167
- 'aria-live': 'off' as const,
168
- for: inputId,
169
- };
170
- });
171
-
172
- // Label props
173
- const labelProps = createMemo(() => {
174
- return {
175
- id: labelId,
176
- for: inputId,
177
- };
178
- });
179
-
180
- return {
181
- get trackProps() {
182
- return trackProps();
183
- },
184
- get thumbProps() {
185
- return thumbProps();
186
- },
187
- get inputProps() {
188
- return inputProps();
189
- },
190
- get outputProps() {
191
- return outputProps();
192
- },
193
- get labelProps() {
194
- return labelProps();
195
- },
196
- };
197
- }
1
+ /**
2
+ * createColorSlider hook.
3
+ *
4
+ * Provides ARIA attributes and keyboard handling for a color slider.
5
+ */
6
+
7
+ import { createMemo, type Accessor } from 'solid-js';
8
+ import type { ColorSliderState } from '@proyecto-viviana/solid-stately';
9
+ import { createId } from '../ssr';
10
+ import type { AriaColorSliderOptions, ColorSliderAria } from './types';
11
+
12
+ /**
13
+ * Creates ARIA props for a color slider.
14
+ */
15
+ export function createColorSlider(
16
+ props: Accessor<AriaColorSliderOptions>,
17
+ state: Accessor<ColorSliderState>,
18
+ trackRef: Accessor<HTMLDivElement | null>
19
+ ): ColorSliderAria {
20
+ const getProps = () => props();
21
+ const getState = () => state();
22
+
23
+ // Generate IDs
24
+ const inputId = createId();
25
+ const labelId = createId();
26
+
27
+ // Get channel name for ARIA label
28
+ const channelName = createMemo(() => {
29
+ const p = getProps();
30
+ if (p.channelName) return p.channelName;
31
+ const s = getState();
32
+ return s.value.getChannelName(s.channel, 'en-US');
33
+ });
34
+
35
+ const updateFromClientX = (clientX: number) => {
36
+ if (getProps().isDisabled || getState().isDisabled) return;
37
+
38
+ const track = trackRef();
39
+ if (!track) return;
40
+
41
+ const rect = track.getBoundingClientRect();
42
+ const percent = (clientX - rect.left) / rect.width;
43
+ getState().setThumbPercent(Math.max(0, Math.min(1, percent)));
44
+ };
45
+
46
+ const endDrag = (target: EventTarget | null, pointerId?: number) => {
47
+ const s = getState();
48
+ if (!s.isDragging) return;
49
+ s.setDragging(false);
50
+ if (pointerId == null) return;
51
+ (target as HTMLElement | null)?.releasePointerCapture?.(pointerId);
52
+ };
53
+
54
+ // Handle pointer interaction on the track
55
+ const onTrackPointerDown = (e: PointerEvent) => {
56
+ if (getProps().isDisabled || getState().isDisabled) return;
57
+ updateFromClientX(e.clientX);
58
+ getState().setDragging(true);
59
+ (e.currentTarget as HTMLElement).setPointerCapture?.(e.pointerId);
60
+ e.preventDefault();
61
+ };
62
+
63
+ const onTrackPointerMove = (e: PointerEvent) => {
64
+ if (!getState().isDragging) return;
65
+ updateFromClientX(e.clientX);
66
+ };
67
+
68
+ const onTrackPointerUp = (e: PointerEvent) => {
69
+ endDrag(e.currentTarget, e.pointerId);
70
+ };
71
+
72
+ const onTrackPointerCancel = (e: PointerEvent) => {
73
+ endDrag(e.currentTarget, e.pointerId);
74
+ };
75
+
76
+ const onTrackMouseDown = (e: MouseEvent) => {
77
+ if (getProps().isDisabled || getState().isDisabled) return;
78
+ updateFromClientX(e.clientX);
79
+ getState().setDragging(true);
80
+ e.preventDefault();
81
+ };
82
+
83
+ const onTrackMouseMove = (e: MouseEvent) => {
84
+ if (!getState().isDragging) return;
85
+ updateFromClientX(e.clientX);
86
+ };
87
+
88
+ const onTrackMouseUp = (e: MouseEvent) => {
89
+ endDrag(e.currentTarget);
90
+ };
91
+
92
+ // Handle keyboard
93
+ const onKeyDown = (e: KeyboardEvent) => {
94
+ if (getProps().isDisabled || getState().isDisabled) return;
95
+
96
+ const s = getState();
97
+ let handled = true;
98
+
99
+ switch (e.key) {
100
+ case 'ArrowRight':
101
+ case 'ArrowUp':
102
+ s.incrementThumb();
103
+ break;
104
+ case 'ArrowLeft':
105
+ case 'ArrowDown':
106
+ s.decrementThumb();
107
+ break;
108
+ case 'PageUp':
109
+ s.incrementThumb(s.pageSize);
110
+ break;
111
+ case 'PageDown':
112
+ s.decrementThumb(s.pageSize);
113
+ break;
114
+ case 'Home':
115
+ s.setThumbValue(s.minValue);
116
+ break;
117
+ case 'End':
118
+ s.setThumbValue(s.maxValue);
119
+ break;
120
+ default:
121
+ handled = false;
122
+ }
123
+
124
+ if (handled) {
125
+ e.preventDefault();
126
+ e.stopPropagation();
127
+ }
128
+ };
129
+
130
+ // Generate gradient background for the slider track
131
+ const generateBackground = () => {
132
+ const s = getState();
133
+ const value = s.value;
134
+ const channel = s.channel;
135
+ const to = 'right';
136
+
137
+ switch (channel) {
138
+ case 'hue': {
139
+ const stops = [0, 60, 120, 180, 240, 300, 360]
140
+ .map(hue => value.withChannelValue('hue', hue).toString('css'))
141
+ .join(', ');
142
+ return `linear-gradient(to ${to}, ${stops})`;
143
+ }
144
+ case 'lightness': {
145
+ const min = s.minValue;
146
+ const max = s.maxValue;
147
+ const start = value.withChannelValue(channel, min).toString('css');
148
+ const middle = value.withChannelValue(channel, (max - min) / 2).toString('css');
149
+ const end = value.withChannelValue(channel, max).toString('css');
150
+ return `linear-gradient(to ${to}, ${start}, ${middle}, ${end})`;
151
+ }
152
+ case 'saturation':
153
+ case 'brightness':
154
+ case 'red':
155
+ case 'green':
156
+ case 'blue':
157
+ case 'alpha': {
158
+ const start = value.withChannelValue(channel, s.minValue).toString('css');
159
+ const end = value.withChannelValue(channel, s.maxValue).toString('css');
160
+ return `linear-gradient(to ${to}, ${start}, ${end})`;
161
+ }
162
+ default:
163
+ return undefined;
164
+ }
165
+ };
166
+
167
+ // Track props
168
+ const trackProps = createMemo(() => {
169
+ const s = getState();
170
+ const bg = generateBackground();
171
+ return {
172
+ role: 'presentation' as const,
173
+ onPointerDown: onTrackPointerDown,
174
+ onPointerMove: onTrackPointerMove,
175
+ onPointerUp: onTrackPointerUp,
176
+ onPointerCancel: onTrackPointerCancel,
177
+ onMouseDown: onTrackMouseDown,
178
+ onMouseMove: onTrackMouseMove,
179
+ onMouseUp: onTrackMouseUp,
180
+ style: {
181
+ position: 'relative' as const,
182
+ 'touch-action': 'none',
183
+ ...(bg ? { background: bg, 'forced-color-adjust': 'none' as const } : {}),
184
+ },
185
+ 'data-disabled': s.isDisabled || undefined,
186
+ };
187
+ });
188
+
189
+ // Thumb props
190
+ const thumbProps = createMemo(() => {
191
+ const s = getState();
192
+ const p = getProps();
193
+ const percent = s.getThumbPercent();
194
+
195
+ return {
196
+ role: 'presentation' as const,
197
+ style: {
198
+ position: 'absolute' as const,
199
+ left: `${percent * 100}%`,
200
+ top: '50%',
201
+ transform: 'translate(-50%, -50%)',
202
+ 'touch-action': 'none',
203
+ },
204
+ 'data-dragging': s.isDragging || undefined,
205
+ 'data-disabled': s.isDisabled || p.isDisabled || undefined,
206
+ };
207
+ });
208
+
209
+ // Input props (hidden, for accessibility)
210
+ const inputProps = createMemo(() => {
211
+ const s = getState();
212
+ const p = getProps();
213
+
214
+ return {
215
+ type: 'range',
216
+ id: inputId,
217
+ min: s.minValue,
218
+ max: s.maxValue,
219
+ step: s.step,
220
+ value: s.getThumbValue(),
221
+ disabled: s.isDisabled || p.isDisabled,
222
+ 'aria-label': p['aria-label'] ?? channelName(),
223
+ 'aria-labelledby': p['aria-labelledby'],
224
+ 'aria-describedby': p['aria-describedby'],
225
+ 'aria-valuetext': s.getThumbValueLabel(),
226
+ onKeyDown,
227
+ onChange: (e: Event) => {
228
+ const target = e.target as HTMLInputElement;
229
+ s.setThumbValue(parseFloat(target.value));
230
+ },
231
+ onFocus: () => {
232
+ // Focus handling
233
+ },
234
+ onBlur: () => {
235
+ if (s.isDragging) {
236
+ s.setDragging(false);
237
+ }
238
+ },
239
+ style: {
240
+ position: 'absolute' as const,
241
+ width: '1px',
242
+ height: '1px',
243
+ padding: '0',
244
+ margin: '-1px',
245
+ overflow: 'hidden',
246
+ clip: 'rect(0, 0, 0, 0)',
247
+ 'white-space': 'nowrap',
248
+ border: '0',
249
+ },
250
+ };
251
+ });
252
+
253
+ // Output props
254
+ const outputProps = createMemo(() => {
255
+ return {
256
+ 'aria-live': 'off' as const,
257
+ for: inputId,
258
+ };
259
+ });
260
+
261
+ // Label props
262
+ const labelProps = createMemo(() => {
263
+ return {
264
+ id: labelId,
265
+ for: inputId,
266
+ };
267
+ });
268
+
269
+ return {
270
+ get trackProps() {
271
+ return trackProps();
272
+ },
273
+ get thumbProps() {
274
+ return thumbProps();
275
+ },
276
+ get inputProps() {
277
+ return inputProps();
278
+ },
279
+ get outputProps() {
280
+ return outputProps();
281
+ },
282
+ get labelProps() {
283
+ return labelProps();
284
+ },
285
+ };
286
+ }
@@ -1,40 +1,40 @@
1
- /**
2
- * createColorSwatch hook.
3
- *
4
- * Provides ARIA attributes for a color swatch display.
5
- */
6
-
7
- import { createMemo, type Accessor } from 'solid-js';
8
- import { normalizeColor } from '@proyecto-viviana/solid-stately';
9
- import type { AriaColorSwatchOptions, ColorSwatchAria } from './types';
10
-
11
- /**
12
- * Creates ARIA props for a color swatch.
13
- */
14
- export function createColorSwatch(
15
- props: Accessor<AriaColorSwatchOptions>
16
- ): ColorSwatchAria {
17
- const getProps = () => props();
18
-
19
- // Swatch props
20
- const swatchProps = createMemo(() => {
21
- const p = getProps();
22
- const color = normalizeColor(p.color);
23
- const colorName = color.getColorName('en-US');
24
-
25
- return {
26
- role: 'img' as const,
27
- 'aria-label': p['aria-label'] ?? colorName,
28
- 'aria-roledescription': 'color swatch',
29
- style: {
30
- 'background-color': color.toString('css'),
31
- },
32
- };
33
- });
34
-
35
- return {
36
- get swatchProps() {
37
- return swatchProps();
38
- },
39
- };
40
- }
1
+ /**
2
+ * createColorSwatch hook.
3
+ *
4
+ * Provides ARIA attributes for a color swatch display.
5
+ */
6
+
7
+ import { createMemo, type Accessor } from 'solid-js';
8
+ import { normalizeColor } from '@proyecto-viviana/solid-stately';
9
+ import type { AriaColorSwatchOptions, ColorSwatchAria } from './types';
10
+
11
+ /**
12
+ * Creates ARIA props for a color swatch.
13
+ */
14
+ export function createColorSwatch(
15
+ props: Accessor<AriaColorSwatchOptions>
16
+ ): ColorSwatchAria {
17
+ const getProps = () => props();
18
+
19
+ // Swatch props
20
+ const swatchProps = createMemo(() => {
21
+ const p = getProps();
22
+ const color = normalizeColor(p.color);
23
+ const colorName = color.getColorName('en-US');
24
+
25
+ return {
26
+ role: 'img' as const,
27
+ 'aria-label': p['aria-label'] ?? colorName,
28
+ 'aria-roledescription': 'color swatch',
29
+ style: {
30
+ 'background-color': color.toString('css'),
31
+ },
32
+ };
33
+ });
34
+
35
+ return {
36
+ get swatchProps() {
37
+ return swatchProps();
38
+ },
39
+ };
40
+ }