@wordpress/components 16.0.1-next.5df0cd52b7.0 → 19.0.1

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 (1823) hide show
  1. package/CHANGELOG.md +71 -4
  2. package/CONTRIBUTING.md +398 -6
  3. package/README.md +9 -1
  4. package/build/angle-picker-control/index.js +29 -24
  5. package/build/angle-picker-control/index.js.map +1 -1
  6. package/build/angle-picker-control/styles/angle-picker-control-styles.js +10 -13
  7. package/build/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
  8. package/build/animate/index.js +1 -1
  9. package/build/animate/index.js.map +1 -1
  10. package/build/autocomplete/autocompleter-ui.native.js +5 -4
  11. package/build/autocomplete/autocompleter-ui.native.js.map +1 -1
  12. package/build/base-control/index.js +2 -2
  13. package/build/base-control/index.js.map +1 -1
  14. package/build/base-field/hook.js +1 -1
  15. package/build/base-field/hook.js.map +1 -1
  16. package/build/button/index.js +4 -1
  17. package/build/button/index.js.map +1 -1
  18. package/build/card/card/component.js +3 -3
  19. package/build/card/card/component.js.map +1 -1
  20. package/build/card/card/hook.js +4 -5
  21. package/build/card/card/hook.js.map +1 -1
  22. package/build/card/card-body/component.js +2 -2
  23. package/build/card/card-body/component.js.map +1 -1
  24. package/build/card/card-body/hook.js +1 -1
  25. package/build/card/card-body/hook.js.map +1 -1
  26. package/build/card/card-divider/component.js +2 -2
  27. package/build/card/card-divider/component.js.map +1 -1
  28. package/build/card/card-divider/hook.js +1 -1
  29. package/build/card/card-divider/hook.js.map +1 -1
  30. package/build/card/card-footer/component.js +2 -2
  31. package/build/card/card-footer/component.js.map +1 -1
  32. package/build/card/card-footer/hook.js +1 -1
  33. package/build/card/card-footer/hook.js.map +1 -1
  34. package/build/card/card-header/component.js +2 -2
  35. package/build/card/card-header/component.js.map +1 -1
  36. package/build/card/card-header/hook.js +1 -1
  37. package/build/card/card-header/hook.js.map +1 -1
  38. package/build/card/card-media/component.js +23 -7
  39. package/build/card/card-media/component.js.map +1 -1
  40. package/build/card/card-media/hook.js +1 -1
  41. package/build/card/card-media/hook.js.map +1 -1
  42. package/build/color-edit/index.js +181 -201
  43. package/build/color-edit/index.js.map +1 -1
  44. package/build/color-edit/styles.js +112 -0
  45. package/build/color-edit/styles.js.map +1 -0
  46. package/build/color-list-picker/index.js +6 -1
  47. package/build/color-list-picker/index.js.map +1 -1
  48. package/build/color-palette/index.js +115 -42
  49. package/build/color-palette/index.js.map +1 -1
  50. package/build/color-palette/styles.js +31 -0
  51. package/build/color-palette/styles.js.map +1 -0
  52. package/build/{ui/color-picker → color-picker}/color-display.js +36 -21
  53. package/build/color-picker/color-display.js.map +1 -0
  54. package/build/{ui/color-picker → color-picker}/color-input.js +0 -0
  55. package/build/color-picker/color-input.js.map +1 -0
  56. package/build/{ui/color-picker → color-picker}/component.js +37 -49
  57. package/build/color-picker/component.js.map +1 -0
  58. package/build/color-picker/hex-input.js +63 -0
  59. package/build/color-picker/hex-input.js.map +1 -0
  60. package/build/{ui/color-picker → color-picker}/hsl-input.js +40 -30
  61. package/build/color-picker/hsl-input.js.map +1 -0
  62. package/build/color-picker/index.js +6 -276
  63. package/build/color-picker/index.js.map +1 -1
  64. package/build/color-picker/index.native.js +16 -11
  65. package/build/color-picker/index.native.js.map +1 -1
  66. package/build/{ui/color-picker → color-picker}/input-with-slider.js +10 -13
  67. package/build/color-picker/input-with-slider.js.map +1 -0
  68. package/build/color-picker/legacy-adapter.js +24 -0
  69. package/build/color-picker/legacy-adapter.js.map +1 -0
  70. package/build/color-picker/picker.js +37 -0
  71. package/build/color-picker/picker.js.map +1 -0
  72. package/build/{ui/color-picker → color-picker}/rgb-input.js +10 -12
  73. package/build/color-picker/rgb-input.js.map +1 -0
  74. package/build/color-picker/styles.js +102 -0
  75. package/build/color-picker/styles.js.map +1 -0
  76. package/build/{segmented-control → color-picker}/types.js +0 -0
  77. package/build/color-picker/types.js.map +1 -0
  78. package/build/color-picker/use-deprecated-props.js +81 -0
  79. package/build/color-picker/use-deprecated-props.js.map +1 -0
  80. package/build/combobox-control/index.js +25 -5
  81. package/build/combobox-control/index.js.map +1 -1
  82. package/build/custom-gradient-bar/constants.js +2 -2
  83. package/build/custom-gradient-bar/constants.js.map +1 -1
  84. package/build/custom-gradient-bar/control-points.js +29 -53
  85. package/build/custom-gradient-bar/control-points.js.map +1 -1
  86. package/build/custom-gradient-picker/index.js +4 -3
  87. package/build/custom-gradient-picker/index.js.map +1 -1
  88. package/build/custom-gradient-picker/styles/custom-gradient-picker-styles.js +6 -6
  89. package/build/custom-gradient-picker/styles/custom-gradient-picker-styles.js.map +1 -1
  90. package/build/custom-gradient-picker/utils.js +8 -4
  91. package/build/custom-gradient-picker/utils.js.map +1 -1
  92. package/build/custom-select-control/index.js +32 -8
  93. package/build/custom-select-control/index.js.map +1 -1
  94. package/build/dashicon/index.native.js +39 -0
  95. package/build/dashicon/index.native.js.map +1 -0
  96. package/build/date-time/index.js +1 -1
  97. package/build/date-time/index.js.map +1 -1
  98. package/build/dimension-control/sizes.js +5 -5
  99. package/build/dimension-control/sizes.js.map +1 -1
  100. package/build/divider/component.js.map +1 -1
  101. package/build/drop-zone/index.js +54 -3
  102. package/build/drop-zone/index.js.map +1 -1
  103. package/build/dropdown/index.js +7 -1
  104. package/build/dropdown/index.js.map +1 -1
  105. package/build/dropdown-menu/index.js +21 -35
  106. package/build/dropdown-menu/index.js.map +1 -1
  107. package/build/dropdown-menu/index.native.js +2 -22
  108. package/build/dropdown-menu/index.native.js.map +1 -1
  109. package/build/duotone-picker/custom-duotone-bar.js +0 -1
  110. package/build/duotone-picker/custom-duotone-bar.js.map +1 -1
  111. package/build/duotone-picker/duotone-picker.js +1 -0
  112. package/build/duotone-picker/duotone-picker.js.map +1 -1
  113. package/build/duotone-picker/utils.js +6 -3
  114. package/build/duotone-picker/utils.js.map +1 -1
  115. package/build/elevation/component.js +24 -8
  116. package/build/elevation/component.js.map +1 -1
  117. package/build/elevation/hook.js +5 -5
  118. package/build/elevation/hook.js.map +1 -1
  119. package/build/flex/flex/component.js +2 -2
  120. package/build/flex/flex/component.js.map +1 -1
  121. package/build/flex/flex/hook.js +26 -32
  122. package/build/flex/flex/hook.js.map +1 -1
  123. package/build/flex/flex-block/component.js +23 -7
  124. package/build/flex/flex-block/component.js.map +1 -1
  125. package/build/flex/flex-block/hook.js +1 -1
  126. package/build/flex/flex-block/hook.js.map +1 -1
  127. package/build/flex/flex-item/component.js +23 -7
  128. package/build/flex/flex-item/component.js.map +1 -1
  129. package/build/flex/flex-item/hook.js +2 -2
  130. package/build/flex/flex-item/hook.js.map +1 -1
  131. package/build/flyout/flyout/component.js +2 -2
  132. package/build/flyout/flyout/component.js.map +1 -1
  133. package/build/flyout/flyout/hook.js +1 -1
  134. package/build/flyout/flyout/hook.js.map +1 -1
  135. package/build/flyout/flyout-content/component.js +2 -2
  136. package/build/flyout/flyout-content/component.js.map +1 -1
  137. package/build/focal-point-picker/controls.js +1 -1
  138. package/build/focal-point-picker/controls.js.map +1 -1
  139. package/build/focusable-iframe/index.js +6 -28
  140. package/build/focusable-iframe/index.js.map +1 -1
  141. package/build/font-size-picker/index.js +107 -72
  142. package/build/font-size-picker/index.js.map +1 -1
  143. package/build/font-size-picker/index.native.js +162 -0
  144. package/build/font-size-picker/index.native.js.map +1 -0
  145. package/build/font-size-picker/utils.js +119 -0
  146. package/build/font-size-picker/utils.js.map +1 -0
  147. package/build/gradient-picker/index.js +69 -9
  148. package/build/gradient-picker/index.js.map +1 -1
  149. package/build/grid/component.js +21 -7
  150. package/build/grid/component.js.map +1 -1
  151. package/build/grid/hook.js +2 -2
  152. package/build/grid/hook.js.map +1 -1
  153. package/build/guide/index.js +10 -9
  154. package/build/guide/index.js.map +1 -1
  155. package/build/h-stack/component.js +23 -7
  156. package/build/h-stack/component.js.map +1 -1
  157. package/build/h-stack/hook.js +1 -1
  158. package/build/h-stack/hook.js.map +1 -1
  159. package/build/heading/component.js +25 -9
  160. package/build/heading/component.js.map +1 -1
  161. package/build/heading/hook.js +1 -1
  162. package/build/heading/hook.js.map +1 -1
  163. package/build/higher-order/navigate-regions/index.js +42 -29
  164. package/build/higher-order/navigate-regions/index.js.map +1 -1
  165. package/build/index.js +50 -16
  166. package/build/index.js.map +1 -1
  167. package/build/index.native.js +20 -2
  168. package/build/index.native.js.map +1 -1
  169. package/build/input-control/input-field.js.map +1 -1
  170. package/build/input-control/label.js.map +1 -1
  171. package/build/input-control/reducer/actions.js.map +1 -1
  172. package/build/input-control/reducer/reducer.js.map +1 -1
  173. package/build/input-control/reducer/state.js.map +1 -1
  174. package/build/input-control/styles/input-control-styles.js +25 -25
  175. package/build/input-control/styles/input-control-styles.js.map +1 -1
  176. package/build/item-group/item/component.js.map +1 -1
  177. package/build/item-group/item/hook.js +10 -3
  178. package/build/item-group/item/hook.js.map +1 -1
  179. package/build/item-group/item-group/component.js.map +1 -1
  180. package/build/item-group/item-group/hook.js.map +1 -1
  181. package/build/item-group/styles.js +18 -10
  182. package/build/item-group/styles.js.map +1 -1
  183. package/build/menu-group/index.js +9 -6
  184. package/build/menu-group/index.js.map +1 -1
  185. package/build/menu-item/index.js +20 -29
  186. package/build/menu-item/index.js.map +1 -1
  187. package/build/mobile/bottom-sheet/bottom-sheet-navigation/navigation-container.native.js +13 -4
  188. package/build/mobile/bottom-sheet/bottom-sheet-navigation/navigation-container.native.js.map +1 -1
  189. package/build/mobile/bottom-sheet/cell.native.js +11 -3
  190. package/build/mobile/bottom-sheet/cell.native.js.map +1 -1
  191. package/build/mobile/bottom-sheet/footer-message-link/footer-message-link.native.js +3 -3
  192. package/build/mobile/bottom-sheet/footer-message-link/footer-message-link.native.js.map +1 -1
  193. package/build/mobile/bottom-sheet/index.native.js +16 -4
  194. package/build/mobile/bottom-sheet/index.native.js.map +1 -1
  195. package/build/mobile/bottom-sheet/link-cell.native.js +3 -2
  196. package/build/mobile/bottom-sheet/link-cell.native.js.map +1 -1
  197. package/build/mobile/bottom-sheet/nav-bar/action-button.native.js +42 -0
  198. package/build/mobile/bottom-sheet/nav-bar/action-button.native.js.map +1 -0
  199. package/build/mobile/bottom-sheet/nav-bar/apply-button.native.js +58 -0
  200. package/build/mobile/bottom-sheet/nav-bar/apply-button.native.js.map +1 -0
  201. package/build/mobile/bottom-sheet/nav-bar/back-button.native.js +115 -0
  202. package/build/mobile/bottom-sheet/nav-bar/back-button.native.js.map +1 -0
  203. package/build/mobile/bottom-sheet/nav-bar/heading.native.js +42 -0
  204. package/build/mobile/bottom-sheet/nav-bar/heading.native.js.map +1 -0
  205. package/build/mobile/bottom-sheet/nav-bar/index.native.js +43 -0
  206. package/build/mobile/bottom-sheet/nav-bar/index.native.js.map +1 -0
  207. package/build/mobile/bottom-sheet/range-cell.native.js +14 -2
  208. package/build/mobile/bottom-sheet/range-cell.native.js.map +1 -1
  209. package/build/mobile/bottom-sheet/range-text-input.native.js +2 -1
  210. package/build/mobile/bottom-sheet/range-text-input.native.js.map +1 -1
  211. package/build/mobile/bottom-sheet/stepper-cell/stepper.ios.js +1 -1
  212. package/build/mobile/bottom-sheet/stepper-cell/stepper.ios.js.map +1 -1
  213. package/build/mobile/bottom-sheet-select-control/index.native.js +3 -4
  214. package/build/mobile/bottom-sheet-select-control/index.native.js.map +1 -1
  215. package/build/mobile/bottom-sheet-text-control/index.native.js +5 -8
  216. package/build/mobile/bottom-sheet-text-control/index.native.js.map +1 -1
  217. package/build/mobile/color-settings/gradient-picker-screen.native.js +4 -5
  218. package/build/mobile/color-settings/gradient-picker-screen.native.js.map +1 -1
  219. package/build/mobile/color-settings/palette.screen.native.js +11 -7
  220. package/build/mobile/color-settings/palette.screen.native.js.map +1 -1
  221. package/build/mobile/color-settings/picker-screen.native.js +2 -4
  222. package/build/mobile/color-settings/picker-screen.native.js.map +1 -1
  223. package/build/mobile/dashicons/index.native.js +31 -0
  224. package/build/mobile/dashicons/index.native.js.map +1 -0
  225. package/build/mobile/focal-point-settings-panel/index.native.js +6 -7
  226. package/build/mobile/focal-point-settings-panel/index.native.js.map +1 -1
  227. package/build/mobile/global-styles-context/index.native.js +4 -2
  228. package/build/mobile/global-styles-context/index.native.js.map +1 -1
  229. package/build/mobile/global-styles-context/utils.native.js +118 -10
  230. package/build/mobile/global-styles-context/utils.native.js.map +1 -1
  231. package/build/mobile/html-text-input/index.native.js +14 -4
  232. package/build/mobile/html-text-input/index.native.js.map +1 -1
  233. package/build/mobile/inserter-button/index.native.js +5 -4
  234. package/build/mobile/inserter-button/index.native.js.map +1 -1
  235. package/build/mobile/link-picker/index.native.js +6 -7
  236. package/build/mobile/link-picker/index.native.js.map +1 -1
  237. package/build/mobile/link-settings/image-link-destinations-screen.native.js +140 -0
  238. package/build/mobile/link-settings/image-link-destinations-screen.native.js.map +1 -0
  239. package/build/mobile/link-settings/index.native.js +3 -2
  240. package/build/mobile/link-settings/index.native.js.map +1 -1
  241. package/build/mobile/link-settings/link-settings-navigation.native.js +1 -0
  242. package/build/mobile/link-settings/link-settings-navigation.native.js.map +1 -1
  243. package/build/mobile/link-settings/link-settings-screen.native.js +11 -5
  244. package/build/mobile/link-settings/link-settings-screen.native.js.map +1 -1
  245. package/build/mobile/picker/index.android.js +4 -2
  246. package/build/mobile/picker/index.android.js.map +1 -1
  247. package/build/mobile/segmented-control/index.native.js +2 -1
  248. package/build/mobile/segmented-control/index.native.js.map +1 -1
  249. package/build/modal/index.js +111 -151
  250. package/build/modal/index.js.map +1 -1
  251. package/build/navigable-container/container.js +2 -0
  252. package/build/navigable-container/container.js.map +1 -1
  253. package/build/navigable-container/index.js.map +1 -1
  254. package/build/navigable-container/menu.js +2 -0
  255. package/build/navigable-container/menu.js.map +1 -1
  256. package/build/navigable-container/tabbable.js +2 -0
  257. package/build/navigable-container/tabbable.js.map +1 -1
  258. package/build/navigation/group/index.js +1 -2
  259. package/build/navigation/group/index.js.map +1 -1
  260. package/build/navigation/menu/index.js +1 -1
  261. package/build/navigation/menu/index.js.map +1 -1
  262. package/build/navigation/menu/menu-title-search.js +8 -27
  263. package/build/navigation/menu/menu-title-search.js.map +1 -1
  264. package/build/navigation/menu/menu-title.js +2 -2
  265. package/build/navigation/menu/menu-title.js.map +1 -1
  266. package/build/navigation/styles/navigation-styles.js +43 -30
  267. package/build/navigation/styles/navigation-styles.js.map +1 -1
  268. package/build/navigator/context.js +16 -0
  269. package/build/navigator/context.js.map +1 -0
  270. package/build/navigator/index.js +32 -0
  271. package/build/navigator/index.js.map +1 -0
  272. package/build/navigator/navigator-provider/component.js +106 -0
  273. package/build/navigator/navigator-provider/component.js.map +1 -0
  274. package/build/{ui/color-picker → navigator/navigator-provider}/index.js +1 -1
  275. package/build/navigator/navigator-provider/index.js.map +1 -0
  276. package/build/navigator/navigator-screen/component.js +160 -0
  277. package/build/navigator/navigator-screen/component.js.map +1 -0
  278. package/build/navigator/navigator-screen/index.js +16 -0
  279. package/build/navigator/navigator-screen/index.js.map +1 -0
  280. package/build/{ui/color-picker → navigator}/types.js +0 -0
  281. package/build/navigator/types.js.map +1 -0
  282. package/build/navigator/use-navigator.js +38 -0
  283. package/build/navigator/use-navigator.js.map +1 -0
  284. package/build/number-control/index.js +25 -30
  285. package/build/number-control/index.js.map +1 -1
  286. package/build/panel/body.native.js +1 -0
  287. package/build/panel/body.native.js.map +1 -1
  288. package/build/popover/index.js +14 -22
  289. package/build/popover/index.js.map +1 -1
  290. package/build/popover/utils.js +57 -35
  291. package/build/popover/utils.js.map +1 -1
  292. package/build/query-controls/index.native.js +2 -2
  293. package/build/query-controls/index.native.js.map +1 -1
  294. package/build/range-control/index.js +9 -2
  295. package/build/range-control/index.js.map +1 -1
  296. package/build/range-control/input-range.js +0 -17
  297. package/build/range-control/input-range.js.map +1 -1
  298. package/build/range-control/rail.js +4 -0
  299. package/build/range-control/rail.js.map +1 -1
  300. package/build/range-control/styles/range-control-styles.js +51 -51
  301. package/build/range-control/styles/range-control-styles.js.map +1 -1
  302. package/build/range-control/tooltip.js +11 -23
  303. package/build/range-control/tooltip.js.map +1 -1
  304. package/build/resizable-box/index.js +35 -32
  305. package/build/resizable-box/index.js.map +1 -1
  306. package/build/resizable-box/resize-tooltip/index.js +0 -2
  307. package/build/resizable-box/resize-tooltip/index.js.map +1 -1
  308. package/build/resizable-box/resize-tooltip/label.js +8 -4
  309. package/build/resizable-box/resize-tooltip/label.js.map +1 -1
  310. package/build/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +4 -12
  311. package/build/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js.map +1 -1
  312. package/build/resizable-box/resize-tooltip/utils.js +21 -30
  313. package/build/resizable-box/resize-tooltip/utils.js.map +1 -1
  314. package/build/sandbox/index.js +3 -9
  315. package/build/sandbox/index.js.map +1 -1
  316. package/build/sandbox/index.native.js +75 -31
  317. package/build/sandbox/index.native.js.map +1 -1
  318. package/build/scrollable/component.js +24 -8
  319. package/build/scrollable/component.js.map +1 -1
  320. package/build/scrollable/hook.js +1 -1
  321. package/build/scrollable/hook.js.map +1 -1
  322. package/build/search-control/index.js +37 -14
  323. package/build/search-control/index.js.map +1 -1
  324. package/build/search-control/index.native.js +11 -2
  325. package/build/search-control/index.native.js.map +1 -1
  326. package/build/select-control/index.js +3 -2
  327. package/build/select-control/index.js.map +1 -1
  328. package/build/snackbar/index.js +5 -2
  329. package/build/snackbar/index.js.map +1 -1
  330. package/build/snackbar/list.js +6 -2
  331. package/build/snackbar/list.js.map +1 -1
  332. package/build/spacer/component.js +24 -8
  333. package/build/spacer/component.js.map +1 -1
  334. package/build/spacer/hook.js +1 -1
  335. package/build/spacer/hook.js.map +1 -1
  336. package/build/surface/component.js +22 -6
  337. package/build/surface/component.js.map +1 -1
  338. package/build/surface/hook.js +1 -1
  339. package/build/surface/hook.js.map +1 -1
  340. package/build/text/component.js +23 -7
  341. package/build/text/component.js.map +1 -1
  342. package/build/text/hook.js +5 -5
  343. package/build/text/hook.js.map +1 -1
  344. package/build/text/styles.js +7 -7
  345. package/build/text/styles.js.map +1 -1
  346. package/build/toggle-control/index.native.js +9 -3
  347. package/build/toggle-control/index.native.js.map +1 -1
  348. package/build/toggle-group-control/context.js +20 -0
  349. package/build/toggle-group-control/context.js.map +1 -0
  350. package/build/toggle-group-control/index.js +22 -0
  351. package/build/toggle-group-control/index.js.map +1 -0
  352. package/build/toggle-group-control/toggle-group-control/component.js +128 -0
  353. package/build/toggle-group-control/toggle-group-control/component.js.map +1 -0
  354. package/build/toggle-group-control/toggle-group-control/index.js +16 -0
  355. package/build/toggle-group-control/toggle-group-control/index.js.map +1 -0
  356. package/build/toggle-group-control/toggle-group-control/styles.js +37 -0
  357. package/build/toggle-group-control/toggle-group-control/styles.js.map +1 -0
  358. package/build/{segmented-control/segmented-control-backdrop.js → toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js} +21 -6
  359. package/build/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js.map +1 -0
  360. package/build/toggle-group-control/toggle-group-control-option/component.js +104 -0
  361. package/build/toggle-group-control/toggle-group-control-option/component.js.map +1 -0
  362. package/build/toggle-group-control/toggle-group-control-option/index.js +16 -0
  363. package/build/toggle-group-control/toggle-group-control-option/index.js.map +1 -0
  364. package/build/toggle-group-control/toggle-group-control-option/styles.js +73 -0
  365. package/build/toggle-group-control/toggle-group-control-option/styles.js.map +1 -0
  366. package/build/toggle-group-control/types.js +2 -0
  367. package/build/toggle-group-control/types.js.map +1 -0
  368. package/build/tools-panel/context.js +15 -1
  369. package/build/tools-panel/context.js.map +1 -1
  370. package/build/tools-panel/index.js +8 -0
  371. package/build/tools-panel/index.js.map +1 -1
  372. package/build/tools-panel/styles.js +69 -9
  373. package/build/tools-panel/styles.js.map +1 -1
  374. package/build/tools-panel/tools-panel/component.js +16 -10
  375. package/build/tools-panel/tools-panel/component.js.map +1 -1
  376. package/build/tools-panel/tools-panel/hook.js +123 -23
  377. package/build/tools-panel/tools-panel/hook.js.map +1 -1
  378. package/build/tools-panel/tools-panel/index.js.map +1 -1
  379. package/build/tools-panel/tools-panel-header/component.js +99 -22
  380. package/build/tools-panel/tools-panel-header/component.js.map +1 -1
  381. package/build/tools-panel/tools-panel-header/hook.js +12 -2
  382. package/build/tools-panel/tools-panel-header/hook.js.map +1 -1
  383. package/build/tools-panel/tools-panel-header/index.js.map +1 -1
  384. package/build/tools-panel/tools-panel-item/component.js +9 -1
  385. package/build/tools-panel/tools-panel-item/component.js.map +1 -1
  386. package/build/tools-panel/tools-panel-item/hook.js +56 -20
  387. package/build/tools-panel/tools-panel-item/hook.js.map +1 -1
  388. package/build/tools-panel/tools-panel-item/index.js.map +1 -1
  389. package/build/tools-panel/types.js +2 -0
  390. package/build/tools-panel/types.js.map +1 -0
  391. package/build/tooltip/index.js +10 -4
  392. package/build/tooltip/index.js.map +1 -1
  393. package/build/tooltip/index.native.js +2 -1
  394. package/build/tooltip/index.native.js.map +1 -1
  395. package/build/tree-grid/index.js +3 -1
  396. package/build/tree-grid/index.js.map +1 -1
  397. package/build/truncate/component.js +23 -7
  398. package/build/truncate/component.js.map +1 -1
  399. package/build/truncate/hook.js +2 -2
  400. package/build/truncate/hook.js.map +1 -1
  401. package/build/ui/context/context-connect.js +3 -3
  402. package/build/ui/context/context-connect.js.map +1 -1
  403. package/build/ui/context/index.js +4 -4
  404. package/build/ui/context/index.js.map +1 -1
  405. package/build/ui/context/use-context-system.js +1 -1
  406. package/build/ui/context/use-context-system.js.map +1 -1
  407. package/build/ui/context/wordpress-component.js +2 -0
  408. package/build/ui/context/wordpress-component.js.map +1 -0
  409. package/build/ui/control-group/component.js +2 -2
  410. package/build/ui/control-group/component.js.map +1 -1
  411. package/build/ui/control-group/hook.js +1 -1
  412. package/build/ui/control-group/hook.js.map +1 -1
  413. package/build/ui/control-label/component.js +25 -7
  414. package/build/ui/control-label/component.js.map +1 -1
  415. package/build/ui/control-label/hook.js +1 -1
  416. package/build/ui/control-label/hook.js.map +1 -1
  417. package/build/ui/form-group/form-group-content.js +1 -1
  418. package/build/ui/form-group/form-group-content.js.map +1 -1
  419. package/build/ui/form-group/form-group-label.js +1 -1
  420. package/build/ui/form-group/form-group-label.js.map +1 -1
  421. package/build/ui/form-group/form-group.js +2 -2
  422. package/build/ui/form-group/form-group.js.map +1 -1
  423. package/build/ui/form-group/use-form-group.js +1 -1
  424. package/build/ui/form-group/use-form-group.js.map +1 -1
  425. package/build/ui/shortcut/component.js.map +1 -1
  426. package/build/ui/spinner/component.js +2 -2
  427. package/build/ui/spinner/component.js.map +1 -1
  428. package/build/ui/tooltip/component.js +2 -2
  429. package/build/ui/tooltip/component.js.map +1 -1
  430. package/build/ui/tooltip/content.js +2 -2
  431. package/build/ui/tooltip/content.js.map +1 -1
  432. package/build/ui/tooltip/styles.js +4 -4
  433. package/build/ui/tooltip/styles.js.map +1 -1
  434. package/build/ui/utils/colors.js +6 -6
  435. package/build/ui/utils/colors.js.map +1 -1
  436. package/build/ui/utils/index.js +0 -8
  437. package/build/ui/utils/index.js.map +1 -1
  438. package/build/ui/utils/space.js +2 -2
  439. package/build/ui/utils/space.js.map +1 -1
  440. package/build/ui/utils/use-responsive-value.js +0 -4
  441. package/build/ui/utils/use-responsive-value.js.map +1 -1
  442. package/build/unit-control/index.js +34 -18
  443. package/build/unit-control/index.js.map +1 -1
  444. package/build/unit-control/index.native.js +5 -1
  445. package/build/unit-control/index.native.js.map +1 -1
  446. package/build/unit-control/styles/unit-control-styles.js +17 -17
  447. package/build/unit-control/styles/unit-control-styles.js.map +1 -1
  448. package/build/unit-control/types.js +2 -0
  449. package/build/unit-control/types.js.map +1 -0
  450. package/build/unit-control/unit-select-control.js +11 -28
  451. package/build/unit-control/unit-select-control.js.map +1 -1
  452. package/build/unit-control/utils.js +73 -45
  453. package/build/unit-control/utils.js.map +1 -1
  454. package/build/utils/colors.js +6 -8
  455. package/build/utils/colors.js.map +1 -1
  456. package/build/utils/config-values.js +8 -8
  457. package/build/utils/config-values.js.map +1 -1
  458. package/build/utils/hooks/index.js +6 -6
  459. package/build/utils/hooks/index.js.map +1 -1
  460. package/build/utils/hooks/use-combined-ref.js +28 -0
  461. package/build/utils/hooks/use-combined-ref.js.map +1 -0
  462. package/build/v-stack/component.js +23 -7
  463. package/build/v-stack/component.js.map +1 -1
  464. package/build/v-stack/hook.js +1 -1
  465. package/build/v-stack/hook.js.map +1 -1
  466. package/build/view/component.js +2 -2
  467. package/build/view/component.js.map +1 -1
  468. package/build/visually-hidden/component.js +2 -2
  469. package/build/visually-hidden/component.js.map +1 -1
  470. package/build/z-stack/component.js.map +1 -1
  471. package/build-module/angle-picker-control/index.js +26 -21
  472. package/build-module/angle-picker-control/index.js.map +1 -1
  473. package/build-module/angle-picker-control/styles/angle-picker-control-styles.js +8 -13
  474. package/build-module/angle-picker-control/styles/angle-picker-control-styles.js.map +1 -1
  475. package/build-module/animate/index.js +1 -1
  476. package/build-module/animate/index.js.map +1 -1
  477. package/build-module/autocomplete/autocompleter-ui.native.js +5 -4
  478. package/build-module/autocomplete/autocompleter-ui.native.js.map +1 -1
  479. package/build-module/base-control/index.js +2 -2
  480. package/build-module/base-control/index.js.map +1 -1
  481. package/build-module/base-field/hook.js +1 -1
  482. package/build-module/base-field/hook.js.map +1 -1
  483. package/build-module/button/index.js +4 -2
  484. package/build-module/button/index.js.map +1 -1
  485. package/build-module/card/card/component.js +3 -3
  486. package/build-module/card/card/component.js.map +1 -1
  487. package/build-module/card/card/hook.js +4 -5
  488. package/build-module/card/card/hook.js.map +1 -1
  489. package/build-module/card/card-body/component.js +2 -2
  490. package/build-module/card/card-body/component.js.map +1 -1
  491. package/build-module/card/card-body/hook.js +1 -1
  492. package/build-module/card/card-body/hook.js.map +1 -1
  493. package/build-module/card/card-divider/component.js +2 -2
  494. package/build-module/card/card-divider/component.js.map +1 -1
  495. package/build-module/card/card-divider/hook.js +1 -1
  496. package/build-module/card/card-divider/hook.js.map +1 -1
  497. package/build-module/card/card-footer/component.js +2 -2
  498. package/build-module/card/card-footer/component.js.map +1 -1
  499. package/build-module/card/card-footer/hook.js +1 -1
  500. package/build-module/card/card-footer/hook.js.map +1 -1
  501. package/build-module/card/card-header/component.js +2 -2
  502. package/build-module/card/card-header/component.js.map +1 -1
  503. package/build-module/card/card-header/hook.js +1 -1
  504. package/build-module/card/card-header/hook.js.map +1 -1
  505. package/build-module/card/card-media/component.js +19 -7
  506. package/build-module/card/card-media/component.js.map +1 -1
  507. package/build-module/card/card-media/hook.js +1 -1
  508. package/build-module/card/card-media/hook.js.map +1 -1
  509. package/build-module/color-edit/index.js +175 -202
  510. package/build-module/color-edit/index.js.map +1 -1
  511. package/build-module/color-edit/styles.js +90 -0
  512. package/build-module/color-edit/styles.js.map +1 -0
  513. package/build-module/color-list-picker/index.js +6 -1
  514. package/build-module/color-list-picker/index.js.map +1 -1
  515. package/build-module/color-palette/index.js +110 -42
  516. package/build-module/color-palette/index.js.map +1 -1
  517. package/build-module/color-palette/styles.js +27 -0
  518. package/build-module/color-palette/styles.js.map +1 -0
  519. package/build-module/{ui/color-picker → color-picker}/color-display.js +38 -20
  520. package/build-module/color-picker/color-display.js.map +1 -0
  521. package/build-module/{ui/color-picker → color-picker}/color-input.js +0 -0
  522. package/build-module/color-picker/color-input.js.map +1 -0
  523. package/build-module/{ui/color-picker → color-picker}/component.js +36 -49
  524. package/build-module/color-picker/component.js.map +1 -0
  525. package/build-module/color-picker/hex-input.js +48 -0
  526. package/build-module/color-picker/hex-input.js.map +1 -0
  527. package/build-module/{ui/color-picker → color-picker}/hsl-input.js +40 -31
  528. package/build-module/color-picker/hsl-input.js.map +1 -0
  529. package/build-module/color-picker/index.js +1 -264
  530. package/build-module/color-picker/index.js.map +1 -1
  531. package/build-module/color-picker/index.native.js +14 -8
  532. package/build-module/color-picker/index.native.js.map +1 -1
  533. package/build-module/{ui/color-picker → color-picker}/input-with-slider.js +11 -11
  534. package/build-module/color-picker/input-with-slider.js.map +1 -0
  535. package/build-module/color-picker/legacy-adapter.js +11 -0
  536. package/build-module/color-picker/legacy-adapter.js.map +1 -0
  537. package/build-module/color-picker/picker.js +27 -0
  538. package/build-module/color-picker/picker.js.map +1 -0
  539. package/build-module/{ui/color-picker → color-picker}/rgb-input.js +10 -10
  540. package/build-module/color-picker/rgb-input.js.map +1 -0
  541. package/build-module/color-picker/styles.js +84 -0
  542. package/build-module/color-picker/styles.js.map +1 -0
  543. package/build-module/{segmented-control → color-picker}/types.js +0 -0
  544. package/build-module/{segmented-control → color-picker}/types.js.map +0 -0
  545. package/build-module/color-picker/use-deprecated-props.js +73 -0
  546. package/build-module/color-picker/use-deprecated-props.js.map +1 -0
  547. package/build-module/combobox-control/index.js +25 -5
  548. package/build-module/combobox-control/index.js.map +1 -1
  549. package/build-module/custom-gradient-bar/constants.js +2 -2
  550. package/build-module/custom-gradient-bar/constants.js.map +1 -1
  551. package/build-module/custom-gradient-bar/control-points.js +25 -50
  552. package/build-module/custom-gradient-bar/control-points.js.map +1 -1
  553. package/build-module/custom-gradient-picker/index.js +5 -4
  554. package/build-module/custom-gradient-picker/index.js.map +1 -1
  555. package/build-module/custom-gradient-picker/styles/custom-gradient-picker-styles.js +6 -6
  556. package/build-module/custom-gradient-picker/styles/custom-gradient-picker-styles.js.map +1 -1
  557. package/build-module/custom-gradient-picker/utils.js +5 -3
  558. package/build-module/custom-gradient-picker/utils.js.map +1 -1
  559. package/build-module/custom-select-control/index.js +31 -8
  560. package/build-module/custom-select-control/index.js.map +1 -1
  561. package/build-module/dashicon/index.native.js +24 -0
  562. package/build-module/dashicon/index.native.js.map +1 -0
  563. package/build-module/date-time/index.js +1 -1
  564. package/build-module/date-time/index.js.map +1 -1
  565. package/build-module/dimension-control/sizes.js +6 -6
  566. package/build-module/dimension-control/sizes.js.map +1 -1
  567. package/build-module/divider/component.js +1 -2
  568. package/build-module/divider/component.js.map +1 -1
  569. package/build-module/drop-zone/index.js +54 -4
  570. package/build-module/drop-zone/index.js.map +1 -1
  571. package/build-module/dropdown/index.js +6 -1
  572. package/build-module/dropdown/index.js.map +1 -1
  573. package/build-module/dropdown-menu/index.js +20 -34
  574. package/build-module/dropdown-menu/index.js.map +1 -1
  575. package/build-module/dropdown-menu/index.native.js +2 -21
  576. package/build-module/dropdown-menu/index.native.js.map +1 -1
  577. package/build-module/duotone-picker/custom-duotone-bar.js +0 -1
  578. package/build-module/duotone-picker/custom-duotone-bar.js.map +1 -1
  579. package/build-module/duotone-picker/duotone-picker.js +1 -0
  580. package/build-module/duotone-picker/duotone-picker.js.map +1 -1
  581. package/build-module/duotone-picker/utils.js +4 -2
  582. package/build-module/duotone-picker/utils.js.map +1 -1
  583. package/build-module/elevation/component.js +19 -7
  584. package/build-module/elevation/component.js.map +1 -1
  585. package/build-module/elevation/hook.js +5 -5
  586. package/build-module/elevation/hook.js.map +1 -1
  587. package/build-module/flex/flex/component.js +2 -2
  588. package/build-module/flex/flex/component.js.map +1 -1
  589. package/build-module/flex/flex/hook.js +25 -31
  590. package/build-module/flex/flex/hook.js.map +1 -1
  591. package/build-module/flex/flex-block/component.js +19 -7
  592. package/build-module/flex/flex-block/component.js.map +1 -1
  593. package/build-module/flex/flex-block/hook.js +1 -1
  594. package/build-module/flex/flex-block/hook.js.map +1 -1
  595. package/build-module/flex/flex-item/component.js +19 -7
  596. package/build-module/flex/flex-item/component.js.map +1 -1
  597. package/build-module/flex/flex-item/hook.js +2 -2
  598. package/build-module/flex/flex-item/hook.js.map +1 -1
  599. package/build-module/flyout/flyout/component.js +2 -2
  600. package/build-module/flyout/flyout/component.js.map +1 -1
  601. package/build-module/flyout/flyout/hook.js +1 -1
  602. package/build-module/flyout/flyout/hook.js.map +1 -1
  603. package/build-module/flyout/flyout-content/component.js +2 -2
  604. package/build-module/flyout/flyout-content/component.js.map +1 -1
  605. package/build-module/focal-point-picker/controls.js +1 -1
  606. package/build-module/focal-point-picker/controls.js.map +1 -1
  607. package/build-module/focusable-iframe/index.js +6 -30
  608. package/build-module/focusable-iframe/index.js.map +1 -1
  609. package/build-module/font-size-picker/index.js +108 -74
  610. package/build-module/font-size-picker/index.js.map +1 -1
  611. package/build-module/font-size-picker/index.native.js +144 -0
  612. package/build-module/font-size-picker/index.native.js.map +1 -0
  613. package/build-module/font-size-picker/utils.js +104 -0
  614. package/build-module/font-size-picker/utils.js.map +1 -0
  615. package/build-module/gradient-picker/index.js +67 -9
  616. package/build-module/gradient-picker/index.js.map +1 -1
  617. package/build-module/grid/component.js +19 -7
  618. package/build-module/grid/component.js.map +1 -1
  619. package/build-module/grid/hook.js +2 -2
  620. package/build-module/grid/hook.js.map +1 -1
  621. package/build-module/guide/index.js +9 -8
  622. package/build-module/guide/index.js.map +1 -1
  623. package/build-module/h-stack/component.js +19 -7
  624. package/build-module/h-stack/component.js.map +1 -1
  625. package/build-module/h-stack/hook.js +1 -1
  626. package/build-module/h-stack/hook.js.map +1 -1
  627. package/build-module/heading/component.js +21 -8
  628. package/build-module/heading/component.js.map +1 -1
  629. package/build-module/heading/hook.js +2 -3
  630. package/build-module/heading/hook.js.map +1 -1
  631. package/build-module/higher-order/navigate-regions/index.js +44 -31
  632. package/build-module/higher-order/navigate-regions/index.js.map +1 -1
  633. package/build-module/index.js +5 -3
  634. package/build-module/index.js.map +1 -1
  635. package/build-module/index.native.js +4 -1
  636. package/build-module/index.native.js.map +1 -1
  637. package/build-module/input-control/input-field.js.map +1 -1
  638. package/build-module/input-control/label.js.map +1 -1
  639. package/build-module/input-control/reducer/actions.js.map +1 -1
  640. package/build-module/input-control/reducer/reducer.js.map +1 -1
  641. package/build-module/input-control/reducer/state.js.map +1 -1
  642. package/build-module/input-control/styles/input-control-styles.js +25 -25
  643. package/build-module/input-control/styles/input-control-styles.js.map +1 -1
  644. package/build-module/item-group/item/component.js.map +1 -1
  645. package/build-module/item-group/item/hook.js +9 -3
  646. package/build-module/item-group/item/hook.js.map +1 -1
  647. package/build-module/item-group/item-group/component.js.map +1 -1
  648. package/build-module/item-group/item-group/hook.js.map +1 -1
  649. package/build-module/item-group/styles.js +18 -10
  650. package/build-module/item-group/styles.js.map +1 -1
  651. package/build-module/menu-group/index.js +8 -6
  652. package/build-module/menu-group/index.js.map +1 -1
  653. package/build-module/menu-item/index.js +19 -29
  654. package/build-module/menu-item/index.js.map +1 -1
  655. package/build-module/mobile/bottom-sheet/bottom-sheet-navigation/navigation-container.native.js +14 -5
  656. package/build-module/mobile/bottom-sheet/bottom-sheet-navigation/navigation-container.native.js.map +1 -1
  657. package/build-module/mobile/bottom-sheet/cell.native.js +11 -3
  658. package/build-module/mobile/bottom-sheet/cell.native.js.map +1 -1
  659. package/build-module/mobile/bottom-sheet/footer-message-link/footer-message-link.native.js +4 -3
  660. package/build-module/mobile/bottom-sheet/footer-message-link/footer-message-link.native.js.map +1 -1
  661. package/build-module/mobile/bottom-sheet/index.native.js +16 -4
  662. package/build-module/mobile/bottom-sheet/index.native.js.map +1 -1
  663. package/build-module/mobile/bottom-sheet/link-cell.native.js +3 -2
  664. package/build-module/mobile/bottom-sheet/link-cell.native.js.map +1 -1
  665. package/build-module/mobile/bottom-sheet/nav-bar/action-button.native.js +30 -0
  666. package/build-module/mobile/bottom-sheet/nav-bar/action-button.native.js.map +1 -0
  667. package/build-module/mobile/bottom-sheet/nav-bar/apply-button.native.js +43 -0
  668. package/build-module/mobile/bottom-sheet/nav-bar/apply-button.native.js.map +1 -0
  669. package/build-module/mobile/bottom-sheet/nav-bar/back-button.native.js +99 -0
  670. package/build-module/mobile/bottom-sheet/nav-bar/back-button.native.js.map +1 -0
  671. package/build-module/mobile/bottom-sheet/nav-bar/heading.native.js +30 -0
  672. package/build-module/mobile/bottom-sheet/nav-bar/heading.native.js.map +1 -0
  673. package/build-module/mobile/bottom-sheet/nav-bar/index.native.js +29 -0
  674. package/build-module/mobile/bottom-sheet/nav-bar/index.native.js.map +1 -0
  675. package/build-module/mobile/bottom-sheet/range-cell.native.js +14 -2
  676. package/build-module/mobile/bottom-sheet/range-cell.native.js.map +1 -1
  677. package/build-module/mobile/bottom-sheet/range-text-input.native.js +2 -1
  678. package/build-module/mobile/bottom-sheet/range-text-input.native.js.map +1 -1
  679. package/build-module/mobile/bottom-sheet/stepper-cell/stepper.ios.js +2 -2
  680. package/build-module/mobile/bottom-sheet/stepper-cell/stepper.ios.js.map +1 -1
  681. package/build-module/mobile/bottom-sheet-select-control/index.native.js +3 -4
  682. package/build-module/mobile/bottom-sheet-select-control/index.native.js.map +1 -1
  683. package/build-module/mobile/bottom-sheet-text-control/index.native.js +5 -8
  684. package/build-module/mobile/bottom-sheet-text-control/index.native.js.map +1 -1
  685. package/build-module/mobile/color-settings/gradient-picker-screen.native.js +4 -5
  686. package/build-module/mobile/color-settings/gradient-picker-screen.native.js.map +1 -1
  687. package/build-module/mobile/color-settings/palette.screen.native.js +11 -7
  688. package/build-module/mobile/color-settings/palette.screen.native.js.map +1 -1
  689. package/build-module/mobile/color-settings/picker-screen.native.js +1 -1
  690. package/build-module/mobile/color-settings/picker-screen.native.js.map +1 -1
  691. package/build-module/mobile/dashicons/index.native.js +21 -0
  692. package/build-module/mobile/dashicons/index.native.js.map +1 -0
  693. package/build-module/mobile/focal-point-settings-panel/index.native.js +6 -7
  694. package/build-module/mobile/focal-point-settings-panel/index.native.js.map +1 -1
  695. package/build-module/mobile/global-styles-context/index.native.js +5 -3
  696. package/build-module/mobile/global-styles-context/index.native.js.map +1 -1
  697. package/build-module/mobile/global-styles-context/utils.native.js +113 -11
  698. package/build-module/mobile/global-styles-context/utils.native.js.map +1 -1
  699. package/build-module/mobile/html-text-input/index.native.js +14 -4
  700. package/build-module/mobile/html-text-input/index.native.js.map +1 -1
  701. package/build-module/mobile/inserter-button/index.native.js +4 -4
  702. package/build-module/mobile/inserter-button/index.native.js.map +1 -1
  703. package/build-module/mobile/link-picker/index.native.js +6 -7
  704. package/build-module/mobile/link-picker/index.native.js.map +1 -1
  705. package/build-module/mobile/link-settings/image-link-destinations-screen.native.js +121 -0
  706. package/build-module/mobile/link-settings/image-link-destinations-screen.native.js.map +1 -0
  707. package/build-module/mobile/link-settings/index.native.js +3 -2
  708. package/build-module/mobile/link-settings/index.native.js.map +1 -1
  709. package/build-module/mobile/link-settings/link-settings-navigation.native.js +1 -0
  710. package/build-module/mobile/link-settings/link-settings-navigation.native.js.map +1 -1
  711. package/build-module/mobile/link-settings/link-settings-screen.native.js +11 -5
  712. package/build-module/mobile/link-settings/link-settings-screen.native.js.map +1 -1
  713. package/build-module/mobile/picker/index.android.js +4 -2
  714. package/build-module/mobile/picker/index.android.js.map +1 -1
  715. package/build-module/mobile/segmented-control/index.native.js +2 -1
  716. package/build-module/mobile/segmented-control/index.native.js.map +1 -1
  717. package/build-module/modal/index.js +109 -151
  718. package/build-module/modal/index.js.map +1 -1
  719. package/build-module/navigable-container/container.js +1 -0
  720. package/build-module/navigable-container/container.js.map +1 -1
  721. package/build-module/navigable-container/index.js +2 -0
  722. package/build-module/navigable-container/index.js.map +1 -1
  723. package/build-module/navigable-container/menu.js +1 -0
  724. package/build-module/navigable-container/menu.js.map +1 -1
  725. package/build-module/navigable-container/tabbable.js +1 -0
  726. package/build-module/navigable-container/tabbable.js.map +1 -1
  727. package/build-module/navigation/group/index.js +1 -2
  728. package/build-module/navigation/group/index.js.map +1 -1
  729. package/build-module/navigation/menu/index.js +1 -1
  730. package/build-module/navigation/menu/index.js.map +1 -1
  731. package/build-module/navigation/menu/menu-title-search.js +8 -24
  732. package/build-module/navigation/menu/menu-title-search.js.map +1 -1
  733. package/build-module/navigation/menu/menu-title.js +3 -3
  734. package/build-module/navigation/menu/menu-title.js.map +1 -1
  735. package/build-module/navigation/styles/navigation-styles.js +41 -29
  736. package/build-module/navigation/styles/navigation-styles.js.map +1 -1
  737. package/build-module/navigator/context.js +11 -0
  738. package/build-module/navigator/context.js.map +1 -0
  739. package/build-module/navigator/index.js +4 -0
  740. package/build-module/navigator/index.js.map +1 -0
  741. package/build-module/navigator/navigator-provider/component.js +104 -0
  742. package/build-module/navigator/navigator-provider/component.js.map +1 -0
  743. package/build-module/navigator/navigator-provider/index.js +2 -0
  744. package/build-module/navigator/navigator-provider/index.js.map +1 -0
  745. package/build-module/navigator/navigator-screen/component.js +155 -0
  746. package/build-module/navigator/navigator-screen/component.js.map +1 -0
  747. package/build-module/navigator/navigator-screen/index.js +2 -0
  748. package/build-module/navigator/navigator-screen/index.js.map +1 -0
  749. package/build-module/{ui/color-picker → navigator}/types.js +0 -0
  750. package/build-module/{ui/color-picker → navigator}/types.js.map +0 -0
  751. package/build-module/navigator/use-navigator.js +28 -0
  752. package/build-module/navigator/use-navigator.js.map +1 -0
  753. package/build-module/number-control/index.js +25 -29
  754. package/build-module/number-control/index.js.map +1 -1
  755. package/build-module/panel/body.native.js +1 -0
  756. package/build-module/panel/body.native.js.map +1 -1
  757. package/build-module/popover/index.js +15 -22
  758. package/build-module/popover/index.js.map +1 -1
  759. package/build-module/popover/utils.js +57 -35
  760. package/build-module/popover/utils.js.map +1 -1
  761. package/build-module/query-controls/index.native.js +3 -3
  762. package/build-module/query-controls/index.native.js.map +1 -1
  763. package/build-module/range-control/index.js +9 -2
  764. package/build-module/range-control/index.js.map +1 -1
  765. package/build-module/range-control/input-range.js +0 -16
  766. package/build-module/range-control/input-range.js.map +1 -1
  767. package/build-module/range-control/rail.js +4 -0
  768. package/build-module/range-control/rail.js.map +1 -1
  769. package/build-module/range-control/styles/range-control-styles.js +51 -52
  770. package/build-module/range-control/styles/range-control-styles.js.map +1 -1
  771. package/build-module/range-control/tooltip.js +11 -22
  772. package/build-module/range-control/tooltip.js.map +1 -1
  773. package/build-module/resizable-box/index.js +35 -33
  774. package/build-module/resizable-box/index.js.map +1 -1
  775. package/build-module/resizable-box/resize-tooltip/index.js +2 -4
  776. package/build-module/resizable-box/resize-tooltip/index.js.map +1 -1
  777. package/build-module/resizable-box/resize-tooltip/label.js +8 -4
  778. package/build-module/resizable-box/resize-tooltip/label.js.map +1 -1
  779. package/build-module/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +4 -12
  780. package/build-module/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js.map +1 -1
  781. package/build-module/resizable-box/resize-tooltip/utils.js +20 -27
  782. package/build-module/resizable-box/resize-tooltip/utils.js.map +1 -1
  783. package/build-module/sandbox/index.js +3 -7
  784. package/build-module/sandbox/index.js.map +1 -1
  785. package/build-module/sandbox/index.native.js +74 -31
  786. package/build-module/sandbox/index.native.js.map +1 -1
  787. package/build-module/scrollable/component.js +20 -8
  788. package/build-module/scrollable/component.js.map +1 -1
  789. package/build-module/scrollable/hook.js +1 -1
  790. package/build-module/scrollable/hook.js.map +1 -1
  791. package/build-module/search-control/index.js +36 -15
  792. package/build-module/search-control/index.js.map +1 -1
  793. package/build-module/search-control/index.native.js +11 -3
  794. package/build-module/search-control/index.native.js.map +1 -1
  795. package/build-module/select-control/index.js +3 -2
  796. package/build-module/select-control/index.js.map +1 -1
  797. package/build-module/snackbar/index.js +5 -2
  798. package/build-module/snackbar/index.js.map +1 -1
  799. package/build-module/snackbar/list.js +7 -2
  800. package/build-module/snackbar/list.js.map +1 -1
  801. package/build-module/spacer/component.js +20 -7
  802. package/build-module/spacer/component.js.map +1 -1
  803. package/build-module/spacer/hook.js +2 -3
  804. package/build-module/spacer/hook.js.map +1 -1
  805. package/build-module/surface/component.js +19 -6
  806. package/build-module/surface/component.js.map +1 -1
  807. package/build-module/surface/hook.js +1 -1
  808. package/build-module/surface/hook.js.map +1 -1
  809. package/build-module/text/component.js +21 -7
  810. package/build-module/text/component.js.map +1 -1
  811. package/build-module/text/hook.js +5 -5
  812. package/build-module/text/hook.js.map +1 -1
  813. package/build-module/text/styles.js +7 -7
  814. package/build-module/text/styles.js.map +1 -1
  815. package/build-module/toggle-control/index.native.js +8 -3
  816. package/build-module/toggle-control/index.native.js.map +1 -1
  817. package/build-module/toggle-group-control/context.js +12 -0
  818. package/build-module/toggle-group-control/context.js.map +1 -0
  819. package/build-module/toggle-group-control/index.js +3 -0
  820. package/build-module/toggle-group-control/index.js.map +1 -0
  821. package/build-module/toggle-group-control/toggle-group-control/component.js +111 -0
  822. package/build-module/toggle-group-control/toggle-group-control/component.js.map +1 -0
  823. package/build-module/toggle-group-control/toggle-group-control/index.js +2 -0
  824. package/build-module/toggle-group-control/toggle-group-control/index.js.map +1 -0
  825. package/build-module/toggle-group-control/toggle-group-control/styles.js +30 -0
  826. package/build-module/toggle-group-control/toggle-group-control/styles.js.map +1 -0
  827. package/build-module/{segmented-control/segmented-control-backdrop.js → toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js} +21 -6
  828. package/build-module/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.js.map +1 -0
  829. package/build-module/toggle-group-control/toggle-group-control-option/component.js +89 -0
  830. package/build-module/toggle-group-control/toggle-group-control-option/component.js.map +1 -0
  831. package/build-module/toggle-group-control/toggle-group-control-option/index.js +2 -0
  832. package/build-module/toggle-group-control/toggle-group-control-option/index.js.map +1 -0
  833. package/build-module/toggle-group-control/toggle-group-control-option/styles.js +61 -0
  834. package/build-module/toggle-group-control/toggle-group-control-option/styles.js.map +1 -0
  835. package/build-module/toggle-group-control/types.js +2 -0
  836. package/{build/segmented-control → build-module/toggle-group-control}/types.js.map +0 -0
  837. package/build-module/tools-panel/context.js +19 -1
  838. package/build-module/tools-panel/context.js.map +1 -1
  839. package/build-module/tools-panel/index.js +1 -0
  840. package/build-module/tools-panel/index.js.map +1 -1
  841. package/build-module/tools-panel/styles.js +60 -8
  842. package/build-module/tools-panel/styles.js.map +1 -1
  843. package/build-module/tools-panel/tools-panel/component.js +16 -9
  844. package/build-module/tools-panel/tools-panel/component.js.map +1 -1
  845. package/build-module/tools-panel/tools-panel/hook.js +124 -24
  846. package/build-module/tools-panel/tools-panel/hook.js.map +1 -1
  847. package/build-module/tools-panel/tools-panel/index.js.map +1 -1
  848. package/build-module/tools-panel/tools-panel-header/component.js +99 -24
  849. package/build-module/tools-panel/tools-panel-header/component.js.map +1 -1
  850. package/build-module/tools-panel/tools-panel-header/hook.js +12 -2
  851. package/build-module/tools-panel/tools-panel-header/hook.js.map +1 -1
  852. package/build-module/tools-panel/tools-panel-header/index.js.map +1 -1
  853. package/build-module/tools-panel/tools-panel-item/component.js +12 -3
  854. package/build-module/tools-panel/tools-panel-item/component.js.map +1 -1
  855. package/build-module/tools-panel/tools-panel-item/hook.js +57 -21
  856. package/build-module/tools-panel/tools-panel-item/hook.js.map +1 -1
  857. package/build-module/tools-panel/tools-panel-item/index.js.map +1 -1
  858. package/build-module/tools-panel/types.js +2 -0
  859. package/{build/ui/color-picker → build-module/tools-panel}/types.js.map +0 -0
  860. package/build-module/tooltip/index.js +9 -4
  861. package/build-module/tooltip/index.js.map +1 -1
  862. package/build-module/tooltip/index.native.js +2 -1
  863. package/build-module/tooltip/index.native.js.map +1 -1
  864. package/build-module/tree-grid/index.js +3 -1
  865. package/build-module/tree-grid/index.js.map +1 -1
  866. package/build-module/truncate/component.js +21 -7
  867. package/build-module/truncate/component.js.map +1 -1
  868. package/build-module/truncate/hook.js +2 -2
  869. package/build-module/truncate/hook.js.map +1 -1
  870. package/build-module/ui/context/context-connect.js +3 -3
  871. package/build-module/ui/context/context-connect.js.map +1 -1
  872. package/build-module/ui/context/index.js +1 -1
  873. package/build-module/ui/context/index.js.map +1 -1
  874. package/build-module/ui/context/use-context-system.js +1 -1
  875. package/build-module/ui/context/use-context-system.js.map +1 -1
  876. package/build-module/ui/context/wordpress-component.js +2 -0
  877. package/build-module/ui/context/{polymorphic-component.js.map → wordpress-component.js.map} +0 -0
  878. package/build-module/ui/control-group/component.js +2 -2
  879. package/build-module/ui/control-group/component.js.map +1 -1
  880. package/build-module/ui/control-group/hook.js +1 -1
  881. package/build-module/ui/control-group/hook.js.map +1 -1
  882. package/build-module/ui/control-label/component.js +21 -7
  883. package/build-module/ui/control-label/component.js.map +1 -1
  884. package/build-module/ui/control-label/hook.js +1 -1
  885. package/build-module/ui/control-label/hook.js.map +1 -1
  886. package/build-module/ui/form-group/form-group-content.js +1 -1
  887. package/build-module/ui/form-group/form-group-content.js.map +1 -1
  888. package/build-module/ui/form-group/form-group-label.js +1 -1
  889. package/build-module/ui/form-group/form-group-label.js.map +1 -1
  890. package/build-module/ui/form-group/form-group.js +2 -2
  891. package/build-module/ui/form-group/form-group.js.map +1 -1
  892. package/build-module/ui/form-group/use-form-group.js +1 -1
  893. package/build-module/ui/form-group/use-form-group.js.map +1 -1
  894. package/build-module/ui/shortcut/component.js +1 -2
  895. package/build-module/ui/shortcut/component.js.map +1 -1
  896. package/build-module/ui/spinner/component.js +2 -2
  897. package/build-module/ui/spinner/component.js.map +1 -1
  898. package/build-module/ui/tooltip/component.js +2 -2
  899. package/build-module/ui/tooltip/component.js.map +1 -1
  900. package/build-module/ui/tooltip/content.js +2 -2
  901. package/build-module/ui/tooltip/content.js.map +1 -1
  902. package/build-module/ui/tooltip/styles.js +4 -4
  903. package/build-module/ui/tooltip/styles.js.map +1 -1
  904. package/build-module/ui/utils/colors.js +5 -4
  905. package/build-module/ui/utils/colors.js.map +1 -1
  906. package/build-module/ui/utils/index.js +0 -1
  907. package/build-module/ui/utils/index.js.map +1 -1
  908. package/build-module/ui/utils/space.js +2 -2
  909. package/build-module/ui/utils/space.js.map +1 -1
  910. package/build-module/ui/utils/use-responsive-value.js +0 -4
  911. package/build-module/ui/utils/use-responsive-value.js.map +1 -1
  912. package/build-module/unit-control/index.js +36 -16
  913. package/build-module/unit-control/index.js.map +1 -1
  914. package/build-module/unit-control/index.native.js +5 -1
  915. package/build-module/unit-control/index.native.js.map +1 -1
  916. package/build-module/unit-control/styles/unit-control-styles.js +17 -17
  917. package/build-module/unit-control/styles/unit-control-styles.js.map +1 -1
  918. package/build-module/unit-control/types.js +2 -0
  919. package/{build/ui/context/polymorphic-component.js.map → build-module/unit-control/types.js.map} +0 -0
  920. package/build-module/unit-control/unit-select-control.js +12 -28
  921. package/build-module/unit-control/unit-select-control.js.map +1 -1
  922. package/build-module/unit-control/utils.js +75 -44
  923. package/build-module/unit-control/utils.js.map +1 -1
  924. package/build-module/utils/colors.js +4 -7
  925. package/build-module/utils/colors.js.map +1 -1
  926. package/build-module/utils/config-values.js +8 -8
  927. package/build-module/utils/config-values.js.map +1 -1
  928. package/build-module/utils/hooks/index.js +1 -1
  929. package/build-module/utils/hooks/index.js.map +1 -1
  930. package/build-module/utils/hooks/use-combined-ref.js +25 -0
  931. package/build-module/utils/hooks/use-combined-ref.js.map +1 -0
  932. package/build-module/v-stack/component.js +19 -7
  933. package/build-module/v-stack/component.js.map +1 -1
  934. package/build-module/v-stack/hook.js +1 -1
  935. package/build-module/v-stack/hook.js.map +1 -1
  936. package/build-module/view/component.js +2 -2
  937. package/build-module/view/component.js.map +1 -1
  938. package/build-module/visually-hidden/component.js +2 -2
  939. package/build-module/visually-hidden/component.js.map +1 -1
  940. package/build-module/z-stack/component.js +1 -2
  941. package/build-module/z-stack/component.js.map +1 -1
  942. package/build-style/style-rtl.css +136 -367
  943. package/build-style/style.css +136 -372
  944. package/build-types/animate/index.d.ts +4 -4
  945. package/build-types/animate/index.d.ts.map +1 -1
  946. package/build-types/base-control/index.d.ts +12 -3
  947. package/build-types/base-control/index.d.ts.map +1 -1
  948. package/build-types/base-control/styles/base-control-styles.d.ts +4 -4
  949. package/build-types/base-field/hook.d.ts +222 -222
  950. package/build-types/base-field/hook.d.ts.map +1 -1
  951. package/build-types/button/index.d.ts.map +1 -1
  952. package/build-types/card/card/component.d.ts +1 -1
  953. package/build-types/card/card/component.d.ts.map +1 -1
  954. package/build-types/card/card/hook.d.ts +222 -222
  955. package/build-types/card/card/hook.d.ts.map +1 -1
  956. package/build-types/card/card-body/component.d.ts +1 -1
  957. package/build-types/card/card-body/component.d.ts.map +1 -1
  958. package/build-types/card/card-body/hook.d.ts +222 -222
  959. package/build-types/card/card-body/hook.d.ts.map +1 -1
  960. package/build-types/card/card-divider/component.d.ts +1 -1
  961. package/build-types/card/card-divider/component.d.ts.map +1 -1
  962. package/build-types/card/card-divider/hook.d.ts +225 -225
  963. package/build-types/card/card-divider/hook.d.ts.map +1 -1
  964. package/build-types/card/card-footer/component.d.ts +1 -1
  965. package/build-types/card/card-footer/component.d.ts.map +1 -1
  966. package/build-types/card/card-footer/hook.d.ts +223 -223
  967. package/build-types/card/card-footer/hook.d.ts.map +1 -1
  968. package/build-types/card/card-header/component.d.ts +2 -2
  969. package/build-types/card/card-header/hook.d.ts +222 -222
  970. package/build-types/card/card-header/hook.d.ts.map +1 -1
  971. package/build-types/card/card-media/component.d.ts +3 -3
  972. package/build-types/card/card-media/component.d.ts.map +1 -1
  973. package/build-types/card/card-media/hook.d.ts +222 -222
  974. package/build-types/card/card-media/hook.d.ts.map +1 -1
  975. package/build-types/dashicon/index.d.ts +1 -1
  976. package/build-types/dashicon/index.d.ts.map +1 -1
  977. package/build-types/disabled/styles/disabled-styles.d.ts +1 -1
  978. package/build-types/divider/component.d.ts +1 -1
  979. package/build-types/divider/component.d.ts.map +1 -1
  980. package/build-types/divider/styles.d.ts +1 -1
  981. package/build-types/dropdown/index.d.ts +14 -0
  982. package/build-types/dropdown/index.d.ts.map +1 -0
  983. package/build-types/dropdown-menu/index.d.ts +3 -0
  984. package/build-types/dropdown-menu/index.d.ts.map +1 -0
  985. package/build-types/elevation/component.d.ts +2 -2
  986. package/build-types/elevation/component.d.ts.map +1 -1
  987. package/build-types/elevation/hook.d.ts +221 -221
  988. package/build-types/elevation/hook.d.ts.map +1 -1
  989. package/build-types/flex/flex/component.d.ts +1 -1
  990. package/build-types/flex/flex/component.d.ts.map +1 -1
  991. package/build-types/flex/flex/hook.d.ts +222 -222
  992. package/build-types/flex/flex/hook.d.ts.map +1 -1
  993. package/build-types/flex/flex-block/component.d.ts +2 -2
  994. package/build-types/flex/flex-block/component.d.ts.map +1 -1
  995. package/build-types/flex/flex-block/hook.d.ts +222 -222
  996. package/build-types/flex/flex-block/hook.d.ts.map +1 -1
  997. package/build-types/flex/flex-item/component.d.ts +2 -2
  998. package/build-types/flex/flex-item/component.d.ts.map +1 -1
  999. package/build-types/flex/flex-item/hook.d.ts +222 -222
  1000. package/build-types/flex/flex-item/hook.d.ts.map +1 -1
  1001. package/build-types/flex/types.d.ts +0 -1
  1002. package/build-types/flex/types.d.ts.map +1 -1
  1003. package/build-types/flyout/flyout/component.d.ts +1 -1
  1004. package/build-types/flyout/flyout/component.d.ts.map +1 -1
  1005. package/build-types/flyout/flyout/hook.d.ts +223 -223
  1006. package/build-types/flyout/flyout/hook.d.ts.map +1 -1
  1007. package/build-types/flyout/flyout-content/component.d.ts +1 -1
  1008. package/build-types/flyout/flyout-content/component.d.ts.map +1 -1
  1009. package/build-types/flyout/styles.d.ts +6 -6
  1010. package/build-types/grid/component.d.ts +2 -2
  1011. package/build-types/grid/component.d.ts.map +1 -1
  1012. package/build-types/grid/hook.d.ts +222 -222
  1013. package/build-types/grid/hook.d.ts.map +1 -1
  1014. package/build-types/h-stack/component.d.ts +2 -2
  1015. package/build-types/h-stack/component.d.ts.map +1 -1
  1016. package/build-types/h-stack/hook.d.ts +222 -222
  1017. package/build-types/h-stack/hook.d.ts.map +1 -1
  1018. package/build-types/heading/component.d.ts +4 -3
  1019. package/build-types/heading/component.d.ts.map +1 -1
  1020. package/build-types/heading/hook.d.ts +227 -224
  1021. package/build-types/heading/hook.d.ts.map +1 -1
  1022. package/build-types/input-control/index.d.ts +1 -1
  1023. package/build-types/input-control/input-field.d.ts +5 -5
  1024. package/build-types/input-control/input-field.d.ts.map +1 -1
  1025. package/build-types/input-control/label.d.ts +2 -2
  1026. package/build-types/input-control/label.d.ts.map +1 -1
  1027. package/build-types/input-control/reducer/actions.d.ts +1 -1
  1028. package/build-types/input-control/reducer/actions.d.ts.map +1 -1
  1029. package/build-types/input-control/reducer/reducer.d.ts +1 -1
  1030. package/build-types/input-control/reducer/reducer.d.ts.map +1 -1
  1031. package/build-types/input-control/reducer/state.d.ts +1 -1
  1032. package/build-types/input-control/reducer/state.d.ts.map +1 -1
  1033. package/build-types/input-control/styles/input-control-styles.d.ts +13 -13
  1034. package/build-types/input-control/styles/input-control-styles.d.ts.map +1 -1
  1035. package/build-types/input-control/types.d.ts +8 -7
  1036. package/build-types/input-control/types.d.ts.map +1 -1
  1037. package/build-types/item-group/item/component.d.ts +1 -1
  1038. package/build-types/item-group/item/hook.d.ts +222 -225
  1039. package/build-types/item-group/item/hook.d.ts.map +1 -1
  1040. package/build-types/item-group/item-group/component.d.ts +1 -1
  1041. package/build-types/item-group/item-group/hook.d.ts +222 -222
  1042. package/build-types/item-group/item-group/hook.d.ts.map +1 -1
  1043. package/build-types/item-group/styles.d.ts.map +1 -1
  1044. package/build-types/item-group/types.d.ts +0 -6
  1045. package/build-types/item-group/types.d.ts.map +1 -1
  1046. package/build-types/menu-group/index.d.ts +3 -0
  1047. package/build-types/menu-group/index.d.ts.map +1 -0
  1048. package/build-types/menu-item/index.d.ts +4 -0
  1049. package/build-types/menu-item/index.d.ts.map +1 -0
  1050. package/build-types/navigable-container/container.d.ts +3 -0
  1051. package/build-types/navigable-container/container.d.ts.map +1 -0
  1052. package/build-types/navigable-container/index.d.ts +3 -0
  1053. package/build-types/navigable-container/index.d.ts.map +1 -0
  1054. package/build-types/navigable-container/menu.d.ts +12 -0
  1055. package/build-types/navigable-container/menu.d.ts.map +1 -0
  1056. package/build-types/navigable-container/tabbable.d.ts +10 -0
  1057. package/build-types/navigable-container/tabbable.d.ts.map +1 -0
  1058. package/build-types/navigator/context.d.ts +7 -0
  1059. package/build-types/navigator/context.d.ts.map +1 -0
  1060. package/build-types/navigator/index.d.ts +4 -0
  1061. package/build-types/navigator/index.d.ts.map +1 -0
  1062. package/build-types/navigator/navigator-provider/component.d.ts +49 -0
  1063. package/build-types/navigator/navigator-provider/component.d.ts.map +1 -0
  1064. package/build-types/navigator/navigator-provider/index.d.ts +2 -0
  1065. package/build-types/navigator/navigator-provider/index.d.ts.map +1 -0
  1066. package/build-types/navigator/navigator-screen/component.d.ts +55 -0
  1067. package/build-types/navigator/navigator-screen/component.d.ts.map +1 -0
  1068. package/build-types/navigator/navigator-screen/index.d.ts +2 -0
  1069. package/build-types/navigator/navigator-screen/index.d.ts.map +1 -0
  1070. package/build-types/navigator/types.d.ts +39 -0
  1071. package/build-types/navigator/types.d.ts.map +1 -0
  1072. package/build-types/navigator/use-navigator.d.ts +7 -0
  1073. package/build-types/navigator/use-navigator.d.ts.map +1 -0
  1074. package/build-types/number-control/index.d.ts.map +1 -1
  1075. package/build-types/number-control/styles/number-control-styles.d.ts +1 -1
  1076. package/build-types/popover/index.d.ts +1 -1
  1077. package/build-types/popover/index.d.ts.map +1 -1
  1078. package/build-types/popover/utils.d.ts +29 -29
  1079. package/build-types/popover/utils.d.ts.map +1 -1
  1080. package/build-types/range-control/index.d.ts.map +1 -1
  1081. package/build-types/range-control/input-range.d.ts +0 -6
  1082. package/build-types/range-control/input-range.d.ts.map +1 -1
  1083. package/build-types/range-control/styles/range-control-styles.d.ts +14 -14
  1084. package/build-types/range-control/styles/range-control-styles.d.ts.map +1 -1
  1085. package/build-types/range-control/tooltip.d.ts +2 -2
  1086. package/build-types/range-control/tooltip.d.ts.map +1 -1
  1087. package/build-types/range-control/utils.d.ts +5 -5
  1088. package/build-types/resizable-box/index.d.ts +29 -0
  1089. package/build-types/resizable-box/index.d.ts.map +1 -0
  1090. package/build-types/resizable-box/resize-tooltip/index.d.ts +22 -0
  1091. package/build-types/resizable-box/resize-tooltip/index.d.ts.map +1 -0
  1092. package/build-types/resizable-box/resize-tooltip/label.d.ts +12 -0
  1093. package/build-types/resizable-box/resize-tooltip/label.d.ts.map +1 -0
  1094. package/build-types/resizable-box/resize-tooltip/styles/resize-tooltip.styles.d.ts +20 -0
  1095. package/build-types/resizable-box/resize-tooltip/styles/resize-tooltip.styles.d.ts.map +1 -0
  1096. package/build-types/resizable-box/resize-tooltip/utils.d.ts +39 -0
  1097. package/build-types/resizable-box/resize-tooltip/utils.d.ts.map +1 -0
  1098. package/build-types/resizable-box/styles/resizable-box.styles.d.ts +1 -0
  1099. package/build-types/resizable-box/styles/resizable-box.styles.d.ts.map +1 -0
  1100. package/build-types/scrollable/component.d.ts +3 -3
  1101. package/build-types/scrollable/component.d.ts.map +1 -1
  1102. package/build-types/scrollable/hook.d.ts +222 -222
  1103. package/build-types/scrollable/hook.d.ts.map +1 -1
  1104. package/build-types/select-control/index.d.ts +6 -3
  1105. package/build-types/select-control/index.d.ts.map +1 -1
  1106. package/build-types/select-control/styles/select-control-styles.d.ts +2 -2
  1107. package/build-types/shortcut/index.d.ts.map +1 -1
  1108. package/build-types/spacer/component.d.ts +3 -2
  1109. package/build-types/spacer/component.d.ts.map +1 -1
  1110. package/build-types/spacer/hook.d.ts +225 -222
  1111. package/build-types/spacer/hook.d.ts.map +1 -1
  1112. package/build-types/spinner/styles/spinner-styles.d.ts +1 -1
  1113. package/build-types/surface/component.d.ts +22 -2
  1114. package/build-types/surface/component.d.ts.map +1 -1
  1115. package/build-types/surface/hook.d.ts +222 -222
  1116. package/build-types/surface/hook.d.ts.map +1 -1
  1117. package/build-types/surface/styles.d.ts +4 -4
  1118. package/build-types/text/component.d.ts +2 -2
  1119. package/build-types/text/component.d.ts.map +1 -1
  1120. package/build-types/text/hook.d.ts +223 -223
  1121. package/build-types/text/hook.d.ts.map +1 -1
  1122. package/build-types/text/utils.d.ts +1 -1
  1123. package/build-types/toggle-group-control/context.d.ts +9 -0
  1124. package/build-types/toggle-group-control/context.d.ts.map +1 -0
  1125. package/build-types/toggle-group-control/index.d.ts +3 -0
  1126. package/build-types/toggle-group-control/index.d.ts.map +1 -0
  1127. package/build-types/toggle-group-control/toggle-group-control/component.d.ts +30 -0
  1128. package/build-types/toggle-group-control/toggle-group-control/component.d.ts.map +1 -0
  1129. package/build-types/toggle-group-control/toggle-group-control/index.d.ts +2 -0
  1130. package/build-types/toggle-group-control/toggle-group-control/index.d.ts.map +1 -0
  1131. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts +8 -0
  1132. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts.map +1 -0
  1133. package/build-types/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.d.ts +9 -0
  1134. package/build-types/toggle-group-control/toggle-group-control/toggle-group-control-backdrop.d.ts.map +1 -0
  1135. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts +25 -0
  1136. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts.map +1 -0
  1137. package/build-types/toggle-group-control/toggle-group-control-option/index.d.ts +2 -0
  1138. package/build-types/toggle-group-control/toggle-group-control-option/index.d.ts.map +1 -0
  1139. package/build-types/toggle-group-control/toggle-group-control-option/styles.d.ts +19 -0
  1140. package/build-types/toggle-group-control/toggle-group-control-option/styles.d.ts.map +1 -0
  1141. package/build-types/toggle-group-control/types.d.ts +73 -0
  1142. package/build-types/toggle-group-control/types.d.ts.map +1 -0
  1143. package/build-types/tools-panel/context.d.ts +8 -0
  1144. package/build-types/tools-panel/context.d.ts.map +1 -0
  1145. package/build-types/tools-panel/index.d.ts +4 -0
  1146. package/build-types/tools-panel/index.d.ts.map +1 -0
  1147. package/build-types/tools-panel/styles.d.ts +14 -0
  1148. package/build-types/tools-panel/styles.d.ts.map +1 -0
  1149. package/build-types/tools-panel/tools-panel/component.d.ts +4 -0
  1150. package/build-types/tools-panel/tools-panel/component.d.ts.map +1 -0
  1151. package/build-types/tools-panel/tools-panel/hook.d.ts +279 -0
  1152. package/build-types/tools-panel/tools-panel/hook.d.ts.map +1 -0
  1153. package/build-types/tools-panel/tools-panel/index.d.ts +3 -0
  1154. package/build-types/tools-panel/tools-panel/index.d.ts.map +1 -0
  1155. package/build-types/tools-panel/tools-panel-header/component.d.ts +4 -0
  1156. package/build-types/tools-panel/tools-panel-header/component.d.ts.map +1 -0
  1157. package/build-types/tools-panel/tools-panel-header/hook.d.ts +272 -0
  1158. package/build-types/tools-panel/tools-panel-header/hook.d.ts.map +1 -0
  1159. package/build-types/tools-panel/tools-panel-header/index.d.ts +2 -0
  1160. package/build-types/tools-panel/tools-panel-header/index.d.ts.map +1 -0
  1161. package/build-types/tools-panel/tools-panel-item/component.d.ts +4 -0
  1162. package/build-types/tools-panel/tools-panel-item/component.d.ts.map +1 -0
  1163. package/build-types/tools-panel/tools-panel-item/hook.d.ts +266 -0
  1164. package/build-types/tools-panel/tools-panel-item/hook.d.ts.map +1 -0
  1165. package/build-types/tools-panel/tools-panel-item/index.d.ts +3 -0
  1166. package/build-types/tools-panel/tools-panel-item/index.d.ts.map +1 -0
  1167. package/build-types/tools-panel/types.d.ts +135 -0
  1168. package/build-types/tools-panel/types.d.ts.map +1 -0
  1169. package/build-types/tooltip/index.d.ts +2 -1
  1170. package/build-types/tooltip/index.d.ts.map +1 -1
  1171. package/build-types/truncate/component.d.ts +2 -2
  1172. package/build-types/truncate/component.d.ts.map +1 -1
  1173. package/build-types/truncate/hook.d.ts +222 -222
  1174. package/build-types/truncate/hook.d.ts.map +1 -1
  1175. package/build-types/ui/context/context-connect.d.ts +5 -5
  1176. package/build-types/ui/context/context-connect.d.ts.map +1 -1
  1177. package/build-types/ui/context/index.d.ts +1 -1
  1178. package/build-types/ui/context/use-context-system.d.ts +1 -1
  1179. package/build-types/ui/context/use-context-system.d.ts.map +1 -1
  1180. package/build-types/ui/context/{polymorphic-component.d.ts → wordpress-component.d.ts} +6 -6
  1181. package/build-types/ui/context/wordpress-component.d.ts.map +1 -0
  1182. package/build-types/ui/control-group/component.d.ts +1 -1
  1183. package/build-types/ui/control-group/component.d.ts.map +1 -1
  1184. package/build-types/ui/control-group/hook.d.ts +224 -224
  1185. package/build-types/ui/control-group/hook.d.ts.map +1 -1
  1186. package/build-types/ui/control-label/component.d.ts +2 -2
  1187. package/build-types/ui/control-label/component.d.ts.map +1 -1
  1188. package/build-types/ui/control-label/hook.d.ts +224 -224
  1189. package/build-types/ui/control-label/hook.d.ts.map +1 -1
  1190. package/build-types/ui/form-group/form-group-content.d.ts +2 -2
  1191. package/build-types/ui/form-group/form-group-content.d.ts.map +1 -1
  1192. package/build-types/ui/form-group/form-group-context.d.ts +1 -1
  1193. package/build-types/ui/form-group/form-group-context.d.ts.map +1 -1
  1194. package/build-types/ui/form-group/form-group-label.d.ts +2 -2
  1195. package/build-types/ui/form-group/form-group-label.d.ts.map +1 -1
  1196. package/build-types/ui/form-group/form-group.d.ts +14 -14
  1197. package/build-types/ui/form-group/use-form-group.d.ts +470 -470
  1198. package/build-types/ui/form-group/use-form-group.d.ts.map +1 -1
  1199. package/build-types/ui/shortcut/component.d.ts +1 -1
  1200. package/build-types/ui/shortcut/component.d.ts.map +1 -1
  1201. package/build-types/ui/spinner/component.d.ts +1 -1
  1202. package/build-types/ui/spinner/styles.d.ts +3 -3
  1203. package/build-types/ui/tooltip/component.d.ts +1 -1
  1204. package/build-types/ui/tooltip/component.d.ts.map +1 -1
  1205. package/build-types/ui/tooltip/content.d.ts +1 -1
  1206. package/build-types/ui/tooltip/context.d.ts +1 -1
  1207. package/build-types/ui/tooltip/styles.d.ts +4 -4
  1208. package/build-types/ui/utils/colors.d.ts.map +1 -1
  1209. package/build-types/ui/utils/index.d.ts +0 -1
  1210. package/build-types/ui/utils/space.d.ts.map +1 -1
  1211. package/build-types/ui/utils/use-responsive-value.d.ts.map +1 -1
  1212. package/build-types/unit-control/index.d.ts +35 -0
  1213. package/build-types/unit-control/index.d.ts.map +1 -0
  1214. package/build-types/unit-control/styles/unit-control-styles.d.ts +41 -0
  1215. package/build-types/unit-control/styles/unit-control-styles.d.ts.map +1 -0
  1216. package/build-types/unit-control/types.d.ts +106 -0
  1217. package/build-types/unit-control/types.d.ts.map +1 -0
  1218. package/build-types/unit-control/unit-select-control.d.ts +8 -0
  1219. package/build-types/unit-control/unit-select-control.d.ts.map +1 -0
  1220. package/build-types/unit-control/utils.d.ts +102 -0
  1221. package/build-types/unit-control/utils.d.ts.map +1 -0
  1222. package/build-types/utils/colors.d.ts.map +1 -1
  1223. package/build-types/utils/config-values.d.ts +9 -9
  1224. package/build-types/utils/hooks/index.d.ts +1 -1
  1225. package/build-types/utils/hooks/use-combined-ref.d.ts +8 -0
  1226. package/build-types/utils/hooks/use-combined-ref.d.ts.map +1 -0
  1227. package/build-types/utils/hooks/use-controlled-state.d.ts +1 -1
  1228. package/build-types/utils/hooks/use-controlled-state.d.ts.map +1 -1
  1229. package/build-types/utils/rtl.d.ts +12 -0
  1230. package/build-types/utils/rtl.d.ts.map +1 -1
  1231. package/build-types/v-stack/component.d.ts +2 -2
  1232. package/build-types/v-stack/component.d.ts.map +1 -1
  1233. package/build-types/v-stack/hook.d.ts +222 -222
  1234. package/build-types/v-stack/hook.d.ts.map +1 -1
  1235. package/build-types/view/component.d.ts +2 -2
  1236. package/build-types/view/component.d.ts.map +1 -1
  1237. package/build-types/visually-hidden/component.d.ts +1 -1
  1238. package/build-types/visually-hidden/component.d.ts.map +1 -1
  1239. package/build-types/z-stack/component.d.ts +1 -1
  1240. package/build-types/z-stack/component.d.ts.map +1 -1
  1241. package/build-types/z-stack/styles.d.ts +2 -2
  1242. package/package.json +18 -18
  1243. package/src/alignment-matrix-control/README.md +60 -2
  1244. package/src/alignment-matrix-control/stories/index.js +3 -0
  1245. package/src/angle-picker-control/index.js +42 -40
  1246. package/src/angle-picker-control/styles/angle-picker-control-styles.js +10 -7
  1247. package/src/animate/index.js +1 -1
  1248. package/src/autocomplete/autocompleter-ui.native.js +4 -3
  1249. package/src/base-control/index.js +2 -2
  1250. package/src/base-control/stories/index.js +7 -1
  1251. package/src/base-field/hook.js +1 -1
  1252. package/src/base-field/test/__snapshots__/index.js.snap +1 -1
  1253. package/src/button/index.js +7 -2
  1254. package/src/button/stories/index.js +14 -9
  1255. package/src/card/card/component.js +2 -2
  1256. package/src/card/card/hook.js +3 -5
  1257. package/src/card/card-body/component.js +2 -2
  1258. package/src/card/card-body/hook.js +1 -1
  1259. package/src/card/card-divider/component.js +2 -2
  1260. package/src/card/card-divider/hook.js +1 -1
  1261. package/src/card/card-footer/component.js +2 -2
  1262. package/src/card/card-footer/hook.js +1 -1
  1263. package/src/card/card-header/component.js +2 -2
  1264. package/src/card/card-header/hook.js +1 -1
  1265. package/src/card/card-media/component.js +14 -7
  1266. package/src/card/card-media/hook.js +1 -1
  1267. package/src/card/stories/index.js +3 -0
  1268. package/src/card/test/__snapshots__/index.js.snap +25 -25
  1269. package/src/checkbox-control/stories/index.js +3 -0
  1270. package/src/circular-option-picker/style.scss +3 -5
  1271. package/src/clipboard-button/README.md +41 -1
  1272. package/src/color-edit/index.js +248 -275
  1273. package/src/color-edit/style.scss +4 -45
  1274. package/src/color-edit/styles.js +97 -0
  1275. package/src/color-indicator/stories/index.js +3 -0
  1276. package/src/color-list-picker/index.js +5 -0
  1277. package/src/color-list-picker/style.scss +4 -0
  1278. package/src/color-palette/index.js +131 -59
  1279. package/src/color-palette/stories/index.js +7 -1
  1280. package/src/color-palette/style.native.scss +1 -1
  1281. package/src/color-palette/style.scss +18 -0
  1282. package/src/color-palette/styles.js +19 -0
  1283. package/src/color-palette/test/__snapshots__/index.js.snap +453 -496
  1284. package/src/color-picker/README.md +41 -12
  1285. package/src/{ui/color-picker → color-picker}/color-display.tsx +41 -27
  1286. package/src/{ui/color-picker → color-picker}/color-input.tsx +3 -3
  1287. package/src/color-picker/component.tsx +138 -0
  1288. package/src/color-picker/hex-input.tsx +54 -0
  1289. package/src/{ui/color-picker → color-picker}/hsl-input.tsx +42 -26
  1290. package/src/color-picker/index.native.js +14 -9
  1291. package/src/color-picker/index.ts +4 -0
  1292. package/src/{ui/color-picker → color-picker}/input-with-slider.tsx +13 -10
  1293. package/src/color-picker/legacy-adapter.tsx +11 -0
  1294. package/src/color-picker/picker.tsx +31 -0
  1295. package/src/{ui/color-picker → color-picker}/rgb-input.tsx +9 -9
  1296. package/src/color-picker/stories/index.js +63 -12
  1297. package/src/color-picker/styles.ts +123 -0
  1298. package/src/color-picker/test/index.js +114 -87
  1299. package/src/{ui/color-picker → color-picker}/types.ts +0 -0
  1300. package/src/color-picker/use-deprecated-props.ts +148 -0
  1301. package/src/combobox-control/index.js +27 -4
  1302. package/src/custom-gradient-bar/constants.js +2 -2
  1303. package/src/custom-gradient-bar/control-points.js +44 -56
  1304. package/src/custom-gradient-picker/index.js +5 -7
  1305. package/src/custom-gradient-picker/style.scss +41 -18
  1306. package/src/custom-gradient-picker/styles/custom-gradient-picker-styles.js +1 -1
  1307. package/src/custom-gradient-picker/utils.js +6 -3
  1308. package/src/custom-select-control/README.md +7 -0
  1309. package/src/custom-select-control/index.js +28 -9
  1310. package/src/custom-select-control/style.scss +10 -4
  1311. package/src/dashicon/index.native.js +18 -0
  1312. package/src/date-time/README.md +0 -9
  1313. package/src/date-time/index.js +2 -1
  1314. package/src/date-time/stories/index.js +3 -0
  1315. package/src/date-time/stories/time.js +7 -1
  1316. package/src/date-time/style.scss +5 -0
  1317. package/src/dimension-control/sizes.js +6 -6
  1318. package/src/divider/component.tsx +6 -4
  1319. package/src/divider/stories/index.js +3 -0
  1320. package/src/drop-zone/index.js +63 -11
  1321. package/src/drop-zone/style.scss +11 -20
  1322. package/src/dropdown/README.md +13 -12
  1323. package/src/dropdown/index.js +5 -0
  1324. package/src/dropdown/style.scss +8 -2
  1325. package/src/dropdown-menu/index.js +18 -32
  1326. package/src/dropdown-menu/index.native.js +0 -19
  1327. package/src/dropdown-menu/stories/index.js +24 -10
  1328. package/src/dropdown-menu/style.scss +11 -10
  1329. package/src/duotone-picker/README.md +6 -6
  1330. package/src/duotone-picker/custom-duotone-bar.js +0 -1
  1331. package/src/duotone-picker/duotone-picker.js +1 -0
  1332. package/src/duotone-picker/utils.js +5 -2
  1333. package/src/elevation/component.js +14 -7
  1334. package/src/elevation/hook.js +1 -1
  1335. package/src/elevation/stories/index.js +3 -0
  1336. package/src/external-link/stories/index.js +7 -1
  1337. package/src/flex/flex/README.md +0 -3
  1338. package/src/flex/flex/component.js +2 -2
  1339. package/src/flex/flex/hook.js +41 -31
  1340. package/src/flex/flex-block/component.js +14 -7
  1341. package/src/flex/flex-block/hook.js +1 -1
  1342. package/src/flex/flex-item/component.js +14 -7
  1343. package/src/flex/flex-item/hook.js +1 -1
  1344. package/src/flex/stories/index.js +1 -1
  1345. package/src/flex/test/__snapshots__/index.js.snap +1 -1
  1346. package/src/flex/types.ts +0 -1
  1347. package/src/flyout/flyout/component.js +2 -2
  1348. package/src/flyout/flyout/hook.js +1 -1
  1349. package/src/flyout/flyout-content/component.js +2 -2
  1350. package/src/flyout/test/__snapshots__/index.js.snap +1 -1
  1351. package/src/focal-point-picker/controls.js +1 -1
  1352. package/src/focusable-iframe/README.md +2 -0
  1353. package/src/focusable-iframe/index.js +6 -29
  1354. package/src/font-size-picker/README.md +9 -0
  1355. package/src/font-size-picker/index.js +196 -108
  1356. package/src/font-size-picker/index.native.js +184 -0
  1357. package/src/font-size-picker/stories/index.js +55 -3
  1358. package/src/font-size-picker/style.native.scss +6 -0
  1359. package/src/font-size-picker/style.scss +16 -11
  1360. package/src/font-size-picker/test/index.js +8 -0
  1361. package/src/font-size-picker/utils.js +101 -0
  1362. package/src/form-token-field/stories/index.js +3 -0
  1363. package/src/gradient-picker/index.js +79 -11
  1364. package/src/gradient-picker/stories/index.js +3 -0
  1365. package/src/grid/component.js +14 -7
  1366. package/src/grid/hook.js +1 -1
  1367. package/src/grid/stories/index.js +3 -0
  1368. package/src/guide/index.js +8 -9
  1369. package/src/guide/stories/index.js +7 -1
  1370. package/src/h-stack/component.js +14 -7
  1371. package/src/h-stack/hook.js +1 -1
  1372. package/src/h-stack/stories/index.js +1 -1
  1373. package/src/h-stack/test/__snapshots__/index.js.snap +3 -3
  1374. package/src/heading/component.tsx +37 -0
  1375. package/src/heading/hook.ts +7 -8
  1376. package/src/heading/stories/index.js +1 -1
  1377. package/src/heading/test/__snapshots__/index.js.snap +1 -1
  1378. package/src/higher-order/navigate-regions/index.js +62 -36
  1379. package/src/icon/stories/index.js +17 -11
  1380. package/src/index.js +12 -5
  1381. package/src/index.native.js +4 -1
  1382. package/src/input-control/input-field.tsx +2 -2
  1383. package/src/input-control/label.tsx +2 -2
  1384. package/src/input-control/reducer/actions.ts +1 -4
  1385. package/src/input-control/reducer/reducer.ts +1 -1
  1386. package/src/input-control/reducer/state.ts +1 -1
  1387. package/src/input-control/stories/index.js +3 -0
  1388. package/src/input-control/styles/input-control-styles.tsx +2 -2
  1389. package/src/input-control/types.ts +10 -8
  1390. package/src/item-group/item/README.md +2 -3
  1391. package/src/item-group/item/component.tsx +2 -2
  1392. package/src/item-group/item/hook.ts +24 -12
  1393. package/src/item-group/item-group/component.tsx +2 -2
  1394. package/src/item-group/item-group/hook.ts +2 -2
  1395. package/src/item-group/stories/index.js +98 -15
  1396. package/src/item-group/styles.ts +5 -1
  1397. package/src/item-group/test/__snapshots__/index.js.snap +11 -32
  1398. package/src/item-group/test/index.js +28 -10
  1399. package/src/item-group/types.ts +0 -6
  1400. package/src/menu-group/index.js +3 -6
  1401. package/src/menu-group/style.scss +1 -0
  1402. package/src/menu-item/README.md +8 -0
  1403. package/src/menu-item/index.js +13 -24
  1404. package/src/menu-item/style.scss +17 -3
  1405. package/src/menu-item/test/__snapshots__/index.js.snap +2 -2
  1406. package/src/mobile/README.md +3 -0
  1407. package/src/mobile/bottom-sheet/bottom-sheet-navigation/navigation-container.native.js +17 -7
  1408. package/src/mobile/bottom-sheet/cell.native.js +29 -3
  1409. package/src/mobile/bottom-sheet/cellStyles.android.scss +5 -1
  1410. package/src/mobile/bottom-sheet/cellStyles.ios.scss +5 -1
  1411. package/src/mobile/bottom-sheet/footer-message-link/footer-message-link.native.js +7 -6
  1412. package/src/mobile/bottom-sheet/index.native.js +18 -5
  1413. package/src/mobile/bottom-sheet/link-cell.native.js +10 -3
  1414. package/src/mobile/bottom-sheet/nav-bar/README.md +63 -0
  1415. package/src/mobile/bottom-sheet/nav-bar/action-button.native.js +30 -0
  1416. package/src/mobile/bottom-sheet/nav-bar/apply-button.native.js +53 -0
  1417. package/src/mobile/bottom-sheet/nav-bar/back-button.native.js +94 -0
  1418. package/src/mobile/bottom-sheet/nav-bar/heading.native.js +33 -0
  1419. package/src/mobile/bottom-sheet/nav-bar/index.native.js +23 -0
  1420. package/src/mobile/bottom-sheet/nav-bar/styles.native.scss +69 -0
  1421. package/src/mobile/bottom-sheet/range-cell.native.js +12 -2
  1422. package/src/mobile/bottom-sheet/range-text-input.native.js +1 -0
  1423. package/src/mobile/bottom-sheet/stepper-cell/stepper.ios.js +2 -2
  1424. package/src/mobile/bottom-sheet/styles.native.scss +32 -14
  1425. package/src/mobile/bottom-sheet/sub-sheet/README.md +4 -4
  1426. package/src/mobile/bottom-sheet-select-control/index.native.js +6 -4
  1427. package/src/mobile/bottom-sheet-text-control/index.native.js +8 -9
  1428. package/src/mobile/color-settings/gradient-picker-screen.native.js +5 -5
  1429. package/src/mobile/color-settings/palette.screen.native.js +25 -11
  1430. package/src/mobile/color-settings/picker-screen.native.js +1 -1
  1431. package/src/mobile/color-settings/style.native.scss +11 -0
  1432. package/src/mobile/dashicons/index.native.js +22 -0
  1433. package/src/mobile/focal-point-settings-panel/index.native.js +12 -7
  1434. package/src/mobile/global-styles-context/index.native.js +15 -2
  1435. package/src/mobile/global-styles-context/test/fixtures/theme.native.js +6 -0
  1436. package/src/mobile/global-styles-context/test/utils.native.js +3 -3
  1437. package/src/mobile/global-styles-context/utils.native.js +120 -7
  1438. package/src/mobile/html-text-input/index.native.js +17 -10
  1439. package/src/mobile/inserter-button/index.native.js +4 -7
  1440. package/src/mobile/inserter-button/style.native.scss +0 -5
  1441. package/src/mobile/link-picker/index.native.js +6 -7
  1442. package/src/mobile/link-settings/image-link-destinations-screen.native.js +148 -0
  1443. package/src/mobile/link-settings/index.native.js +3 -2
  1444. package/src/mobile/link-settings/link-settings-navigation.native.js +1 -0
  1445. package/src/mobile/link-settings/link-settings-screen.native.js +6 -2
  1446. package/src/mobile/link-settings/style.native.scss +17 -0
  1447. package/src/mobile/picker/index.android.js +2 -1
  1448. package/src/mobile/segmented-control/index.native.js +1 -0
  1449. package/src/modal/README.md +8 -0
  1450. package/src/modal/index.js +158 -150
  1451. package/src/modal/stories/index.js +11 -4
  1452. package/src/modal/style.scss +5 -0
  1453. package/src/navigable-container/container.js +1 -0
  1454. package/src/navigable-container/index.js +1 -0
  1455. package/src/navigable-container/menu.js +1 -0
  1456. package/src/navigable-container/tabbable.js +1 -0
  1457. package/src/navigation/README.md +9 -0
  1458. package/src/navigation/group/index.js +1 -2
  1459. package/src/navigation/menu/index.js +9 -7
  1460. package/src/navigation/menu/menu-title-search.js +11 -26
  1461. package/src/navigation/menu/menu-title.js +4 -4
  1462. package/src/navigation/styles/navigation-styles.js +59 -74
  1463. package/src/navigator/context.ts +12 -0
  1464. package/src/navigator/index.ts +3 -0
  1465. package/src/navigator/navigator-provider/README.md +75 -0
  1466. package/src/navigator/navigator-provider/component.tsx +107 -0
  1467. package/src/{tools-panel/tools-panel-header/index.js → navigator/navigator-provider/index.ts} +0 -0
  1468. package/src/navigator/navigator-screen/README.md +21 -0
  1469. package/src/navigator/navigator-screen/component.tsx +185 -0
  1470. package/src/navigator/navigator-screen/index.ts +1 -0
  1471. package/src/navigator/stories/index.js +188 -0
  1472. package/src/navigator/test/index.js +218 -0
  1473. package/src/navigator/types.ts +45 -0
  1474. package/src/navigator/use-navigator.ts +25 -0
  1475. package/src/notice/stories/index.js +3 -0
  1476. package/src/number-control/README.md +18 -2
  1477. package/src/number-control/index.js +32 -34
  1478. package/src/number-control/stories/index.js +4 -1
  1479. package/src/number-control/test/index.js +40 -0
  1480. package/src/panel/body.native.js +4 -1
  1481. package/src/panel/stories/index.js +13 -2
  1482. package/src/panel/style.scss +1 -2
  1483. package/src/placeholder/stories/index.js +7 -1
  1484. package/src/popover/index.js +14 -24
  1485. package/src/popover/stories/index.js +7 -1
  1486. package/src/popover/utils.js +69 -36
  1487. package/src/query-controls/index.native.js +33 -31
  1488. package/src/range-control/README.md +13 -7
  1489. package/src/range-control/index.js +9 -2
  1490. package/src/range-control/input-range.js +0 -17
  1491. package/src/range-control/rail.js +3 -0
  1492. package/src/range-control/stories/index.js +36 -8
  1493. package/src/range-control/styles/range-control-styles.js +29 -24
  1494. package/src/range-control/tooltip.js +11 -22
  1495. package/src/resizable-box/index.tsx +128 -0
  1496. package/src/resizable-box/resize-tooltip/{index.js → index.tsx} +19 -6
  1497. package/src/resizable-box/resize-tooltip/{label.js → label.tsx} +23 -9
  1498. package/src/resizable-box/resize-tooltip/styles/resize-tooltip.styles.js +1 -1
  1499. package/src/resizable-box/resize-tooltip/{utils.js → utils.ts} +51 -30
  1500. package/src/resizable-box/stories/index.js +7 -1
  1501. package/src/resizable-box/style.scss +9 -1
  1502. package/src/sandbox/index.js +3 -7
  1503. package/src/sandbox/index.native.js +75 -25
  1504. package/src/sandbox/style.native.scss +4 -0
  1505. package/src/scrollable/README.md +1 -1
  1506. package/src/scrollable/component.js +15 -8
  1507. package/src/scrollable/hook.js +1 -1
  1508. package/src/scrollable/stories/index.js +3 -0
  1509. package/src/search-control/index.js +47 -23
  1510. package/src/search-control/index.native.js +14 -5
  1511. package/src/search-control/platform-style.android.scss +1 -4
  1512. package/src/search-control/platform-style.ios.scss +0 -3
  1513. package/src/search-control/stories/index.js +3 -0
  1514. package/src/search-control/style.native.scss +1 -3
  1515. package/src/search-control/style.scss +1 -1
  1516. package/src/select-control/README.md +36 -4
  1517. package/src/select-control/index.tsx +21 -19
  1518. package/src/select-control/stories/index.js +38 -1
  1519. package/src/select-control/test/select-control.js +82 -0
  1520. package/src/slot-fill/stories/index.js +3 -0
  1521. package/src/snackbar/index.js +4 -0
  1522. package/src/snackbar/list.js +4 -1
  1523. package/src/snackbar/stories/index.js +7 -1
  1524. package/src/spacer/{component.ts → component.tsx} +20 -7
  1525. package/src/spacer/hook.ts +2 -4
  1526. package/src/spacer/stories/index.js +3 -0
  1527. package/src/style.scss +1 -1
  1528. package/src/surface/README.md +1 -1
  1529. package/src/surface/component.js +15 -6
  1530. package/src/surface/hook.js +1 -1
  1531. package/src/surface/stories/index.js +3 -0
  1532. package/src/tab-panel/stories/index.js +7 -1
  1533. package/src/text/component.js +14 -7
  1534. package/src/text/hook.js +1 -1
  1535. package/src/text/styles.js +1 -1
  1536. package/src/text/test/__snapshots__/index.js.snap +2 -2
  1537. package/src/text-control/stories/index.js +3 -0
  1538. package/src/text-highlight/stories/index.js +7 -1
  1539. package/src/textarea-control/stories/index.js +3 -0
  1540. package/src/tip/stories/index.js +7 -1
  1541. package/src/toggle-control/index.native.js +8 -2
  1542. package/src/toggle-control/stories/index.js +7 -1
  1543. package/src/toggle-group-control/context.ts +16 -0
  1544. package/src/toggle-group-control/index.ts +2 -0
  1545. package/src/toggle-group-control/stories/index.js +142 -0
  1546. package/src/{segmented-control → toggle-group-control}/test/__snapshots__/index.js.snap +95 -117
  1547. package/src/toggle-group-control/test/index.js +41 -0
  1548. package/src/toggle-group-control/toggle-group-control/README.md +76 -0
  1549. package/src/toggle-group-control/toggle-group-control/component.tsx +150 -0
  1550. package/src/toggle-group-control/toggle-group-control/index.ts +1 -0
  1551. package/src/toggle-group-control/toggle-group-control/styles.ts +52 -0
  1552. package/src/{segmented-control/segmented-control-backdrop.tsx → toggle-group-control/toggle-group-control/toggle-group-control-backdrop.tsx} +18 -7
  1553. package/src/toggle-group-control/toggle-group-control-option/README.md +40 -0
  1554. package/src/toggle-group-control/toggle-group-control-option/component.tsx +104 -0
  1555. package/src/toggle-group-control/toggle-group-control-option/index.ts +1 -0
  1556. package/src/{segmented-control → toggle-group-control/toggle-group-control-option}/styles.ts +2 -55
  1557. package/src/{segmented-control → toggle-group-control}/types.ts +19 -24
  1558. package/src/toolbar-button/stories/index.js +13 -3
  1559. package/src/tools-panel/context.ts +25 -0
  1560. package/src/tools-panel/{index.js → index.ts} +1 -0
  1561. package/src/tools-panel/stories/index.js +166 -8
  1562. package/src/tools-panel/stories/typography-panel.js +215 -0
  1563. package/src/tools-panel/styles.ts +118 -0
  1564. package/src/tools-panel/test/index.js +288 -38
  1565. package/src/tools-panel/tools-panel/README.md +23 -10
  1566. package/src/tools-panel/tools-panel/component.tsx +49 -0
  1567. package/src/tools-panel/tools-panel/hook.ts +220 -0
  1568. package/src/tools-panel/tools-panel/{index.js → index.ts} +0 -0
  1569. package/src/tools-panel/tools-panel-header/README.md +6 -11
  1570. package/src/tools-panel/tools-panel-header/component.tsx +194 -0
  1571. package/src/tools-panel/tools-panel-header/hook.ts +51 -0
  1572. package/src/tools-panel/tools-panel-header/index.ts +1 -0
  1573. package/src/tools-panel/tools-panel-item/README.md +38 -2
  1574. package/src/tools-panel/tools-panel-item/component.tsx +46 -0
  1575. package/src/tools-panel/tools-panel-item/hook.ts +129 -0
  1576. package/src/tools-panel/tools-panel-item/{index.js → index.ts} +0 -0
  1577. package/src/tools-panel/types.ts +142 -0
  1578. package/src/tooltip/README.md +8 -0
  1579. package/src/tooltip/index.js +14 -3
  1580. package/src/tooltip/index.native.js +1 -0
  1581. package/src/tooltip/stories/index.js +40 -2
  1582. package/src/tooltip/test/index.js +54 -0
  1583. package/src/tooltip/test/index.native.js +103 -0
  1584. package/src/tree-grid/index.js +3 -1
  1585. package/src/tree-select/stories/index.js +3 -0
  1586. package/src/truncate/component.js +14 -7
  1587. package/src/truncate/hook.js +1 -1
  1588. package/src/truncate/stories/index.js +4 -1
  1589. package/src/ui/context/context-connect.js +3 -3
  1590. package/src/ui/context/index.js +1 -1
  1591. package/src/ui/context/stories/ComponentsProvider.stories.js +1 -1
  1592. package/src/ui/context/use-context-system.js +1 -1
  1593. package/src/ui/context/{polymorphic-component.ts → wordpress-component.ts} +7 -7
  1594. package/src/ui/control-group/component.js +2 -2
  1595. package/src/ui/control-group/hook.js +1 -1
  1596. package/src/ui/control-group/test/__snapshots__/index.js.snap +1 -1
  1597. package/src/ui/control-label/component.js +14 -7
  1598. package/src/ui/control-label/hook.js +1 -1
  1599. package/src/ui/control-label/stories/index.js +1 -1
  1600. package/src/ui/control-label/test/__snapshots__/index.js.snap +3 -3
  1601. package/src/ui/form-group/form-group-content.js +1 -1
  1602. package/src/ui/form-group/form-group-label.js +1 -1
  1603. package/src/ui/form-group/form-group.js +2 -2
  1604. package/src/ui/form-group/stories/index.js +1 -1
  1605. package/src/ui/form-group/test/__snapshots__/index.js.snap +2 -2
  1606. package/src/ui/form-group/use-form-group.js +1 -1
  1607. package/src/ui/shortcut/component.tsx +6 -4
  1608. package/src/ui/spinner/component.js +2 -2
  1609. package/src/ui/spinner/stories/index.js +1 -1
  1610. package/src/ui/tooltip/component.js +2 -2
  1611. package/src/ui/tooltip/content.js +2 -2
  1612. package/src/ui/tooltip/stories/index.js +1 -1
  1613. package/src/ui/tooltip/styles.js +1 -1
  1614. package/src/ui/tooltip/test/__snapshots__/index.js.snap +1 -1
  1615. package/src/ui/utils/colors.js +6 -7
  1616. package/src/ui/utils/index.js +0 -1
  1617. package/src/ui/utils/space.ts +2 -1
  1618. package/src/ui/utils/use-responsive-value.ts +0 -3
  1619. package/src/unit-control/README.md +21 -24
  1620. package/src/unit-control/index.native.js +4 -0
  1621. package/src/unit-control/{index.js → index.tsx} +73 -28
  1622. package/src/unit-control/stories/index.js +47 -3
  1623. package/src/unit-control/styles/{unit-control-styles.js → unit-control-styles.ts} +18 -7
  1624. package/src/unit-control/test/index.js +18 -0
  1625. package/src/unit-control/test/utils.js +123 -1
  1626. package/src/unit-control/types.ts +115 -0
  1627. package/src/unit-control/unit-select-control.tsx +62 -0
  1628. package/src/unit-control/{utils.js → utils.ts} +121 -51
  1629. package/src/utils/colors.js +5 -3
  1630. package/src/utils/config-values.js +9 -8
  1631. package/src/utils/hooks/index.js +1 -1
  1632. package/src/utils/hooks/use-combined-ref.ts +29 -0
  1633. package/src/utils/test/colors.js +11 -0
  1634. package/src/v-stack/component.js +14 -7
  1635. package/src/v-stack/hook.js +1 -1
  1636. package/src/v-stack/test/__snapshots__/index.js.snap +3 -3
  1637. package/src/view/component.js +1 -1
  1638. package/src/visually-hidden/component.js +2 -2
  1639. package/src/z-stack/component.tsx +2 -3
  1640. package/src/z-stack/stories/index.js +3 -0
  1641. package/tsconfig.json +15 -2
  1642. package/tsconfig.tsbuildinfo +1 -10694
  1643. package/build/color-picker/alpha.js +0 -202
  1644. package/build/color-picker/alpha.js.map +0 -1
  1645. package/build/color-picker/hue.js +0 -202
  1646. package/build/color-picker/hue.js.map +0 -1
  1647. package/build/color-picker/inputs.js +0 -345
  1648. package/build/color-picker/inputs.js.map +0 -1
  1649. package/build/color-picker/saturation.js +0 -209
  1650. package/build/color-picker/saturation.js.map +0 -1
  1651. package/build/color-picker/utils.js +0 -253
  1652. package/build/color-picker/utils.js.map +0 -1
  1653. package/build/mobile/bottom-sheet/navigation-header.native.js +0 -106
  1654. package/build/mobile/bottom-sheet/navigation-header.native.js.map +0 -1
  1655. package/build/modal/frame.js +0 -109
  1656. package/build/modal/frame.js.map +0 -1
  1657. package/build/modal/header.js +0 -53
  1658. package/build/modal/header.js.map +0 -1
  1659. package/build/segmented-control/component.js +0 -94
  1660. package/build/segmented-control/component.js.map +0 -1
  1661. package/build/segmented-control/index.js +0 -24
  1662. package/build/segmented-control/index.js.map +0 -1
  1663. package/build/segmented-control/segmented-control-backdrop.js.map +0 -1
  1664. package/build/segmented-control/segmented-control-button.js +0 -85
  1665. package/build/segmented-control/segmented-control-button.js.map +0 -1
  1666. package/build/segmented-control/segmented-control-context.js +0 -20
  1667. package/build/segmented-control/segmented-control-context.js.map +0 -1
  1668. package/build/segmented-control/segmented-control-option.js +0 -70
  1669. package/build/segmented-control/segmented-control-option.js.map +0 -1
  1670. package/build/segmented-control/styles.js +0 -99
  1671. package/build/segmented-control/styles.js.map +0 -1
  1672. package/build/ui/color-picker/color-display.js.map +0 -1
  1673. package/build/ui/color-picker/color-input.js.map +0 -1
  1674. package/build/ui/color-picker/component.js.map +0 -1
  1675. package/build/ui/color-picker/hex-input.js +0 -65
  1676. package/build/ui/color-picker/hex-input.js.map +0 -1
  1677. package/build/ui/color-picker/hsl-input.js.map +0 -1
  1678. package/build/ui/color-picker/index.js.map +0 -1
  1679. package/build/ui/color-picker/input-with-slider.js.map +0 -1
  1680. package/build/ui/color-picker/picker.js +0 -36
  1681. package/build/ui/color-picker/picker.js.map +0 -1
  1682. package/build/ui/color-picker/rgb-input.js.map +0 -1
  1683. package/build/ui/color-picker/styles.js +0 -51
  1684. package/build/ui/color-picker/styles.js.map +0 -1
  1685. package/build/ui/context/polymorphic-component.js +0 -2
  1686. package/build/ui/utils/create-component.js +0 -59
  1687. package/build/ui/utils/create-component.js.map +0 -1
  1688. package/build/utils/hooks/use-jump-step.js +0 -57
  1689. package/build/utils/hooks/use-jump-step.js.map +0 -1
  1690. package/build-module/color-picker/alpha.js +0 -183
  1691. package/build-module/color-picker/alpha.js.map +0 -1
  1692. package/build-module/color-picker/hue.js +0 -182
  1693. package/build-module/color-picker/hue.js.map +0 -1
  1694. package/build-module/color-picker/inputs.js +0 -320
  1695. package/build-module/color-picker/inputs.js.map +0 -1
  1696. package/build-module/color-picker/saturation.js +0 -188
  1697. package/build-module/color-picker/saturation.js.map +0 -1
  1698. package/build-module/color-picker/utils.js +0 -232
  1699. package/build-module/color-picker/utils.js.map +0 -1
  1700. package/build-module/mobile/bottom-sheet/navigation-header.native.js +0 -91
  1701. package/build-module/mobile/bottom-sheet/navigation-header.native.js.map +0 -1
  1702. package/build-module/modal/frame.js +0 -96
  1703. package/build-module/modal/frame.js.map +0 -1
  1704. package/build-module/modal/header.js +0 -41
  1705. package/build-module/modal/header.js.map +0 -1
  1706. package/build-module/segmented-control/component.js +0 -77
  1707. package/build-module/segmented-control/component.js.map +0 -1
  1708. package/build-module/segmented-control/index.js +0 -3
  1709. package/build-module/segmented-control/index.js.map +0 -1
  1710. package/build-module/segmented-control/segmented-control-backdrop.js.map +0 -1
  1711. package/build-module/segmented-control/segmented-control-button.js +0 -68
  1712. package/build-module/segmented-control/segmented-control-button.js.map +0 -1
  1713. package/build-module/segmented-control/segmented-control-context.js +0 -12
  1714. package/build-module/segmented-control/segmented-control-context.js.map +0 -1
  1715. package/build-module/segmented-control/segmented-control-option.js +0 -55
  1716. package/build-module/segmented-control/segmented-control-option.js.map +0 -1
  1717. package/build-module/segmented-control/styles.js +0 -83
  1718. package/build-module/segmented-control/styles.js.map +0 -1
  1719. package/build-module/ui/color-picker/color-display.js.map +0 -1
  1720. package/build-module/ui/color-picker/color-input.js.map +0 -1
  1721. package/build-module/ui/color-picker/component.js.map +0 -1
  1722. package/build-module/ui/color-picker/hex-input.js +0 -48
  1723. package/build-module/ui/color-picker/hex-input.js.map +0 -1
  1724. package/build-module/ui/color-picker/hsl-input.js.map +0 -1
  1725. package/build-module/ui/color-picker/index.js +0 -2
  1726. package/build-module/ui/color-picker/index.js.map +0 -1
  1727. package/build-module/ui/color-picker/input-with-slider.js.map +0 -1
  1728. package/build-module/ui/color-picker/picker.js +0 -26
  1729. package/build-module/ui/color-picker/picker.js.map +0 -1
  1730. package/build-module/ui/color-picker/rgb-input.js.map +0 -1
  1731. package/build-module/ui/color-picker/styles.js +0 -42
  1732. package/build-module/ui/color-picker/styles.js.map +0 -1
  1733. package/build-module/ui/context/polymorphic-component.js +0 -2
  1734. package/build-module/ui/utils/create-component.js +0 -46
  1735. package/build-module/ui/utils/create-component.js.map +0 -1
  1736. package/build-module/utils/hooks/use-jump-step.js +0 -48
  1737. package/build-module/utils/hooks/use-jump-step.js.map +0 -1
  1738. package/build-types/segmented-control/component.d.ts +0 -4
  1739. package/build-types/segmented-control/component.d.ts.map +0 -1
  1740. package/build-types/segmented-control/index.d.ts +0 -3
  1741. package/build-types/segmented-control/index.d.ts.map +0 -1
  1742. package/build-types/segmented-control/segmented-control-backdrop.d.ts +0 -9
  1743. package/build-types/segmented-control/segmented-control-backdrop.d.ts.map +0 -1
  1744. package/build-types/segmented-control/segmented-control-button.d.ts +0 -6
  1745. package/build-types/segmented-control/segmented-control-button.d.ts.map +0 -1
  1746. package/build-types/segmented-control/segmented-control-context.d.ts +0 -9
  1747. package/build-types/segmented-control/segmented-control-context.d.ts.map +0 -1
  1748. package/build-types/segmented-control/segmented-control-option.d.ts +0 -4
  1749. package/build-types/segmented-control/segmented-control-option.d.ts.map +0 -1
  1750. package/build-types/segmented-control/styles.d.ts +0 -29
  1751. package/build-types/segmented-control/styles.d.ts.map +0 -1
  1752. package/build-types/segmented-control/types.d.ts +0 -77
  1753. package/build-types/segmented-control/types.d.ts.map +0 -1
  1754. package/build-types/ui/color-picker/color-display.d.ts +0 -14
  1755. package/build-types/ui/color-picker/color-display.d.ts.map +0 -1
  1756. package/build-types/ui/color-picker/color-input.d.ts +0 -14
  1757. package/build-types/ui/color-picker/color-input.d.ts.map +0 -1
  1758. package/build-types/ui/color-picker/component.d.ts +0 -12
  1759. package/build-types/ui/color-picker/component.d.ts.map +0 -1
  1760. package/build-types/ui/color-picker/hex-input.d.ts +0 -13
  1761. package/build-types/ui/color-picker/hex-input.d.ts.map +0 -1
  1762. package/build-types/ui/color-picker/hsl-input.d.ts +0 -13
  1763. package/build-types/ui/color-picker/hsl-input.d.ts.map +0 -1
  1764. package/build-types/ui/color-picker/index.d.ts +0 -2
  1765. package/build-types/ui/color-picker/index.d.ts.map +0 -1
  1766. package/build-types/ui/color-picker/input-with-slider.d.ts +0 -12
  1767. package/build-types/ui/color-picker/input-with-slider.d.ts.map +0 -1
  1768. package/build-types/ui/color-picker/picker.d.ts +0 -13
  1769. package/build-types/ui/color-picker/picker.d.ts.map +0 -1
  1770. package/build-types/ui/color-picker/rgb-input.d.ts +0 -13
  1771. package/build-types/ui/color-picker/rgb-input.d.ts.map +0 -1
  1772. package/build-types/ui/color-picker/styles.d.ts +0 -43
  1773. package/build-types/ui/color-picker/styles.d.ts.map +0 -1
  1774. package/build-types/ui/color-picker/types.d.ts +0 -2
  1775. package/build-types/ui/color-picker/types.d.ts.map +0 -1
  1776. package/build-types/ui/context/polymorphic-component.d.ts.map +0 -1
  1777. package/build-types/ui/utils/create-component.d.ts +0 -22
  1778. package/build-types/ui/utils/create-component.d.ts.map +0 -1
  1779. package/build-types/utils/hooks/use-jump-step.d.ts +0 -25
  1780. package/build-types/utils/hooks/use-jump-step.d.ts.map +0 -1
  1781. package/src/color-picker/alpha.js +0 -184
  1782. package/src/color-picker/hue.js +0 -184
  1783. package/src/color-picker/index.js +0 -264
  1784. package/src/color-picker/inputs.js +0 -305
  1785. package/src/color-picker/saturation.js +0 -190
  1786. package/src/color-picker/style.scss +0 -269
  1787. package/src/color-picker/test/__snapshots__/index.js.snap +0 -817
  1788. package/src/color-picker/test/input.js +0 -174
  1789. package/src/color-picker/utils.js +0 -214
  1790. package/src/focusable-iframe/stories/index.js +0 -19
  1791. package/src/heading/component.ts +0 -25
  1792. package/src/mobile/bottom-sheet/navigation-header.native.js +0 -137
  1793. package/src/modal/frame.js +0 -111
  1794. package/src/modal/header.js +0 -53
  1795. package/src/resizable-box/index.js +0 -114
  1796. package/src/segmented-control/README.md +0 -70
  1797. package/src/segmented-control/component.tsx +0 -103
  1798. package/src/segmented-control/index.ts +0 -2
  1799. package/src/segmented-control/segmented-control-button.tsx +0 -72
  1800. package/src/segmented-control/segmented-control-context.ts +0 -16
  1801. package/src/segmented-control/segmented-control-option.tsx +0 -71
  1802. package/src/segmented-control/stories/index.js +0 -59
  1803. package/src/segmented-control/test/index.js +0 -42
  1804. package/src/tools-panel/context.js +0 -7
  1805. package/src/tools-panel/styles.js +0 -64
  1806. package/src/tools-panel/tools-panel/component.js +0 -38
  1807. package/src/tools-panel/tools-panel/hook.js +0 -79
  1808. package/src/tools-panel/tools-panel-header/component.js +0 -81
  1809. package/src/tools-panel/tools-panel-header/hook.js +0 -34
  1810. package/src/tools-panel/tools-panel-item/component.js +0 -31
  1811. package/src/tools-panel/tools-panel-item/hook.js +0 -67
  1812. package/src/ui/color-picker/README.md +0 -57
  1813. package/src/ui/color-picker/component.tsx +0 -141
  1814. package/src/ui/color-picker/hex-input.tsx +0 -55
  1815. package/src/ui/color-picker/index.ts +0 -1
  1816. package/src/ui/color-picker/picker.tsx +0 -26
  1817. package/src/ui/color-picker/stories/index.js +0 -59
  1818. package/src/ui/color-picker/styles.ts +0 -61
  1819. package/src/ui/utils/create-component.tsx +0 -59
  1820. package/src/ui/utils/test/create-component.js +0 -70
  1821. package/src/unit-control/unit-select-control.js +0 -70
  1822. package/src/utils/hooks/test/use-jump-step.js +0 -127
  1823. package/src/utils/hooks/use-jump-step.js +0 -51
@@ -2,10 +2,12 @@
2
2
  * External dependencies
3
3
  */
4
4
  import memoize from 'memize';
5
- import tinycolor from 'tinycolor2';
5
+ import { colord, extend } from 'colord';
6
+ import namesPlugin from 'colord/plugins/names';
6
7
  /** @type {HTMLDivElement} */
7
8
 
8
9
  let colorComputationNode;
10
+ extend([namesPlugin]);
9
11
  /**
10
12
  * @return {HTMLDivElement | undefined} The HTML element for color computation.
11
13
  */
@@ -33,7 +35,7 @@ function getColorComputationNode() {
33
35
 
34
36
  function isColor(value) {
35
37
  if (typeof value !== 'string') return false;
36
- const test = tinycolor(value);
38
+ const test = colord(value);
37
39
  return test.isValid();
38
40
  }
39
41
  /**
@@ -75,8 +77,7 @@ const getComputedBackgroundColor = memoize(_getComputedBackgroundColor);
75
77
 
76
78
  export function getOptimalTextColor(backgroundColor) {
77
79
  const background = getComputedBackgroundColor(backgroundColor);
78
- const isReadableWithBlackText = tinycolor.isReadable(background, '#000000');
79
- return isReadableWithBlackText ? '#000000' : '#ffffff';
80
+ return colord(background).isLight() ? '#000000' : '#ffffff';
80
81
  }
81
82
  /**
82
83
  * Get the text shade optimized for readability, based on a background color.
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/ui/utils/colors.js"],"names":["memoize","tinycolor","colorComputationNode","getColorComputationNode","document","el","createElement","setAttribute","body","appendChild","isColor","value","test","isValid","_getComputedBackgroundColor","backgroundColor","includes","style","background","computedColor","window","getComputedStyle","getComputedBackgroundColor","getOptimalTextColor","isReadableWithBlackText","isReadable","getOptimalTextShade","result"],"mappings":"AAAA;AACA;AACA;AACA,OAAOA,OAAP,MAAoB,QAApB;AACA,OAAOC,SAAP,MAAsB,YAAtB;AAEA;;AACA,IAAIC,oBAAJ;AAEA;AACA;AACA;;AACA,SAASC,uBAAT,GAAmC;AAClC,MAAK,OAAOC,QAAP,KAAoB,WAAzB,EAAuC;;AAEvC,MAAK,CAAEF,oBAAP,EAA8B;AAC7B;AACA,UAAMG,EAAE,GAAGD,QAAQ,CAACE,aAAT,CAAwB,KAAxB,CAAX;AACAD,IAAAA,EAAE,CAACE,YAAH,CAAiB,gCAAjB,EAAmD,EAAnD,EAH6B,CAI7B;;AACAH,IAAAA,QAAQ,CAACI,IAAT,CAAcC,WAAd,CAA2BJ,EAA3B;AACAH,IAAAA,oBAAoB,GAAGG,EAAvB;AACA;;AAED,SAAOH,oBAAP;AACA;AAED;AACA;AACA;AACA;AACA;;;AACA,SAASQ,OAAT,CAAkBC,KAAlB,EAA0B;AACzB,MAAK,OAAOA,KAAP,KAAiB,QAAtB,EAAiC,OAAO,KAAP;AACjC,QAAMC,IAAI,GAAGX,SAAS,CAAEU,KAAF,CAAtB;AAEA,SAAOC,IAAI,CAACC,OAAL,EAAP;AACA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACA,SAASC,2BAAT,CAAsCC,eAAtC,EAAwD;AAAA;;AACvD,MAAK,OAAOA,eAAP,KAA2B,QAAhC,EAA2C,OAAO,EAAP;AAE3C,MAAKL,OAAO,CAAEK,eAAF,CAAZ,EAAkC,OAAOA,eAAP;AAElC,MAAK,CAAEA,eAAe,CAACC,QAAhB,CAA0B,MAA1B,CAAP,EAA4C,OAAO,EAAP;AAC5C,MAAK,OAAOZ,QAAP,KAAoB,WAAzB,EAAuC,OAAO,EAAP,CANgB,CAQvD;;AACA,QAAMC,EAAE,GAAGF,uBAAuB,EAAlC;AACA,MAAK,CAAEE,EAAP,EAAY,OAAO,EAAP;AAEZA,EAAAA,EAAE,CAACY,KAAH,CAASC,UAAT,GAAsBH,eAAtB,CAZuD,CAavD;;AACA,QAAMI,aAAa,cAAGC,MAAH,4CAAG,QAAQC,gBAAR,CAA0BhB,EAA1B,EAA+Ba,UAArD,CAduD,CAevD;;AACAb,EAAAA,EAAE,CAACY,KAAH,CAASC,UAAT,GAAsB,EAAtB;AAEA,SAAOC,aAAa,IAAI,EAAxB;AACA;;AAED,MAAMG,0BAA0B,GAAGtB,OAAO,CAAEc,2BAAF,CAA1C;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASS,mBAAT,CAA8BR,eAA9B,EAAgD;AACtD,QAAMG,UAAU,GAAGI,0BAA0B,CAAEP,eAAF,CAA7C;AACA,QAAMS,uBAAuB,GAAGvB,SAAS,CAACwB,UAAV,CAC/BP,UAD+B,EAE/B,SAF+B,CAAhC;AAKA,SAAOM,uBAAuB,GAAG,SAAH,GAAe,SAA7C;AACA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASE,mBAAT,CAA8BX,eAA9B,EAAgD;AACtD,QAAMY,MAAM,GAAGJ,mBAAmB,CAAER,eAAF,CAAlC;AAEA,SAAOY,MAAM,KAAK,SAAX,GAAuB,MAAvB,GAAgC,OAAvC;AACA","sourcesContent":["/**\n * External dependencies\n */\nimport memoize from 'memize';\nimport tinycolor from 'tinycolor2';\n\n/** @type {HTMLDivElement} */\nlet colorComputationNode;\n\n/**\n * @return {HTMLDivElement | undefined} The HTML element for color computation.\n */\nfunction getColorComputationNode() {\n\tif ( typeof document === 'undefined' ) return;\n\n\tif ( ! colorComputationNode ) {\n\t\t// Create a temporary element for style computation.\n\t\tconst el = document.createElement( 'div' );\n\t\tel.setAttribute( 'data-g2-color-computation-node', '' );\n\t\t// Inject for window computed style.\n\t\tdocument.body.appendChild( el );\n\t\tcolorComputationNode = el;\n\t}\n\n\treturn colorComputationNode;\n}\n\n/**\n * @param {string | unknown} value\n *\n * @return {boolean} Whether the value is a valid color.\n */\nfunction isColor( value ) {\n\tif ( typeof value !== 'string' ) return false;\n\tconst test = tinycolor( value );\n\n\treturn test.isValid();\n}\n\n/**\n * Retrieves the computed background color. This is useful for getting the\n * value of a CSS variable color.\n *\n * @param {string | unknown} backgroundColor The background color to compute.\n *\n * @return {string} The computed background color.\n */\nfunction _getComputedBackgroundColor( backgroundColor ) {\n\tif ( typeof backgroundColor !== 'string' ) return '';\n\n\tif ( isColor( backgroundColor ) ) return backgroundColor;\n\n\tif ( ! backgroundColor.includes( 'var(' ) ) return '';\n\tif ( typeof document === 'undefined' ) return '';\n\n\t// Attempts to gracefully handle CSS variables color values.\n\tconst el = getColorComputationNode();\n\tif ( ! el ) return '';\n\n\tel.style.background = backgroundColor;\n\t// Grab the style\n\tconst computedColor = window?.getComputedStyle( el ).background;\n\t// Reset\n\tel.style.background = '';\n\n\treturn computedColor || '';\n}\n\nconst getComputedBackgroundColor = memoize( _getComputedBackgroundColor );\n\n/**\n * Get the text shade optimized for readability, based on a background color.\n *\n * @param {string | unknown} backgroundColor The background color.\n *\n * @return {string} The optimized text color (black or white).\n */\nexport function getOptimalTextColor( backgroundColor ) {\n\tconst background = getComputedBackgroundColor( backgroundColor );\n\tconst isReadableWithBlackText = tinycolor.isReadable(\n\t\tbackground,\n\t\t'#000000'\n\t);\n\n\treturn isReadableWithBlackText ? '#000000' : '#ffffff';\n}\n\n/**\n * Get the text shade optimized for readability, based on a background color.\n *\n * @param {string | unknown} backgroundColor The background color.\n *\n * @return {string} The optimized text shade (dark or light).\n */\nexport function getOptimalTextShade( backgroundColor ) {\n\tconst result = getOptimalTextColor( backgroundColor );\n\n\treturn result === '#000000' ? 'dark' : 'light';\n}\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/ui/utils/colors.js"],"names":["memoize","colord","extend","namesPlugin","colorComputationNode","getColorComputationNode","document","el","createElement","setAttribute","body","appendChild","isColor","value","test","isValid","_getComputedBackgroundColor","backgroundColor","includes","style","background","computedColor","window","getComputedStyle","getComputedBackgroundColor","getOptimalTextColor","isLight","getOptimalTextShade","result"],"mappings":"AAAA;AACA;AACA;AACA,OAAOA,OAAP,MAAoB,QAApB;AACA,SAASC,MAAT,EAAiBC,MAAjB,QAA+B,QAA/B;AACA,OAAOC,WAAP,MAAwB,sBAAxB;AAEA;;AACA,IAAIC,oBAAJ;AAEAF,MAAM,CAAE,CAAEC,WAAF,CAAF,CAAN;AAEA;AACA;AACA;;AACA,SAASE,uBAAT,GAAmC;AAClC,MAAK,OAAOC,QAAP,KAAoB,WAAzB,EAAuC;;AAEvC,MAAK,CAAEF,oBAAP,EAA8B;AAC7B;AACA,UAAMG,EAAE,GAAGD,QAAQ,CAACE,aAAT,CAAwB,KAAxB,CAAX;AACAD,IAAAA,EAAE,CAACE,YAAH,CAAiB,gCAAjB,EAAmD,EAAnD,EAH6B,CAI7B;;AACAH,IAAAA,QAAQ,CAACI,IAAT,CAAcC,WAAd,CAA2BJ,EAA3B;AACAH,IAAAA,oBAAoB,GAAGG,EAAvB;AACA;;AAED,SAAOH,oBAAP;AACA;AAED;AACA;AACA;AACA;AACA;;;AACA,SAASQ,OAAT,CAAkBC,KAAlB,EAA0B;AACzB,MAAK,OAAOA,KAAP,KAAiB,QAAtB,EAAiC,OAAO,KAAP;AACjC,QAAMC,IAAI,GAAGb,MAAM,CAAEY,KAAF,CAAnB;AAEA,SAAOC,IAAI,CAACC,OAAL,EAAP;AACA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACA,SAASC,2BAAT,CAAsCC,eAAtC,EAAwD;AAAA;;AACvD,MAAK,OAAOA,eAAP,KAA2B,QAAhC,EAA2C,OAAO,EAAP;AAE3C,MAAKL,OAAO,CAAEK,eAAF,CAAZ,EAAkC,OAAOA,eAAP;AAElC,MAAK,CAAEA,eAAe,CAACC,QAAhB,CAA0B,MAA1B,CAAP,EAA4C,OAAO,EAAP;AAC5C,MAAK,OAAOZ,QAAP,KAAoB,WAAzB,EAAuC,OAAO,EAAP,CANgB,CAQvD;;AACA,QAAMC,EAAE,GAAGF,uBAAuB,EAAlC;AACA,MAAK,CAAEE,EAAP,EAAY,OAAO,EAAP;AAEZA,EAAAA,EAAE,CAACY,KAAH,CAASC,UAAT,GAAsBH,eAAtB,CAZuD,CAavD;;AACA,QAAMI,aAAa,cAAGC,MAAH,4CAAG,QAAQC,gBAAR,CAA0BhB,EAA1B,EAA+Ba,UAArD,CAduD,CAevD;;AACAb,EAAAA,EAAE,CAACY,KAAH,CAASC,UAAT,GAAsB,EAAtB;AAEA,SAAOC,aAAa,IAAI,EAAxB;AACA;;AAED,MAAMG,0BAA0B,GAAGxB,OAAO,CAAEgB,2BAAF,CAA1C;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASS,mBAAT,CAA8BR,eAA9B,EAAgD;AACtD,QAAMG,UAAU,GAAGI,0BAA0B,CAAEP,eAAF,CAA7C;AAEA,SAAOhB,MAAM,CAAEmB,UAAF,CAAN,CAAqBM,OAArB,KAAiC,SAAjC,GAA6C,SAApD;AACA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASC,mBAAT,CAA8BV,eAA9B,EAAgD;AACtD,QAAMW,MAAM,GAAGH,mBAAmB,CAAER,eAAF,CAAlC;AAEA,SAAOW,MAAM,KAAK,SAAX,GAAuB,MAAvB,GAAgC,OAAvC;AACA","sourcesContent":["/**\n * External dependencies\n */\nimport memoize from 'memize';\nimport { colord, extend } from 'colord';\nimport namesPlugin from 'colord/plugins/names';\n\n/** @type {HTMLDivElement} */\nlet colorComputationNode;\n\nextend( [ namesPlugin ] );\n\n/**\n * @return {HTMLDivElement | undefined} The HTML element for color computation.\n */\nfunction getColorComputationNode() {\n\tif ( typeof document === 'undefined' ) return;\n\n\tif ( ! colorComputationNode ) {\n\t\t// Create a temporary element for style computation.\n\t\tconst el = document.createElement( 'div' );\n\t\tel.setAttribute( 'data-g2-color-computation-node', '' );\n\t\t// Inject for window computed style.\n\t\tdocument.body.appendChild( el );\n\t\tcolorComputationNode = el;\n\t}\n\n\treturn colorComputationNode;\n}\n\n/**\n * @param {string | unknown} value\n *\n * @return {boolean} Whether the value is a valid color.\n */\nfunction isColor( value ) {\n\tif ( typeof value !== 'string' ) return false;\n\tconst test = colord( value );\n\n\treturn test.isValid();\n}\n\n/**\n * Retrieves the computed background color. This is useful for getting the\n * value of a CSS variable color.\n *\n * @param {string | unknown} backgroundColor The background color to compute.\n *\n * @return {string} The computed background color.\n */\nfunction _getComputedBackgroundColor( backgroundColor ) {\n\tif ( typeof backgroundColor !== 'string' ) return '';\n\n\tif ( isColor( backgroundColor ) ) return backgroundColor;\n\n\tif ( ! backgroundColor.includes( 'var(' ) ) return '';\n\tif ( typeof document === 'undefined' ) return '';\n\n\t// Attempts to gracefully handle CSS variables color values.\n\tconst el = getColorComputationNode();\n\tif ( ! el ) return '';\n\n\tel.style.background = backgroundColor;\n\t// Grab the style\n\tconst computedColor = window?.getComputedStyle( el ).background;\n\t// Reset\n\tel.style.background = '';\n\n\treturn computedColor || '';\n}\n\nconst getComputedBackgroundColor = memoize( _getComputedBackgroundColor );\n\n/**\n * Get the text shade optimized for readability, based on a background color.\n *\n * @param {string | unknown} backgroundColor The background color.\n *\n * @return {string} The optimized text color (black or white).\n */\nexport function getOptimalTextColor( backgroundColor ) {\n\tconst background = getComputedBackgroundColor( backgroundColor );\n\n\treturn colord( background ).isLight() ? '#000000' : '#ffffff';\n}\n\n/**\n * Get the text shade optimized for readability, based on a background color.\n *\n * @param {string | unknown} backgroundColor The background color.\n *\n * @return {string} The optimized text shade (dark or light).\n */\nexport function getOptimalTextShade( backgroundColor ) {\n\tconst result = getOptimalTextColor( backgroundColor );\n\n\treturn result === '#000000' ? 'dark' : 'light';\n}\n"]}
@@ -1,3 +1,2 @@
1
1
  export { getOptimalTextShade } from './colors';
2
- export { createComponent } from './create-component';
3
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/ui/utils/index.js"],"names":["getOptimalTextShade","createComponent"],"mappings":"AAAA,SAASA,mBAAT,QAAoC,UAApC;AACA,SAASC,eAAT,QAAgC,oBAAhC","sourcesContent":["export { getOptimalTextShade } from './colors';\nexport { createComponent } from './create-component';\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/ui/utils/index.js"],"names":["getOptimalTextShade"],"mappings":"AAAA,SAASA,mBAAT,QAAoC,UAApC","sourcesContent":["export { getOptimalTextShade } from './colors';\n"]}
@@ -15,7 +15,7 @@ const GRID_BASE = '4px';
15
15
  */
16
16
 
17
17
  export function space(value) {
18
- var _CSS$supports, _CSS;
18
+ var _window$CSS, _window$CSS$supports;
19
19
 
20
20
  if (typeof value === 'undefined') {
21
21
  return undefined;
@@ -28,7 +28,7 @@ export function space(value) {
28
28
 
29
29
  const asInt = typeof value === 'number' ? value : Number(value); // test if the input has a unit, was NaN, or was one of the named CSS values (like `auto`), in which case just use that value
30
30
 
31
- if ((_CSS$supports = (_CSS = CSS).supports) !== null && _CSS$supports !== void 0 && _CSS$supports.call(_CSS, 'margin', value.toString()) || Number.isNaN(asInt)) {
31
+ if (typeof window !== 'undefined' && (_window$CSS = window.CSS) !== null && _window$CSS !== void 0 && (_window$CSS$supports = _window$CSS.supports) !== null && _window$CSS$supports !== void 0 && _window$CSS$supports.call(_window$CSS, 'margin', value.toString()) || Number.isNaN(asInt)) {
32
32
  return value.toString();
33
33
  }
34
34
 
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/ui/utils/space.ts"],"names":["GRID_BASE","space","value","undefined","asInt","Number","CSS","supports","toString","isNaN"],"mappings":"AAAA;AACA;AACA;AAGA,MAAMA,SAAS,GAAG,KAAlB;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASC,KAAT,CAAgBC,KAAhB,EAAyD;AAAA;;AAC/D,MAAK,OAAOA,KAAP,KAAiB,WAAtB,EAAoC;AACnC,WAAOC,SAAP;AACA,GAH8D,CAK/D;;;AACA,MAAK,CAAED,KAAP,EAAe;AACd,WAAO,GAAP;AACA;;AAED,QAAME,KAAK,GAAG,OAAOF,KAAP,KAAiB,QAAjB,GAA4BA,KAA5B,GAAoCG,MAAM,CAAEH,KAAF,CAAxD,CAV+D,CAY/D;;AACA,MACC,yBAAAI,GAAG,EAACC,QAAJ,mEAAgB,QAAhB,EAA0BL,KAAK,CAACM,QAAN,EAA1B,KACAH,MAAM,CAACI,KAAP,CAAcL,KAAd,CAFD,EAGE;AACD,WAAOF,KAAK,CAACM,QAAN,EAAP;AACA;;AAED,SAAQ,QAAQR,SAAW,MAAME,KAAO,GAAxC;AACA","sourcesContent":["/**\n * A real number or something parsable as a number\n */\nexport type SpaceInput = number | string;\n\nconst GRID_BASE = '4px';\n\n/**\n * A function that handles numbers, numeric strings, and unit values.\n *\n * When given a number or a numeric string, it will return the grid-based\n * value as a factor of GRID_BASE, defined above.\n *\n * When given a unit value or one of the named CSS values like `auto`,\n * it will simply return the value back.\n *\n * @param value A number, numeric string, or a unit value.\n */\nexport function space( value?: SpaceInput ): string | undefined {\n\tif ( typeof value === 'undefined' ) {\n\t\treturn undefined;\n\t}\n\n\t// handle empty strings, if it's the number 0 this still works\n\tif ( ! value ) {\n\t\treturn '0';\n\t}\n\n\tconst asInt = typeof value === 'number' ? value : Number( value );\n\n\t// test if the input has a unit, was NaN, or was one of the named CSS values (like `auto`), in which case just use that value\n\tif (\n\t\tCSS.supports?.( 'margin', value.toString() ) ||\n\t\tNumber.isNaN( asInt )\n\t) {\n\t\treturn value.toString();\n\t}\n\n\treturn `calc(${ GRID_BASE } * ${ value })`;\n}\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/ui/utils/space.ts"],"names":["GRID_BASE","space","value","undefined","asInt","Number","window","CSS","supports","toString","isNaN"],"mappings":"AAAA;AACA;AACA;AAGA,MAAMA,SAAS,GAAG,KAAlB;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASC,KAAT,CAAgBC,KAAhB,EAAyD;AAAA;;AAC/D,MAAK,OAAOA,KAAP,KAAiB,WAAtB,EAAoC;AACnC,WAAOC,SAAP;AACA,GAH8D,CAK/D;;;AACA,MAAK,CAAED,KAAP,EAAe;AACd,WAAO,GAAP;AACA;;AAED,QAAME,KAAK,GAAG,OAAOF,KAAP,KAAiB,QAAjB,GAA4BA,KAA5B,GAAoCG,MAAM,CAAEH,KAAF,CAAxD,CAV+D,CAY/D;;AACA,MACG,OAAOI,MAAP,KAAkB,WAAlB,mBACDA,MAAM,CAACC,GADN,gEACD,YAAYC,QADX,iDACD,uCAAwB,QAAxB,EAAkCN,KAAK,CAACO,QAAN,EAAlC,CADD,IAEAJ,MAAM,CAACK,KAAP,CAAcN,KAAd,CAHD,EAIE;AACD,WAAOF,KAAK,CAACO,QAAN,EAAP;AACA;;AAED,SAAQ,QAAQT,SAAW,MAAME,KAAO,GAAxC;AACA","sourcesContent":["/**\n * A real number or something parsable as a number\n */\nexport type SpaceInput = number | string;\n\nconst GRID_BASE = '4px';\n\n/**\n * A function that handles numbers, numeric strings, and unit values.\n *\n * When given a number or a numeric string, it will return the grid-based\n * value as a factor of GRID_BASE, defined above.\n *\n * When given a unit value or one of the named CSS values like `auto`,\n * it will simply return the value back.\n *\n * @param value A number, numeric string, or a unit value.\n */\nexport function space( value?: SpaceInput ): string | undefined {\n\tif ( typeof value === 'undefined' ) {\n\t\treturn undefined;\n\t}\n\n\t// handle empty strings, if it's the number 0 this still works\n\tif ( ! value ) {\n\t\treturn '0';\n\t}\n\n\tconst asInt = typeof value === 'number' ? value : Number( value );\n\n\t// test if the input has a unit, was NaN, or was one of the named CSS values (like `auto`), in which case just use that value\n\tif (\n\t\t( typeof window !== 'undefined' &&\n\t\t\twindow.CSS?.supports?.( 'margin', value.toString() ) ) ||\n\t\tNumber.isNaN( asInt )\n\t) {\n\t\treturn value.toString();\n\t}\n\n\treturn `calc(${ GRID_BASE } * ${ value })`;\n}\n"]}
@@ -31,16 +31,12 @@ export const useBreakpointIndex = (options = {}) => {
31
31
  onResize();
32
32
 
33
33
  if (typeof window !== 'undefined') {
34
- // Disable reason: We don't really care about what document we listen to, we just want to know that we're resizing.
35
-
36
- /* eslint-disable @wordpress/no-global-event-listener */
37
34
  window.addEventListener('resize', onResize);
38
35
  }
39
36
 
40
37
  return () => {
41
38
  if (typeof window !== 'undefined') {
42
39
  window.removeEventListener('resize', onResize);
43
- /* eslint-enable @wordpress/no-global-event-listener */
44
40
  }
45
41
  };
46
42
  }, [value]);
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/ui/utils/use-responsive-value.ts"],"names":["useEffect","useState","breakpoints","useBreakpointIndex","options","defaultIndex","TypeError","length","RangeError","value","setValue","getIndex","filter","bp","window","matchMedia","matches","onResize","newValue","addEventListener","removeEventListener","useResponsiveValue","values","index","Array","isArray","array"],"mappings":"AAAA;AACA;AACA;AACA,SAASA,SAAT,EAAoBC,QAApB,QAAoC,oBAApC;AAEA,MAAMC,WAAW,GAAG,CAAE,MAAF,EAAU,MAAV,EAAkB,MAAlB,CAApB;AAEA,OAAO,MAAMC,kBAAkB,GAAG,CACjCC,OAAkC,GAAG,EADJ,KAE7B;AACJ,QAAM;AAAEC,IAAAA,YAAY,GAAG;AAAjB,MAAuBD,OAA7B;;AAEA,MAAK,OAAOC,YAAP,KAAwB,QAA7B,EAAwC;AACvC,UAAM,IAAIC,SAAJ,CACJ,qDAAqDD,YAAc,KAAK,OAAOA,YAAc,EADzF,CAAN;AAGA,GAJD,MAIO,IAAKA,YAAY,GAAG,CAAf,IAAoBA,YAAY,GAAGH,WAAW,CAACK,MAAZ,GAAqB,CAA7D,EAAiE;AACvE,UAAM,IAAIC,UAAJ,CACJ,oDAAoDN,WAAW,CAACK,MAAQ,2BAA2BF,YAAc,EAD7G,CAAN;AAGA;;AAED,QAAM,CAAEI,KAAF,EAASC,QAAT,IAAsBT,QAAQ,CAAEI,YAAF,CAApC;AAEAL,EAAAA,SAAS,CAAE,MAAM;AAChB,UAAMW,QAAQ,GAAG,MAChBT,WAAW,CAACU,MAAZ,CAAsBC,EAAF,IAAU;AAC7B,aAAO,OAAOC,MAAP,KAAkB,WAAlB,GACJA,MAAM,CAACC,UAAP,CAAoB,0BAA0BF,EAAI,GAAlD,EACCG,OAFG,GAGJ,KAHH;AAIA,KALD,EAKIT,MANL;;AAQA,UAAMU,QAAQ,GAAG,MAAM;AACtB,YAAMC,QAAQ,GAAGP,QAAQ,EAAzB;;AACA,UAAKF,KAAK,KAAKS,QAAf,EAA0B;AACzBR,QAAAA,QAAQ,CAAEQ,QAAF,CAAR;AACA;AACD,KALD;;AAOAD,IAAAA,QAAQ;;AAER,QAAK,OAAOH,MAAP,KAAkB,WAAvB,EAAqC;AACpC;;AACA;AACAA,MAAAA,MAAM,CAACK,gBAAP,CAAyB,QAAzB,EAAmCF,QAAnC;AACA;;AACD,WAAO,MAAM;AACZ,UAAK,OAAOH,MAAP,KAAkB,WAAvB,EAAqC;AACpCA,QAAAA,MAAM,CAACM,mBAAP,CAA4B,QAA5B,EAAsCH,QAAtC;AACA;AACA;AACD,KALD;AAMA,GA7BQ,EA6BN,CAAER,KAAF,CA7BM,CAAT;AA+BA,SAAOA,KAAP;AACA,CAjDM;AAmDP,OAAO,SAASY,kBAAT,CACNC,MADM,EAENlB,OAAqD,GAAG,EAFlD,EAGU;AAChB,QAAMmB,KAAK,GAAGpB,kBAAkB,CAAEC,OAAF,CAAhC,CADgB,CAGhB;;AACA,MAAK,CAAEoB,KAAK,CAACC,OAAN,CAAeH,MAAf,CAAF,IAA6B,OAAOA,MAAP,KAAkB,UAApD,EACC,OAAOA,MAAP;AAED,QAAMI,KAAK,GAAGJ,MAAM,IAAI,EAAxB;AAEA;;AACA;AAAO;AAAmBI,IAAAA,KAAK;AAC9B;AACAH,IAAAA,KAAK,IAAIG,KAAK,CAACnB,MAAf,GAAwBmB,KAAK,CAACnB,MAAN,GAAe,CAAvC,GAA2CgB,KAFb;AAA/B;AAIA","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { useEffect, useState } from '@wordpress/element';\n\nconst breakpoints = [ '40em', '52em', '64em' ];\n\nexport const useBreakpointIndex = (\n\toptions: { defaultIndex?: number } = {}\n) => {\n\tconst { defaultIndex = 0 } = options;\n\n\tif ( typeof defaultIndex !== 'number' ) {\n\t\tthrow new TypeError(\n\t\t\t`Default breakpoint index should be a number. Got: ${ defaultIndex }, ${ typeof defaultIndex }`\n\t\t);\n\t} else if ( defaultIndex < 0 || defaultIndex > breakpoints.length - 1 ) {\n\t\tthrow new RangeError(\n\t\t\t`Default breakpoint index out of range. Theme has ${ breakpoints.length } breakpoints, got index ${ defaultIndex }`\n\t\t);\n\t}\n\n\tconst [ value, setValue ] = useState( defaultIndex );\n\n\tuseEffect( () => {\n\t\tconst getIndex = () =>\n\t\t\tbreakpoints.filter( ( bp ) => {\n\t\t\t\treturn typeof window !== 'undefined'\n\t\t\t\t\t? window.matchMedia( `screen and (min-width: ${ bp })` )\n\t\t\t\t\t\t\t.matches\n\t\t\t\t\t: false;\n\t\t\t} ).length;\n\n\t\tconst onResize = () => {\n\t\t\tconst newValue = getIndex();\n\t\t\tif ( value !== newValue ) {\n\t\t\t\tsetValue( newValue );\n\t\t\t}\n\t\t};\n\n\t\tonResize();\n\n\t\tif ( typeof window !== 'undefined' ) {\n\t\t\t// Disable reason: We don't really care about what document we listen to, we just want to know that we're resizing.\n\t\t\t/* eslint-disable @wordpress/no-global-event-listener */\n\t\t\twindow.addEventListener( 'resize', onResize );\n\t\t}\n\t\treturn () => {\n\t\t\tif ( typeof window !== 'undefined' ) {\n\t\t\t\twindow.removeEventListener( 'resize', onResize );\n\t\t\t\t/* eslint-enable @wordpress/no-global-event-listener */\n\t\t\t}\n\t\t};\n\t}, [ value ] );\n\n\treturn value;\n};\n\nexport function useResponsiveValue< T >(\n\tvalues: ( T | undefined )[],\n\toptions: Parameters< typeof useBreakpointIndex >[ 0 ] = {}\n): T | undefined {\n\tconst index = useBreakpointIndex( options );\n\n\t// Allow calling the function with a \"normal\" value without having to check on the outside.\n\tif ( ! Array.isArray( values ) && typeof values !== 'function' )\n\t\treturn values;\n\n\tconst array = values || [];\n\n\t/* eslint-disable jsdoc/no-undefined-types */\n\treturn /** @type {T[]} */ array[\n\t\t/* eslint-enable jsdoc/no-undefined-types */\n\t\tindex >= array.length ? array.length - 1 : index\n\t];\n}\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/ui/utils/use-responsive-value.ts"],"names":["useEffect","useState","breakpoints","useBreakpointIndex","options","defaultIndex","TypeError","length","RangeError","value","setValue","getIndex","filter","bp","window","matchMedia","matches","onResize","newValue","addEventListener","removeEventListener","useResponsiveValue","values","index","Array","isArray","array"],"mappings":"AAAA;AACA;AACA;AACA,SAASA,SAAT,EAAoBC,QAApB,QAAoC,oBAApC;AAEA,MAAMC,WAAW,GAAG,CAAE,MAAF,EAAU,MAAV,EAAkB,MAAlB,CAApB;AAEA,OAAO,MAAMC,kBAAkB,GAAG,CACjCC,OAAkC,GAAG,EADJ,KAE7B;AACJ,QAAM;AAAEC,IAAAA,YAAY,GAAG;AAAjB,MAAuBD,OAA7B;;AAEA,MAAK,OAAOC,YAAP,KAAwB,QAA7B,EAAwC;AACvC,UAAM,IAAIC,SAAJ,CACJ,qDAAqDD,YAAc,KAAK,OAAOA,YAAc,EADzF,CAAN;AAGA,GAJD,MAIO,IAAKA,YAAY,GAAG,CAAf,IAAoBA,YAAY,GAAGH,WAAW,CAACK,MAAZ,GAAqB,CAA7D,EAAiE;AACvE,UAAM,IAAIC,UAAJ,CACJ,oDAAoDN,WAAW,CAACK,MAAQ,2BAA2BF,YAAc,EAD7G,CAAN;AAGA;;AAED,QAAM,CAAEI,KAAF,EAASC,QAAT,IAAsBT,QAAQ,CAAEI,YAAF,CAApC;AAEAL,EAAAA,SAAS,CAAE,MAAM;AAChB,UAAMW,QAAQ,GAAG,MAChBT,WAAW,CAACU,MAAZ,CAAsBC,EAAF,IAAU;AAC7B,aAAO,OAAOC,MAAP,KAAkB,WAAlB,GACJA,MAAM,CAACC,UAAP,CAAoB,0BAA0BF,EAAI,GAAlD,EACCG,OAFG,GAGJ,KAHH;AAIA,KALD,EAKIT,MANL;;AAQA,UAAMU,QAAQ,GAAG,MAAM;AACtB,YAAMC,QAAQ,GAAGP,QAAQ,EAAzB;;AACA,UAAKF,KAAK,KAAKS,QAAf,EAA0B;AACzBR,QAAAA,QAAQ,CAAEQ,QAAF,CAAR;AACA;AACD,KALD;;AAOAD,IAAAA,QAAQ;;AAER,QAAK,OAAOH,MAAP,KAAkB,WAAvB,EAAqC;AACpCA,MAAAA,MAAM,CAACK,gBAAP,CAAyB,QAAzB,EAAmCF,QAAnC;AACA;;AACD,WAAO,MAAM;AACZ,UAAK,OAAOH,MAAP,KAAkB,WAAvB,EAAqC;AACpCA,QAAAA,MAAM,CAACM,mBAAP,CAA4B,QAA5B,EAAsCH,QAAtC;AACA;AACD,KAJD;AAKA,GA1BQ,EA0BN,CAAER,KAAF,CA1BM,CAAT;AA4BA,SAAOA,KAAP;AACA,CA9CM;AAgDP,OAAO,SAASY,kBAAT,CACNC,MADM,EAENlB,OAAqD,GAAG,EAFlD,EAGU;AAChB,QAAMmB,KAAK,GAAGpB,kBAAkB,CAAEC,OAAF,CAAhC,CADgB,CAGhB;;AACA,MAAK,CAAEoB,KAAK,CAACC,OAAN,CAAeH,MAAf,CAAF,IAA6B,OAAOA,MAAP,KAAkB,UAApD,EACC,OAAOA,MAAP;AAED,QAAMI,KAAK,GAAGJ,MAAM,IAAI,EAAxB;AAEA;;AACA;AAAO;AAAmBI,IAAAA,KAAK;AAC9B;AACAH,IAAAA,KAAK,IAAIG,KAAK,CAACnB,MAAf,GAAwBmB,KAAK,CAACnB,MAAN,GAAe,CAAvC,GAA2CgB,KAFb;AAA/B;AAIA","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { useEffect, useState } from '@wordpress/element';\n\nconst breakpoints = [ '40em', '52em', '64em' ];\n\nexport const useBreakpointIndex = (\n\toptions: { defaultIndex?: number } = {}\n) => {\n\tconst { defaultIndex = 0 } = options;\n\n\tif ( typeof defaultIndex !== 'number' ) {\n\t\tthrow new TypeError(\n\t\t\t`Default breakpoint index should be a number. Got: ${ defaultIndex }, ${ typeof defaultIndex }`\n\t\t);\n\t} else if ( defaultIndex < 0 || defaultIndex > breakpoints.length - 1 ) {\n\t\tthrow new RangeError(\n\t\t\t`Default breakpoint index out of range. Theme has ${ breakpoints.length } breakpoints, got index ${ defaultIndex }`\n\t\t);\n\t}\n\n\tconst [ value, setValue ] = useState( defaultIndex );\n\n\tuseEffect( () => {\n\t\tconst getIndex = () =>\n\t\t\tbreakpoints.filter( ( bp ) => {\n\t\t\t\treturn typeof window !== 'undefined'\n\t\t\t\t\t? window.matchMedia( `screen and (min-width: ${ bp })` )\n\t\t\t\t\t\t\t.matches\n\t\t\t\t\t: false;\n\t\t\t} ).length;\n\n\t\tconst onResize = () => {\n\t\t\tconst newValue = getIndex();\n\t\t\tif ( value !== newValue ) {\n\t\t\t\tsetValue( newValue );\n\t\t\t}\n\t\t};\n\n\t\tonResize();\n\n\t\tif ( typeof window !== 'undefined' ) {\n\t\t\twindow.addEventListener( 'resize', onResize );\n\t\t}\n\t\treturn () => {\n\t\t\tif ( typeof window !== 'undefined' ) {\n\t\t\t\twindow.removeEventListener( 'resize', onResize );\n\t\t\t}\n\t\t};\n\t}, [ value ] );\n\n\treturn value;\n};\n\nexport function useResponsiveValue< T >(\n\tvalues: ( T | undefined )[],\n\toptions: Parameters< typeof useBreakpointIndex >[ 0 ] = {}\n): T | undefined {\n\tconst index = useBreakpointIndex( options );\n\n\t// Allow calling the function with a \"normal\" value without having to check on the outside.\n\tif ( ! Array.isArray( values ) && typeof values !== 'function' )\n\t\treturn values;\n\n\tconst array = values || [];\n\n\t/* eslint-disable jsdoc/no-undefined-types */\n\treturn /** @type {T[]} */ array[\n\t\t/* eslint-enable jsdoc/no-undefined-types */\n\t\tindex >= array.length ? array.length - 1 : index\n\t];\n}\n"]}
@@ -4,13 +4,14 @@ import { createElement } from "@wordpress/element";
4
4
  /**
5
5
  * External dependencies
6
6
  */
7
+ // eslint-disable-next-line no-restricted-imports
7
8
  import { noop, omit } from 'lodash';
8
9
  import classnames from 'classnames';
9
10
  /**
10
11
  * WordPress dependencies
11
12
  */
12
13
 
13
- import { forwardRef, useRef } from '@wordpress/element';
14
+ import { forwardRef, useMemo, useRef } from '@wordpress/element';
14
15
  import { __ } from '@wordpress/i18n';
15
16
  import { ENTER } from '@wordpress/keycodes';
16
17
  /**
@@ -21,7 +22,7 @@ import * as inputControlActionTypes from '../input-control/reducer/actions';
21
22
  import { composeStateReducers } from '../input-control/reducer/reducer';
22
23
  import { Root, ValueInput } from './styles/unit-control-styles';
23
24
  import UnitSelectControl from './unit-select-control';
24
- import { CSS_UNITS, getParsedValue, getValidParsedUnit } from './utils';
25
+ import { CSS_UNITS, getParsedValue, getUnitsWithCurrentUnit, getValidParsedUnit } from './utils';
25
26
  import { useControlledState } from '../utils/hooks';
26
27
 
27
28
  function UnitControl({
@@ -39,13 +40,15 @@ function UnitControl({
39
40
  size = 'default',
40
41
  style,
41
42
  unit: unitProp,
42
- units = CSS_UNITS,
43
+ units: unitsProp = CSS_UNITS,
43
44
  value: valueProp,
44
45
  ...props
45
- }, ref) {
46
+ }, forwardedRef) {
47
+ const units = useMemo(() => getUnitsWithCurrentUnit(valueProp, unitProp, unitsProp), [valueProp, unitProp, unitsProp]);
46
48
  const [value, initialUnit] = getParsedValue(valueProp, unitProp, units);
47
49
  const [unit, setUnit] = useControlledState(unitProp, {
48
- initial: initialUnit
50
+ initial: initialUnit,
51
+ fallback: ''
49
52
  }); // Stores parsed value for hand-off in state reducer
50
53
 
51
54
  const refParsedValue = useRef(null);
@@ -82,16 +85,16 @@ function UnitControl({
82
85
  };
83
86
 
84
87
  const mayUpdateUnit = event => {
85
- if (!isNaN(event.target.value)) {
88
+ if (!isNaN(Number(event.currentTarget.value))) {
86
89
  refParsedValue.current = null;
87
90
  return;
88
91
  }
89
92
 
90
- const [parsedValue, parsedUnit] = getValidParsedUnit(event.target.value, units, value, unit);
91
- refParsedValue.current = parsedValue;
93
+ const [parsedValue, parsedUnit] = getValidParsedUnit(event.currentTarget.value, units, value, unit);
94
+ refParsedValue.current = parsedValue.toString();
92
95
 
93
96
  if (isPressEnterToChange && parsedUnit !== unit) {
94
- const data = units.find(option => option.value === parsedUnit);
97
+ const data = Array.isArray(units) ? units.find(option => option.value === parsedUnit) : undefined;
95
98
  const changeProps = {
96
99
  event,
97
100
  data
@@ -118,9 +121,9 @@ function UnitControl({
118
121
  * This allows us to tap into actions to transform the (next) state for
119
122
  * InputControl.
120
123
  *
121
- * @param {Object} state State from InputControl
122
- * @param {Object} action Action triggering state change
123
- * @return {Object} The updated state to apply to InputControl
124
+ * @param state State from InputControl
125
+ * @param action Action triggering state change
126
+ * @return The updated state to apply to InputControl
124
127
  */
125
128
 
126
129
 
@@ -143,11 +146,11 @@ function UnitControl({
143
146
  const inputSuffix = !disableUnits ? createElement(UnitSelectControl, {
144
147
  "aria-label": __('Select unit'),
145
148
  disabled: disabled,
146
- isTabbable: isUnitSelectTabbable,
147
- options: units,
149
+ isUnitSelectTabbable: isUnitSelectTabbable,
148
150
  onChange: handleOnUnitChange,
149
151
  size: size,
150
- value: unit
152
+ unit: unit,
153
+ units: units
151
154
  }) : null;
152
155
  let step = props.step;
153
156
  /*
@@ -178,7 +181,7 @@ function UnitControl({
178
181
  onBlur: handleOnBlur,
179
182
  onKeyDown: handleOnKeyDown,
180
183
  onChange: handleOnChange,
181
- ref: ref,
184
+ ref: forwardedRef,
182
185
  size: size,
183
186
  suffix: inputSuffix,
184
187
  value: value,
@@ -186,6 +189,23 @@ function UnitControl({
186
189
  __unstableStateReducer: composeStateReducers(unitControlStateReducer, stateReducer)
187
190
  })));
188
191
  }
192
+ /**
193
+ * `UnitControl` allows the user to set a value as well as a unit (e.g. `px`).
194
+ *
195
+ *
196
+ * @example
197
+ * ```jsx
198
+ * import { __experimentalUnitControl as UnitControl } from '@wordpress/components';
199
+ * import { useState } from '@wordpress/element';
200
+ *
201
+ * const Example = () => {
202
+ * const [ value, setValue ] = useState( '10px' );
203
+ *
204
+ * return <UnitControl onChange={ setValue } value={ value } />;
205
+ * };
206
+ * ```
207
+ */
208
+
189
209
 
190
210
  const ForwardedUnitControl = forwardRef(UnitControl);
191
211
  export { parseUnit, useCustomUnits } from './utils';
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/unit-control/index.js"],"names":["noop","omit","classnames","forwardRef","useRef","__","ENTER","inputControlActionTypes","composeStateReducers","Root","ValueInput","UnitSelectControl","CSS_UNITS","getParsedValue","getValidParsedUnit","useControlledState","UnitControl","__unstableStateReducer","stateReducer","state","autoComplete","className","disabled","disableUnits","isPressEnterToChange","isResetValueOnUnitChange","isUnitSelectTabbable","label","onChange","onUnitChange","size","style","unit","unitProp","units","value","valueProp","props","ref","initialUnit","setUnit","initial","refParsedValue","classes","handleOnChange","next","changeProps","join","handleOnUnitChange","data","nextValue","default","undefined","mayUpdateUnit","event","isNaN","target","current","parsedValue","parsedUnit","find","option","handleOnBlur","handleOnKeyDown","keyCode","unitControlStateReducer","action","type","COMMIT","inputSuffix","step","activeUnit","ForwardedUnitControl","parseUnit","useCustomUnits"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { noop, omit } from 'lodash';\nimport classnames from 'classnames';\n\n/**\n * WordPress dependencies\n */\nimport { forwardRef, useRef } from '@wordpress/element';\nimport { __ } from '@wordpress/i18n';\nimport { ENTER } from '@wordpress/keycodes';\n\n/**\n * Internal dependencies\n */\nimport * as inputControlActionTypes from '../input-control/reducer/actions';\nimport { composeStateReducers } from '../input-control/reducer/reducer';\nimport { Root, ValueInput } from './styles/unit-control-styles';\nimport UnitSelectControl from './unit-select-control';\nimport { CSS_UNITS, getParsedValue, getValidParsedUnit } from './utils';\nimport { useControlledState } from '../utils/hooks';\n\nfunction UnitControl(\n\t{\n\t\t__unstableStateReducer: stateReducer = ( state ) => state,\n\t\tautoComplete = 'off',\n\t\tclassName,\n\t\tdisabled = false,\n\t\tdisableUnits = false,\n\t\tisPressEnterToChange = false,\n\t\tisResetValueOnUnitChange = false,\n\t\tisUnitSelectTabbable = true,\n\t\tlabel,\n\t\tonChange = noop,\n\t\tonUnitChange = noop,\n\t\tsize = 'default',\n\t\tstyle,\n\t\tunit: unitProp,\n\t\tunits = CSS_UNITS,\n\t\tvalue: valueProp,\n\t\t...props\n\t},\n\tref\n) {\n\tconst [ value, initialUnit ] = getParsedValue( valueProp, unitProp, units );\n\tconst [ unit, setUnit ] = useControlledState( unitProp, {\n\t\tinitial: initialUnit,\n\t} );\n\n\t// Stores parsed value for hand-off in state reducer\n\tconst refParsedValue = useRef( null );\n\n\tconst classes = classnames( 'components-unit-control', className );\n\n\tconst handleOnChange = ( next, changeProps ) => {\n\t\tif ( next === '' ) {\n\t\t\tonChange( '', changeProps );\n\t\t\treturn;\n\t\t}\n\n\t\t/*\n\t\t * Customizing the onChange callback.\n\t\t * This allows as to broadcast a combined value+unit to onChange.\n\t\t */\n\t\tnext = getValidParsedUnit( next, units, value, unit ).join( '' );\n\n\t\tonChange( next, changeProps );\n\t};\n\n\tconst handleOnUnitChange = ( next, changeProps ) => {\n\t\tconst { data } = changeProps;\n\n\t\tlet nextValue = `${ value }${ next }`;\n\n\t\tif ( isResetValueOnUnitChange && data?.default !== undefined ) {\n\t\t\tnextValue = `${ data.default }${ next }`;\n\t\t}\n\n\t\tonChange( nextValue, changeProps );\n\t\tonUnitChange( next, changeProps );\n\n\t\tsetUnit( next );\n\t};\n\n\tconst mayUpdateUnit = ( event ) => {\n\t\tif ( ! isNaN( event.target.value ) ) {\n\t\t\trefParsedValue.current = null;\n\t\t\treturn;\n\t\t}\n\t\tconst [ parsedValue, parsedUnit ] = getValidParsedUnit(\n\t\t\tevent.target.value,\n\t\t\tunits,\n\t\t\tvalue,\n\t\t\tunit\n\t\t);\n\n\t\trefParsedValue.current = parsedValue;\n\n\t\tif ( isPressEnterToChange && parsedUnit !== unit ) {\n\t\t\tconst data = units.find(\n\t\t\t\t( option ) => option.value === parsedUnit\n\t\t\t);\n\t\t\tconst changeProps = { event, data };\n\n\t\t\tonChange( `${ parsedValue }${ parsedUnit }`, changeProps );\n\t\t\tonUnitChange( parsedUnit, changeProps );\n\n\t\t\tsetUnit( parsedUnit );\n\t\t}\n\t};\n\n\tconst handleOnBlur = mayUpdateUnit;\n\n\tconst handleOnKeyDown = ( event ) => {\n\t\tconst { keyCode } = event;\n\t\tif ( keyCode === ENTER ) {\n\t\t\tmayUpdateUnit( event );\n\t\t}\n\t};\n\n\t/**\n\t * \"Middleware\" function that intercepts updates from InputControl.\n\t * This allows us to tap into actions to transform the (next) state for\n\t * InputControl.\n\t *\n\t * @param {Object} state State from InputControl\n\t * @param {Object} action Action triggering state change\n\t * @return {Object} The updated state to apply to InputControl\n\t */\n\tconst unitControlStateReducer = ( state, action ) => {\n\t\t/*\n\t\t * On commits (when pressing ENTER and on blur if\n\t\t * isPressEnterToChange is true), if a parse has been performed\n\t\t * then use that result to update the state.\n\t\t */\n\t\tif ( action.type === inputControlActionTypes.COMMIT ) {\n\t\t\tif ( refParsedValue.current !== null ) {\n\t\t\t\tstate.value = refParsedValue.current;\n\t\t\t\trefParsedValue.current = null;\n\t\t\t}\n\t\t}\n\n\t\treturn state;\n\t};\n\n\tconst inputSuffix = ! disableUnits ? (\n\t\t<UnitSelectControl\n\t\t\taria-label={ __( 'Select unit' ) }\n\t\t\tdisabled={ disabled }\n\t\t\tisTabbable={ isUnitSelectTabbable }\n\t\t\toptions={ units }\n\t\t\tonChange={ handleOnUnitChange }\n\t\t\tsize={ size }\n\t\t\tvalue={ unit }\n\t\t/>\n\t) : null;\n\n\tlet step = props.step;\n\n\t/*\n\t * If no step prop has been passed, lookup the active unit and\n\t * try to get step from `units`, or default to a value of `1`\n\t */\n\tif ( ! step && units ) {\n\t\tconst activeUnit = units.find( ( option ) => option.value === unit );\n\t\tstep = activeUnit?.step ?? 1;\n\t}\n\n\treturn (\n\t\t<Root className=\"components-unit-control-wrapper\" style={ style }>\n\t\t\t<ValueInput\n\t\t\t\taria-label={ label }\n\t\t\t\ttype={ isPressEnterToChange ? 'text' : 'number' }\n\t\t\t\t{ ...omit( props, [ 'children' ] ) }\n\t\t\t\tautoComplete={ autoComplete }\n\t\t\t\tclassName={ classes }\n\t\t\t\tdisabled={ disabled }\n\t\t\t\tdisableUnits={ disableUnits }\n\t\t\t\tisPressEnterToChange={ isPressEnterToChange }\n\t\t\t\tlabel={ label }\n\t\t\t\tonBlur={ handleOnBlur }\n\t\t\t\tonKeyDown={ handleOnKeyDown }\n\t\t\t\tonChange={ handleOnChange }\n\t\t\t\tref={ ref }\n\t\t\t\tsize={ size }\n\t\t\t\tsuffix={ inputSuffix }\n\t\t\t\tvalue={ value }\n\t\t\t\tstep={ step }\n\t\t\t\t__unstableStateReducer={ composeStateReducers(\n\t\t\t\t\tunitControlStateReducer,\n\t\t\t\t\tstateReducer\n\t\t\t\t) }\n\t\t\t/>\n\t\t</Root>\n\t);\n}\n\nconst ForwardedUnitControl = forwardRef( UnitControl );\n\nexport { parseUnit, useCustomUnits } from './utils';\nexport default ForwardedUnitControl;\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/unit-control/index.tsx"],"names":["noop","omit","classnames","forwardRef","useMemo","useRef","__","ENTER","inputControlActionTypes","composeStateReducers","Root","ValueInput","UnitSelectControl","CSS_UNITS","getParsedValue","getUnitsWithCurrentUnit","getValidParsedUnit","useControlledState","UnitControl","__unstableStateReducer","stateReducer","state","autoComplete","className","disabled","disableUnits","isPressEnterToChange","isResetValueOnUnitChange","isUnitSelectTabbable","label","onChange","onUnitChange","size","style","unit","unitProp","units","unitsProp","value","valueProp","props","forwardedRef","initialUnit","setUnit","initial","fallback","refParsedValue","classes","handleOnChange","next","changeProps","join","handleOnUnitChange","data","nextValue","default","undefined","mayUpdateUnit","event","isNaN","Number","currentTarget","current","parsedValue","parsedUnit","toString","Array","isArray","find","option","handleOnBlur","handleOnKeyDown","keyCode","unitControlStateReducer","action","type","COMMIT","inputSuffix","step","activeUnit","ForwardedUnitControl","parseUnit","useCustomUnits"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\n// eslint-disable-next-line no-restricted-imports\nimport type {\n\tFocusEventHandler,\n\tKeyboardEvent,\n\tRef,\n\tSyntheticEvent,\n} from 'react';\nimport { noop, omit } from 'lodash';\nimport classnames from 'classnames';\n\n/**\n * WordPress dependencies\n */\nimport { forwardRef, useMemo, useRef } from '@wordpress/element';\nimport { __ } from '@wordpress/i18n';\nimport { ENTER } from '@wordpress/keycodes';\n\n/**\n * Internal dependencies\n */\nimport type { WordPressComponentProps } from '../ui/context';\nimport * as inputControlActionTypes from '../input-control/reducer/actions';\nimport { composeStateReducers } from '../input-control/reducer/reducer';\nimport { Root, ValueInput } from './styles/unit-control-styles';\nimport UnitSelectControl from './unit-select-control';\nimport {\n\tCSS_UNITS,\n\tgetParsedValue,\n\tgetUnitsWithCurrentUnit,\n\tgetValidParsedUnit,\n} from './utils';\nimport { useControlledState } from '../utils/hooks';\nimport type { UnitControlProps, UnitControlOnChangeCallback } from './types';\nimport type { StateReducer } from '../input-control/reducer/state';\n\nfunction UnitControl(\n\t{\n\t\t__unstableStateReducer: stateReducer = ( state ) => state,\n\t\tautoComplete = 'off',\n\t\tclassName,\n\t\tdisabled = false,\n\t\tdisableUnits = false,\n\t\tisPressEnterToChange = false,\n\t\tisResetValueOnUnitChange = false,\n\t\tisUnitSelectTabbable = true,\n\t\tlabel,\n\t\tonChange = noop,\n\t\tonUnitChange = noop,\n\t\tsize = 'default',\n\t\tstyle,\n\t\tunit: unitProp,\n\t\tunits: unitsProp = CSS_UNITS,\n\t\tvalue: valueProp,\n\t\t...props\n\t}: WordPressComponentProps< UnitControlProps, 'input', false >,\n\tforwardedRef: Ref< any >\n) {\n\tconst units = useMemo(\n\t\t() => getUnitsWithCurrentUnit( valueProp, unitProp, unitsProp ),\n\t\t[ valueProp, unitProp, unitsProp ]\n\t);\n\tconst [ value, initialUnit ] = getParsedValue( valueProp, unitProp, units );\n\tconst [ unit, setUnit ] = useControlledState< string | undefined >(\n\t\tunitProp,\n\t\t{\n\t\t\tinitial: initialUnit,\n\t\t\tfallback: '',\n\t\t}\n\t);\n\n\t// Stores parsed value for hand-off in state reducer\n\tconst refParsedValue = useRef< string | null >( null );\n\n\tconst classes = classnames( 'components-unit-control', className );\n\n\tconst handleOnChange: UnitControlOnChangeCallback = (\n\t\tnext,\n\t\tchangeProps\n\t) => {\n\t\tif ( next === '' ) {\n\t\t\tonChange( '', changeProps );\n\t\t\treturn;\n\t\t}\n\n\t\t/*\n\t\t * Customizing the onChange callback.\n\t\t * This allows as to broadcast a combined value+unit to onChange.\n\t\t */\n\t\tnext = getValidParsedUnit( next, units, value, unit ).join( '' );\n\n\t\tonChange( next, changeProps );\n\t};\n\n\tconst handleOnUnitChange: UnitControlOnChangeCallback = (\n\t\tnext,\n\t\tchangeProps\n\t) => {\n\t\tconst { data } = changeProps;\n\n\t\tlet nextValue = `${ value }${ next }`;\n\n\t\tif ( isResetValueOnUnitChange && data?.default !== undefined ) {\n\t\t\tnextValue = `${ data.default }${ next }`;\n\t\t}\n\n\t\tonChange( nextValue, changeProps );\n\t\tonUnitChange( next, changeProps );\n\n\t\tsetUnit( next );\n\t};\n\n\tconst mayUpdateUnit = ( event: SyntheticEvent< HTMLInputElement > ) => {\n\t\tif ( ! isNaN( Number( event.currentTarget.value ) ) ) {\n\t\t\trefParsedValue.current = null;\n\t\t\treturn;\n\t\t}\n\t\tconst [ parsedValue, parsedUnit ] = getValidParsedUnit(\n\t\t\tevent.currentTarget.value,\n\t\t\tunits,\n\t\t\tvalue,\n\t\t\tunit\n\t\t);\n\n\t\trefParsedValue.current = parsedValue.toString();\n\n\t\tif ( isPressEnterToChange && parsedUnit !== unit ) {\n\t\t\tconst data = Array.isArray( units )\n\t\t\t\t? units.find( ( option ) => option.value === parsedUnit )\n\t\t\t\t: undefined;\n\t\t\tconst changeProps = { event, data };\n\n\t\t\tonChange( `${ parsedValue }${ parsedUnit }`, changeProps );\n\t\t\tonUnitChange( parsedUnit, changeProps );\n\n\t\t\tsetUnit( parsedUnit );\n\t\t}\n\t};\n\n\tconst handleOnBlur: FocusEventHandler< HTMLInputElement > = mayUpdateUnit;\n\n\tconst handleOnKeyDown = ( event: KeyboardEvent< HTMLInputElement > ) => {\n\t\tconst { keyCode } = event;\n\t\tif ( keyCode === ENTER ) {\n\t\t\tmayUpdateUnit( event );\n\t\t}\n\t};\n\n\t/**\n\t * \"Middleware\" function that intercepts updates from InputControl.\n\t * This allows us to tap into actions to transform the (next) state for\n\t * InputControl.\n\t *\n\t * @param state State from InputControl\n\t * @param action Action triggering state change\n\t * @return The updated state to apply to InputControl\n\t */\n\tconst unitControlStateReducer: StateReducer = ( state, action ) => {\n\t\t/*\n\t\t * On commits (when pressing ENTER and on blur if\n\t\t * isPressEnterToChange is true), if a parse has been performed\n\t\t * then use that result to update the state.\n\t\t */\n\t\tif ( action.type === inputControlActionTypes.COMMIT ) {\n\t\t\tif ( refParsedValue.current !== null ) {\n\t\t\t\tstate.value = refParsedValue.current;\n\t\t\t\trefParsedValue.current = null;\n\t\t\t}\n\t\t}\n\n\t\treturn state;\n\t};\n\n\tconst inputSuffix = ! disableUnits ? (\n\t\t<UnitSelectControl\n\t\t\taria-label={ __( 'Select unit' ) }\n\t\t\tdisabled={ disabled }\n\t\t\tisUnitSelectTabbable={ isUnitSelectTabbable }\n\t\t\tonChange={ handleOnUnitChange }\n\t\t\tsize={ size }\n\t\t\tunit={ unit }\n\t\t\tunits={ units }\n\t\t/>\n\t) : null;\n\n\tlet step = props.step;\n\n\t/*\n\t * If no step prop has been passed, lookup the active unit and\n\t * try to get step from `units`, or default to a value of `1`\n\t */\n\tif ( ! step && units ) {\n\t\tconst activeUnit = units.find( ( option ) => option.value === unit );\n\t\tstep = activeUnit?.step ?? 1;\n\t}\n\n\treturn (\n\t\t<Root className=\"components-unit-control-wrapper\" style={ style }>\n\t\t\t<ValueInput\n\t\t\t\taria-label={ label }\n\t\t\t\ttype={ isPressEnterToChange ? 'text' : 'number' }\n\t\t\t\t{ ...omit( props, [ 'children' ] ) }\n\t\t\t\tautoComplete={ autoComplete }\n\t\t\t\tclassName={ classes }\n\t\t\t\tdisabled={ disabled }\n\t\t\t\tdisableUnits={ disableUnits }\n\t\t\t\tisPressEnterToChange={ isPressEnterToChange }\n\t\t\t\tlabel={ label }\n\t\t\t\tonBlur={ handleOnBlur }\n\t\t\t\tonKeyDown={ handleOnKeyDown }\n\t\t\t\tonChange={ handleOnChange }\n\t\t\t\tref={ forwardedRef }\n\t\t\t\tsize={ size }\n\t\t\t\tsuffix={ inputSuffix }\n\t\t\t\tvalue={ value }\n\t\t\t\tstep={ step }\n\t\t\t\t__unstableStateReducer={ composeStateReducers(\n\t\t\t\t\tunitControlStateReducer,\n\t\t\t\t\tstateReducer\n\t\t\t\t) }\n\t\t\t/>\n\t\t</Root>\n\t);\n}\n\n/**\n * `UnitControl` allows the user to set a value as well as a unit (e.g. `px`).\n *\n *\n * @example\n * ```jsx\n * import { __experimentalUnitControl as UnitControl } from '@wordpress/components';\n * import { useState } from '@wordpress/element';\n *\n * const Example = () => {\n * const [ value, setValue ] = useState( '10px' );\n *\n * return <UnitControl onChange={ setValue } value={ value } />;\n * };\n * ```\n */\nconst ForwardedUnitControl = forwardRef( UnitControl );\n\nexport { parseUnit, useCustomUnits } from './utils';\nexport default ForwardedUnitControl;\n"]}
@@ -68,7 +68,7 @@ function UnitControl({
68
68
  }
69
69
 
70
70
  return unitButton;
71
- }, [onPickerPresent, accessibilityLabel, accessibilityHint, unitButtonTextStyle, unit]);
71
+ }, [onPickerPresent, accessibilityLabel, accessibilityHint, unitButtonTextStyle, unit, units]);
72
72
  const getAnchor = useCallback(() => anchorNodeRef !== null && anchorNodeRef !== void 0 && anchorNodeRef.current ? findNodeHandle(anchorNodeRef === null || anchorNodeRef === void 0 ? void 0 : anchorNodeRef.current) : undefined, [anchorNodeRef === null || anchorNodeRef === void 0 ? void 0 : anchorNodeRef.current]);
73
73
 
74
74
  const getDecimal = step => {
@@ -82,6 +82,10 @@ function UnitControl({
82
82
  };
83
83
 
84
84
  const renderUnitPicker = useCallback(() => {
85
+ if (units === false) {
86
+ return null;
87
+ }
88
+
85
89
  return createElement(View, {
86
90
  style: styles.unitMenu,
87
91
  ref: anchorNodeRef
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/components/src/unit-control/index.native.js"],"names":["Text","View","TouchableWithoutFeedback","Platform","findNodeHandle","RangeCell","StepperCell","Picker","styles","CSS_UNITS","hasUnits","parseA11yLabelForUnit","useRef","useCallback","useMemo","memo","withPreferredColorScheme","__","sprintf","UnitControl","currentInput","label","value","onChange","onUnitChange","initialPosition","min","max","separatorType","units","unit","getStylesFromColorScheme","props","pickerRef","anchorNodeRef","onPickerPresent","current","presentPicker","currentInputValue","initialControlValue","isFinite","unitButtonTextStyle","unitButtonText","unitButtonTextDark","accessibilityLabel","accessibilityHint","OS","renderUnitButton","unitButton","length","getAnchor","undefined","getDecimal","step","stepToString","splitStep","toString","split","renderUnitPicker","unitMenu","activeUnit","find","option","decimalNum","useCustomUnits"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport {\n\tText,\n\tView,\n\tTouchableWithoutFeedback,\n\tPlatform,\n\tfindNodeHandle,\n} from 'react-native';\n\n/**\n * Internal dependencies\n */\nimport RangeCell from '../mobile/bottom-sheet/range-cell';\nimport StepperCell from '../mobile/bottom-sheet/stepper-cell';\nimport Picker from '../mobile/picker';\nimport styles from './style.scss';\nimport { CSS_UNITS, hasUnits, parseA11yLabelForUnit } from './utils';\n\n/**\n * WordPress dependencies\n */\nimport { useRef, useCallback, useMemo, memo } from '@wordpress/element';\nimport { withPreferredColorScheme } from '@wordpress/compose';\nimport { __, sprintf } from '@wordpress/i18n';\n\nfunction UnitControl( {\n\tcurrentInput,\n\tlabel,\n\tvalue,\n\tonChange,\n\tonUnitChange,\n\tinitialPosition,\n\tmin,\n\tmax,\n\tseparatorType,\n\tunits = CSS_UNITS,\n\tunit,\n\tgetStylesFromColorScheme,\n\t...props\n} ) {\n\tconst pickerRef = useRef();\n\tconst anchorNodeRef = useRef();\n\n\tconst onPickerPresent = useCallback( () => {\n\t\tif ( pickerRef?.current ) {\n\t\t\tpickerRef.current.presentPicker();\n\t\t}\n\t}, [ pickerRef?.current ] );\n\n\tconst currentInputValue = currentInput === null ? value : currentInput;\n\tconst initialControlValue = isFinite( currentInputValue )\n\t\t? currentInputValue\n\t\t: initialPosition;\n\n\tconst unitButtonTextStyle = getStylesFromColorScheme(\n\t\tstyles.unitButtonText,\n\t\tstyles.unitButtonTextDark\n\t);\n\n\t/* translators: accessibility text. Inform about current unit value. %s: Current unit value. */\n\tconst accessibilityLabel = sprintf( __( 'Current unit is %s' ), unit );\n\n\tconst accessibilityHint =\n\t\tPlatform.OS === 'ios'\n\t\t\t? __( 'Double tap to open Action Sheet with available options' )\n\t\t\t: __( 'Double tap to open Bottom Sheet with available options' );\n\n\tconst renderUnitButton = useMemo( () => {\n\t\tconst unitButton = (\n\t\t\t<View style={ styles.unitButton }>\n\t\t\t\t<Text style={ unitButtonTextStyle }>{ unit }</Text>\n\t\t\t</View>\n\t\t);\n\n\t\tif ( hasUnits( units ) && units?.length > 1 ) {\n\t\t\treturn (\n\t\t\t\t<TouchableWithoutFeedback\n\t\t\t\t\tonPress={ onPickerPresent }\n\t\t\t\t\taccessibilityLabel={ accessibilityLabel }\n\t\t\t\t\taccessibilityRole=\"button\"\n\t\t\t\t\taccessibilityHint={ accessibilityHint }\n\t\t\t\t>\n\t\t\t\t\t{ unitButton }\n\t\t\t\t</TouchableWithoutFeedback>\n\t\t\t);\n\t\t}\n\n\t\treturn unitButton;\n\t}, [\n\t\tonPickerPresent,\n\t\taccessibilityLabel,\n\t\taccessibilityHint,\n\t\tunitButtonTextStyle,\n\t\tunit,\n\t] );\n\n\tconst getAnchor = useCallback(\n\t\t() =>\n\t\t\tanchorNodeRef?.current\n\t\t\t\t? findNodeHandle( anchorNodeRef?.current )\n\t\t\t\t: undefined,\n\t\t[ anchorNodeRef?.current ]\n\t);\n\n\tconst getDecimal = ( step ) => {\n\t\t// Return the decimal offset based on the step size.\n\t\t// if step size is 0.1 we expect the offset to be 1.\n\t\t// for example 12 + 0.1 we would expect the see 12.1 (not 12.10 or 12 );\n\t\t// steps are defined in the CSS_UNITS and they vary from unit to unit.\n\t\tconst stepToString = step;\n\t\tconst splitStep = stepToString.toString().split( '.' );\n\t\treturn splitStep[ 1 ] ? splitStep[ 1 ].length : 0;\n\t};\n\n\tconst renderUnitPicker = useCallback( () => {\n\t\treturn (\n\t\t\t<View style={ styles.unitMenu } ref={ anchorNodeRef }>\n\t\t\t\t{ renderUnitButton }\n\t\t\t\t{ hasUnits( units ) && units?.length > 1 ? (\n\t\t\t\t\t<Picker\n\t\t\t\t\t\tref={ pickerRef }\n\t\t\t\t\t\toptions={ units }\n\t\t\t\t\t\tonChange={ onUnitChange }\n\t\t\t\t\t\thideCancelButton\n\t\t\t\t\t\tleftAlign\n\t\t\t\t\t\tgetAnchor={ getAnchor }\n\t\t\t\t\t/>\n\t\t\t\t) : null }\n\t\t\t</View>\n\t\t);\n\t}, [ pickerRef, units, onUnitChange, getAnchor, renderUnitButton ] );\n\n\tlet step = props.step;\n\n\t/*\n\t * If no step prop has been passed, lookup the active unit and\n\t * try to get step from `units`, or default to a value of `1`\n\t */\n\tif ( ! step && units ) {\n\t\tconst activeUnit = units.find( ( option ) => option.value === unit );\n\t\tstep = activeUnit?.step ?? 1;\n\t}\n\n\tconst decimalNum = getDecimal( step );\n\n\treturn (\n\t\t<>\n\t\t\t{ unit !== '%' ? (\n\t\t\t\t<StepperCell\n\t\t\t\t\tlabel={ label }\n\t\t\t\t\tmax={ max }\n\t\t\t\t\tmin={ min }\n\t\t\t\t\tonChange={ onChange }\n\t\t\t\t\tseparatorType={ separatorType }\n\t\t\t\t\tvalue={ value }\n\t\t\t\t\tstep={ step }\n\t\t\t\t\tdefaultValue={ initialControlValue }\n\t\t\t\t\tshouldDisplayTextInput\n\t\t\t\t\tdecimalNum={ decimalNum }\n\t\t\t\t\topenUnitPicker={ onPickerPresent }\n\t\t\t\t\tunitLabel={ parseA11yLabelForUnit( unit ) }\n\t\t\t\t\t{ ...props }\n\t\t\t\t>\n\t\t\t\t\t{ renderUnitPicker() }\n\t\t\t\t</StepperCell>\n\t\t\t) : (\n\t\t\t\t<RangeCell\n\t\t\t\t\tlabel={ label }\n\t\t\t\t\tonChange={ onChange }\n\t\t\t\t\tminimumValue={ min }\n\t\t\t\t\tmaximumValue={ max }\n\t\t\t\t\tvalue={ value }\n\t\t\t\t\tstep={ step }\n\t\t\t\t\tunit={ unit }\n\t\t\t\t\tdefaultValue={ initialControlValue }\n\t\t\t\t\tseparatorType={ separatorType }\n\t\t\t\t\tdecimalNum={ decimalNum }\n\t\t\t\t\topenUnitPicker={ onPickerPresent }\n\t\t\t\t\tunitLabel={ parseA11yLabelForUnit( unit ) }\n\t\t\t\t\t{ ...props }\n\t\t\t\t>\n\t\t\t\t\t{ renderUnitPicker() }\n\t\t\t\t</RangeCell>\n\t\t\t) }\n\t\t</>\n\t);\n}\n\nexport { useCustomUnits } from './utils';\nexport default memo( withPreferredColorScheme( UnitControl ) );\n"]}
1
+ {"version":3,"sources":["@wordpress/components/src/unit-control/index.native.js"],"names":["Text","View","TouchableWithoutFeedback","Platform","findNodeHandle","RangeCell","StepperCell","Picker","styles","CSS_UNITS","hasUnits","parseA11yLabelForUnit","useRef","useCallback","useMemo","memo","withPreferredColorScheme","__","sprintf","UnitControl","currentInput","label","value","onChange","onUnitChange","initialPosition","min","max","separatorType","units","unit","getStylesFromColorScheme","props","pickerRef","anchorNodeRef","onPickerPresent","current","presentPicker","currentInputValue","initialControlValue","isFinite","unitButtonTextStyle","unitButtonText","unitButtonTextDark","accessibilityLabel","accessibilityHint","OS","renderUnitButton","unitButton","length","getAnchor","undefined","getDecimal","step","stepToString","splitStep","toString","split","renderUnitPicker","unitMenu","activeUnit","find","option","decimalNum","useCustomUnits"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport {\n\tText,\n\tView,\n\tTouchableWithoutFeedback,\n\tPlatform,\n\tfindNodeHandle,\n} from 'react-native';\n\n/**\n * Internal dependencies\n */\nimport RangeCell from '../mobile/bottom-sheet/range-cell';\nimport StepperCell from '../mobile/bottom-sheet/stepper-cell';\nimport Picker from '../mobile/picker';\nimport styles from './style.scss';\nimport { CSS_UNITS, hasUnits, parseA11yLabelForUnit } from './utils';\n\n/**\n * WordPress dependencies\n */\nimport { useRef, useCallback, useMemo, memo } from '@wordpress/element';\nimport { withPreferredColorScheme } from '@wordpress/compose';\nimport { __, sprintf } from '@wordpress/i18n';\n\nfunction UnitControl( {\n\tcurrentInput,\n\tlabel,\n\tvalue,\n\tonChange,\n\tonUnitChange,\n\tinitialPosition,\n\tmin,\n\tmax,\n\tseparatorType,\n\tunits = CSS_UNITS,\n\tunit,\n\tgetStylesFromColorScheme,\n\t...props\n} ) {\n\tconst pickerRef = useRef();\n\tconst anchorNodeRef = useRef();\n\n\tconst onPickerPresent = useCallback( () => {\n\t\tif ( pickerRef?.current ) {\n\t\t\tpickerRef.current.presentPicker();\n\t\t}\n\t}, [ pickerRef?.current ] );\n\n\tconst currentInputValue = currentInput === null ? value : currentInput;\n\tconst initialControlValue = isFinite( currentInputValue )\n\t\t? currentInputValue\n\t\t: initialPosition;\n\n\tconst unitButtonTextStyle = getStylesFromColorScheme(\n\t\tstyles.unitButtonText,\n\t\tstyles.unitButtonTextDark\n\t);\n\n\t/* translators: accessibility text. Inform about current unit value. %s: Current unit value. */\n\tconst accessibilityLabel = sprintf( __( 'Current unit is %s' ), unit );\n\n\tconst accessibilityHint =\n\t\tPlatform.OS === 'ios'\n\t\t\t? __( 'Double tap to open Action Sheet with available options' )\n\t\t\t: __( 'Double tap to open Bottom Sheet with available options' );\n\n\tconst renderUnitButton = useMemo( () => {\n\t\tconst unitButton = (\n\t\t\t<View style={ styles.unitButton }>\n\t\t\t\t<Text style={ unitButtonTextStyle }>{ unit }</Text>\n\t\t\t</View>\n\t\t);\n\n\t\tif ( hasUnits( units ) && units?.length > 1 ) {\n\t\t\treturn (\n\t\t\t\t<TouchableWithoutFeedback\n\t\t\t\t\tonPress={ onPickerPresent }\n\t\t\t\t\taccessibilityLabel={ accessibilityLabel }\n\t\t\t\t\taccessibilityRole=\"button\"\n\t\t\t\t\taccessibilityHint={ accessibilityHint }\n\t\t\t\t>\n\t\t\t\t\t{ unitButton }\n\t\t\t\t</TouchableWithoutFeedback>\n\t\t\t);\n\t\t}\n\n\t\treturn unitButton;\n\t}, [\n\t\tonPickerPresent,\n\t\taccessibilityLabel,\n\t\taccessibilityHint,\n\t\tunitButtonTextStyle,\n\t\tunit,\n\t\tunits,\n\t] );\n\n\tconst getAnchor = useCallback(\n\t\t() =>\n\t\t\tanchorNodeRef?.current\n\t\t\t\t? findNodeHandle( anchorNodeRef?.current )\n\t\t\t\t: undefined,\n\t\t[ anchorNodeRef?.current ]\n\t);\n\n\tconst getDecimal = ( step ) => {\n\t\t// Return the decimal offset based on the step size.\n\t\t// if step size is 0.1 we expect the offset to be 1.\n\t\t// for example 12 + 0.1 we would expect the see 12.1 (not 12.10 or 12 );\n\t\t// steps are defined in the CSS_UNITS and they vary from unit to unit.\n\t\tconst stepToString = step;\n\t\tconst splitStep = stepToString.toString().split( '.' );\n\t\treturn splitStep[ 1 ] ? splitStep[ 1 ].length : 0;\n\t};\n\n\tconst renderUnitPicker = useCallback( () => {\n\t\tif ( units === false ) {\n\t\t\treturn null;\n\t\t}\n\t\treturn (\n\t\t\t<View style={ styles.unitMenu } ref={ anchorNodeRef }>\n\t\t\t\t{ renderUnitButton }\n\t\t\t\t{ hasUnits( units ) && units?.length > 1 ? (\n\t\t\t\t\t<Picker\n\t\t\t\t\t\tref={ pickerRef }\n\t\t\t\t\t\toptions={ units }\n\t\t\t\t\t\tonChange={ onUnitChange }\n\t\t\t\t\t\thideCancelButton\n\t\t\t\t\t\tleftAlign\n\t\t\t\t\t\tgetAnchor={ getAnchor }\n\t\t\t\t\t/>\n\t\t\t\t) : null }\n\t\t\t</View>\n\t\t);\n\t}, [ pickerRef, units, onUnitChange, getAnchor, renderUnitButton ] );\n\n\tlet step = props.step;\n\n\t/*\n\t * If no step prop has been passed, lookup the active unit and\n\t * try to get step from `units`, or default to a value of `1`\n\t */\n\tif ( ! step && units ) {\n\t\tconst activeUnit = units.find( ( option ) => option.value === unit );\n\t\tstep = activeUnit?.step ?? 1;\n\t}\n\n\tconst decimalNum = getDecimal( step );\n\n\treturn (\n\t\t<>\n\t\t\t{ unit !== '%' ? (\n\t\t\t\t<StepperCell\n\t\t\t\t\tlabel={ label }\n\t\t\t\t\tmax={ max }\n\t\t\t\t\tmin={ min }\n\t\t\t\t\tonChange={ onChange }\n\t\t\t\t\tseparatorType={ separatorType }\n\t\t\t\t\tvalue={ value }\n\t\t\t\t\tstep={ step }\n\t\t\t\t\tdefaultValue={ initialControlValue }\n\t\t\t\t\tshouldDisplayTextInput\n\t\t\t\t\tdecimalNum={ decimalNum }\n\t\t\t\t\topenUnitPicker={ onPickerPresent }\n\t\t\t\t\tunitLabel={ parseA11yLabelForUnit( unit ) }\n\t\t\t\t\t{ ...props }\n\t\t\t\t>\n\t\t\t\t\t{ renderUnitPicker() }\n\t\t\t\t</StepperCell>\n\t\t\t) : (\n\t\t\t\t<RangeCell\n\t\t\t\t\tlabel={ label }\n\t\t\t\t\tonChange={ onChange }\n\t\t\t\t\tminimumValue={ min }\n\t\t\t\t\tmaximumValue={ max }\n\t\t\t\t\tvalue={ value }\n\t\t\t\t\tstep={ step }\n\t\t\t\t\tunit={ unit }\n\t\t\t\t\tdefaultValue={ initialControlValue }\n\t\t\t\t\tseparatorType={ separatorType }\n\t\t\t\t\tdecimalNum={ decimalNum }\n\t\t\t\t\topenUnitPicker={ onPickerPresent }\n\t\t\t\t\tunitLabel={ parseA11yLabelForUnit( unit ) }\n\t\t\t\t\t{ ...props }\n\t\t\t\t>\n\t\t\t\t\t{ renderUnitPicker() }\n\t\t\t\t</RangeCell>\n\t\t\t) }\n\t\t</>\n\t);\n}\n\nexport { useCustomUnits } from './utils';\nexport default memo( withPreferredColorScheme( UnitControl ) );\n"]}