@wordpress/components 21.3.0 → 22.1.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 (811) hide show
  1. package/CHANGELOG.md +107 -1
  2. package/build/angle-picker-control/index.js +4 -2
  3. package/build/angle-picker-control/index.js.map +1 -1
  4. package/build/autocomplete/autocompleter-ui.js +28 -2
  5. package/build/autocomplete/autocompleter-ui.js.map +1 -1
  6. package/build/autocomplete/index.js +7 -3
  7. package/build/autocomplete/index.js.map +1 -1
  8. package/build/border-box-control/border-box-control/component.js +63 -15
  9. package/build/border-box-control/border-box-control/component.js.map +1 -1
  10. package/build/border-box-control/border-box-control/hook.js +19 -3
  11. package/build/border-box-control/border-box-control/hook.js.map +1 -1
  12. package/build/border-box-control/border-box-control-linked-button/hook.js +3 -3
  13. package/build/border-box-control/border-box-control-linked-button/hook.js.map +1 -1
  14. package/build/border-box-control/border-box-control-split-controls/component.js +3 -3
  15. package/build/border-box-control/border-box-control-split-controls/component.js.map +1 -1
  16. package/build/border-box-control/border-box-control-split-controls/hook.js +18 -11
  17. package/build/border-box-control/border-box-control-split-controls/hook.js.map +1 -1
  18. package/build/border-box-control/border-box-control-visualizer/hook.js +3 -7
  19. package/build/border-box-control/border-box-control-visualizer/hook.js.map +1 -1
  20. package/build/border-box-control/styles.js +34 -34
  21. package/build/border-box-control/styles.js.map +1 -1
  22. package/build/border-control/border-control/component.js +6 -5
  23. package/build/border-control/border-control/component.js.map +1 -1
  24. package/build/border-control/border-control/hook.js +22 -5
  25. package/build/border-control/border-control/hook.js.map +1 -1
  26. package/build/border-control/border-control-dropdown/component.js +1 -1
  27. package/build/border-control/border-control-dropdown/component.js.map +1 -1
  28. package/build/border-control/border-control-dropdown/hook.js +15 -7
  29. package/build/border-control/border-control-dropdown/hook.js.map +1 -1
  30. package/build/border-control/styles.js +19 -34
  31. package/build/border-control/styles.js.map +1 -1
  32. package/build/box-control/index.js +6 -2
  33. package/build/box-control/index.js.map +1 -1
  34. package/build/circular-option-picker/index.js +14 -14
  35. package/build/circular-option-picker/index.js.map +1 -1
  36. package/build/color-palette/index.js +84 -31
  37. package/build/color-palette/index.js.map +1 -1
  38. package/build/color-palette/styles.js +3 -3
  39. package/build/color-palette/styles.js.map +1 -1
  40. package/build/color-palette/types.js +6 -0
  41. package/build/color-palette/types.js.map +1 -0
  42. package/build/color-picker/input-with-slider.js +18 -4
  43. package/build/color-picker/input-with-slider.js.map +1 -1
  44. package/build/custom-gradient-picker/gradient-bar/index.js +1 -3
  45. package/build/custom-gradient-picker/gradient-bar/index.js.map +1 -1
  46. package/build/custom-select-control/index.js +12 -5
  47. package/build/custom-select-control/index.js.map +1 -1
  48. package/build/dashicon/index.js +17 -2
  49. package/build/dashicon/index.js.map +1 -1
  50. package/build/date-time/date-time/index.js +2 -0
  51. package/build/date-time/date-time/index.js.map +1 -1
  52. package/build/date-time/time/index.js +4 -4
  53. package/build/date-time/time/index.js.map +1 -1
  54. package/build/disabled/index.js +8 -1
  55. package/build/disabled/index.js.map +1 -1
  56. package/build/draggable/index.js +58 -38
  57. package/build/draggable/index.js.map +1 -1
  58. package/build/draggable/types.js +6 -0
  59. package/build/draggable/types.js.map +1 -0
  60. package/build/external-link/index.js +13 -2
  61. package/build/external-link/index.js.map +1 -1
  62. package/build/flex/flex/hook.js +2 -3
  63. package/build/flex/flex/hook.js.map +1 -1
  64. package/build/focal-point-picker/focal-point.js +2 -12
  65. package/build/focal-point-picker/focal-point.js.map +1 -1
  66. package/build/focal-point-picker/styles/focal-point-style.js +11 -51
  67. package/build/focal-point-picker/styles/focal-point-style.js.map +1 -1
  68. package/build/focusable-iframe/index.js +0 -1
  69. package/build/focusable-iframe/index.js.map +1 -1
  70. package/build/font-size-picker/constants.js +41 -0
  71. package/build/font-size-picker/constants.js.map +1 -0
  72. package/build/font-size-picker/font-size-picker-select.js +97 -0
  73. package/build/font-size-picker/font-size-picker-select.js.map +1 -0
  74. package/build/font-size-picker/font-size-picker-toggle-group.js +50 -0
  75. package/build/font-size-picker/font-size-picker-toggle-group.js.map +1 -0
  76. package/build/font-size-picker/index.js +86 -110
  77. package/build/font-size-picker/index.js.map +1 -1
  78. package/build/font-size-picker/utils.js +16 -109
  79. package/build/font-size-picker/utils.js.map +1 -1
  80. package/build/form-file-upload/index.js.map +1 -1
  81. package/build/form-token-field/index.js +9 -6
  82. package/build/form-token-field/index.js.map +1 -1
  83. package/build/higher-order/navigate-regions/index.js +3 -0
  84. package/build/higher-order/navigate-regions/index.js.map +1 -1
  85. package/build/higher-order/with-filters/index.js +1 -7
  86. package/build/higher-order/with-filters/index.js.map +1 -1
  87. package/build/icon/index.js +3 -2
  88. package/build/icon/index.js.map +1 -1
  89. package/build/index.js +15 -1
  90. package/build/index.js.map +1 -1
  91. package/build/input-control/index.js +2 -0
  92. package/build/input-control/index.js.map +1 -1
  93. package/build/input-control/input-base.js +1 -1
  94. package/build/input-control/input-base.js.map +1 -1
  95. package/build/input-control/styles/input-control-styles.js +21 -21
  96. package/build/input-control/styles/input-control-styles.js.map +1 -1
  97. package/build/isolated-event-container/index.js +5 -9
  98. package/build/isolated-event-container/index.js.map +1 -1
  99. package/build/item-group/styles.js +10 -10
  100. package/build/item-group/styles.js.map +1 -1
  101. package/build/menu-group/index.js +17 -3
  102. package/build/menu-group/index.js.map +1 -1
  103. package/build/menu-group/types.js +6 -0
  104. package/build/menu-group/types.js.map +1 -0
  105. package/build/navigator/navigator-screen/component.js +27 -17
  106. package/build/navigator/navigator-screen/component.js.map +1 -1
  107. package/build/number-control/index.js +82 -22
  108. package/build/number-control/index.js.map +1 -1
  109. package/build/number-control/styles/number-control-styles.js +36 -6
  110. package/build/number-control/styles/number-control-styles.js.map +1 -1
  111. package/build/palette-edit/index.js +3 -1
  112. package/build/palette-edit/index.js.map +1 -1
  113. package/build/popover/index.js +23 -33
  114. package/build/popover/index.js.map +1 -1
  115. package/build/radio-group/index.js +7 -1
  116. package/build/radio-group/index.js.map +1 -1
  117. package/build/{radio → radio-group/radio}/index.js +7 -1
  118. package/build/radio-group/radio/index.js.map +1 -0
  119. package/build/{radio-context → radio-group/radio-context}/index.js +0 -0
  120. package/build/radio-group/radio-context/index.js.map +1 -0
  121. package/build/range-control/styles/range-control-styles.js +47 -57
  122. package/build/range-control/styles/range-control-styles.js.map +1 -1
  123. package/build/slot-fill/bubbles-virtually/fill.js +9 -5
  124. package/build/slot-fill/bubbles-virtually/fill.js.map +1 -1
  125. package/build/slot-fill/bubbles-virtually/slot.js +13 -8
  126. package/build/slot-fill/bubbles-virtually/slot.js.map +1 -1
  127. package/build/slot-fill/bubbles-virtually/use-slot.js +15 -9
  128. package/build/slot-fill/bubbles-virtually/use-slot.js.map +1 -1
  129. package/build/slot-fill/fill.js +12 -4
  130. package/build/slot-fill/fill.js.map +1 -1
  131. package/build/slot-fill/use-slot.js +3 -1
  132. package/build/slot-fill/use-slot.js.map +1 -1
  133. package/build/snackbar/index.js +1 -1
  134. package/build/snackbar/index.js.map +1 -1
  135. package/build/spinner/styles.js +4 -4
  136. package/build/spinner/styles.js.map +1 -1
  137. package/build/tab-panel/index.js +4 -9
  138. package/build/tab-panel/index.js.map +1 -1
  139. package/build/text-control/index.js +0 -2
  140. package/build/text-control/index.js.map +1 -1
  141. package/build/toggle-control/index.js +15 -3
  142. package/build/toggle-control/index.js.map +1 -1
  143. package/build/toggle-group-control/toggle-group-control/as-button-group.js +90 -0
  144. package/build/toggle-group-control/toggle-group-control/as-button-group.js.map +1 -0
  145. package/build/toggle-group-control/toggle-group-control/as-radio-group.js +90 -0
  146. package/build/toggle-group-control/toggle-group-control/as-radio-group.js.map +1 -0
  147. package/build/toggle-group-control/toggle-group-control/component.js +22 -50
  148. package/build/toggle-group-control/toggle-group-control/component.js.map +1 -1
  149. package/build/toggle-group-control/toggle-group-control/styles.js +13 -8
  150. package/build/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  151. package/build/toggle-group-control/toggle-group-control-option-base/component.js +39 -17
  152. package/build/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -1
  153. package/build/toggle-group-control/toggle-group-control-option-base/styles.js +23 -23
  154. package/build/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  155. package/build/toolbar-dropdown-menu/index.js +1 -1
  156. package/build/toolbar-dropdown-menu/index.js.map +1 -1
  157. package/build/tools-panel/styles.js +14 -14
  158. package/build/tools-panel/styles.js.map +1 -1
  159. package/build/tools-panel/tools-panel-item/hook.js +9 -5
  160. package/build/tools-panel/tools-panel-item/hook.js.map +1 -1
  161. package/build/ui/context/context-system-provider.js +9 -22
  162. package/build/ui/context/context-system-provider.js.map +1 -1
  163. package/build/unit-control/index.js +7 -9
  164. package/build/unit-control/index.js.map +1 -1
  165. package/build/unit-control/styles/unit-control-styles.js +15 -25
  166. package/build/unit-control/styles/unit-control-styles.js.map +1 -1
  167. package/build/utils/colors-values.js +3 -2
  168. package/build/utils/colors-values.js.map +1 -1
  169. package/build/utils/config-values.js +0 -1
  170. package/build/utils/config-values.js.map +1 -1
  171. package/build/utils/hooks/use-update-effect.js +5 -1
  172. package/build/utils/hooks/use-update-effect.js.map +1 -1
  173. package/build/utils/input/base.js +2 -2
  174. package/build/utils/input/base.js.map +1 -1
  175. package/build/view/index.js.map +1 -1
  176. package/build-module/angle-picker-control/index.js +3 -2
  177. package/build-module/angle-picker-control/index.js.map +1 -1
  178. package/build-module/autocomplete/autocompleter-ui.js +29 -3
  179. package/build-module/autocomplete/autocompleter-ui.js.map +1 -1
  180. package/build-module/autocomplete/index.js +7 -3
  181. package/build-module/autocomplete/index.js.map +1 -1
  182. package/build-module/border-box-control/border-box-control/component.js +61 -13
  183. package/build-module/border-box-control/border-box-control/component.js.map +1 -1
  184. package/build-module/border-box-control/border-box-control/hook.js +19 -3
  185. package/build-module/border-box-control/border-box-control/hook.js.map +1 -1
  186. package/build-module/border-box-control/border-box-control-linked-button/hook.js +3 -3
  187. package/build-module/border-box-control/border-box-control-linked-button/hook.js.map +1 -1
  188. package/build-module/border-box-control/border-box-control-split-controls/component.js +3 -3
  189. package/build-module/border-box-control/border-box-control-split-controls/component.js.map +1 -1
  190. package/build-module/border-box-control/border-box-control-split-controls/hook.js +19 -10
  191. package/build-module/border-box-control/border-box-control-split-controls/hook.js.map +1 -1
  192. package/build-module/border-box-control/border-box-control-visualizer/hook.js +4 -6
  193. package/build-module/border-box-control/border-box-control-visualizer/hook.js.map +1 -1
  194. package/build-module/border-box-control/styles.js +26 -28
  195. package/build-module/border-box-control/styles.js.map +1 -1
  196. package/build-module/border-control/border-control/component.js +6 -5
  197. package/build-module/border-control/border-control/component.js.map +1 -1
  198. package/build-module/border-control/border-control/hook.js +22 -5
  199. package/build-module/border-control/border-control/hook.js.map +1 -1
  200. package/build-module/border-control/border-control-dropdown/component.js +1 -1
  201. package/build-module/border-control/border-control-dropdown/component.js.map +1 -1
  202. package/build-module/border-control/border-control-dropdown/hook.js +15 -7
  203. package/build-module/border-control/border-control-dropdown/hook.js.map +1 -1
  204. package/build-module/border-control/styles.js +20 -36
  205. package/build-module/border-control/styles.js.map +1 -1
  206. package/build-module/box-control/index.js +6 -2
  207. package/build-module/box-control/index.js.map +1 -1
  208. package/build-module/circular-option-picker/index.js +14 -14
  209. package/build-module/circular-option-picker/index.js.map +1 -1
  210. package/build-module/color-palette/index.js +82 -29
  211. package/build-module/color-palette/index.js.map +1 -1
  212. package/build-module/color-palette/styles.js +3 -3
  213. package/build-module/color-palette/styles.js.map +1 -1
  214. package/build-module/color-palette/types.js +2 -0
  215. package/build-module/color-palette/types.js.map +1 -0
  216. package/build-module/color-picker/input-with-slider.js +18 -4
  217. package/build-module/color-picker/input-with-slider.js.map +1 -1
  218. package/build-module/custom-gradient-picker/gradient-bar/index.js +1 -2
  219. package/build-module/custom-gradient-picker/gradient-bar/index.js.map +1 -1
  220. package/build-module/custom-select-control/index.js +12 -5
  221. package/build-module/custom-select-control/index.js.map +1 -1
  222. package/build-module/dashicon/index.js +17 -2
  223. package/build-module/dashicon/index.js.map +1 -1
  224. package/build-module/date-time/date-time/index.js +2 -0
  225. package/build-module/date-time/date-time/index.js.map +1 -1
  226. package/build-module/date-time/time/index.js +4 -4
  227. package/build-module/date-time/time/index.js.map +1 -1
  228. package/build-module/disabled/index.js +8 -1
  229. package/build-module/disabled/index.js.map +1 -1
  230. package/build-module/draggable/index.js +59 -38
  231. package/build-module/draggable/index.js.map +1 -1
  232. package/build-module/draggable/types.js +2 -0
  233. package/build-module/draggable/types.js.map +1 -0
  234. package/build-module/external-link/index.js +13 -2
  235. package/build-module/external-link/index.js.map +1 -1
  236. package/build-module/flex/flex/hook.js +2 -3
  237. package/build-module/flex/flex/hook.js.map +1 -1
  238. package/build-module/focal-point-picker/focal-point.js +3 -13
  239. package/build-module/focal-point-picker/focal-point.js.map +1 -1
  240. package/build-module/focal-point-picker/styles/focal-point-style.js +6 -52
  241. package/build-module/focal-point-picker/styles/focal-point-style.js.map +1 -1
  242. package/build-module/focusable-iframe/index.js +0 -1
  243. package/build-module/focusable-iframe/index.js.map +1 -1
  244. package/build-module/font-size-picker/constants.js +31 -0
  245. package/build-module/font-size-picker/constants.js.map +1 -0
  246. package/build-module/font-size-picker/font-size-picker-select.js +83 -0
  247. package/build-module/font-size-picker/font-size-picker-select.js.map +1 -0
  248. package/build-module/font-size-picker/font-size-picker-toggle-group.js +40 -0
  249. package/build-module/font-size-picker/font-size-picker-toggle-group.js.map +1 -0
  250. package/build-module/font-size-picker/index.js +88 -111
  251. package/build-module/font-size-picker/index.js.map +1 -1
  252. package/build-module/font-size-picker/utils.js +15 -105
  253. package/build-module/font-size-picker/utils.js.map +1 -1
  254. package/build-module/form-file-upload/index.js.map +1 -1
  255. package/build-module/form-token-field/index.js +9 -6
  256. package/build-module/form-token-field/index.js.map +1 -1
  257. package/build-module/higher-order/navigate-regions/index.js +3 -0
  258. package/build-module/higher-order/navigate-regions/index.js.map +1 -1
  259. package/build-module/higher-order/with-filters/index.js +1 -6
  260. package/build-module/higher-order/with-filters/index.js.map +1 -1
  261. package/build-module/icon/index.js +3 -2
  262. package/build-module/icon/index.js.map +1 -1
  263. package/build-module/index.js +3 -2
  264. package/build-module/index.js.map +1 -1
  265. package/build-module/input-control/index.js +2 -0
  266. package/build-module/input-control/index.js.map +1 -1
  267. package/build-module/input-control/input-base.js +1 -1
  268. package/build-module/input-control/input-base.js.map +1 -1
  269. package/build-module/input-control/styles/input-control-styles.js +21 -21
  270. package/build-module/input-control/styles/input-control-styles.js.map +1 -1
  271. package/build-module/isolated-event-container/index.js +7 -9
  272. package/build-module/isolated-event-container/index.js.map +1 -1
  273. package/build-module/item-group/styles.js +10 -10
  274. package/build-module/item-group/styles.js.map +1 -1
  275. package/build-module/menu-group/index.js +20 -2
  276. package/build-module/menu-group/index.js.map +1 -1
  277. package/build-module/menu-group/types.js +2 -0
  278. package/build-module/menu-group/types.js.map +1 -0
  279. package/build-module/navigator/navigator-screen/component.js +27 -7
  280. package/build-module/navigator/navigator-screen/component.js.map +1 -1
  281. package/build-module/number-control/index.js +81 -26
  282. package/build-module/number-control/index.js.map +1 -1
  283. package/build-module/number-control/styles/number-control-styles.js +30 -4
  284. package/build-module/number-control/styles/number-control-styles.js.map +1 -1
  285. package/build-module/palette-edit/index.js +3 -1
  286. package/build-module/palette-edit/index.js.map +1 -1
  287. package/build-module/popover/index.js +23 -33
  288. package/build-module/popover/index.js.map +1 -1
  289. package/build-module/radio-group/index.js +6 -1
  290. package/build-module/radio-group/index.js.map +1 -1
  291. package/build-module/{radio → radio-group/radio}/index.js +6 -1
  292. package/build-module/radio-group/radio/index.js.map +1 -0
  293. package/build-module/{radio-context → radio-group/radio-context}/index.js +0 -0
  294. package/build-module/radio-group/radio-context/index.js.map +1 -0
  295. package/build-module/range-control/styles/range-control-styles.js +47 -57
  296. package/build-module/range-control/styles/range-control-styles.js.map +1 -1
  297. package/build-module/slot-fill/bubbles-virtually/fill.js +9 -5
  298. package/build-module/slot-fill/bubbles-virtually/fill.js.map +1 -1
  299. package/build-module/slot-fill/bubbles-virtually/slot.js +13 -8
  300. package/build-module/slot-fill/bubbles-virtually/slot.js.map +1 -1
  301. package/build-module/slot-fill/bubbles-virtually/use-slot.js +15 -9
  302. package/build-module/slot-fill/bubbles-virtually/use-slot.js.map +1 -1
  303. package/build-module/slot-fill/fill.js +12 -4
  304. package/build-module/slot-fill/fill.js.map +1 -1
  305. package/build-module/slot-fill/use-slot.js +3 -1
  306. package/build-module/slot-fill/use-slot.js.map +1 -1
  307. package/build-module/snackbar/index.js +1 -1
  308. package/build-module/snackbar/index.js.map +1 -1
  309. package/build-module/spinner/styles.js +4 -4
  310. package/build-module/spinner/styles.js.map +1 -1
  311. package/build-module/tab-panel/index.js +5 -10
  312. package/build-module/tab-panel/index.js.map +1 -1
  313. package/build-module/text-control/index.js +0 -2
  314. package/build-module/text-control/index.js.map +1 -1
  315. package/build-module/toggle-control/index.js +15 -3
  316. package/build-module/toggle-control/index.js.map +1 -1
  317. package/build-module/toggle-group-control/toggle-group-control/as-button-group.js +76 -0
  318. package/build-module/toggle-group-control/toggle-group-control/as-button-group.js.map +1 -0
  319. package/build-module/toggle-group-control/toggle-group-control/as-radio-group.js +75 -0
  320. package/build-module/toggle-group-control/toggle-group-control/as-radio-group.js.map +1 -0
  321. package/build-module/toggle-group-control/toggle-group-control/component.js +20 -49
  322. package/build-module/toggle-group-control/toggle-group-control/component.js.map +1 -1
  323. package/build-module/toggle-group-control/toggle-group-control/styles.js +13 -6
  324. package/build-module/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  325. package/build-module/toggle-group-control/toggle-group-control-option-base/component.js +39 -17
  326. package/build-module/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -1
  327. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js +21 -18
  328. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  329. package/build-module/toolbar-dropdown-menu/index.js +1 -1
  330. package/build-module/toolbar-dropdown-menu/index.js.map +1 -1
  331. package/build-module/tools-panel/styles.js +14 -14
  332. package/build-module/tools-panel/styles.js.map +1 -1
  333. package/build-module/tools-panel/tools-panel-item/hook.js +9 -5
  334. package/build-module/tools-panel/tools-panel-item/hook.js.map +1 -1
  335. package/build-module/ui/context/context-system-provider.js +6 -20
  336. package/build-module/ui/context/context-system-provider.js.map +1 -1
  337. package/build-module/unit-control/index.js +8 -10
  338. package/build-module/unit-control/index.js.map +1 -1
  339. package/build-module/unit-control/styles/unit-control-styles.js +8 -24
  340. package/build-module/unit-control/styles/unit-control-styles.js.map +1 -1
  341. package/build-module/utils/colors-values.js +3 -2
  342. package/build-module/utils/colors-values.js.map +1 -1
  343. package/build-module/utils/config-values.js +0 -1
  344. package/build-module/utils/config-values.js.map +1 -1
  345. package/build-module/utils/hooks/use-update-effect.js +5 -1
  346. package/build-module/utils/hooks/use-update-effect.js.map +1 -1
  347. package/build-module/utils/input/base.js +2 -2
  348. package/build-module/utils/input/base.js.map +1 -1
  349. package/build-module/view/index.js.map +1 -1
  350. package/build-style/style-rtl.css +93 -85
  351. package/build-style/style.css +91 -83
  352. package/build-types/base-field/hook.d.ts +11 -11
  353. package/build-types/border-box-control/border-box-control/component.d.ts +55 -6
  354. package/build-types/border-box-control/border-box-control/component.d.ts.map +1 -1
  355. package/build-types/border-box-control/border-box-control/hook.d.ts +18 -17
  356. package/build-types/border-box-control/border-box-control/hook.d.ts.map +1 -1
  357. package/build-types/border-box-control/border-box-control-linked-button/component.d.ts +4 -2
  358. package/build-types/border-box-control/border-box-control-linked-button/component.d.ts.map +1 -1
  359. package/build-types/border-box-control/border-box-control-linked-button/hook.d.ts +12 -12
  360. package/build-types/border-box-control/border-box-control-linked-button/hook.d.ts.map +1 -1
  361. package/build-types/border-box-control/border-box-control-split-controls/component.d.ts +3 -3
  362. package/build-types/border-box-control/border-box-control-split-controls/component.d.ts.map +1 -1
  363. package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts +17 -17
  364. package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts.map +1 -1
  365. package/build-types/border-box-control/border-box-control-visualizer/component.d.ts +3 -2
  366. package/build-types/border-box-control/border-box-control-visualizer/component.d.ts.map +1 -1
  367. package/build-types/border-box-control/border-box-control-visualizer/hook.d.ts +12 -12
  368. package/build-types/border-box-control/border-box-control-visualizer/hook.d.ts.map +1 -1
  369. package/build-types/border-box-control/stories/index.d.ts +17 -0
  370. package/build-types/border-box-control/stories/index.d.ts.map +1 -0
  371. package/build-types/border-box-control/styles.d.ts +7 -6
  372. package/build-types/border-box-control/styles.d.ts.map +1 -1
  373. package/build-types/border-box-control/types.d.ts +5 -42
  374. package/build-types/border-box-control/types.d.ts.map +1 -1
  375. package/build-types/border-control/border-control/component.d.ts +4 -2
  376. package/build-types/border-control/border-control/component.d.ts.map +1 -1
  377. package/build-types/border-control/border-control/hook.d.ts +18 -18
  378. package/build-types/border-control/border-control/hook.d.ts.map +1 -1
  379. package/build-types/border-control/border-control-dropdown/component.d.ts +3 -3
  380. package/build-types/border-control/border-control-dropdown/component.d.ts.map +1 -1
  381. package/build-types/border-control/border-control-dropdown/hook.d.ts +16 -16
  382. package/build-types/border-control/border-control-dropdown/hook.d.ts.map +1 -1
  383. package/build-types/border-control/border-control-style-picker/hook.d.ts +11 -11
  384. package/build-types/border-control/stories/index.d.ts +24 -12
  385. package/build-types/border-control/stories/index.d.ts.map +1 -1
  386. package/build-types/border-control/styles.d.ts +3 -3
  387. package/build-types/border-control/styles.d.ts.map +1 -1
  388. package/build-types/border-control/types.d.ts +10 -53
  389. package/build-types/border-control/types.d.ts.map +1 -1
  390. package/build-types/card/card/hook.d.ts +12 -12
  391. package/build-types/card/card-body/hook.d.ts +12 -12
  392. package/build-types/card/card-divider/hook.d.ts +13 -13
  393. package/build-types/card/card-footer/hook.d.ts +12 -12
  394. package/build-types/card/card-header/hook.d.ts +12 -12
  395. package/build-types/card/card-media/hook.d.ts +12 -12
  396. package/build-types/card/stories/index.d.ts.map +1 -1
  397. package/build-types/circular-option-picker/index.d.ts +4 -24
  398. package/build-types/circular-option-picker/index.d.ts.map +1 -1
  399. package/build-types/color-palette/index.d.ts +43 -14
  400. package/build-types/color-palette/index.d.ts.map +1 -1
  401. package/build-types/color-palette/stories/index.d.ts +50 -0
  402. package/build-types/color-palette/stories/index.d.ts.map +1 -0
  403. package/build-types/color-palette/styles.d.ts +3 -2
  404. package/build-types/color-palette/styles.d.ts.map +1 -1
  405. package/build-types/color-palette/test/index.d.ts +2 -0
  406. package/build-types/color-palette/test/index.d.ts.map +1 -0
  407. package/build-types/color-palette/types.d.ts +90 -0
  408. package/build-types/color-palette/types.d.ts.map +1 -0
  409. package/build-types/color-picker/input-with-slider.d.ts.map +1 -1
  410. package/build-types/color-picker/styles.d.ts +5 -4
  411. package/build-types/color-picker/styles.d.ts.map +1 -1
  412. package/build-types/confirm-dialog/component.d.ts +4 -4
  413. package/build-types/custom-select-control/index.d.ts +1 -12
  414. package/build-types/custom-select-control/index.d.ts.map +1 -1
  415. package/build-types/custom-select-control/styles.d.ts +3 -1
  416. package/build-types/custom-select-control/styles.d.ts.map +1 -1
  417. package/build-types/dashicon/index.d.ts +6 -1
  418. package/build-types/dashicon/index.d.ts.map +1 -1
  419. package/build-types/date-time/date/styles.d.ts +3 -3
  420. package/build-types/date-time/date-time/index.d.ts +2 -0
  421. package/build-types/date-time/date-time/index.d.ts.map +1 -1
  422. package/build-types/date-time/date-time/styles.d.ts +3 -3
  423. package/build-types/date-time/stories/date-time.d.ts.map +1 -1
  424. package/build-types/date-time/time/styles.d.ts +8 -4
  425. package/build-types/date-time/time/styles.d.ts.map +1 -1
  426. package/build-types/date-time/types.d.ts +0 -16
  427. package/build-types/date-time/types.d.ts.map +1 -1
  428. package/build-types/disabled/index.d.ts +8 -1
  429. package/build-types/disabled/index.d.ts.map +1 -1
  430. package/build-types/draggable/index.d.ts +42 -66
  431. package/build-types/draggable/index.d.ts.map +1 -1
  432. package/build-types/draggable/stories/index.d.ts +12 -0
  433. package/build-types/draggable/stories/index.d.ts.map +1 -0
  434. package/build-types/draggable/types.d.ts +58 -0
  435. package/build-types/draggable/types.d.ts.map +1 -0
  436. package/build-types/elevation/hook.d.ts +12 -12
  437. package/build-types/external-link/index.d.ts.map +1 -1
  438. package/build-types/external-link/styles/external-link-styles.d.ts +1 -1
  439. package/build-types/external-link/test/index.d.ts +2 -0
  440. package/build-types/external-link/test/index.d.ts.map +1 -0
  441. package/build-types/flex/flex/hook.d.ts +12 -12
  442. package/build-types/flex/flex/hook.d.ts.map +1 -1
  443. package/build-types/flex/flex-block/hook.d.ts +12 -12
  444. package/build-types/flex/flex-item/hook.d.ts +12 -12
  445. package/build-types/focal-point-picker/focal-point.d.ts.map +1 -1
  446. package/build-types/focal-point-picker/styles/focal-point-picker-style.d.ts +2 -2
  447. package/build-types/focal-point-picker/styles/focal-point-style.d.ts +1 -12
  448. package/build-types/focal-point-picker/styles/focal-point-style.d.ts.map +1 -1
  449. package/build-types/focusable-iframe/index.d.ts.map +1 -1
  450. package/build-types/font-size-picker/constants.d.ts +15 -0
  451. package/build-types/font-size-picker/constants.d.ts.map +1 -0
  452. package/build-types/font-size-picker/font-size-picker-select.d.ts +5 -0
  453. package/build-types/font-size-picker/font-size-picker-select.d.ts.map +1 -0
  454. package/build-types/font-size-picker/font-size-picker-toggle-group.d.ts +5 -0
  455. package/build-types/font-size-picker/font-size-picker-toggle-group.d.ts.map +1 -0
  456. package/build-types/font-size-picker/index.d.ts.map +1 -1
  457. package/build-types/font-size-picker/types.d.ts +14 -14
  458. package/build-types/font-size-picker/types.d.ts.map +1 -1
  459. package/build-types/font-size-picker/utils.d.ts +6 -26
  460. package/build-types/font-size-picker/utils.d.ts.map +1 -1
  461. package/build-types/form-file-upload/index.d.ts.map +1 -1
  462. package/build-types/form-file-upload/types.d.ts +5 -4
  463. package/build-types/form-file-upload/types.d.ts.map +1 -1
  464. package/build-types/form-token-field/index.d.ts.map +1 -1
  465. package/build-types/grid/hook.d.ts +12 -12
  466. package/build-types/h-stack/component.d.ts +1 -1
  467. package/build-types/h-stack/hook.d.ts +12 -12
  468. package/build-types/heading/hook.d.ts +12 -12
  469. package/build-types/icon/index.d.ts +1 -1
  470. package/build-types/icon/index.d.ts.map +1 -1
  471. package/build-types/input-control/index.d.ts +1 -1
  472. package/build-types/input-control/index.d.ts.map +1 -1
  473. package/build-types/input-control/input-base.d.ts +5 -2
  474. package/build-types/input-control/input-base.d.ts.map +1 -1
  475. package/build-types/input-control/styles/input-control-styles.d.ts.map +1 -1
  476. package/build-types/input-control/types.d.ts +3 -8
  477. package/build-types/input-control/types.d.ts.map +1 -1
  478. package/build-types/input-control/utils.d.ts +1 -1
  479. package/build-types/isolated-event-container/index.d.ts +3 -2
  480. package/build-types/isolated-event-container/index.d.ts.map +1 -1
  481. package/build-types/item-group/item/hook.d.ts +13 -13
  482. package/build-types/item-group/item-group/hook.d.ts +13 -13
  483. package/build-types/menu-group/index.d.ts +21 -1
  484. package/build-types/menu-group/index.d.ts.map +1 -1
  485. package/build-types/menu-group/test/index.d.ts +2 -0
  486. package/build-types/menu-group/test/index.d.ts.map +1 -0
  487. package/build-types/menu-group/types.d.ts +23 -0
  488. package/build-types/menu-group/types.d.ts.map +1 -0
  489. package/build-types/navigator/navigator-back-button/hook.d.ts +13 -13
  490. package/build-types/navigator/navigator-button/hook.d.ts +13 -13
  491. package/build-types/navigator/navigator-screen/component.d.ts.map +1 -1
  492. package/build-types/number-control/index.d.ts +2 -4
  493. package/build-types/number-control/index.d.ts.map +1 -1
  494. package/build-types/number-control/styles/number-control-styles.d.ts +5 -0
  495. package/build-types/number-control/styles/number-control-styles.d.ts.map +1 -1
  496. package/build-types/number-control/types.d.ts +12 -0
  497. package/build-types/number-control/types.d.ts.map +1 -1
  498. package/build-types/popover/index.d.ts +1 -1
  499. package/build-types/popover/index.d.ts.map +1 -1
  500. package/build-types/popover/stories/e2e/index.d.ts +1 -1
  501. package/build-types/popover/stories/index.d.ts +2 -0
  502. package/build-types/popover/stories/index.d.ts.map +1 -1
  503. package/build-types/popover/types.d.ts +18 -14
  504. package/build-types/popover/types.d.ts.map +1 -1
  505. package/build-types/radio-group/index.d.ts +10 -0
  506. package/build-types/radio-group/index.d.ts.map +1 -0
  507. package/build-types/radio-group/radio/index.d.ts +7 -0
  508. package/build-types/radio-group/radio/index.d.ts.map +1 -0
  509. package/build-types/{radio-context → radio-group/radio-context}/index.d.ts +0 -0
  510. package/build-types/radio-group/radio-context/index.d.ts.map +1 -0
  511. package/build-types/range-control/index.d.ts +1 -1
  512. package/build-types/range-control/styles/range-control-styles.d.ts +2 -1
  513. package/build-types/range-control/styles/range-control-styles.d.ts.map +1 -1
  514. package/build-types/resizable-box/index.d.ts +1 -1
  515. package/build-types/resizable-box/resize-tooltip/index.d.ts +1 -1
  516. package/build-types/resizable-box/resize-tooltip/label.d.ts +1 -1
  517. package/build-types/scrollable/hook.d.ts +12 -12
  518. package/build-types/search-control/index.d.ts +2 -2
  519. package/build-types/search-control/stories/index.d.ts +4 -4
  520. package/build-types/select-control/stories/index.d.ts.map +1 -1
  521. package/build-types/slot-fill/bubbles-virtually/use-slot.d.ts.map +1 -1
  522. package/build-types/slot-fill/fill.d.ts.map +1 -1
  523. package/build-types/slot-fill/use-slot.d.ts.map +1 -1
  524. package/build-types/spacer/hook.d.ts +12 -12
  525. package/build-types/spinner/index.d.ts +1 -1
  526. package/build-types/surface/hook.d.ts +12 -12
  527. package/build-types/tab-panel/index.d.ts.map +1 -1
  528. package/build-types/text/hook.d.ts +12 -12
  529. package/build-types/text-control/index.d.ts +2 -4
  530. package/build-types/text-control/index.d.ts.map +1 -1
  531. package/build-types/text-control/stories/index.d.ts.map +1 -1
  532. package/build-types/toggle-control/index.d.ts.map +1 -1
  533. package/build-types/toggle-control/types.d.ts +2 -1
  534. package/build-types/toggle-control/types.d.ts.map +1 -1
  535. package/build-types/toggle-group-control/stories/index.d.ts +2 -2
  536. package/build-types/toggle-group-control/stories/index.d.ts.map +1 -1
  537. package/build-types/toggle-group-control/toggle-group-control/as-button-group.d.ts +6 -0
  538. package/build-types/toggle-group-control/toggle-group-control/as-button-group.d.ts.map +1 -0
  539. package/build-types/toggle-group-control/toggle-group-control/as-radio-group.d.ts +6 -0
  540. package/build-types/toggle-group-control/toggle-group-control/as-radio-group.d.ts.map +1 -0
  541. package/build-types/toggle-group-control/toggle-group-control/component.d.ts +2 -2
  542. package/build-types/toggle-group-control/toggle-group-control/component.d.ts.map +1 -1
  543. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts +1 -2
  544. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts.map +1 -1
  545. package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts.map +1 -1
  546. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts +4 -7
  547. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts.map +1 -1
  548. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts +1 -1
  549. package/build-types/toggle-group-control/types.d.ts +21 -15
  550. package/build-types/toggle-group-control/types.d.ts.map +1 -1
  551. package/build-types/tools-panel/tools-panel/hook.d.ts +12 -12
  552. package/build-types/tools-panel/tools-panel-header/hook.d.ts +12 -12
  553. package/build-types/tools-panel/tools-panel-item/hook.d.ts +12 -12
  554. package/build-types/tools-panel/tools-panel-item/hook.d.ts.map +1 -1
  555. package/build-types/truncate/hook.d.ts +12 -12
  556. package/build-types/ui/context/context-system-provider.d.ts.map +1 -1
  557. package/build-types/ui/control-group/hook.d.ts +12 -12
  558. package/build-types/ui/control-label/component.d.ts +1 -1
  559. package/build-types/ui/control-label/hook.d.ts +12 -12
  560. package/build-types/ui/form-group/form-group.d.ts +4 -4
  561. package/build-types/ui/form-group/use-form-group.d.ts +28 -28
  562. package/build-types/unit-control/index.d.ts +2 -2
  563. package/build-types/unit-control/index.d.ts.map +1 -1
  564. package/build-types/unit-control/styles/unit-control-styles.d.ts +2 -5
  565. package/build-types/unit-control/styles/unit-control-styles.d.ts.map +1 -1
  566. package/build-types/unit-control/types.d.ts +3 -3
  567. package/build-types/unit-control/types.d.ts.map +1 -1
  568. package/build-types/utils/colors-values.d.ts +1 -0
  569. package/build-types/utils/colors-values.d.ts.map +1 -1
  570. package/build-types/utils/config-values.d.ts +0 -1
  571. package/build-types/utils/hooks/use-update-effect.d.ts.map +1 -1
  572. package/build-types/utils/types.d.ts +0 -14
  573. package/build-types/utils/types.d.ts.map +1 -1
  574. package/build-types/v-stack/component.d.ts +2 -2
  575. package/build-types/v-stack/hook.d.ts +12 -12
  576. package/build-types/v-stack/stories/index.d.ts +2 -2
  577. package/build-types/view/index.d.ts +1 -1
  578. package/build-types/view/index.d.ts.map +1 -1
  579. package/package.json +17 -17
  580. package/src/angle-picker-control/index.js +3 -2
  581. package/src/angle-picker-control/stories/index.js +3 -0
  582. package/src/autocomplete/autocompleter-ui.js +29 -2
  583. package/src/autocomplete/index.js +12 -3
  584. package/src/autocomplete/style.scss +1 -1
  585. package/src/autocomplete/test/index.js +89 -0
  586. package/src/base-field/test/__snapshots__/index.js.snap +9 -7
  587. package/src/base-field/test/index.js +27 -15
  588. package/src/border-box-control/border-box-control/README.md +13 -17
  589. package/src/border-box-control/border-box-control/component.tsx +64 -13
  590. package/src/border-box-control/border-box-control/hook.ts +25 -6
  591. package/src/border-box-control/border-box-control-linked-button/hook.ts +3 -6
  592. package/src/border-box-control/border-box-control-split-controls/component.tsx +3 -6
  593. package/src/border-box-control/border-box-control-split-controls/hook.ts +21 -14
  594. package/src/border-box-control/border-box-control-visualizer/hook.ts +4 -7
  595. package/src/border-box-control/stories/index.tsx +90 -0
  596. package/src/border-box-control/styles.ts +28 -22
  597. package/src/border-box-control/test/index.js +287 -122
  598. package/src/border-box-control/types.ts +32 -62
  599. package/src/border-control/border-control/README.md +12 -17
  600. package/src/border-control/border-control/component.tsx +5 -4
  601. package/src/border-control/border-control/hook.ts +20 -6
  602. package/src/border-control/border-control-dropdown/component.tsx +7 -6
  603. package/src/border-control/border-control-dropdown/hook.ts +14 -8
  604. package/src/border-control/stories/index.tsx +12 -14
  605. package/src/border-control/styles.ts +20 -23
  606. package/src/border-control/test/index.js +139 -96
  607. package/src/border-control/types.ts +43 -82
  608. package/src/box-control/README.md +14 -0
  609. package/src/box-control/index.js +4 -0
  610. package/src/box-control/stories/index.js +8 -27
  611. package/src/button/README.md +2 -15
  612. package/src/button/stories/index.js +109 -178
  613. package/src/button/style.scss +17 -54
  614. package/src/card/stories/index.tsx +27 -31
  615. package/src/card/test/__snapshots__/index.tsx.snap +98 -401
  616. package/src/card/test/index.tsx +4 -8
  617. package/src/checkbox-control/style.scss +3 -3
  618. package/src/circular-option-picker/index.js +14 -20
  619. package/src/color-palette/README.md +47 -49
  620. package/src/color-palette/{index.js → index.tsx} +132 -51
  621. package/src/color-palette/stories/{index.js → index.tsx} +38 -27
  622. package/src/color-palette/style.scss +3 -3
  623. package/src/color-palette/{styles.js → styles.ts} +0 -0
  624. package/src/color-palette/test/__snapshots__/{index.js.snap → index.tsx.snap} +0 -0
  625. package/src/color-palette/test/{index.js → index.tsx} +1 -1
  626. package/src/color-palette/types.ts +97 -0
  627. package/src/color-picker/input-with-slider.tsx +14 -3
  628. package/src/custom-gradient-picker/gradient-bar/index.js +1 -3
  629. package/src/custom-select-control/README.md +14 -0
  630. package/src/custom-select-control/index.js +29 -15
  631. package/src/custom-select-control/stories/index.js +1 -0
  632. package/src/custom-select-control/style.scss +6 -1
  633. package/src/custom-select-control/test/index.js +39 -0
  634. package/src/dashicon/index.js +21 -2
  635. package/src/date-time/date/test/index.tsx +2 -2
  636. package/src/date-time/date-time/index.tsx +2 -0
  637. package/src/date-time/stories/date-time.tsx +4 -0
  638. package/src/date-time/time/index.tsx +4 -4
  639. package/src/date-time/types.ts +0 -19
  640. package/src/dimension-control/test/__snapshots__/index.test.js.snap +4 -0
  641. package/src/disabled/README.md +2 -0
  642. package/src/disabled/index.tsx +8 -1
  643. package/src/disabled/test/index.tsx +0 -5
  644. package/src/divider/test/index.tsx +4 -4
  645. package/src/draggable/README.md +13 -18
  646. package/src/draggable/{index.js → index.tsx} +71 -47
  647. package/src/draggable/stories/index.tsx +83 -0
  648. package/src/draggable/types.ts +58 -0
  649. package/src/drop-zone/style.scss +1 -1
  650. package/src/external-link/index.tsx +14 -6
  651. package/src/external-link/test/index.tsx +106 -0
  652. package/src/flex/flex/hook.ts +0 -3
  653. package/src/flex/test/index.tsx +29 -3
  654. package/src/focal-point-picker/focal-point.tsx +2 -24
  655. package/src/focal-point-picker/styles/focal-point-style.ts +8 -32
  656. package/src/focusable-iframe/index.js +0 -1
  657. package/src/font-size-picker/README.md +3 -3
  658. package/src/font-size-picker/constants.ts +37 -0
  659. package/src/font-size-picker/font-size-picker-select.tsx +98 -0
  660. package/src/font-size-picker/font-size-picker-toggle-group.tsx +41 -0
  661. package/src/font-size-picker/index.tsx +161 -214
  662. package/src/font-size-picker/test/index.tsx +653 -171
  663. package/src/font-size-picker/test/utils.ts +56 -140
  664. package/src/font-size-picker/types.ts +26 -17
  665. package/src/font-size-picker/utils.ts +16 -124
  666. package/src/form-file-upload/README.md +1 -3
  667. package/src/form-file-upload/index.tsx +1 -0
  668. package/src/form-file-upload/types.ts +5 -4
  669. package/src/form-toggle/style.scss +3 -3
  670. package/src/form-toggle/test/__snapshots__/index.tsx.snap +15 -13
  671. package/src/form-toggle/test/index.tsx +1 -1
  672. package/src/form-token-field/index.tsx +13 -5
  673. package/src/form-token-field/style.scss +2 -2
  674. package/src/form-token-field/test/index.tsx +6 -6
  675. package/src/h-stack/test/__snapshots__/index.tsx.snap +36 -30
  676. package/src/h-stack/test/index.tsx +3 -3
  677. package/src/higher-order/navigate-regions/index.js +4 -0
  678. package/src/higher-order/navigate-regions/style.scss +72 -20
  679. package/src/higher-order/with-filters/index.js +4 -9
  680. package/src/higher-order/with-notices/test/index.js +1 -1
  681. package/src/icon/index.tsx +3 -2
  682. package/src/icon/test/index.js +10 -0
  683. package/src/index.js +3 -1
  684. package/src/input-control/index.tsx +2 -0
  685. package/src/input-control/input-base.tsx +3 -3
  686. package/src/input-control/styles/input-control-styles.tsx +1 -0
  687. package/src/input-control/types.ts +4 -11
  688. package/src/isolated-event-container/index.tsx +32 -0
  689. package/src/item-group/stories/index.js +1 -1
  690. package/src/item-group/styles.ts +1 -1
  691. package/src/item-group/test/__snapshots__/index.js.snap +90 -85
  692. package/src/item-group/test/index.js +7 -17
  693. package/src/menu-group/{index.js → index.tsx} +22 -3
  694. package/src/menu-group/test/{index.js → index.tsx} +0 -0
  695. package/src/menu-group/types.ts +23 -0
  696. package/src/menu-item/style.scss +1 -1
  697. package/src/mobile/bottom-sheet/test/range-cell.native.js +4 -4
  698. package/src/mobile/html-text-input/test/index.native.js +2 -2
  699. package/src/mobile/link-settings/test/edit.native.js +29 -29
  700. package/src/mobile/link-settings/test/link-settings-navigation.native.js +5 -5
  701. package/src/navigator/navigator-screen/component.tsx +28 -6
  702. package/src/notice/README.md +2 -1
  703. package/src/notice/style.scss +1 -1
  704. package/src/number-control/README.md +9 -4
  705. package/src/number-control/index.tsx +100 -33
  706. package/src/number-control/styles/number-control-styles.js +26 -1
  707. package/src/number-control/test/index.js +50 -0
  708. package/src/number-control/types.ts +12 -0
  709. package/src/palette-edit/index.js +3 -0
  710. package/src/panel/style.scss +1 -1
  711. package/src/popover/README.md +12 -7
  712. package/src/popover/index.tsx +38 -37
  713. package/src/popover/stories/index.tsx +29 -1
  714. package/src/popover/style.scss +9 -0
  715. package/src/popover/types.ts +18 -15
  716. package/src/radio-group/README.md +4 -0
  717. package/src/radio-group/index.js +6 -1
  718. package/src/{radio → radio-group/radio}/index.js +6 -1
  719. package/src/{radio-context → radio-group/radio-context}/index.js +0 -0
  720. package/src/radio-group/stories/index.js +11 -2
  721. package/src/range-control/styles/range-control-styles.ts +2 -2
  722. package/src/resizable-box/style.scss +2 -2
  723. package/src/sandbox/test/index.js +2 -2
  724. package/src/scrollable/test/index.tsx +7 -3
  725. package/src/search-control/style.scss +1 -1
  726. package/src/select-control/stories/index.tsx +9 -4
  727. package/src/slot-fill/bubbles-virtually/fill.js +5 -5
  728. package/src/slot-fill/bubbles-virtually/slot.js +10 -8
  729. package/src/slot-fill/bubbles-virtually/use-slot.js +15 -9
  730. package/src/slot-fill/fill.js +12 -2
  731. package/src/slot-fill/use-slot.js +3 -0
  732. package/src/snackbar/index.js +1 -1
  733. package/src/snackbar/style.scss +2 -2
  734. package/src/spacer/test/index.tsx +33 -3
  735. package/src/spinner/styles.ts +1 -1
  736. package/src/surface/test/__snapshots__/index.tsx.snap +58 -46
  737. package/src/surface/test/index.tsx +12 -22
  738. package/src/tab-panel/index.tsx +10 -8
  739. package/src/tab-panel/style.scss +4 -5
  740. package/src/tab-panel/test/index.tsx +78 -1
  741. package/src/text/test/__snapshots__/index.tsx.snap +19 -15
  742. package/src/text/test/index.tsx +6 -6
  743. package/src/text-control/index.tsx +0 -2
  744. package/src/text-control/stories/index.tsx +5 -6
  745. package/src/toggle-control/README.md +6 -4
  746. package/src/toggle-control/index.tsx +13 -2
  747. package/src/toggle-control/types.ts +2 -4
  748. package/src/toggle-group-control/stories/index.tsx +6 -4
  749. package/src/toggle-group-control/test/__snapshots__/index.tsx.snap +221 -164
  750. package/src/toggle-group-control/test/index.tsx +156 -17
  751. package/src/toggle-group-control/toggle-group-control/README.md +8 -1
  752. package/src/toggle-group-control/toggle-group-control/as-button-group.tsx +103 -0
  753. package/src/toggle-group-control/toggle-group-control/as-radio-group.tsx +99 -0
  754. package/src/toggle-group-control/toggle-group-control/component.tsx +29 -74
  755. package/src/toggle-group-control/toggle-group-control/styles.ts +23 -15
  756. package/src/toggle-group-control/toggle-group-control-option-base/component.tsx +49 -25
  757. package/src/toggle-group-control/toggle-group-control-option-base/styles.ts +39 -19
  758. package/src/toggle-group-control/types.ts +76 -63
  759. package/src/toolbar-dropdown-menu/index.js +1 -1
  760. package/src/tools-panel/stories/index.js +0 -1
  761. package/src/tools-panel/stories/tools-panel-with-item-group-slot.js +0 -1
  762. package/src/tools-panel/styles.ts +1 -1
  763. package/src/tools-panel/tools-panel-item/hook.ts +6 -1
  764. package/src/tree-grid/test/__snapshots__/cell.js.snap +20 -18
  765. package/src/tree-grid/test/__snapshots__/roving-tab-index.js.snap +3 -1
  766. package/src/tree-grid/test/__snapshots__/row.js.snap +33 -29
  767. package/src/tree-grid/test/cell.js +1 -1
  768. package/src/tree-grid/test/index.js +12 -12
  769. package/src/tree-grid/test/roving-tab-index.js +1 -1
  770. package/src/tree-grid/test/row.js +2 -2
  771. package/src/truncate/test/index.tsx +9 -9
  772. package/src/ui/context/context-system-provider.js +5 -18
  773. package/src/ui/context/test/__snapshots__/context-system-provider.js.snap +23 -17
  774. package/src/ui/context/test/context-system-provider.js +3 -3
  775. package/src/ui/control-group/test/__snapshots__/index.js.snap +18 -16
  776. package/src/ui/control-group/test/index.js +1 -1
  777. package/src/ui/control-label/test/__snapshots__/index.js.snap +27 -21
  778. package/src/ui/control-label/test/index.js +3 -3
  779. package/src/ui/form-group/test/__snapshots__/index.js.snap +34 -30
  780. package/src/ui/form-group/test/index.js +18 -19
  781. package/src/ui/shortcut/test/__snapshots__/index.js.snap +1 -1
  782. package/src/ui/shortcut/test/index.js +1 -1
  783. package/src/ui/spinner/test/__snapshots__/index.js.snap +75 -73
  784. package/src/ui/spinner/test/index.js +3 -7
  785. package/src/unit-control/index.tsx +29 -30
  786. package/src/unit-control/styles/unit-control-styles.ts +6 -12
  787. package/src/unit-control/test/utils.ts +43 -0
  788. package/src/unit-control/types.ts +5 -6
  789. package/src/utils/colors-values.js +4 -2
  790. package/src/utils/config-values.js +0 -1
  791. package/src/utils/hooks/stories/use-cx.js +1 -1
  792. package/src/utils/hooks/use-update-effect.js +5 -1
  793. package/src/utils/input/base.js +2 -2
  794. package/src/utils/types.ts +0 -15
  795. package/src/v-stack/test/__snapshots__/index.tsx.snap +36 -30
  796. package/src/v-stack/test/index.tsx +3 -3
  797. package/src/view/{index.js → index.ts} +0 -0
  798. package/src/view/test/__snapshots__/index.js.snap +34 -24
  799. package/src/view/test/index.js +5 -5
  800. package/tsconfig.json +0 -2
  801. package/tsconfig.tsbuildinfo +1 -1
  802. package/build/radio/index.js.map +0 -1
  803. package/build/radio-context/index.js.map +0 -1
  804. package/build-module/radio/index.js.map +0 -1
  805. package/build-module/radio-context/index.js.map +0 -1
  806. package/build-types/radio-context/index.d.ts.map +0 -1
  807. package/src/border-box-control/stories/index.js +0 -106
  808. package/src/draggable/stories/index.js +0 -72
  809. package/src/form-file-upload/stories/index.js +0 -51
  810. package/src/isolated-event-container/index.js +0 -28
  811. package/src/radio/stories/index.js +0 -20
@@ -1,249 +1,731 @@
1
1
  /**
2
2
  * External dependencies
3
3
  */
4
- import { render, fireEvent, screen } from '@testing-library/react';
4
+ import { render, screen, fireEvent } from '@testing-library/react';
5
+ import userEvent from '@testing-library/user-event';
5
6
 
6
7
  /**
7
8
  * Internal dependencies
8
9
  */
9
10
  import FontSizePicker from '../';
10
-
11
- const getUnitSelect = () =>
12
- document.body.querySelector( '.components-unit-control select' );
13
- const getUnitLabel = () =>
14
- document.body.querySelector( '.components-unit-control__unit-label' );
15
-
16
- const toggleCustomInput = ( showCustomInput: boolean ) => {
17
- const label = showCustomInput ? 'Set custom size' : 'Use size preset';
18
- const toggleCustom = screen.getByLabelText( label, { selector: 'button' } );
19
- fireEvent.click( toggleCustom );
20
- };
11
+ import type { FontSize } from '../types';
21
12
 
22
13
  describe( 'FontSizePicker', () => {
23
- describe( 'onChange values', () => {
24
- it( 'should not use units when the initial value is a number', () => {
25
- let fontSize = 12;
26
- const setFontSize = jest.fn(
27
- ( nextSize ) => ( fontSize = nextSize )
28
- );
29
-
14
+ test.each( [
15
+ // Use units when initial value uses units.
16
+ { value: '12px', expectedValue: '80px' },
17
+ // Don't use units when initial value does not use units.
18
+ { value: 12, expectedValue: 80 },
19
+ ] )(
20
+ 'should call onChange( $expectedValue ) after user types 80 when value is $value',
21
+ async ( { value, expectedValue } ) => {
22
+ const user = userEvent.setup( {
23
+ advanceTimers: jest.advanceTimersByTime,
24
+ } );
25
+ const onChange = jest.fn();
30
26
  render(
31
27
  <FontSizePicker
32
- value={ fontSize }
33
- onChange={ setFontSize }
34
28
  __nextHasNoMarginBottom
29
+ value={ value }
30
+ onChange={ onChange }
35
31
  />
36
32
  );
33
+ const input = screen.getByLabelText( 'Custom' );
34
+ await user.clear( input );
35
+ await user.type( input, '80' );
36
+ expect( onChange ).toHaveBeenCalledTimes( 3 ); // Once for the clear, then once per keystroke.
37
+ expect( onChange ).toHaveBeenCalledWith( expectedValue );
38
+ }
39
+ );
37
40
 
38
- const unitSelect = getUnitSelect();
39
- const unitLabel = getUnitLabel();
40
- const input = screen.getByLabelText( 'Custom', {
41
- selector: 'input',
41
+ test.each( [
42
+ // Use units when first font size uses units.
43
+ { firstFontSize: '12px', expectedValue: '80px' },
44
+ // Don't use units when first font size does not use units.
45
+ { firstFontSize: 12, expectedValue: 80 },
46
+ ] )(
47
+ 'should call onChange( $expectedValue ) after user types 80 when first font size is $firstFontSize',
48
+ async ( { firstFontSize, expectedValue } ) => {
49
+ const user = userEvent.setup( {
50
+ advanceTimers: jest.advanceTimersByTime,
42
51
  } );
43
-
44
- input.focus();
45
- fireEvent.change( input, { target: { value: 16 } } );
46
-
47
- expect( unitSelect ).toBeFalsy();
48
- expect( unitLabel ).toBeTruthy();
49
- expect( fontSize ).toBe( 16 );
50
- } );
51
-
52
- it( 'should use units when the initial value has a unit', () => {
53
- let fontSize = '12px';
54
- const setFontSize = jest.fn(
55
- ( nextSize ) => ( fontSize = nextSize )
52
+ const onChange = jest.fn();
53
+ render(
54
+ <FontSizePicker
55
+ __nextHasNoMarginBottom
56
+ fontSizes={ [ { slug: 'slug', size: firstFontSize } ] }
57
+ onChange={ onChange }
58
+ />
59
+ );
60
+ await user.click(
61
+ screen.getByRole( 'button', { name: 'Set custom size' } )
56
62
  );
63
+ const input = screen.getByLabelText( 'Custom' );
64
+ await user.type( input, '80' );
65
+ expect( onChange ).toHaveBeenCalledTimes( 2 ); // Once per keystroke.
66
+ expect( onChange ).toHaveBeenCalledWith( expectedValue );
67
+ }
68
+ );
57
69
 
70
+ describe( 'with > 5 homogeneous font sizes', () => {
71
+ const fontSizes = [
72
+ {
73
+ slug: 'tiny',
74
+ name: 'Tiny',
75
+ size: '8px',
76
+ },
77
+ {
78
+ slug: 'small',
79
+ name: 'Small',
80
+ size: '12px',
81
+ },
82
+ {
83
+ slug: 'medium',
84
+ name: 'Medium',
85
+ size: '16px',
86
+ },
87
+ {
88
+ slug: 'large',
89
+ name: 'Large',
90
+ size: '20px',
91
+ },
92
+ {
93
+ slug: 'x-large',
94
+ name: 'Extra Large',
95
+ size: '30px',
96
+ },
97
+ {
98
+ slug: 'xx-large',
99
+ // no name
100
+ size: '40px',
101
+ },
102
+ ];
103
+
104
+ it( 'displays a select control', async () => {
105
+ const user = userEvent.setup( {
106
+ advanceTimers: jest.advanceTimersByTime,
107
+ } );
58
108
  render(
59
109
  <FontSizePicker
60
- value={ fontSize }
61
- onChange={ setFontSize }
62
110
  __nextHasNoMarginBottom
111
+ fontSizes={ fontSizes }
63
112
  />
64
113
  );
114
+ await user.click(
115
+ screen.getByRole( 'button', { name: 'Font size' } )
116
+ );
117
+ const options = screen.getAllByRole( 'option' );
118
+ expect( options ).toHaveLength( 8 );
119
+ expect( options[ 0 ] ).toHaveAccessibleName( 'Default' );
120
+ expect( options[ 1 ] ).toHaveAccessibleName( 'Tiny 8' );
121
+ expect( options[ 2 ] ).toHaveAccessibleName( 'Small 12' );
122
+ expect( options[ 3 ] ).toHaveAccessibleName( 'Medium 16' );
123
+ expect( options[ 4 ] ).toHaveAccessibleName( 'Large 20' );
124
+ expect( options[ 5 ] ).toHaveAccessibleName( 'Extra Large 30' );
125
+ expect( options[ 6 ] ).toHaveAccessibleName( 'xx-large 40' );
126
+ expect( options[ 7 ] ).toHaveAccessibleName( 'Custom' );
127
+ } );
65
128
 
66
- const unitSelect = getUnitSelect();
67
- const unitLabel = getUnitLabel();
68
- const input = screen.getByLabelText( 'Custom', {
69
- selector: 'input',
70
- } );
129
+ test.each( [
130
+ { value: undefined, expectedLabel: 'Size (px)' },
131
+ { value: '8px', expectedLabel: 'Size (px)' },
132
+ { value: '3px', expectedLabel: 'Size Custom' },
133
+ ] )(
134
+ 'displays $expectedLabel as label when value is $value',
135
+ ( { value, expectedLabel } ) => {
136
+ render(
137
+ <FontSizePicker
138
+ __nextHasNoMarginBottom
139
+ fontSizes={ fontSizes }
140
+ value={ value }
141
+ />
142
+ );
143
+ expect(
144
+ screen.getByLabelText( expectedLabel )
145
+ ).toBeInTheDocument();
146
+ }
147
+ );
71
148
 
72
- input.focus();
73
- fireEvent.change( input, { target: { value: 16 } } );
149
+ test.each( [
150
+ {
151
+ option: 'Default',
152
+ value: '8px',
153
+ expectedArguments: [ undefined ],
154
+ },
155
+ {
156
+ option: 'Tiny 8',
157
+ value: undefined,
158
+ expectedArguments: [ '8px', fontSizes[ 0 ] ],
159
+ },
160
+ ] )(
161
+ 'calls onChange( $expectedArguments ) when $option is selected',
162
+ async ( { option, value, expectedArguments } ) => {
163
+ const user = userEvent.setup( {
164
+ advanceTimers: jest.advanceTimersByTime,
165
+ } );
166
+ const onChange = jest.fn();
167
+ render(
168
+ <FontSizePicker
169
+ __nextHasNoMarginBottom
170
+ fontSizes={ fontSizes }
171
+ value={ value }
172
+ onChange={ onChange }
173
+ />
174
+ );
175
+ await user.click(
176
+ screen.getByRole( 'button', { name: 'Font size' } )
177
+ );
178
+ await user.click(
179
+ screen.getByRole( 'option', { name: option } )
180
+ );
181
+ expect( onChange ).toHaveBeenCalledTimes( 1 );
182
+ expect( onChange ).toHaveBeenCalledWith( ...expectedArguments );
183
+ }
184
+ );
74
185
 
75
- expect( unitSelect ).toBeTruthy();
76
- expect( unitLabel ).toBeFalsy();
77
- expect( fontSize ).toBe( '16px' );
78
- } );
186
+ commonSelectTests( fontSizes );
187
+ commonTests( fontSizes );
188
+ } );
79
189
 
80
- it( 'should not use units when fontSizes size values are numbers', () => {
81
- let fontSize;
82
- const fontSizes = [
83
- {
84
- name: 'Small',
85
- slug: 'small',
86
- size: 12,
87
- },
88
- ];
89
- const setFontSize = jest.fn(
90
- ( nextSize ) => ( fontSize = nextSize )
91
- );
190
+ describe( 'with > 5 heterogeneous font sizes', () => {
191
+ const fontSizes = [
192
+ {
193
+ slug: 'tiny',
194
+ name: 'Tiny',
195
+ size: '8px',
196
+ },
197
+ {
198
+ slug: 'small',
199
+ name: 'Small',
200
+ size: '1em',
201
+ },
202
+ {
203
+ slug: 'medium',
204
+ name: 'Medium',
205
+ size: '2rem',
206
+ },
207
+ {
208
+ slug: 'large',
209
+ name: 'Large',
210
+ size: 'clamp(1.75rem, 3vw, 2.25rem)',
211
+ },
212
+ {
213
+ slug: 'x-large',
214
+ name: 'Extra Large',
215
+ size: '30px',
216
+ },
217
+ {
218
+ slug: 'xx-large',
219
+ // no name
220
+ size: '40px',
221
+ },
222
+ ];
92
223
 
224
+ it( 'displays a select control', async () => {
225
+ const user = userEvent.setup( {
226
+ advanceTimers: jest.advanceTimersByTime,
227
+ } );
93
228
  render(
94
229
  <FontSizePicker
95
- fontSizes={ fontSizes }
96
- value={ fontSize }
97
- onChange={ setFontSize }
98
230
  __nextHasNoMarginBottom
231
+ fontSizes={ fontSizes }
99
232
  />
100
233
  );
234
+ await user.click(
235
+ screen.getByRole( 'button', { name: 'Font size' } )
236
+ );
237
+ const options = screen.getAllByRole( 'option' );
238
+ expect( options ).toHaveLength( 8 );
239
+ expect( options[ 0 ] ).toHaveAccessibleName( 'Default' );
240
+ expect( options[ 1 ] ).toHaveAccessibleName( 'Tiny 8px' );
241
+ expect( options[ 2 ] ).toHaveAccessibleName( 'Small 1em' );
242
+ expect( options[ 3 ] ).toHaveAccessibleName( 'Medium 2rem' );
243
+ expect( options[ 4 ] ).toHaveAccessibleName( 'Large' );
244
+ expect( options[ 5 ] ).toHaveAccessibleName( 'Extra Large 30px' );
245
+ expect( options[ 6 ] ).toHaveAccessibleName( 'xx-large 40px' );
246
+ expect( options[ 7 ] ).toHaveAccessibleName( 'Custom' );
247
+ } );
101
248
 
102
- toggleCustomInput( true );
103
- const unitSelect = getUnitSelect();
104
- const unitLabel = getUnitLabel();
105
- const input = screen.getByLabelText( 'Custom', {
106
- selector: 'input',
107
- } );
249
+ test.each( [
250
+ { value: undefined, option: 'Default' },
251
+ { value: '', option: 'Default' },
252
+ { value: '8px', option: 'Tiny' },
253
+ ] )(
254
+ 'defaults to $option when value is $value',
255
+ ( { value, option } ) => {
256
+ render(
257
+ <FontSizePicker
258
+ __nextHasNoMarginBottom
259
+ fontSizes={ fontSizes }
260
+ value={ value }
261
+ />
262
+ );
263
+ expect(
264
+ screen.getByRole( 'button', { name: 'Font size' } )
265
+ ).toHaveTextContent( option );
266
+ }
267
+ );
108
268
 
109
- input.focus();
110
- fireEvent.change( input, { target: { value: 16 } } );
269
+ test.each( [
270
+ { value: undefined, expectedLabel: 'Size' },
271
+ { value: '8px', expectedLabel: 'Size' },
272
+ { value: '1em', expectedLabel: 'Size' },
273
+ { value: '2rem', expectedLabel: 'Size' },
274
+ { value: 'clamp(1.75rem, 3vw, 2.25rem)', expectedLabel: 'Size' },
275
+ { value: '3px', expectedLabel: 'Size Custom' },
276
+ ] )(
277
+ 'displays $expectedLabel as label when value is $value',
278
+ ( { value, expectedLabel } ) => {
279
+ render(
280
+ <FontSizePicker
281
+ __nextHasNoMarginBottom
282
+ fontSizes={ fontSizes }
283
+ value={ value }
284
+ />
285
+ );
286
+ expect(
287
+ screen.getByLabelText( expectedLabel )
288
+ ).toBeInTheDocument();
289
+ }
290
+ );
111
291
 
112
- expect( unitSelect ).toBeFalsy();
113
- expect( unitLabel ).toBeTruthy();
114
- expect( fontSize ).toBe( 16 );
115
- } );
292
+ test.each( [
293
+ {
294
+ option: 'Default',
295
+ value: '8px',
296
+ expectedArguments: [ undefined ],
297
+ },
298
+ {
299
+ option: 'Tiny 8px',
300
+ value: undefined,
301
+ expectedArguments: [ '8px', fontSizes[ 0 ] ],
302
+ },
303
+ {
304
+ option: 'Small 1em',
305
+ value: '8px',
306
+ expectedArguments: [ '1em', fontSizes[ 1 ] ],
307
+ },
308
+ {
309
+ option: 'Medium 2rem',
310
+ value: '8px',
311
+ expectedArguments: [ '2rem', fontSizes[ 2 ] ],
312
+ },
313
+ {
314
+ option: 'Large',
315
+ value: '8px',
316
+ expectedArguments: [
317
+ 'clamp(1.75rem, 3vw, 2.25rem)',
318
+ fontSizes[ 3 ],
319
+ ],
320
+ },
321
+ ] )(
322
+ 'calls onChange( $expectedValue ) when $option is selected',
323
+ async ( { option, value, expectedArguments } ) => {
324
+ const user = userEvent.setup( {
325
+ advanceTimers: jest.advanceTimersByTime,
326
+ } );
327
+ const onChange = jest.fn();
328
+ render(
329
+ <FontSizePicker
330
+ __nextHasNoMarginBottom
331
+ fontSizes={ fontSizes }
332
+ value={ value }
333
+ onChange={ onChange }
334
+ />
335
+ );
336
+ await user.click(
337
+ screen.getByRole( 'button', { name: 'Font size' } )
338
+ );
339
+ await user.click(
340
+ screen.getByRole( 'option', { name: option } )
341
+ );
342
+ expect( onChange ).toHaveBeenCalledTimes( 1 );
343
+ expect( onChange ).toHaveBeenCalledWith( ...expectedArguments );
344
+ }
345
+ );
116
346
 
117
- it( 'should use units when fontSizes size values have units', () => {
118
- let fontSize;
119
- const fontSizes = [
120
- {
121
- name: 'Small',
122
- slug: 'small',
123
- size: '12px',
124
- },
125
- ];
126
- const setFontSize = jest.fn(
127
- ( nextSize ) => ( fontSize = nextSize )
128
- );
347
+ commonSelectTests( fontSizes );
348
+ commonTests( fontSizes );
349
+ } );
350
+
351
+ describe( 'with ≤ 5 homogeneous font sizes', () => {
352
+ const fontSizes = [
353
+ {
354
+ slug: 'small',
355
+ // no name
356
+ size: '12px',
357
+ },
358
+ {
359
+ slug: 'medium',
360
+ name: 'Medium',
361
+ size: '16px',
362
+ },
363
+ {
364
+ slug: 'large',
365
+ name: 'Large',
366
+ size: '22px',
367
+ },
368
+ {
369
+ slug: 'huge',
370
+ name: 'Huge',
371
+ size: '30px',
372
+ },
373
+ {
374
+ slug: 'gigantosaurus',
375
+ name: 'Gigantosaurus',
376
+ size: '40px',
377
+ },
378
+ ];
129
379
 
380
+ it( 'displays a toggle group control with t-shirt sizes', () => {
130
381
  render(
131
382
  <FontSizePicker
132
- fontSizes={ fontSizes }
133
- value={ fontSize }
134
- onChange={ setFontSize }
135
383
  __nextHasNoMarginBottom
384
+ fontSizes={ fontSizes }
136
385
  />
137
386
  );
387
+ const options = screen.getAllByRole( 'radio' );
388
+ expect( options ).toHaveLength( 5 );
389
+ expect( options[ 0 ] ).toHaveTextContent( 'S' );
390
+ expect( options[ 0 ] ).toHaveAccessibleName( 'Small' );
391
+ expect( options[ 1 ] ).toHaveTextContent( 'M' );
392
+ expect( options[ 1 ] ).toHaveAccessibleName( 'Medium' );
393
+ expect( options[ 2 ] ).toHaveTextContent( 'L' );
394
+ expect( options[ 2 ] ).toHaveAccessibleName( 'Large' );
395
+ expect( options[ 3 ] ).toHaveTextContent( 'XL' );
396
+ expect( options[ 3 ] ).toHaveAccessibleName( 'Huge' );
397
+ expect( options[ 4 ] ).toHaveTextContent( 'XXL' );
398
+ expect( options[ 4 ] ).toHaveAccessibleName( 'Gigantosaurus' );
399
+ } );
138
400
 
139
- toggleCustomInput( true );
140
- const unitSelect = getUnitSelect();
141
- const unitLabel = getUnitLabel();
142
- const input = screen.getByLabelText( 'Custom', {
143
- selector: 'input',
144
- } );
145
-
146
- input.focus();
147
- fireEvent.change( input, { target: { value: 16 } } );
401
+ test.each( [
402
+ { value: undefined, expectedLabel: 'Size' },
403
+ { value: '12px', expectedLabel: 'Size Small' },
404
+ { value: '40px', expectedLabel: 'Size Gigantosaurus' },
405
+ ] )(
406
+ 'displays $expectedLabel as label when value is $value',
407
+ ( { value, expectedLabel } ) => {
408
+ render(
409
+ <FontSizePicker
410
+ __nextHasNoMarginBottom
411
+ fontSizes={ fontSizes }
412
+ value={ value }
413
+ />
414
+ );
415
+ expect(
416
+ screen.getByLabelText( expectedLabel )
417
+ ).toBeInTheDocument();
418
+ }
419
+ );
148
420
 
149
- expect( unitSelect ).toBeTruthy();
150
- expect( unitLabel ).toBeFalsy();
151
- expect( fontSize ).toBe( '16px' );
421
+ it( 'calls onChange when a font size is selected', async () => {
422
+ const user = userEvent.setup( {
423
+ advanceTimers: jest.advanceTimersByTime,
424
+ } );
425
+ const onChange = jest.fn();
426
+ render(
427
+ <FontSizePicker
428
+ __nextHasNoMarginBottom
429
+ fontSizes={ fontSizes }
430
+ onChange={ onChange }
431
+ />
432
+ );
433
+ await user.click( screen.getByRole( 'radio', { name: 'Medium' } ) );
434
+ expect( onChange ).toHaveBeenCalledTimes( 1 );
435
+ expect( onChange ).toHaveBeenCalledWith( '16px', fontSizes[ 1 ] );
152
436
  } );
437
+
438
+ commonToggleGroupTests( fontSizes );
439
+ commonTests( fontSizes );
153
440
  } );
154
- describe( 'renders different control', () => {
155
- const options = [
441
+
442
+ describe( 'with 5 heterogeneous font sizes', () => {
443
+ const fontSizes = [
156
444
  {
157
- name: 'Small',
158
445
  slug: 'small',
159
- size: '0.65rem',
446
+ name: 'Small',
447
+ size: '12px',
160
448
  },
161
449
  {
162
- name: 'Medium',
163
450
  slug: 'medium',
164
- size: '1.125rem',
451
+ name: 'Medium',
452
+ size: '1em',
165
453
  },
166
454
  {
167
- name: 'Large',
168
455
  slug: 'large',
169
- size: '1.7rem',
456
+ name: 'Large',
457
+ size: '2rem',
458
+ },
459
+ {
460
+ slug: 'x-large',
461
+ name: 'Extra Large',
462
+ size: 'clamp(1.75rem, 3vw, 2.25rem)',
170
463
  },
171
464
  ];
172
- it( 'should render select control when we have more than five font sizes', () => {
173
- const extraOptions = [
174
- {
175
- name: 'Extra Large',
176
- slug: 'extra-large',
177
- size: '1.95rem',
178
- },
179
- {
180
- name: 'Extra Extra Large',
181
- slug: 'extra-extra-large',
182
- size: '2.5rem',
183
- },
184
- {
185
- name: 'Huge',
186
- slug: 'huge',
187
- size: '2.8rem',
188
- },
189
- ];
190
- const fontSizes = [ ...options, ...extraOptions ];
465
+
466
+ it( 'displays a toggle group control with t-shirt sizes', () => {
191
467
  render(
192
468
  <FontSizePicker
193
- fontSizes={ fontSizes }
194
- value={ fontSizes[ 0 ].size }
195
469
  __nextHasNoMarginBottom
470
+ fontSizes={ fontSizes }
196
471
  />
197
472
  );
198
- // Trigger click to open the select menu and take into account
199
- // the two extra options (default, custom);
200
- fireEvent.click(
201
- screen.getByLabelText( 'Font size', { selector: 'button' } )
202
- );
203
- const element = screen.getAllByRole( 'option' );
204
- expect( element ).toHaveLength( fontSizes.length + 2 );
473
+ const options = screen.getAllByRole( 'radio' );
474
+ expect( options ).toHaveLength( 4 );
475
+ expect( options[ 0 ] ).toHaveTextContent( 'S' );
476
+ expect( options[ 0 ] ).toHaveAccessibleName( 'Small' );
477
+ expect( options[ 1 ] ).toHaveTextContent( 'M' );
478
+ expect( options[ 1 ] ).toHaveAccessibleName( 'Medium' );
479
+ expect( options[ 2 ] ).toHaveTextContent( 'L' );
480
+ expect( options[ 2 ] ).toHaveAccessibleName( 'Large' );
481
+ expect( options[ 3 ] ).toHaveTextContent( 'XL' );
482
+ expect( options[ 3 ] ).toHaveAccessibleName( 'Extra Large' );
205
483
  } );
206
- describe( 'segmented control', () => {
207
- it( 'should use t-shirt labels for simple css values', () => {
208
- const fontSizes = [ ...options ];
484
+
485
+ test.each( [
486
+ { value: undefined, expectedLabel: 'Size' },
487
+ { value: '12px', expectedLabel: 'Size Small' },
488
+ { value: '1em', expectedLabel: 'Size Medium' },
489
+ { value: '2rem', expectedLabel: 'Size Large' },
490
+ {
491
+ value: 'clamp(1.75rem, 3vw, 2.25rem)',
492
+ expectedLabel: 'Size Extra Large',
493
+ },
494
+ ] )(
495
+ 'displays $expectedLabel as label when value is $value',
496
+ ( { value, expectedLabel } ) => {
209
497
  render(
210
498
  <FontSizePicker
211
- fontSizes={ fontSizes }
212
- value={ fontSizes[ 0 ].size }
213
499
  __nextHasNoMarginBottom
500
+ fontSizes={ fontSizes }
501
+ value={ value }
214
502
  />
215
503
  );
216
- const element = screen.getByLabelText( 'Large' );
217
- expect( element ).toBeInTheDocument();
218
- expect( element.children[ 0 ] ).toHaveTextContent( 'L' );
219
- } );
220
- it( 'should use incremental sequence of t-shirt sizes as labels if we have complex css', () => {
221
- const fontSizes = [
222
- ...options,
223
- {
224
- name: 'Extra Large',
225
- slug: 'extra-large',
226
- size: 'clamp(1.75rem, 3vw, 2.25rem)',
227
- },
228
- ];
504
+ expect(
505
+ screen.getByLabelText( expectedLabel )
506
+ ).toBeInTheDocument();
507
+ }
508
+ );
509
+
510
+ test.each( [
511
+ { radio: 'Small', expectedArguments: [ '12px', fontSizes[ 0 ] ] },
512
+ { radio: 'Medium', expectedArguments: [ '1em', fontSizes[ 1 ] ] },
513
+ { radio: 'Large', expectedArguments: [ '2rem', fontSizes[ 2 ] ] },
514
+ {
515
+ radio: 'Extra Large',
516
+ expectedArguments: [
517
+ 'clamp(1.75rem, 3vw, 2.25rem)',
518
+ fontSizes[ 3 ],
519
+ ],
520
+ },
521
+ ] )(
522
+ 'calls onChange( $expectedArguments ) when $radio is selected',
523
+ async ( { radio, expectedArguments } ) => {
524
+ const user = userEvent.setup( {
525
+ advanceTimers: jest.advanceTimersByTime,
526
+ } );
527
+ const onChange = jest.fn();
229
528
  render(
230
529
  <FontSizePicker
231
- fontSizes={ fontSizes }
232
- value={ fontSizes[ 0 ].size }
233
530
  __nextHasNoMarginBottom
531
+ fontSizes={ fontSizes }
532
+ onChange={ onChange }
234
533
  />
235
534
  );
236
- const largeElement = screen.getByLabelText( 'Large' );
237
- expect( largeElement ).toBeInTheDocument();
238
- expect( largeElement ).toHaveTextContent( 'L' );
239
-
240
- const extraLargeElement =
241
- screen.getByLabelText( 'Extra Large' );
242
- expect( extraLargeElement ).toBeInTheDocument();
243
- expect( extraLargeElement.children[ 0 ] ).toHaveTextContent(
244
- 'XL'
535
+ await user.click(
536
+ screen.getByRole( 'radio', { name: radio } )
537
+ );
538
+ expect( onChange ).toHaveBeenCalledTimes( 1 );
539
+ expect( onChange ).toHaveBeenCalledWith( ...expectedArguments );
540
+ }
541
+ );
542
+
543
+ commonToggleGroupTests( fontSizes );
544
+ commonTests( fontSizes );
545
+ } );
546
+
547
+ function commonToggleGroupTests( fontSizes: FontSize[] ) {
548
+ it( 'defaults to M when value is 16px', () => {
549
+ render(
550
+ <FontSizePicker
551
+ __nextHasNoMarginBottom
552
+ fontSizes={ fontSizes }
553
+ value={ fontSizes[ 0 ].size }
554
+ />
555
+ );
556
+ expect(
557
+ screen.getByRole( 'radio', { checked: true } )
558
+ ).toHaveTextContent( 'S' );
559
+ } );
560
+
561
+ test.each( [ undefined, '' ] )(
562
+ 'has no selection when value is %p',
563
+ ( value ) => {
564
+ render(
565
+ <FontSizePicker
566
+ __nextHasNoMarginBottom
567
+ fontSizes={ fontSizes }
568
+ value={ value }
569
+ />
245
570
  );
571
+ expect( screen.getByRole( 'radiogroup' ) ).toBeInTheDocument();
572
+ expect(
573
+ screen.queryByRole( 'radio', { checked: true } )
574
+ ).not.toBeInTheDocument();
575
+ }
576
+ );
577
+ }
578
+
579
+ function commonSelectTests( fontSizes: FontSize[] ) {
580
+ it( 'shows custom input when Custom is selected', async () => {
581
+ const user = userEvent.setup( {
582
+ advanceTimers: jest.advanceTimersByTime,
246
583
  } );
584
+ const onChange = jest.fn();
585
+ render(
586
+ <FontSizePicker
587
+ __nextHasNoMarginBottom
588
+ fontSizes={ fontSizes }
589
+ onChange={ onChange }
590
+ />
591
+ );
592
+ await user.click(
593
+ screen.getByRole( 'button', { name: 'Font size' } )
594
+ );
595
+ await user.click(
596
+ screen.getByRole( 'option', { name: 'Custom' } )
597
+ );
598
+ expect( screen.getByLabelText( 'Custom' ) ).toBeInTheDocument();
599
+ expect( onChange ).not.toHaveBeenCalled();
247
600
  } );
248
- } );
601
+ }
602
+
603
+ function commonTests( fontSizes: FontSize[] ) {
604
+ it( 'shows custom input when value is unknown', () => {
605
+ render(
606
+ <FontSizePicker
607
+ __nextHasNoMarginBottom
608
+ fontSizes={ fontSizes }
609
+ value="3px"
610
+ />
611
+ );
612
+ expect( screen.getByLabelText( 'Custom' ) ).toBeInTheDocument();
613
+ } );
614
+
615
+ it( 'allows custom values by default', async () => {
616
+ const user = userEvent.setup( {
617
+ advanceTimers: jest.advanceTimersByTime,
618
+ } );
619
+ const onChange = jest.fn();
620
+ render(
621
+ <FontSizePicker
622
+ __nextHasNoMarginBottom
623
+ fontSizes={ fontSizes }
624
+ onChange={ onChange }
625
+ />
626
+ );
627
+ await user.click(
628
+ screen.getByRole( 'button', { name: 'Set custom size' } )
629
+ );
630
+ await user.type( screen.getByLabelText( 'Custom' ), '80' );
631
+ expect( onChange ).toHaveBeenCalledTimes( 2 ); // Once per keystroke.
632
+ expect( onChange ).toHaveBeenCalledWith( '80px' );
633
+ } );
634
+
635
+ it( 'does not allow custom values when disableCustomFontSizes is set', () => {
636
+ render(
637
+ <FontSizePicker
638
+ __nextHasNoMarginBottom
639
+ fontSizes={ fontSizes }
640
+ disableCustomFontSizes
641
+ />
642
+ );
643
+ expect(
644
+ screen.queryByRole( 'button', { name: 'Set custom size' } )
645
+ ).not.toBeInTheDocument();
646
+ } );
647
+
648
+ it( 'does not display a slider by default', async () => {
649
+ const user = userEvent.setup( {
650
+ advanceTimers: jest.advanceTimersByTime,
651
+ } );
652
+ render(
653
+ <FontSizePicker
654
+ __nextHasNoMarginBottom
655
+ fontSizes={ fontSizes }
656
+ />
657
+ );
658
+ await user.click(
659
+ screen.getByRole( 'button', { name: 'Set custom size' } )
660
+ );
661
+ expect(
662
+ screen.queryByLabelText( 'Custom Size' )
663
+ ).not.toBeInTheDocument();
664
+ } );
665
+
666
+ it( 'allows a slider to be used when withSlider is set', async () => {
667
+ const user = userEvent.setup( {
668
+ advanceTimers: jest.advanceTimersByTime,
669
+ } );
670
+ const onChange = jest.fn();
671
+ render(
672
+ <FontSizePicker
673
+ __nextHasNoMarginBottom
674
+ fontSizes={ fontSizes }
675
+ withSlider
676
+ onChange={ onChange }
677
+ />
678
+ );
679
+ await user.click(
680
+ screen.getByRole( 'button', { name: 'Set custom size' } )
681
+ );
682
+ const sliderInput = screen.getByLabelText( 'Custom Size' );
683
+ fireEvent.change( sliderInput, {
684
+ target: { value: 80 },
685
+ } );
686
+ expect( onChange ).toHaveBeenCalledTimes( 1 );
687
+ expect( onChange ).toHaveBeenCalledWith( '80px' );
688
+ } );
689
+
690
+ it( 'allows reset by default', async () => {
691
+ const user = userEvent.setup( {
692
+ advanceTimers: jest.advanceTimersByTime,
693
+ } );
694
+ const onChange = jest.fn();
695
+ render(
696
+ <FontSizePicker
697
+ __nextHasNoMarginBottom
698
+ fontSizes={ fontSizes }
699
+ value={ fontSizes[ 0 ].size }
700
+ onChange={ onChange }
701
+ />
702
+ );
703
+ await user.click(
704
+ screen.getByRole( 'button', { name: 'Set custom size' } )
705
+ );
706
+ await user.click( screen.getByRole( 'button', { name: 'Reset' } ) );
707
+ expect( onChange ).toHaveBeenCalledTimes( 1 );
708
+ expect( onChange ).toHaveBeenCalledWith( undefined );
709
+ } );
710
+
711
+ it( 'does not allow reset when withReset is false', async () => {
712
+ const user = userEvent.setup( {
713
+ advanceTimers: jest.advanceTimersByTime,
714
+ } );
715
+ render(
716
+ <FontSizePicker
717
+ __nextHasNoMarginBottom
718
+ fontSizes={ fontSizes }
719
+ value={ fontSizes[ 0 ].size }
720
+ withReset={ false }
721
+ />
722
+ );
723
+ await user.click(
724
+ screen.getByRole( 'button', { name: 'Set custom size' } )
725
+ );
726
+ expect(
727
+ screen.queryByRole( 'button', { name: 'Reset' } )
728
+ ).not.toBeInTheDocument();
729
+ } );
730
+ }
249
731
  } );