@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
@@ -0,0 +1,138 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import { colord, extend } from 'colord';
5
+ import a11yPlugin from 'colord/plugins/a11y';
6
+ import namesPlugin from 'colord/plugins/names';
7
+
8
+ /**
9
+ * WordPress dependencies
10
+ */
11
+ import warning from '@wordpress/warning';
12
+
13
+ /**
14
+ * Internal dependencies
15
+ */
16
+ import type { ThemeInputValues, ThemeOutputValues } from './types';
17
+ import { COLORS } from '../utils';
18
+
19
+ extend( [ namesPlugin, a11yPlugin ] );
20
+
21
+ export function generateThemeVariables(
22
+ inputs: ThemeInputValues
23
+ ): ThemeOutputValues {
24
+ validateInputs( inputs );
25
+
26
+ const generatedColors = {
27
+ ...generateAccentDependentColors( inputs.accent ),
28
+ ...generateBackgroundDependentColors( inputs.background ),
29
+ };
30
+
31
+ warnContrastIssues( checkContrasts( inputs, generatedColors ) );
32
+
33
+ return { colors: generatedColors };
34
+ }
35
+
36
+ function validateInputs( inputs: ThemeInputValues ) {
37
+ for ( const [ key, value ] of Object.entries( inputs ) ) {
38
+ if ( typeof value !== 'undefined' && ! colord( value ).isValid() ) {
39
+ warning(
40
+ `wp.components.Theme: "${ value }" is not a valid color value for the '${ key }' prop.`
41
+ );
42
+ }
43
+ }
44
+ }
45
+
46
+ export function checkContrasts(
47
+ inputs: ThemeInputValues,
48
+ outputs: ThemeOutputValues[ 'colors' ]
49
+ ) {
50
+ const background = inputs.background || COLORS.white;
51
+ const accent = inputs.accent || '#007cba';
52
+ const foreground = outputs.foreground || COLORS.gray[ 900 ];
53
+ const gray = outputs.gray || COLORS.gray;
54
+
55
+ return {
56
+ accent: colord( background ).isReadable( accent )
57
+ ? undefined
58
+ : `The background color ("${ background }") does not have sufficient contrast against the accent color ("${ accent }").`,
59
+ foreground: colord( background ).isReadable( foreground )
60
+ ? undefined
61
+ : `The background color provided ("${ background }") does not have sufficient contrast against the standard foreground colors.`,
62
+ grays:
63
+ colord( background ).contrast( gray[ 600 ] ) >= 3 &&
64
+ colord( background ).contrast( gray[ 700 ] ) >= 4.5
65
+ ? undefined
66
+ : `The background color provided ("${ background }") cannot generate a set of grayscale foreground colors with sufficient contrast. Try adjusting the color to be lighter or darker.`,
67
+ };
68
+ }
69
+
70
+ function warnContrastIssues( issues: ReturnType< typeof checkContrasts > ) {
71
+ for ( const error of Object.values( issues ) ) {
72
+ if ( error ) {
73
+ warning( 'wp.components.Theme: ' + error );
74
+ }
75
+ }
76
+ }
77
+
78
+ function generateAccentDependentColors( accent?: string ) {
79
+ if ( ! accent ) return {};
80
+
81
+ return {
82
+ accent,
83
+ accentDarker10: colord( accent ).darken( 0.1 ).toHex(),
84
+ accentDarker20: colord( accent ).darken( 0.2 ).toHex(),
85
+ accentInverted: getForegroundForColor( accent ),
86
+ };
87
+ }
88
+
89
+ function generateBackgroundDependentColors( background?: string ) {
90
+ if ( ! background ) return {};
91
+
92
+ const foreground = getForegroundForColor( background );
93
+
94
+ return {
95
+ background,
96
+ foreground,
97
+ foregroundInverted: getForegroundForColor( foreground ),
98
+ gray: generateShades( background, foreground ),
99
+ };
100
+ }
101
+
102
+ function getForegroundForColor( color: string ) {
103
+ return colord( color ).isDark() ? COLORS.white : COLORS.gray[ 900 ];
104
+ }
105
+
106
+ export function generateShades( background: string, foreground: string ) {
107
+ // How much darkness you need to add to #fff to get the COLORS.gray[n] color
108
+ const SHADES = {
109
+ 100: 0.06,
110
+ 200: 0.121,
111
+ 300: 0.132,
112
+ 400: 0.2,
113
+ 600: 0.42,
114
+ 700: 0.543,
115
+ 800: 0.821,
116
+ };
117
+
118
+ // Darkness of COLORS.gray[ 900 ], relative to #fff
119
+ const limit = 0.884;
120
+
121
+ const direction = colord( background ).isDark() ? 'lighten' : 'darken';
122
+
123
+ // Lightness delta between the background and foreground colors
124
+ const range =
125
+ Math.abs(
126
+ colord( background ).toHsl().l - colord( foreground ).toHsl().l
127
+ ) / 100;
128
+
129
+ const result: Record< number, string > = {};
130
+
131
+ Object.entries( SHADES ).forEach( ( [ key, value ] ) => {
132
+ result[ parseInt( key ) ] = colord( background )
133
+ [ direction ]( ( value / limit ) * range )
134
+ .toHex();
135
+ } );
136
+
137
+ return result as NonNullable< ThemeOutputValues[ 'colors' ][ 'gray' ] >;
138
+ }
@@ -1,18 +1,16 @@
1
1
  /**
2
- * External dependencies
2
+ * WordPress dependencies
3
3
  */
4
- import { colord, extend } from 'colord';
5
- import a11yPlugin from 'colord/plugins/a11y';
6
- import namesPlugin from 'colord/plugins/names';
4
+ import { useMemo } from '@wordpress/element';
7
5
 
8
6
  /**
9
7
  * Internal dependencies
10
8
  */
11
9
  import type { ThemeProps } from './types';
12
10
  import type { WordPressComponentProps } from '../ui/context';
13
- import { Wrapper } from './styles';
14
-
15
- extend( [ namesPlugin, a11yPlugin ] );
11
+ import { colorVariables, Wrapper } from './styles';
12
+ import { generateThemeVariables } from './color-algorithms';
13
+ import { useCx } from '../utils';
16
14
 
17
15
  /**
18
16
  * `Theme` allows defining theme variables for components in the `@wordpress/components` package.
@@ -36,16 +34,25 @@ extend( [ namesPlugin, a11yPlugin ] );
36
34
  * };
37
35
  * ```
38
36
  */
39
- function Theme( props: WordPressComponentProps< ThemeProps, 'div', true > ) {
40
- const { accent } = props;
41
- if ( accent && ! colord( accent ).isValid() ) {
42
- // eslint-disable-next-line no-console
43
- console.warn(
44
- `wp.components.Theme: "${ accent }" is not a valid color value for the 'accent' prop.`
45
- );
46
- }
37
+ function Theme( {
38
+ accent,
39
+ background,
40
+ className,
41
+ ...props
42
+ }: WordPressComponentProps< ThemeProps, 'div', true > ) {
43
+ const cx = useCx();
44
+ const classes = useMemo(
45
+ () =>
46
+ cx(
47
+ ...colorVariables(
48
+ generateThemeVariables( { accent, background } )
49
+ ),
50
+ className
51
+ ),
52
+ [ accent, background, className, cx ]
53
+ );
47
54
 
48
- return <Wrapper { ...props } />;
55
+ return <Wrapper className={ classes } { ...props } />;
49
56
  }
50
57
 
51
58
  export default Theme;
@@ -8,12 +8,15 @@ import type { ComponentMeta, ComponentStory } from '@storybook/react';
8
8
  */
9
9
  import Theme from '../index';
10
10
  import Button from '../../button';
11
+ import { generateThemeVariables, checkContrasts } from '../color-algorithms';
12
+ import { HStack } from '../../h-stack';
11
13
 
12
14
  const meta: ComponentMeta< typeof Theme > = {
13
15
  component: Theme,
14
16
  title: 'Components (Experimental)/Theme',
15
17
  argTypes: {
16
18
  accent: { control: { type: 'color' } },
19
+ background: { control: { type: 'color' } },
17
20
  },
18
21
  parameters: {
19
22
  controls: { expanded: true },
@@ -45,3 +48,67 @@ export const Nested: ComponentStory< typeof Theme > = ( args ) => (
45
48
  Nested.args = {
46
49
  accent: 'blue',
47
50
  };
51
+
52
+ /**
53
+ * The rest of the required colors are generated based on the given accent and background colors.
54
+ */
55
+ export const ColorScheme: ComponentStory< typeof Theme > = ( {
56
+ accent,
57
+ background,
58
+ } ) => {
59
+ const { colors } = generateThemeVariables( { accent, background } );
60
+ const { gray, ...otherColors } = colors;
61
+ const contrastIssues = Object.entries(
62
+ checkContrasts( { accent, background }, colors )
63
+ ).filter( ( [ _, error ] ) => !! error );
64
+
65
+ const Chip = ( { color, name }: { color: string; name: string } ) => (
66
+ <HStack justify="flex-start">
67
+ <div
68
+ style={ {
69
+ backgroundColor: color,
70
+ height: '1.25em',
71
+ width: 40,
72
+ } }
73
+ />
74
+ <div style={ { fontSize: 14 } }>{ name }</div>
75
+ </HStack>
76
+ );
77
+
78
+ return (
79
+ <>
80
+ { Object.entries( otherColors ).map( ( [ key, value ] ) => (
81
+ <Chip color={ value } name={ key } key={ key } />
82
+ ) ) }
83
+ { Object.entries( gray as NonNullable< typeof gray > ).map(
84
+ ( [ key, value ] ) => (
85
+ <Chip
86
+ color={ value }
87
+ name={ `gray ${ key }` }
88
+ key={ key }
89
+ />
90
+ )
91
+ ) }
92
+ { !! contrastIssues.length && (
93
+ <>
94
+ <h2>Contrast issues</h2>
95
+ <ul>
96
+ { contrastIssues.map( ( [ key, error ] ) => (
97
+ <li key={ key }>{ error }</li>
98
+ ) ) }
99
+ </ul>
100
+ </>
101
+ ) }
102
+ </>
103
+ );
104
+ };
105
+ ColorScheme.args = {
106
+ accent: '#007cba',
107
+ background: '#fff',
108
+ };
109
+ ColorScheme.argTypes = {
110
+ children: { table: { disable: true } },
111
+ };
112
+ ColorScheme.parameters = {
113
+ docs: { source: { state: 'closed' } },
114
+ };
@@ -1,28 +1,33 @@
1
1
  /**
2
2
  * External dependencies
3
3
  */
4
- import { colord } from 'colord';
5
4
  import styled from '@emotion/styled';
6
5
  import { css } from '@emotion/react';
7
6
 
8
7
  /**
9
8
  * Internal dependencies
10
9
  */
11
- import type { ThemeProps } from './types';
10
+ import type { ThemeOutputValues } from './types';
12
11
 
13
- const accentColor = ( { accent }: ThemeProps ) =>
14
- accent
15
- ? css`
16
- --wp-components-color-accent: ${ accent };
17
- --wp-components-color-accent-darker-10: ${ colord( accent )
18
- .darken( 0.1 )
19
- .toHex() };
20
- --wp-components-color-accent-darker-20: ${ colord( accent )
21
- .darken( 0.2 )
22
- .toHex() };
23
- `
24
- : undefined;
12
+ export const colorVariables = ( { colors }: ThemeOutputValues ) => {
13
+ const shades = Object.entries( colors.gray || {} )
14
+ .map( ( [ k, v ] ) => `--wp-components-color-gray-${ k }: ${ v };` )
15
+ .join( '' );
25
16
 
26
- export const Wrapper = styled.div< ThemeProps >`
27
- ${ accentColor }
28
- `;
17
+ return [
18
+ css`
19
+ --wp-components-color-accent: ${ colors.accent };
20
+ --wp-components-color-accent-darker-10: ${ colors.accentDarker10 };
21
+ --wp-components-color-accent-darker-20: ${ colors.accentDarker20 };
22
+ --wp-components-color-accent-inverted: ${ colors.accentInverted };
23
+
24
+ --wp-components-color-background: ${ colors.background };
25
+ --wp-components-color-foreground: ${ colors.foreground };
26
+ --wp-components-color-foreground-inverted: ${ colors.foregroundInverted };
27
+
28
+ ${ shades }
29
+ `,
30
+ ];
31
+ };
32
+
33
+ export const Wrapper = styled.div``;
@@ -0,0 +1,100 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import { colord } from 'colord';
5
+
6
+ /**
7
+ * Internal dependencies
8
+ */
9
+ import { COLORS } from '../../utils';
10
+
11
+ /**
12
+ * Internal dependencies
13
+ */
14
+ import { generateShades, generateThemeVariables } from '../color-algorithms';
15
+
16
+ describe( 'Theme color algorithms', () => {
17
+ describe( 'generateThemeVariables', () => {
18
+ it( 'should allow explicitly undefined values', () => {
19
+ generateThemeVariables( {
20
+ accent: undefined,
21
+ background: undefined,
22
+ } );
23
+ expect( console ).not.toHaveWarned();
24
+ } );
25
+
26
+ it( 'should warn if invalid colors are passed', () => {
27
+ generateThemeVariables( { accent: 'var(--invalid)' } );
28
+ expect( console ).toHaveWarned();
29
+ } );
30
+
31
+ it( 'should warn if standard foreground colors are not readable against background', () => {
32
+ generateThemeVariables( { background: '#777' } );
33
+ expect( console ).toHaveWarnedWith(
34
+ 'wp.components.Theme: The background color provided ("#777") does not have sufficient contrast against the standard foreground colors.'
35
+ );
36
+ } );
37
+
38
+ it( 'should warn if accent color is not readable against background', () => {
39
+ generateThemeVariables( { background: '#fefefe' } );
40
+ expect( console ).not.toHaveWarned();
41
+
42
+ generateThemeVariables( {
43
+ accent: '#000',
44
+ background: '#fff',
45
+ } );
46
+ expect( console ).not.toHaveWarned();
47
+
48
+ generateThemeVariables( {
49
+ accent: '#111',
50
+ background: '#000',
51
+ } );
52
+ expect( console ).toHaveWarnedWith(
53
+ 'wp.components.Theme: The background color ("#000") does not have sufficient contrast against the accent color ("#111").'
54
+ );
55
+
56
+ generateThemeVariables( { background: '#eee' } );
57
+ expect( console ).toHaveWarnedWith(
58
+ 'wp.components.Theme: The background color ("#eee") does not have sufficient contrast against the accent color ("#007cba").'
59
+ );
60
+ } );
61
+
62
+ it( 'should warn if a readable grayscale cannot be generated', () => {
63
+ generateThemeVariables( { background: '#ddd' } );
64
+ expect( console ).toHaveWarnedWith(
65
+ 'wp.components.Theme: The background color provided ("#ddd") cannot generate a set of grayscale foreground colors with sufficient contrast. Try adjusting the color to be lighter or darker.'
66
+ );
67
+ } );
68
+ } );
69
+
70
+ describe( 'generateShades', () => {
71
+ it( 'should generate the default WP shades when the default WP background/foreground colors are given', () => {
72
+ const shades = generateShades( '#fff', '#1e1e1e' );
73
+
74
+ Object.entries( shades ).forEach( ( [ k, color ] ) => {
75
+ const key = parseInt( k, 10 ) as keyof typeof shades;
76
+ const normalizedExpectedColor = colord(
77
+ COLORS.gray[ key ]
78
+ ).toHex();
79
+
80
+ expect( color ).toBe( normalizedExpectedColor );
81
+ } );
82
+ } );
83
+
84
+ it.each( [
85
+ [ '#000', '#fff' ], // wide delta
86
+ [ '#fff', '#000' ], // flipped
87
+ [ '#eee', '#fff' ], // narrow delta
88
+ ] )( 'should generate unique shades (bg: %s, fg: %s)', ( bg, fg ) => {
89
+ const shades = generateShades( bg, fg );
90
+
91
+ // The darkest and lightest shades should be different from the fg/bg colors
92
+ expect( colord( shades[ 100 ] ).isEqual( bg ) ).toBe( false );
93
+ expect( colord( shades[ 800 ] ).isEqual( fg ) ).toBe( false );
94
+
95
+ // The shades should be unique
96
+ const shadeValues = Object.values( shades );
97
+ expect( shadeValues ).toHaveLength( new Set( shadeValues ).size );
98
+ } );
99
+ } );
100
+ } );
@@ -28,59 +28,93 @@ describe( 'Theme', () => {
28
28
  describe( 'accent color', () => {
29
29
  it( 'it does not define the accent color (and its variations) as a CSS variable when the `accent` prop is undefined', () => {
30
30
  render(
31
- <Theme>
31
+ <Theme data-testid="theme">
32
32
  <MyThemableComponent>Inner</MyThemableComponent>
33
33
  </Theme>
34
34
  );
35
35
 
36
- const inner = screen.getByText( 'Inner' );
37
-
38
- if ( inner?.parentElement === null ) {
39
- throw new Error(
40
- 'Somehow the `Theme` component does not render a DOM element?'
41
- );
42
- }
43
-
44
36
  const innerElementStyles = window.getComputedStyle(
45
- inner?.parentElement
37
+ screen.getByTestId( 'theme' )
46
38
  );
47
39
 
48
- expect(
49
- innerElementStyles.getPropertyValue(
50
- '--wp-components-color-accent'
51
- )
52
- ).toBe( '' );
53
-
54
- expect(
55
- innerElementStyles.getPropertyValue(
56
- '--wp-components-color-accent-darker-10'
57
- )
58
- ).toBe( '' );
59
-
60
- expect(
61
- innerElementStyles.getPropertyValue(
62
- '--wp-components-color-accent-darker-20'
63
- )
64
- ).toBe( '' );
40
+ [
41
+ '--wp-components-color-accent',
42
+ '--wp-components-color-accent-darker-10',
43
+ '--wp-components-color-accent-darker-20',
44
+ '--wp-components-color-accent-inverted',
45
+ ].forEach( ( cssVariable ) => {
46
+ expect(
47
+ innerElementStyles.getPropertyValue( cssVariable )
48
+ ).toBe( '' );
49
+ } );
65
50
  } );
66
51
 
67
52
  it( 'it defines the accent color (and its variations) as a CSS variable', () => {
68
53
  render(
69
- <Theme accent="#123abc">
54
+ <Theme accent="#123abc" data-testid="theme">
70
55
  <MyThemableComponent>Inner</MyThemableComponent>
71
56
  </Theme>
72
57
  );
73
58
 
74
- const inner = screen.getByText( 'Inner' );
75
-
76
- expect( inner?.parentElement ).toHaveStyle( {
59
+ expect( screen.getByTestId( 'theme' ) ).toHaveStyle( {
77
60
  '--wp-components-color-accent': '#123abc',
78
61
  '--wp-components-color-accent-darker-10': '#0e2c8d',
79
62
  '--wp-components-color-accent-darker-20': '#091d5f',
63
+ '--wp-components-color-accent-inverted': '#fff',
64
+ } );
65
+ } );
66
+ } );
67
+
68
+ describe( 'background color', () => {
69
+ it( 'it does not define the background color (and its dependent colors) as a CSS variable when the `background` prop is undefined', () => {
70
+ render(
71
+ <Theme data-testid="theme">
72
+ <MyThemableComponent>Inner</MyThemableComponent>
73
+ </Theme>
74
+ );
75
+
76
+ const innerElementStyles = window.getComputedStyle(
77
+ screen.getByTestId( 'theme' )
78
+ );
79
+
80
+ [
81
+ '--wp-components-color-background',
82
+ '--wp-components-color-foreground',
83
+ '--wp-components-color-foreground-inverted',
84
+ ...[ '100', '200', '300', '400', '600', '700', '800' ].map(
85
+ ( shade ) => `--wp-components-color-gray-${ shade }`
86
+ ),
87
+ ].forEach( ( cssVariable ) => {
88
+ expect(
89
+ innerElementStyles.getPropertyValue( cssVariable )
90
+ ).toBe( '' );
91
+ } );
92
+ } );
93
+
94
+ it( 'it defines the background color (and its dependent colors) as a CSS variable', () => {
95
+ render(
96
+ <Theme background="#ffffff" data-testid="theme">
97
+ <MyThemableComponent>Inner</MyThemableComponent>
98
+ </Theme>
99
+ );
100
+
101
+ expect( screen.getByTestId( 'theme' ) ).toHaveStyle( {
102
+ '--wp-components-color-background': '#ffffff',
103
+ '--wp-components-color-foreground': '#1e1e1e',
104
+ '--wp-components-color-foreground-inverted': '#fff',
105
+ '--wp-components-color-gray-100': '#f0f0f0',
106
+ '--wp-components-color-gray-200': '#e0e0e0',
107
+ '--wp-components-color-gray-300': '#dddddd',
108
+ '--wp-components-color-gray-400': '#cccccc',
109
+ '--wp-components-color-gray-600': '#949494',
110
+ '--wp-components-color-gray-700': '#757575',
111
+ '--wp-components-color-gray-800': '#2f2f2f',
80
112
  } );
81
113
  } );
114
+ } );
82
115
 
83
- describe( 'unsupported values', () => {
116
+ describe( 'unsupported values', () => {
117
+ describe.each( [ 'accent', 'background' ] )( '%s', ( propName ) => {
84
118
  it.each( [
85
119
  // Keywords
86
120
  'currentcolor',
@@ -91,9 +125,8 @@ describe( 'Theme', () => {
91
125
  'unset',
92
126
  // CSS Custom properties
93
127
  'var( --my-variable )',
94
- ] )( 'should warn when the value is "%s"', ( accentValue ) => {
95
- render( <Theme accent={ accentValue } /> );
96
-
128
+ ] )( 'should warn when the value is "%s"', ( value ) => {
129
+ render( <Theme { ...{ [ propName ]: value } } /> );
97
130
  expect( console ).toHaveWarned();
98
131
  } );
99
132
  } );
@@ -3,17 +3,57 @@
3
3
  */
4
4
  import type { ReactNode } from 'react';
5
5
 
6
- export type ThemeProps = {
6
+ export type ThemeInputValues = {
7
7
  /**
8
- * Used to set the accent color (used by components as the primary color).
8
+ * The accent color (used by components as the primary color).
9
9
  *
10
10
  * If an accent color is not defined, the default fallback value is the original
11
- * WP Admin main theme color. No all valid CSS color syntaxes are supported —
11
+ * WP Admin main theme color. Not all valid CSS color syntaxes are supported —
12
12
  * in particular, keywords (like `'currentcolor'`, `'inherit'`, `'initial'`,
13
13
  * `'revert'`, `'unset'`...) and CSS custom properties (e.g.
14
14
  * `var(--my-custom-property)`) are _not_ supported values for this property.
15
15
  */
16
16
  accent?: string;
17
+ /**
18
+ * The background color.
19
+ *
20
+ * If a component explicitly has a background, it will be this color.
21
+ * Otherwise, this color will simply be used to determine what the foreground colors should be.
22
+ * The actual background color will need to be set on the component's container element.
23
+ *
24
+ * If a background color is not defined, the default fallback value is #fff.
25
+ * Not all valid CSS color syntaxes are supported —
26
+ * in particular, keywords (like `'currentcolor'`, `'inherit'`, `'initial'`,
27
+ * `'revert'`, `'unset'`...) and CSS custom properties (e.g.
28
+ * `var(--my-custom-property)`) are _not_ supported values for this property.
29
+ */
30
+ background?: string;
31
+ };
32
+
33
+ export type ThemeOutputValues = {
34
+ colors: Partial< {
35
+ accent: string;
36
+ accentDarker10: string;
37
+ accentDarker20: string;
38
+ /** Foreground color to use when accent color is the background. */
39
+ accentInverted: string;
40
+ background: string;
41
+ foreground: string;
42
+ /** Foreground color to use when foreground color is the background. */
43
+ foregroundInverted: string;
44
+ gray: {
45
+ 100: string;
46
+ 200: string;
47
+ 300: string;
48
+ 400: string;
49
+ 600: string;
50
+ 700: string;
51
+ 800: string;
52
+ };
53
+ } >;
54
+ };
55
+
56
+ export type ThemeProps = ThemeInputValues & {
17
57
  /**
18
58
  * The children elements.
19
59
  */
@@ -12,6 +12,7 @@ import { useInstanceId } from '@wordpress/compose';
12
12
  /**
13
13
  * Internal dependencies
14
14
  */
15
+ import { FlexBlock } from '../flex';
15
16
  import FormToggle from '../form-toggle';
16
17
  import BaseControl from '../base-control';
17
18
  import type { WordPressComponentProps } from '../ui/context/wordpress-component';
@@ -94,12 +95,13 @@ export function ToggleControl( {
94
95
  aria-describedby={ describedBy }
95
96
  disabled={ disabled }
96
97
  />
97
- <label
98
+ <FlexBlock
99
+ as="label"
98
100
  htmlFor={ id }
99
101
  className="components-toggle-control__label"
100
102
  >
101
103
  { label }
102
- </label>
104
+ </FlexBlock>
103
105
  </HStack>
104
106
  </BaseControl>
105
107
  );
@@ -81,6 +81,7 @@ Default.args = {
81
81
  { value: 'right', label: 'Right' },
82
82
  { value: 'justify', label: 'Justify' },
83
83
  ].map( mapPropsToOptionComponent ),
84
+ isBlock: true,
84
85
  label: 'Label',
85
86
  };
86
87
 
@@ -121,6 +122,7 @@ WithIcons.args = {
121
122
  { value: 'uppercase', label: 'Uppercase', icon: formatUppercase },
122
123
  { value: 'lowercase', label: 'Lowercase', icon: formatLowercase },
123
124
  ].map( mapPropsToOptionIconComponent ),
125
+ isBlock: false,
124
126
  };
125
127
 
126
128
  /**