@wordpress/components 22.0.0 → 23.0.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 (796) hide show
  1. package/CHANGELOG.md +99 -0
  2. package/build/alignment-matrix-control/cell.js.map +1 -1
  3. package/build/alignment-matrix-control/icon.js +4 -2
  4. package/build/alignment-matrix-control/icon.js.map +1 -1
  5. package/build/alignment-matrix-control/index.js +25 -1
  6. package/build/alignment-matrix-control/index.js.map +1 -1
  7. package/build/alignment-matrix-control/styles/alignment-matrix-control-icon-styles.js +13 -13
  8. package/build/alignment-matrix-control/styles/alignment-matrix-control-icon-styles.js.map +1 -1
  9. package/build/alignment-matrix-control/styles/alignment-matrix-control-styles.js +16 -16
  10. package/build/alignment-matrix-control/styles/alignment-matrix-control-styles.js.map +1 -1
  11. package/build/alignment-matrix-control/types.js +6 -0
  12. package/build/alignment-matrix-control/types.js.map +1 -0
  13. package/build/alignment-matrix-control/utils.js +9 -8
  14. package/build/alignment-matrix-control/utils.js.map +1 -1
  15. package/build/angle-picker-control/index.js +3 -1
  16. package/build/angle-picker-control/index.js.map +1 -1
  17. package/build/angle-picker-control/styles/angle-picker-control-styles.js +9 -9
  18. package/build/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
  19. package/build/autocomplete/index.js +45 -12
  20. package/build/autocomplete/index.js.map +1 -1
  21. package/build/base-control/hooks.js +52 -0
  22. package/build/base-control/hooks.js.map +1 -0
  23. package/build/base-control/index.js +24 -7
  24. package/build/base-control/index.js.map +1 -1
  25. package/build/base-field/hook.js +0 -14
  26. package/build/base-field/hook.js.map +1 -1
  27. package/build/base-field/index.js.map +1 -1
  28. package/build/base-field/styles.js +5 -5
  29. package/build/base-field/styles.js.map +1 -1
  30. package/build/base-field/types.js +6 -0
  31. package/build/base-field/types.js.map +1 -0
  32. package/build/border-box-control/border-box-control/component.js +1 -1
  33. package/build/border-box-control/border-box-control/component.js.map +1 -1
  34. package/build/border-box-control/border-box-control/hook.js +13 -1
  35. package/build/border-box-control/border-box-control/hook.js.map +1 -1
  36. package/build/border-box-control/border-box-control-split-controls/hook.js +11 -1
  37. package/build/border-box-control/border-box-control-split-controls/hook.js.map +1 -1
  38. package/build/border-control/border-control/component.js +3 -2
  39. package/build/border-control/border-control/component.js.map +1 -1
  40. package/build/border-control/border-control/hook.js +11 -1
  41. package/build/border-control/border-control/hook.js.map +1 -1
  42. package/build/border-control/border-control-dropdown/component.js +1 -1
  43. package/build/border-control/border-control-dropdown/component.js.map +1 -1
  44. package/build/border-control/border-control-dropdown/hook.js +10 -2
  45. package/build/border-control/border-control-dropdown/hook.js.map +1 -1
  46. package/build/border-control/styles.js +16 -16
  47. package/build/border-control/styles.js.map +1 -1
  48. package/build/box-control/linked-button.js +3 -4
  49. package/build/box-control/linked-button.js.map +1 -1
  50. package/build/color-palette/index.js +3 -8
  51. package/build/color-palette/index.js.map +1 -1
  52. package/build/color-picker/input-with-slider.js +18 -3
  53. package/build/color-picker/input-with-slider.js.map +1 -1
  54. package/build/color-picker/styles.js +8 -8
  55. package/build/color-picker/styles.js.map +1 -1
  56. package/build/custom-select-control/index.js +19 -4
  57. package/build/custom-select-control/index.js.map +1 -1
  58. package/build/dashicon/index.js +18 -6
  59. package/build/dashicon/index.js.map +1 -1
  60. package/build/date-time/date-time/index.js +4 -4
  61. package/build/date-time/date-time/index.js.map +1 -1
  62. package/build/draggable/index.js +58 -38
  63. package/build/draggable/index.js.map +1 -1
  64. package/build/draggable/types.js +6 -0
  65. package/build/draggable/types.js.map +1 -0
  66. package/build/duotone-picker/duotone-picker.js +2 -2
  67. package/build/duotone-picker/duotone-picker.js.map +1 -1
  68. package/build/flex/flex/hook.js +2 -3
  69. package/build/flex/flex/hook.js.map +1 -1
  70. package/build/focal-point-picker/focal-point.js +2 -12
  71. package/build/focal-point-picker/focal-point.js.map +1 -1
  72. package/build/focal-point-picker/styles/focal-point-style.js +11 -51
  73. package/build/focal-point-picker/styles/focal-point-style.js.map +1 -1
  74. package/build/font-size-picker/constants.js +41 -0
  75. package/build/font-size-picker/constants.js.map +1 -0
  76. package/build/font-size-picker/font-size-picker-select.js +97 -0
  77. package/build/font-size-picker/font-size-picker-select.js.map +1 -0
  78. package/build/font-size-picker/font-size-picker-toggle-group.js +50 -0
  79. package/build/font-size-picker/font-size-picker-toggle-group.js.map +1 -0
  80. package/build/font-size-picker/index.js +39 -76
  81. package/build/font-size-picker/index.js.map +1 -1
  82. package/build/font-size-picker/utils.js +17 -89
  83. package/build/font-size-picker/utils.js.map +1 -1
  84. package/build/form-token-field/index.js +9 -6
  85. package/build/form-token-field/index.js.map +1 -1
  86. package/build/gradient-picker/index.js +3 -9
  87. package/build/gradient-picker/index.js.map +1 -1
  88. package/build/higher-order/navigate-regions/index.js +3 -0
  89. package/build/higher-order/navigate-regions/index.js.map +1 -1
  90. package/build/higher-order/with-fallback-styles/index.js +2 -2
  91. package/build/higher-order/with-fallback-styles/index.js.map +1 -1
  92. package/build/icon/index.js +3 -2
  93. package/build/icon/index.js.map +1 -1
  94. package/build/index.js +21 -1
  95. package/build/index.js.map +1 -1
  96. package/build/input-control/index.js +17 -5
  97. package/build/input-control/index.js.map +1 -1
  98. package/build/input-control/input-base.js +2 -0
  99. package/build/input-control/input-base.js.map +1 -1
  100. package/build/menu-group/index.js +17 -3
  101. package/build/menu-group/index.js.map +1 -1
  102. package/build/menu-group/types.js +6 -0
  103. package/build/menu-group/types.js.map +1 -0
  104. package/build/mobile/bottom-sheet/cell.native.js +1 -1
  105. package/build/mobile/bottom-sheet/cell.native.js.map +1 -1
  106. package/build/mobile/bottom-sheet/switch-cell.native.js +1 -3
  107. package/build/mobile/bottom-sheet/switch-cell.native.js.map +1 -1
  108. package/build/mobile/global-styles-context/index.native.js +8 -8
  109. package/build/mobile/global-styles-context/index.native.js.map +1 -1
  110. package/build/mobile/keyboard-aware-flat-list/index.ios.js +4 -2
  111. package/build/mobile/keyboard-aware-flat-list/index.ios.js.map +1 -1
  112. package/build/modal/index.js +8 -0
  113. package/build/modal/index.js.map +1 -1
  114. package/build/navigator/navigator-provider/component.js +12 -8
  115. package/build/navigator/navigator-provider/component.js.map +1 -1
  116. package/build/navigator/navigator-screen/component.js +9 -5
  117. package/build/navigator/navigator-screen/component.js.map +1 -1
  118. package/build/number-control/styles/number-control-styles.js +8 -8
  119. package/build/number-control/styles/number-control-styles.js.map +1 -1
  120. package/build/palette-edit/index.js +75 -34
  121. package/build/palette-edit/index.js.map +1 -1
  122. package/build/popover/index.js +18 -6
  123. package/build/popover/index.js.map +1 -1
  124. package/build/query-controls/index.js +1 -0
  125. package/build/query-controls/index.js.map +1 -1
  126. package/build/range-control/styles/range-control-styles.js +47 -57
  127. package/build/range-control/styles/range-control-styles.js.map +1 -1
  128. package/build/snackbar/index.js +35 -24
  129. package/build/snackbar/index.js.map +1 -1
  130. package/build/snackbar/list.js +14 -19
  131. package/build/snackbar/list.js.map +1 -1
  132. package/build/snackbar/types.js +6 -0
  133. package/build/snackbar/types.js.map +1 -0
  134. package/build/spinner/styles.js +4 -4
  135. package/build/spinner/styles.js.map +1 -1
  136. package/build/tab-panel/index.js +12 -8
  137. package/build/tab-panel/index.js.map +1 -1
  138. package/build/theme/color-algorithms.js +118 -0
  139. package/build/theme/color-algorithms.js.map +1 -0
  140. package/build/theme/index.js +21 -18
  141. package/build/theme/index.js.map +1 -1
  142. package/build/theme/styles.js +10 -7
  143. package/build/theme/styles.js.map +1 -1
  144. package/build/toggle-control/index.js +5 -2
  145. package/build/toggle-control/index.js.map +1 -1
  146. package/build/toggle-group-control/toggle-group-control/component.js +1 -0
  147. package/build/toggle-group-control/toggle-group-control/component.js.map +1 -1
  148. package/build/toggle-group-control/toggle-group-control/styles.js +11 -6
  149. package/build/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  150. package/build/tools-panel/styles.js +14 -14
  151. package/build/tools-panel/styles.js.map +1 -1
  152. package/build/tools-panel/tools-panel-item/hook.js +9 -5
  153. package/build/tools-panel/tools-panel-item/hook.js.map +1 -1
  154. package/build/ui/context/context-system-provider.js +3 -1
  155. package/build/ui/context/context-system-provider.js.map +1 -1
  156. package/build/unit-control/index.js +5 -2
  157. package/build/unit-control/index.js.map +1 -1
  158. package/build/utils/colors-values.js +4 -3
  159. package/build/utils/colors-values.js.map +1 -1
  160. package/build/utils/config-values.js +0 -2
  161. package/build/utils/config-values.js.map +1 -1
  162. package/build/utils/hooks/use-controlled-value.js.map +1 -1
  163. package/build/utils/input/base.js +2 -2
  164. package/build/utils/input/base.js.map +1 -1
  165. package/build/view/index.js.map +1 -1
  166. package/build-module/alignment-matrix-control/cell.js.map +1 -1
  167. package/build-module/alignment-matrix-control/icon.js +4 -2
  168. package/build-module/alignment-matrix-control/icon.js.map +1 -1
  169. package/build-module/alignment-matrix-control/index.js +23 -1
  170. package/build-module/alignment-matrix-control/index.js.map +1 -1
  171. package/build-module/alignment-matrix-control/styles/alignment-matrix-control-icon-styles.js +13 -13
  172. package/build-module/alignment-matrix-control/styles/alignment-matrix-control-icon-styles.js.map +1 -1
  173. package/build-module/alignment-matrix-control/styles/alignment-matrix-control-styles.js +16 -16
  174. package/build-module/alignment-matrix-control/styles/alignment-matrix-control-styles.js.map +1 -1
  175. package/build-module/alignment-matrix-control/types.js +2 -0
  176. package/build-module/alignment-matrix-control/types.js.map +1 -0
  177. package/build-module/alignment-matrix-control/utils.js +13 -8
  178. package/build-module/alignment-matrix-control/utils.js.map +1 -1
  179. package/build-module/angle-picker-control/index.js +2 -1
  180. package/build-module/angle-picker-control/index.js.map +1 -1
  181. package/build-module/angle-picker-control/styles/angle-picker-control-styles.js +9 -9
  182. package/build-module/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
  183. package/build-module/autocomplete/index.js +45 -12
  184. package/build-module/autocomplete/index.js.map +1 -1
  185. package/build-module/base-control/hooks.js +41 -0
  186. package/build-module/base-control/hooks.js.map +1 -0
  187. package/build-module/base-control/index.js +18 -8
  188. package/build-module/base-control/index.js.map +1 -1
  189. package/build-module/base-field/hook.js +0 -14
  190. package/build-module/base-field/hook.js.map +1 -1
  191. package/build-module/base-field/index.js.map +1 -1
  192. package/build-module/base-field/styles.js +5 -5
  193. package/build-module/base-field/styles.js.map +1 -1
  194. package/build-module/base-field/types.js +2 -0
  195. package/build-module/base-field/types.js.map +1 -0
  196. package/build-module/border-box-control/border-box-control/component.js +1 -1
  197. package/build-module/border-box-control/border-box-control/component.js.map +1 -1
  198. package/build-module/border-box-control/border-box-control/hook.js +13 -1
  199. package/build-module/border-box-control/border-box-control/hook.js.map +1 -1
  200. package/build-module/border-box-control/border-box-control-split-controls/hook.js +11 -1
  201. package/build-module/border-box-control/border-box-control-split-controls/hook.js.map +1 -1
  202. package/build-module/border-control/border-control/component.js +3 -2
  203. package/build-module/border-control/border-control/component.js.map +1 -1
  204. package/build-module/border-control/border-control/hook.js +11 -1
  205. package/build-module/border-control/border-control/hook.js.map +1 -1
  206. package/build-module/border-control/border-control-dropdown/component.js +1 -1
  207. package/build-module/border-control/border-control-dropdown/component.js.map +1 -1
  208. package/build-module/border-control/border-control-dropdown/hook.js +10 -2
  209. package/build-module/border-control/border-control-dropdown/hook.js.map +1 -1
  210. package/build-module/border-control/styles.js +17 -17
  211. package/build-module/border-control/styles.js.map +1 -1
  212. package/build-module/box-control/linked-button.js +3 -4
  213. package/build-module/box-control/linked-button.js.map +1 -1
  214. package/build-module/color-palette/index.js +3 -8
  215. package/build-module/color-palette/index.js.map +1 -1
  216. package/build-module/color-picker/input-with-slider.js +18 -3
  217. package/build-module/color-picker/input-with-slider.js.map +1 -1
  218. package/build-module/color-picker/styles.js +8 -8
  219. package/build-module/color-picker/styles.js.map +1 -1
  220. package/build-module/custom-select-control/index.js +19 -4
  221. package/build-module/custom-select-control/index.js.map +1 -1
  222. package/build-module/dashicon/index.js +18 -6
  223. package/build-module/dashicon/index.js.map +1 -1
  224. package/build-module/date-time/date-time/index.js +4 -4
  225. package/build-module/date-time/date-time/index.js.map +1 -1
  226. package/build-module/draggable/index.js +59 -38
  227. package/build-module/draggable/index.js.map +1 -1
  228. package/build-module/draggable/types.js +2 -0
  229. package/build-module/draggable/types.js.map +1 -0
  230. package/build-module/duotone-picker/duotone-picker.js +2 -2
  231. package/build-module/duotone-picker/duotone-picker.js.map +1 -1
  232. package/build-module/flex/flex/hook.js +2 -3
  233. package/build-module/flex/flex/hook.js.map +1 -1
  234. package/build-module/focal-point-picker/focal-point.js +3 -13
  235. package/build-module/focal-point-picker/focal-point.js.map +1 -1
  236. package/build-module/focal-point-picker/styles/focal-point-style.js +6 -52
  237. package/build-module/focal-point-picker/styles/focal-point-style.js.map +1 -1
  238. package/build-module/font-size-picker/constants.js +31 -0
  239. package/build-module/font-size-picker/constants.js.map +1 -0
  240. package/build-module/font-size-picker/font-size-picker-select.js +83 -0
  241. package/build-module/font-size-picker/font-size-picker-select.js.map +1 -0
  242. package/build-module/font-size-picker/font-size-picker-toggle-group.js +40 -0
  243. package/build-module/font-size-picker/font-size-picker-toggle-group.js.map +1 -0
  244. package/build-module/font-size-picker/index.js +38 -76
  245. package/build-module/font-size-picker/index.js.map +1 -1
  246. package/build-module/font-size-picker/utils.js +15 -86
  247. package/build-module/font-size-picker/utils.js.map +1 -1
  248. package/build-module/form-token-field/index.js +9 -6
  249. package/build-module/form-token-field/index.js.map +1 -1
  250. package/build-module/gradient-picker/index.js +3 -8
  251. package/build-module/gradient-picker/index.js.map +1 -1
  252. package/build-module/higher-order/navigate-regions/index.js +3 -0
  253. package/build-module/higher-order/navigate-regions/index.js.map +1 -1
  254. package/build-module/higher-order/with-fallback-styles/index.js +2 -2
  255. package/build-module/higher-order/with-fallback-styles/index.js.map +1 -1
  256. package/build-module/icon/index.js +3 -2
  257. package/build-module/icon/index.js.map +1 -1
  258. package/build-module/index.js +3 -2
  259. package/build-module/index.js.map +1 -1
  260. package/build-module/input-control/index.js +16 -5
  261. package/build-module/input-control/index.js.map +1 -1
  262. package/build-module/input-control/input-base.js +2 -0
  263. package/build-module/input-control/input-base.js.map +1 -1
  264. package/build-module/menu-group/index.js +20 -2
  265. package/build-module/menu-group/index.js.map +1 -1
  266. package/build-module/menu-group/types.js +2 -0
  267. package/build-module/menu-group/types.js.map +1 -0
  268. package/build-module/mobile/bottom-sheet/cell.native.js +1 -1
  269. package/build-module/mobile/bottom-sheet/cell.native.js.map +1 -1
  270. package/build-module/mobile/bottom-sheet/switch-cell.native.js +1 -2
  271. package/build-module/mobile/bottom-sheet/switch-cell.native.js.map +1 -1
  272. package/build-module/mobile/global-styles-context/index.native.js +8 -7
  273. package/build-module/mobile/global-styles-context/index.native.js.map +1 -1
  274. package/build-module/mobile/keyboard-aware-flat-list/index.ios.js +2 -2
  275. package/build-module/mobile/keyboard-aware-flat-list/index.ios.js.map +1 -1
  276. package/build-module/modal/index.js +8 -0
  277. package/build-module/modal/index.js.map +1 -1
  278. package/build-module/navigator/navigator-provider/component.js +12 -8
  279. package/build-module/navigator/navigator-provider/component.js.map +1 -1
  280. package/build-module/navigator/navigator-screen/component.js +9 -5
  281. package/build-module/navigator/navigator-screen/component.js.map +1 -1
  282. package/build-module/number-control/styles/number-control-styles.js +8 -10
  283. package/build-module/number-control/styles/number-control-styles.js.map +1 -1
  284. package/build-module/palette-edit/index.js +76 -35
  285. package/build-module/palette-edit/index.js.map +1 -1
  286. package/build-module/popover/index.js +18 -6
  287. package/build-module/popover/index.js.map +1 -1
  288. package/build-module/query-controls/index.js +1 -0
  289. package/build-module/query-controls/index.js.map +1 -1
  290. package/build-module/range-control/styles/range-control-styles.js +47 -57
  291. package/build-module/range-control/styles/range-control-styles.js.map +1 -1
  292. package/build-module/snackbar/index.js +33 -23
  293. package/build-module/snackbar/index.js.map +1 -1
  294. package/build-module/snackbar/list.js +14 -22
  295. package/build-module/snackbar/list.js.map +1 -1
  296. package/build-module/snackbar/types.js +2 -0
  297. package/build-module/snackbar/types.js.map +1 -0
  298. package/build-module/spinner/styles.js +4 -4
  299. package/build-module/spinner/styles.js.map +1 -1
  300. package/build-module/tab-panel/index.js +13 -9
  301. package/build-module/tab-panel/index.js.map +1 -1
  302. package/build-module/theme/color-algorithms.js +105 -0
  303. package/build-module/theme/color-algorithms.js.map +1 -0
  304. package/build-module/theme/index.js +21 -17
  305. package/build-module/theme/index.js.map +1 -1
  306. package/build-module/theme/styles.js +8 -6
  307. package/build-module/theme/styles.js.map +1 -1
  308. package/build-module/toggle-control/index.js +4 -2
  309. package/build-module/toggle-control/index.js.map +1 -1
  310. package/build-module/toggle-group-control/toggle-group-control/component.js +1 -0
  311. package/build-module/toggle-group-control/toggle-group-control/component.js.map +1 -1
  312. package/build-module/toggle-group-control/toggle-group-control/styles.js +12 -6
  313. package/build-module/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  314. package/build-module/tools-panel/styles.js +14 -14
  315. package/build-module/tools-panel/styles.js.map +1 -1
  316. package/build-module/tools-panel/tools-panel-item/hook.js +9 -5
  317. package/build-module/tools-panel/tools-panel-item/hook.js.map +1 -1
  318. package/build-module/ui/context/context-system-provider.js +3 -2
  319. package/build-module/ui/context/context-system-provider.js.map +1 -1
  320. package/build-module/unit-control/index.js +5 -2
  321. package/build-module/unit-control/index.js.map +1 -1
  322. package/build-module/utils/colors-values.js +4 -3
  323. package/build-module/utils/colors-values.js.map +1 -1
  324. package/build-module/utils/config-values.js +0 -2
  325. package/build-module/utils/config-values.js.map +1 -1
  326. package/build-module/utils/hooks/use-controlled-value.js.map +1 -1
  327. package/build-module/utils/input/base.js +2 -2
  328. package/build-module/utils/input/base.js.map +1 -1
  329. package/build-module/view/index.js.map +1 -1
  330. package/build-style/style-rtl.css +145 -100
  331. package/build-style/style.css +145 -100
  332. package/build-types/alignment-matrix-control/cell.d.ts +5 -0
  333. package/build-types/alignment-matrix-control/cell.d.ts.map +1 -0
  334. package/build-types/alignment-matrix-control/icon.d.ts +6 -0
  335. package/build-types/alignment-matrix-control/icon.d.ts.map +1 -0
  336. package/build-types/alignment-matrix-control/index.d.ts +30 -0
  337. package/build-types/alignment-matrix-control/index.d.ts.map +1 -0
  338. package/build-types/alignment-matrix-control/stories/index.d.ts +14 -0
  339. package/build-types/alignment-matrix-control/stories/index.d.ts.map +1 -0
  340. package/build-types/alignment-matrix-control/styles/alignment-matrix-control-icon-styles.d.ts +19 -0
  341. package/build-types/alignment-matrix-control/styles/alignment-matrix-control-icon-styles.d.ts.map +1 -0
  342. package/build-types/alignment-matrix-control/styles/alignment-matrix-control-styles.d.ts +23 -0
  343. package/build-types/alignment-matrix-control/styles/alignment-matrix-control-styles.d.ts.map +1 -0
  344. package/build-types/alignment-matrix-control/test/index.d.ts +2 -0
  345. package/build-types/alignment-matrix-control/test/index.d.ts.map +1 -0
  346. package/build-types/alignment-matrix-control/types.d.ts +39 -0
  347. package/build-types/alignment-matrix-control/types.d.ts.map +1 -0
  348. package/build-types/alignment-matrix-control/utils.d.ts +33 -0
  349. package/build-types/alignment-matrix-control/utils.d.ts.map +1 -0
  350. package/build-types/base-control/hooks.d.ts +23 -0
  351. package/build-types/base-control/hooks.d.ts.map +1 -0
  352. package/build-types/base-control/index.d.ts +17 -7
  353. package/build-types/base-control/index.d.ts.map +1 -1
  354. package/build-types/base-control/stories/index.d.ts.map +1 -1
  355. package/build-types/base-control/test/index.d.ts +2 -0
  356. package/build-types/base-control/test/index.d.ts.map +1 -0
  357. package/build-types/base-control/types.d.ts +8 -2
  358. package/build-types/base-control/types.d.ts.map +1 -1
  359. package/build-types/base-field/hook.d.ts +7 -31
  360. package/build-types/base-field/hook.d.ts.map +1 -1
  361. package/build-types/base-field/index.d.ts +1 -1
  362. package/build-types/base-field/index.d.ts.map +1 -1
  363. package/build-types/base-field/styles.d.ts +5 -5
  364. package/build-types/base-field/styles.d.ts.map +1 -1
  365. package/build-types/base-field/test/index.d.ts +2 -0
  366. package/build-types/base-field/test/index.d.ts.map +1 -0
  367. package/build-types/base-field/types.d.ts +29 -0
  368. package/build-types/base-field/types.d.ts.map +1 -0
  369. package/build-types/border-box-control/border-box-control/component.d.ts +4 -4
  370. package/build-types/border-box-control/border-box-control/component.d.ts.map +1 -1
  371. package/build-types/border-box-control/border-box-control/hook.d.ts +8 -8
  372. package/build-types/border-box-control/border-box-control/hook.d.ts.map +1 -1
  373. package/build-types/border-box-control/border-box-control-linked-button/component.d.ts +4 -2
  374. package/build-types/border-box-control/border-box-control-linked-button/component.d.ts.map +1 -1
  375. package/build-types/border-box-control/border-box-control-linked-button/hook.d.ts +2 -2
  376. package/build-types/border-box-control/border-box-control-split-controls/component.d.ts +3 -3
  377. package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts +7 -7
  378. package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts.map +1 -1
  379. package/build-types/border-box-control/border-box-control-visualizer/component.d.ts +3 -2
  380. package/build-types/border-box-control/border-box-control-visualizer/component.d.ts.map +1 -1
  381. package/build-types/border-box-control/border-box-control-visualizer/hook.d.ts +2 -2
  382. package/build-types/border-box-control/stories/index.d.ts +3 -3
  383. package/build-types/border-box-control/types.d.ts +5 -38
  384. package/build-types/border-box-control/types.d.ts.map +1 -1
  385. package/build-types/border-control/border-control/component.d.ts +4 -2
  386. package/build-types/border-control/border-control/component.d.ts.map +1 -1
  387. package/build-types/border-control/border-control/hook.d.ts +7 -7
  388. package/build-types/border-control/border-control/hook.d.ts.map +1 -1
  389. package/build-types/border-control/border-control-dropdown/component.d.ts +3 -3
  390. package/build-types/border-control/border-control-dropdown/component.d.ts.map +1 -1
  391. package/build-types/border-control/border-control-dropdown/hook.d.ts +7 -7
  392. package/build-types/border-control/border-control-dropdown/hook.d.ts.map +1 -1
  393. package/build-types/border-control/border-control-style-picker/hook.d.ts +2 -2
  394. package/build-types/border-control/stories/index.d.ts +24 -12
  395. package/build-types/border-control/stories/index.d.ts.map +1 -1
  396. package/build-types/border-control/styles.d.ts.map +1 -1
  397. package/build-types/border-control/types.d.ts +10 -51
  398. package/build-types/border-control/types.d.ts.map +1 -1
  399. package/build-types/card/card/hook.d.ts +2 -2
  400. package/build-types/card/card-body/hook.d.ts +2 -2
  401. package/build-types/card/card-divider/hook.d.ts +2 -2
  402. package/build-types/card/card-footer/hook.d.ts +2 -2
  403. package/build-types/card/card-header/hook.d.ts +2 -2
  404. package/build-types/card/card-media/hook.d.ts +2 -2
  405. package/build-types/color-palette/index.d.ts +16 -2
  406. package/build-types/color-palette/index.d.ts.map +1 -1
  407. package/build-types/color-palette/stories/index.d.ts +30 -2
  408. package/build-types/color-palette/stories/index.d.ts.map +1 -1
  409. package/build-types/color-palette/styles.d.ts +1 -1
  410. package/build-types/color-palette/types.d.ts +14 -10
  411. package/build-types/color-palette/types.d.ts.map +1 -1
  412. package/build-types/color-picker/input-with-slider.d.ts.map +1 -1
  413. package/build-types/color-picker/styles.d.ts +5 -5
  414. package/build-types/color-picker/styles.d.ts.map +1 -1
  415. package/build-types/custom-select-control/index.d.ts.map +1 -1
  416. package/build-types/dashicon/index.d.ts +7 -16
  417. package/build-types/dashicon/index.d.ts.map +1 -1
  418. package/build-types/dashicon/types.d.ts +14 -0
  419. package/build-types/dashicon/types.d.ts.map +1 -1
  420. package/build-types/date-time/date/styles.d.ts +3 -3
  421. package/build-types/date-time/date-time/styles.d.ts +3 -3
  422. package/build-types/date-time/time/styles.d.ts +8 -8
  423. package/build-types/date-time/types.d.ts +0 -16
  424. package/build-types/date-time/types.d.ts.map +1 -1
  425. package/build-types/draggable/index.d.ts +42 -66
  426. package/build-types/draggable/index.d.ts.map +1 -1
  427. package/build-types/draggable/stories/index.d.ts +12 -0
  428. package/build-types/draggable/stories/index.d.ts.map +1 -0
  429. package/build-types/draggable/types.d.ts +58 -0
  430. package/build-types/draggable/types.d.ts.map +1 -0
  431. package/build-types/elevation/hook.d.ts +2 -2
  432. package/build-types/external-link/styles/external-link-styles.d.ts +1 -1
  433. package/build-types/flex/flex/hook.d.ts +2 -2
  434. package/build-types/flex/flex/hook.d.ts.map +1 -1
  435. package/build-types/flex/flex-block/hook.d.ts +2 -2
  436. package/build-types/flex/flex-item/hook.d.ts +2 -2
  437. package/build-types/focal-point-picker/focal-point.d.ts.map +1 -1
  438. package/build-types/focal-point-picker/styles/focal-point-picker-style.d.ts +2 -5
  439. package/build-types/focal-point-picker/styles/focal-point-picker-style.d.ts.map +1 -1
  440. package/build-types/focal-point-picker/styles/focal-point-style.d.ts +1 -12
  441. package/build-types/focal-point-picker/styles/focal-point-style.d.ts.map +1 -1
  442. package/build-types/font-size-picker/constants.d.ts +15 -0
  443. package/build-types/font-size-picker/constants.d.ts.map +1 -0
  444. package/build-types/font-size-picker/font-size-picker-select.d.ts +5 -0
  445. package/build-types/font-size-picker/font-size-picker-select.d.ts.map +1 -0
  446. package/build-types/font-size-picker/font-size-picker-toggle-group.d.ts +5 -0
  447. package/build-types/font-size-picker/font-size-picker-toggle-group.d.ts.map +1 -0
  448. package/build-types/font-size-picker/index.d.ts.map +1 -1
  449. package/build-types/font-size-picker/types.d.ts +13 -13
  450. package/build-types/font-size-picker/types.d.ts.map +1 -1
  451. package/build-types/font-size-picker/utils.d.ts +6 -18
  452. package/build-types/font-size-picker/utils.d.ts.map +1 -1
  453. package/build-types/form-token-field/index.d.ts.map +1 -1
  454. package/build-types/grid/hook.d.ts +2 -2
  455. package/build-types/h-stack/component.d.ts +1 -1
  456. package/build-types/h-stack/hook.d.ts +2 -2
  457. package/build-types/heading/hook.d.ts +2 -2
  458. package/build-types/icon/index.d.ts +1 -1
  459. package/build-types/icon/index.d.ts.map +1 -1
  460. package/build-types/input-control/index.d.ts +1 -1
  461. package/build-types/input-control/index.d.ts.map +1 -1
  462. package/build-types/input-control/input-base.d.ts.map +1 -1
  463. package/build-types/input-control/stories/index.d.ts +1 -0
  464. package/build-types/input-control/stories/index.d.ts.map +1 -1
  465. package/build-types/input-control/types.d.ts +2 -1
  466. package/build-types/input-control/types.d.ts.map +1 -1
  467. package/build-types/item-group/item/hook.d.ts +2 -2
  468. package/build-types/item-group/item-group/hook.d.ts +2 -2
  469. package/build-types/menu-group/index.d.ts +21 -1
  470. package/build-types/menu-group/index.d.ts.map +1 -1
  471. package/build-types/menu-group/test/index.d.ts +2 -0
  472. package/build-types/menu-group/test/index.d.ts.map +1 -0
  473. package/build-types/menu-group/types.d.ts +23 -0
  474. package/build-types/menu-group/types.d.ts.map +1 -0
  475. package/build-types/modal/index.d.ts.map +1 -1
  476. package/build-types/modal/stories/index.d.ts.map +1 -1
  477. package/build-types/navigator/navigator-back-button/hook.d.ts +3 -3
  478. package/build-types/navigator/navigator-button/hook.d.ts +3 -3
  479. package/build-types/navigator/navigator-provider/component.d.ts.map +1 -1
  480. package/build-types/navigator/navigator-screen/component.d.ts.map +1 -1
  481. package/build-types/number-control/index.d.ts +2 -2
  482. package/build-types/number-control/index.d.ts.map +1 -1
  483. package/build-types/number-control/stories/index.d.ts +25 -0
  484. package/build-types/number-control/stories/index.d.ts.map +1 -0
  485. package/build-types/number-control/styles/number-control-styles.d.ts +6 -6
  486. package/build-types/number-control/styles/number-control-styles.d.ts.map +1 -1
  487. package/build-types/number-control/test/index.d.ts +2 -0
  488. package/build-types/number-control/test/index.d.ts.map +1 -0
  489. package/build-types/popover/index.d.ts +1 -1
  490. package/build-types/popover/index.d.ts.map +1 -1
  491. package/build-types/popover/stories/e2e/index.d.ts +1 -1
  492. package/build-types/range-control/index.d.ts +1 -1
  493. package/build-types/range-control/styles/range-control-styles.d.ts +2 -2
  494. package/build-types/resizable-box/resize-tooltip/index.d.ts +15 -19
  495. package/build-types/resizable-box/resize-tooltip/index.d.ts.map +1 -1
  496. package/build-types/resizable-box/resize-tooltip/label.d.ts +4 -3
  497. package/build-types/resizable-box/resize-tooltip/label.d.ts.map +1 -1
  498. package/build-types/scrollable/hook.d.ts +2 -2
  499. package/build-types/search-control/index.d.ts +1 -1
  500. package/build-types/search-control/stories/index.d.ts +2 -2
  501. package/build-types/snackbar/index.d.ts +19 -0
  502. package/build-types/snackbar/index.d.ts.map +1 -0
  503. package/build-types/snackbar/list.d.ts +18 -0
  504. package/build-types/snackbar/list.d.ts.map +1 -0
  505. package/build-types/snackbar/stories/index.d.ts +16 -0
  506. package/build-types/snackbar/stories/index.d.ts.map +1 -0
  507. package/build-types/snackbar/stories/list.d.ts +12 -0
  508. package/build-types/snackbar/stories/list.d.ts.map +1 -0
  509. package/build-types/snackbar/types.d.ts +111 -0
  510. package/build-types/snackbar/types.d.ts.map +1 -0
  511. package/build-types/spacer/hook.d.ts +2 -2
  512. package/build-types/spinner/index.d.ts +1 -1
  513. package/build-types/surface/hook.d.ts +2 -2
  514. package/build-types/tab-panel/index.d.ts +1 -1
  515. package/build-types/tab-panel/index.d.ts.map +1 -1
  516. package/build-types/tab-panel/types.d.ts +19 -1
  517. package/build-types/tab-panel/types.d.ts.map +1 -1
  518. package/build-types/text/hook.d.ts +2 -2
  519. package/build-types/text-control/index.d.ts +2 -2
  520. package/build-types/text-control/stories/index.d.ts.map +1 -1
  521. package/build-types/text-control/types.d.ts +1 -5
  522. package/build-types/text-control/types.d.ts.map +1 -1
  523. package/build-types/theme/color-algorithms.d.ts +20 -0
  524. package/build-types/theme/color-algorithms.d.ts.map +1 -0
  525. package/build-types/theme/index.d.ts +1 -1
  526. package/build-types/theme/index.d.ts.map +1 -1
  527. package/build-types/theme/stories/index.d.ts +4 -0
  528. package/build-types/theme/stories/index.d.ts.map +1 -1
  529. package/build-types/theme/styles.d.ts +3 -2
  530. package/build-types/theme/styles.d.ts.map +1 -1
  531. package/build-types/theme/test/color-algorithms.d.ts +2 -0
  532. package/build-types/theme/test/color-algorithms.d.ts.map +1 -0
  533. package/build-types/theme/types.d.ts +41 -3
  534. package/build-types/theme/types.d.ts.map +1 -1
  535. package/build-types/toggle-control/index.d.ts.map +1 -1
  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 +2 -2
  538. package/build-types/toggle-group-control/toggle-group-control/as-radio-group.d.ts +2 -2
  539. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts +1 -2
  540. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts.map +1 -1
  541. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts +1 -1
  542. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts +1 -1
  543. package/build-types/toggle-group-control/types.d.ts +2 -1
  544. package/build-types/toggle-group-control/types.d.ts.map +1 -1
  545. package/build-types/tools-panel/tools-panel/hook.d.ts +2 -2
  546. package/build-types/tools-panel/tools-panel-header/hook.d.ts +2 -2
  547. package/build-types/tools-panel/tools-panel-item/hook.d.ts +2 -2
  548. package/build-types/tools-panel/tools-panel-item/hook.d.ts.map +1 -1
  549. package/build-types/truncate/hook.d.ts +2 -2
  550. package/build-types/ui/context/context-system-provider.d.ts.map +1 -1
  551. package/build-types/ui/control-group/hook.d.ts +2 -2
  552. package/build-types/ui/control-label/hook.d.ts +2 -2
  553. package/build-types/ui/form-group/form-group.d.ts +2 -2
  554. package/build-types/ui/form-group/use-form-group.d.ts +5 -5
  555. package/build-types/unit-control/index.d.ts +2 -1
  556. package/build-types/unit-control/index.d.ts.map +1 -1
  557. package/build-types/unit-control/styles/unit-control-styles.d.ts +2 -2
  558. package/build-types/unit-control/types.d.ts +4 -0
  559. package/build-types/unit-control/types.d.ts.map +1 -1
  560. package/build-types/utils/colors-values.d.ts +1 -0
  561. package/build-types/utils/colors-values.d.ts.map +1 -1
  562. package/build-types/utils/config-values.d.ts +0 -2
  563. package/build-types/utils/hooks/use-controlled-value.d.ts +2 -1
  564. package/build-types/utils/hooks/use-controlled-value.d.ts.map +1 -1
  565. package/build-types/v-stack/component.d.ts +2 -2
  566. package/build-types/v-stack/hook.d.ts +2 -2
  567. package/build-types/v-stack/stories/index.d.ts +2 -2
  568. package/build-types/view/index.d.ts +1 -1
  569. package/build-types/view/index.d.ts.map +1 -1
  570. package/package.json +21 -20
  571. package/src/alignment-matrix-control/README.md +7 -7
  572. package/src/alignment-matrix-control/{cell.js → cell.tsx} +7 -1
  573. package/src/alignment-matrix-control/{icon.js → icon.tsx} +6 -3
  574. package/src/alignment-matrix-control/{index.js → index.tsx} +31 -4
  575. package/src/alignment-matrix-control/stories/{index.js → index.tsx} +17 -9
  576. package/src/alignment-matrix-control/styles/{alignment-matrix-control-icon-styles.js → alignment-matrix-control-icon-styles.ts} +11 -3
  577. package/src/alignment-matrix-control/styles/{alignment-matrix-control-styles.js → alignment-matrix-control-styles.ts} +13 -3
  578. package/src/alignment-matrix-control/test/{index.js → index.tsx} +5 -5
  579. package/src/alignment-matrix-control/types.ts +54 -0
  580. package/src/alignment-matrix-control/{utils.js → utils.tsx} +24 -14
  581. package/src/angle-picker-control/index.js +2 -1
  582. package/src/angle-picker-control/styles/angle-picker-control-styles.js +4 -0
  583. package/src/autocomplete/index.js +55 -15
  584. package/src/autocomplete/style.scss +1 -1
  585. package/src/base-control/README.md +21 -12
  586. package/src/base-control/hooks.ts +45 -0
  587. package/src/base-control/index.tsx +18 -7
  588. package/src/base-control/stories/index.tsx +8 -10
  589. package/src/base-control/test/index.tsx +52 -0
  590. package/src/base-control/types.ts +8 -2
  591. package/src/base-field/README.md +21 -22
  592. package/src/base-field/{hook.js → hook.ts} +5 -15
  593. package/src/base-field/{index.js → index.ts} +0 -0
  594. package/src/base-field/{styles.js → styles.ts} +2 -2
  595. package/src/base-field/test/__snapshots__/{index.js.snap → index.tsx.snap} +13 -11
  596. package/src/base-field/test/index.tsx +84 -0
  597. package/src/base-field/types.ts +29 -0
  598. package/src/border-box-control/border-box-control/README.md +6 -17
  599. package/src/border-box-control/border-box-control/component.tsx +1 -1
  600. package/src/border-box-control/border-box-control/hook.ts +18 -4
  601. package/src/border-box-control/border-box-control-split-controls/hook.ts +10 -0
  602. package/src/border-box-control/test/index.js +3 -1
  603. package/src/border-box-control/types.ts +32 -58
  604. package/src/border-control/border-control/README.md +4 -17
  605. package/src/border-control/border-control/component.tsx +3 -2
  606. package/src/border-control/border-control/hook.ts +10 -0
  607. package/src/border-control/border-control-dropdown/component.tsx +7 -6
  608. package/src/border-control/border-control-dropdown/hook.ts +9 -1
  609. package/src/border-control/styles.ts +1 -10
  610. package/src/border-control/types.ts +43 -80
  611. package/src/box-control/linked-button.js +8 -11
  612. package/src/box-control/test/index.js +206 -135
  613. package/src/button/stories/index.js +30 -0
  614. package/src/button/style.scss +17 -14
  615. package/src/button/test/index.js +32 -15
  616. package/src/card/test/__snapshots__/index.tsx.snap +64 -368
  617. package/src/card/test/index.tsx +34 -22
  618. package/src/checkbox-control/style.scss +3 -3
  619. package/src/circular-option-picker/style.scss +1 -0
  620. package/src/color-palette/README.md +12 -16
  621. package/src/color-palette/index.tsx +5 -7
  622. package/src/color-palette/stories/index.tsx +1 -5
  623. package/src/color-palette/style.scss +1 -1
  624. package/src/color-palette/test/__snapshots__/index.tsx.snap +4 -4
  625. package/src/color-palette/test/index.tsx +84 -36
  626. package/src/color-palette/types.ts +14 -10
  627. package/src/color-picker/README.md +1 -0
  628. package/src/color-picker/input-with-slider.tsx +14 -2
  629. package/src/color-picker/styles.ts +0 -4
  630. package/src/confirm-dialog/README.md +3 -2
  631. package/src/custom-select-control/README.md +14 -0
  632. package/src/custom-select-control/index.js +21 -2
  633. package/src/custom-select-control/stories/index.js +1 -0
  634. package/src/custom-select-control/style.scss +6 -1
  635. package/src/custom-select-control/test/index.js +39 -0
  636. package/src/dashicon/index.tsx +51 -0
  637. package/src/dashicon/types.ts +17 -0
  638. package/src/date-time/date/test/index.tsx +2 -2
  639. package/src/date-time/date-time/index.tsx +2 -2
  640. package/src/date-time/types.ts +0 -19
  641. package/src/dimension-control/test/__snapshots__/index.test.js.snap +4 -8
  642. package/src/disabled/test/index.tsx +21 -11
  643. package/src/divider/test/index.tsx +4 -4
  644. package/src/draggable/README.md +13 -18
  645. package/src/draggable/{index.js → index.tsx} +71 -47
  646. package/src/draggable/stories/index.tsx +83 -0
  647. package/src/draggable/types.ts +58 -0
  648. package/src/drop-zone/style.scss +1 -1
  649. package/src/dropdown/test/index.js +39 -49
  650. package/src/dropdown-menu/test/index.js +18 -12
  651. package/src/duotone-picker/duotone-picker.js +2 -2
  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/focal-point-picker/test/media.js +26 -21
  657. package/src/font-size-picker/constants.ts +37 -0
  658. package/src/font-size-picker/font-size-picker-select.tsx +98 -0
  659. package/src/font-size-picker/font-size-picker-toggle-group.tsx +41 -0
  660. package/src/font-size-picker/index.tsx +55 -118
  661. package/src/font-size-picker/test/index.tsx +253 -44
  662. package/src/font-size-picker/test/utils.ts +58 -98
  663. package/src/font-size-picker/types.ts +25 -16
  664. package/src/font-size-picker/utils.ts +16 -102
  665. package/src/form-toggle/style.scss +3 -3
  666. package/src/form-token-field/index.tsx +13 -5
  667. package/src/form-token-field/style.scss +3 -3
  668. package/src/form-token-field/test/index.tsx +6 -6
  669. package/src/gradient-picker/index.js +5 -8
  670. package/src/grid/test/grid.tsx +31 -31
  671. package/src/higher-order/navigate-regions/index.js +4 -0
  672. package/src/higher-order/navigate-regions/style.scss +52 -20
  673. package/src/higher-order/with-fallback-styles/index.js +4 -2
  674. package/src/higher-order/with-filters/test/index.js +94 -101
  675. package/src/higher-order/with-focus-return/test/index.js +1 -4
  676. package/src/higher-order/with-notices/test/index.js +1 -1
  677. package/src/icon/index.tsx +3 -2
  678. package/src/icon/test/index.js +10 -0
  679. package/src/index.js +3 -2
  680. package/src/input-control/index.tsx +42 -28
  681. package/src/input-control/input-base.tsx +8 -1
  682. package/src/input-control/stories/index.tsx +6 -0
  683. package/src/input-control/test/index.js +18 -0
  684. package/src/input-control/types.ts +2 -0
  685. package/src/item-group/stories/index.js +1 -1
  686. package/src/menu-group/{index.js → index.tsx} +22 -3
  687. package/src/menu-group/test/{index.js → index.tsx} +0 -0
  688. package/src/menu-group/types.ts +23 -0
  689. package/src/menu-item/style.scss +1 -1
  690. package/src/mobile/bottom-sheet/cell.native.js +1 -1
  691. package/src/mobile/bottom-sheet/switch-cell.native.js +2 -2
  692. package/src/mobile/bottom-sheet/test/range-cell.native.js +4 -4
  693. package/src/mobile/global-styles-context/index.native.js +9 -11
  694. package/src/mobile/html-text-input/test/index.native.js +2 -2
  695. package/src/mobile/keyboard-aware-flat-list/index.ios.js +2 -2
  696. package/src/mobile/link-settings/test/edit.native.js +70 -126
  697. package/src/mobile/link-settings/test/link-settings-navigation.native.js +5 -5
  698. package/src/modal/index.tsx +11 -0
  699. package/src/modal/stories/index.tsx +3 -0
  700. package/src/modal/test/index.tsx +15 -0
  701. package/src/navigation/stories/index.js +6 -6
  702. package/src/navigation/stories/{controlled-state.js → utils/controlled-state.js} +3 -3
  703. package/src/navigation/stories/{default.js → utils/default.js} +3 -3
  704. package/src/navigation/stories/{group.js → utils/group.js} +4 -4
  705. package/src/navigation/stories/{hide-if-empty.js → utils/hide-if-empty.js} +3 -3
  706. package/src/navigation/stories/{more-examples.js → utils/more-examples.js} +4 -4
  707. package/src/navigation/stories/{search.js → utils/search.js} +5 -5
  708. package/src/navigator/navigator-provider/component.tsx +13 -10
  709. package/src/navigator/navigator-screen/component.tsx +8 -3
  710. package/src/notice/README.md +2 -1
  711. package/src/notice/style.scss +1 -1
  712. package/src/notice/test/list.js +8 -5
  713. package/src/number-control/stories/{index.js → index.tsx} +24 -7
  714. package/src/number-control/styles/{number-control-styles.js → number-control-styles.ts} +5 -3
  715. package/src/number-control/test/index.tsx +600 -0
  716. package/src/palette-edit/index.js +91 -39
  717. package/src/palette-edit/test/index.js +25 -1
  718. package/src/panel/style.scss +1 -1
  719. package/src/popover/index.tsx +28 -9
  720. package/src/popover/style.scss +12 -11
  721. package/src/popover/test/index.tsx +25 -15
  722. package/src/query-controls/index.js +1 -0
  723. package/src/range-control/styles/range-control-styles.ts +2 -2
  724. package/src/range-control/test/index.tsx +57 -60
  725. package/src/resizable-box/style.scss +3 -2
  726. package/src/sandbox/test/index.js +13 -11
  727. package/src/scrollable/test/index.tsx +7 -3
  728. package/src/search-control/style.scss +5 -1
  729. package/src/snackbar/README.md +63 -8
  730. package/src/snackbar/{index.js → index.tsx} +46 -28
  731. package/src/snackbar/{list.js → list.tsx} +20 -21
  732. package/src/snackbar/stories/index.tsx +96 -0
  733. package/src/snackbar/stories/list.tsx +98 -0
  734. package/src/snackbar/style.scss +2 -2
  735. package/src/snackbar/types.ts +116 -0
  736. package/src/spacer/test/index.tsx +33 -3
  737. package/src/spinner/styles.ts +1 -1
  738. package/src/surface/test/index.tsx +12 -12
  739. package/src/tab-panel/README.md +9 -0
  740. package/src/tab-panel/index.tsx +23 -9
  741. package/src/tab-panel/style.scss +46 -35
  742. package/src/tab-panel/test/index.tsx +111 -0
  743. package/src/tab-panel/types.ts +20 -1
  744. package/src/text/test/__snapshots__/index.tsx.snap +1 -0
  745. package/src/text/test/index.tsx +100 -48
  746. package/src/text-control/stories/index.tsx +0 -1
  747. package/src/text-control/types.ts +1 -6
  748. package/src/theme/README.md +32 -2
  749. package/src/theme/color-algorithms.ts +138 -0
  750. package/src/theme/index.tsx +23 -16
  751. package/src/theme/stories/index.tsx +67 -0
  752. package/src/theme/styles.ts +22 -17
  753. package/src/theme/test/color-algorithms.ts +100 -0
  754. package/src/theme/test/index.tsx +68 -35
  755. package/src/theme/types.ts +43 -3
  756. package/src/toggle-control/index.tsx +4 -2
  757. package/src/toggle-group-control/stories/index.tsx +2 -0
  758. package/src/toggle-group-control/test/__snapshots__/index.tsx.snap +6 -8
  759. package/src/toggle-group-control/test/index.tsx +40 -17
  760. package/src/toggle-group-control/toggle-group-control/README.md +8 -1
  761. package/src/toggle-group-control/toggle-group-control/component.tsx +1 -1
  762. package/src/toggle-group-control/toggle-group-control/styles.ts +22 -16
  763. package/src/toggle-group-control/types.ts +2 -1
  764. package/src/toolbar-group/test/index.js +8 -6
  765. package/src/tools-panel/stories/index.js +1 -1
  766. package/src/tools-panel/stories/{tools-panel-with-item-group-slot.js → utils/tools-panel-with-item-group-slot.js} +14 -11
  767. package/src/tools-panel/styles.ts +1 -1
  768. package/src/tools-panel/test/index.js +20 -14
  769. package/src/tools-panel/tools-panel-item/hook.ts +6 -1
  770. package/src/tooltip/README.md +7 -0
  771. package/src/tooltip/style.scss +2 -2
  772. package/src/tooltip/test/index.js +109 -18
  773. package/src/tree-grid/test/index.js +12 -12
  774. package/src/truncate/test/index.tsx +9 -9
  775. package/src/ui/context/context-system-provider.js +3 -2
  776. package/src/ui/context/test/context-system-provider.js +5 -4
  777. package/src/ui/control-label/test/index.js +3 -5
  778. package/src/ui/form-group/test/index.js +16 -17
  779. package/src/unit-control/README.md +9 -1
  780. package/src/unit-control/index.tsx +3 -0
  781. package/src/unit-control/test/index.tsx +1 -0
  782. package/src/unit-control/types.ts +4 -0
  783. package/src/utils/colors-values.js +5 -3
  784. package/src/utils/config-values.js +0 -2
  785. package/src/utils/hooks/stories/use-cx.js +1 -1
  786. package/src/utils/hooks/use-controlled-value.ts +2 -2
  787. package/src/utils/input/base.js +2 -2
  788. package/src/utils/theme-variables.scss +20 -0
  789. package/src/view/{index.js → index.ts} +0 -0
  790. package/tsconfig.json +2 -4
  791. package/tsconfig.tsbuildinfo +1 -1
  792. package/src/base-field/test/index.js +0 -67
  793. package/src/dashicon/index.js +0 -26
  794. package/src/draggable/stories/index.js +0 -72
  795. package/src/number-control/test/index.js +0 -478
  796. package/src/snackbar/stories/index.js +0 -89
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * External dependencies
3
3
  */
4
- import { render, screen, act } from '@testing-library/react';
4
+ import { render, screen, act, waitFor } from '@testing-library/react';
5
5
  import userEvent from '@testing-library/user-event';
6
6
 
7
7
  /**
@@ -13,6 +13,10 @@ import Tooltip from '../';
13
13
  */
14
14
  import { TOOLTIP_DELAY } from '../index.js';
15
15
 
16
+ function getWrappingPopoverElement( element ) {
17
+ return element.closest( '.components-popover' );
18
+ }
19
+
16
20
  describe( 'Tooltip', () => {
17
21
  describe( '#render()', () => {
18
22
  it( 'should not render the tooltip if multiple children are passed', () => {
@@ -24,7 +28,7 @@ describe( 'Tooltip', () => {
24
28
  );
25
29
 
26
30
  const button = screen.getByText( 'Button 1' );
27
- button.focus();
31
+ act( () => button.focus() );
28
32
  expect( screen.queryByText( 'Help text' ) ).not.toBeInTheDocument();
29
33
  } );
30
34
 
@@ -37,11 +41,11 @@ describe( 'Tooltip', () => {
37
41
 
38
42
  expect(
39
43
  screen.getByRole( 'button', { name: 'Hover Me!' } )
40
- ).toBeInTheDocument();
44
+ ).toBeVisible();
41
45
  expect( screen.queryByText( 'Help text' ) ).not.toBeInTheDocument();
42
46
  } );
43
47
 
44
- it( 'should render children with additional tooltip when focused', () => {
48
+ it( 'should render children with additional tooltip when focused', async () => {
45
49
  const mockOnFocus = jest.fn();
46
50
 
47
51
  render(
@@ -51,20 +55,28 @@ describe( 'Tooltip', () => {
51
55
  );
52
56
 
53
57
  const button = screen.getByRole( 'button', { name: 'Hover Me!' } );
54
- expect( button ).toBeInTheDocument();
58
+ expect( button ).toBeVisible();
55
59
 
56
60
  // Before focus, the tooltip is not shown.
57
61
  expect( screen.queryByText( 'Help text' ) ).not.toBeInTheDocument();
58
62
 
59
- button.focus();
63
+ act( () => button.focus() );
60
64
 
61
65
  // Tooltip is shown after focusing the anchor.
62
- expect( screen.getByText( 'Help text' ) ).toBeInTheDocument();
66
+ const tooltip = screen.getByText( 'Help text' );
67
+ expect( tooltip ).toBeVisible();
63
68
  expect( mockOnFocus ).toHaveBeenCalledWith(
64
69
  expect.objectContaining( {
65
70
  type: 'focus',
66
71
  } )
67
72
  );
73
+
74
+ // Wait for the tooltip element to be positioned (aligned with the button)
75
+ await waitFor( () =>
76
+ expect(
77
+ getWrappingPopoverElement( tooltip )
78
+ ).toBePositionedPopover()
79
+ );
68
80
  } );
69
81
 
70
82
  it( 'should render children with additional tooltip when hovered', async () => {
@@ -79,7 +91,7 @@ describe( 'Tooltip', () => {
79
91
  );
80
92
 
81
93
  const button = screen.getByRole( 'button', { name: 'Hover Me!' } );
82
- expect( button ).toBeInTheDocument();
94
+ expect( button ).toBeVisible();
83
95
 
84
96
  await user.hover( button );
85
97
 
@@ -89,7 +101,15 @@ describe( 'Tooltip', () => {
89
101
  act( () => jest.advanceTimersByTime( TOOLTIP_DELAY ) );
90
102
 
91
103
  // Tooltip shows after the delay
92
- expect( screen.getByText( 'Help text' ) ).toBeInTheDocument();
104
+ const tooltip = screen.getByText( 'Help text' );
105
+ expect( tooltip ).toBeVisible();
106
+
107
+ // Wait for the tooltip element to be positioned (aligned with the button)
108
+ await waitFor( () =>
109
+ expect(
110
+ getWrappingPopoverElement( tooltip )
111
+ ).toBePositionedPopover()
112
+ );
93
113
  } );
94
114
 
95
115
  it( 'should not show tooltip on focus as result of mouse click', async () => {
@@ -105,7 +125,7 @@ describe( 'Tooltip', () => {
105
125
  );
106
126
 
107
127
  const button = screen.getByRole( 'button', { text: 'Hover Me!' } );
108
- expect( button ).toBeInTheDocument();
128
+ expect( button ).toBeVisible();
109
129
 
110
130
  await user.click( button );
111
131
 
@@ -144,7 +164,7 @@ describe( 'Tooltip', () => {
144
164
  );
145
165
 
146
166
  const button = screen.getByRole( 'button', { name: 'Hover Me!' } );
147
- expect( button ).toBeInTheDocument();
167
+ expect( button ).toBeVisible();
148
168
 
149
169
  await user.hover( button );
150
170
 
@@ -161,9 +181,17 @@ describe( 'Tooltip', () => {
161
181
  act( () => jest.advanceTimersByTime( TEST_DELAY - TOOLTIP_DELAY ) );
162
182
 
163
183
  // Tooltip shows after TEST_DELAY time
164
- expect( screen.getByText( 'Help text' ) ).toBeInTheDocument();
184
+ const tooltip = screen.getByText( 'Help text' );
185
+ expect( tooltip ).toBeVisible();
165
186
 
166
187
  expect( mockOnFocus ).not.toHaveBeenCalled();
188
+
189
+ // Wait for the tooltip element to be positioned (aligned with the button)
190
+ await waitFor( () =>
191
+ expect(
192
+ getWrappingPopoverElement( tooltip )
193
+ ).toBePositionedPopover()
194
+ );
167
195
  } );
168
196
 
169
197
  it( 'should show tooltip when an element is disabled', async () => {
@@ -178,12 +206,13 @@ describe( 'Tooltip', () => {
178
206
  );
179
207
 
180
208
  const button = screen.getByRole( 'button', { name: 'Click me' } );
181
- expect( button ).toBeInTheDocument();
209
+ expect( button ).toBeVisible();
182
210
  expect( button ).toBeDisabled();
183
211
 
184
212
  // Note: this is testing for implementation details,
185
213
  // but couldn't find a better way.
186
214
  const buttonRect = button.getBoundingClientRect();
215
+ // eslint-disable-next-line testing-library/no-container, testing-library/no-node-access
187
216
  const eventCatcher = container.querySelector( '.event-catcher' );
188
217
  const eventCatcherRect = eventCatcher.getBoundingClientRect();
189
218
  expect( buttonRect ).toEqual( eventCatcherRect );
@@ -198,9 +227,15 @@ describe( 'Tooltip', () => {
198
227
  act( () => jest.advanceTimersByTime( TOOLTIP_DELAY ) );
199
228
 
200
229
  // Tooltip shows after the delay
201
- expect(
202
- screen.getByText( 'Show helpful text here' )
203
- ).toBeInTheDocument();
230
+ const tooltip = screen.getByText( 'Show helpful text here' );
231
+ expect( tooltip ).toBeVisible();
232
+
233
+ // Wait for the tooltip element to be positioned (aligned with the button)
234
+ await waitFor( () =>
235
+ expect(
236
+ getWrappingPopoverElement( tooltip )
237
+ ).toBePositionedPopover()
238
+ );
204
239
  } );
205
240
 
206
241
  it( 'should not emit events back to children when they are disabled', async () => {
@@ -217,8 +252,8 @@ describe( 'Tooltip', () => {
217
252
  </Tooltip>
218
253
  );
219
254
 
220
- const eventCatcher =
221
- container.getElementsByClassName( 'event-catcher' )[ 0 ];
255
+ // eslint-disable-next-line testing-library/no-container, testing-library/no-node-access
256
+ const eventCatcher = container.querySelector( '.event-catcher' );
222
257
  await user.click( eventCatcher );
223
258
  expect( onClickMock ).not.toHaveBeenCalled();
224
259
  } );
@@ -276,5 +311,61 @@ describe( 'Tooltip', () => {
276
311
  // Tooltip won't show, since the mouse has left the anchor
277
312
  expect( screen.queryByText( 'Help text' ) ).not.toBeInTheDocument();
278
313
  } );
314
+
315
+ it( 'should render the shortcut display text when a string is passed as the shortcut', async () => {
316
+ const user = userEvent.setup( {
317
+ advanceTimers: jest.advanceTimersByTime,
318
+ } );
319
+
320
+ render(
321
+ <Tooltip text="Help text" shortcut="shortcut text">
322
+ <button>Hover Me!</button>
323
+ </Tooltip>
324
+ );
325
+
326
+ const button = screen.getByRole( 'button', { name: 'Hover Me!' } );
327
+ await user.hover( button );
328
+
329
+ const tooltip = await screen.findByText( 'shortcut text' );
330
+ expect( tooltip ).toBeVisible();
331
+
332
+ // Wait for the tooltip element to be positioned (aligned with the button)
333
+ await waitFor( () =>
334
+ expect(
335
+ getWrappingPopoverElement( tooltip )
336
+ ).toBePositionedPopover()
337
+ );
338
+ } );
339
+
340
+ it( 'should render the shortcut display text and aria-label when an object is passed as the shortcut with the correct properties', async () => {
341
+ const user = userEvent.setup( {
342
+ advanceTimers: jest.advanceTimersByTime,
343
+ } );
344
+
345
+ render(
346
+ <Tooltip
347
+ text="Help text"
348
+ shortcut={ {
349
+ display: 'shortcut text',
350
+ ariaLabel: 'shortcut label',
351
+ } }
352
+ >
353
+ <button>Hover Me!</button>
354
+ </Tooltip>
355
+ );
356
+
357
+ const button = screen.getByRole( 'button', { name: 'Hover Me!' } );
358
+ await user.hover( button );
359
+
360
+ const tooltip = await screen.findByLabelText( 'shortcut label' );
361
+ expect( tooltip ).toHaveTextContent( 'shortcut text' );
362
+
363
+ // Wait for the tooltip element to be positioned (aligned with the button)
364
+ await waitFor( () =>
365
+ expect(
366
+ getWrappingPopoverElement( tooltip )
367
+ ).toBePositionedPopover()
368
+ );
369
+ } );
279
370
  } );
280
371
  } );
@@ -97,7 +97,7 @@ describe( 'TreeGrid', () => {
97
97
  );
98
98
 
99
99
  screen.getByText( 'Row 1' ).focus();
100
- const row1Element = screen.getByText( 'Row 1' ).closest( 'tr' );
100
+ const row1Element = screen.getByRole( 'row', { name: 'Row 1' } );
101
101
 
102
102
  fireEvent.keyDown( screen.getByText( 'Row 1' ), {
103
103
  key: 'ArrowRight',
@@ -149,7 +149,7 @@ describe( 'TreeGrid', () => {
149
149
  );
150
150
 
151
151
  screen.getByText( 'Row 1' ).focus();
152
- const row1Element = screen.getByText( 'Row 1' ).closest( 'tr' );
152
+ const row1Element = screen.getByRole( 'row', { name: 'Row 1' } );
153
153
 
154
154
  fireEvent.keyDown( screen.getByText( 'Row 1' ), {
155
155
  key: 'ArrowLeft',
@@ -188,8 +188,8 @@ describe( 'TreeGrid', () => {
188
188
 
189
189
  screen.getByText( 'Row 2' ).focus();
190
190
 
191
- const row2Element = screen.getByText( 'Row 2' ).closest( 'tr' );
192
- const row3Element = screen.getByText( 'Row 3' ).closest( 'tr' );
191
+ const row2Element = screen.getByRole( 'row', { name: 'Row 2' } );
192
+ const row3Element = screen.getByRole( 'row', { name: 'Row 3' } );
193
193
 
194
194
  fireEvent.keyDown( screen.getByText( 'Row 2' ), {
195
195
  key: 'ArrowDown',
@@ -210,8 +210,8 @@ describe( 'TreeGrid', () => {
210
210
 
211
211
  screen.getByText( 'Row 1' ).focus();
212
212
 
213
- const row1Element = screen.getByText( 'Row 1' ).closest( 'tr' );
214
- const row3Element = screen.getByText( 'Row 3' ).closest( 'tr' );
213
+ const row1Element = screen.getByRole( 'row', { name: 'Row 1' } );
214
+ const row3Element = screen.getByRole( 'row', { name: 'Row 3' } );
215
215
 
216
216
  fireEvent.keyDown( screen.getByText( 'Row 1' ), {
217
217
  key: 'End',
@@ -232,8 +232,8 @@ describe( 'TreeGrid', () => {
232
232
 
233
233
  screen.getByText( 'Row 2' ).focus();
234
234
 
235
- const row2Element = screen.getByText( 'Row 2' ).closest( 'tr' );
236
- const row1Element = screen.getByText( 'Row 1' ).closest( 'tr' );
235
+ const row2Element = screen.getByRole( 'row', { name: 'Row 2' } );
236
+ const row1Element = screen.getByRole( 'row', { name: 'Row 1' } );
237
237
 
238
238
  fireEvent.keyDown( screen.getByText( 'Row 2' ), {
239
239
  key: 'ArrowUp',
@@ -254,8 +254,8 @@ describe( 'TreeGrid', () => {
254
254
 
255
255
  screen.getByText( 'Row 3' ).focus();
256
256
 
257
- const row3Element = screen.getByText( 'Row 3' ).closest( 'tr' );
258
- const row1Element = screen.getByText( 'Row 1' ).closest( 'tr' );
257
+ const row3Element = screen.getByRole( 'row', { name: 'Row 3' } );
258
+ const row1Element = screen.getByRole( 'row', { name: 'Row 1' } );
259
259
 
260
260
  fireEvent.keyDown( screen.getByText( 'Row 3' ), {
261
261
  key: 'Home',
@@ -276,8 +276,8 @@ describe( 'TreeGrid', () => {
276
276
 
277
277
  screen.getByText( 'Row 2' ).focus();
278
278
 
279
- const row2Element = screen.getByText( 'Row 2' ).closest( 'tr' );
280
- const row1Element = screen.getByText( 'Row 1' ).closest( 'tr' );
279
+ const row2Element = screen.getByRole( 'row', { name: 'Row 2' } );
280
+ const row1Element = screen.getByRole( 'row', { name: 'Row 1' } );
281
281
 
282
282
  fireEvent.keyDown( screen.getByText( 'Row 2' ), {
283
283
  key: 'ArrowUp',
@@ -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
@@ -10,34 +10,34 @@ import { Truncate } from '..';
10
10
 
11
11
  describe( 'props', () => {
12
12
  test( 'should render correctly', () => {
13
- const { container } = render( <Truncate>Lorem ipsum.</Truncate> );
14
- expect( container.firstChild ).toHaveTextContent( 'Lorem ipsum.' );
13
+ render( <Truncate>Lorem ipsum.</Truncate> );
14
+ expect( screen.getByText( 'Lorem ipsum.' ) ).toBeVisible();
15
15
  } );
16
16
 
17
17
  test( 'should render limit', () => {
18
- const { container } = render(
18
+ render(
19
19
  <Truncate limit={ 1 } ellipsizeMode="tail">
20
20
  Lorem ipsum.
21
21
  </Truncate>
22
22
  );
23
- expect( container.firstChild ).toHaveTextContent( 'L…' );
23
+ expect( screen.getByText( 'L…' ) ).toBeVisible();
24
24
  } );
25
25
 
26
26
  test( 'should render custom ellipsis', () => {
27
- const { container } = render(
27
+ render(
28
28
  <Truncate ellipsis="!!!" limit={ 5 } ellipsizeMode="tail">
29
29
  Lorem ipsum.
30
30
  </Truncate>
31
31
  );
32
- expect( container.firstChild ).toHaveTextContent( 'Lorem!!!' );
32
+ expect( screen.getByText( 'Lorem!!!' ) ).toBeVisible();
33
33
  } );
34
34
 
35
35
  test( 'should render custom ellipsizeMode', () => {
36
- const { container } = render(
36
+ render(
37
37
  <Truncate ellipsis="!!!" ellipsizeMode="middle" limit={ 5 }>
38
38
  Lorem ipsum.
39
39
  </Truncate>
40
40
  );
41
- expect( container.firstChild ).toHaveTextContent( 'Lo!!!m.' );
41
+ expect( screen.getByText( 'Lo!!!m.' ) ).toBeVisible();
42
42
  } );
43
43
  } );
@@ -1,7 +1,8 @@
1
1
  /**
2
2
  * External dependencies
3
3
  */
4
- import { isEqual, merge } from 'lodash';
4
+ import fastDeepEqual from 'fast-deep-equal/es6';
5
+ import { merge } from 'lodash';
5
6
 
6
7
  /**
7
8
  * WordPress dependencies
@@ -42,7 +43,7 @@ function useContextSystemBridge( { value } ) {
42
43
  useUpdateEffect( () => {
43
44
  if (
44
45
  // Objects are equivalent.
45
- isEqual( valueRef.current, value ) &&
46
+ fastDeepEqual( valueRef.current, value ) &&
46
47
  // But not the same reference.
47
48
  valueRef.current !== value
48
49
  ) {
@@ -61,7 +61,7 @@ describe( 'props', () => {
61
61
  );
62
62
 
63
63
  expect( container ).toMatchSnapshot();
64
- expect( container.firstChild.innerHTML ).toContain( 'Code is Poetry' );
64
+ expect( screen.getByText( 'Code is Poetry' ) ).toBeVisible();
65
65
  } );
66
66
 
67
67
  test( 'should render _override props', () => {
@@ -100,10 +100,11 @@ describe( 'props', () => {
100
100
 
101
101
  expect( container ).toMatchSnapshot();
102
102
 
103
- const el = container.querySelector( '.test-component' );
103
+ const element = screen.getByText( 'Code is Poetry' );
104
+ expect( element ).toBeVisible();
105
+ expect( element ).toHaveClass( 'test-component' );
104
106
 
105
- expect( el.innerHTML ).toContain( 'Code is Poetry' );
106
- expect( el.innerHTML ).not.toContain( 'WordPress.org' );
107
+ expect( screen.queryByText( 'WordPress.org' ) ).not.toBeInTheDocument();
107
108
  } );
108
109
  } );
109
110
 
@@ -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
@@ -16,11 +16,9 @@ describe( 'props', () => {
16
16
  } );
17
17
 
18
18
  test( 'should render htmlFor', () => {
19
- const { container } = render(
20
- <ControlLabel htmlFor="Field">Label</ControlLabel>
21
- );
19
+ render( <ControlLabel htmlFor="Field">Label</ControlLabel> );
22
20
 
23
- expect( container.firstChild ).toHaveAttribute( 'for', 'Field' );
21
+ expect( screen.getByText( 'Label' ) ).toHaveAttribute( 'for', 'Field' );
24
22
  } );
25
23
 
26
24
  test( 'should render size', () => {
@@ -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
@@ -20,44 +20,43 @@ const TextInput = ( { id: idProp, ...props } ) => {
20
20
  /* eslint-disable no-restricted-syntax */
21
21
  describe( 'props', () => {
22
22
  test( 'should render correctly', () => {
23
- const { container } = render(
23
+ render(
24
24
  <FormGroup id="fname" label="First name">
25
25
  <TextInput />
26
26
  </FormGroup>
27
27
  );
28
28
 
29
- const label = container.querySelector( 'label' );
30
- expect( label ).toHaveAttribute( 'for', 'fname' );
31
- expect( label ).toContainHTML( 'First name' );
32
-
33
- const input = container.querySelector( 'input' );
34
- expect( input ).toHaveAttribute( 'id', 'fname' );
29
+ expect(
30
+ screen.getByRole( 'textbox', { name: 'First name' } )
31
+ ).toBeVisible();
35
32
  } );
36
33
 
37
34
  test( 'should render label without prop correctly', () => {
38
- const { container } = render(
35
+ render(
39
36
  <FormGroup id="fname">
40
37
  <ControlLabel htmlFor="fname">First name</ControlLabel>
41
38
  <TextInput />
42
39
  </FormGroup>
43
40
  );
44
41
 
45
- const label = container.querySelector( 'label' );
46
- expect( label ).toHaveAttribute( 'for', 'fname' );
47
- expect( label ).toContainHTML( 'First name' );
42
+ expect(
43
+ screen.getByRole( 'textbox', { name: 'First name' } )
44
+ ).toBeVisible();
48
45
  } );
49
46
 
50
47
  test( 'should render labelHidden', () => {
51
- const { container } = render(
48
+ render(
52
49
  <FormGroup labelHidden id="fname" label="First name">
53
50
  <TextInput />
54
51
  </FormGroup>
55
52
  );
56
53
 
57
- const label = container.querySelector( 'label' );
58
- expect( label ).toContainHTML( 'First name' );
59
- // @todo: Refactor this after adding next VisuallyHidden.
60
- expect( label ).toHaveClass( 'components-visually-hidden' );
54
+ expect(
55
+ screen.getByRole( 'textbox', { name: 'First name' } )
56
+ ).toBeVisible();
57
+ expect( screen.getByText( 'First name' ) ).toHaveClass(
58
+ 'components-visually-hidden'
59
+ );
61
60
  } );
62
61
 
63
62
  test( 'should render alignLabel', () => {
@@ -67,6 +67,12 @@ Callback invoked when either the quantity or unit inputs fire the `blur` event.
67
67
 
68
68
  - Required: No
69
69
 
70
+ ### `onFocus`: `FocusEventHandler< HTMLInputElement | HTMLSelectElement >`
71
+
72
+ Callback invoked when either the quantity or unit inputs fire the `focus` event.
73
+
74
+ - Required: No
75
+
70
76
  ### `onChange`: `UnitControlOnChangeCallback`
71
77
 
72
78
  Callback when the `value` changes.
@@ -121,7 +127,9 @@ const Example = () => {
121
127
  { value: 'em', label: 'em', default: 0 },
122
128
  ];
123
129
 
124
- return <UnitControl onChange={ setValue } value={ value } units={units} />;
130
+ return (
131
+ <UnitControl onChange={ setValue } value={ value } units={ units } />
132
+ );
125
133
  };
126
134
  ```
127
135
 
@@ -60,6 +60,7 @@ function UnforwardedUnitControl(
60
60
  units: unitsProp = CSS_UNITS,
61
61
  value: valueProp,
62
62
  onBlur: onBlurProp,
63
+ onFocus: onFocusProp,
63
64
  ...props
64
65
  } = unitControlProps;
65
66
 
@@ -244,6 +245,7 @@ function UnforwardedUnitControl(
244
245
  unit={ unit }
245
246
  units={ units }
246
247
  onBlur={ onBlurProp }
248
+ onFocus={ onFocusProp }
247
249
  />
248
250
  ) : null;
249
251
 
@@ -277,6 +279,7 @@ function UnforwardedUnitControl(
277
279
  value={ parsedQuantity ?? '' }
278
280
  step={ step }
279
281
  __unstableStateReducer={ stateReducer }
282
+ onFocus={ onFocusProp }
280
283
  />
281
284
  );
282
285
  }
@@ -115,6 +115,7 @@ describe( 'UnitControl', () => {
115
115
  withoutClassName.querySelector( '.components-unit-control' )
116
116
  ).not.toHaveClass( 'hello' );
117
117
  expect(
118
+ // eslint-disable-next-line testing-library/no-container, testing-library/no-node-access
118
119
  withClassName.querySelector( '.components-unit-control' )
119
120
  ).toHaveClass( 'hello' );
120
121
  } );
@@ -99,4 +99,8 @@ export type UnitControlProps = Omit< UnitSelectControlProps, 'unit' > &
99
99
  * Callback when either the quantity or the unit inputs lose focus.
100
100
  */
101
101
  onBlur?: FocusEventHandler< HTMLInputElement | HTMLSelectElement >;
102
+ /**
103
+ * Callback when either the quantity or the unit inputs gains focus.
104
+ */
105
+ onFocus?: FocusEventHandler< HTMLInputElement | HTMLSelectElement >;
102
106
  };
@@ -31,15 +31,17 @@ const ALERT = {
31
31
 
32
32
  // Matches @wordpress/base-styles
33
33
  const ADMIN = {
34
- theme: 'var( --wp-admin-theme-color, #007cba)',
35
- themeDark10: 'var( --wp-admin-theme-color-darker-10, #006ba1)',
34
+ theme: 'var(--wp-components-color-accent, var(--wp-admin-theme-color, #007cba))',
35
+ themeDark10:
36
+ 'var(--wp-components-color-accent-darker-10, var(--wp-admin-theme-color-darker-10, #006ba1))',
36
37
  };
37
38
 
38
39
  const UI = {
39
40
  theme: ADMIN.theme,
41
+ themeDark10: ADMIN.themeDark10,
40
42
  background: white,
41
43
  backgroundDisabled: GRAY[ 100 ],
42
- border: GRAY[ 700 ],
44
+ border: GRAY[ 600 ],
43
45
  borderHover: GRAY[ 700 ],
44
46
  borderFocus: ADMIN.themeDark10,
45
47
  borderDisabled: GRAY[ 400 ],
@@ -15,9 +15,7 @@ const CONTROL_PROPS = {
15
15
  controlPaddingXSmall: `calc(${ CONTROL_PADDING_X } / 1.3334)`,
16
16
  controlBackgroundColor: COLORS.white,
17
17
  controlBorderRadius: '2px',
18
- controlBorderColor: COLORS.gray[ 700 ],
19
18
  controlBoxShadow: 'transparent',
20
- controlBorderColorHover: COLORS.gray[ 700 ],
21
19
  controlBoxShadowFocus: `0 0 0 0.5px ${ COLORS.ui.theme }`,
22
20
  controlDestructiveBorderColor: COLORS.alert.red,
23
21
  controlHeight: CONTROL_HEIGHT,
@@ -32,9 +32,9 @@ const Example = ( { serializedStyles, children } ) => {
32
32
  const ExampleWithUseMemoWrong = ( { serializedStyles, children } ) => {
33
33
  const cx = useCx();
34
34
  // Wrong: using 'useMemo' without adding 'cx' to the dependency list.
35
- // eslint-disable-next-line react-hooks/exhaustive-deps
36
35
  const classes = useMemo(
37
36
  () => cx( serializedStyles ),
37
+ // eslint-disable-next-line react-hooks/exhaustive-deps
38
38
  [ serializedStyles ]
39
39
  );
40
40
  return <span className={ classes }>{ children }</span>;
@@ -22,7 +22,7 @@ export function useControlledValue< T >( {
22
22
  defaultValue,
23
23
  onChange,
24
24
  value: valueProp,
25
- }: Props< T > ): [ T | undefined, ( value: T ) => void ] {
25
+ }: Props< T > ) {
26
26
  const hasValue = typeof valueProp !== 'undefined';
27
27
  const initialValue = hasValue ? valueProp : defaultValue;
28
28
  const [ state, setState ] = useState( initialValue );
@@ -40,5 +40,5 @@ export function useControlledValue< T >( {
40
40
  setValue = setState;
41
41
  }
42
42
 
43
- return [ value, setValue ];
43
+ return [ value, setValue as typeof setState ] as const;
44
44
  }
@@ -19,10 +19,10 @@ export const inputStyleNeutral = css`
19
19
  `;
20
20
 
21
21
  export const inputStyleFocus = css`
22
- border-color: var( --wp-admin-theme-color );
22
+ border-color: ${ COLORS.ui.theme };
23
23
  box-shadow: 0 0 0
24
24
  calc( ${ CONFIG.borderWidthFocus } - ${ CONFIG.borderWidth } )
25
- var( --wp-admin-theme-color );
25
+ ${ COLORS.ui.theme };
26
26
 
27
27
  // Windows High Contrast mode will show this outline, but not the box-shadow.
28
28
  outline: 2px solid transparent;
@@ -6,3 +6,23 @@
6
6
  $components-color-accent: var(--wp-components-color-accent, var(--wp-admin-theme-color, #007cba));
7
7
  $components-color-accent-darker-10: var(--wp-components-color-accent-darker-10, var(--wp-admin-theme-color-darker-10, #006ba1));
8
8
  $components-color-accent-darker-20: var(--wp-components-color-accent-darker-20, var(--wp-admin-theme-color-darker-20, #005a87));
9
+
10
+ // Used when placing text on the accent color.
11
+ $components-color-accent-inverted: var(--wp-components-color-accent-inverted, $white);
12
+
13
+ $components-color-background: var(--wp-components-color-background, $white);
14
+ $components-color-foreground: var(--wp-components-color-foreground, $gray-900);
15
+
16
+ // Used when placing text on the foreground color.
17
+ $components-color-foreground-inverted: var(--wp-components-color-foreground-inverted, $white);
18
+
19
+ $components-color-gray-100: var(--wp-components-color-gray-100, $gray-100);
20
+ $components-color-gray-200: var(--wp-components-color-gray-200, $gray-200);
21
+ $components-color-gray-300: var(--wp-components-color-gray-300, $gray-300);
22
+ $components-color-gray-400: var(--wp-components-color-gray-400, $gray-400);
23
+ $components-color-gray-600: var(--wp-components-color-gray-600, $gray-600);
24
+ $components-color-gray-700: var(--wp-components-color-gray-700, $gray-700);
25
+ $components-color-gray-800: var(--wp-components-color-gray-800, $gray-800);
26
+
27
+ // Semantic aliases (prefer these over raw gray values when applicable).
28
+ $components-color-border: #{ $components-color-gray-600 };
File without changes