@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,14 +1,3 @@
1
- /**
2
- * External dependencies
3
- */
4
- import styled from '@emotion/styled';
5
- import { text, select, number } from '@storybook/addon-knobs';
6
-
7
- /**
8
- * WordPress dependencies
9
- */
10
- import { useState } from '@wordpress/element';
11
-
12
1
  /**
13
2
  * Internal dependencies
14
3
  */
@@ -17,79 +6,80 @@ import Tooltip from '../';
17
6
  export default {
18
7
  title: 'Components/ToolTip',
19
8
  component: Tooltip,
9
+ argTypes: {
10
+ delay: { control: 'number' },
11
+ position: {
12
+ control: {
13
+ type: 'select',
14
+ options: [
15
+ 'top left',
16
+ 'top center',
17
+ 'top right',
18
+ 'bottom left',
19
+ 'bottom center',
20
+ 'bottom right',
21
+ ],
22
+ },
23
+ },
24
+ text: { control: 'text' },
25
+ },
20
26
  parameters: {
21
- knobs: { disable: false },
27
+ docs: { source: { state: 'open' } },
22
28
  },
23
29
  };
24
30
 
25
- export const _default = () => {
26
- const positionOptions = {
27
- 'top left': 'top left',
28
- 'top center ': 'top center',
29
- 'top right': 'top right',
30
- 'bottom left': 'bottom left',
31
- 'bottom center ': 'bottom center',
32
- 'bottom right': 'bottom right',
33
- };
34
- const tooltipText = text( 'Text', 'More information' );
35
- const position = select( 'Position', positionOptions, 'top center' );
36
- const delay = number( 'Delay', 700 );
37
- return (
38
- <>
39
- <Tooltip text={ tooltipText } position={ position } delay={ delay }>
40
- <div
41
- style={ {
42
- margin: '50px auto',
43
- width: '200px',
44
- padding: '20px',
45
- textAlign: 'center',
46
- border: '1px solid #ccc',
47
- } }
48
- >
49
- Hover for more information
50
- </div>
51
- </Tooltip>
52
- <Tooltip text={ tooltipText } position={ position } delay={ delay }>
53
- <div
54
- style={ {
55
- margin: '50px auto',
56
- width: 'min-content',
57
- padding: '4px',
58
- textAlign: 'center',
59
- border: '1px solid #ccc',
60
- } }
61
- >
62
- Small target
63
- </div>
64
- </Tooltip>
65
- </>
66
- );
31
+ const Template = ( args ) => {
32
+ return <Tooltip { ...args } />;
67
33
  };
68
34
 
69
- const Button = styled.button`
70
- margin: 0 10px;
71
- `;
35
+ export const Default = Template.bind( {} );
36
+ Default.args = {
37
+ text: 'More information',
38
+ children: (
39
+ <div
40
+ style={ {
41
+ margin: '50px auto',
42
+ width: '200px',
43
+ padding: '20px',
44
+ textAlign: 'center',
45
+ border: '1px solid #ccc',
46
+ } }
47
+ >
48
+ Hover for more information
49
+ </div>
50
+ ),
51
+ };
72
52
 
73
- export const DisabledElement = () => {
74
- const [ showMessage, toggleMessage ] = useState( false );
53
+ export const SmallTarget = Template.bind( {} );
54
+ SmallTarget.args = {
55
+ ...Default.args,
56
+ children: (
57
+ <div
58
+ style={ {
59
+ margin: '50px auto',
60
+ width: 'min-content',
61
+ padding: '4px',
62
+ textAlign: 'center',
63
+ border: '1px solid #ccc',
64
+ } }
65
+ >
66
+ Small target
67
+ </div>
68
+ ),
69
+ };
75
70
 
76
- return (
77
- <>
78
- <Tooltip text="Hey, I am tooltip" position="bottom center">
79
- <Button onClick={ () => toggleMessage( ! showMessage ) }>
80
- Hover me!
81
- </Button>
82
- </Tooltip>
83
- <Tooltip text="Hey, I am tooltip" position="bottom center">
84
- <Button
85
- disabled
86
- onClick={ () => toggleMessage( ! showMessage ) }
87
- >
88
- Hover me, but I am disabled
89
- </Button>
90
- </Tooltip>
91
- <br />
92
- { showMessage ? <p>Hello World!</p> : null }
93
- </>
94
- );
71
+ export const DisabledChild = Template.bind( {} );
72
+ DisabledChild.args = {
73
+ ...Default.args,
74
+ children: (
75
+ <button
76
+ disabled
77
+ onClick={ () =>
78
+ // eslint-disable-next-line no-alert
79
+ window.alert( 'This alert should not be triggered' )
80
+ }
81
+ >
82
+ Hover me, but I am disabled
83
+ </button>
84
+ ),
95
85
  };
@@ -7,11 +7,11 @@
7
7
  }
8
8
 
9
9
  .components-tooltip .components-popover__content {
10
- background: $gray-900;
10
+ background: $components-color-foreground; // TODO: Discuss with designers.
11
11
  border-radius: $radius-block-ui;
12
12
  border-width: 0;
13
13
  outline: none;
14
- color: $white;
14
+ color: $components-color-foreground-inverted;
15
15
  white-space: nowrap;
16
16
  text-align: center;
17
17
  line-height: 1.4;
@@ -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,12 @@ import Tooltip from '../';
13
13
  */
14
14
  import { TOOLTIP_DELAY } from '../index.js';
15
15
 
16
+ jest.useFakeTimers();
17
+
18
+ function getWrappingPopoverElement( element ) {
19
+ return element.closest( '.components-popover' );
20
+ }
21
+
16
22
  describe( 'Tooltip', () => {
17
23
  describe( '#render()', () => {
18
24
  it( 'should not render the tooltip if multiple children are passed', () => {
@@ -24,7 +30,7 @@ describe( 'Tooltip', () => {
24
30
  );
25
31
 
26
32
  const button = screen.getByText( 'Button 1' );
27
- button.focus();
33
+ act( () => button.focus() );
28
34
  expect( screen.queryByText( 'Help text' ) ).not.toBeInTheDocument();
29
35
  } );
30
36
 
@@ -37,11 +43,11 @@ describe( 'Tooltip', () => {
37
43
 
38
44
  expect(
39
45
  screen.getByRole( 'button', { name: 'Hover Me!' } )
40
- ).toBeInTheDocument();
46
+ ).toBeVisible();
41
47
  expect( screen.queryByText( 'Help text' ) ).not.toBeInTheDocument();
42
48
  } );
43
49
 
44
- it( 'should render children with additional tooltip when focused', () => {
50
+ it( 'should render children with additional tooltip when focused', async () => {
45
51
  const mockOnFocus = jest.fn();
46
52
 
47
53
  render(
@@ -51,20 +57,28 @@ describe( 'Tooltip', () => {
51
57
  );
52
58
 
53
59
  const button = screen.getByRole( 'button', { name: 'Hover Me!' } );
54
- expect( button ).toBeInTheDocument();
60
+ expect( button ).toBeVisible();
55
61
 
56
62
  // Before focus, the tooltip is not shown.
57
63
  expect( screen.queryByText( 'Help text' ) ).not.toBeInTheDocument();
58
64
 
59
- button.focus();
65
+ act( () => button.focus() );
60
66
 
61
67
  // Tooltip is shown after focusing the anchor.
62
- expect( screen.getByText( 'Help text' ) ).toBeInTheDocument();
68
+ const tooltip = screen.getByText( 'Help text' );
69
+ expect( tooltip ).toBeVisible();
63
70
  expect( mockOnFocus ).toHaveBeenCalledWith(
64
71
  expect.objectContaining( {
65
72
  type: 'focus',
66
73
  } )
67
74
  );
75
+
76
+ // Wait for the tooltip element to be positioned (aligned with the button)
77
+ await waitFor( () =>
78
+ expect(
79
+ getWrappingPopoverElement( tooltip )
80
+ ).toBePositionedPopover()
81
+ );
68
82
  } );
69
83
 
70
84
  it( 'should render children with additional tooltip when hovered', async () => {
@@ -79,7 +93,7 @@ describe( 'Tooltip', () => {
79
93
  );
80
94
 
81
95
  const button = screen.getByRole( 'button', { name: 'Hover Me!' } );
82
- expect( button ).toBeInTheDocument();
96
+ expect( button ).toBeVisible();
83
97
 
84
98
  await user.hover( button );
85
99
 
@@ -89,7 +103,15 @@ describe( 'Tooltip', () => {
89
103
  act( () => jest.advanceTimersByTime( TOOLTIP_DELAY ) );
90
104
 
91
105
  // Tooltip shows after the delay
92
- expect( screen.getByText( 'Help text' ) ).toBeInTheDocument();
106
+ const tooltip = screen.getByText( 'Help text' );
107
+ expect( tooltip ).toBeVisible();
108
+
109
+ // Wait for the tooltip element to be positioned (aligned with the button)
110
+ await waitFor( () =>
111
+ expect(
112
+ getWrappingPopoverElement( tooltip )
113
+ ).toBePositionedPopover()
114
+ );
93
115
  } );
94
116
 
95
117
  it( 'should not show tooltip on focus as result of mouse click', async () => {
@@ -105,7 +127,7 @@ describe( 'Tooltip', () => {
105
127
  );
106
128
 
107
129
  const button = screen.getByRole( 'button', { text: 'Hover Me!' } );
108
- expect( button ).toBeInTheDocument();
130
+ expect( button ).toBeVisible();
109
131
 
110
132
  await user.click( button );
111
133
 
@@ -144,7 +166,7 @@ describe( 'Tooltip', () => {
144
166
  );
145
167
 
146
168
  const button = screen.getByRole( 'button', { name: 'Hover Me!' } );
147
- expect( button ).toBeInTheDocument();
169
+ expect( button ).toBeVisible();
148
170
 
149
171
  await user.hover( button );
150
172
 
@@ -161,9 +183,17 @@ describe( 'Tooltip', () => {
161
183
  act( () => jest.advanceTimersByTime( TEST_DELAY - TOOLTIP_DELAY ) );
162
184
 
163
185
  // Tooltip shows after TEST_DELAY time
164
- expect( screen.getByText( 'Help text' ) ).toBeInTheDocument();
186
+ const tooltip = screen.getByText( 'Help text' );
187
+ expect( tooltip ).toBeVisible();
165
188
 
166
189
  expect( mockOnFocus ).not.toHaveBeenCalled();
190
+
191
+ // Wait for the tooltip element to be positioned (aligned with the button)
192
+ await waitFor( () =>
193
+ expect(
194
+ getWrappingPopoverElement( tooltip )
195
+ ).toBePositionedPopover()
196
+ );
167
197
  } );
168
198
 
169
199
  it( 'should show tooltip when an element is disabled', async () => {
@@ -178,12 +208,13 @@ describe( 'Tooltip', () => {
178
208
  );
179
209
 
180
210
  const button = screen.getByRole( 'button', { name: 'Click me' } );
181
- expect( button ).toBeInTheDocument();
211
+ expect( button ).toBeVisible();
182
212
  expect( button ).toBeDisabled();
183
213
 
184
214
  // Note: this is testing for implementation details,
185
215
  // but couldn't find a better way.
186
216
  const buttonRect = button.getBoundingClientRect();
217
+ // eslint-disable-next-line testing-library/no-container, testing-library/no-node-access
187
218
  const eventCatcher = container.querySelector( '.event-catcher' );
188
219
  const eventCatcherRect = eventCatcher.getBoundingClientRect();
189
220
  expect( buttonRect ).toEqual( eventCatcherRect );
@@ -198,9 +229,15 @@ describe( 'Tooltip', () => {
198
229
  act( () => jest.advanceTimersByTime( TOOLTIP_DELAY ) );
199
230
 
200
231
  // Tooltip shows after the delay
201
- expect(
202
- screen.getByText( 'Show helpful text here' )
203
- ).toBeInTheDocument();
232
+ const tooltip = screen.getByText( 'Show helpful text here' );
233
+ expect( tooltip ).toBeVisible();
234
+
235
+ // Wait for the tooltip element to be positioned (aligned with the button)
236
+ await waitFor( () =>
237
+ expect(
238
+ getWrappingPopoverElement( tooltip )
239
+ ).toBePositionedPopover()
240
+ );
204
241
  } );
205
242
 
206
243
  it( 'should not emit events back to children when they are disabled', async () => {
@@ -217,8 +254,8 @@ describe( 'Tooltip', () => {
217
254
  </Tooltip>
218
255
  );
219
256
 
220
- const eventCatcher =
221
- container.getElementsByClassName( 'event-catcher' )[ 0 ];
257
+ // eslint-disable-next-line testing-library/no-container, testing-library/no-node-access
258
+ const eventCatcher = container.querySelector( '.event-catcher' );
222
259
  await user.click( eventCatcher );
223
260
  expect( onClickMock ).not.toHaveBeenCalled();
224
261
  } );
@@ -276,5 +313,61 @@ describe( 'Tooltip', () => {
276
313
  // Tooltip won't show, since the mouse has left the anchor
277
314
  expect( screen.queryByText( 'Help text' ) ).not.toBeInTheDocument();
278
315
  } );
316
+
317
+ it( 'should render the shortcut display text when a string is passed as the shortcut', async () => {
318
+ const user = userEvent.setup( {
319
+ advanceTimers: jest.advanceTimersByTime,
320
+ } );
321
+
322
+ render(
323
+ <Tooltip text="Help text" shortcut="shortcut text">
324
+ <button>Hover Me!</button>
325
+ </Tooltip>
326
+ );
327
+
328
+ const button = screen.getByRole( 'button', { name: 'Hover Me!' } );
329
+ await user.hover( button );
330
+
331
+ const tooltip = await screen.findByText( 'shortcut text' );
332
+ expect( tooltip ).toBeVisible();
333
+
334
+ // Wait for the tooltip element to be positioned (aligned with the button)
335
+ await waitFor( () =>
336
+ expect(
337
+ getWrappingPopoverElement( tooltip )
338
+ ).toBePositionedPopover()
339
+ );
340
+ } );
341
+
342
+ it( 'should render the shortcut display text and aria-label when an object is passed as the shortcut with the correct properties', async () => {
343
+ const user = userEvent.setup( {
344
+ advanceTimers: jest.advanceTimersByTime,
345
+ } );
346
+
347
+ render(
348
+ <Tooltip
349
+ text="Help text"
350
+ shortcut={ {
351
+ display: 'shortcut text',
352
+ ariaLabel: 'shortcut label',
353
+ } }
354
+ >
355
+ <button>Hover Me!</button>
356
+ </Tooltip>
357
+ );
358
+
359
+ const button = screen.getByRole( 'button', { name: 'Hover Me!' } );
360
+ await user.hover( button );
361
+
362
+ const tooltip = await screen.findByLabelText( 'shortcut label' );
363
+ expect( tooltip ).toHaveTextContent( 'shortcut text' );
364
+
365
+ // Wait for the tooltip element to be positioned (aligned with the button)
366
+ await waitFor( () =>
367
+ expect(
368
+ getWrappingPopoverElement( tooltip )
369
+ ).toBePositionedPopover()
370
+ );
371
+ } );
279
372
  } );
280
373
  } );
@@ -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', () => {
@@ -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
  }
@@ -16,6 +16,8 @@ import UnitControl from '..';
16
16
  import { parseQuantityAndUnitFromRawValue } from '../utils';
17
17
  import type { UnitControlOnChangeCallback } from '../types';
18
18
 
19
+ jest.useFakeTimers();
20
+
19
21
  const getInput = ( {
20
22
  isInputTypeText = false,
21
23
  }: {
@@ -112,9 +114,11 @@ describe( 'UnitControl', () => {
112
114
  );
113
115
 
114
116
  expect(
117
+ // eslint-disable-next-line testing-library/no-node-access
115
118
  withoutClassName.querySelector( '.components-unit-control' )
116
119
  ).not.toHaveClass( 'hello' );
117
120
  expect(
121
+ // eslint-disable-next-line testing-library/no-container, testing-library/no-node-access
118
122
  withClassName.querySelector( '.components-unit-control' )
119
123
  ).toHaveClass( 'hello' );
120
124
  } );
@@ -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
  };
@@ -41,7 +41,7 @@ const UI = {
41
41
  themeDark10: ADMIN.themeDark10,
42
42
  background: white,
43
43
  backgroundDisabled: GRAY[ 100 ],
44
- border: GRAY[ 700 ],
44
+ border: GRAY[ 600 ],
45
45
  borderHover: GRAY[ 700 ],
46
46
  borderFocus: ADMIN.themeDark10,
47
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,
@@ -13,6 +13,8 @@ import { useState } from '@wordpress/element';
13
13
  */
14
14
  import { useLatestRef } from '..';
15
15
 
16
+ jest.useFakeTimers();
17
+
16
18
  function debounce( callback, timeout = 0 ) {
17
19
  let timeoutId = 0;
18
20
  return ( ...args ) => {
@@ -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
  }
@@ -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 };
package/tsconfig.json CHANGED
@@ -37,10 +37,9 @@
37
37
  "src/**/*.ios.js",
38
38
  "src/**/*.native.js",
39
39
  "src/**/react-native-*",
40
- "src/**/stories/**.js", // only exclude js files, tsx files should be checked
41
- "src/**/test/**.js", // only exclude js files, ts{x} files should be checked
40
+ "src/**/stories/**/*.js", // only exclude js files, tsx files should be checked
41
+ "src/**/test/**/*.js", // only exclude js files, ts{x} files should be checked
42
42
  "src/index.js",
43
- "src/alignment-matrix-control",
44
43
  "src/angle-picker-control",
45
44
  "src/autocomplete",
46
45
  "src/box-control",
@@ -65,7 +64,6 @@
65
64
  "src/query-controls",
66
65
  "src/responsive-wrapper",
67
66
  "src/sandbox",
68
- "src/snackbar",
69
67
  "src/toolbar",
70
68
  "src/toolbar-button",
71
69
  "src/toolbar-context",