@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
@@ -93,7 +93,7 @@ function Snackbar(
93
93
  }, NOTICE_TIMEOUT );
94
94
 
95
95
  return () => clearTimeout( timeoutHandle );
96
- }, [ onDismiss, onRemove ] );
96
+ }, [ onDismiss, onRemove, explicitDismiss ] );
97
97
 
98
98
  const classes = classnames( className, 'components-snackbar', {
99
99
  'components-snackbar-explicit-dismiss': !! explicitDismiss,
@@ -22,7 +22,7 @@
22
22
  &:focus {
23
23
  box-shadow:
24
24
  0 0 0 1px $white,
25
- 0 0 0 3px var(--wp-admin-theme-color);
25
+ 0 0 0 3px $components-color-accent;
26
26
  }
27
27
 
28
28
  &.components-snackbar-explicit-dismiss {
@@ -64,7 +64,7 @@
64
64
  }
65
65
 
66
66
  &:hover {
67
- color: var(--wp-admin-theme-color);
67
+ color: $components-color-accent;
68
68
  }
69
69
  }
70
70
  }
@@ -9,64 +9,77 @@ import { render, screen } from '@testing-library/react';
9
9
  import { Spacer } from '../index';
10
10
 
11
11
  describe( 'props', () => {
12
- beforeEach( () => {
12
+ test( 'should render correctly', () => {
13
13
  render( <Spacer data-testid="spacer" /> );
14
- } );
15
14
 
16
- test( 'should render correctly', () => {
17
15
  expect( screen.getByTestId( 'spacer' ) ).toMatchSnapshot();
18
16
  } );
19
17
 
20
18
  test( 'should render margin', () => {
19
+ render( <Spacer data-testid="spacer" /> );
21
20
  render( <Spacer margin={ 5 } data-testid="customized-spacer" /> );
21
+
22
22
  expect(
23
23
  screen.getByTestId( 'customized-spacer' )
24
24
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
25
25
  } );
26
26
 
27
27
  test( 'should render marginX', () => {
28
+ render( <Spacer data-testid="spacer" /> );
28
29
  render( <Spacer marginX={ 5 } data-testid="customized-spacer" /> );
30
+
29
31
  expect(
30
32
  screen.getByTestId( 'customized-spacer' )
31
33
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
32
34
  } );
33
35
 
34
36
  test( 'should render marginY', () => {
37
+ render( <Spacer data-testid="spacer" /> );
35
38
  render( <Spacer marginY={ 5 } data-testid="customized-spacer" /> );
39
+
36
40
  expect(
37
41
  screen.getByTestId( 'customized-spacer' )
38
42
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
39
43
  } );
40
44
 
41
45
  test( 'should render marginTop', () => {
46
+ render( <Spacer data-testid="spacer" /> );
42
47
  render( <Spacer marginTop={ 5 } data-testid="customized-spacer" /> );
48
+
43
49
  expect(
44
50
  screen.getByTestId( 'customized-spacer' )
45
51
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
46
52
  } );
47
53
 
48
54
  test( 'should render marginBottom', () => {
55
+ render( <Spacer data-testid="spacer" /> );
49
56
  render( <Spacer marginBottom={ 5 } data-testid="customized-spacer" /> );
57
+
50
58
  expect(
51
59
  screen.getByTestId( 'customized-spacer' )
52
60
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
53
61
  } );
54
62
 
55
63
  test( 'should render marginLeft', () => {
64
+ render( <Spacer data-testid="spacer" /> );
56
65
  render( <Spacer marginLeft={ 5 } data-testid="customized-spacer" /> );
66
+
57
67
  expect(
58
68
  screen.getByTestId( 'customized-spacer' )
59
69
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
60
70
  } );
61
71
 
62
72
  test( 'should render marginRight', () => {
73
+ render( <Spacer data-testid="spacer" /> );
63
74
  render( <Spacer marginRight={ 5 } data-testid="customized-spacer" /> );
75
+
64
76
  expect(
65
77
  screen.getByTestId( 'customized-spacer' )
66
78
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
67
79
  } );
68
80
 
69
81
  test( 'should override margin props from less to more specific', () => {
82
+ render( <Spacer data-testid="spacer" /> );
70
83
  render(
71
84
  <Spacer
72
85
  margin={ 10 }
@@ -76,63 +89,79 @@ describe( 'props', () => {
76
89
  data-testid="customized-spacer"
77
90
  />
78
91
  );
92
+
79
93
  expect(
80
94
  screen.getByTestId( 'customized-spacer' )
81
95
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
82
96
  } );
83
97
 
84
98
  test( 'should render padding', () => {
99
+ render( <Spacer data-testid="spacer" /> );
85
100
  render( <Spacer padding={ 5 } data-testid="customized-spacer" /> );
101
+
86
102
  expect(
87
103
  screen.getByTestId( 'customized-spacer' )
88
104
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
89
105
  } );
90
106
 
91
107
  test( 'should render paddingX', () => {
108
+ render( <Spacer data-testid="spacer" /> );
92
109
  render( <Spacer paddingX={ 5 } data-testid="customized-spacer" /> );
110
+
93
111
  expect(
94
112
  screen.getByTestId( 'customized-spacer' )
95
113
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
96
114
  } );
97
115
 
98
116
  test( 'should render paddingY', () => {
117
+ render( <Spacer data-testid="spacer" /> );
99
118
  render( <Spacer paddingY={ 5 } data-testid="customized-spacer" /> );
119
+
100
120
  expect(
101
121
  screen.getByTestId( 'customized-spacer' )
102
122
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
103
123
  } );
104
124
 
105
125
  test( 'should render paddingTop', () => {
126
+ render( <Spacer data-testid="spacer" /> );
106
127
  render( <Spacer paddingTop={ 5 } data-testid="customized-spacer" /> );
128
+
107
129
  expect(
108
130
  screen.getByTestId( 'customized-spacer' )
109
131
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
110
132
  } );
111
133
 
112
134
  test( 'should render paddingBottom', () => {
135
+ render( <Spacer data-testid="spacer" /> );
113
136
  render(
114
137
  <Spacer paddingBottom={ 5 } data-testid="customized-spacer" />
115
138
  );
139
+
116
140
  expect(
117
141
  screen.getByTestId( 'customized-spacer' )
118
142
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
119
143
  } );
120
144
 
121
145
  test( 'should render paddingLeft', () => {
146
+ render( <Spacer data-testid="spacer" /> );
122
147
  render( <Spacer paddingLeft={ 5 } data-testid="customized-spacer" /> );
148
+
123
149
  expect(
124
150
  screen.getByTestId( 'customized-spacer' )
125
151
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
126
152
  } );
127
153
 
128
154
  test( 'should render paddingRight', () => {
155
+ render( <Spacer data-testid="spacer" /> );
129
156
  render( <Spacer paddingRight={ 5 } data-testid="customized-spacer" /> );
157
+
130
158
  expect(
131
159
  screen.getByTestId( 'customized-spacer' )
132
160
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
133
161
  } );
134
162
 
135
163
  test( 'should override padding props from less to more specific', () => {
164
+ render( <Spacer data-testid="spacer" /> );
136
165
  render(
137
166
  <Spacer
138
167
  padding={ 10 }
@@ -142,6 +171,7 @@ describe( 'props', () => {
142
171
  data-testid="customized-spacer"
143
172
  />
144
173
  );
174
+
145
175
  expect(
146
176
  screen.getByTestId( 'customized-spacer' )
147
177
  ).toMatchStyleDiffSnapshot( screen.getByTestId( 'spacer' ) );
@@ -24,7 +24,7 @@ export const StyledSpinner = styled.svg`
24
24
  display: inline-block;
25
25
  margin: 5px 11px 0;
26
26
  position: relative;
27
- color: var( --wp-admin-theme-color );
27
+ color: ${ COLORS.ui.theme };
28
28
  overflow: visible;
29
29
  `;
30
30
 
@@ -5,14 +5,16 @@ Snapshot Diff:
5
5
  - First value
6
6
  + Second value
7
7
 
8
- <div
9
- - class="components-surface css-pt58n0-View-Surface-getBorders-primary e19lxcc00"
10
- + class="components-surface css-soe81k-View-Surface-getBorders-primary e19lxcc00"
11
- data-wp-c16t="true"
12
- data-wp-component="Surface"
13
- >
14
- Surface
15
- </div>
8
+ @@ -1,8 +1,8 @@
9
+ <div>
10
+ <div
11
+ - class="components-surface css-pt58n0-View-Surface-getBorders-primary e19lxcc00"
12
+ + class="components-surface css-soe81k-View-Surface-getBorders-primary e19lxcc00"
13
+ data-wp-c16t="true"
14
+ data-wp-component="Surface"
15
+ >
16
+ Surface
17
+ </div>
16
18
  `;
17
19
 
18
20
  exports[`props should render borderLeft 1`] = `
@@ -20,14 +22,16 @@ Snapshot Diff:
20
22
  - First value
21
23
  + Second value
22
24
 
23
- <div
24
- - class="components-surface css-1vckp4o-View-Surface-getBorders-primary e19lxcc00"
25
- + class="components-surface css-soe81k-View-Surface-getBorders-primary e19lxcc00"
26
- data-wp-c16t="true"
27
- data-wp-component="Surface"
28
- >
29
- Surface
30
- </div>
25
+ @@ -1,8 +1,8 @@
26
+ <div>
27
+ <div
28
+ - class="components-surface css-1vckp4o-View-Surface-getBorders-primary e19lxcc00"
29
+ + class="components-surface css-soe81k-View-Surface-getBorders-primary e19lxcc00"
30
+ data-wp-c16t="true"
31
+ data-wp-component="Surface"
32
+ >
33
+ Surface
34
+ </div>
31
35
  `;
32
36
 
33
37
  exports[`props should render borderRight 1`] = `
@@ -35,14 +39,16 @@ Snapshot Diff:
35
39
  - First value
36
40
  + Second value
37
41
 
38
- <div
39
- - class="components-surface css-sw9dzi-View-Surface-getBorders-primary e19lxcc00"
40
- + class="components-surface css-soe81k-View-Surface-getBorders-primary e19lxcc00"
41
- data-wp-c16t="true"
42
- data-wp-component="Surface"
43
- >
44
- Surface
45
- </div>
42
+ @@ -1,8 +1,8 @@
43
+ <div>
44
+ <div
45
+ - class="components-surface css-sw9dzi-View-Surface-getBorders-primary e19lxcc00"
46
+ + class="components-surface css-soe81k-View-Surface-getBorders-primary e19lxcc00"
47
+ data-wp-c16t="true"
48
+ data-wp-component="Surface"
49
+ >
50
+ Surface
51
+ </div>
46
52
  `;
47
53
 
48
54
  exports[`props should render borderTop 1`] = `
@@ -50,14 +56,16 @@ Snapshot Diff:
50
56
  - First value
51
57
  + Second value
52
58
 
53
- <div
54
- - class="components-surface css-123k66h-View-Surface-getBorders-primary e19lxcc00"
55
- + class="components-surface css-soe81k-View-Surface-getBorders-primary e19lxcc00"
56
- data-wp-c16t="true"
57
- data-wp-component="Surface"
58
- >
59
- Surface
60
- </div>
59
+ @@ -1,8 +1,8 @@
60
+ <div>
61
+ <div
62
+ - class="components-surface css-123k66h-View-Surface-getBorders-primary e19lxcc00"
63
+ + class="components-surface css-soe81k-View-Surface-getBorders-primary e19lxcc00"
64
+ data-wp-c16t="true"
65
+ data-wp-component="Surface"
66
+ >
67
+ Surface
68
+ </div>
61
69
  `;
62
70
 
63
71
  exports[`props should render correctly 1`] = `
@@ -67,12 +75,14 @@ exports[`props should render correctly 1`] = `
67
75
  position: relative;
68
76
  }
69
77
 
70
- <div
71
- class="components-surface emotion-0 emotion-1"
72
- data-wp-c16t="true"
73
- data-wp-component="Surface"
74
- >
75
- Surface
78
+ <div>
79
+ <div
80
+ class="components-surface emotion-0 emotion-1"
81
+ data-wp-c16t="true"
82
+ data-wp-component="Surface"
83
+ >
84
+ Surface
85
+ </div>
76
86
  </div>
77
87
  `;
78
88
 
@@ -81,12 +91,14 @@ Snapshot Diff:
81
91
  - First value
82
92
  + Second value
83
93
 
84
- <div
85
- - class="components-surface css-1m2pafr-View-Surface-getBorders-secondary e19lxcc00"
86
- + class="components-surface css-soe81k-View-Surface-getBorders-primary e19lxcc00"
87
- data-wp-c16t="true"
88
- data-wp-component="Surface"
89
- >
90
- Surface
91
- </div>
94
+ @@ -1,8 +1,8 @@
95
+ <div>
96
+ <div
97
+ - class="components-surface css-1m2pafr-View-Surface-getBorders-secondary e19lxcc00"
98
+ + class="components-surface css-soe81k-View-Surface-getBorders-primary e19lxcc00"
99
+ data-wp-c16t="true"
100
+ data-wp-component="Surface"
101
+ >
102
+ Surface
103
+ </div>
92
104
  `;
@@ -2,7 +2,6 @@
2
2
  * External dependencies
3
3
  */
4
4
  import { render } from '@testing-library/react';
5
- import type { RenderResult } from '@testing-library/react';
6
5
 
7
6
  /**
8
7
  * Internal dependencies
@@ -10,49 +9,40 @@ import type { RenderResult } from '@testing-library/react';
10
9
  import { Surface } from '../index';
11
10
 
12
11
  describe( 'props', () => {
13
- let base: RenderResult;
14
- beforeEach( () => {
15
- base = render( <Surface>Surface</Surface> );
16
- } );
17
-
18
12
  test( 'should render correctly', () => {
19
- expect( base.container.firstChild ).toMatchSnapshot();
13
+ const { container } = render( <Surface>Surface</Surface> );
14
+ expect( container ).toMatchSnapshot();
20
15
  } );
21
16
 
22
17
  test( 'should render variants', () => {
18
+ const view = render( <Surface>Surface</Surface> );
23
19
  const { container } = render(
24
20
  <Surface variant="secondary">Surface</Surface>
25
21
  );
26
- expect( container.firstChild ).toMatchDiffSnapshot(
27
- base.container.firstChild
28
- );
22
+ expect( container ).toMatchDiffSnapshot( view.container );
29
23
  } );
30
24
 
31
25
  test( 'should render borderLeft', () => {
26
+ const view = render( <Surface>Surface</Surface> );
32
27
  const { container } = render( <Surface borderLeft>Surface</Surface> );
33
- expect( container.firstChild ).toMatchDiffSnapshot(
34
- base.container.firstChild
35
- );
28
+ expect( container ).toMatchDiffSnapshot( view.container );
36
29
  } );
37
30
 
38
31
  test( 'should render borderRight', () => {
32
+ const view = render( <Surface>Surface</Surface> );
39
33
  const { container } = render( <Surface borderRight>Surface</Surface> );
40
- expect( container.firstChild ).toMatchDiffSnapshot(
41
- base.container.firstChild
42
- );
34
+ expect( container ).toMatchDiffSnapshot( view.container );
43
35
  } );
44
36
 
45
37
  test( 'should render borderTop', () => {
38
+ const view = render( <Surface>Surface</Surface> );
46
39
  const { container } = render( <Surface borderTop>Surface</Surface> );
47
- expect( container.firstChild ).toMatchDiffSnapshot(
48
- base.container.firstChild
49
- );
40
+ expect( container ).toMatchDiffSnapshot( view.container );
50
41
  } );
51
42
 
52
43
  test( 'should render borderBottom', () => {
44
+ const view = render( <Surface>Surface</Surface> );
53
45
  const { container } = render( <Surface borderBottom>Surface</Surface> );
54
- expect( container.firstChild ).toMatchDiffSnapshot(
55
- base.container.firstChild
56
- );
46
+ expect( container ).toMatchDiffSnapshot( view.container );
57
47
  } );
58
48
  } );
@@ -7,7 +7,7 @@ import { find } from 'lodash';
7
7
  /**
8
8
  * WordPress dependencies
9
9
  */
10
- import { useState, useEffect } from '@wordpress/element';
10
+ import { useState, useEffect, useCallback } from '@wordpress/element';
11
11
  import { useInstanceId } from '@wordpress/compose';
12
12
 
13
13
  /**
@@ -85,10 +85,13 @@ export function TabPanel( {
85
85
  const instanceId = useInstanceId( TabPanel, 'tab-panel' );
86
86
  const [ selected, setSelected ] = useState< string >();
87
87
 
88
- const handleTabSelection = ( tabKey: string ) => {
89
- setSelected( tabKey );
90
- onSelect?.( tabKey );
91
- };
88
+ const handleTabSelection = useCallback(
89
+ ( tabKey: string ) => {
90
+ setSelected( tabKey );
91
+ onSelect?.( tabKey );
92
+ },
93
+ [ onSelect ]
94
+ );
92
95
 
93
96
  const onNavigate = ( _childIndex: number, child: HTMLButtonElement ) => {
94
97
  child.click();
@@ -97,11 +100,10 @@ export function TabPanel( {
97
100
  const selectedId = `${ instanceId }-${ selectedTab?.name ?? 'none' }`;
98
101
 
99
102
  useEffect( () => {
100
- const newSelectedTab = find( tabs, { name: selected } );
101
- if ( ! newSelectedTab && tabs.length > 0 ) {
103
+ if ( ! selectedTab?.name && tabs.length > 0 ) {
102
104
  handleTabSelection( initialTabName || tabs[ 0 ].name );
103
105
  }
104
- }, [ tabs ] );
106
+ }, [ tabs, selectedTab?.name, initialTabName, handleTabSelection ] );
105
107
 
106
108
  return (
107
109
  <div className={ className }>
@@ -33,13 +33,12 @@
33
33
  }
34
34
 
35
35
  &:focus:not(:disabled) {
36
- box-shadow: inset 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);
36
+ box-shadow: inset 0 var(--wp-admin-border-width-focus) $components-color-accent;
37
37
  }
38
38
 
39
-
40
39
  &.is-active {
41
40
  // The transparent shadow ensures no jumpiness when focus animates on an active tab.
42
- box-shadow: inset 0 0 0 var(--wp-admin-border-width-focus) transparent, inset 0 0 -$border-width-tab 0 0 var(--wp-admin-theme-color);
41
+ box-shadow: inset 0 0 0 var(--wp-admin-border-width-focus) transparent, inset 0 0 -$border-width-tab 0 0 $components-color-accent;
43
42
  position: relative;
44
43
 
45
44
  // This border appears in Windows High Contrast mode instead of the box-shadow.
@@ -55,10 +54,10 @@
55
54
  }
56
55
 
57
56
  &:focus {
58
- box-shadow: inset 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);
57
+ box-shadow: inset 0 0 0 var(--wp-admin-border-width-focus) $components-color-accent;
59
58
  }
60
59
 
61
60
  &.is-active:focus {
62
- box-shadow: inset 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color), inset 0 -#{$border-width-tab * 2} 0 0 var(--wp-admin-theme-color);
61
+ box-shadow: inset 0 0 0 var(--wp-admin-border-width-focus) $components-color-accent, inset 0 -#{$border-width-tab * 2} 0 0 $components-color-accent;
63
62
  }
64
63
  }
@@ -38,14 +38,22 @@ describe( 'TabPanel', () => {
38
38
  it( 'should render a tabpanel, and clicking should change tabs', async () => {
39
39
  const user = setupUser();
40
40
  const panelRenderFunction = jest.fn();
41
+ const mockOnSelect = jest.fn();
41
42
 
42
- render( <TabPanel tabs={ TABS } children={ panelRenderFunction } /> );
43
+ render(
44
+ <TabPanel
45
+ tabs={ TABS }
46
+ children={ panelRenderFunction }
47
+ onSelect={ mockOnSelect }
48
+ />
49
+ );
43
50
 
44
51
  expect( getSelectedTab() ).toHaveTextContent( 'Alpha' );
45
52
  expect(
46
53
  screen.getByRole( 'tabpanel', { name: 'Alpha' } )
47
54
  ).toBeInTheDocument();
48
55
  expect( panelRenderFunction ).toHaveBeenLastCalledWith( TABS[ 0 ] );
56
+ expect( mockOnSelect ).toHaveBeenLastCalledWith( 'alpha' );
49
57
 
50
58
  await user.click( screen.getByRole( 'tab', { name: 'Beta' } ) );
51
59
 
@@ -54,6 +62,7 @@ describe( 'TabPanel', () => {
54
62
  screen.getByRole( 'tabpanel', { name: 'Beta' } )
55
63
  ).toBeInTheDocument();
56
64
  expect( panelRenderFunction ).toHaveBeenLastCalledWith( TABS[ 1 ] );
65
+ expect( mockOnSelect ).toHaveBeenLastCalledWith( 'beta' );
57
66
 
58
67
  await user.click( screen.getByRole( 'tab', { name: 'Alpha' } ) );
59
68
 
@@ -62,6 +71,7 @@ describe( 'TabPanel', () => {
62
71
  screen.getByRole( 'tabpanel', { name: 'Alpha' } )
63
72
  ).toBeInTheDocument();
64
73
  expect( panelRenderFunction ).toHaveBeenLastCalledWith( TABS[ 0 ] );
74
+ expect( mockOnSelect ).toHaveBeenLastCalledWith( 'alpha' );
65
75
  } );
66
76
 
67
77
  it( 'should render with a tab initially selected by prop initialTabIndex', () => {
@@ -117,4 +127,71 @@ describe( 'TabPanel', () => {
117
127
  'gamma-class'
118
128
  );
119
129
  } );
130
+
131
+ it( 'should select `initialTabname` if defined', () => {
132
+ const mockOnSelect = jest.fn();
133
+
134
+ render(
135
+ <TabPanel
136
+ tabs={ TABS }
137
+ initialTabName="beta"
138
+ children={ () => undefined }
139
+ onSelect={ mockOnSelect }
140
+ />
141
+ );
142
+ expect( getSelectedTab() ).toHaveTextContent( 'Beta' );
143
+ expect( mockOnSelect ).toHaveBeenLastCalledWith( 'beta' );
144
+ } );
145
+
146
+ describe( 'fallbacks when new tab list invalidates current selection', () => {
147
+ it( 'should select `initialTabName` if defined', async () => {
148
+ const user = setupUser();
149
+ const mockOnSelect = jest.fn();
150
+
151
+ const { rerender } = render(
152
+ <TabPanel
153
+ tabs={ TABS }
154
+ initialTabName="gamma"
155
+ children={ () => undefined }
156
+ onSelect={ mockOnSelect }
157
+ />
158
+ );
159
+ await user.click( screen.getByRole( 'tab', { name: 'Alpha' } ) );
160
+
161
+ rerender(
162
+ <TabPanel
163
+ tabs={ TABS.slice( 1 ) /* remove alpha */ }
164
+ initialTabName="gamma"
165
+ children={ () => undefined }
166
+ onSelect={ mockOnSelect }
167
+ />
168
+ );
169
+ expect( getSelectedTab() ).toHaveTextContent( 'Gamma' );
170
+ expect( mockOnSelect ).toHaveBeenLastCalledWith( 'gamma' );
171
+ } );
172
+
173
+ it( 'should select first tab if `initialTabName` not defined', async () => {
174
+ const user = setupUser();
175
+ const mockOnSelect = jest.fn();
176
+
177
+ const { rerender } = render(
178
+ <TabPanel
179
+ tabs={ TABS }
180
+ children={ () => undefined }
181
+ onSelect={ mockOnSelect }
182
+ />
183
+ );
184
+ await user.click( screen.getByRole( 'tab', { name: 'Alpha' } ) );
185
+
186
+ rerender(
187
+ <TabPanel
188
+ tabs={ TABS.slice( 1 ) /* remove alpha */ }
189
+ children={ () => undefined }
190
+ onSelect={ mockOnSelect }
191
+ />
192
+ );
193
+ expect( getSelectedTab() ).toHaveTextContent( 'Beta' );
194
+ expect( mockOnSelect ).toHaveBeenLastCalledWith( 'beta' );
195
+ } );
196
+ } );
120
197
  } );
@@ -31,17 +31,19 @@ exports[`Text should render highlighted words with highlightCaseSensitive 1`] =
31
31
  box-shadow: 0 0 0 1px rgba( 0, 0, 0, 0.05 ) inset,0 -1px 0 rgba( 0, 0, 0, 0.1 ) inset;
32
32
  }
33
33
 
34
- <span
35
- class="components-truncate components-text emotion-0 emotion-1"
36
- data-wp-c16t="true"
37
- data-wp-component="Text"
38
- >
34
+ <div>
39
35
  <span
40
- class=""
36
+ class="components-truncate components-text emotion-0 emotion-1"
37
+ data-wp-c16t="true"
38
+ data-wp-component="Text"
41
39
  >
42
- Lorem ipsum.
40
+ <span
41
+ class=""
42
+ >
43
+ Lorem ipsum.
44
+ </span>
43
45
  </span>
44
- </span>
46
+ </div>
45
47
  `;
46
48
 
47
49
  exports[`Text snapshot tests should render correctly 1`] = `
@@ -53,11 +55,13 @@ exports[`Text snapshot tests should render correctly 1`] = `
53
55
  font-weight: normal;
54
56
  }
55
57
 
56
- <span
57
- class="components-truncate components-text emotion-0 emotion-1"
58
- data-wp-c16t="true"
59
- data-wp-component="Text"
60
- >
61
- Lorem ipsum.
62
- </span>
58
+ <div>
59
+ <span
60
+ class="components-truncate components-text emotion-0 emotion-1"
61
+ data-wp-c16t="true"
62
+ data-wp-component="Text"
63
+ >
64
+ Lorem ipsum.
65
+ </span>
66
+ </div>
63
67
  `;