@wordpress/components 25.7.0 → 25.8.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 (607) hide show
  1. package/CHANGELOG.md +55 -1
  2. package/build/animation/index.js +6 -0
  3. package/build/animation/index.js.map +1 -1
  4. package/build/border-control/border-control-dropdown/component.js +1 -1
  5. package/build/border-control/border-control-dropdown/component.js.map +1 -1
  6. package/build/border-control/styles.js +20 -20
  7. package/build/border-control/styles.js.map +1 -1
  8. package/build/box-control/unit-control.js +1 -1
  9. package/build/box-control/unit-control.js.map +1 -1
  10. package/build/button/index.js +9 -1
  11. package/build/button/index.js.map +1 -1
  12. package/build/button/types.js.map +1 -1
  13. package/build/circular-option-picker/circular-option-picker-actions.js +53 -0
  14. package/build/circular-option-picker/circular-option-picker-actions.js.map +1 -0
  15. package/build/circular-option-picker/circular-option-picker-context.js +14 -0
  16. package/build/circular-option-picker/circular-option-picker-context.js.map +1 -0
  17. package/build/circular-option-picker/circular-option-picker-option-group.js +26 -0
  18. package/build/circular-option-picker/circular-option-picker-option-group.js.map +1 -0
  19. package/build/circular-option-picker/circular-option-picker-option.js +122 -0
  20. package/build/circular-option-picker/circular-option-picker-option.js.map +1 -0
  21. package/build/circular-option-picker/circular-option-picker.js +172 -0
  22. package/build/circular-option-picker/circular-option-picker.js.map +1 -0
  23. package/build/circular-option-picker/index.js +29 -137
  24. package/build/circular-option-picker/index.js.map +1 -1
  25. package/build/circular-option-picker/types.js.map +1 -1
  26. package/build/color-palette/index.js +58 -19
  27. package/build/color-palette/index.js.map +1 -1
  28. package/build/color-palette/types.js.map +1 -1
  29. package/build/combobox-control/index.js +0 -3
  30. package/build/combobox-control/index.js.map +1 -1
  31. package/build/composite/index.js.map +1 -1
  32. package/build/custom-gradient-picker/gradient-bar/control-points.js.map +1 -1
  33. package/build/date-time/time/timezone.js +1 -1
  34. package/build/date-time/time/timezone.js.map +1 -1
  35. package/build/dropdown/index.js +11 -23
  36. package/build/dropdown/index.js.map +1 -1
  37. package/build/dropdown/types.js.map +1 -1
  38. package/build/dropdown-menu/index.js +7 -1
  39. package/build/dropdown-menu/index.js.map +1 -1
  40. package/build/dropdown-menu/types.js.map +1 -1
  41. package/build/dropdown-menu-v2/styles.js +16 -16
  42. package/build/dropdown-menu-v2/styles.js.map +1 -1
  43. package/build/duotone-picker/color-list-picker/index.js +18 -3
  44. package/build/duotone-picker/color-list-picker/index.js.map +1 -1
  45. package/build/duotone-picker/duotone-picker.js +33 -1
  46. package/build/duotone-picker/duotone-picker.js.map +1 -1
  47. package/build/duotone-picker/types.js.map +1 -1
  48. package/build/focusable-iframe/index.js +0 -4
  49. package/build/focusable-iframe/index.js.map +1 -1
  50. package/build/focusable-iframe/types.js +6 -0
  51. package/build/focusable-iframe/types.js.map +1 -0
  52. package/build/form-token-field/index.js +6 -2
  53. package/build/form-token-field/index.js.map +1 -1
  54. package/build/form-token-field/types.js.map +1 -1
  55. package/build/gradient-picker/index.js +57 -15
  56. package/build/gradient-picker/index.js.map +1 -1
  57. package/build/gradient-picker/types.js.map +1 -1
  58. package/build/higher-order/navigate-regions/index.js.map +1 -1
  59. package/build/higher-order/with-focus-outside/index.js +1 -2
  60. package/build/higher-order/with-focus-outside/index.js.map +1 -1
  61. package/build/higher-order/with-spoken-messages/index.js.map +1 -1
  62. package/build/index.js +6 -0
  63. package/build/index.js.map +1 -1
  64. package/build/input-control/styles/input-control-styles.js +22 -22
  65. package/build/input-control/styles/input-control-styles.js.map +1 -1
  66. package/build/mobile/bottom-sheet/index.native.js +1 -0
  67. package/build/mobile/bottom-sheet/index.native.js.map +1 -1
  68. package/build/mobile/global-styles-context/index.native.js.map +1 -1
  69. package/build/navigation/use-navigation-tree-nodes.js.map +1 -1
  70. package/build/notice/index.js +19 -7
  71. package/build/notice/index.js.map +1 -1
  72. package/build/palette-edit/styles.js +10 -10
  73. package/build/palette-edit/styles.js.map +1 -1
  74. package/build/placeholder/index.js.map +1 -1
  75. package/build/popover/index.js +37 -83
  76. package/build/popover/index.js.map +1 -1
  77. package/build/popover/types.js.map +1 -1
  78. package/build/popover/utils.js +9 -41
  79. package/build/popover/utils.js.map +1 -1
  80. package/build/search-control/index.js +12 -3
  81. package/build/search-control/index.js.map +1 -1
  82. package/build/search-control/types.js.map +1 -1
  83. package/build/text/styles.js +7 -7
  84. package/build/text/styles.js.map +1 -1
  85. package/build/toggle-group-control/toggle-group-control/as-button-group.js +30 -45
  86. package/build/toggle-group-control/toggle-group-control/as-button-group.js.map +1 -1
  87. package/build/toggle-group-control/toggle-group-control/as-radio-group.js +40 -41
  88. package/build/toggle-group-control/toggle-group-control/as-radio-group.js.map +1 -1
  89. package/build/toggle-group-control/toggle-group-control/component.js +10 -5
  90. package/build/toggle-group-control/toggle-group-control/component.js.map +1 -1
  91. package/build/toggle-group-control/toggle-group-control/styles.js +9 -16
  92. package/build/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  93. package/build/toggle-group-control/toggle-group-control/utils.js +44 -0
  94. package/build/toggle-group-control/toggle-group-control/utils.js.map +1 -0
  95. package/build/toggle-group-control/toggle-group-control-option-base/component.js +36 -17
  96. package/build/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -1
  97. package/build/toggle-group-control/toggle-group-control-option-base/styles.js +10 -8
  98. package/build/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  99. package/build/toggle-group-control/types.js.map +1 -1
  100. package/build/toolbar/toolbar/index.js +7 -1
  101. package/build/toolbar/toolbar/index.js.map +1 -1
  102. package/build/toolbar/toolbar-dropdown-menu/index.js +1 -3
  103. package/build/toolbar/toolbar-dropdown-menu/index.js.map +1 -1
  104. package/build/toolbar/toolbar-group/index.js +16 -12
  105. package/build/toolbar/toolbar-group/index.js.map +1 -1
  106. package/build/toolbar/toolbar-group/toolbar-group-collapsed.js +0 -2
  107. package/build/toolbar/toolbar-group/toolbar-group-collapsed.js.map +1 -1
  108. package/build/toolbar/toolbar-group/toolbar-group-container.js +3 -1
  109. package/build/toolbar/toolbar-group/toolbar-group-container.js.map +1 -1
  110. package/build/toolbar/toolbar-group/types.js +6 -0
  111. package/build/toolbar/toolbar-group/types.js.map +1 -0
  112. package/build/toolbar/toolbar-item/index.js +1 -1
  113. package/build/toolbar/toolbar-item/index.js.map +1 -1
  114. package/build/tooltip/index.js +51 -225
  115. package/build/tooltip/index.js.map +1 -1
  116. package/build/tooltip/types.js +6 -0
  117. package/build/tooltip/types.js.map +1 -0
  118. package/build/ui/context/context-connect.js.map +1 -1
  119. package/build/ui/context/wordpress-component.js.map +1 -1
  120. package/build/unit-control/index.js.map +1 -1
  121. package/build/unit-control/styles/unit-control-styles.js +7 -7
  122. package/build/unit-control/styles/unit-control-styles.js.map +1 -1
  123. package/build/utils/colors-values.js +1 -1
  124. package/build/utils/colors-values.js.map +1 -1
  125. package/build/utils/use-deprecated-props.js.map +1 -1
  126. package/build-module/animation/index.js +1 -1
  127. package/build-module/animation/index.js.map +1 -1
  128. package/build-module/border-control/border-control-dropdown/component.js +1 -1
  129. package/build-module/border-control/border-control-dropdown/component.js.map +1 -1
  130. package/build-module/border-control/styles.js +20 -20
  131. package/build-module/border-control/styles.js.map +1 -1
  132. package/build-module/box-control/unit-control.js +1 -1
  133. package/build-module/box-control/unit-control.js.map +1 -1
  134. package/build-module/button/index.js +9 -1
  135. package/build-module/button/index.js.map +1 -1
  136. package/build-module/button/types.js.map +1 -1
  137. package/build-module/circular-option-picker/circular-option-picker-actions.js +44 -0
  138. package/build-module/circular-option-picker/circular-option-picker-actions.js.map +1 -0
  139. package/build-module/circular-option-picker/circular-option-picker-context.js +11 -0
  140. package/build-module/circular-option-picker/circular-option-picker-context.js.map +1 -0
  141. package/build-module/circular-option-picker/circular-option-picker-option-group.js +23 -0
  142. package/build-module/circular-option-picker/circular-option-picker-option-group.js.map +1 -0
  143. package/build-module/circular-option-picker/circular-option-picker-option.js +114 -0
  144. package/build-module/circular-option-picker/circular-option-picker-option.js.map +1 -0
  145. package/build-module/circular-option-picker/circular-option-picker.js +165 -0
  146. package/build-module/circular-option-picker/circular-option-picker.js.map +1 -0
  147. package/build-module/circular-option-picker/index.js +4 -132
  148. package/build-module/circular-option-picker/index.js.map +1 -1
  149. package/build-module/circular-option-picker/types.js.map +1 -1
  150. package/build-module/color-palette/index.js +58 -19
  151. package/build-module/color-palette/index.js.map +1 -1
  152. package/build-module/color-palette/types.js.map +1 -1
  153. package/build-module/combobox-control/index.js +0 -3
  154. package/build-module/combobox-control/index.js.map +1 -1
  155. package/build-module/composite/index.js +2 -0
  156. package/build-module/composite/index.js.map +1 -1
  157. package/build-module/custom-gradient-picker/gradient-bar/control-points.js.map +1 -1
  158. package/build-module/date-time/time/timezone.js +1 -1
  159. package/build-module/date-time/time/timezone.js.map +1 -1
  160. package/build-module/dropdown/index.js +12 -24
  161. package/build-module/dropdown/index.js.map +1 -1
  162. package/build-module/dropdown/types.js.map +1 -1
  163. package/build-module/dropdown-menu/index.js +7 -1
  164. package/build-module/dropdown-menu/index.js.map +1 -1
  165. package/build-module/dropdown-menu/types.js.map +1 -1
  166. package/build-module/dropdown-menu-v2/styles.js +16 -16
  167. package/build-module/dropdown-menu-v2/styles.js.map +1 -1
  168. package/build-module/duotone-picker/color-list-picker/index.js +18 -3
  169. package/build-module/duotone-picker/color-list-picker/index.js.map +1 -1
  170. package/build-module/duotone-picker/duotone-picker.js +33 -1
  171. package/build-module/duotone-picker/duotone-picker.js.map +1 -1
  172. package/build-module/duotone-picker/types.js.map +1 -1
  173. package/build-module/focusable-iframe/index.js +2 -3
  174. package/build-module/focusable-iframe/index.js.map +1 -1
  175. package/build-module/focusable-iframe/types.js +2 -0
  176. package/build-module/focusable-iframe/types.js.map +1 -0
  177. package/build-module/form-token-field/index.js +6 -2
  178. package/build-module/form-token-field/index.js.map +1 -1
  179. package/build-module/form-token-field/types.js.map +1 -1
  180. package/build-module/gradient-picker/index.js +57 -15
  181. package/build-module/gradient-picker/index.js.map +1 -1
  182. package/build-module/gradient-picker/types.js.map +1 -1
  183. package/build-module/higher-order/navigate-regions/index.js.map +1 -1
  184. package/build-module/higher-order/with-focus-outside/index.js +1 -3
  185. package/build-module/higher-order/with-focus-outside/index.js.map +1 -1
  186. package/build-module/higher-order/with-spoken-messages/index.js.map +1 -1
  187. package/build-module/index.js +1 -1
  188. package/build-module/index.js.map +1 -1
  189. package/build-module/input-control/styles/input-control-styles.js +23 -23
  190. package/build-module/input-control/styles/input-control-styles.js.map +1 -1
  191. package/build-module/mobile/bottom-sheet/index.native.js +1 -0
  192. package/build-module/mobile/bottom-sheet/index.native.js.map +1 -1
  193. package/build-module/mobile/global-styles-context/index.native.js.map +1 -1
  194. package/build-module/navigation/use-navigation-tree-nodes.js.map +1 -1
  195. package/build-module/notice/index.js +19 -7
  196. package/build-module/notice/index.js.map +1 -1
  197. package/build-module/palette-edit/styles.js +10 -10
  198. package/build-module/palette-edit/styles.js.map +1 -1
  199. package/build-module/placeholder/index.js.map +1 -1
  200. package/build-module/popover/index.js +38 -84
  201. package/build-module/popover/index.js.map +1 -1
  202. package/build-module/popover/types.js.map +1 -1
  203. package/build-module/popover/utils.js +8 -39
  204. package/build-module/popover/utils.js.map +1 -1
  205. package/build-module/search-control/index.js +12 -3
  206. package/build-module/search-control/index.js.map +1 -1
  207. package/build-module/search-control/types.js.map +1 -1
  208. package/build-module/text/styles.js +7 -7
  209. package/build-module/text/styles.js.map +1 -1
  210. package/build-module/toggle-group-control/toggle-group-control/as-button-group.js +32 -47
  211. package/build-module/toggle-group-control/toggle-group-control/as-button-group.js.map +1 -1
  212. package/build-module/toggle-group-control/toggle-group-control/as-radio-group.js +41 -42
  213. package/build-module/toggle-group-control/toggle-group-control/as-radio-group.js.map +1 -1
  214. package/build-module/toggle-group-control/toggle-group-control/component.js +10 -6
  215. package/build-module/toggle-group-control/toggle-group-control/component.js.map +1 -1
  216. package/build-module/toggle-group-control/toggle-group-control/styles.js +8 -14
  217. package/build-module/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  218. package/build-module/toggle-group-control/toggle-group-control/utils.js +42 -0
  219. package/build-module/toggle-group-control/toggle-group-control/utils.js.map +1 -0
  220. package/build-module/toggle-group-control/toggle-group-control-option-base/component.js +35 -16
  221. package/build-module/toggle-group-control/toggle-group-control-option-base/component.js.map +1 -1
  222. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js +8 -7
  223. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  224. package/build-module/toggle-group-control/types.js.map +1 -1
  225. package/build-module/toolbar/toolbar/index.js +7 -1
  226. package/build-module/toolbar/toolbar/index.js.map +1 -1
  227. package/build-module/toolbar/toolbar-dropdown-menu/index.js +5 -3
  228. package/build-module/toolbar/toolbar-dropdown-menu/index.js.map +1 -1
  229. package/build-module/toolbar/toolbar-group/index.js +15 -12
  230. package/build-module/toolbar/toolbar-group/index.js.map +1 -1
  231. package/build-module/toolbar/toolbar-group/toolbar-group-collapsed.js +0 -2
  232. package/build-module/toolbar/toolbar-group/toolbar-group-collapsed.js.map +1 -1
  233. package/build-module/toolbar/toolbar-group/toolbar-group-container.js +3 -1
  234. package/build-module/toolbar/toolbar-group/toolbar-group-container.js.map +1 -1
  235. package/build-module/toolbar/toolbar-group/types.js +2 -0
  236. package/build-module/toolbar/toolbar-group/types.js.map +1 -0
  237. package/build-module/toolbar/toolbar-item/index.js +1 -1
  238. package/build-module/toolbar/toolbar-item/index.js.map +1 -1
  239. package/build-module/tooltip/index.js +53 -224
  240. package/build-module/tooltip/index.js.map +1 -1
  241. package/build-module/tooltip/types.js +2 -0
  242. package/build-module/tooltip/types.js.map +1 -0
  243. package/build-module/ui/context/context-connect.js.map +1 -1
  244. package/build-module/ui/context/wordpress-component.js.map +1 -1
  245. package/build-module/unit-control/index.js.map +1 -1
  246. package/build-module/unit-control/styles/unit-control-styles.js +7 -7
  247. package/build-module/unit-control/styles/unit-control-styles.js.map +1 -1
  248. package/build-module/utils/colors-values.js +1 -1
  249. package/build-module/utils/colors-values.js.map +1 -1
  250. package/build-module/utils/use-deprecated-props.js.map +1 -1
  251. package/build-style/style-rtl.css +35 -63
  252. package/build-style/style.css +35 -63
  253. package/build-types/animation/index.d.ts +1 -1
  254. package/build-types/animation/index.d.ts.map +1 -1
  255. package/build-types/base-control/hooks.d.ts +1 -1
  256. package/build-types/border-box-control/border-box-control/component.d.ts +1 -1
  257. package/build-types/border-box-control/border-box-control/hook.d.ts +46 -46
  258. package/build-types/border-box-control/border-box-control-linked-button/hook.d.ts +51 -51
  259. package/build-types/border-box-control/border-box-control-split-controls/component.d.ts +1 -1
  260. package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts +46 -46
  261. package/build-types/border-box-control/border-box-control-visualizer/hook.d.ts +46 -46
  262. package/build-types/border-box-control/stories/index.story.d.ts +2 -2
  263. package/build-types/border-control/border-control/hook.d.ts +45 -45
  264. package/build-types/border-control/border-control-dropdown/hook.d.ts +45 -45
  265. package/build-types/border-control/border-control-style-picker/hook.d.ts +45 -45
  266. package/build-types/border-control/stories/index.story.d.ts +6 -6
  267. package/build-types/box-control/styles/box-control-styles.d.ts +1 -1
  268. package/build-types/button/deprecated.d.ts +16 -22
  269. package/build-types/button/deprecated.d.ts.map +1 -1
  270. package/build-types/button/index.d.ts.map +1 -1
  271. package/build-types/button/types.d.ts +0 -4
  272. package/build-types/button/types.d.ts.map +1 -1
  273. package/build-types/card/card/hook.d.ts +46 -46
  274. package/build-types/card/card-body/hook.d.ts +46 -46
  275. package/build-types/card/card-divider/hook.d.ts +47 -47
  276. package/build-types/card/card-footer/hook.d.ts +46 -46
  277. package/build-types/card/card-header/hook.d.ts +46 -46
  278. package/build-types/card/card-media/hook.d.ts +46 -46
  279. package/build-types/card/stories/index.story.d.ts +2 -2
  280. package/build-types/circular-option-picker/circular-option-picker-actions.d.ts +7 -0
  281. package/build-types/circular-option-picker/circular-option-picker-actions.d.ts.map +1 -0
  282. package/build-types/circular-option-picker/circular-option-picker-context.d.ts +7 -0
  283. package/build-types/circular-option-picker/circular-option-picker-context.d.ts.map +1 -0
  284. package/build-types/circular-option-picker/circular-option-picker-option-group.d.ts +7 -0
  285. package/build-types/circular-option-picker/circular-option-picker-option-group.d.ts.map +1 -0
  286. package/build-types/circular-option-picker/circular-option-picker-option.d.ts +4 -0
  287. package/build-types/circular-option-picker/circular-option-picker-option.d.ts.map +1 -0
  288. package/build-types/circular-option-picker/circular-option-picker.d.ts +11 -0
  289. package/build-types/circular-option-picker/circular-option-picker.d.ts.map +1 -0
  290. package/build-types/circular-option-picker/index.d.ts +5 -56
  291. package/build-types/circular-option-picker/index.d.ts.map +1 -1
  292. package/build-types/circular-option-picker/stories/index.story.d.ts +3 -1
  293. package/build-types/circular-option-picker/stories/index.story.d.ts.map +1 -1
  294. package/build-types/circular-option-picker/test/index.d.ts +2 -0
  295. package/build-types/circular-option-picker/test/index.d.ts.map +1 -0
  296. package/build-types/circular-option-picker/types.d.ts +53 -1
  297. package/build-types/circular-option-picker/types.d.ts.map +1 -1
  298. package/build-types/color-palette/index.d.ts +3 -19
  299. package/build-types/color-palette/index.d.ts.map +1 -1
  300. package/build-types/color-palette/stories/index.story.d.ts +3 -36
  301. package/build-types/color-palette/stories/index.story.d.ts.map +1 -1
  302. package/build-types/color-palette/styles.d.ts +1 -1
  303. package/build-types/color-palette/types.d.ts +31 -1
  304. package/build-types/color-palette/types.d.ts.map +1 -1
  305. package/build-types/color-picker/component.d.ts +1 -1
  306. package/build-types/color-picker/stories/index.story.d.ts +1 -1
  307. package/build-types/color-picker/styles.d.ts +6 -6
  308. package/build-types/combobox-control/index.d.ts.map +1 -1
  309. package/build-types/combobox-control/stories/index.story.d.ts +2 -2
  310. package/build-types/composite/index.d.ts +14 -1
  311. package/build-types/composite/index.d.ts.map +1 -1
  312. package/build-types/custom-gradient-picker/styles/custom-gradient-picker-styles.d.ts +2 -2
  313. package/build-types/date-time/date/styles.d.ts +3 -3
  314. package/build-types/date-time/date-time/styles.d.ts +2 -2
  315. package/build-types/date-time/time/styles.d.ts +12 -12
  316. package/build-types/dropdown/index.d.ts.map +1 -1
  317. package/build-types/dropdown/stories/index.story.d.ts.map +1 -1
  318. package/build-types/dropdown/types.d.ts +12 -4
  319. package/build-types/dropdown/types.d.ts.map +1 -1
  320. package/build-types/dropdown-menu/index.d.ts.map +1 -1
  321. package/build-types/dropdown-menu/stories/index.story.d.ts.map +1 -1
  322. package/build-types/dropdown-menu/types.d.ts +22 -5
  323. package/build-types/dropdown-menu/types.d.ts.map +1 -1
  324. package/build-types/duotone-picker/color-list-picker/index.d.ts.map +1 -1
  325. package/build-types/duotone-picker/duotone-picker.d.ts +1 -1
  326. package/build-types/duotone-picker/duotone-picker.d.ts.map +1 -1
  327. package/build-types/duotone-picker/types.d.ts +31 -1
  328. package/build-types/duotone-picker/types.d.ts.map +1 -1
  329. package/build-types/elevation/hook.d.ts +46 -46
  330. package/build-types/external-link/styles/external-link-styles.d.ts +1 -1
  331. package/build-types/flex/flex/hook.d.ts +46 -46
  332. package/build-types/flex/flex-block/hook.d.ts +46 -46
  333. package/build-types/flex/flex-item/hook.d.ts +46 -46
  334. package/build-types/focal-point-picker/stories/index.story.d.ts +8 -8
  335. package/build-types/focal-point-picker/styles/focal-point-picker-style.d.ts +1 -1
  336. package/build-types/focusable-iframe/index.d.ts +4 -5
  337. package/build-types/focusable-iframe/index.d.ts.map +1 -1
  338. package/build-types/focusable-iframe/types.d.ts +8 -0
  339. package/build-types/focusable-iframe/types.d.ts.map +1 -0
  340. package/build-types/font-size-picker/styles.d.ts +2 -2
  341. package/build-types/form-token-field/index.d.ts.map +1 -1
  342. package/build-types/form-token-field/types.d.ts +6 -0
  343. package/build-types/form-token-field/types.d.ts.map +1 -1
  344. package/build-types/gradient-picker/index.d.ts +1 -1
  345. package/build-types/gradient-picker/index.d.ts.map +1 -1
  346. package/build-types/gradient-picker/stories/index.story.d.ts +3 -36
  347. package/build-types/gradient-picker/stories/index.story.d.ts.map +1 -1
  348. package/build-types/gradient-picker/types.d.ts +31 -1
  349. package/build-types/gradient-picker/types.d.ts.map +1 -1
  350. package/build-types/grid/hook.d.ts +46 -46
  351. package/build-types/h-stack/component.d.ts +1 -1
  352. package/build-types/h-stack/hook.d.ts +46 -46
  353. package/build-types/heading/hook.d.ts +45 -45
  354. package/build-types/higher-order/navigate-regions/index.d.ts.map +1 -1
  355. package/build-types/higher-order/with-focus-outside/index.d.ts +1 -0
  356. package/build-types/higher-order/with-focus-outside/index.d.ts.map +1 -1
  357. package/build-types/higher-order/with-focus-outside/test/index.d.ts +2 -0
  358. package/build-types/higher-order/with-focus-outside/test/index.d.ts.map +1 -0
  359. package/build-types/higher-order/with-spoken-messages/index.d.ts.map +1 -1
  360. package/build-types/index.d.ts +1 -1
  361. package/build-types/index.d.ts.map +1 -1
  362. package/build-types/isolated-event-container/test/index.d.ts +2 -0
  363. package/build-types/isolated-event-container/test/index.d.ts.map +1 -0
  364. package/build-types/item-group/item/hook.d.ts +46 -46
  365. package/build-types/item-group/item-group/hook.d.ts +46 -46
  366. package/build-types/menu-item/index.d.ts +1 -1
  367. package/build-types/menu-item/stories/index.story.d.ts +4 -4
  368. package/build-types/navigable-container/menu.d.ts +1 -1
  369. package/build-types/navigation/back-button/index.d.ts +1 -1
  370. package/build-types/navigation/styles/navigation-styles.d.ts +5 -3
  371. package/build-types/navigation/styles/navigation-styles.d.ts.map +1 -1
  372. package/build-types/navigator/navigator-back-button/component.d.ts +2 -3
  373. package/build-types/navigator/navigator-back-button/component.d.ts.map +1 -1
  374. package/build-types/navigator/navigator-back-button/hook.d.ts +53 -54
  375. package/build-types/navigator/navigator-back-button/hook.d.ts.map +1 -1
  376. package/build-types/navigator/navigator-button/component.d.ts +2 -3
  377. package/build-types/navigator/navigator-button/component.d.ts.map +1 -1
  378. package/build-types/navigator/navigator-button/hook.d.ts +53 -54
  379. package/build-types/navigator/navigator-button/hook.d.ts.map +1 -1
  380. package/build-types/navigator/navigator-to-parent-button/component.d.ts +2 -3
  381. package/build-types/navigator/navigator-to-parent-button/component.d.ts.map +1 -1
  382. package/build-types/notice/index.d.ts.map +1 -1
  383. package/build-types/number-control/index.d.ts +3 -3
  384. package/build-types/number-control/stories/index.story.d.ts +3 -3
  385. package/build-types/palette-edit/styles.d.ts +4 -4
  386. package/build-types/palette-edit/styles.d.ts.map +1 -1
  387. package/build-types/placeholder/index.d.ts.map +1 -1
  388. package/build-types/popover/index.d.ts +1 -1
  389. package/build-types/popover/index.d.ts.map +1 -1
  390. package/build-types/popover/overlay-middlewares.d.ts +1 -1
  391. package/build-types/popover/stories/e2e/index.story.d.ts +1 -1
  392. package/build-types/popover/types.d.ts +0 -4
  393. package/build-types/popover/types.d.ts.map +1 -1
  394. package/build-types/popover/utils.d.ts +2 -6
  395. package/build-types/popover/utils.d.ts.map +1 -1
  396. package/build-types/range-control/index.d.ts +1 -1
  397. package/build-types/range-control/styles/range-control-styles.d.ts +3 -3
  398. package/build-types/resizable-box/index.d.ts +1 -1
  399. package/build-types/resizable-box/resize-tooltip/index.d.ts +1 -1
  400. package/build-types/resizable-box/resize-tooltip/label.d.ts +1 -1
  401. package/build-types/resizable-box/stories/index.story.d.ts +2 -2
  402. package/build-types/scrollable/hook.d.ts +46 -46
  403. package/build-types/search-control/index.d.ts +4 -2
  404. package/build-types/search-control/index.d.ts.map +1 -1
  405. package/build-types/search-control/stories/index.story.d.ts +8 -4
  406. package/build-types/search-control/stories/index.story.d.ts.map +1 -1
  407. package/build-types/search-control/types.d.ts +12 -0
  408. package/build-types/search-control/types.d.ts.map +1 -1
  409. package/build-types/spacer/hook.d.ts +46 -46
  410. package/build-types/spinner/index.d.ts +1 -1
  411. package/build-types/surface/hook.d.ts +46 -46
  412. package/build-types/text/hook.d.ts +46 -46
  413. package/build-types/text/styles.d.ts.map +1 -1
  414. package/build-types/text-control/index.d.ts +3 -3
  415. package/build-types/toggle-control/stories/index.story.d.ts +2 -2
  416. package/build-types/toggle-group-control/toggle-group-control/as-button-group.d.ts +2 -4
  417. package/build-types/toggle-group-control/toggle-group-control/as-button-group.d.ts.map +1 -1
  418. package/build-types/toggle-group-control/toggle-group-control/as-radio-group.d.ts +2 -4
  419. package/build-types/toggle-group-control/toggle-group-control/as-radio-group.d.ts.map +1 -1
  420. package/build-types/toggle-group-control/toggle-group-control/component.d.ts +2 -2
  421. package/build-types/toggle-group-control/toggle-group-control/component.d.ts.map +1 -1
  422. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts +1 -5
  423. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts.map +1 -1
  424. package/build-types/toggle-group-control/toggle-group-control/utils.d.ts +18 -0
  425. package/build-types/toggle-group-control/toggle-group-control/utils.d.ts.map +1 -0
  426. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts +1 -1
  427. package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts +5 -1
  428. package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts.map +1 -1
  429. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts +1 -0
  430. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts.map +1 -1
  431. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts +1 -1
  432. package/build-types/toggle-group-control/types.d.ts +13 -24
  433. package/build-types/toggle-group-control/types.d.ts.map +1 -1
  434. package/build-types/toolbar/stories/index.story.d.ts.map +1 -1
  435. package/build-types/toolbar/toolbar/index.d.ts.map +1 -1
  436. package/build-types/toolbar/toolbar-button/index.d.ts +16 -22
  437. package/build-types/toolbar/toolbar-button/index.d.ts.map +1 -1
  438. package/build-types/toolbar/toolbar-dropdown-menu/index.d.ts +3 -1
  439. package/build-types/toolbar/toolbar-dropdown-menu/index.d.ts.map +1 -1
  440. package/build-types/toolbar/toolbar-group/index.d.ts +10 -14
  441. package/build-types/toolbar/toolbar-group/index.d.ts.map +1 -1
  442. package/build-types/toolbar/toolbar-group/toolbar-group-collapsed.d.ts +3 -5
  443. package/build-types/toolbar/toolbar-group/toolbar-group-collapsed.d.ts.map +1 -1
  444. package/build-types/toolbar/toolbar-group/toolbar-group-container.d.ts +7 -5
  445. package/build-types/toolbar/toolbar-group/toolbar-group-container.d.ts.map +1 -1
  446. package/build-types/toolbar/toolbar-group/types.d.ts +77 -0
  447. package/build-types/toolbar/toolbar-group/types.d.ts.map +1 -0
  448. package/build-types/toolbar/toolbar-item/index.d.ts.map +1 -1
  449. package/build-types/tools-panel/tools-panel/hook.d.ts +46 -46
  450. package/build-types/tools-panel/tools-panel-header/hook.d.ts +46 -46
  451. package/build-types/tools-panel/tools-panel-item/hook.d.ts +46 -46
  452. package/build-types/tooltip/index.d.ts +8 -5
  453. package/build-types/tooltip/index.d.ts.map +1 -1
  454. package/build-types/tooltip/stories/index.story.d.ts +13 -0
  455. package/build-types/tooltip/stories/index.story.d.ts.map +1 -0
  456. package/build-types/tooltip/test/index.d.ts +2 -0
  457. package/build-types/tooltip/test/index.d.ts.map +1 -0
  458. package/build-types/tooltip/test/utils/index.d.ts +11 -0
  459. package/build-types/tooltip/test/utils/index.d.ts.map +1 -0
  460. package/build-types/tooltip/types.d.ts +61 -0
  461. package/build-types/tooltip/types.d.ts.map +1 -0
  462. package/build-types/truncate/hook.d.ts +46 -46
  463. package/build-types/ui/tooltip/content.d.ts +1 -1
  464. package/build-types/unit-control/index.d.ts +1 -1
  465. package/build-types/unit-control/index.d.ts.map +1 -1
  466. package/build-types/unit-control/styles/unit-control-styles.d.ts +3 -3
  467. package/build-types/unit-control/styles/unit-control-styles.d.ts.map +1 -1
  468. package/build-types/unit-control/unit-select-control.d.ts +1 -1
  469. package/build-types/utils/use-deprecated-props.d.ts +1 -1
  470. package/build-types/v-stack/component.d.ts +1 -1
  471. package/build-types/v-stack/hook.d.ts +46 -46
  472. package/build-types/v-stack/stories/index.story.d.ts +2 -2
  473. package/package.json +19 -19
  474. package/src/animation/index.tsx +1 -0
  475. package/src/border-control/border-control/README.md +2 -2
  476. package/src/border-control/border-control-dropdown/component.tsx +1 -1
  477. package/src/border-control/styles.ts +7 -7
  478. package/src/border-control/test/index.js +79 -69
  479. package/src/box-control/unit-control.tsx +1 -1
  480. package/src/button/README.md +0 -6
  481. package/src/button/index.tsx +9 -1
  482. package/src/button/test/index.tsx +19 -0
  483. package/src/button/types.ts +0 -4
  484. package/src/circular-option-picker/README.md +14 -0
  485. package/src/circular-option-picker/circular-option-picker-actions.tsx +60 -0
  486. package/src/circular-option-picker/circular-option-picker-context.tsx +12 -0
  487. package/src/circular-option-picker/circular-option-picker-option-group.tsx +34 -0
  488. package/src/circular-option-picker/circular-option-picker-option.tsx +139 -0
  489. package/src/circular-option-picker/circular-option-picker.tsx +202 -0
  490. package/src/circular-option-picker/index.tsx +7 -174
  491. package/src/circular-option-picker/stories/index.story.tsx +34 -9
  492. package/src/circular-option-picker/style.scss +11 -7
  493. package/src/circular-option-picker/test/index.tsx +133 -0
  494. package/src/circular-option-picker/types.ts +64 -1
  495. package/src/color-palette/README.md +14 -0
  496. package/src/color-palette/index.tsx +69 -28
  497. package/src/color-palette/stories/index.story.tsx +16 -2
  498. package/src/color-palette/test/index.tsx +32 -30
  499. package/src/color-palette/types.ts +34 -1
  500. package/src/combobox-control/index.tsx +7 -5
  501. package/src/composite/{index.js → index.ts} +3 -0
  502. package/src/confirm-dialog/stories/index.story.js +13 -14
  503. package/src/confirm-dialog/test/index.js +10 -18
  504. package/src/custom-gradient-picker/gradient-bar/control-points.tsx +1 -1
  505. package/src/custom-gradient-picker/gradient-bar/test/utils.ts +5 -5
  506. package/src/date-time/time/timezone.tsx +1 -1
  507. package/src/dropdown/README.md +13 -3
  508. package/src/dropdown/index.tsx +16 -34
  509. package/src/dropdown/stories/index.story.tsx +10 -7
  510. package/src/dropdown/types.ts +12 -4
  511. package/src/dropdown-menu/README.md +18 -0
  512. package/src/dropdown-menu/index.tsx +8 -1
  513. package/src/dropdown-menu/stories/index.story.tsx +5 -0
  514. package/src/dropdown-menu/types.ts +23 -6
  515. package/src/dropdown-menu-v2/styles.ts +1 -1
  516. package/src/duotone-picker/README.md +14 -0
  517. package/src/duotone-picker/color-list-picker/index.tsx +28 -12
  518. package/src/duotone-picker/duotone-picker.tsx +33 -0
  519. package/src/duotone-picker/types.ts +34 -1
  520. package/src/focusable-iframe/{index.js → index.tsx} +7 -4
  521. package/src/focusable-iframe/types.ts +9 -0
  522. package/src/form-token-field/README.md +1 -0
  523. package/src/form-token-field/index.tsx +5 -1
  524. package/src/form-token-field/style.scss +5 -9
  525. package/src/form-token-field/test/index.tsx +36 -1
  526. package/src/form-token-field/types.ts +7 -1
  527. package/src/gradient-picker/README.md +14 -0
  528. package/src/gradient-picker/index.tsx +60 -11
  529. package/src/gradient-picker/types.ts +34 -1
  530. package/src/higher-order/navigate-regions/index.tsx +5 -6
  531. package/src/higher-order/with-filters/test/index.tsx +36 -43
  532. package/src/higher-order/with-focus-outside/{index.js → index.tsx} +8 -5
  533. package/src/higher-order/with-focus-outside/test/{index.js → index.tsx} +13 -11
  534. package/src/higher-order/with-notices/test/index.tsx +1 -1
  535. package/src/higher-order/with-spoken-messages/index.tsx +7 -8
  536. package/src/index.ts +5 -1
  537. package/src/input-control/styles/input-control-styles.tsx +2 -2
  538. package/src/isolated-event-container/test/{index.js → index.tsx} +1 -1
  539. package/src/mobile/bottom-sheet/index.native.js +1 -0
  540. package/src/mobile/global-styles-context/index.native.js +7 -8
  541. package/src/modal/test/index.tsx +107 -0
  542. package/src/navigation/use-navigation-tree-nodes.tsx +1 -1
  543. package/src/notice/index.tsx +18 -6
  544. package/src/notice/style.scss +0 -1
  545. package/src/notice/test/__snapshots__/index.tsx.snap +9 -1
  546. package/src/palette-edit/styles.js +2 -1
  547. package/src/placeholder/index.tsx +1 -0
  548. package/src/placeholder/style.scss +2 -4
  549. package/src/popover/index.tsx +47 -110
  550. package/src/popover/test/index.tsx +3 -3
  551. package/src/popover/types.ts +0 -5
  552. package/src/popover/utils.ts +19 -67
  553. package/src/search-control/README.md +7 -0
  554. package/src/search-control/index.tsx +10 -1
  555. package/src/search-control/style.scss +14 -7
  556. package/src/search-control/types.ts +12 -0
  557. package/src/tab-panel/test/index.tsx +5 -0
  558. package/src/text/styles.js +2 -1
  559. package/src/theme/README.md +5 -5
  560. package/src/toggle-group-control/test/__snapshots__/index.tsx.snap +567 -59
  561. package/src/toggle-group-control/test/index.tsx +110 -56
  562. package/src/toggle-group-control/toggle-group-control/README.md +0 -1
  563. package/src/toggle-group-control/toggle-group-control/as-button-group.tsx +39 -57
  564. package/src/toggle-group-control/toggle-group-control/as-radio-group.tsx +52 -48
  565. package/src/toggle-group-control/toggle-group-control/component.tsx +12 -6
  566. package/src/toggle-group-control/toggle-group-control/styles.ts +2 -19
  567. package/src/toggle-group-control/toggle-group-control/utils.ts +50 -0
  568. package/src/toggle-group-control/toggle-group-control-option-base/component.tsx +70 -20
  569. package/src/toggle-group-control/toggle-group-control-option-base/styles.ts +17 -3
  570. package/src/toggle-group-control/types.ts +14 -32
  571. package/src/toolbar/stories/index.story.tsx +3 -5
  572. package/src/toolbar/test/toolbar-group.tsx +13 -7
  573. package/src/toolbar/toolbar/index.tsx +9 -1
  574. package/src/toolbar/toolbar-dropdown-menu/{index.js → index.tsx} +11 -4
  575. package/src/toolbar/toolbar-group/README.md +2 -2
  576. package/src/toolbar/toolbar-group/{index.js → index.tsx} +19 -14
  577. package/src/toolbar/toolbar-group/{toolbar-group-collapsed.js → toolbar-group-collapsed.tsx} +10 -4
  578. package/src/toolbar/toolbar-group/toolbar-group-container.tsx +16 -0
  579. package/src/toolbar/toolbar-group/types.ts +92 -0
  580. package/src/toolbar/toolbar-item/index.tsx +3 -1
  581. package/src/tooltip/README.md +31 -28
  582. package/src/tooltip/index.tsx +106 -0
  583. package/src/tooltip/stories/index.story.tsx +59 -0
  584. package/src/tooltip/style.scss +2 -27
  585. package/src/tooltip/test/index.tsx +335 -0
  586. package/src/tooltip/test/utils/index.tsx +20 -0
  587. package/src/tooltip/types.ts +61 -0
  588. package/src/ui/context/context-connect.ts +3 -3
  589. package/src/ui/context/wordpress-component.ts +4 -4
  590. package/src/unit-control/index.tsx +9 -4
  591. package/src/unit-control/styles/unit-control-styles.ts +3 -1
  592. package/src/unit-control/test/utils.ts +1 -1
  593. package/src/utils/colors-values.js +1 -1
  594. package/src/utils/use-deprecated-props.ts +1 -1
  595. package/tsconfig.tsbuildinfo +1 -1
  596. package/build/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js +0 -78
  597. package/build/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js.map +0 -1
  598. package/build-module/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js +0 -76
  599. package/build-module/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js.map +0 -1
  600. package/build-types/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.d.ts +0 -9
  601. package/build-types/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.d.ts.map +0 -1
  602. package/src/color-palette/test/__snapshots__/index.tsx.snap +0 -288
  603. package/src/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.tsx +0 -84
  604. package/src/toolbar/toolbar-group/toolbar-group-container.js +0 -8
  605. package/src/tooltip/index.js +0 -293
  606. package/src/tooltip/stories/index.story.js +0 -85
  607. package/src/tooltip/test/index.js +0 -323
@@ -7,50 +7,76 @@ import userEvent from '@testing-library/user-event';
7
7
  /**
8
8
  * WordPress dependencies
9
9
  */
10
+ import { useState } from '@wordpress/element';
10
11
  import { formatLowercase, formatUppercase } from '@wordpress/icons';
11
12
 
12
13
  /**
13
14
  * Internal dependencies
14
15
  */
16
+ import Button from '../../button';
15
17
  import {
16
18
  ToggleGroupControl,
17
19
  ToggleGroupControlOption,
18
20
  ToggleGroupControlOptionIcon,
19
21
  } from '../index';
22
+ import type { ToggleGroupControlProps } from '../types';
23
+ import cleanupTooltip from '../../tooltip/test/utils';
20
24
 
21
- function getWrappingPopoverElement( element: HTMLElement ) {
22
- return element.closest( '.components-popover' );
23
- }
25
+ const ControlledToggleGroupControl = ( {
26
+ value: valueProp,
27
+ onChange,
28
+ ...props
29
+ }: ToggleGroupControlProps ) => {
30
+ const [ value, setValue ] = useState( valueProp );
24
31
 
25
- describe( 'ToggleGroupControl', () => {
26
- const options = (
32
+ return (
27
33
  <>
28
- <ToggleGroupControlOption value="rigas" label="R" />
29
- <ToggleGroupControlOption value="jack" label="J" />
30
- </>
31
- );
32
- const optionsWithTooltip = (
33
- <>
34
- <ToggleGroupControlOption
35
- value="gnocchi"
36
- label="Delicious Gnocchi"
37
- aria-label="Click for Delicious Gnocchi"
38
- showTooltip={ true }
39
- />
40
- <ToggleGroupControlOption
41
- value="caponata"
42
- label="Sumptuous Caponata"
43
- aria-label="Click for Sumptuous Caponata"
34
+ <ToggleGroupControl
35
+ { ...props }
36
+ onChange={ ( ...changeArgs ) => {
37
+ setValue( ...changeArgs );
38
+ onChange?.( ...changeArgs );
39
+ } }
40
+ value={ value }
44
41
  />
42
+ <Button onClick={ () => setValue( undefined ) }>Reset</Button>
45
43
  </>
46
44
  );
45
+ };
46
+ const options = (
47
+ <>
48
+ <ToggleGroupControlOption value="rigas" label="R" />
49
+ <ToggleGroupControlOption value="jack" label="J" />
50
+ </>
51
+ );
52
+ const optionsWithTooltip = (
53
+ <>
54
+ <ToggleGroupControlOption
55
+ value="gnocchi"
56
+ label="Delicious Gnocchi"
57
+ aria-label="Click for Delicious Gnocchi"
58
+ showTooltip={ true }
59
+ />
60
+ <ToggleGroupControlOption
61
+ value="caponata"
62
+ label="Sumptuous Caponata"
63
+ aria-label="Click for Sumptuous Caponata"
64
+ />
65
+ </>
66
+ );
67
+
68
+ describe.each( [
69
+ [ 'uncontrolled', ToggleGroupControl ],
70
+ [ 'controlled', ControlledToggleGroupControl ],
71
+ ] )( 'ToggleGroupControl %s', ( ...modeAndComponent ) => {
72
+ const [ mode, Component ] = modeAndComponent;
47
73
 
48
74
  describe( 'should render correctly', () => {
49
75
  it( 'with text options', () => {
50
76
  const { container } = render(
51
- <ToggleGroupControl label="Test Toggle Group Control">
77
+ <Component label="Test Toggle Group Control">
52
78
  { options }
53
- </ToggleGroupControl>
79
+ </Component>
54
80
  );
55
81
 
56
82
  expect( container ).toMatchSnapshot();
@@ -58,10 +84,7 @@ describe( 'ToggleGroupControl', () => {
58
84
 
59
85
  it( 'with icons', () => {
60
86
  const { container } = render(
61
- <ToggleGroupControl
62
- value="uppercase"
63
- label="Test Toggle Group Control"
64
- >
87
+ <Component value="uppercase" label="Test Toggle Group Control">
65
88
  <ToggleGroupControlOptionIcon
66
89
  value="uppercase"
67
90
  icon={ formatUppercase }
@@ -72,7 +95,7 @@ describe( 'ToggleGroupControl', () => {
72
95
  icon={ formatLowercase }
73
96
  label="Lowercase"
74
97
  />
75
- </ToggleGroupControl>
98
+ </Component>
76
99
  );
77
100
 
78
101
  expect( container ).toMatchSnapshot();
@@ -83,13 +106,13 @@ describe( 'ToggleGroupControl', () => {
83
106
  const mockOnChange = jest.fn();
84
107
 
85
108
  render(
86
- <ToggleGroupControl
109
+ <Component
87
110
  value="jack"
88
111
  onChange={ mockOnChange }
89
112
  label="Test Toggle Group Control"
90
113
  >
91
114
  { options }
92
- </ToggleGroupControl>
115
+ </Component>
93
116
  );
94
117
 
95
118
  await user.click( screen.getByRole( 'radio', { name: 'R' } ) );
@@ -100,9 +123,9 @@ describe( 'ToggleGroupControl', () => {
100
123
  it( 'should render tooltip where `showTooltip` === `true`', async () => {
101
124
  const user = userEvent.setup();
102
125
  render(
103
- <ToggleGroupControl label="Test Toggle Group Control">
126
+ <Component label="Test Toggle Group Control">
104
127
  { optionsWithTooltip }
105
- </ToggleGroupControl>
128
+ </Component>
106
129
  );
107
130
 
108
131
  const firstRadio = screen.getByLabelText(
@@ -115,21 +138,17 @@ describe( 'ToggleGroupControl', () => {
115
138
  'Click for Delicious Gnocchi'
116
139
  );
117
140
 
118
- await waitFor( () =>
119
- expect(
120
- getWrappingPopoverElement( tooltip )
121
- ).toBePositionedPopover()
122
- );
141
+ await waitFor( () => expect( tooltip ).toBeVisible() );
123
142
 
124
- expect( tooltip ).toBeVisible();
143
+ await cleanupTooltip( user );
125
144
  } );
126
145
 
127
146
  it( 'should not render tooltip', async () => {
128
147
  const user = userEvent.setup();
129
148
  render(
130
- <ToggleGroupControl label="Test Toggle Group Control">
149
+ <Component label="Test Toggle Group Control">
131
150
  { optionsWithTooltip }
132
- </ToggleGroupControl>
151
+ </Component>
133
152
  );
134
153
 
135
154
  const secondRadio = screen.getByLabelText(
@@ -145,6 +164,36 @@ describe( 'ToggleGroupControl', () => {
145
164
  );
146
165
  } );
147
166
 
167
+ if ( mode === 'controlled' ) {
168
+ it( 'should reset values correctly', async () => {
169
+ const user = userEvent.setup();
170
+
171
+ render(
172
+ <Component label="Test Toggle Group Control">
173
+ { options }
174
+ </Component>
175
+ );
176
+
177
+ const rigasOption = screen.getByRole( 'radio', { name: 'R' } );
178
+ const jackOption = screen.getByRole( 'radio', { name: 'J' } );
179
+
180
+ await user.click( rigasOption );
181
+
182
+ expect( jackOption ).not.toBeChecked();
183
+ expect( rigasOption ).toBeChecked();
184
+
185
+ await user.keyboard( '[ArrowRight]' );
186
+
187
+ expect( rigasOption ).not.toBeChecked();
188
+ expect( jackOption ).toBeChecked();
189
+
190
+ await user.click( screen.getByRole( 'button', { name: 'Reset' } ) );
191
+
192
+ expect( rigasOption ).not.toBeChecked();
193
+ expect( jackOption ).not.toBeChecked();
194
+ } );
195
+ }
196
+
148
197
  describe( 'isDeselectable', () => {
149
198
  describe( 'isDeselectable = false', () => {
150
199
  it( 'should not be deselectable', async () => {
@@ -152,13 +201,13 @@ describe( 'ToggleGroupControl', () => {
152
201
  const user = userEvent.setup();
153
202
 
154
203
  render(
155
- <ToggleGroupControl
204
+ <Component
156
205
  value="rigas"
157
206
  label="Test"
158
207
  onChange={ mockOnChange }
159
208
  >
160
209
  { options }
161
- </ToggleGroupControl>
210
+ </Component>
162
211
  );
163
212
 
164
213
  const rigas = screen.getByRole( 'radio', {
@@ -173,9 +222,9 @@ describe( 'ToggleGroupControl', () => {
173
222
  const user = userEvent.setup();
174
223
 
175
224
  render(
176
- <ToggleGroupControl value="rigas" label="Test">
225
+ <Component value="rigas" label="Test">
177
226
  { options }
178
- </ToggleGroupControl>
227
+ </Component>
179
228
  );
180
229
 
181
230
  const rigas = screen.getByRole( 'radio', {
@@ -186,7 +235,13 @@ describe( 'ToggleGroupControl', () => {
186
235
  expect( rigas ).toHaveFocus();
187
236
 
188
237
  await user.tab();
189
- expect( rigas.ownerDocument.body ).toHaveFocus();
238
+
239
+ const expectedFocusTarget =
240
+ mode === 'uncontrolled'
241
+ ? rigas.ownerDocument.body
242
+ : screen.getByRole( 'button', { name: 'Reset' } );
243
+
244
+ expect( expectedFocusTarget ).toHaveFocus();
190
245
  } );
191
246
  } );
192
247
 
@@ -196,14 +251,14 @@ describe( 'ToggleGroupControl', () => {
196
251
  const user = userEvent.setup();
197
252
 
198
253
  render(
199
- <ToggleGroupControl
254
+ <Component
200
255
  value="rigas"
201
256
  label="Test"
202
257
  onChange={ mockOnChange }
203
258
  isDeselectable
204
259
  >
205
260
  { options }
206
- </ToggleGroupControl>
261
+ </Component>
207
262
  );
208
263
 
209
264
  await user.click(
@@ -213,26 +268,25 @@ describe( 'ToggleGroupControl', () => {
213
268
  } )
214
269
  );
215
270
  expect( mockOnChange ).toHaveBeenCalledTimes( 1 );
216
- expect( mockOnChange ).toHaveBeenCalledWith( undefined );
217
- expect(
271
+ expect( mockOnChange ).toHaveBeenLastCalledWith( undefined );
272
+
273
+ await user.click(
218
274
  screen.getByRole( 'button', {
219
275
  name: 'R',
220
276
  pressed: false,
221
277
  } )
222
- ).toBeVisible();
278
+ );
279
+ expect( mockOnChange ).toHaveBeenCalledTimes( 2 );
280
+ expect( mockOnChange ).toHaveBeenLastCalledWith( 'rigas' );
223
281
  } );
224
282
 
225
283
  it( 'should tab to the next option button', async () => {
226
284
  const user = userEvent.setup();
227
285
 
228
286
  render(
229
- <ToggleGroupControl
230
- isDeselectable
231
- value="rigas"
232
- label="Test"
233
- >
287
+ <Component isDeselectable value="rigas" label="Test">
234
288
  { options }
235
- </ToggleGroupControl>
289
+ </Component>
236
290
  );
237
291
 
238
292
  await user.tab();
@@ -77,7 +77,6 @@ Callback when a segment is selected.
77
77
  - Required: No
78
78
  - Default: `() => {}`
79
79
 
80
-
81
80
  ### `value`: `string | number`
82
81
 
83
82
  The value of the `ToggleGroupControl`.
@@ -1,28 +1,21 @@
1
- /**
2
- * External dependencies
3
- */
4
- import type { ForwardedRef } from 'react';
5
-
6
1
  /**
7
2
  * WordPress dependencies
8
3
  */
9
- import {
10
- useMergeRefs,
11
- useInstanceId,
12
- usePrevious,
13
- useResizeObserver,
14
- } from '@wordpress/compose';
15
- import { forwardRef, useRef, useState } from '@wordpress/element';
4
+ import { useInstanceId } from '@wordpress/compose';
5
+ import { forwardRef, useMemo } from '@wordpress/element';
16
6
 
17
7
  /**
18
8
  * Internal dependencies
19
9
  */
20
10
  import { View } from '../../view';
21
- import ToggleGroupControlBackdrop from './toggle-group-control-backdrop';
22
- import ToggleGroupControlContext from '../context';
23
- import { useUpdateEffect } from '../../utils/hooks';
11
+ import { useControlledValue } from '../../utils';
24
12
  import type { WordPressComponentProps } from '../../ui/context';
25
- import type { ToggleGroupControlMainControlProps } from '../types';
13
+ import ToggleGroupControlContext from '../context';
14
+ import { useComputeControlledOrUncontrolledValue } from './utils';
15
+ import type {
16
+ ToggleGroupControlMainControlProps,
17
+ ToggleGroupControlContextProps,
18
+ } from '../types';
26
19
 
27
20
  function UnforwardedToggleGroupControlAsButtonGroup(
28
21
  {
@@ -31,67 +24,56 @@ function UnforwardedToggleGroupControlAsButtonGroup(
31
24
  label,
32
25
  onChange,
33
26
  size,
34
- value,
27
+ value: valueProp,
28
+ id: idProp,
35
29
  ...otherProps
36
30
  }: WordPressComponentProps<
37
31
  ToggleGroupControlMainControlProps,
38
32
  'div',
39
33
  false
40
34
  >,
41
- forwardedRef: ForwardedRef< HTMLDivElement >
35
+ forwardedRef: React.ForwardedRef< HTMLDivElement >
42
36
  ) {
43
- const containerRef = useRef();
44
- const [ resizeListener, sizes ] = useResizeObserver();
45
- const baseId = useInstanceId(
37
+ const generatedId = useInstanceId(
46
38
  ToggleGroupControlAsButtonGroup,
47
39
  'toggle-group-control-as-button-group'
48
- ).toString();
49
- const [ selectedValue, setSelectedValue ] = useState( value );
50
- const groupContext = {
51
- baseId,
52
- state: selectedValue,
53
- setState: setSelectedValue,
54
- };
55
- const previousValue = usePrevious( value );
40
+ );
41
+ const baseId = idProp || generatedId;
56
42
 
57
- // Propagate groupContext.state change.
58
- useUpdateEffect( () => {
59
- // Avoid calling onChange if groupContext state changed
60
- // from incoming value.
61
- if ( previousValue !== groupContext.state ) {
62
- onChange( groupContext.state );
63
- }
64
- }, [ groupContext.state ] );
43
+ // Use a heuristic to understand if the component is being used in controlled
44
+ // or uncontrolled mode, and consequently:
45
+ // - when controlled, convert `undefined` values to `''` (ie. "no value")
46
+ // - use the `value` prop as the `defaultValue` when uncontrolled
47
+ const { value, defaultValue } =
48
+ useComputeControlledOrUncontrolledValue( valueProp );
65
49
 
66
- // Sync incoming value with groupContext.state.
67
- useUpdateEffect( () => {
68
- if ( value !== groupContext.state ) {
69
- groupContext.setState( value );
70
- }
71
- }, [ value ] );
50
+ const [ selectedValue, setSelectedValue ] = useControlledValue( {
51
+ defaultValue,
52
+ value,
53
+ onChange,
54
+ } );
72
55
 
73
- return (
74
- <ToggleGroupControlContext.Provider
75
- value={ {
76
- ...groupContext,
56
+ const groupContextValue = useMemo(
57
+ () =>
58
+ ( {
59
+ baseId,
60
+ value: selectedValue,
61
+ setValue: setSelectedValue,
77
62
  isBlock: ! isAdaptiveWidth,
78
63
  isDeselectable: true,
79
64
  size,
80
- } }
81
- >
65
+ } ) as ToggleGroupControlContextProps,
66
+ [ baseId, selectedValue, setSelectedValue, isAdaptiveWidth, size ]
67
+ );
68
+
69
+ return (
70
+ <ToggleGroupControlContext.Provider value={ groupContextValue }>
82
71
  <View
83
72
  aria-label={ label }
84
73
  { ...otherProps }
85
- ref={ useMergeRefs( [ containerRef, forwardedRef ] ) }
74
+ ref={ forwardedRef }
86
75
  role="group"
87
76
  >
88
- { resizeListener }
89
- <ToggleGroupControlBackdrop
90
- state={ groupContext.state }
91
- containerRef={ containerRef }
92
- containerWidth={ sizes.width }
93
- isAdaptiveWidth={ isAdaptiveWidth }
94
- />
95
77
  { children }
96
78
  </View>
97
79
  </ToggleGroupControlContext.Provider>
@@ -3,37 +3,35 @@
3
3
  */
4
4
  import type { ForwardedRef } from 'react';
5
5
  // eslint-disable-next-line no-restricted-imports
6
- import { RadioGroup, useRadioState } from 'reakit';
6
+ import { RadioGroup, useRadioStore } from '@ariakit/react/radio';
7
7
 
8
8
  /**
9
9
  * WordPress dependencies
10
10
  */
11
- import {
12
- useMergeRefs,
13
- useInstanceId,
14
- usePrevious,
15
- useResizeObserver,
16
- } from '@wordpress/compose';
17
- import { forwardRef, useRef } from '@wordpress/element';
11
+ import { useInstanceId } from '@wordpress/compose';
12
+ import { forwardRef, useMemo } from '@wordpress/element';
18
13
 
19
14
  /**
20
15
  * Internal dependencies
21
16
  */
22
17
  import { View } from '../../view';
23
- import ToggleGroupControlBackdrop from './toggle-group-control-backdrop';
24
- import ToggleGroupControlContext from '../context';
25
- import { useUpdateEffect } from '../../utils/hooks';
26
18
  import type { WordPressComponentProps } from '../../ui/context';
27
- import type { ToggleGroupControlMainControlProps } from '../types';
19
+ import ToggleGroupControlContext from '../context';
20
+ import { useComputeControlledOrUncontrolledValue } from './utils';
21
+ import type {
22
+ ToggleGroupControlMainControlProps,
23
+ ToggleGroupControlContextProps,
24
+ } from '../types';
28
25
 
29
26
  function UnforwardedToggleGroupControlAsRadioGroup(
30
27
  {
31
28
  children,
32
29
  isAdaptiveWidth,
33
30
  label,
34
- onChange,
31
+ onChange: onChangeProp,
35
32
  size,
36
- value,
33
+ value: valueProp,
34
+ id: idProp,
37
35
  ...otherProps
38
36
  }: WordPressComponentProps<
39
37
  ToggleGroupControlMainControlProps,
@@ -42,52 +40,58 @@ function UnforwardedToggleGroupControlAsRadioGroup(
42
40
  >,
43
41
  forwardedRef: ForwardedRef< HTMLDivElement >
44
42
  ) {
45
- const containerRef = useRef();
46
- const [ resizeListener, sizes ] = useResizeObserver();
47
- const baseId = useInstanceId(
43
+ const generatedId = useInstanceId(
48
44
  ToggleGroupControlAsRadioGroup,
49
45
  'toggle-group-control-as-radio-group'
50
- ).toString();
51
- const radio = useRadioState( {
52
- baseId,
53
- state: value,
46
+ );
47
+ const baseId = idProp || generatedId;
48
+
49
+ // Use a heuristic to understand if the component is being used in controlled
50
+ // or uncontrolled mode, and consequently:
51
+ // - when controlled, convert `undefined` values to `''` (ie. "no value")
52
+ // - use the `value` prop as the `defaultValue` when uncontrolled
53
+ const { value, defaultValue } =
54
+ useComputeControlledOrUncontrolledValue( valueProp );
55
+
56
+ // `useRadioStore`'s `setValue` prop can be called with `null`, while
57
+ // the component's `onChange` prop only expects `undefined`
58
+ const wrappedOnChangeProp = onChangeProp
59
+ ? ( v: string | number | null ) => {
60
+ onChangeProp( v ?? undefined );
61
+ }
62
+ : undefined;
63
+
64
+ const radio = useRadioStore( {
65
+ defaultValue,
66
+ value,
67
+ setValue: wrappedOnChangeProp,
54
68
  } );
55
- const previousValue = usePrevious( value );
56
69
 
57
- // Propagate radio.state change.
58
- useUpdateEffect( () => {
59
- // Avoid calling onChange if radio state changed
60
- // from incoming value.
61
- if ( previousValue !== radio.state ) {
62
- onChange( radio.state );
63
- }
64
- }, [ radio.state ] );
70
+ const selectedValue = radio.useState( 'value' );
71
+ const setValue = radio.setValue;
65
72
 
66
- // Sync incoming value with radio.state.
67
- useUpdateEffect( () => {
68
- if ( value !== radio.state ) {
69
- radio.setState( value );
70
- }
71
- }, [ value ] );
73
+ const groupContextValue = useMemo(
74
+ () =>
75
+ ( {
76
+ baseId,
77
+ isBlock: ! isAdaptiveWidth,
78
+ size,
79
+ value: selectedValue,
80
+ setValue,
81
+ } ) as ToggleGroupControlContextProps,
82
+ [ baseId, isAdaptiveWidth, size, selectedValue, setValue ]
83
+ );
72
84
 
73
85
  return (
74
- <ToggleGroupControlContext.Provider
75
- value={ { ...radio, isBlock: ! isAdaptiveWidth, size } }
76
- >
86
+ <ToggleGroupControlContext.Provider value={ groupContextValue }>
77
87
  <RadioGroup
78
- { ...radio }
88
+ store={ radio }
79
89
  aria-label={ label }
80
90
  as={ View }
81
91
  { ...otherProps }
82
- ref={ useMergeRefs( [ containerRef, forwardedRef ] ) }
92
+ id={ baseId }
93
+ ref={ forwardedRef }
83
94
  >
84
- { resizeListener }
85
- <ToggleGroupControlBackdrop
86
- state={ radio.state }
87
- containerRef={ containerRef }
88
- containerWidth={ sizes.width }
89
- isAdaptiveWidth={ isAdaptiveWidth }
90
- />
91
95
  { children }
92
96
  </RadioGroup>
93
97
  </ToggleGroupControlContext.Provider>
@@ -2,9 +2,13 @@
2
2
  * External dependencies
3
3
  */
4
4
  import type { ForwardedRef } from 'react';
5
+ // eslint-disable-next-line no-restricted-imports
6
+ import { LayoutGroup } from 'framer-motion';
7
+
5
8
  /**
6
9
  * WordPress dependencies
7
10
  */
11
+ import { useInstanceId } from '@wordpress/compose';
8
12
  import { __ } from '@wordpress/i18n';
9
13
  import { useMemo } from '@wordpress/element';
10
14
 
@@ -21,8 +25,6 @@ import * as styles from './styles';
21
25
  import { ToggleGroupControlAsRadioGroup } from './as-radio-group';
22
26
  import { ToggleGroupControlAsButtonGroup } from './as-button-group';
23
27
 
24
- const noop = () => {};
25
-
26
28
  function UnconnectedToggleGroupControl(
27
29
  props: WordPressComponentProps< ToggleGroupControlProps, 'div', false >,
28
30
  forwardedRef: ForwardedRef< any >
@@ -36,18 +38,21 @@ function UnconnectedToggleGroupControl(
36
38
  label,
37
39
  hideLabelFromVision = false,
38
40
  help,
39
- onChange = noop,
41
+ onChange,
40
42
  size = 'default',
41
43
  value,
42
44
  children,
43
45
  ...otherProps
44
46
  } = useContextSystem( props, 'ToggleGroupControl' );
47
+
48
+ const baseId = useInstanceId( ToggleGroupControl, 'toggle-group-control' );
49
+
45
50
  const cx = useCx();
46
51
 
47
52
  const classes = useMemo(
48
53
  () =>
49
54
  cx(
50
- styles.ToggleGroupControl( { isBlock, isDeselectable, size } ),
55
+ styles.toggleGroupControl( { isBlock, isDeselectable, size } ),
51
56
  isBlock && styles.block,
52
57
  className
53
58
  ),
@@ -70,7 +75,6 @@ function UnconnectedToggleGroupControl(
70
75
  ) }
71
76
  <MainControl
72
77
  { ...otherProps }
73
- children={ children }
74
78
  className={ classes }
75
79
  isAdaptiveWidth={ isAdaptiveWidth }
76
80
  label={ label }
@@ -78,7 +82,9 @@ function UnconnectedToggleGroupControl(
78
82
  ref={ forwardedRef }
79
83
  size={ size }
80
84
  value={ value }
81
- />
85
+ >
86
+ <LayoutGroup id={ baseId }>{ children }</LayoutGroup>
87
+ </MainControl>
82
88
  </BaseControl>
83
89
  );
84
90
  }