@wordpress/components 22.1.0 → 23.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 (660) hide show
  1. package/CHANGELOG.md +67 -0
  2. package/CONTRIBUTING.md +0 -21
  3. package/build/alignment-matrix-control/cell.js.map +1 -1
  4. package/build/alignment-matrix-control/icon.js +4 -2
  5. package/build/alignment-matrix-control/icon.js.map +1 -1
  6. package/build/alignment-matrix-control/index.js +25 -1
  7. package/build/alignment-matrix-control/index.js.map +1 -1
  8. package/build/alignment-matrix-control/styles/alignment-matrix-control-icon-styles.js +13 -13
  9. package/build/alignment-matrix-control/styles/alignment-matrix-control-icon-styles.js.map +1 -1
  10. package/build/alignment-matrix-control/styles/alignment-matrix-control-styles.js +16 -16
  11. package/build/alignment-matrix-control/styles/alignment-matrix-control-styles.js.map +1 -1
  12. package/build/alignment-matrix-control/types.js +6 -0
  13. package/build/alignment-matrix-control/types.js.map +1 -0
  14. package/build/alignment-matrix-control/utils.js +9 -8
  15. package/build/alignment-matrix-control/utils.js.map +1 -1
  16. package/build/angle-picker-control/styles/angle-picker-control-styles.js +9 -9
  17. package/build/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
  18. package/build/autocomplete/index.js +39 -12
  19. package/build/autocomplete/index.js.map +1 -1
  20. package/build/base-control/hooks.js +52 -0
  21. package/build/base-control/hooks.js.map +1 -0
  22. package/build/base-control/index.js +24 -7
  23. package/build/base-control/index.js.map +1 -1
  24. package/build/base-field/hook.js +0 -14
  25. package/build/base-field/hook.js.map +1 -1
  26. package/build/base-field/index.js.map +1 -1
  27. package/build/base-field/styles.js +5 -5
  28. package/build/base-field/styles.js.map +1 -1
  29. package/build/base-field/types.js +6 -0
  30. package/build/base-field/types.js.map +1 -0
  31. package/build/border-box-control/border-box-control/component.js +0 -3
  32. package/build/border-box-control/border-box-control/component.js.map +1 -1
  33. package/build/border-box-control/border-box-control/hook.js +0 -2
  34. package/build/border-box-control/border-box-control/hook.js.map +1 -1
  35. package/build/border-box-control/border-box-control-split-controls/component.js +0 -2
  36. package/build/border-box-control/border-box-control-split-controls/component.js.map +1 -1
  37. package/build/border-box-control/border-box-control-split-controls/hook.js +0 -2
  38. package/build/border-box-control/border-box-control-split-controls/hook.js.map +1 -1
  39. package/build/border-control/border-control/component.js +1 -2
  40. package/build/border-control/border-control/component.js.map +1 -1
  41. package/build/border-control/border-control/hook.js +0 -2
  42. package/build/border-control/border-control/hook.js.map +1 -1
  43. package/build/border-control/border-control-dropdown/component.js +6 -11
  44. package/build/border-control/border-control-dropdown/component.js.map +1 -1
  45. package/build/border-control/border-control-dropdown/hook.js +0 -2
  46. package/build/border-control/border-control-dropdown/hook.js.map +1 -1
  47. package/build/border-control/styles.js +16 -16
  48. package/build/border-control/styles.js.map +1 -1
  49. package/build/box-control/linked-button.js +3 -4
  50. package/build/box-control/linked-button.js.map +1 -1
  51. package/build/color-palette/index.js +7 -15
  52. package/build/color-palette/index.js.map +1 -1
  53. package/build/color-picker/input-with-slider.js +1 -0
  54. package/build/color-picker/input-with-slider.js.map +1 -1
  55. package/build/color-picker/styles.js +8 -8
  56. package/build/color-picker/styles.js.map +1 -1
  57. package/build/custom-select-control/index.js +14 -2
  58. package/build/custom-select-control/index.js.map +1 -1
  59. package/build/dashicon/index.js +1 -4
  60. package/build/dashicon/index.js.map +1 -1
  61. package/build/date-time/date-time/index.js +4 -4
  62. package/build/date-time/date-time/index.js.map +1 -1
  63. package/build/dimension-control/index.js.map +1 -1
  64. package/build/dropdown/index.js +45 -10
  65. package/build/dropdown/index.js.map +1 -1
  66. package/build/duotone-picker/duotone-picker.js +2 -2
  67. package/build/duotone-picker/duotone-picker.js.map +1 -1
  68. package/build/gradient-picker/index.js +4 -11
  69. package/build/gradient-picker/index.js.map +1 -1
  70. package/build/higher-order/navigate-regions/index.js +4 -3
  71. package/build/higher-order/navigate-regions/index.js.map +1 -1
  72. package/build/higher-order/with-fallback-styles/index.js +2 -2
  73. package/build/higher-order/with-fallback-styles/index.js.map +1 -1
  74. package/build/index.js +13 -9
  75. package/build/index.js.map +1 -1
  76. package/build/input-control/index.js +17 -5
  77. package/build/input-control/index.js.map +1 -1
  78. package/build/input-control/input-base.js +2 -0
  79. package/build/input-control/input-base.js.map +1 -1
  80. package/build/mobile/bottom-sheet/cell.native.js +1 -1
  81. package/build/mobile/bottom-sheet/cell.native.js.map +1 -1
  82. package/build/mobile/bottom-sheet/picker-cell.native.js +1 -9
  83. package/build/mobile/bottom-sheet/picker-cell.native.js.map +1 -1
  84. package/build/mobile/bottom-sheet/switch-cell.native.js +1 -3
  85. package/build/mobile/bottom-sheet/switch-cell.native.js.map +1 -1
  86. package/build/mobile/global-styles-context/index.native.js +8 -8
  87. package/build/mobile/global-styles-context/index.native.js.map +1 -1
  88. package/build/mobile/global-styles-context/utils.native.js +30 -12
  89. package/build/mobile/global-styles-context/utils.native.js.map +1 -1
  90. package/build/mobile/keyboard-aware-flat-list/index.ios.js +4 -2
  91. package/build/mobile/keyboard-aware-flat-list/index.ios.js.map +1 -1
  92. package/build/modal/index.js +8 -0
  93. package/build/modal/index.js.map +1 -1
  94. package/build/navigator/navigator-provider/component.js +12 -8
  95. package/build/navigator/navigator-provider/component.js.map +1 -1
  96. package/build/number-control/styles/number-control-styles.js +8 -8
  97. package/build/number-control/styles/number-control-styles.js.map +1 -1
  98. package/build/palette-edit/index.js +72 -33
  99. package/build/palette-edit/index.js.map +1 -1
  100. package/build/popover/index.js +10 -2
  101. package/build/popover/index.js.map +1 -1
  102. package/build/query-controls/index.js +1 -0
  103. package/build/query-controls/index.js.map +1 -1
  104. package/build/snackbar/index.js +35 -24
  105. package/build/snackbar/index.js.map +1 -1
  106. package/build/snackbar/list.js +14 -19
  107. package/build/snackbar/list.js.map +1 -1
  108. package/build/snackbar/types.js +6 -0
  109. package/build/snackbar/types.js.map +1 -0
  110. package/build/tab-panel/index.js +15 -9
  111. package/build/tab-panel/index.js.map +1 -1
  112. package/build/theme/color-algorithms.js +118 -0
  113. package/build/theme/color-algorithms.js.map +1 -0
  114. package/build/theme/index.js +21 -18
  115. package/build/theme/index.js.map +1 -1
  116. package/build/theme/styles.js +10 -7
  117. package/build/theme/styles.js.map +1 -1
  118. package/build/toggle-control/index.js +5 -2
  119. package/build/toggle-control/index.js.map +1 -1
  120. package/build/ui/context/context-system-provider.js +3 -1
  121. package/build/ui/context/context-system-provider.js.map +1 -1
  122. package/build/unit-control/index.js +5 -2
  123. package/build/unit-control/index.js.map +1 -1
  124. package/build/utils/colors-values.js +1 -1
  125. package/build/utils/colors-values.js.map +1 -1
  126. package/build/utils/config-values.js +0 -2
  127. package/build/utils/config-values.js.map +1 -1
  128. package/build/utils/hooks/use-controlled-value.js.map +1 -1
  129. package/build-module/alignment-matrix-control/cell.js.map +1 -1
  130. package/build-module/alignment-matrix-control/icon.js +4 -2
  131. package/build-module/alignment-matrix-control/icon.js.map +1 -1
  132. package/build-module/alignment-matrix-control/index.js +23 -1
  133. package/build-module/alignment-matrix-control/index.js.map +1 -1
  134. package/build-module/alignment-matrix-control/styles/alignment-matrix-control-icon-styles.js +13 -13
  135. package/build-module/alignment-matrix-control/styles/alignment-matrix-control-icon-styles.js.map +1 -1
  136. package/build-module/alignment-matrix-control/styles/alignment-matrix-control-styles.js +16 -16
  137. package/build-module/alignment-matrix-control/styles/alignment-matrix-control-styles.js.map +1 -1
  138. package/build-module/alignment-matrix-control/types.js +2 -0
  139. package/build-module/alignment-matrix-control/types.js.map +1 -0
  140. package/build-module/alignment-matrix-control/utils.js +13 -8
  141. package/build-module/alignment-matrix-control/utils.js.map +1 -1
  142. package/build-module/angle-picker-control/styles/angle-picker-control-styles.js +9 -9
  143. package/build-module/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
  144. package/build-module/autocomplete/index.js +39 -11
  145. package/build-module/autocomplete/index.js.map +1 -1
  146. package/build-module/base-control/hooks.js +41 -0
  147. package/build-module/base-control/hooks.js.map +1 -0
  148. package/build-module/base-control/index.js +18 -8
  149. package/build-module/base-control/index.js.map +1 -1
  150. package/build-module/base-field/hook.js +0 -14
  151. package/build-module/base-field/hook.js.map +1 -1
  152. package/build-module/base-field/index.js.map +1 -1
  153. package/build-module/base-field/styles.js +5 -5
  154. package/build-module/base-field/styles.js.map +1 -1
  155. package/build-module/base-field/types.js +2 -0
  156. package/build-module/base-field/types.js.map +1 -0
  157. package/build-module/border-box-control/border-box-control/component.js +0 -3
  158. package/build-module/border-box-control/border-box-control/component.js.map +1 -1
  159. package/build-module/border-box-control/border-box-control/hook.js +0 -2
  160. package/build-module/border-box-control/border-box-control/hook.js.map +1 -1
  161. package/build-module/border-box-control/border-box-control-split-controls/component.js +0 -2
  162. package/build-module/border-box-control/border-box-control-split-controls/component.js.map +1 -1
  163. package/build-module/border-box-control/border-box-control-split-controls/hook.js +0 -2
  164. package/build-module/border-box-control/border-box-control-split-controls/hook.js.map +1 -1
  165. package/build-module/border-control/border-control/component.js +1 -2
  166. package/build-module/border-control/border-control/component.js.map +1 -1
  167. package/build-module/border-control/border-control/hook.js +0 -2
  168. package/build-module/border-control/border-control/hook.js.map +1 -1
  169. package/build-module/border-control/border-control-dropdown/component.js +6 -11
  170. package/build-module/border-control/border-control-dropdown/component.js.map +1 -1
  171. package/build-module/border-control/border-control-dropdown/hook.js +0 -2
  172. package/build-module/border-control/border-control-dropdown/hook.js.map +1 -1
  173. package/build-module/border-control/styles.js +17 -17
  174. package/build-module/border-control/styles.js.map +1 -1
  175. package/build-module/box-control/linked-button.js +3 -4
  176. package/build-module/box-control/linked-button.js.map +1 -1
  177. package/build-module/color-palette/index.js +7 -15
  178. package/build-module/color-palette/index.js.map +1 -1
  179. package/build-module/color-picker/input-with-slider.js +1 -0
  180. package/build-module/color-picker/input-with-slider.js.map +1 -1
  181. package/build-module/color-picker/styles.js +8 -8
  182. package/build-module/color-picker/styles.js.map +1 -1
  183. package/build-module/custom-select-control/index.js +14 -2
  184. package/build-module/custom-select-control/index.js.map +1 -1
  185. package/build-module/dashicon/index.js +1 -4
  186. package/build-module/dashicon/index.js.map +1 -1
  187. package/build-module/date-time/date-time/index.js +4 -4
  188. package/build-module/date-time/date-time/index.js.map +1 -1
  189. package/build-module/dimension-control/index.js +1 -2
  190. package/build-module/dimension-control/index.js.map +1 -1
  191. package/build-module/dropdown/index.js +44 -10
  192. package/build-module/dropdown/index.js.map +1 -1
  193. package/build-module/duotone-picker/duotone-picker.js +2 -2
  194. package/build-module/duotone-picker/duotone-picker.js.map +1 -1
  195. package/build-module/gradient-picker/index.js +4 -10
  196. package/build-module/gradient-picker/index.js.map +1 -1
  197. package/build-module/higher-order/navigate-regions/index.js +4 -3
  198. package/build-module/higher-order/navigate-regions/index.js.map +1 -1
  199. package/build-module/higher-order/with-fallback-styles/index.js +2 -2
  200. package/build-module/higher-order/with-fallback-styles/index.js.map +1 -1
  201. package/build-module/index.js +2 -3
  202. package/build-module/index.js.map +1 -1
  203. package/build-module/input-control/index.js +16 -5
  204. package/build-module/input-control/index.js.map +1 -1
  205. package/build-module/input-control/input-base.js +2 -0
  206. package/build-module/input-control/input-base.js.map +1 -1
  207. package/build-module/mobile/bottom-sheet/cell.native.js +1 -1
  208. package/build-module/mobile/bottom-sheet/cell.native.js.map +1 -1
  209. package/build-module/mobile/bottom-sheet/picker-cell.native.js +1 -8
  210. package/build-module/mobile/bottom-sheet/picker-cell.native.js.map +1 -1
  211. package/build-module/mobile/bottom-sheet/switch-cell.native.js +1 -2
  212. package/build-module/mobile/bottom-sheet/switch-cell.native.js.map +1 -1
  213. package/build-module/mobile/global-styles-context/index.native.js +8 -7
  214. package/build-module/mobile/global-styles-context/index.native.js.map +1 -1
  215. package/build-module/mobile/global-styles-context/utils.native.js +31 -13
  216. package/build-module/mobile/global-styles-context/utils.native.js.map +1 -1
  217. package/build-module/mobile/keyboard-aware-flat-list/index.ios.js +2 -2
  218. package/build-module/mobile/keyboard-aware-flat-list/index.ios.js.map +1 -1
  219. package/build-module/modal/index.js +8 -0
  220. package/build-module/modal/index.js.map +1 -1
  221. package/build-module/navigator/navigator-provider/component.js +12 -8
  222. package/build-module/navigator/navigator-provider/component.js.map +1 -1
  223. package/build-module/number-control/styles/number-control-styles.js +8 -10
  224. package/build-module/number-control/styles/number-control-styles.js.map +1 -1
  225. package/build-module/palette-edit/index.js +73 -34
  226. package/build-module/palette-edit/index.js.map +1 -1
  227. package/build-module/popover/index.js +10 -2
  228. package/build-module/popover/index.js.map +1 -1
  229. package/build-module/query-controls/index.js +1 -0
  230. package/build-module/query-controls/index.js.map +1 -1
  231. package/build-module/snackbar/index.js +33 -23
  232. package/build-module/snackbar/index.js.map +1 -1
  233. package/build-module/snackbar/list.js +14 -22
  234. package/build-module/snackbar/list.js.map +1 -1
  235. package/build-module/snackbar/types.js +2 -0
  236. package/build-module/snackbar/types.js.map +1 -0
  237. package/build-module/tab-panel/index.js +15 -8
  238. package/build-module/tab-panel/index.js.map +1 -1
  239. package/build-module/theme/color-algorithms.js +105 -0
  240. package/build-module/theme/color-algorithms.js.map +1 -0
  241. package/build-module/theme/index.js +21 -17
  242. package/build-module/theme/index.js.map +1 -1
  243. package/build-module/theme/styles.js +8 -6
  244. package/build-module/theme/styles.js.map +1 -1
  245. package/build-module/toggle-control/index.js +4 -2
  246. package/build-module/toggle-control/index.js.map +1 -1
  247. package/build-module/ui/context/context-system-provider.js +3 -2
  248. package/build-module/ui/context/context-system-provider.js.map +1 -1
  249. package/build-module/unit-control/index.js +5 -2
  250. package/build-module/unit-control/index.js.map +1 -1
  251. package/build-module/utils/colors-values.js +1 -1
  252. package/build-module/utils/colors-values.js.map +1 -1
  253. package/build-module/utils/config-values.js +0 -2
  254. package/build-module/utils/config-values.js.map +1 -1
  255. package/build-module/utils/hooks/use-controlled-value.js.map +1 -1
  256. package/build-style/style-rtl.css +108 -104
  257. package/build-style/style.css +108 -104
  258. package/build-types/alignment-matrix-control/cell.d.ts +5 -0
  259. package/build-types/alignment-matrix-control/cell.d.ts.map +1 -0
  260. package/build-types/alignment-matrix-control/icon.d.ts +6 -0
  261. package/build-types/alignment-matrix-control/icon.d.ts.map +1 -0
  262. package/build-types/alignment-matrix-control/index.d.ts +30 -0
  263. package/build-types/alignment-matrix-control/index.d.ts.map +1 -0
  264. package/build-types/alignment-matrix-control/stories/index.d.ts +14 -0
  265. package/build-types/alignment-matrix-control/stories/index.d.ts.map +1 -0
  266. package/build-types/alignment-matrix-control/styles/alignment-matrix-control-icon-styles.d.ts +19 -0
  267. package/build-types/alignment-matrix-control/styles/alignment-matrix-control-icon-styles.d.ts.map +1 -0
  268. package/build-types/alignment-matrix-control/styles/alignment-matrix-control-styles.d.ts +23 -0
  269. package/build-types/alignment-matrix-control/styles/alignment-matrix-control-styles.d.ts.map +1 -0
  270. package/build-types/alignment-matrix-control/test/index.d.ts +2 -0
  271. package/build-types/alignment-matrix-control/test/index.d.ts.map +1 -0
  272. package/build-types/alignment-matrix-control/types.d.ts +39 -0
  273. package/build-types/alignment-matrix-control/types.d.ts.map +1 -0
  274. package/build-types/alignment-matrix-control/utils.d.ts +33 -0
  275. package/build-types/alignment-matrix-control/utils.d.ts.map +1 -0
  276. package/build-types/base-control/hooks.d.ts +23 -0
  277. package/build-types/base-control/hooks.d.ts.map +1 -0
  278. package/build-types/base-control/index.d.ts +17 -7
  279. package/build-types/base-control/index.d.ts.map +1 -1
  280. package/build-types/base-control/stories/index.d.ts.map +1 -1
  281. package/build-types/base-control/test/index.d.ts +2 -0
  282. package/build-types/base-control/test/index.d.ts.map +1 -0
  283. package/build-types/base-control/types.d.ts +8 -2
  284. package/build-types/base-control/types.d.ts.map +1 -1
  285. package/build-types/base-field/hook.d.ts +7 -31
  286. package/build-types/base-field/hook.d.ts.map +1 -1
  287. package/build-types/base-field/index.d.ts +1 -1
  288. package/build-types/base-field/index.d.ts.map +1 -1
  289. package/build-types/base-field/styles.d.ts +5 -5
  290. package/build-types/base-field/styles.d.ts.map +1 -1
  291. package/build-types/base-field/test/index.d.ts +2 -0
  292. package/build-types/base-field/test/index.d.ts.map +1 -0
  293. package/build-types/base-field/types.d.ts +29 -0
  294. package/build-types/base-field/types.d.ts.map +1 -0
  295. package/build-types/border-box-control/border-box-control/component.d.ts +1 -1
  296. package/build-types/border-box-control/border-box-control/component.d.ts.map +1 -1
  297. package/build-types/border-box-control/border-box-control/hook.d.ts +2 -3
  298. package/build-types/border-box-control/border-box-control/hook.d.ts.map +1 -1
  299. package/build-types/border-box-control/border-box-control-linked-button/hook.d.ts +2 -2
  300. package/build-types/border-box-control/border-box-control-split-controls/component.d.ts +1 -1
  301. package/build-types/border-box-control/border-box-control-split-controls/component.d.ts.map +1 -1
  302. package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts +2 -3
  303. package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts.map +1 -1
  304. package/build-types/border-box-control/border-box-control-visualizer/hook.d.ts +2 -2
  305. package/build-types/border-box-control/stories/index.d.ts +1 -1
  306. package/build-types/border-control/border-control/component.d.ts +1 -1
  307. package/build-types/border-control/border-control/component.d.ts.map +1 -1
  308. package/build-types/border-control/border-control/hook.d.ts +2 -3
  309. package/build-types/border-control/border-control/hook.d.ts.map +1 -1
  310. package/build-types/border-control/border-control-dropdown/component.d.ts +1 -1
  311. package/build-types/border-control/border-control-dropdown/component.d.ts.map +1 -1
  312. package/build-types/border-control/border-control-dropdown/hook.d.ts +2 -3
  313. package/build-types/border-control/border-control-dropdown/hook.d.ts.map +1 -1
  314. package/build-types/border-control/border-control-style-picker/hook.d.ts +2 -2
  315. package/build-types/border-control/stories/index.d.ts +6 -6
  316. package/build-types/border-control/stories/index.d.ts.map +1 -1
  317. package/build-types/border-control/styles.d.ts.map +1 -1
  318. package/build-types/border-control/types.d.ts +1 -1
  319. package/build-types/border-control/types.d.ts.map +1 -1
  320. package/build-types/card/card/hook.d.ts +2 -2
  321. package/build-types/card/card-body/hook.d.ts +2 -2
  322. package/build-types/card/card-divider/hook.d.ts +2 -2
  323. package/build-types/card/card-footer/hook.d.ts +2 -2
  324. package/build-types/card/card-header/hook.d.ts +2 -2
  325. package/build-types/card/card-media/hook.d.ts +2 -2
  326. package/build-types/color-palette/index.d.ts +3 -4
  327. package/build-types/color-palette/index.d.ts.map +1 -1
  328. package/build-types/color-palette/stories/index.d.ts +6 -14
  329. package/build-types/color-palette/stories/index.d.ts.map +1 -1
  330. package/build-types/color-palette/styles.d.ts +1 -1
  331. package/build-types/color-palette/types.d.ts +4 -17
  332. package/build-types/color-palette/types.d.ts.map +1 -1
  333. package/build-types/color-picker/input-with-slider.d.ts.map +1 -1
  334. package/build-types/color-picker/styles.d.ts +5 -5
  335. package/build-types/color-picker/styles.d.ts.map +1 -1
  336. package/build-types/custom-select-control/index.d.ts.map +1 -1
  337. package/build-types/dashicon/index.d.ts +6 -20
  338. package/build-types/dashicon/index.d.ts.map +1 -1
  339. package/build-types/dashicon/types.d.ts +14 -0
  340. package/build-types/dashicon/types.d.ts.map +1 -1
  341. package/build-types/date-time/date/styles.d.ts +3 -3
  342. package/build-types/date-time/date-time/styles.d.ts +3 -3
  343. package/build-types/date-time/time/styles.d.ts +8 -8
  344. package/build-types/disabled/stories/index.d.ts.map +1 -1
  345. package/build-types/dropdown/index.d.ts +29 -1
  346. package/build-types/dropdown/index.d.ts.map +1 -1
  347. package/build-types/dropdown/stories/index.d.ts +23 -0
  348. package/build-types/dropdown/stories/index.d.ts.map +1 -0
  349. package/build-types/dropdown/test/index.d.ts +2 -0
  350. package/build-types/dropdown/test/index.d.ts.map +1 -0
  351. package/build-types/dropdown/types.d.ts +101 -0
  352. package/build-types/dropdown/types.d.ts.map +1 -1
  353. package/build-types/elevation/hook.d.ts +2 -2
  354. package/build-types/external-link/styles/external-link-styles.d.ts +1 -1
  355. package/build-types/flex/flex/hook.d.ts +2 -2
  356. package/build-types/flex/flex-block/hook.d.ts +2 -2
  357. package/build-types/flex/flex-item/hook.d.ts +2 -2
  358. package/build-types/focal-point-picker/styles/focal-point-picker-style.d.ts +2 -5
  359. package/build-types/focal-point-picker/styles/focal-point-picker-style.d.ts.map +1 -1
  360. package/build-types/grid/hook.d.ts +2 -2
  361. package/build-types/h-stack/component.d.ts +1 -1
  362. package/build-types/h-stack/hook.d.ts +2 -2
  363. package/build-types/heading/hook.d.ts +2 -2
  364. package/build-types/icon/stories/index.d.ts +22 -0
  365. package/build-types/icon/stories/index.d.ts.map +1 -0
  366. package/build-types/input-control/index.d.ts +1 -1
  367. package/build-types/input-control/index.d.ts.map +1 -1
  368. package/build-types/input-control/input-base.d.ts.map +1 -1
  369. package/build-types/input-control/stories/index.d.ts +1 -0
  370. package/build-types/input-control/stories/index.d.ts.map +1 -1
  371. package/build-types/input-control/types.d.ts +2 -1
  372. package/build-types/input-control/types.d.ts.map +1 -1
  373. package/build-types/item-group/item/hook.d.ts +2 -2
  374. package/build-types/item-group/item-group/hook.d.ts +2 -2
  375. package/build-types/modal/index.d.ts.map +1 -1
  376. package/build-types/modal/stories/index.d.ts.map +1 -1
  377. package/build-types/navigator/navigator-back-button/hook.d.ts +3 -3
  378. package/build-types/navigator/navigator-button/hook.d.ts +3 -3
  379. package/build-types/navigator/navigator-provider/component.d.ts.map +1 -1
  380. package/build-types/number-control/index.d.ts +2 -2
  381. package/build-types/number-control/index.d.ts.map +1 -1
  382. package/build-types/number-control/stories/index.d.ts +25 -0
  383. package/build-types/number-control/stories/index.d.ts.map +1 -0
  384. package/build-types/number-control/styles/number-control-styles.d.ts +6 -6
  385. package/build-types/number-control/styles/number-control-styles.d.ts.map +1 -1
  386. package/build-types/number-control/test/index.d.ts +2 -0
  387. package/build-types/number-control/test/index.d.ts.map +1 -0
  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/stories/e2e/index.d.ts +1 -1
  391. package/build-types/range-control/index.d.ts +1 -1
  392. package/build-types/range-control/styles/range-control-styles.d.ts +2 -2
  393. package/build-types/resizable-box/resize-tooltip/index.d.ts +15 -19
  394. package/build-types/resizable-box/resize-tooltip/index.d.ts.map +1 -1
  395. package/build-types/resizable-box/resize-tooltip/label.d.ts +4 -3
  396. package/build-types/resizable-box/resize-tooltip/label.d.ts.map +1 -1
  397. package/build-types/scrollable/hook.d.ts +2 -2
  398. package/build-types/search-control/index.d.ts +1 -1
  399. package/build-types/search-control/stories/index.d.ts +2 -2
  400. package/build-types/snackbar/index.d.ts +19 -0
  401. package/build-types/snackbar/index.d.ts.map +1 -0
  402. package/build-types/snackbar/list.d.ts +18 -0
  403. package/build-types/snackbar/list.d.ts.map +1 -0
  404. package/build-types/snackbar/stories/index.d.ts +16 -0
  405. package/build-types/snackbar/stories/index.d.ts.map +1 -0
  406. package/build-types/snackbar/stories/list.d.ts +12 -0
  407. package/build-types/snackbar/stories/list.d.ts.map +1 -0
  408. package/build-types/snackbar/types.d.ts +111 -0
  409. package/build-types/snackbar/types.d.ts.map +1 -0
  410. package/build-types/spacer/hook.d.ts +2 -2
  411. package/build-types/spinner/index.d.ts +1 -1
  412. package/build-types/surface/hook.d.ts +2 -2
  413. package/build-types/tab-panel/index.d.ts +1 -1
  414. package/build-types/tab-panel/index.d.ts.map +1 -1
  415. package/build-types/tab-panel/types.d.ts +19 -1
  416. package/build-types/tab-panel/types.d.ts.map +1 -1
  417. package/build-types/text/hook.d.ts +2 -2
  418. package/build-types/text-control/index.d.ts +2 -2
  419. package/build-types/text-control/stories/index.d.ts.map +1 -1
  420. package/build-types/text-control/types.d.ts +1 -5
  421. package/build-types/text-control/types.d.ts.map +1 -1
  422. package/build-types/theme/color-algorithms.d.ts +20 -0
  423. package/build-types/theme/color-algorithms.d.ts.map +1 -0
  424. package/build-types/theme/index.d.ts +1 -1
  425. package/build-types/theme/index.d.ts.map +1 -1
  426. package/build-types/theme/stories/index.d.ts +4 -0
  427. package/build-types/theme/stories/index.d.ts.map +1 -1
  428. package/build-types/theme/styles.d.ts +3 -2
  429. package/build-types/theme/styles.d.ts.map +1 -1
  430. package/build-types/theme/test/color-algorithms.d.ts +2 -0
  431. package/build-types/theme/test/color-algorithms.d.ts.map +1 -0
  432. package/build-types/theme/types.d.ts +41 -3
  433. package/build-types/theme/types.d.ts.map +1 -1
  434. package/build-types/toggle-control/index.d.ts.map +1 -1
  435. package/build-types/toggle-group-control/toggle-group-control/as-button-group.d.ts +2 -2
  436. package/build-types/toggle-group-control/toggle-group-control/as-radio-group.d.ts +2 -2
  437. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts +1 -1
  438. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts +1 -1
  439. package/build-types/tools-panel/tools-panel/hook.d.ts +2 -2
  440. package/build-types/tools-panel/tools-panel-header/hook.d.ts +2 -2
  441. package/build-types/tools-panel/tools-panel-item/hook.d.ts +2 -2
  442. package/build-types/truncate/hook.d.ts +2 -2
  443. package/build-types/ui/context/context-system-provider.d.ts.map +1 -1
  444. package/build-types/ui/control-group/hook.d.ts +2 -2
  445. package/build-types/ui/control-label/hook.d.ts +2 -2
  446. package/build-types/ui/form-group/form-group.d.ts +2 -2
  447. package/build-types/ui/form-group/use-form-group.d.ts +5 -5
  448. package/build-types/unit-control/index.d.ts +2 -1
  449. package/build-types/unit-control/index.d.ts.map +1 -1
  450. package/build-types/unit-control/styles/unit-control-styles.d.ts +2 -2
  451. package/build-types/unit-control/types.d.ts +4 -0
  452. package/build-types/unit-control/types.d.ts.map +1 -1
  453. package/build-types/utils/config-values.d.ts +0 -2
  454. package/build-types/utils/hooks/use-controlled-value.d.ts +2 -1
  455. package/build-types/utils/hooks/use-controlled-value.d.ts.map +1 -1
  456. package/build-types/v-stack/component.d.ts +2 -2
  457. package/build-types/v-stack/hook.d.ts +2 -2
  458. package/build-types/v-stack/stories/index.d.ts +2 -2
  459. package/package.json +21 -20
  460. package/src/alignment-matrix-control/README.md +7 -7
  461. package/src/alignment-matrix-control/{cell.js → cell.tsx} +7 -1
  462. package/src/alignment-matrix-control/{icon.js → icon.tsx} +6 -3
  463. package/src/alignment-matrix-control/{index.js → index.tsx} +31 -4
  464. package/src/alignment-matrix-control/stories/{index.js → index.tsx} +17 -9
  465. package/src/alignment-matrix-control/styles/{alignment-matrix-control-icon-styles.js → alignment-matrix-control-icon-styles.ts} +11 -3
  466. package/src/alignment-matrix-control/styles/{alignment-matrix-control-styles.js → alignment-matrix-control-styles.ts} +13 -3
  467. package/src/alignment-matrix-control/test/{index.js → index.tsx} +5 -5
  468. package/src/alignment-matrix-control/types.ts +54 -0
  469. package/src/alignment-matrix-control/{utils.js → utils.tsx} +24 -14
  470. package/src/angle-picker-control/styles/angle-picker-control-styles.js +4 -0
  471. package/src/autocomplete/index.js +44 -15
  472. package/src/autocomplete/test/index.js +2 -0
  473. package/src/base-control/README.md +21 -12
  474. package/src/base-control/hooks.ts +45 -0
  475. package/src/base-control/index.tsx +18 -7
  476. package/src/base-control/stories/index.tsx +8 -10
  477. package/src/base-control/test/index.tsx +53 -0
  478. package/src/base-control/types.ts +8 -2
  479. package/src/base-field/README.md +21 -22
  480. package/src/base-field/{hook.js → hook.ts} +5 -15
  481. package/src/base-field/{index.js → index.ts} +0 -0
  482. package/src/base-field/{styles.js → styles.ts} +2 -2
  483. package/src/base-field/test/__snapshots__/{index.js.snap → index.tsx.snap} +4 -4
  484. package/src/base-field/test/{index.js → index.tsx} +10 -5
  485. package/src/base-field/types.ts +29 -0
  486. package/src/border-box-control/border-box-control/README.md +1 -0
  487. package/src/border-box-control/border-box-control/component.tsx +0 -7
  488. package/src/border-box-control/border-box-control/hook.ts +0 -2
  489. package/src/border-box-control/border-box-control-split-controls/component.tsx +0 -2
  490. package/src/border-box-control/border-box-control-split-controls/hook.ts +0 -2
  491. package/src/border-box-control/test/index.js +5 -1
  492. package/src/border-control/border-control/component.tsx +1 -4
  493. package/src/border-control/border-control/hook.ts +0 -2
  494. package/src/border-control/border-control-dropdown/component.tsx +11 -17
  495. package/src/border-control/border-control-dropdown/hook.ts +0 -2
  496. package/src/border-control/stories/index.tsx +0 -1
  497. package/src/border-control/styles.ts +1 -10
  498. package/src/border-control/test/index.js +70 -67
  499. package/src/border-control/types.ts +1 -4
  500. package/src/box-control/linked-button.js +8 -11
  501. package/src/box-control/test/index.js +207 -134
  502. package/src/button/stories/index.js +30 -0
  503. package/src/button/style.scss +17 -14
  504. package/src/button/test/index.js +32 -15
  505. package/src/card/test/index.tsx +32 -20
  506. package/src/checkbox-control/test/index.tsx +2 -0
  507. package/src/circular-option-picker/style.scss +1 -0
  508. package/src/color-palette/index.tsx +16 -18
  509. package/src/color-palette/stories/index.tsx +1 -18
  510. package/src/color-palette/test/__snapshots__/index.tsx.snap +4 -4
  511. package/src/color-palette/test/index.tsx +86 -36
  512. package/src/color-palette/types.ts +4 -18
  513. package/src/color-picker/README.md +1 -0
  514. package/src/color-picker/input-with-slider.tsx +1 -0
  515. package/src/color-picker/styles.ts +0 -4
  516. package/src/color-picker/test/index.js +2 -0
  517. package/src/combobox-control/test/index.js +2 -0
  518. package/src/confirm-dialog/README.md +3 -2
  519. package/src/confirm-dialog/test/index.js +2 -0
  520. package/src/custom-select-control/README.md +14 -0
  521. package/src/custom-select-control/index.js +14 -2
  522. package/src/dashicon/{index.js → index.tsx} +10 -4
  523. package/src/dashicon/types.ts +17 -0
  524. package/src/date-time/date/test/index.tsx +2 -0
  525. package/src/date-time/date-time/index.tsx +2 -2
  526. package/src/date-time/time/test/index.tsx +2 -0
  527. package/src/dimension-control/index.js +2 -3
  528. package/src/dimension-control/test/__snapshots__/index.test.js.snap +4 -8
  529. package/src/dimension-control/test/index.test.js +2 -0
  530. package/src/disabled/stories/index.tsx +6 -2
  531. package/src/disabled/test/index.tsx +23 -11
  532. package/src/dropdown/README.md +41 -46
  533. package/src/dropdown/{index.js → index.tsx} +57 -13
  534. package/src/dropdown/stories/{index.js → index.tsx} +21 -8
  535. package/src/dropdown/test/index.tsx +88 -0
  536. package/src/dropdown/types.ts +107 -0
  537. package/src/dropdown-menu/README.md +2 -3
  538. package/src/dropdown-menu/test/index.js +20 -12
  539. package/src/duotone-picker/duotone-picker.js +2 -2
  540. package/src/external-link/test/index.tsx +2 -0
  541. package/src/focal-point-picker/test/index.js +2 -0
  542. package/src/focal-point-picker/test/media.js +26 -21
  543. package/src/font-size-picker/test/index.tsx +2 -0
  544. package/src/form-file-upload/test/index.tsx +2 -0
  545. package/src/form-toggle/test/index.tsx +2 -0
  546. package/src/form-token-field/style.scss +1 -1
  547. package/src/form-token-field/test/index.tsx +3 -0
  548. package/src/gradient-picker/index.js +6 -10
  549. package/src/gradient-picker/stories/index.js +0 -1
  550. package/src/grid/test/grid.tsx +31 -31
  551. package/src/guide/test/index.js +2 -0
  552. package/src/higher-order/navigate-regions/index.js +5 -2
  553. package/src/higher-order/navigate-regions/style.scss +13 -59
  554. package/src/higher-order/with-fallback-styles/index.js +4 -2
  555. package/src/higher-order/with-filters/test/index.js +32 -43
  556. package/src/higher-order/with-focus-outside/test/index.js +2 -0
  557. package/src/higher-order/with-focus-return/test/index.js +3 -4
  558. package/src/higher-order/with-notices/test/index.js +1 -0
  559. package/src/icon/stories/index.tsx +103 -0
  560. package/src/index.js +2 -3
  561. package/src/input-control/index.tsx +42 -28
  562. package/src/input-control/input-base.tsx +8 -1
  563. package/src/input-control/stories/index.tsx +6 -0
  564. package/src/input-control/test/index.js +21 -0
  565. package/src/input-control/types.ts +2 -0
  566. package/src/isolated-event-container/test/index.js +2 -0
  567. package/src/mobile/bottom-sheet/cell.native.js +1 -1
  568. package/src/mobile/bottom-sheet/picker-cell.native.js +1 -6
  569. package/src/mobile/bottom-sheet/switch-cell.native.js +2 -2
  570. package/src/mobile/global-styles-context/index.native.js +9 -11
  571. package/src/mobile/global-styles-context/utils.native.js +17 -16
  572. package/src/mobile/keyboard-aware-flat-list/index.ios.js +2 -2
  573. package/src/mobile/link-settings/test/edit.native.js +68 -124
  574. package/src/modal/index.tsx +11 -0
  575. package/src/modal/stories/index.tsx +3 -0
  576. package/src/modal/test/index.tsx +13 -0
  577. package/src/navigable-container/test/navigable-menu.js +2 -0
  578. package/src/navigable-container/test/tababble-container.js +2 -0
  579. package/src/navigation/stories/index.js +6 -6
  580. package/src/navigation/stories/{controlled-state.js → utils/controlled-state.js} +3 -3
  581. package/src/navigation/stories/{default.js → utils/default.js} +3 -3
  582. package/src/navigation/stories/{group.js → utils/group.js} +4 -4
  583. package/src/navigation/stories/{hide-if-empty.js → utils/hide-if-empty.js} +3 -3
  584. package/src/navigation/stories/{more-examples.js → utils/more-examples.js} +4 -4
  585. package/src/navigation/stories/{search.js → utils/search.js} +5 -5
  586. package/src/navigation/test/index.js +2 -0
  587. package/src/navigator/navigator-provider/component.tsx +13 -10
  588. package/src/navigator/test/index.tsx +2 -0
  589. package/src/notice/test/index.js +8 -3
  590. package/src/notice/test/list.js +8 -5
  591. package/src/number-control/stories/{index.js → index.tsx} +24 -7
  592. package/src/number-control/styles/{number-control-styles.js → number-control-styles.ts} +5 -3
  593. package/src/number-control/test/index.tsx +602 -0
  594. package/src/palette-edit/index.js +88 -39
  595. package/src/palette-edit/test/index.js +25 -1
  596. package/src/panel/test/__snapshots__/body.js.snap +9 -0
  597. package/src/panel/test/body.js +71 -62
  598. package/src/placeholder/test/index.tsx +3 -0
  599. package/src/popover/index.tsx +10 -2
  600. package/src/popover/style.scss +12 -11
  601. package/src/popover/test/index.tsx +25 -15
  602. package/src/query-controls/index.js +1 -0
  603. package/src/range-control/test/index.tsx +57 -60
  604. package/src/resizable-box/style.scss +1 -0
  605. package/src/sandbox/test/index.js +13 -11
  606. package/src/search-control/style.scss +4 -0
  607. package/src/select-control/test/select-control.tsx +2 -0
  608. package/src/snackbar/README.md +63 -8
  609. package/src/snackbar/{index.js → index.tsx} +46 -28
  610. package/src/snackbar/{list.js → list.tsx} +20 -21
  611. package/src/snackbar/stories/index.tsx +96 -0
  612. package/src/snackbar/stories/list.tsx +98 -0
  613. package/src/snackbar/types.ts +116 -0
  614. package/src/tab-panel/README.md +9 -0
  615. package/src/tab-panel/index.tsx +15 -5
  616. package/src/tab-panel/style.scss +46 -34
  617. package/src/tab-panel/test/index.tsx +113 -0
  618. package/src/tab-panel/types.ts +20 -1
  619. package/src/text/test/__snapshots__/index.tsx.snap +1 -0
  620. package/src/text/test/index.tsx +98 -46
  621. package/src/text-control/stories/index.tsx +0 -1
  622. package/src/text-control/types.ts +1 -6
  623. package/src/text-highlight/test/index.tsx +1 -0
  624. package/src/theme/README.md +32 -2
  625. package/src/theme/color-algorithms.ts +138 -0
  626. package/src/theme/index.tsx +23 -16
  627. package/src/theme/stories/index.tsx +67 -0
  628. package/src/theme/styles.ts +22 -17
  629. package/src/theme/test/color-algorithms.ts +100 -0
  630. package/src/theme/test/index.tsx +68 -35
  631. package/src/theme/types.ts +43 -3
  632. package/src/toggle-control/index.tsx +4 -2
  633. package/src/toggle-group-control/test/index.tsx +15 -2
  634. package/src/toolbar/style.scss +1 -1
  635. package/src/toolbar-group/test/index.js +10 -6
  636. package/src/tools-panel/stories/index.js +1 -1
  637. package/src/tools-panel/stories/{tools-panel-with-item-group-slot.js → utils/tools-panel-with-item-group-slot.js} +14 -11
  638. package/src/tools-panel/test/index.js +20 -14
  639. package/src/tooltip/README.md +7 -0
  640. package/src/tooltip/stories/index.js +68 -78
  641. package/src/tooltip/style.scss +2 -2
  642. package/src/tooltip/test/index.js +111 -18
  643. package/src/ui/context/context-system-provider.js +3 -2
  644. package/src/ui/context/test/context-system-provider.js +5 -4
  645. package/src/ui/control-label/test/index.js +3 -5
  646. package/src/unit-control/README.md +9 -1
  647. package/src/unit-control/index.tsx +3 -0
  648. package/src/unit-control/test/index.tsx +4 -0
  649. package/src/unit-control/types.ts +4 -0
  650. package/src/utils/colors-values.js +1 -1
  651. package/src/utils/config-values.js +0 -2
  652. package/src/utils/hooks/test/use-latest-ref.js +2 -0
  653. package/src/utils/hooks/use-controlled-value.ts +2 -2
  654. package/src/utils/theme-variables.scss +20 -0
  655. package/tsconfig.json +2 -4
  656. package/tsconfig.tsbuildinfo +1 -1
  657. package/src/dropdown/test/index.js +0 -98
  658. package/src/icon/stories/index.js +0 -128
  659. package/src/number-control/test/index.js +0 -478
  660. package/src/snackbar/stories/index.js +0 -89
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * External dependencies
3
3
  */
4
- import { render, screen } from '@testing-library/react';
4
+ import { act, render, screen } from '@testing-library/react';
5
5
 
6
6
  /**
7
7
  * WordPress dependencies
@@ -76,20 +76,20 @@ describe( 'Button', () => {
76
76
  expect( screen.getByRole( 'button' ) ).toHaveClass( 'is-pressed' );
77
77
  } );
78
78
 
79
- it( 'should render a button element with has-text when children are passed', async () => {
79
+ it( 'should render a button element with has-text when children are passed', () => {
80
80
  render( <Button icon={ plusCircle }>Children</Button> );
81
- await screen.getByRole( 'button' ).focus();
81
+ act( () => screen.getByRole( 'button' ).focus() );
82
82
  expect( screen.getByRole( 'button' ) ).toHaveClass( 'has-text' );
83
83
  } );
84
84
 
85
- it( 'should render a button element without has-text when children are not passed', async () => {
85
+ it( 'should render a button element without has-text when children are not passed', () => {
86
86
  render( <Button icon={ plusCircle }></Button> );
87
87
  expect( screen.getByRole( 'button' ) ).not.toHaveClass(
88
88
  'has-text'
89
89
  );
90
90
  } );
91
91
 
92
- it( 'should render a button element without has-text when children are empty fragment', async () => {
92
+ it( 'should render a button element without has-text when children are empty fragment', () => {
93
93
  render(
94
94
  <Button icon={ plusCircle }>
95
95
  <></>
@@ -100,7 +100,7 @@ describe( 'Button', () => {
100
100
  );
101
101
  } );
102
102
 
103
- it( 'should render a button element without has-text when a button wrapped in Tooltip', async () => {
103
+ it( 'should render a button element without has-text when a button wrapped in Tooltip', () => {
104
104
  render(
105
105
  <Tooltip text="Help text">
106
106
  <Button icon={ plusCircle } />
@@ -184,10 +184,15 @@ describe( 'Button', () => {
184
184
 
185
185
  it( 'should add an aria-label when the label property is used, with Tooltip wrapper', async () => {
186
186
  render( <Button icon={ plusCircle } label="WordPress" /> );
187
+ // Wait for the `floating-ui` effects in `Tooltip`/`Popover` to finish running
188
+ // See also: https://floating-ui.com/docs/react-dom#testing
189
+ await act( () => Promise.resolve() );
187
190
 
188
191
  expect( screen.queryByText( 'WordPress' ) ).not.toBeInTheDocument();
189
192
 
190
- await screen.getByRole( 'button', { name: 'WordPress' } ).focus();
193
+ await act( () => {
194
+ screen.getByRole( 'button', { name: 'WordPress' } ).focus();
195
+ } );
191
196
 
192
197
  expect( screen.getByText( 'WordPress' ) ).toBeVisible();
193
198
  } );
@@ -218,15 +223,18 @@ describe( 'Button', () => {
218
223
  icon={ plusCircle }
219
224
  />
220
225
  );
226
+ await act( () => Promise.resolve() );
221
227
 
222
228
  expect( screen.queryByText( 'Label' ) ).not.toBeInTheDocument();
223
229
 
224
- await screen.getByRole( 'button', { name: 'Label' } ).focus();
230
+ await act( async () => {
231
+ screen.getByRole( 'button', { name: 'Label' } ).focus();
232
+ } );
225
233
 
226
234
  expect( screen.getByText( 'Label' ) ).toBeVisible();
227
235
  } );
228
236
 
229
- it( 'should populate tooltip with description content for buttons with visible labels (buttons with children)', () => {
237
+ it( 'should populate tooltip with description content for buttons with visible labels (buttons with children)', async () => {
230
238
  render(
231
239
  <Button
232
240
  label="Label"
@@ -237,6 +245,7 @@ describe( 'Button', () => {
237
245
  Children
238
246
  </Button>
239
247
  );
248
+ await act( () => Promise.resolve() );
240
249
 
241
250
  expect(
242
251
  screen.getByRole( 'button', {
@@ -245,7 +254,7 @@ describe( 'Button', () => {
245
254
  ).toBeVisible();
246
255
  } );
247
256
 
248
- it( 'should allow tooltip disable', async () => {
257
+ it( 'should allow tooltip disable', () => {
249
258
  render(
250
259
  <Button
251
260
  icon={ plusCircle }
@@ -259,7 +268,7 @@ describe( 'Button', () => {
259
268
 
260
269
  expect( screen.queryByText( 'WordPress' ) ).not.toBeInTheDocument();
261
270
 
262
- await button.focus();
271
+ act( () => button.focus() );
263
272
 
264
273
  expect( screen.queryByText( 'WordPress' ) ).not.toBeInTheDocument();
265
274
  } );
@@ -268,15 +277,18 @@ describe( 'Button', () => {
268
277
  render(
269
278
  <Button icon={ plusCircle } label="WordPress" children={ [] } />
270
279
  );
280
+ await act( () => Promise.resolve() );
271
281
 
272
282
  expect( screen.queryByText( 'WordPress' ) ).not.toBeInTheDocument();
273
283
 
274
- await screen.getByRole( 'button', { name: 'WordPress' } ).focus();
284
+ await act( async () => {
285
+ screen.getByRole( 'button', { name: 'WordPress' } ).focus();
286
+ } );
275
287
 
276
288
  expect( screen.getByText( 'WordPress' ) ).toBeVisible();
277
289
  } );
278
290
 
279
- it( 'should not show the tooltip when icon and children defined', async () => {
291
+ it( 'should not show the tooltip when icon and children defined', () => {
280
292
  render(
281
293
  <Button icon={ plusCircle } label="WordPress">
282
294
  Children
@@ -285,7 +297,9 @@ describe( 'Button', () => {
285
297
 
286
298
  expect( screen.queryByText( 'WordPress' ) ).not.toBeInTheDocument();
287
299
 
288
- await screen.getByRole( 'button', { name: 'WordPress' } ).focus();
300
+ act( () => {
301
+ screen.getByRole( 'button', { name: 'WordPress' } ).focus();
302
+ } );
289
303
 
290
304
  expect( screen.queryByText( 'WordPress' ) ).not.toBeInTheDocument();
291
305
  } );
@@ -296,10 +310,13 @@ describe( 'Button', () => {
296
310
  Children
297
311
  </Button>
298
312
  );
313
+ await act( () => Promise.resolve() );
299
314
 
300
315
  expect( screen.queryByText( 'WordPress' ) ).not.toBeInTheDocument();
301
316
 
302
- await screen.getByRole( 'button', { name: 'WordPress' } ).focus();
317
+ await act( async () => {
318
+ screen.getByRole( 'button', { name: 'WordPress' } ).focus();
319
+ } );
303
320
 
304
321
  expect( screen.getByText( 'WordPress' ) ).toBeVisible();
305
322
  } );
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * External dependencies
3
3
  */
4
- import { render } from '@testing-library/react';
4
+ import { render, screen } from '@testing-library/react';
5
5
 
6
6
  /**
7
7
  * Internal dependencies
@@ -38,27 +38,39 @@ describe( 'Card', () => {
38
38
  } );
39
39
 
40
40
  it( 'should remove borders when the isBorderless prop is true', () => {
41
- const { rerender, container } = render(
42
- <Card>Code is Poetry</Card>
41
+ const { rerender } = render(
42
+ <Card data-testid="card-wrapper">Code is Poetry</Card>
43
43
  );
44
- expect( container.firstChild ).not.toHaveStyle(
44
+
45
+ expect( screen.getByTestId( 'card-wrapper' ) ).not.toHaveStyle(
45
46
  'box-shadow: none'
46
47
  );
47
48
 
48
- rerender( <Card isBorderless={ true }>Code is Poetry</Card> );
49
- expect( container.firstChild ).toHaveStyle( 'box-shadow: none' );
49
+ rerender(
50
+ <Card data-testid="card-wrapper" isBorderless>
51
+ Code is Poetry
52
+ </Card>
53
+ );
54
+
55
+ expect( screen.getByTestId( 'card-wrapper' ) ).toHaveStyle(
56
+ 'box-shadow: none'
57
+ );
50
58
  } );
51
59
 
52
60
  it( 'should add rounded border when the isRounded prop is true', () => {
53
- const { container: containerRounded } = render(
54
- <Card isRounded={ true }>Code is Poetry</Card>
61
+ render(
62
+ <Card data-testid="card-rounded" isRounded>
63
+ Code is Poetry
64
+ </Card>
55
65
  );
56
- const { container: containerSquared } = render(
57
- <Card isRounded={ false }>Code is Poetry</Card>
66
+ render(
67
+ <Card data-testid="card-squared" isRounded={ false }>
68
+ Code is Poetry
69
+ </Card>
58
70
  );
59
71
  expect(
60
- containerRounded.firstElementChild
61
- ).toMatchStyleDiffSnapshot( containerSquared.firstElementChild );
72
+ screen.getByTestId( 'card-rounded' )
73
+ ).toMatchStyleDiffSnapshot( screen.getByTestId( 'card-squared' ) );
62
74
  } );
63
75
 
64
76
  it( 'should show a box shadow when the elevation prop is greater than 0', () => {
@@ -94,7 +106,7 @@ describe( 'Card', () => {
94
106
  it( 'should warn when the isElevated prop is passed', () => {
95
107
  // `isElevated` is automatically converted to `elevation="2"`
96
108
  const { container } = render(
97
- <Card isElevated={ true }>Code is Poetry</Card>
109
+ <Card isElevated>Code is Poetry</Card>
98
110
  );
99
111
  expect( container ).toMatchSnapshot();
100
112
 
@@ -103,7 +115,7 @@ describe( 'Card', () => {
103
115
 
104
116
  it( 'should pass the isBorderless and isSize props from its context to its sub-components', () => {
105
117
  const { container: withoutBorderLarge } = render(
106
- <Card isBorderless={ true } size="large">
118
+ <Card isBorderless size="large">
107
119
  <CardHeader>Header</CardHeader>
108
120
  <CardBody>Body</CardBody>
109
121
  <CardFooter>Footer</CardFooter>
@@ -121,14 +133,14 @@ describe( 'Card', () => {
121
133
 
122
134
  it( 'should get the isBorderless and isSize props (passed from its context) overriddenwhen the same props is specified directly on the component', () => {
123
135
  const { container: withoutBorder } = render(
124
- <Card isBorderless={ true } size="large">
136
+ <Card isBorderless size="large">
125
137
  <CardHeader>Header</CardHeader>
126
138
  <CardBody>Body</CardBody>
127
139
  <CardFooter>Footer</CardFooter>
128
140
  </Card>
129
141
  );
130
142
  const { container: withBorder } = render(
131
- <Card isBorderless={ true } size="large">
143
+ <Card isBorderless size="large">
132
144
  <CardHeader isBorderless={ false } size="small">
133
145
  Header
134
146
  </CardHeader>
@@ -165,7 +177,7 @@ describe( 'Card', () => {
165
177
  it( 'should render with a darker background color when isShady is true', () => {
166
178
  const { container } = render( <CardHeader>Header</CardHeader> );
167
179
  const { container: containerShady } = render(
168
- <CardHeader isShady={ true }>Header</CardHeader>
180
+ <CardHeader isShady>Header</CardHeader>
169
181
  );
170
182
  expect( container ).toMatchDiffSnapshot( containerShady );
171
183
  } );
@@ -175,7 +187,7 @@ describe( 'Card', () => {
175
187
  it( 'should render with a darker background color when isShady is true', () => {
176
188
  const { container } = render( <CardFooter>Footer</CardFooter> );
177
189
  const { container: containerShady } = render(
178
- <CardFooter isShady={ true }>Footer</CardFooter>
190
+ <CardFooter isShady>Footer</CardFooter>
179
191
  );
180
192
  expect( container ).toMatchDiffSnapshot( containerShady );
181
193
  } );
@@ -193,14 +205,14 @@ describe( 'Card', () => {
193
205
  it( 'should render with a darker background color when isShady is true', () => {
194
206
  const { container } = render( <CardBody>Body</CardBody> );
195
207
  const { container: containerShady } = render(
196
- <CardBody isShady={ true }>Body</CardBody>
208
+ <CardBody isShady>Body</CardBody>
197
209
  );
198
210
  expect( container ).toMatchDiffSnapshot( containerShady );
199
211
  } );
200
212
 
201
213
  it( 'should allow scrolling content with the scrollable prop is true', () => {
202
214
  const { container: containerScrollable } = render(
203
- <CardBody isScrollable={ true }>Body</CardBody>
215
+ <CardBody isScrollable>Body</CardBody>
204
216
  );
205
217
  const { container } = render( <CardBody>Body</CardBody> );
206
218
  expect( container ).toMatchDiffSnapshot( containerScrollable );
@@ -15,6 +15,8 @@ import { useState } from '@wordpress/element';
15
15
  import BaseCheckboxControl from '..';
16
16
  import type { CheckboxControlProps } from '../types';
17
17
 
18
+ jest.useFakeTimers();
19
+
18
20
  const noop = () => {};
19
21
 
20
22
  const getInput = () => screen.getByRole( 'checkbox' ) as HTMLInputElement;
@@ -26,6 +26,7 @@ $color-palette-circle-spacing: 12px;
26
26
  vertical-align: top;
27
27
  transform: scale(1);
28
28
  transition: 100ms transform ease;
29
+ will-change: transform;
29
30
  @include reduce-motion("transition");
30
31
 
31
32
  &:hover {
@@ -32,6 +32,7 @@ import type {
32
32
  SinglePaletteProps,
33
33
  } from './types';
34
34
  import type { WordPressComponentProps } from '../ui/context';
35
+ import type { DropdownProps } from '../dropdown/types';
35
36
 
36
37
  extend( [ namesPlugin, a11yPlugin ] );
37
38
 
@@ -70,7 +71,7 @@ function SinglePalette( {
70
71
  }
71
72
  style={ { backgroundColor: color, color } }
72
73
  onClick={
73
- isSelected ? clearColor : () => onChange( color )
74
+ isSelected ? clearColor : () => onChange( color, index )
74
75
  }
75
76
  aria-label={
76
77
  name
@@ -84,10 +85,6 @@ function SinglePalette( {
84
85
  } );
85
86
  }, [ colors, value, onChange, clearColor ] );
86
87
 
87
- if ( colors.length === 0 ) {
88
- return null;
89
- }
90
-
91
88
  return (
92
89
  <CircularOptionPicker
93
90
  className={ className }
@@ -118,7 +115,9 @@ function MultiplePalettes( {
118
115
  <SinglePalette
119
116
  clearColor={ clearColor }
120
117
  colors={ colorPalette }
121
- onChange={ onChange }
118
+ onChange={ ( newColor ) =>
119
+ onChange( newColor, index )
120
+ }
122
121
  value={ value }
123
122
  actions={
124
123
  colors.length === index + 1 ? actions : null
@@ -136,7 +135,7 @@ export function CustomColorPickerDropdown( {
136
135
  popoverProps: receivedPopoverProps,
137
136
  ...props
138
137
  }: CustomColorPickerDropdownProps ) {
139
- const popoverProps = useMemo(
138
+ const popoverProps = useMemo< DropdownProps[ 'popoverProps' ] >(
140
139
  () => ( {
141
140
  shift: true,
142
141
  ...( isRenderedInSidebar
@@ -168,7 +167,7 @@ export function CustomColorPickerDropdown( {
168
167
  export const extractColorNameFromCurrentValue = (
169
168
  currentValue?: ColorPaletteProps[ 'value' ],
170
169
  colors: ColorPaletteProps[ 'colors' ] = [],
171
- showMultiplePalettes: ColorPaletteProps[ '__experimentalHasMultipleOrigins' ] = false
170
+ showMultiplePalettes: boolean = false
172
171
  ) => {
173
172
  if ( ! currentValue ) {
174
173
  return '';
@@ -226,33 +225,32 @@ function UnforwardedColorPalette(
226
225
  enableAlpha = false,
227
226
  onChange,
228
227
  value,
229
- __experimentalHasMultipleOrigins = false,
230
228
  __experimentalIsRenderedInSidebar = false,
231
229
  ...otherProps
232
230
  } = props;
233
231
  const clearColor = useCallback( () => onChange( undefined ), [ onChange ] );
234
232
 
233
+ const hasMultipleColorOrigins =
234
+ colors.length > 0 &&
235
+ ( colors as PaletteObject[] )[ 0 ].colors !== undefined;
235
236
  const buttonLabelName = useMemo(
236
237
  () =>
237
238
  extractColorNameFromCurrentValue(
238
239
  value,
239
240
  colors,
240
- __experimentalHasMultipleOrigins
241
+ hasMultipleColorOrigins
241
242
  ),
242
- [ value, colors, __experimentalHasMultipleOrigins ]
243
+ [ value, colors, hasMultipleColorOrigins ]
243
244
  );
244
245
 
245
- // Make sure that the `colors` array has a format (single/multiple) that is
246
- // compatible with the `__experimentalHasMultipleOrigins` flag. This is true
247
- // when __experimentalHasMultipleOrigins and areColorsMultiplePalette() are
248
- // either both `true` or both `false`.
246
+ // Make sure that the `colors` array has a valid format.
249
247
  if (
250
248
  colors.length > 0 &&
251
- __experimentalHasMultipleOrigins !== areColorsMultiplePalette( colors )
249
+ hasMultipleColorOrigins !== areColorsMultiplePalette( colors )
252
250
  ) {
253
251
  // eslint-disable-next-line no-console
254
252
  console.warn(
255
- 'wp.components.ColorPalette: please specify a format for the `colors` prop that is compatible with the `__experimentalHasMultipleOrigins` prop.'
253
+ 'wp.components.ColorPalette: please specify a valid format for the `colors` prop. '
256
254
  );
257
255
  return null;
258
256
  }
@@ -342,7 +340,7 @@ function UnforwardedColorPalette(
342
340
  ) }
343
341
  />
344
342
  ) }
345
- { __experimentalHasMultipleOrigins ? (
343
+ { hasMultipleColorOrigins ? (
346
344
  <MultiplePalettes
347
345
  { ...paletteCommonProps }
348
346
  colors={ colors as PaletteObject[] }
@@ -15,19 +15,11 @@ import { useState } from '@wordpress/element';
15
15
  import ColorPalette from '..';
16
16
  import Popover from '../../popover';
17
17
  import { Provider as SlotFillProvider } from '../../slot-fill';
18
- import type { ColorObject, PaletteObject } from '../types';
19
18
 
20
19
  const meta: ComponentMeta< typeof ColorPalette > = {
21
20
  title: 'Components/ColorPalette',
22
21
  component: ColorPalette,
23
22
  argTypes: {
24
- // Removing the control because setting this prop without changing the
25
- // format of the `colors` prop can break the component.
26
- __experimentalHasMultipleOrigins: {
27
- control: {
28
- type: null,
29
- },
30
- },
31
23
  as: { control: { type: null } },
32
24
  onChange: { action: 'onChange', control: { type: null } },
33
25
  value: { control: { type: null } },
@@ -43,10 +35,7 @@ const Template: ComponentStory< typeof ColorPalette > = ( {
43
35
  onChange,
44
36
  ...args
45
37
  } ) => {
46
- const firstColor =
47
- ( args.colors as ColorObject[] )[ 0 ].color ||
48
- ( args.colors as PaletteObject[] )[ 0 ].colors[ 0 ].color;
49
- const [ color, setColor ] = useState< string | undefined >( firstColor );
38
+ const [ color, setColor ] = useState< string | undefined >();
50
39
 
51
40
  return (
52
41
  <SlotFillProvider>
@@ -73,14 +62,8 @@ Default.args = {
73
62
  ],
74
63
  };
75
64
 
76
- /**
77
- * When setting the `__experimentalHasMultipleOrigins` prop to `true`,
78
- * the `colors` prop is expected to be an array of color palettes, rather
79
- * than an array of color objects.
80
- */
81
65
  export const MultipleOrigins = Template.bind( {} );
82
66
  MultipleOrigins.args = {
83
- __experimentalHasMultipleOrigins: true,
84
67
  colors: [
85
68
  {
86
69
  name: 'Primary colors',
@@ -63,10 +63,10 @@ exports[`ColorPalette should allow disabling custom color picker 1`] = `
63
63
  class="components-circular-option-picker__option-wrapper"
64
64
  >
65
65
  <button
66
- aria-label="Color: white"
66
+ aria-label="Color: green"
67
67
  aria-pressed="false"
68
68
  class="components-button components-circular-option-picker__option"
69
- style="background-color: rgb(255, 255, 255); color: rgb(255, 255, 255);"
69
+ style="background-color: rgb(0, 255, 0); color: rgb(0, 255, 0);"
70
70
  type="button"
71
71
  />
72
72
  </div>
@@ -235,10 +235,10 @@ exports[`ColorPalette should render a dynamic toolbar of colors 1`] = `
235
235
  class="components-circular-option-picker__option-wrapper"
236
236
  >
237
237
  <button
238
- aria-label="Color: white"
238
+ aria-label="Color: green"
239
239
  aria-pressed="false"
240
240
  class="components-button components-circular-option-picker__option"
241
- style="background-color: rgb(255, 255, 255); color: rgb(255, 255, 255);"
241
+ style="background-color: rgb(0, 255, 0); color: rgb(0, 255, 0);"
242
242
  type="button"
243
243
  />
244
244
  </div>