@react-spectrum/s2 0.11.1 → 0.12.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 (566) hide show
  1. package/dist/Accordion.cjs +3 -3
  2. package/dist/Accordion.css +2 -2
  3. package/dist/Accordion.mjs +3 -3
  4. package/dist/ActionBar.cjs +61 -62
  5. package/dist/ActionBar.cjs.map +1 -1
  6. package/dist/ActionBar.css +62 -66
  7. package/dist/ActionBar.css.map +1 -1
  8. package/dist/ActionBar.mjs +61 -62
  9. package/dist/ActionBar.mjs.map +1 -1
  10. package/dist/ActionButton.cjs +356 -250
  11. package/dist/ActionButton.cjs.map +1 -1
  12. package/dist/ActionButton.css +208 -144
  13. package/dist/ActionButton.css.map +1 -1
  14. package/dist/ActionButton.mjs +357 -251
  15. package/dist/ActionButton.mjs.map +1 -1
  16. package/dist/ActionButtonGroup.cjs +16 -16
  17. package/dist/ActionButtonGroup.css +9 -9
  18. package/dist/ActionButtonGroup.mjs +16 -16
  19. package/dist/Add.cjs +10 -10
  20. package/dist/Add.css +6 -6
  21. package/dist/Add.mjs +10 -10
  22. package/dist/AlertDialog.cjs +3 -3
  23. package/dist/AlertDialog.css +3 -3
  24. package/dist/AlertDialog.mjs +3 -3
  25. package/dist/Asterisk.cjs +6 -6
  26. package/dist/Asterisk.css +4 -4
  27. package/dist/Asterisk.mjs +6 -6
  28. package/dist/Avatar.cjs +20 -16
  29. package/dist/Avatar.cjs.map +1 -1
  30. package/dist/Avatar.css +22 -14
  31. package/dist/Avatar.css.map +1 -1
  32. package/dist/Avatar.mjs +20 -16
  33. package/dist/Avatar.mjs.map +1 -1
  34. package/dist/AvatarGroup.cjs +135 -135
  35. package/dist/AvatarGroup.css +33 -33
  36. package/dist/AvatarGroup.mjs +135 -135
  37. package/dist/Badge.cjs +207 -207
  38. package/dist/Badge.css +127 -127
  39. package/dist/Badge.mjs +207 -207
  40. package/dist/Breadcrumbs.cjs +255 -255
  41. package/dist/Breadcrumbs.css +109 -109
  42. package/dist/Breadcrumbs.mjs +255 -255
  43. package/dist/Button.cjs +356 -354
  44. package/dist/Button.cjs.map +1 -1
  45. package/dist/Button.css +179 -179
  46. package/dist/Button.css.map +1 -1
  47. package/dist/Button.mjs +357 -356
  48. package/dist/Button.mjs.map +1 -1
  49. package/dist/ButtonGroup.cjs +21 -21
  50. package/dist/ButtonGroup.css +15 -15
  51. package/dist/ButtonGroup.mjs +21 -21
  52. package/dist/Calendar.cjs +127 -127
  53. package/dist/Calendar.cjs.map +1 -1
  54. package/dist/Calendar.css +134 -134
  55. package/dist/Calendar.css.map +1 -1
  56. package/dist/Calendar.mjs +127 -127
  57. package/dist/Calendar.mjs.map +1 -1
  58. package/dist/Card.cjs +335 -311
  59. package/dist/Card.cjs.map +1 -1
  60. package/dist/Card.css +213 -213
  61. package/dist/Card.css.map +1 -1
  62. package/dist/Card.mjs +335 -311
  63. package/dist/Card.mjs.map +1 -1
  64. package/dist/CardView.cjs +25 -19
  65. package/dist/CardView.cjs.map +1 -1
  66. package/dist/CardView.css +16 -16
  67. package/dist/CardView.css.map +1 -1
  68. package/dist/CardView.mjs +26 -20
  69. package/dist/CardView.mjs.map +1 -1
  70. package/dist/CenterBaseline.cjs +1 -1
  71. package/dist/CenterBaseline.css +2 -2
  72. package/dist/CenterBaseline.mjs +1 -1
  73. package/dist/Checkbox.cjs +171 -171
  74. package/dist/Checkbox.css +92 -92
  75. package/dist/Checkbox.mjs +171 -171
  76. package/dist/CheckboxGroup.cjs +46 -46
  77. package/dist/CheckboxGroup.css +38 -38
  78. package/dist/CheckboxGroup.mjs +46 -46
  79. package/dist/Checkmark.cjs +12 -12
  80. package/dist/Checkmark.css +8 -8
  81. package/dist/Checkmark.mjs +12 -12
  82. package/dist/Chevron.cjs +12 -12
  83. package/dist/Chevron.css +10 -10
  84. package/dist/Chevron.mjs +12 -12
  85. package/dist/ClearButton.cjs +29 -29
  86. package/dist/ClearButton.css +29 -29
  87. package/dist/ClearButton.mjs +29 -29
  88. package/dist/CloseButton.cjs +55 -55
  89. package/dist/CloseButton.css +46 -46
  90. package/dist/CloseButton.mjs +55 -55
  91. package/dist/ColorArea.cjs +25 -18
  92. package/dist/ColorArea.cjs.map +1 -1
  93. package/dist/ColorArea.css +16 -16
  94. package/dist/ColorArea.css.map +1 -1
  95. package/dist/ColorArea.mjs +26 -19
  96. package/dist/ColorArea.mjs.map +1 -1
  97. package/dist/ColorField.cjs +33 -33
  98. package/dist/ColorField.cjs.map +1 -1
  99. package/dist/ColorField.css +28 -28
  100. package/dist/ColorField.css.map +1 -1
  101. package/dist/ColorField.mjs +33 -33
  102. package/dist/ColorField.mjs.map +1 -1
  103. package/dist/ColorHandle.cjs +27 -27
  104. package/dist/ColorHandle.css +43 -43
  105. package/dist/ColorHandle.mjs +27 -27
  106. package/dist/ColorSlider.cjs +122 -121
  107. package/dist/ColorSlider.cjs.map +1 -1
  108. package/dist/ColorSlider.css +54 -54
  109. package/dist/ColorSlider.css.map +1 -1
  110. package/dist/ColorSlider.mjs +122 -121
  111. package/dist/ColorSlider.mjs.map +1 -1
  112. package/dist/ColorSwatch.cjs +30 -30
  113. package/dist/ColorSwatch.css +29 -29
  114. package/dist/ColorSwatch.mjs +30 -30
  115. package/dist/ColorSwatchPicker.cjs +28 -28
  116. package/dist/ColorSwatchPicker.css +46 -46
  117. package/dist/ColorSwatchPicker.mjs +28 -28
  118. package/dist/ColorWheel.cjs +26 -26
  119. package/dist/ColorWheel.css +17 -17
  120. package/dist/ColorWheel.mjs +26 -26
  121. package/dist/ComboBox.cjs +474 -452
  122. package/dist/ComboBox.cjs.map +1 -1
  123. package/dist/ComboBox.css +213 -185
  124. package/dist/ComboBox.css.map +1 -1
  125. package/dist/ComboBox.mjs +475 -453
  126. package/dist/ComboBox.mjs.map +1 -1
  127. package/dist/ContextualHelp.cjs +36 -33
  128. package/dist/ContextualHelp.cjs.map +1 -1
  129. package/dist/ContextualHelp.css +68 -60
  130. package/dist/ContextualHelp.css.map +1 -1
  131. package/dist/ContextualHelp.mjs +37 -34
  132. package/dist/ContextualHelp.mjs.map +1 -1
  133. package/dist/Cross.cjs +14 -14
  134. package/dist/Cross.css +10 -10
  135. package/dist/Cross.mjs +14 -14
  136. package/dist/CustomDialog.cjs +26 -26
  137. package/dist/CustomDialog.cjs.map +1 -1
  138. package/dist/CustomDialog.css +25 -25
  139. package/dist/CustomDialog.css.map +1 -1
  140. package/dist/CustomDialog.mjs +26 -26
  141. package/dist/CustomDialog.mjs.map +1 -1
  142. package/dist/Dash.cjs +10 -10
  143. package/dist/Dash.css +6 -6
  144. package/dist/Dash.mjs +10 -10
  145. package/dist/DateField.cjs +74 -74
  146. package/dist/DateField.cjs.map +1 -1
  147. package/dist/DateField.css +77 -77
  148. package/dist/DateField.css.map +1 -1
  149. package/dist/DateField.mjs +74 -74
  150. package/dist/DateField.mjs.map +1 -1
  151. package/dist/DatePicker.cjs +194 -191
  152. package/dist/DatePicker.cjs.map +1 -1
  153. package/dist/DatePicker.css +138 -126
  154. package/dist/DatePicker.css.map +1 -1
  155. package/dist/DatePicker.mjs +195 -192
  156. package/dist/DatePicker.mjs.map +1 -1
  157. package/dist/DateRangePicker.cjs +57 -57
  158. package/dist/DateRangePicker.cjs.map +1 -1
  159. package/dist/DateRangePicker.css +60 -60
  160. package/dist/DateRangePicker.css.map +1 -1
  161. package/dist/DateRangePicker.mjs +57 -57
  162. package/dist/DateRangePicker.mjs.map +1 -1
  163. package/dist/Dialog.cjs +17 -17
  164. package/dist/Dialog.cjs.map +1 -1
  165. package/dist/Dialog.css +88 -84
  166. package/dist/Dialog.css.map +1 -1
  167. package/dist/Dialog.mjs +17 -17
  168. package/dist/Dialog.mjs.map +1 -1
  169. package/dist/Disclosure.cjs +128 -147
  170. package/dist/Disclosure.cjs.map +1 -1
  171. package/dist/Disclosure.css +144 -112
  172. package/dist/Disclosure.css.map +1 -1
  173. package/dist/Disclosure.mjs +128 -147
  174. package/dist/Disclosure.mjs.map +1 -1
  175. package/dist/Divider.cjs +26 -26
  176. package/dist/Divider.css +25 -25
  177. package/dist/Divider.mjs +26 -26
  178. package/dist/DropZone.cjs +63 -63
  179. package/dist/DropZone.cjs.map +1 -1
  180. package/dist/DropZone.css +58 -58
  181. package/dist/DropZone.css.map +1 -1
  182. package/dist/DropZone.mjs +63 -63
  183. package/dist/DropZone.mjs.map +1 -1
  184. package/dist/Field.cjs +370 -370
  185. package/dist/Field.cjs.map +1 -1
  186. package/dist/Field.css +146 -142
  187. package/dist/Field.css.map +1 -1
  188. package/dist/Field.mjs +370 -370
  189. package/dist/Field.mjs.map +1 -1
  190. package/dist/Form.cjs +10 -10
  191. package/dist/Form.css +9 -9
  192. package/dist/Form.mjs +10 -10
  193. package/dist/FullscreenDialog.cjs +5 -5
  194. package/dist/FullscreenDialog.cjs.map +1 -1
  195. package/dist/FullscreenDialog.css +93 -93
  196. package/dist/FullscreenDialog.css.map +1 -1
  197. package/dist/FullscreenDialog.mjs +5 -5
  198. package/dist/FullscreenDialog.mjs.map +1 -1
  199. package/dist/IllustratedMessage.cjs +257 -257
  200. package/dist/IllustratedMessage.css +78 -78
  201. package/dist/IllustratedMessage.mjs +257 -257
  202. package/dist/Image.cjs +25 -17
  203. package/dist/Image.cjs.map +1 -1
  204. package/dist/Image.css +14 -14
  205. package/dist/Image.css.map +1 -1
  206. package/dist/Image.mjs +25 -17
  207. package/dist/Image.mjs.map +1 -1
  208. package/dist/InlineAlert.cjs +138 -153
  209. package/dist/InlineAlert.cjs.map +1 -1
  210. package/dist/InlineAlert.css +82 -151
  211. package/dist/InlineAlert.css.map +1 -1
  212. package/dist/InlineAlert.mjs +138 -153
  213. package/dist/InlineAlert.mjs.map +1 -1
  214. package/dist/Link.cjs +55 -55
  215. package/dist/Link.css +46 -46
  216. package/dist/Link.mjs +55 -55
  217. package/dist/LinkOut.cjs +8 -8
  218. package/dist/LinkOut.css +8 -8
  219. package/dist/LinkOut.mjs +8 -8
  220. package/dist/Menu.cjs +529 -501
  221. package/dist/Menu.cjs.map +1 -1
  222. package/dist/Menu.css +195 -191
  223. package/dist/Menu.css.map +1 -1
  224. package/dist/Menu.mjs +529 -502
  225. package/dist/Menu.mjs.map +1 -1
  226. package/dist/Meter.cjs +164 -164
  227. package/dist/Meter.css +93 -93
  228. package/dist/Meter.mjs +164 -164
  229. package/dist/Modal.cjs +90 -70
  230. package/dist/Modal.cjs.map +1 -1
  231. package/dist/Modal.css +76 -60
  232. package/dist/Modal.css.map +1 -1
  233. package/dist/Modal.mjs +90 -70
  234. package/dist/Modal.mjs.map +1 -1
  235. package/dist/NotificationBadge.cjs +59 -59
  236. package/dist/NotificationBadge.css +51 -51
  237. package/dist/NotificationBadge.mjs +59 -59
  238. package/dist/NumberField.cjs +116 -116
  239. package/dist/NumberField.cjs.map +1 -1
  240. package/dist/NumberField.css +100 -100
  241. package/dist/NumberField.css.map +1 -1
  242. package/dist/NumberField.mjs +116 -116
  243. package/dist/NumberField.mjs.map +1 -1
  244. package/dist/Picker.cjs +424 -349
  245. package/dist/Picker.cjs.map +1 -1
  246. package/dist/Picker.css +200 -180
  247. package/dist/Picker.css.map +1 -1
  248. package/dist/Picker.mjs +428 -353
  249. package/dist/Picker.mjs.map +1 -1
  250. package/dist/Popover.cjs +120 -116
  251. package/dist/Popover.cjs.map +1 -1
  252. package/dist/Popover.css +86 -82
  253. package/dist/Popover.css.map +1 -1
  254. package/dist/Popover.mjs +121 -118
  255. package/dist/Popover.mjs.map +1 -1
  256. package/dist/ProgressBar.cjs +174 -174
  257. package/dist/ProgressBar.css +101 -101
  258. package/dist/ProgressBar.mjs +174 -174
  259. package/dist/ProgressCircle.cjs +32 -32
  260. package/dist/ProgressCircle.css +24 -24
  261. package/dist/ProgressCircle.mjs +32 -32
  262. package/dist/Provider.cjs +11 -11
  263. package/dist/Provider.cjs.map +1 -1
  264. package/dist/Provider.css +13 -13
  265. package/dist/Provider.css.map +1 -1
  266. package/dist/Provider.mjs +11 -11
  267. package/dist/Provider.mjs.map +1 -1
  268. package/dist/Radio.cjs +155 -155
  269. package/dist/Radio.css +79 -79
  270. package/dist/Radio.mjs +155 -155
  271. package/dist/RadioGroup.cjs +43 -43
  272. package/dist/RadioGroup.css +38 -38
  273. package/dist/RadioGroup.mjs +43 -43
  274. package/dist/RangeCalendar.cjs +8 -8
  275. package/dist/RangeCalendar.cjs.map +1 -1
  276. package/dist/RangeCalendar.css +10 -10
  277. package/dist/RangeCalendar.css.map +1 -1
  278. package/dist/RangeCalendar.mjs +8 -8
  279. package/dist/RangeCalendar.mjs.map +1 -1
  280. package/dist/RangeSlider.cjs.map +1 -1
  281. package/dist/RangeSlider.mjs.map +1 -1
  282. package/dist/SearchField.cjs +43 -43
  283. package/dist/SearchField.cjs.map +1 -1
  284. package/dist/SearchField.css +46 -46
  285. package/dist/SearchField.css.map +1 -1
  286. package/dist/SearchField.mjs +43 -43
  287. package/dist/SearchField.mjs.map +1 -1
  288. package/dist/SegmentedControl.cjs +193 -224
  289. package/dist/SegmentedControl.cjs.map +1 -1
  290. package/dist/SegmentedControl.css +146 -118
  291. package/dist/SegmentedControl.css.map +1 -1
  292. package/dist/SegmentedControl.mjs +196 -227
  293. package/dist/SegmentedControl.mjs.map +1 -1
  294. package/dist/SelectBoxGroup.cjs +161 -159
  295. package/dist/SelectBoxGroup.cjs.map +1 -1
  296. package/dist/SelectBoxGroup.css +123 -123
  297. package/dist/SelectBoxGroup.css.map +1 -1
  298. package/dist/SelectBoxGroup.mjs +161 -159
  299. package/dist/SelectBoxGroup.mjs.map +1 -1
  300. package/dist/Slider.cjs +300 -300
  301. package/dist/Slider.css +151 -151
  302. package/dist/Slider.mjs +300 -300
  303. package/dist/StatusLight.cjs +126 -126
  304. package/dist/StatusLight.css +61 -61
  305. package/dist/StatusLight.mjs +126 -126
  306. package/dist/Switch.cjs +163 -163
  307. package/dist/Switch.css +74 -74
  308. package/dist/Switch.mjs +163 -163
  309. package/dist/TableView.cjs +340 -328
  310. package/dist/TableView.cjs.map +1 -1
  311. package/dist/TableView.css +176 -172
  312. package/dist/TableView.css.map +1 -1
  313. package/dist/TableView.mjs +340 -328
  314. package/dist/TableView.mjs.map +1 -1
  315. package/dist/Tabs.cjs +150 -190
  316. package/dist/Tabs.cjs.map +1 -1
  317. package/dist/Tabs.css +128 -100
  318. package/dist/Tabs.css.map +1 -1
  319. package/dist/Tabs.mjs +153 -193
  320. package/dist/Tabs.mjs.map +1 -1
  321. package/dist/TabsPicker.cjs +169 -161
  322. package/dist/TabsPicker.cjs.map +1 -1
  323. package/dist/TabsPicker.css +116 -124
  324. package/dist/TabsPicker.css.map +1 -1
  325. package/dist/TabsPicker.mjs +170 -162
  326. package/dist/TabsPicker.mjs.map +1 -1
  327. package/dist/TagGroup.cjs +226 -218
  328. package/dist/TagGroup.cjs.map +1 -1
  329. package/dist/TagGroup.css +147 -147
  330. package/dist/TagGroup.css.map +1 -1
  331. package/dist/TagGroup.mjs +226 -218
  332. package/dist/TagGroup.mjs.map +1 -1
  333. package/dist/TextField.cjs +65 -63
  334. package/dist/TextField.cjs.map +1 -1
  335. package/dist/TextField.css +58 -54
  336. package/dist/TextField.css.map +1 -1
  337. package/dist/TextField.mjs +65 -63
  338. package/dist/TextField.mjs.map +1 -1
  339. package/dist/TimeField.cjs +53 -53
  340. package/dist/TimeField.cjs.map +1 -1
  341. package/dist/TimeField.css +48 -48
  342. package/dist/TimeField.css.map +1 -1
  343. package/dist/TimeField.mjs +53 -53
  344. package/dist/TimeField.mjs.map +1 -1
  345. package/dist/Toast.cjs +120 -120
  346. package/dist/Toast.css +108 -108
  347. package/dist/Toast.mjs +120 -120
  348. package/dist/ToggleButton.cjs +3 -3
  349. package/dist/ToggleButton.css +12 -12
  350. package/dist/ToggleButton.mjs +3 -3
  351. package/dist/Tooltip.cjs +84 -83
  352. package/dist/Tooltip.cjs.map +1 -1
  353. package/dist/Tooltip.css +74 -70
  354. package/dist/Tooltip.css.map +1 -1
  355. package/dist/Tooltip.mjs +84 -83
  356. package/dist/Tooltip.mjs.map +1 -1
  357. package/dist/TreeView.cjs +150 -148
  358. package/dist/TreeView.cjs.map +1 -1
  359. package/dist/TreeView.css +147 -147
  360. package/dist/TreeView.css.map +1 -1
  361. package/dist/TreeView.mjs +151 -149
  362. package/dist/TreeView.mjs.map +1 -1
  363. package/dist/ar-AE.cjs +5 -0
  364. package/dist/ar-AE.cjs.map +1 -1
  365. package/dist/ar-AE.mjs +5 -0
  366. package/dist/ar-AE.mjs.map +1 -1
  367. package/dist/bg-BG.cjs +5 -0
  368. package/dist/bg-BG.cjs.map +1 -1
  369. package/dist/bg-BG.mjs +5 -0
  370. package/dist/bg-BG.mjs.map +1 -1
  371. package/dist/cs-CZ.cjs +5 -0
  372. package/dist/cs-CZ.cjs.map +1 -1
  373. package/dist/cs-CZ.mjs +5 -0
  374. package/dist/cs-CZ.mjs.map +1 -1
  375. package/dist/da-DK.cjs +5 -0
  376. package/dist/da-DK.cjs.map +1 -1
  377. package/dist/da-DK.mjs +5 -0
  378. package/dist/da-DK.mjs.map +1 -1
  379. package/dist/de-DE.cjs +5 -0
  380. package/dist/de-DE.cjs.map +1 -1
  381. package/dist/de-DE.mjs +5 -0
  382. package/dist/de-DE.mjs.map +1 -1
  383. package/dist/el-GR.cjs +5 -0
  384. package/dist/el-GR.cjs.map +1 -1
  385. package/dist/el-GR.mjs +5 -0
  386. package/dist/el-GR.mjs.map +1 -1
  387. package/dist/en-US.cjs +21 -16
  388. package/dist/en-US.cjs.map +1 -1
  389. package/dist/en-US.mjs +21 -16
  390. package/dist/en-US.mjs.map +1 -1
  391. package/dist/es-ES.cjs +5 -0
  392. package/dist/es-ES.cjs.map +1 -1
  393. package/dist/es-ES.mjs +5 -0
  394. package/dist/es-ES.mjs.map +1 -1
  395. package/dist/et-EE.cjs +5 -0
  396. package/dist/et-EE.cjs.map +1 -1
  397. package/dist/et-EE.mjs +5 -0
  398. package/dist/et-EE.mjs.map +1 -1
  399. package/dist/fi-FI.cjs +5 -0
  400. package/dist/fi-FI.cjs.map +1 -1
  401. package/dist/fi-FI.mjs +5 -0
  402. package/dist/fi-FI.mjs.map +1 -1
  403. package/dist/fr-FR.cjs +5 -0
  404. package/dist/fr-FR.cjs.map +1 -1
  405. package/dist/fr-FR.mjs +5 -0
  406. package/dist/fr-FR.mjs.map +1 -1
  407. package/dist/he-IL.cjs +5 -0
  408. package/dist/he-IL.cjs.map +1 -1
  409. package/dist/he-IL.mjs +5 -0
  410. package/dist/he-IL.mjs.map +1 -1
  411. package/dist/hr-HR.cjs +5 -0
  412. package/dist/hr-HR.cjs.map +1 -1
  413. package/dist/hr-HR.mjs +5 -0
  414. package/dist/hr-HR.mjs.map +1 -1
  415. package/dist/hu-HU.cjs +5 -0
  416. package/dist/hu-HU.cjs.map +1 -1
  417. package/dist/hu-HU.mjs +5 -0
  418. package/dist/hu-HU.mjs.map +1 -1
  419. package/dist/it-IT.cjs +5 -0
  420. package/dist/it-IT.cjs.map +1 -1
  421. package/dist/it-IT.mjs +5 -0
  422. package/dist/it-IT.mjs.map +1 -1
  423. package/dist/ja-JP.cjs +5 -0
  424. package/dist/ja-JP.cjs.map +1 -1
  425. package/dist/ja-JP.mjs +5 -0
  426. package/dist/ja-JP.mjs.map +1 -1
  427. package/dist/ko-KR.cjs +5 -0
  428. package/dist/ko-KR.cjs.map +1 -1
  429. package/dist/ko-KR.mjs +5 -0
  430. package/dist/ko-KR.mjs.map +1 -1
  431. package/dist/lt-LT.cjs +5 -0
  432. package/dist/lt-LT.cjs.map +1 -1
  433. package/dist/lt-LT.mjs +5 -0
  434. package/dist/lt-LT.mjs.map +1 -1
  435. package/dist/lv-LV.cjs +5 -0
  436. package/dist/lv-LV.cjs.map +1 -1
  437. package/dist/lv-LV.mjs +5 -0
  438. package/dist/lv-LV.mjs.map +1 -1
  439. package/dist/main.cjs +2 -0
  440. package/dist/main.cjs.map +1 -1
  441. package/dist/module.mjs +3 -3
  442. package/dist/module.mjs.map +1 -1
  443. package/dist/nb-NO.cjs +5 -0
  444. package/dist/nb-NO.cjs.map +1 -1
  445. package/dist/nb-NO.mjs +5 -0
  446. package/dist/nb-NO.mjs.map +1 -1
  447. package/dist/nl-NL.cjs +5 -0
  448. package/dist/nl-NL.cjs.map +1 -1
  449. package/dist/nl-NL.mjs +5 -0
  450. package/dist/nl-NL.mjs.map +1 -1
  451. package/dist/pl-PL.cjs +5 -0
  452. package/dist/pl-PL.cjs.map +1 -1
  453. package/dist/pl-PL.mjs +5 -0
  454. package/dist/pl-PL.mjs.map +1 -1
  455. package/dist/pt-BR.cjs +5 -0
  456. package/dist/pt-BR.cjs.map +1 -1
  457. package/dist/pt-BR.mjs +5 -0
  458. package/dist/pt-BR.mjs.map +1 -1
  459. package/dist/pt-PT.cjs +5 -0
  460. package/dist/pt-PT.cjs.map +1 -1
  461. package/dist/pt-PT.mjs +5 -0
  462. package/dist/pt-PT.mjs.map +1 -1
  463. package/dist/ro-RO.cjs +5 -0
  464. package/dist/ro-RO.cjs.map +1 -1
  465. package/dist/ro-RO.mjs +5 -0
  466. package/dist/ro-RO.mjs.map +1 -1
  467. package/dist/ru-RU.cjs +5 -0
  468. package/dist/ru-RU.cjs.map +1 -1
  469. package/dist/ru-RU.mjs +5 -0
  470. package/dist/ru-RU.mjs.map +1 -1
  471. package/dist/sk-SK.cjs +5 -0
  472. package/dist/sk-SK.cjs.map +1 -1
  473. package/dist/sk-SK.mjs +5 -0
  474. package/dist/sk-SK.mjs.map +1 -1
  475. package/dist/sl-SI.cjs +5 -0
  476. package/dist/sl-SI.cjs.map +1 -1
  477. package/dist/sl-SI.mjs +5 -0
  478. package/dist/sl-SI.mjs.map +1 -1
  479. package/dist/sr-SP.cjs +5 -0
  480. package/dist/sr-SP.cjs.map +1 -1
  481. package/dist/sr-SP.mjs +5 -0
  482. package/dist/sr-SP.mjs.map +1 -1
  483. package/dist/sv-SE.cjs +5 -0
  484. package/dist/sv-SE.cjs.map +1 -1
  485. package/dist/sv-SE.mjs +5 -0
  486. package/dist/sv-SE.mjs.map +1 -1
  487. package/dist/tr-TR.cjs +5 -0
  488. package/dist/tr-TR.cjs.map +1 -1
  489. package/dist/tr-TR.mjs +5 -0
  490. package/dist/tr-TR.mjs.map +1 -1
  491. package/dist/types.d.ts +147 -87
  492. package/dist/types.d.ts.map +1 -1
  493. package/dist/uk-UA.cjs +5 -0
  494. package/dist/uk-UA.cjs.map +1 -1
  495. package/dist/uk-UA.mjs +5 -0
  496. package/dist/uk-UA.mjs.map +1 -1
  497. package/dist/zh-CN.cjs +5 -0
  498. package/dist/zh-CN.cjs.map +1 -1
  499. package/dist/zh-CN.mjs +5 -0
  500. package/dist/zh-CN.mjs.map +1 -1
  501. package/dist/zh-TW.cjs +5 -0
  502. package/dist/zh-TW.cjs.map +1 -1
  503. package/dist/zh-TW.mjs +5 -0
  504. package/dist/zh-TW.mjs.map +1 -1
  505. package/icons/Icon.cjs +10 -10
  506. package/icons/Icon.css +9 -9
  507. package/icons/Icon.mjs +10 -10
  508. package/icons/Skeleton.cjs +2 -2
  509. package/icons/Skeleton.css +6 -6
  510. package/icons/Skeleton.mjs +2 -2
  511. package/package.json +20 -20
  512. package/page.css +7 -7
  513. package/src/ActionBar.tsx +5 -3
  514. package/src/ActionButton.tsx +112 -32
  515. package/src/Avatar.tsx +4 -1
  516. package/src/Button.tsx +27 -28
  517. package/src/Calendar.tsx +3 -0
  518. package/src/Card.tsx +22 -7
  519. package/src/CardView.tsx +9 -1
  520. package/src/ColorArea.tsx +10 -2
  521. package/src/ColorField.tsx +3 -2
  522. package/src/ColorSlider.tsx +3 -2
  523. package/src/ComboBox.tsx +69 -44
  524. package/src/ContextualHelp.tsx +36 -32
  525. package/src/CustomDialog.tsx +1 -1
  526. package/src/DateField.tsx +4 -0
  527. package/src/DatePicker.tsx +28 -20
  528. package/src/DateRangePicker.tsx +5 -1
  529. package/src/Dialog.tsx +6 -3
  530. package/src/Disclosure.tsx +20 -16
  531. package/src/DropZone.tsx +5 -2
  532. package/src/Field.tsx +4 -1
  533. package/src/FullscreenDialog.tsx +1 -1
  534. package/src/Image.tsx +30 -8
  535. package/src/InlineAlert.tsx +10 -27
  536. package/src/Menu.tsx +57 -45
  537. package/src/Modal.tsx +99 -74
  538. package/src/NumberField.tsx +3 -2
  539. package/src/Picker.tsx +114 -51
  540. package/src/Popover.tsx +57 -35
  541. package/src/Provider.tsx +1 -1
  542. package/src/RangeCalendar.tsx +3 -0
  543. package/src/RangeSlider.tsx +3 -0
  544. package/src/SearchField.tsx +2 -1
  545. package/src/SegmentedControl.tsx +16 -44
  546. package/src/SelectBoxGroup.tsx +21 -23
  547. package/src/TableView.tsx +7 -6
  548. package/src/Tabs.tsx +34 -70
  549. package/src/TabsPicker.tsx +35 -26
  550. package/src/TagGroup.tsx +44 -36
  551. package/src/TextField.tsx +11 -6
  552. package/src/TimeField.tsx +4 -0
  553. package/src/Tooltip.tsx +3 -0
  554. package/src/TreeView.tsx +2 -2
  555. package/src/index.ts +3 -2
  556. package/src/page.macro.ts +2 -2
  557. package/src/style-utils.ts +4 -3
  558. package/style/__tests__/style-macro.test.js +56 -56
  559. package/style/dist/spectrum-theme.cjs +36 -6
  560. package/style/dist/spectrum-theme.cjs.map +1 -1
  561. package/style/dist/spectrum-theme.mjs +36 -6
  562. package/style/dist/spectrum-theme.mjs.map +1 -1
  563. package/style/dist/types.d.ts +1 -0
  564. package/style/dist/types.d.ts.map +1 -1
  565. package/style/spectrum-theme.ts +10 -8
  566. package/style/tokens.ts +10 -0
package/icons/Icon.css CHANGED
@@ -1,37 +1,37 @@
1
1
  @layer _.a {
2
- .Zm11 {
2
+ .Zm12 {
3
3
  width: calc(1.25rem * var(--s2-scale));
4
4
  }
5
5
 
6
- .Fn11 {
6
+ .Fn12 {
7
7
  height: calc(1.25rem * var(--s2-scale));
8
8
  }
9
9
 
10
- .ZF11 {
10
+ .ZF12 {
11
11
  width: calc(3rem * var(--s2-scale));
12
12
  }
13
13
 
14
- .ZH11 {
14
+ .ZH12 {
15
15
  width: calc(6rem * var(--s2-scale));
16
16
  }
17
17
 
18
- .Zq11 {
18
+ .Zq12 {
19
19
  width: calc(10rem * var(--s2-scale));
20
20
  }
21
21
 
22
- .Fz11 {
22
+ .Fz12 {
23
23
  height: calc(3rem * var(--s2-scale));
24
24
  }
25
25
 
26
- .FB11 {
26
+ .FB12 {
27
27
  height: calc(6rem * var(--s2-scale));
28
28
  }
29
29
 
30
- .Fr11 {
30
+ .Fr12 {
31
31
  height: calc(10rem * var(--s2-scale));
32
32
  }
33
33
 
34
- ._va11 {
34
+ ._va12 {
35
35
  flex-shrink: 0;
36
36
  }
37
37
  }
package/icons/Icon.mjs CHANGED
@@ -62,9 +62,9 @@ const $ac8c32e6775ddd1f$var$iconStyles = function anonymous(props, overrides) {
62
62
  if (p[1] === "F") height = true;
63
63
  rules += p[0];
64
64
  }
65
- if (!width) rules += ' Zm11';
66
- if (!height) rules += ' Fn11';
67
- rules += ' _va11';
65
+ if (!width) rules += ' Zm12';
66
+ if (!height) rules += ' Fn12';
67
+ rules += ' _va12';
68
68
  return rules;
69
69
  };
70
70
  function $ac8c32e6775ddd1f$export$274edc73af1ae9c8(Component, context = $ac8c32e6775ddd1f$export$a49f528ae1a4d0ed) {
@@ -105,20 +105,20 @@ const $ac8c32e6775ddd1f$var$illustrationStyles = function anonymous(props, overr
105
105
  rules += p[0];
106
106
  }
107
107
  if (props.size === "L") {
108
- if (!width) rules += ' Zq11';
108
+ if (!width) rules += ' Zq12';
109
109
  } else if (props.size === "M") {
110
- if (!width) rules += ' ZH11';
110
+ if (!width) rules += ' ZH12';
111
111
  } else if (props.size === "S") {
112
- if (!width) rules += ' ZF11';
112
+ if (!width) rules += ' ZF12';
113
113
  }
114
114
  if (props.size === "L") {
115
- if (!height) rules += ' Fr11';
115
+ if (!height) rules += ' Fr12';
116
116
  } else if (props.size === "M") {
117
- if (!height) rules += ' FB11';
117
+ if (!height) rules += ' FB12';
118
118
  } else if (props.size === "S") {
119
- if (!height) rules += ' Fz11';
119
+ if (!height) rules += ' Fz12';
120
120
  }
121
- rules += ' _va11';
121
+ rules += ' _va12';
122
122
  return rules;
123
123
  };
124
124
  function $ac8c32e6775ddd1f$export$4d00e7be716a0093(Component) {
@@ -96,7 +96,7 @@ function $5eb75e0c130e0669$export$cb6ddd830302c2a8({ children: children }) {
96
96
  // @ts-ignore - compatibility with React < 19
97
97
  inert: (0, $lzdFu$reactariautils.inertValue)(true),
98
98
  ref: $5eb75e0c130e0669$export$6b288fe07640c94c(true),
99
- className: $5eb75e0c130e0669$export$d2353276f167b21f + " pw11 _ma11 oa11 na11 ka11 ja11",
99
+ className: $5eb75e0c130e0669$export$d2353276f167b21f + " pw12 _ma12 oa12 na12 ka12 ja12",
100
100
  children: children
101
101
  });
102
102
  }
@@ -117,7 +117,7 @@ function $5eb75e0c130e0669$export$6069cbe61f690103({ children: children }) {
117
117
  }
118
118
  function $5eb75e0c130e0669$export$4b7803c08fe9a32b(styles) {
119
119
  let isSkeleton = (0, $lzdFu$react.useContext)($5eb75e0c130e0669$export$74e166679b1f49ee);
120
- if (isSkeleton) return (0, $308b180f49d82d28$exports.mergeStyles)(" oa11 na11 ka11 ja11", styles);
120
+ if (isSkeleton) return (0, $308b180f49d82d28$exports.mergeStyles)(" oa12 na12 ka12 ja12", styles);
121
121
  return styles || '';
122
122
  }
123
123
 
@@ -12,28 +12,28 @@
12
12
  }
13
13
 
14
14
  @layer _.a {
15
- .pw11 {
15
+ .pw12 {
16
16
  color: #0000;
17
17
  }
18
18
 
19
- ._ma11 {
19
+ ._ma12 {
20
20
  -webkit-box-decoration-break: clone;
21
21
  box-decoration-break: clone;
22
22
  }
23
23
 
24
- .oa11 {
24
+ .oa12 {
25
25
  border-start-start-radius: .25rem;
26
26
  }
27
27
 
28
- .na11 {
28
+ .na12 {
29
29
  border-start-end-radius: .25rem;
30
30
  }
31
31
 
32
- .ka11 {
32
+ .ka12 {
33
33
  border-end-start-radius: .25rem;
34
34
  }
35
35
 
36
- .ja11 {
36
+ .ja12 {
37
37
  border-end-end-radius: .25rem;
38
38
  }
39
39
  }
@@ -83,7 +83,7 @@ function $5ad421ec19460c48$export$cb6ddd830302c2a8({ children: children }) {
83
83
  // @ts-ignore - compatibility with React < 19
84
84
  inert: (0, $cHM3s$inertValue)(true),
85
85
  ref: $5ad421ec19460c48$export$6b288fe07640c94c(true),
86
- className: $5ad421ec19460c48$export$d2353276f167b21f + " pw11 _ma11 oa11 na11 ka11 ja11",
86
+ className: $5ad421ec19460c48$export$d2353276f167b21f + " pw12 _ma12 oa12 na12 ka12 ja12",
87
87
  children: children
88
88
  });
89
89
  }
@@ -104,7 +104,7 @@ function $5ad421ec19460c48$export$6069cbe61f690103({ children: children }) {
104
104
  }
105
105
  function $5ad421ec19460c48$export$4b7803c08fe9a32b(styles) {
106
106
  let isSkeleton = (0, $cHM3s$useContext)($5ad421ec19460c48$export$74e166679b1f49ee);
107
- if (isSkeleton) return (0, $feb886035e0d4633$export$e618dc39ac9ad607)(" oa11 na11 ka11 ja11", styles);
107
+ if (isSkeleton) return (0, $feb886035e0d4633$export$e618dc39ac9ad607)(" oa12 na12 ka12 ja12", styles);
108
108
  return styles || '';
109
109
  }
110
110
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@react-spectrum/s2",
3
- "version": "0.11.1",
3
+ "version": "0.12.0",
4
4
  "description": "Spectrum 2 UI components in React",
5
5
  "license": "Apache-2.0",
6
6
  "repository": {
@@ -77,28 +77,28 @@
77
77
  "src"
78
78
  ],
79
79
  "dependencies": {
80
- "@internationalized/date": "^3.9.0",
80
+ "@internationalized/date": "^3.10.0",
81
81
  "@internationalized/number": "^3.6.5",
82
- "@react-aria/calendar": "^3.9.1",
83
- "@react-aria/collections": "3.0.0-rc.6",
84
- "@react-aria/focus": "^3.21.1",
85
- "@react-aria/i18n": "^3.12.12",
86
- "@react-aria/interactions": "^3.25.5",
82
+ "@react-aria/calendar": "^3.9.2",
83
+ "@react-aria/collections": "^3.0.0",
84
+ "@react-aria/focus": "^3.21.2",
85
+ "@react-aria/i18n": "^3.12.13",
86
+ "@react-aria/interactions": "^3.25.6",
87
87
  "@react-aria/live-announcer": "^3.4.4",
88
- "@react-aria/utils": "^3.30.1",
89
- "@react-spectrum/utils": "^3.12.8",
90
- "@react-stately/layout": "^4.5.0",
88
+ "@react-aria/utils": "^3.31.0",
89
+ "@react-spectrum/utils": "^3.12.9",
90
+ "@react-stately/layout": "^4.5.1",
91
91
  "@react-stately/utils": "^3.10.8",
92
- "@react-types/dialog": "^3.5.21",
93
- "@react-types/grid": "^3.3.5",
94
- "@react-types/provider": "^3.8.12",
95
- "@react-types/shared": "^3.32.0",
96
- "@react-types/table": "^3.13.3",
97
- "@react-types/textfield": "^3.12.5",
92
+ "@react-types/dialog": "^3.5.22",
93
+ "@react-types/grid": "^3.3.6",
94
+ "@react-types/provider": "^3.8.13",
95
+ "@react-types/shared": "^3.32.1",
96
+ "@react-types/table": "^3.13.4",
97
+ "@react-types/textfield": "^3.12.6",
98
98
  "csstype": "^3.0.2",
99
- "react-aria": "^3.43.1",
100
- "react-aria-components": "^1.12.1",
101
- "react-stately": "^3.41.0"
99
+ "react-aria": "^3.44.0",
100
+ "react-aria-components": "^1.13.0",
101
+ "react-stately": "^3.42.0"
102
102
  },
103
103
  "peerDependencies": {
104
104
  "react": "^18.0.0 || ^19.0.0-rc.1",
@@ -107,5 +107,5 @@
107
107
  "publishConfig": {
108
108
  "access": "public"
109
109
  },
110
- "gitHead": "ed4815e15c9d1659208fa687e8c3a094879854bb"
110
+ "gitHead": "0bda51183baa23306342af32a82012ea0fe0f2dc"
111
111
  }
package/page.css CHANGED
@@ -1,4 +1,4 @@
1
- html {
1
+ :where(:root, :host) {
2
2
  --lightningcss-light: initial;
3
3
  --lightningcss-dark: ;
4
4
  color-scheme: light dark;
@@ -9,36 +9,36 @@ html {
9
9
  }
10
10
 
11
11
  @media (prefers-color-scheme: dark) {
12
- html {
12
+ :where(:root, :host) {
13
13
  --lightningcss-light: ;
14
14
  --lightningcss-dark: initial;
15
15
  }
16
16
  }
17
17
 
18
18
  @media not ((hover: hover) and (pointer: fine)) {
19
- html {
19
+ :where(:root, :host) {
20
20
  --s2-scale: 1.25;
21
21
  --s2-font-size-base: 17;
22
22
  }
23
23
  }
24
24
 
25
- html[data-color-scheme="light"] {
25
+ :where(:root, :host)[data-color-scheme="light"] {
26
26
  --lightningcss-light: initial;
27
27
  --lightningcss-dark: ;
28
28
  color-scheme: light;
29
29
  }
30
30
 
31
- html[data-color-scheme="dark"] {
31
+ :where(:root, :host)[data-color-scheme="dark"] {
32
32
  --lightningcss-light: ;
33
33
  --lightningcss-dark: initial;
34
34
  color-scheme: dark;
35
35
  }
36
36
 
37
- html[data-background="layer-1"] {
37
+ :where(:root, :host)[data-background="layer-1"] {
38
38
  --s2-container-bg: var(--lightningcss-light, #f8f8f8) var(--lightningcss-dark, #1b1b1b);
39
39
  }
40
40
 
41
- html[data-background="layer-2"] {
41
+ :where(:root, :host)[data-background="layer-2"] {
42
42
  --s2-container-bg: var(--lightningcss-light, #fff) var(--lightningcss-dark, #222);
43
43
  }
44
44
  /*# sourceMappingURL=page.css.map */
package/src/ActionBar.tsx CHANGED
@@ -19,7 +19,7 @@ import {DOMRef, DOMRefValue, Key} from '@react-types/shared';
19
19
  import {FocusScope, useKeyboard} from 'react-aria';
20
20
  // @ts-ignore
21
21
  import intlMessages from '../intl/*.json';
22
- import {style} from '../style' with {type: 'macro'};
22
+ import {lightDark, style} from '../style' with {type: 'macro'};
23
23
  import {useControlledState} from '@react-stately/utils';
24
24
  import {useDOMRef} from '@react-spectrum/utils';
25
25
  import {useEnterAnimation, useExitAnimation, useObjectRef, useResizeObserver} from '@react-aria/utils';
@@ -40,9 +40,8 @@ const actionBarStyles = style({
40
40
  boxSizing: 'border-box',
41
41
  outlineStyle: 'solid',
42
42
  outlineWidth: 1,
43
- outlineOffset: -1,
44
43
  outlineColor: {
45
- default: 'gray-200',
44
+ default: lightDark('transparent-white-25', 'gray-200'),
46
45
  isEmphasized: 'transparent',
47
46
  forcedColors: 'ButtonBorder'
48
47
  },
@@ -90,6 +89,9 @@ export interface ActionBarProps extends SlotProps {
90
89
 
91
90
  export const ActionBarContext = createContext<ContextValue<Partial<ActionBarProps>, DOMRefValue<HTMLDivElement>>>(null);
92
91
 
92
+ /**
93
+ * Action bars are used for single and bulk selection patterns when a user needs to perform actions on one or more items at the same time.
94
+ */
93
95
  export const ActionBar = forwardRef(function ActionBar(props: ActionBarProps, ref: DOMRef<HTMLDivElement>) {
94
96
  [props, ref] = useSpectrumContextProps(props, ref, ActionBarContext);
95
97
  let domRef = useDOMRef(ref);
@@ -19,12 +19,18 @@ import {control, getAllowedOverrides, staticColor, StyleProps} from './style-uti
19
19
  import {createContext, forwardRef, ReactNode, useContext} from 'react';
20
20
  import {FocusableRef, FocusableRefValue, GlobalDOMAttributes} from '@react-types/shared';
21
21
  import {IconContext} from './Icon';
22
+ import {ImageContext} from './Image';
23
+ // @ts-ignore
24
+ import intlMessages from '../intl/*.json';
22
25
  import {NotificationBadgeContext} from './NotificationBadge';
23
26
  import {pressScale} from './pressScale';
27
+ import {ProgressCircle} from './ProgressCircle';
24
28
  import {SkeletonContext} from './Skeleton';
25
29
  import {Text, TextContext} from './Content';
26
30
  import {useFocusableRef} from '@react-spectrum/utils';
27
31
  import {useFormProps} from './Form';
32
+ import {useLocalizedStringFormatter} from '@react-aria/i18n';
33
+ import {usePendingState} from './Button';
28
34
  import {useSpectrumContextProps} from './useSpectrumContextProps';
29
35
 
30
36
  export interface ActionButtonStyleProps {
@@ -53,7 +59,7 @@ interface ActionGroupItemStyleProps {
53
59
  isJustified?: boolean
54
60
  }
55
61
 
56
- export interface ActionButtonProps extends Omit<ButtonProps, 'className' | 'style' | 'children' | 'onHover' | 'onHoverStart' | 'onHoverEnd' | 'onHoverChange' | 'isPending' | 'onClick' | keyof GlobalDOMAttributes>, StyleProps, ActionButtonStyleProps {
62
+ export interface ActionButtonProps extends Omit<ButtonProps, 'className' | 'style' | 'children' | 'onHover' | 'onHoverStart' | 'onHoverEnd' | 'onHoverChange' | 'onClick' | keyof GlobalDOMAttributes>, StyleProps, ActionButtonStyleProps {
57
63
  /** The content to display in the ActionButton. */
58
64
  children: ReactNode
59
65
  }
@@ -67,6 +73,7 @@ export const btnStyles = style<ButtonRenderProps & ActionButtonStyleProps & Togg
67
73
  ...focusRing(),
68
74
  ...staticColor(),
69
75
  ...controlStyle,
76
+ position: 'relative',
70
77
  justifyContent: 'center',
71
78
  flexShrink: {
72
79
  default: 1,
@@ -231,6 +238,15 @@ export const btnStyles = style<ButtonRenderProps & ActionButtonStyleProps & Togg
231
238
  paddingX: {
232
239
  default: controlStyle.paddingX,
233
240
  [avatarOnly]: 0
241
+ },
242
+ // `control` sets this, but we need to override it for avatar only buttons.
243
+ '--iconMargin': {
244
+ type: 'marginStart',
245
+ value: {
246
+ default: fontRelative(-2),
247
+ [iconOnly]: 0,
248
+ [avatarOnly]: 0
249
+ }
234
250
  }
235
251
  }, getAllowedOverrides());
236
252
 
@@ -252,6 +268,8 @@ export const ActionButtonContext = createContext<ContextValue<Partial<ActionButt
252
268
  export const ActionButton = forwardRef(function ActionButton(props: ActionButtonProps, ref: FocusableRef<HTMLButtonElement>) {
253
269
  [props, ref] = useSpectrumContextProps(props, ref, ActionButtonContext);
254
270
  props = useFormProps(props as any);
271
+ let stringFormatter = useLocalizedStringFormatter(intlMessages, '@react-spectrum/s2');
272
+ let {isPending = false} = props;
255
273
  let domRef = useFocusableRef(ref);
256
274
  let overlayTriggerState = useContext(OverlayTriggerStateContext);
257
275
  let ctx = useSlottedContext(ActionButtonGroupContext);
@@ -262,21 +280,21 @@ export const ActionButton = forwardRef(function ActionButton(props: ActionButton
262
280
  orientation = 'horizontal',
263
281
  staticColor = props.staticColor,
264
282
  isQuiet = props.isQuiet,
265
- size = props.size || 'M',
266
- isDisabled = props.isDisabled
283
+ size = props.size || 'M'
267
284
  } = ctx || {};
268
285
 
286
+ let {isProgressVisible} = usePendingState(isPending);
269
287
 
270
288
  return (
271
289
  <RACButton
272
290
  {...props}
273
- isDisabled={isDisabled}
274
291
  ref={domRef}
275
292
  style={pressScale(domRef, props.UNSAFE_style)}
276
293
  className={renderProps => (props.UNSAFE_className || '') + btnStyles({
277
294
  ...renderProps,
278
295
  // Retain hover styles when an overlay is open.
279
296
  isHovered: renderProps.isHovered || overlayTriggerState?.isOpen || false,
297
+ isDisabled: renderProps.isDisabled || isProgressVisible,
280
298
  staticColor,
281
299
  isStaticColor: !!staticColor,
282
300
  size,
@@ -286,34 +304,96 @@ export const ActionButton = forwardRef(function ActionButton(props: ActionButton
286
304
  orientation,
287
305
  isInGroup
288
306
  }, props.styles)}>
289
- <Provider
290
- values={[
291
- [SkeletonContext, null],
292
- [TextContext, {styles: style({order: 1, truncate: true})}],
293
- [IconContext, {
294
- render: centerBaseline({slot: 'icon', styles: style({order: 0})}),
295
- styles: style({size: fontRelative(20), marginStart: '--iconMargin', flexShrink: 0})
296
- }],
297
- [AvatarContext, {
298
- size: avatarSize[size],
299
- styles: style({
300
- marginStart: {
301
- default: '--iconMargin',
302
- ':last-child': 0
303
- },
304
- flexShrink: 0,
305
- order: 0
306
- })
307
- }],
308
- [NotificationBadgeContext, {
309
- staticColor: staticColor,
310
- size: props.size === 'XS' ? undefined : props.size,
311
- isDisabled: props.isDisabled,
312
- styles: style({position: 'absolute', top: '--badgeTop', insetStart: '--badgePosition', marginTop: 'calc((self(height) * -1)/2)', marginStart: 'calc((self(height) * -1)/2)'})
313
- }]
314
- ]}>
315
- {typeof props.children === 'string' ? <Text>{props.children}</Text> : props.children}
316
- </Provider>
307
+ {({isDisabled}) => (
308
+ <>
309
+ <Provider
310
+ values={[
311
+ [SkeletonContext, null],
312
+ [TextContext, {styles:
313
+ style({
314
+ order: 1,
315
+ truncate: true,
316
+ visibility: {
317
+ isProgressVisible: 'hidden'
318
+ }
319
+ })({isProgressVisible})
320
+ }],
321
+ [IconContext, {
322
+ render: centerBaseline({slot: 'icon', styles: style({order: 0})}),
323
+ styles: style({
324
+ size: fontRelative(20),
325
+ marginStart: '--iconMargin',
326
+ flexShrink: 0,
327
+ visibility: {
328
+ isProgressVisible: 'hidden'
329
+ }
330
+ })({isProgressVisible})
331
+ }],
332
+ [AvatarContext, {
333
+ size: avatarSize[size],
334
+ styles: style({
335
+ marginStart: '--iconMargin',
336
+ flexShrink: 0,
337
+ order: 0
338
+ })
339
+ }],
340
+ [ImageContext, {
341
+ styles: style({
342
+ visibility: {
343
+ isProgressVisible: 'hidden'
344
+ }
345
+ })({isProgressVisible})
346
+ }],
347
+ [NotificationBadgeContext, {
348
+ staticColor: staticColor,
349
+ size: props.size === 'XS' ? undefined : props.size,
350
+ isDisabled: isDisabled,
351
+ styles: style({
352
+ position: 'absolute',
353
+ top: '--badgeTop',
354
+ insetStart: '--badgePosition',
355
+ marginTop: 'calc((self(height) * -1)/2)',
356
+ marginStart: 'calc((self(height) * -1)/2)',
357
+ visibility: {
358
+ isProgressVisible: 'hidden'
359
+ }
360
+ })({isProgressVisible})
361
+ }]
362
+ ]}>
363
+ {typeof props.children === 'string' ? <Text>{props.children}</Text> : props.children}
364
+ {isPending &&
365
+ <div
366
+ className={style({
367
+ position: 'absolute',
368
+ top: '50%',
369
+ left: '50%',
370
+ transform: 'translate(-50%, -50%)',
371
+ visibility: {
372
+ default: 'hidden',
373
+ isProgressVisible: 'visible'
374
+ }
375
+ })({isProgressVisible, isPending})}>
376
+ <ProgressCircle
377
+ isIndeterminate
378
+ aria-label={stringFormatter.format('button.pending')}
379
+ size="S"
380
+ staticColor={staticColor}
381
+ styles={style({
382
+ size: {
383
+ size: {
384
+ XS: 12,
385
+ S: 14,
386
+ M: 18,
387
+ L: 20,
388
+ XL: 24
389
+ }
390
+ }
391
+ })({size})} />
392
+ </div>
393
+ }
394
+ </Provider>
395
+ </>
396
+ )}
317
397
  </RACButton>
318
398
  );
319
399
  });
package/src/Avatar.tsx CHANGED
@@ -10,6 +10,7 @@
10
10
  * governing permissions and limitations under the License.
11
11
  */
12
12
 
13
+ import {centerBaselineBefore} from './CenterBaseline';
13
14
  import {ContextValue, SlotProps} from 'react-aria-components';
14
15
  import {createContext, forwardRef} from 'react';
15
16
  import {DOMProps, DOMRef, DOMRefValue} from '@react-types/shared';
@@ -37,6 +38,8 @@ export interface AvatarProps extends UnsafeStyles, DOMProps, SlotProps {
37
38
  }
38
39
 
39
40
  const imageStyles = style({
41
+ display: 'flex',
42
+ alignItems: 'center',
40
43
  borderRadius: 'full',
41
44
  size: 20,
42
45
  flexShrink: 0,
@@ -86,7 +89,7 @@ export const Avatar = forwardRef(function Avatar(props: AvatarProps, ref: DOMRef
86
89
  width: remSize,
87
90
  height: remSize
88
91
  }}
89
- UNSAFE_className={UNSAFE_className}
92
+ UNSAFE_className={UNSAFE_className + ' ' + centerBaselineBefore}
90
93
  styles={imageStyles({isOverBackground, isLarge}, props.styles)}
91
94
  src={src} />
92
95
  );
package/src/Button.tsx CHANGED
@@ -292,6 +292,24 @@ const gradient = style({
292
292
  }
293
293
  });
294
294
 
295
+ export function usePendingState(isPending: boolean) {
296
+ let [isProgressVisible, setIsProgressVisible] = useState(false);
297
+ useEffect(() => {
298
+ let timeout: ReturnType<typeof setTimeout>;
299
+ if (isPending) {
300
+ timeout = setTimeout(() => {
301
+ setIsProgressVisible(true);
302
+ }, 1000);
303
+ } else {
304
+ setIsProgressVisible(false);
305
+ }
306
+ return () => {
307
+ clearTimeout(timeout);
308
+ };
309
+ }, [isPending]);
310
+ return {isProgressVisible};
311
+ }
312
+
295
313
  /**
296
314
  * Buttons allow users to perform an action.
297
315
  * They have multiple styles for various needs, and are ideal for calling attention to
@@ -302,7 +320,7 @@ export const Button = forwardRef(function Button(props: ButtonProps, ref: Focusa
302
320
  props = useFormProps(props);
303
321
  let stringFormatter = useLocalizedStringFormatter(intlMessages, '@react-spectrum/s2');
304
322
  let {
305
- isPending,
323
+ isPending = false,
306
324
  variant = 'primary',
307
325
  fillStyle = 'fill',
308
326
  size = 'M',
@@ -311,24 +329,7 @@ export const Button = forwardRef(function Button(props: ButtonProps, ref: Focusa
311
329
  let domRef = useFocusableRef(ref);
312
330
  let overlayTriggerState = useContext(OverlayTriggerStateContext);
313
331
 
314
- let [isProgressVisible, setIsProgressVisible] = useState(false);
315
- useEffect(() => {
316
- let timeout: ReturnType<typeof setTimeout>;
317
-
318
- if (isPending) {
319
- // Start timer when isPending is set to true.
320
- timeout = setTimeout(() => {
321
- setIsProgressVisible(true);
322
- }, 1000);
323
- } else {
324
- // Exit loading state when isPending is set to false. */
325
- setIsProgressVisible(false);
326
- }
327
- return () => {
328
- // Clean up on unmount or when user removes isPending prop before entering loading state.
329
- clearTimeout(timeout);
330
- };
331
- }, [isPending]);
332
+ let {isProgressVisible} = usePendingState(isPending);
332
333
 
333
334
  return (
334
335
  <RACButton
@@ -366,9 +367,8 @@ export const Button = forwardRef(function Button(props: ButtonProps, ref: Focusa
366
367
  styles: style({
367
368
  paddingY: '--labelPadding',
368
369
  order: 1,
369
- opacity: {
370
- default: 1,
371
- isProgressVisible: 0
370
+ visibility: {
371
+ isProgressVisible: 'hidden'
372
372
  }
373
373
  })({isProgressVisible}),
374
374
  // @ts-ignore data-attributes allowed on all JSX elements, but adding to DOMProps has been problematic in the past
@@ -380,9 +380,8 @@ export const Button = forwardRef(function Button(props: ButtonProps, ref: Focusa
380
380
  size: fontRelative(20),
381
381
  marginStart: '--iconMargin',
382
382
  flexShrink: 0,
383
- opacity: {
384
- default: 1,
385
- isProgressVisible: 0
383
+ visibility: {
384
+ isProgressVisible: 'hidden'
386
385
  }
387
386
  })({isProgressVisible})
388
387
  }]
@@ -395,9 +394,9 @@ export const Button = forwardRef(function Button(props: ButtonProps, ref: Focusa
395
394
  top: '50%',
396
395
  left: '50%',
397
396
  transform: 'translate(-50%, -50%)',
398
- opacity: {
399
- default: 0,
400
- isProgressVisible: 1
397
+ visibility: {
398
+ default: 'hidden',
399
+ isProgressVisible: 'visible'
401
400
  }
402
401
  })({isProgressVisible, isPending})}>
403
402
  <ProgressCircle
package/src/Calendar.tsx CHANGED
@@ -284,6 +284,9 @@ const selectionSpanStyles = style({
284
284
  forcedColorAdjust: 'none'
285
285
  });
286
286
 
287
+ /**
288
+ * Calendars display a grid of days in one or more months and allow users to select a single date.
289
+ */
287
290
  export const Calendar = /*#__PURE__*/ (forwardRef as forwardRefType)(function Calendar<T extends DateValue>(props: CalendarProps<T>, ref: ForwardedRef<HTMLDivElement>) {
288
291
  [props, ref] = useSpectrumContextProps(props, ref, CalendarContext);
289
292
  let {