@wordpress/components 25.13.0 → 25.15.1-next.79a6196f.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (743) hide show
  1. package/CHANGELOG.md +89 -1
  2. package/CONTRIBUTING.md +57 -115
  3. package/LICENSE.md +1 -1
  4. package/build/base-control/index.js +17 -13
  5. package/build/base-control/index.js.map +1 -1
  6. package/build/border-box-control/border-box-control-linked-button/component.js +1 -1
  7. package/build/border-box-control/border-box-control-linked-button/component.js.map +1 -1
  8. package/build/border-control/border-control-dropdown/component.js +4 -2
  9. package/build/border-control/border-control-dropdown/component.js.map +1 -1
  10. package/build/border-control/border-control-dropdown/hook.js +3 -2
  11. package/build/border-control/border-control-dropdown/hook.js.map +1 -1
  12. package/build/border-control/border-control-style-picker/component.js +1 -1
  13. package/build/border-control/border-control-style-picker/component.js.map +1 -1
  14. package/build/border-control/styles.js +17 -17
  15. package/build/border-control/styles.js.map +1 -1
  16. package/build/box-control/index.js +1 -1
  17. package/build/box-control/index.js.map +1 -1
  18. package/build/box-control/linked-button.js +1 -1
  19. package/build/box-control/linked-button.js.map +1 -1
  20. package/build/button/index.js +1 -1
  21. package/build/button/index.js.map +1 -1
  22. package/build/checkbox-control/index.js +1 -1
  23. package/build/checkbox-control/index.js.map +1 -1
  24. package/build/checkbox-control/types.js.map +1 -1
  25. package/build/color-palette/index.native.js +11 -7
  26. package/build/color-palette/index.native.js.map +1 -1
  27. package/build/color-picker/color-copy-button.js +1 -1
  28. package/build/color-picker/color-copy-button.js.map +1 -1
  29. package/build/context/wordpress-component.js.map +1 -1
  30. package/build/custom-select-control-v2/index.js +11 -10
  31. package/build/custom-select-control-v2/index.js.map +1 -1
  32. package/build/date-time/date/styles.js +8 -8
  33. package/build/date-time/date/styles.js.map +1 -1
  34. package/build/date-time/time/timezone.js +11 -2
  35. package/build/date-time/time/timezone.js.map +1 -1
  36. package/build/dimension-control/index.js +2 -0
  37. package/build/dimension-control/index.js.map +1 -1
  38. package/build/dimension-control/types.js.map +1 -1
  39. package/build/dropdown-menu-v2/index.js +205 -159
  40. package/build/dropdown-menu-v2/index.js.map +1 -1
  41. package/build/dropdown-menu-v2/styles.js +86 -77
  42. package/build/dropdown-menu-v2/styles.js.map +1 -1
  43. package/build/dropdown-menu-v2/types.js.map +1 -1
  44. package/build/duotone-picker/duotone-picker.js +4 -3
  45. package/build/duotone-picker/duotone-picker.js.map +1 -1
  46. package/build/focal-point-picker/controls.js +5 -1
  47. package/build/focal-point-picker/controls.js.map +1 -1
  48. package/build/focal-point-picker/index.js +2 -0
  49. package/build/focal-point-picker/index.js.map +1 -1
  50. package/build/focal-point-picker/styles/focal-point-picker-style.js +15 -15
  51. package/build/focal-point-picker/styles/focal-point-picker-style.js.map +1 -1
  52. package/build/focal-point-picker/types.js.map +1 -1
  53. package/build/font-size-picker/font-size-picker-select.js +2 -0
  54. package/build/font-size-picker/font-size-picker-select.js.map +1 -1
  55. package/build/font-size-picker/font-size-picker-toggle-group.js +2 -0
  56. package/build/font-size-picker/font-size-picker-toggle-group.js.map +1 -1
  57. package/build/font-size-picker/index.js +10 -3
  58. package/build/font-size-picker/index.js.map +1 -1
  59. package/build/font-size-picker/index.native.js +6 -3
  60. package/build/font-size-picker/index.native.js.map +1 -1
  61. package/build/font-size-picker/types.js.map +1 -1
  62. package/build/form-token-field/index.js +10 -5
  63. package/build/form-token-field/index.js.map +1 -1
  64. package/build/form-token-field/token.js +1 -0
  65. package/build/form-token-field/token.js.map +1 -1
  66. package/build/gradient-picker/index.js +3 -2
  67. package/build/gradient-picker/index.js.map +1 -1
  68. package/build/index.native.js +20 -19
  69. package/build/index.native.js.map +1 -1
  70. package/build/input-control/styles/input-control-styles.js +32 -29
  71. package/build/input-control/styles/input-control-styles.js.map +1 -1
  72. package/build/input-control/types.js.map +1 -1
  73. package/build/lock-unlock.js +18 -0
  74. package/build/lock-unlock.js.map +1 -0
  75. package/build/mobile/bottom-sheet/index.native.js +8 -0
  76. package/build/mobile/bottom-sheet/index.native.js.map +1 -1
  77. package/build/mobile/color-settings/palette.screen.native.js +8 -4
  78. package/build/mobile/color-settings/palette.screen.native.js.map +1 -1
  79. package/build/mobile/global-styles-context/utils.native.js +39 -13
  80. package/build/mobile/global-styles-context/utils.native.js.map +1 -1
  81. package/build/mobile/image/constants.js +12 -0
  82. package/build/mobile/image/constants.js.map +1 -0
  83. package/build/mobile/image/index.native.js +26 -18
  84. package/build/mobile/image/index.native.js.map +1 -1
  85. package/build/mobile/keyboard-aware-flat-list/index.android.js +40 -8
  86. package/build/mobile/keyboard-aware-flat-list/index.android.js.map +1 -1
  87. package/build/mobile/keyboard-aware-flat-list/index.ios.js +44 -68
  88. package/build/mobile/keyboard-aware-flat-list/index.ios.js.map +1 -1
  89. package/build/mobile/keyboard-aware-flat-list/use-scroll-to-element.native.js +39 -0
  90. package/build/mobile/keyboard-aware-flat-list/use-scroll-to-element.native.js.map +1 -0
  91. package/build/mobile/keyboard-aware-flat-list/{use-scroll-to-text-input.native.js → use-scroll-to-section.native.js} +22 -29
  92. package/build/mobile/keyboard-aware-flat-list/use-scroll-to-section.native.js.map +1 -0
  93. package/build/mobile/keyboard-aware-flat-list/use-scroll.native.js +93 -0
  94. package/build/mobile/keyboard-aware-flat-list/use-scroll.native.js.map +1 -0
  95. package/build/mobile/utils/get-px-from-css-unit.native.js +302 -0
  96. package/build/mobile/utils/get-px-from-css-unit.native.js.map +1 -0
  97. package/build/modal/index.js +18 -13
  98. package/build/modal/index.js.map +1 -1
  99. package/build/navigation/menu/menu-title.js +1 -1
  100. package/build/navigation/menu/menu-title.js.map +1 -1
  101. package/build/navigator/navigator-provider/component.js +13 -15
  102. package/build/navigator/navigator-provider/component.js.map +1 -1
  103. package/build/navigator/navigator-screen/component.js +23 -63
  104. package/build/navigator/navigator-screen/component.js.map +1 -1
  105. package/build/navigator/styles.js +52 -0
  106. package/build/navigator/styles.js.map +1 -0
  107. package/build/number-control/index.js +4 -8
  108. package/build/number-control/index.js.map +1 -1
  109. package/build/number-control/types.js.map +1 -1
  110. package/build/palette-edit/index.js +15 -34
  111. package/build/palette-edit/index.js.map +1 -1
  112. package/build/private-apis.js +11 -26
  113. package/build/private-apis.js.map +1 -1
  114. package/build/private-apis.native.js +21 -0
  115. package/build/private-apis.native.js.map +1 -0
  116. package/build/query-controls/author-select.js +3 -1
  117. package/build/query-controls/author-select.js.map +1 -1
  118. package/build/query-controls/category-select.js +3 -1
  119. package/build/query-controls/category-select.js.map +1 -1
  120. package/build/query-controls/index.js +6 -1
  121. package/build/query-controls/index.js.map +1 -1
  122. package/build/query-controls/types.js.map +1 -1
  123. package/build/radio-control/index.js +1 -0
  124. package/build/radio-control/index.js.map +1 -1
  125. package/build/range-control/index.js +1 -1
  126. package/build/range-control/index.js.map +1 -1
  127. package/build/select-control/styles/select-control-styles.js +15 -25
  128. package/build/select-control/styles/select-control-styles.js.map +1 -1
  129. package/build/slot-fill/index.js +3 -2
  130. package/build/slot-fill/index.js.map +1 -1
  131. package/build/slot-fill/types.js.map +1 -1
  132. package/build/snackbar/types.js.map +1 -1
  133. package/build/tabs/index.js +18 -1
  134. package/build/tabs/index.js.map +1 -1
  135. package/build/tabs/styles.js +3 -3
  136. package/build/tabs/styles.js.map +1 -1
  137. package/build/tabs/tab.js +2 -2
  138. package/build/tabs/tab.js.map +1 -1
  139. package/build/tabs/tabpanel.js +11 -8
  140. package/build/tabs/tabpanel.js.map +1 -1
  141. package/build/tabs/types.js.map +1 -1
  142. package/build/toggle-group-control/toggle-group-control/component.js +4 -4
  143. package/build/toggle-group-control/toggle-group-control/component.js.map +1 -1
  144. package/build/toggle-group-control/toggle-group-control/styles.js +29 -15
  145. package/build/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  146. package/build/toggle-group-control/toggle-group-control/utils.js +17 -17
  147. package/build/toggle-group-control/toggle-group-control/utils.js.map +1 -1
  148. package/build/toggle-group-control/toggle-group-control-option-base/styles.js +9 -9
  149. package/build/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  150. package/build/tools-panel/tools-panel/component.js +3 -1
  151. package/build/tools-panel/tools-panel/component.js.map +1 -1
  152. package/build/tools-panel/tools-panel-header/component.js +9 -8
  153. package/build/tools-panel/tools-panel-header/component.js.map +1 -1
  154. package/build/tools-panel/tools-panel-item/hook.js +11 -11
  155. package/build/tools-panel/tools-panel-item/hook.js.map +1 -1
  156. package/build/tools-panel/types.js.map +1 -1
  157. package/build/tooltip/index.js +34 -10
  158. package/build/tooltip/index.js.map +1 -1
  159. package/build/tooltip/types.js.map +1 -1
  160. package/build/truncate/hook.js +10 -4
  161. package/build/truncate/hook.js.map +1 -1
  162. package/build/truncate/types.js.map +1 -1
  163. package/build/unit-control/index.js +1 -1
  164. package/build/unit-control/index.js.map +1 -1
  165. package/build/utils/strings.js +34 -3
  166. package/build/utils/strings.js.map +1 -1
  167. package/build-module/base-control/index.js +16 -12
  168. package/build-module/base-control/index.js.map +1 -1
  169. package/build-module/border-box-control/border-box-control-linked-button/component.js +1 -1
  170. package/build-module/border-box-control/border-box-control-linked-button/component.js.map +1 -1
  171. package/build-module/border-control/border-control-dropdown/component.js +4 -2
  172. package/build-module/border-control/border-control-dropdown/component.js.map +1 -1
  173. package/build-module/border-control/border-control-dropdown/hook.js +3 -2
  174. package/build-module/border-control/border-control-dropdown/hook.js.map +1 -1
  175. package/build-module/border-control/border-control-style-picker/component.js +1 -1
  176. package/build-module/border-control/border-control-style-picker/component.js.map +1 -1
  177. package/build-module/border-control/styles.js +17 -17
  178. package/build-module/border-control/styles.js.map +1 -1
  179. package/build-module/box-control/index.js +1 -1
  180. package/build-module/box-control/index.js.map +1 -1
  181. package/build-module/box-control/linked-button.js +1 -1
  182. package/build-module/box-control/linked-button.js.map +1 -1
  183. package/build-module/button/index.js +1 -1
  184. package/build-module/button/index.js.map +1 -1
  185. package/build-module/checkbox-control/index.js +1 -1
  186. package/build-module/checkbox-control/index.js.map +1 -1
  187. package/build-module/checkbox-control/types.js.map +1 -1
  188. package/build-module/color-palette/index.native.js +11 -7
  189. package/build-module/color-palette/index.native.js.map +1 -1
  190. package/build-module/color-picker/color-copy-button.js +1 -1
  191. package/build-module/color-picker/color-copy-button.js.map +1 -1
  192. package/build-module/context/wordpress-component.js.map +1 -1
  193. package/build-module/custom-select-control-v2/index.js +11 -10
  194. package/build-module/custom-select-control-v2/index.js.map +1 -1
  195. package/build-module/date-time/date/styles.js +8 -8
  196. package/build-module/date-time/date/styles.js.map +1 -1
  197. package/build-module/date-time/time/timezone.js +11 -2
  198. package/build-module/date-time/time/timezone.js.map +1 -1
  199. package/build-module/dimension-control/index.js +2 -0
  200. package/build-module/dimension-control/index.js.map +1 -1
  201. package/build-module/dimension-control/types.js.map +1 -1
  202. package/build-module/dropdown-menu-v2/index.js +201 -154
  203. package/build-module/dropdown-menu-v2/index.js.map +1 -1
  204. package/build-module/dropdown-menu-v2/styles.js +68 -61
  205. package/build-module/dropdown-menu-v2/styles.js.map +1 -1
  206. package/build-module/dropdown-menu-v2/types.js.map +1 -1
  207. package/build-module/duotone-picker/duotone-picker.js +4 -3
  208. package/build-module/duotone-picker/duotone-picker.js.map +1 -1
  209. package/build-module/focal-point-picker/controls.js +5 -1
  210. package/build-module/focal-point-picker/controls.js.map +1 -1
  211. package/build-module/focal-point-picker/index.js +2 -0
  212. package/build-module/focal-point-picker/index.js.map +1 -1
  213. package/build-module/focal-point-picker/styles/focal-point-picker-style.js +15 -15
  214. package/build-module/focal-point-picker/styles/focal-point-picker-style.js.map +1 -1
  215. package/build-module/focal-point-picker/types.js.map +1 -1
  216. package/build-module/font-size-picker/font-size-picker-select.js +2 -0
  217. package/build-module/font-size-picker/font-size-picker-select.js.map +1 -1
  218. package/build-module/font-size-picker/font-size-picker-toggle-group.js +2 -0
  219. package/build-module/font-size-picker/font-size-picker-toggle-group.js.map +1 -1
  220. package/build-module/font-size-picker/index.js +10 -3
  221. package/build-module/font-size-picker/index.js.map +1 -1
  222. package/build-module/font-size-picker/index.native.js +5 -2
  223. package/build-module/font-size-picker/index.native.js.map +1 -1
  224. package/build-module/font-size-picker/types.js.map +1 -1
  225. package/build-module/form-token-field/index.js +10 -5
  226. package/build-module/form-token-field/index.js.map +1 -1
  227. package/build-module/form-token-field/token.js +1 -0
  228. package/build-module/form-token-field/token.js.map +1 -1
  229. package/build-module/gradient-picker/index.js +3 -2
  230. package/build-module/gradient-picker/index.js.map +1 -1
  231. package/build-module/index.native.js +6 -3
  232. package/build-module/index.native.js.map +1 -1
  233. package/build-module/input-control/styles/input-control-styles.js +31 -29
  234. package/build-module/input-control/styles/input-control-styles.js.map +1 -1
  235. package/build-module/input-control/types.js.map +1 -1
  236. package/build-module/lock-unlock.js +9 -0
  237. package/build-module/lock-unlock.js.map +1 -0
  238. package/build-module/mobile/bottom-sheet/index.native.js +9 -1
  239. package/build-module/mobile/bottom-sheet/index.native.js.map +1 -1
  240. package/build-module/mobile/color-settings/palette.screen.native.js +8 -4
  241. package/build-module/mobile/color-settings/palette.screen.native.js.map +1 -1
  242. package/build-module/mobile/global-styles-context/utils.native.js +38 -13
  243. package/build-module/mobile/global-styles-context/utils.native.js.map +1 -1
  244. package/build-module/mobile/image/constants.js +5 -0
  245. package/build-module/mobile/image/constants.js.map +1 -0
  246. package/build-module/mobile/image/index.native.js +25 -16
  247. package/build-module/mobile/image/index.native.js.map +1 -1
  248. package/build-module/mobile/keyboard-aware-flat-list/index.android.js +40 -6
  249. package/build-module/mobile/keyboard-aware-flat-list/index.android.js.map +1 -1
  250. package/build-module/mobile/keyboard-aware-flat-list/index.ios.js +46 -68
  251. package/build-module/mobile/keyboard-aware-flat-list/index.ios.js.map +1 -1
  252. package/build-module/mobile/keyboard-aware-flat-list/use-scroll-to-element.native.js +33 -0
  253. package/build-module/mobile/keyboard-aware-flat-list/use-scroll-to-element.native.js.map +1 -0
  254. package/build-module/mobile/keyboard-aware-flat-list/{use-scroll-to-text-input.native.js → use-scroll-to-section.native.js} +21 -27
  255. package/build-module/mobile/keyboard-aware-flat-list/use-scroll-to-section.native.js.map +1 -0
  256. package/build-module/mobile/keyboard-aware-flat-list/use-scroll.native.js +86 -0
  257. package/build-module/mobile/keyboard-aware-flat-list/use-scroll.native.js.map +1 -0
  258. package/build-module/mobile/utils/get-px-from-css-unit.native.js +294 -0
  259. package/build-module/mobile/utils/get-px-from-css-unit.native.js.map +1 -0
  260. package/build-module/modal/index.js +18 -13
  261. package/build-module/modal/index.js.map +1 -1
  262. package/build-module/navigation/menu/menu-title.js +1 -1
  263. package/build-module/navigation/menu/menu-title.js.map +1 -1
  264. package/build-module/navigator/navigator-provider/component.js +3 -16
  265. package/build-module/navigator/navigator-provider/component.js.map +1 -1
  266. package/build-module/navigator/navigator-screen/component.js +16 -70
  267. package/build-module/navigator/navigator-screen/component.js.map +1 -1
  268. package/build-module/navigator/styles.js +47 -0
  269. package/build-module/navigator/styles.js.map +1 -0
  270. package/build-module/number-control/index.js +4 -8
  271. package/build-module/number-control/index.js.map +1 -1
  272. package/build-module/number-control/types.js.map +1 -1
  273. package/build-module/palette-edit/index.js +14 -33
  274. package/build-module/palette-edit/index.js.map +1 -1
  275. package/build-module/private-apis.js +10 -23
  276. package/build-module/private-apis.js.map +1 -1
  277. package/build-module/private-apis.native.js +14 -0
  278. package/build-module/private-apis.native.js.map +1 -0
  279. package/build-module/query-controls/author-select.js +3 -1
  280. package/build-module/query-controls/author-select.js.map +1 -1
  281. package/build-module/query-controls/category-select.js +3 -1
  282. package/build-module/query-controls/category-select.js.map +1 -1
  283. package/build-module/query-controls/index.js +6 -1
  284. package/build-module/query-controls/index.js.map +1 -1
  285. package/build-module/query-controls/types.js.map +1 -1
  286. package/build-module/radio-control/index.js +1 -0
  287. package/build-module/radio-control/index.js.map +1 -1
  288. package/build-module/range-control/index.js +1 -1
  289. package/build-module/range-control/index.js.map +1 -1
  290. package/build-module/select-control/styles/select-control-styles.js +15 -25
  291. package/build-module/select-control/styles/select-control-styles.js.map +1 -1
  292. package/build-module/slot-fill/index.js +3 -2
  293. package/build-module/slot-fill/index.js.map +1 -1
  294. package/build-module/slot-fill/types.js.map +1 -1
  295. package/build-module/snackbar/types.js.map +1 -1
  296. package/build-module/tabs/index.js +18 -1
  297. package/build-module/tabs/index.js.map +1 -1
  298. package/build-module/tabs/styles.js +3 -3
  299. package/build-module/tabs/styles.js.map +1 -1
  300. package/build-module/tabs/tab.js +2 -2
  301. package/build-module/tabs/tab.js.map +1 -1
  302. package/build-module/tabs/tabpanel.js +11 -8
  303. package/build-module/tabs/tabpanel.js.map +1 -1
  304. package/build-module/tabs/types.js.map +1 -1
  305. package/build-module/toggle-group-control/toggle-group-control/component.js +4 -4
  306. package/build-module/toggle-group-control/toggle-group-control/component.js.map +1 -1
  307. package/build-module/toggle-group-control/toggle-group-control/styles.js +29 -15
  308. package/build-module/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  309. package/build-module/toggle-group-control/toggle-group-control/utils.js +17 -17
  310. package/build-module/toggle-group-control/toggle-group-control/utils.js.map +1 -1
  311. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js +9 -9
  312. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  313. package/build-module/tools-panel/tools-panel/component.js +3 -1
  314. package/build-module/tools-panel/tools-panel/component.js.map +1 -1
  315. package/build-module/tools-panel/tools-panel-header/component.js +9 -8
  316. package/build-module/tools-panel/tools-panel-header/component.js.map +1 -1
  317. package/build-module/tools-panel/tools-panel-item/hook.js +11 -11
  318. package/build-module/tools-panel/tools-panel-item/hook.js.map +1 -1
  319. package/build-module/tools-panel/types.js.map +1 -1
  320. package/build-module/tooltip/index.js +34 -12
  321. package/build-module/tooltip/index.js.map +1 -1
  322. package/build-module/tooltip/types.js.map +1 -1
  323. package/build-module/truncate/hook.js +10 -4
  324. package/build-module/truncate/hook.js.map +1 -1
  325. package/build-module/truncate/types.js.map +1 -1
  326. package/build-module/unit-control/index.js +1 -1
  327. package/build-module/unit-control/index.js.map +1 -1
  328. package/build-module/utils/strings.js +32 -2
  329. package/build-module/utils/strings.js.map +1 -1
  330. package/build-style/style-rtl.css +30 -6
  331. package/build-style/style.css +30 -6
  332. package/build-types/base-control/index.d.ts +3 -27
  333. package/build-types/base-control/index.d.ts.map +1 -1
  334. package/build-types/base-control/stories/index.story.d.ts +4 -1
  335. package/build-types/base-control/stories/index.story.d.ts.map +1 -1
  336. package/build-types/border-box-control/border-box-control/hook.d.ts +4 -4
  337. package/build-types/border-box-control/border-box-control-linked-button/hook.d.ts +6 -6
  338. package/build-types/border-box-control/border-box-control-split-controls/hook.d.ts +4 -4
  339. package/build-types/border-box-control/border-box-control-visualizer/hook.d.ts +4 -4
  340. package/build-types/border-box-control/stories/index.story.d.ts +1 -1
  341. package/build-types/border-control/border-control/hook.d.ts +4 -4
  342. package/build-types/border-control/border-control-dropdown/component.d.ts.map +1 -1
  343. package/build-types/border-control/border-control-dropdown/hook.d.ts +5 -4
  344. package/build-types/border-control/border-control-dropdown/hook.d.ts.map +1 -1
  345. package/build-types/border-control/border-control-style-picker/hook.d.ts +4 -4
  346. package/build-types/border-control/stories/index.story.d.ts +6 -6
  347. package/build-types/border-control/styles.d.ts +1 -1
  348. package/build-types/border-control/styles.d.ts.map +1 -1
  349. package/build-types/box-control/stories/index.story.d.ts +42 -42
  350. package/build-types/box-control/styles/box-control-styles.d.ts +1 -1
  351. package/build-types/button/deprecated.d.ts +3 -3
  352. package/build-types/card/card/hook.d.ts +4 -4
  353. package/build-types/card/card-body/hook.d.ts +4 -4
  354. package/build-types/card/card-divider/hook.d.ts +4 -4
  355. package/build-types/card/card-footer/hook.d.ts +4 -4
  356. package/build-types/card/card-header/hook.d.ts +4 -4
  357. package/build-types/card/card-media/hook.d.ts +4 -4
  358. package/build-types/checkbox-control/index.d.ts.map +1 -1
  359. package/build-types/checkbox-control/types.d.ts +3 -2
  360. package/build-types/checkbox-control/types.d.ts.map +1 -1
  361. package/build-types/color-palette/styles.d.ts +2 -2
  362. package/build-types/color-picker/component.d.ts +2 -2
  363. package/build-types/color-picker/stories/index.story.d.ts +1 -1
  364. package/build-types/color-picker/stories/index.story.d.ts.map +1 -1
  365. package/build-types/color-picker/styles.d.ts +3 -3
  366. package/build-types/composite/test/index.d.ts.map +1 -0
  367. package/build-types/context/wordpress-component.d.ts +3 -3
  368. package/build-types/context/wordpress-component.d.ts.map +1 -1
  369. package/build-types/custom-select-control-v2/index.d.ts +3 -2
  370. package/build-types/custom-select-control-v2/index.d.ts.map +1 -1
  371. package/build-types/custom-select-control-v2/stories/index.story.d.ts +4 -3
  372. package/build-types/custom-select-control-v2/stories/index.story.d.ts.map +1 -1
  373. package/build-types/date-time/date/styles.d.ts +3 -3
  374. package/build-types/date-time/date-time/styles.d.ts +1 -1
  375. package/build-types/date-time/time/styles.d.ts +4 -4
  376. package/build-types/date-time/time/timezone.d.ts.map +1 -1
  377. package/build-types/dimension-control/index.d.ts.map +1 -1
  378. package/build-types/dimension-control/types.d.ts +6 -0
  379. package/build-types/dimension-control/types.d.ts.map +1 -1
  380. package/build-types/dropdown/index.d.ts +1 -1
  381. package/build-types/dropdown/index.d.ts.map +1 -1
  382. package/build-types/dropdown/stories/index.story.d.ts +3 -3
  383. package/build-types/dropdown/stories/index.story.d.ts.map +1 -1
  384. package/build-types/dropdown-menu/index.d.ts +1 -1
  385. package/build-types/dropdown-menu/index.d.ts.map +1 -1
  386. package/build-types/dropdown-menu/stories/index.story.d.ts +2 -2
  387. package/build-types/dropdown-menu/stories/index.story.d.ts.map +1 -1
  388. package/build-types/dropdown-menu-v2/index.d.ts +18 -15
  389. package/build-types/dropdown-menu-v2/index.d.ts.map +1 -1
  390. package/build-types/dropdown-menu-v2/stories/index.story.d.ts +7 -2
  391. package/build-types/dropdown-menu-v2/stories/index.story.d.ts.map +1 -1
  392. package/build-types/dropdown-menu-v2/styles.d.ts +77 -23
  393. package/build-types/dropdown-menu-v2/styles.d.ts.map +1 -1
  394. package/build-types/dropdown-menu-v2/types.d.ts +89 -173
  395. package/build-types/dropdown-menu-v2/types.d.ts.map +1 -1
  396. package/build-types/duotone-picker/duotone-picker.d.ts.map +1 -1
  397. package/build-types/elevation/hook.d.ts +4 -4
  398. package/build-types/flex/flex/hook.d.ts +4 -4
  399. package/build-types/flex/flex-block/hook.d.ts +4 -4
  400. package/build-types/flex/flex-item/hook.d.ts +4 -4
  401. package/build-types/focal-point-picker/controls.d.ts +1 -1
  402. package/build-types/focal-point-picker/controls.d.ts.map +1 -1
  403. package/build-types/focal-point-picker/index.d.ts +1 -1
  404. package/build-types/focal-point-picker/index.d.ts.map +1 -1
  405. package/build-types/focal-point-picker/stories/index.story.d.ts +8 -4
  406. package/build-types/focal-point-picker/stories/index.story.d.ts.map +1 -1
  407. package/build-types/focal-point-picker/styles/focal-point-picker-style.d.ts +1 -1
  408. package/build-types/focal-point-picker/types.d.ts +7 -0
  409. package/build-types/focal-point-picker/types.d.ts.map +1 -1
  410. package/build-types/font-size-picker/font-size-picker-select.d.ts.map +1 -1
  411. package/build-types/font-size-picker/font-size-picker-toggle-group.d.ts.map +1 -1
  412. package/build-types/font-size-picker/index.d.ts.map +1 -1
  413. package/build-types/font-size-picker/styles.d.ts +1 -1
  414. package/build-types/font-size-picker/types.d.ts +8 -1
  415. package/build-types/font-size-picker/types.d.ts.map +1 -1
  416. package/build-types/form-token-field/index.d.ts.map +1 -1
  417. package/build-types/form-token-field/token.d.ts.map +1 -1
  418. package/build-types/grid/hook.d.ts +4 -4
  419. package/build-types/h-stack/hook.d.ts +4 -4
  420. package/build-types/heading/component.d.ts +1 -1
  421. package/build-types/heading/hook.d.ts +4 -4
  422. package/build-types/input-control/styles/input-control-styles.d.ts +11 -0
  423. package/build-types/input-control/styles/input-control-styles.d.ts.map +1 -1
  424. package/build-types/input-control/types.d.ts +1 -1
  425. package/build-types/input-control/types.d.ts.map +1 -1
  426. package/build-types/item-group/item/hook.d.ts +4 -4
  427. package/build-types/item-group/item-group/hook.d.ts +4 -4
  428. package/build-types/lock-unlock.d.ts +3 -0
  429. package/build-types/lock-unlock.d.ts.map +1 -0
  430. package/build-types/menu-item/index.d.ts +1 -1
  431. package/build-types/menu-item/stories/index.story.d.ts +4 -4
  432. package/build-types/mobile/image/constants.d.ts +5 -0
  433. package/build-types/mobile/image/constants.d.ts.map +1 -0
  434. package/build-types/modal/index.d.ts.map +1 -1
  435. package/build-types/navigation/styles/navigation-styles.d.ts +3 -3
  436. package/build-types/navigator/navigator-back-button/hook.d.ts +6 -6
  437. package/build-types/navigator/navigator-button/hook.d.ts +6 -6
  438. package/build-types/navigator/navigator-provider/component.d.ts.map +1 -1
  439. package/build-types/navigator/navigator-screen/component.d.ts +1 -7
  440. package/build-types/navigator/navigator-screen/component.d.ts.map +1 -1
  441. package/build-types/navigator/styles.d.ts +9 -0
  442. package/build-types/navigator/styles.d.ts.map +1 -0
  443. package/build-types/number-control/index.d.ts +1 -1
  444. package/build-types/number-control/index.d.ts.map +1 -1
  445. package/build-types/number-control/stories/index.story.d.ts +1 -1
  446. package/build-types/number-control/types.d.ts +1 -1
  447. package/build-types/palette-edit/index.d.ts +2 -2
  448. package/build-types/palette-edit/index.d.ts.map +1 -1
  449. package/build-types/palette-edit/styles.d.ts +3 -3
  450. package/build-types/popover/index.d.ts +1 -1
  451. package/build-types/popover/index.d.ts.map +1 -1
  452. package/build-types/popover/stories/e2e/index.story.d.ts +1 -1
  453. package/build-types/private-apis.d.ts +0 -1
  454. package/build-types/private-apis.d.ts.map +1 -1
  455. package/build-types/query-controls/author-select.d.ts +1 -1
  456. package/build-types/query-controls/author-select.d.ts.map +1 -1
  457. package/build-types/query-controls/category-select.d.ts +1 -1
  458. package/build-types/query-controls/category-select.d.ts.map +1 -1
  459. package/build-types/query-controls/index.d.ts +1 -1
  460. package/build-types/query-controls/index.d.ts.map +1 -1
  461. package/build-types/query-controls/types.d.ts +9 -0
  462. package/build-types/query-controls/types.d.ts.map +1 -1
  463. package/build-types/radio-control/index.d.ts.map +1 -1
  464. package/build-types/range-control/index.d.ts +1 -1
  465. package/build-types/range-control/styles/range-control-styles.d.ts +1 -1
  466. package/build-types/resizable-box/index.d.ts +1 -1
  467. package/build-types/resizable-box/resize-tooltip/index.d.ts +1 -1
  468. package/build-types/resizable-box/stories/index.story.d.ts +2 -2
  469. package/build-types/scrollable/hook.d.ts +4 -4
  470. package/build-types/search-control/index.d.ts +1 -1
  471. package/build-types/search-control/stories/index.story.d.ts +2 -2
  472. package/build-types/select-control/styles/select-control-styles.d.ts.map +1 -1
  473. package/build-types/slot-fill/index.d.ts +1 -1
  474. package/build-types/slot-fill/index.d.ts.map +1 -1
  475. package/build-types/slot-fill/types.d.ts +4 -0
  476. package/build-types/slot-fill/types.d.ts.map +1 -1
  477. package/build-types/snackbar/index.d.ts +2 -2
  478. package/build-types/snackbar/stories/index.story.d.ts +0 -3
  479. package/build-types/snackbar/stories/index.story.d.ts.map +1 -1
  480. package/build-types/snackbar/types.d.ts +1 -1
  481. package/build-types/snackbar/types.d.ts.map +1 -1
  482. package/build-types/spacer/hook.d.ts +4 -4
  483. package/build-types/surface/hook.d.ts +4 -4
  484. package/build-types/tabs/index.d.ts +2 -2
  485. package/build-types/tabs/index.d.ts.map +1 -1
  486. package/build-types/tabs/styles.d.ts.map +1 -1
  487. package/build-types/tabs/tab.d.ts +2 -1
  488. package/build-types/tabs/tab.d.ts.map +1 -1
  489. package/build-types/tabs/tabpanel.d.ts +3 -2
  490. package/build-types/tabs/tabpanel.d.ts.map +1 -1
  491. package/build-types/tabs/types.d.ts +8 -3
  492. package/build-types/tabs/types.d.ts.map +1 -1
  493. package/build-types/text/hook.d.ts +4 -4
  494. package/build-types/text-control/index.d.ts +1 -1
  495. package/build-types/textarea-control/index.d.ts +1 -1
  496. package/build-types/toggle-control/stories/index.story.d.ts +2 -2
  497. package/build-types/toggle-group-control/toggle-group-control/as-button-group.d.ts +1 -1
  498. package/build-types/toggle-group-control/toggle-group-control/as-radio-group.d.ts +1 -1
  499. package/build-types/toggle-group-control/toggle-group-control/component.d.ts.map +1 -1
  500. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts +2 -2
  501. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts.map +1 -1
  502. package/build-types/toggle-group-control/toggle-group-control/utils.d.ts.map +1 -1
  503. package/build-types/toggle-group-control/toggle-group-control-option/component.d.ts +1 -1
  504. package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts +1 -1
  505. package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts.map +1 -1
  506. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts.map +1 -1
  507. package/build-types/toggle-group-control/toggle-group-control-option-icon/component.d.ts +1 -1
  508. package/build-types/toolbar/toolbar-button/index.d.ts +3 -3
  509. package/build-types/tools-panel/tools-panel/component.d.ts.map +1 -1
  510. package/build-types/tools-panel/tools-panel/hook.d.ts +5 -4
  511. package/build-types/tools-panel/tools-panel/hook.d.ts.map +1 -1
  512. package/build-types/tools-panel/tools-panel-header/component.d.ts.map +1 -1
  513. package/build-types/tools-panel/tools-panel-header/hook.d.ts +5 -4
  514. package/build-types/tools-panel/tools-panel-header/hook.d.ts.map +1 -1
  515. package/build-types/tools-panel/tools-panel-item/hook.d.ts +4 -4
  516. package/build-types/tools-panel/tools-panel-item/hook.d.ts.map +1 -1
  517. package/build-types/tools-panel/types.d.ts +9 -0
  518. package/build-types/tools-panel/types.d.ts.map +1 -1
  519. package/build-types/tooltip/index.d.ts +1 -1
  520. package/build-types/tooltip/index.d.ts.map +1 -1
  521. package/build-types/tooltip/stories/index.story.d.ts +10 -1
  522. package/build-types/tooltip/stories/index.story.d.ts.map +1 -1
  523. package/build-types/tooltip/types.d.ts +3 -0
  524. package/build-types/tooltip/types.d.ts.map +1 -1
  525. package/build-types/truncate/hook.d.ts +5 -5
  526. package/build-types/truncate/hook.d.ts.map +1 -1
  527. package/build-types/truncate/types.d.ts +4 -0
  528. package/build-types/truncate/types.d.ts.map +1 -1
  529. package/build-types/unit-control/index.d.ts +1 -1
  530. package/build-types/unit-control/styles/unit-control-styles.d.ts +1 -1
  531. package/build-types/utils/strings.d.ts +14 -2
  532. package/build-types/utils/strings.d.ts.map +1 -1
  533. package/build-types/v-stack/hook.d.ts +4 -4
  534. package/build-types/v-stack/stories/index.story.d.ts +1 -1
  535. package/package.json +20 -21
  536. package/src/alignment-matrix-control/test/index.tsx +10 -16
  537. package/src/base-control/index.tsx +21 -16
  538. package/src/border-box-control/border-box-control-linked-button/component.tsx +1 -1
  539. package/src/border-control/border-control-dropdown/component.tsx +3 -1
  540. package/src/border-control/border-control-dropdown/hook.ts +3 -2
  541. package/src/border-control/border-control-style-picker/component.tsx +1 -1
  542. package/src/border-control/styles.ts +2 -9
  543. package/src/box-control/index.tsx +1 -1
  544. package/src/box-control/linked-button.tsx +1 -1
  545. package/src/button/README.md +32 -6
  546. package/src/button/index.tsx +1 -1
  547. package/src/button-group/README.md +0 -6
  548. package/src/card/card/README.md +1 -1
  549. package/src/checkbox-control/README.md +3 -10
  550. package/src/checkbox-control/index.tsx +8 -6
  551. package/src/checkbox-control/test/__snapshots__/index.tsx.snap +3 -8
  552. package/src/checkbox-control/test/index.tsx +7 -0
  553. package/src/checkbox-control/types.ts +3 -2
  554. package/src/color-palette/index.native.js +18 -7
  555. package/src/color-picker/color-copy-button.tsx +1 -1
  556. package/src/combobox-control/README.md +0 -6
  557. package/src/composite/test/index.tsx +576 -0
  558. package/src/context/wordpress-component.ts +11 -6
  559. package/src/custom-select-control/README.md +0 -6
  560. package/src/custom-select-control/test/index.js +367 -35
  561. package/src/custom-select-control-v2/index.tsx +13 -12
  562. package/src/date-time/date/styles.ts +3 -3
  563. package/src/date-time/time/timezone.tsx +15 -3
  564. package/src/dimension-control/index.tsx +2 -0
  565. package/src/dimension-control/test/__snapshots__/index.test.js.snap +2 -2
  566. package/src/dimension-control/types.ts +6 -0
  567. package/src/dropdown-menu/README.md +0 -5
  568. package/src/dropdown-menu-v2/README.md +75 -136
  569. package/src/dropdown-menu-v2/index.tsx +321 -231
  570. package/src/dropdown-menu-v2/stories/index.story.tsx +522 -126
  571. package/src/dropdown-menu-v2/styles.ts +226 -151
  572. package/src/dropdown-menu-v2/test/index.tsx +480 -188
  573. package/src/dropdown-menu-v2/types.ts +98 -184
  574. package/src/duotone-picker/duotone-picker.tsx +7 -3
  575. package/src/focal-point-picker/controls.tsx +4 -0
  576. package/src/focal-point-picker/index.tsx +2 -0
  577. package/src/focal-point-picker/styles/focal-point-picker-style.ts +1 -1
  578. package/src/focal-point-picker/types.ts +7 -0
  579. package/src/font-size-picker/font-size-picker-select.tsx +2 -0
  580. package/src/font-size-picker/font-size-picker-toggle-group.tsx +9 -1
  581. package/src/font-size-picker/index.native.js +8 -2
  582. package/src/font-size-picker/index.tsx +15 -5
  583. package/src/font-size-picker/types.ts +8 -1
  584. package/src/form-toggle/README.md +0 -6
  585. package/src/form-toggle/style.scss +4 -2
  586. package/src/form-token-field/index.tsx +11 -7
  587. package/src/form-token-field/test/index.tsx +97 -0
  588. package/src/form-token-field/token.tsx +1 -0
  589. package/src/gradient-picker/index.tsx +2 -2
  590. package/src/index.native.js +6 -3
  591. package/src/input-control/styles/input-control-styles.tsx +10 -8
  592. package/src/input-control/types.ts +1 -1
  593. package/src/lock-unlock.js +10 -0
  594. package/src/menu-group/README.md +0 -8
  595. package/src/menu-items-choice/README.md +0 -7
  596. package/src/mobile/bottom-sheet/index.native.js +15 -1
  597. package/src/mobile/color-settings/palette.screen.native.js +7 -5
  598. package/src/mobile/global-styles-context/test/fixtures/theme.native.js +0 -20
  599. package/src/mobile/global-styles-context/test/utils.native.js +22 -0
  600. package/src/mobile/global-styles-context/utils.native.js +42 -19
  601. package/src/mobile/image/constants.js +1 -0
  602. package/src/mobile/image/index.native.js +55 -18
  603. package/src/mobile/image/style.native.scss +35 -9
  604. package/src/mobile/keyboard-aware-flat-list/index.android.js +50 -5
  605. package/src/mobile/keyboard-aware-flat-list/index.ios.js +65 -91
  606. package/src/mobile/keyboard-aware-flat-list/test/{use-scroll-to-text-input.native.js → use-scroll-to-section.native.js} +27 -25
  607. package/src/mobile/keyboard-aware-flat-list/test/use-scroll.native.js +71 -0
  608. package/src/mobile/keyboard-aware-flat-list/use-scroll-to-element.native.js +41 -0
  609. package/src/mobile/keyboard-aware-flat-list/{use-scroll-to-text-input.native.js → use-scroll-to-section.native.js} +22 -27
  610. package/src/mobile/keyboard-aware-flat-list/use-scroll.native.js +100 -0
  611. package/src/mobile/link-settings/style.native.scss +0 -17
  612. package/src/mobile/utils/get-px-from-css-unit.native.js +329 -0
  613. package/src/mobile/utils/test/get-px-from-css-unit.native.js +172 -0
  614. package/src/modal/README.md +0 -6
  615. package/src/modal/index.tsx +18 -16
  616. package/src/modal/test/index.tsx +90 -1
  617. package/src/navigation/menu/menu-title.tsx +1 -1
  618. package/src/navigator/navigator-provider/component.tsx +3 -4
  619. package/src/navigator/navigator-screen/component.tsx +15 -93
  620. package/src/navigator/styles.ts +71 -0
  621. package/src/navigator/test/index.tsx +0 -64
  622. package/src/notice/README.md +0 -6
  623. package/src/number-control/README.md +2 -2
  624. package/src/number-control/index.tsx +4 -8
  625. package/src/number-control/types.ts +1 -1
  626. package/src/palette-edit/index.tsx +14 -43
  627. package/src/palette-edit/style.scss +2 -2
  628. package/src/panel/README.md +0 -6
  629. package/src/private-apis.native.js +13 -0
  630. package/src/private-apis.ts +12 -37
  631. package/src/query-controls/author-select.tsx +2 -0
  632. package/src/query-controls/category-select.tsx +2 -0
  633. package/src/query-controls/index.tsx +6 -1
  634. package/src/query-controls/types.ts +9 -0
  635. package/src/radio-control/README.md +0 -6
  636. package/src/radio-control/index.tsx +4 -1
  637. package/src/radio-control/style.scss +29 -2
  638. package/src/radio-group/README.md +0 -6
  639. package/src/range-control/README.md +1 -9
  640. package/src/range-control/index.tsx +1 -1
  641. package/src/search-control/README.md +1 -5
  642. package/src/select-control/README.md +0 -6
  643. package/src/select-control/styles/select-control-styles.ts +10 -28
  644. package/src/slot-fill/index.tsx +5 -2
  645. package/src/slot-fill/types.ts +5 -0
  646. package/src/snackbar/README.md +0 -6
  647. package/src/snackbar/stories/index.story.tsx +7 -5
  648. package/src/snackbar/style.scss +4 -3
  649. package/src/snackbar/types.ts +2 -1
  650. package/src/spacer/README.md +0 -2
  651. package/src/spinner/README.md +2 -0
  652. package/src/tab-panel/README.md +0 -5
  653. package/src/tab-panel/test/index.tsx +39 -56
  654. package/src/tabs/README.md +4 -4
  655. package/src/tabs/index.tsx +22 -1
  656. package/src/tabs/stories/index.story.tsx +48 -48
  657. package/src/tabs/styles.ts +7 -1
  658. package/src/tabs/tab.tsx +3 -3
  659. package/src/tabs/tabpanel.tsx +13 -8
  660. package/src/tabs/test/index.tsx +236 -106
  661. package/src/tabs/types.ts +8 -3
  662. package/src/text-control/README.md +0 -6
  663. package/src/textarea-control/README.md +0 -6
  664. package/src/toggle-group-control/test/__snapshots__/index.tsx.snap +12 -16
  665. package/src/toggle-group-control/test/index.tsx +107 -41
  666. package/src/toggle-group-control/toggle-group-control/component.tsx +5 -4
  667. package/src/toggle-group-control/toggle-group-control/styles.ts +13 -19
  668. package/src/toggle-group-control/toggle-group-control/utils.ts +15 -20
  669. package/src/toggle-group-control/toggle-group-control-option/README.md +1 -1
  670. package/src/toggle-group-control/toggle-group-control-option-base/README.md +1 -1
  671. package/src/toggle-group-control/toggle-group-control-option-base/styles.ts +3 -2
  672. package/src/toggle-group-control/toggle-group-control-option-icon/README.md +1 -1
  673. package/src/toolbar/toolbar/README.md +0 -6
  674. package/src/tools-panel/test/index.tsx +12 -20
  675. package/src/tools-panel/tools-panel/README.md +7 -0
  676. package/src/tools-panel/tools-panel/component.tsx +2 -0
  677. package/src/tools-panel/tools-panel-header/README.md +7 -0
  678. package/src/tools-panel/tools-panel-header/component.tsx +20 -13
  679. package/src/tools-panel/tools-panel-item/hook.ts +10 -21
  680. package/src/tools-panel/types.ts +9 -0
  681. package/src/tooltip/README.md +4 -0
  682. package/src/tooltip/index.tsx +48 -10
  683. package/src/tooltip/stories/index.story.tsx +18 -1
  684. package/src/tooltip/test/index.tsx +404 -254
  685. package/src/tooltip/types.ts +4 -0
  686. package/src/tree-grid/README.md +0 -4
  687. package/src/truncate/README.md +8 -0
  688. package/src/truncate/hook.ts +17 -10
  689. package/src/truncate/test/index.tsx +54 -27
  690. package/src/truncate/types.ts +4 -0
  691. package/src/unit-control/index.tsx +1 -1
  692. package/src/utils/strings.ts +30 -2
  693. package/src/utils/test/strings.js +96 -1
  694. package/tsconfig.tsbuildinfo +1 -1
  695. package/build/dropdown-menu-v2-ariakit/index.js +0 -256
  696. package/build/dropdown-menu-v2-ariakit/index.js.map +0 -1
  697. package/build/dropdown-menu-v2-ariakit/styles.js +0 -180
  698. package/build/dropdown-menu-v2-ariakit/styles.js.map +0 -1
  699. package/build/dropdown-menu-v2-ariakit/types.js +0 -6
  700. package/build/dropdown-menu-v2-ariakit/types.js.map +0 -1
  701. package/build/mobile/inserter-button/index.native.js +0 -98
  702. package/build/mobile/inserter-button/index.native.js.map +0 -1
  703. package/build/mobile/inserter-button/sparkles.js +0 -23
  704. package/build/mobile/inserter-button/sparkles.js.map +0 -1
  705. package/build/mobile/keyboard-aware-flat-list/use-scroll-to-text-input.native.js.map +0 -1
  706. package/build/mobile/link-settings/image-link-destinations-screen.native.js +0 -119
  707. package/build/mobile/link-settings/image-link-destinations-screen.native.js.map +0 -1
  708. package/build-module/dropdown-menu-v2-ariakit/index.js +0 -237
  709. package/build-module/dropdown-menu-v2-ariakit/index.js.map +0 -1
  710. package/build-module/dropdown-menu-v2-ariakit/styles.js +0 -165
  711. package/build-module/dropdown-menu-v2-ariakit/styles.js.map +0 -1
  712. package/build-module/dropdown-menu-v2-ariakit/types.js +0 -2
  713. package/build-module/dropdown-menu-v2-ariakit/types.js.map +0 -1
  714. package/build-module/mobile/inserter-button/index.native.js +0 -89
  715. package/build-module/mobile/inserter-button/index.native.js.map +0 -1
  716. package/build-module/mobile/inserter-button/sparkles.js +0 -15
  717. package/build-module/mobile/inserter-button/sparkles.js.map +0 -1
  718. package/build-module/mobile/keyboard-aware-flat-list/use-scroll-to-text-input.native.js.map +0 -1
  719. package/build-module/mobile/link-settings/image-link-destinations-screen.native.js +0 -110
  720. package/build-module/mobile/link-settings/image-link-destinations-screen.native.js.map +0 -1
  721. package/build-types/dropdown-menu-v2-ariakit/index.d.ts +0 -20
  722. package/build-types/dropdown-menu-v2-ariakit/index.d.ts.map +0 -1
  723. package/build-types/dropdown-menu-v2-ariakit/stories/index.story.d.ts +0 -16
  724. package/build-types/dropdown-menu-v2-ariakit/stories/index.story.d.ts.map +0 -1
  725. package/build-types/dropdown-menu-v2-ariakit/styles.d.ts +0 -96
  726. package/build-types/dropdown-menu-v2-ariakit/styles.d.ts.map +0 -1
  727. package/build-types/dropdown-menu-v2-ariakit/test/index.d.ts.map +0 -1
  728. package/build-types/dropdown-menu-v2-ariakit/types.d.ts +0 -168
  729. package/build-types/dropdown-menu-v2-ariakit/types.d.ts.map +0 -1
  730. package/build-types/mobile/inserter-button/sparkles.d.ts +0 -3
  731. package/build-types/mobile/inserter-button/sparkles.d.ts.map +0 -1
  732. package/src/dropdown-menu-v2-ariakit/README.md +0 -331
  733. package/src/dropdown-menu-v2-ariakit/index.tsx +0 -383
  734. package/src/dropdown-menu-v2-ariakit/stories/index.story.tsx +0 -617
  735. package/src/dropdown-menu-v2-ariakit/styles.ts +0 -333
  736. package/src/dropdown-menu-v2-ariakit/test/index.tsx +0 -1108
  737. package/src/dropdown-menu-v2-ariakit/types.ts +0 -179
  738. package/src/mobile/inserter-button/README.md +0 -62
  739. package/src/mobile/inserter-button/index.native.js +0 -116
  740. package/src/mobile/inserter-button/sparkles.js +0 -15
  741. package/src/mobile/inserter-button/style.native.scss +0 -72
  742. package/src/mobile/link-settings/image-link-destinations-screen.native.js +0 -152
  743. /package/build-types/{dropdown-menu-v2-ariakit → composite}/test/index.d.ts +0 -0
@@ -0,0 +1,71 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+
5
+ import { renderHook } from 'test/helpers';
6
+
7
+ /**
8
+ * Internal dependencies
9
+ */
10
+ import useScroll from '../use-scroll';
11
+
12
+ // Mock Reanimated with default mock
13
+ jest.mock( 'react-native-reanimated', () => ( {
14
+ ...require( 'react-native-reanimated/mock' ),
15
+ useAnimatedScrollHandler: jest.fn( ( args ) => args ),
16
+ } ) );
17
+
18
+ describe( 'useScroll', () => {
19
+ it( 'scrolls using current scroll position', () => {
20
+ const sectionY = 50;
21
+ const sectionHeight = 10;
22
+ const scrollViewMeasurements = { x: 0, y: 0, width: 0, height: 600 };
23
+ const extraScrollHeight = 50;
24
+ const scrollEnabled = true;
25
+ const shouldPreventAutomaticScroll = false;
26
+
27
+ const scrollTo = jest.fn();
28
+ const measureInWindow = jest.fn( ( callback ) =>
29
+ callback( ...Object.values( scrollViewMeasurements ) )
30
+ );
31
+ const scrollRef = { scrollTo, measureInWindow };
32
+ const onScroll = jest.fn();
33
+ const onSizeChange = jest.fn();
34
+
35
+ const { result } = renderHook( () =>
36
+ useScroll( {
37
+ scrollEnabled,
38
+ shouldPreventAutomaticScroll,
39
+ onScroll,
40
+ onSizeChange,
41
+ extraScrollHeight,
42
+ } )
43
+ );
44
+ const {
45
+ scrollViewRef,
46
+ onContentSizeChange,
47
+ scrollHandler,
48
+ scrollToSection,
49
+ } = result.current;
50
+
51
+ // Assign ref
52
+ scrollViewRef.current = scrollRef;
53
+
54
+ // Check content size changes
55
+ onContentSizeChange();
56
+ expect( measureInWindow ).toHaveBeenCalled();
57
+ expect( onSizeChange ).toHaveBeenCalled();
58
+
59
+ // Set up initial scroll offset
60
+ scrollHandler.onScroll( { contentOffset: { y: 150 } } );
61
+
62
+ // Scroll to section
63
+ scrollToSection( sectionY, sectionHeight );
64
+
65
+ // Assert
66
+ expect( scrollTo ).toHaveBeenCalledWith( {
67
+ y: sectionY,
68
+ animated: true,
69
+ } );
70
+ } );
71
+ } );
@@ -0,0 +1,41 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { useCallback } from '@wordpress/element';
5
+
6
+ /** @typedef {import('@wordpress/element').RefObject} RefObject */
7
+ /**
8
+ * Hook to scroll to a specified element by taking into account the Keyboard
9
+ * and the Header.
10
+ *
11
+ * @param {RefObject} scrollViewRef Scroll view reference.
12
+ * @param {Function} scrollToSection Function to scroll.
13
+ * @return {Function[]} Function to scroll to an element.
14
+ */
15
+ export default function useScrollToElement( scrollViewRef, scrollToSection ) {
16
+ /**
17
+ * Function to scroll to an element.
18
+ *
19
+ * @param {RefObject} elementRef Ref of the element.
20
+ */
21
+ const scrollToElement = useCallback(
22
+ ( elementRef ) => {
23
+ if ( ! scrollViewRef.current || ! elementRef ) {
24
+ return;
25
+ }
26
+
27
+ elementRef.current.measureLayout(
28
+ scrollViewRef.current,
29
+ ( _x, y, _width, height ) => {
30
+ if ( height || y ) {
31
+ scrollToSection( Math.round( y ), height );
32
+ }
33
+ },
34
+ () => {}
35
+ );
36
+ },
37
+ [ scrollViewRef, scrollToSection ]
38
+ );
39
+
40
+ return [ scrollToElement ];
41
+ }
@@ -8,24 +8,21 @@ import { useSafeAreaInsets } from 'react-native-safe-area-context';
8
8
  */
9
9
  import { useCallback } from '@wordpress/element';
10
10
 
11
- const DEFAULT_FONT_SIZE = 16;
12
-
13
11
  /** @typedef {import('@wordpress/element').RefObject} RefObject */
14
12
  /** @typedef {import('react-native-reanimated').SharedValue} SharedValue */
15
13
  /**
16
- * Hook to scroll to the currently focused TextInput
17
- * depending on where the caret is placed taking into
18
- * account the Keyboard and the Header.
14
+ * Hook to scroll to a specified section by taking into account the Keyboard
15
+ * and the Header.
19
16
  *
20
17
  * @param {number} extraScrollHeight Extra space to not overlap the content.
21
18
  * @param {number} keyboardOffset Keyboard space offset.
22
19
  * @param {boolean} scrollEnabled Whether the scroll is enabled or not.
23
20
  * @param {RefObject} scrollViewMeasurements ScrollView Layout measurements.
24
- * @param {RefObject} scrollViewRef ScrollView reference.
21
+ * @param {RefObject} scrollViewRef Scroll view reference.
25
22
  * @param {SharedValue} scrollViewYOffset Current offset position of the ScrollView.
26
- * @return {Function[]} Function to scroll to the current TextInput's offset.
23
+ * @return {Function[]} Function to scroll to a section.
27
24
  */
28
- export default function useScrollToTextInput(
25
+ export default function useScrollToSection(
29
26
  extraScrollHeight,
30
27
  keyboardOffset,
31
28
  scrollEnabled,
@@ -37,33 +34,31 @@ export default function useScrollToTextInput(
37
34
  const insets = top + bottom;
38
35
 
39
36
  /**
40
- * Function to scroll to the current TextInput's offset.
37
+ * Function to scroll to a section.
41
38
  *
42
- * @param {Object} caret The caret position data of the currently focused TextInput.
43
- * @param {number} caret.caretHeight The height of the caret.
44
- * @param {number} textInputOffset The offset calculated with the caret's Y coordinate + the
45
- * TextInput's Y coord or height value.
39
+ * @param {Object} section Section data to scroll to.
40
+ * @param {number} section.y Y-coordinate of of the section.
41
+ * @param {number} section.height Height of the section.
46
42
  */
47
- const scrollToTextInputOffset = useCallback(
48
- ( caret, textInputOffset ) => {
49
- const { caretHeight = DEFAULT_FONT_SIZE } = caret ?? {};
50
-
43
+ const scrollToSection = useCallback(
44
+ ( sectionY, sectionHeight ) => {
51
45
  if (
52
46
  ! scrollViewRef.current ||
53
47
  ! scrollEnabled ||
54
- ! scrollViewMeasurements.current
48
+ ! scrollViewMeasurements
55
49
  ) {
56
50
  return;
57
51
  }
52
+
58
53
  const currentScrollViewYOffset = Math.max(
59
54
  0,
60
55
  scrollViewYOffset.value
61
56
  );
62
57
 
63
- // Scroll up.
64
- if ( textInputOffset < currentScrollViewYOffset ) {
58
+ // Scroll to the top of the section.
59
+ if ( sectionY < currentScrollViewYOffset ) {
65
60
  scrollViewRef.current.scrollTo( {
66
- y: textInputOffset,
61
+ y: sectionY,
67
62
  animated: true,
68
63
  } );
69
64
  return;
@@ -72,7 +67,7 @@ export default function useScrollToTextInput(
72
67
  const availableScreenSpace = Math.abs(
73
68
  Math.floor(
74
69
  scrollViewMeasurements.current.height -
75
- ( keyboardOffset + extraScrollHeight + caretHeight )
70
+ ( keyboardOffset + extraScrollHeight + sectionHeight )
76
71
  )
77
72
  );
78
73
  const maxOffset = Math.floor(
@@ -80,12 +75,12 @@ export default function useScrollToTextInput(
80
75
  );
81
76
 
82
77
  const isAtTheTop =
83
- textInputOffset < scrollViewMeasurements.current.y + insets;
78
+ sectionY < scrollViewMeasurements.current.y + insets;
84
79
 
85
- // Scroll down.
86
- if ( textInputOffset > maxOffset && ! isAtTheTop ) {
80
+ // Scroll to the bottom of the section.
81
+ if ( sectionY > maxOffset && ! isAtTheTop ) {
87
82
  scrollViewRef.current.scrollTo( {
88
- y: textInputOffset - availableScreenSpace,
83
+ y: sectionY - availableScreenSpace,
89
84
  animated: true,
90
85
  } );
91
86
  }
@@ -101,5 +96,5 @@ export default function useScrollToTextInput(
101
96
  ]
102
97
  );
103
98
 
104
- return [ scrollToTextInputOffset ];
99
+ return [ scrollToSection ];
105
100
  }
@@ -0,0 +1,100 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+
5
+ import { useWindowDimensions } from 'react-native';
6
+ import {
7
+ useAnimatedScrollHandler,
8
+ useSharedValue,
9
+ } from 'react-native-reanimated';
10
+
11
+ /**
12
+ * WordPress dependencies
13
+ */
14
+ import { useCallback, useEffect, useRef } from '@wordpress/element';
15
+
16
+ /**
17
+ * Internal dependencies
18
+ */
19
+ import useKeyboardOffset from './use-keyboard-offset';
20
+ import useScrollToSection from './use-scroll-to-section';
21
+ import useScrollToElement from './use-scroll-to-element';
22
+
23
+ export default function useScroll( {
24
+ scrollEnabled,
25
+ shouldPreventAutomaticScroll,
26
+ onScroll,
27
+ onSizeChange,
28
+ extraScrollHeight,
29
+ } ) {
30
+ const scrollViewRef = useRef();
31
+ const scrollViewMeasurements = useRef();
32
+ const scrollViewYOffset = useSharedValue( -1 );
33
+ const lastScrollTo = useRef( {
34
+ clientId: null,
35
+ } );
36
+
37
+ const { height: windowHeight, width: windowWidth } = useWindowDimensions();
38
+ const isLandscape = windowWidth >= windowHeight;
39
+
40
+ const [ keyboardOffset ] = useKeyboardOffset(
41
+ scrollEnabled,
42
+ shouldPreventAutomaticScroll
43
+ );
44
+
45
+ const scrollHandler = useAnimatedScrollHandler( {
46
+ onScroll: ( event ) => {
47
+ const { contentOffset } = event;
48
+ scrollViewYOffset.value = contentOffset.y;
49
+ onScroll( event );
50
+ },
51
+ } );
52
+
53
+ // When the orientation changes, the ScrollView measurements
54
+ // need to be re-calculated.
55
+ useEffect( () => {
56
+ scrollViewMeasurements.current = null;
57
+ }, [ isLandscape ] );
58
+
59
+ const [ scrollToSection ] = useScrollToSection(
60
+ extraScrollHeight,
61
+ keyboardOffset,
62
+ scrollEnabled,
63
+ scrollViewMeasurements,
64
+ scrollViewRef,
65
+ scrollViewYOffset
66
+ );
67
+ const [ scrollToElement ] = useScrollToElement(
68
+ scrollViewRef,
69
+ scrollToSection
70
+ );
71
+
72
+ const measureScrollView = useCallback( () => {
73
+ if ( scrollViewRef.current ) {
74
+ scrollViewRef.current.measureInWindow( ( _x, y, width, height ) => {
75
+ scrollViewMeasurements.current = { y, width, height };
76
+ } );
77
+ }
78
+ }, [ scrollViewRef ] );
79
+
80
+ const onContentSizeChange = useCallback( () => {
81
+ if ( onSizeChange ) {
82
+ onSizeChange();
83
+ }
84
+
85
+ // Sets the first values when the content size changes.
86
+ if ( ! scrollViewMeasurements.current ) {
87
+ measureScrollView();
88
+ }
89
+ }, [ measureScrollView, onSizeChange ] );
90
+
91
+ return {
92
+ scrollViewRef,
93
+ scrollHandler,
94
+ keyboardOffset,
95
+ scrollToSection,
96
+ scrollToElement,
97
+ onContentSizeChange,
98
+ lastScrollTo,
99
+ };
100
+ }
@@ -2,20 +2,3 @@
2
2
  padding-left: 0;
3
3
  padding-right: 0;
4
4
  }
5
-
6
- // used in both light and dark modes
7
- .placeholderTextColor {
8
- color: #87a6bc;
9
- }
10
-
11
- .optionIcon {
12
- color: $blue-50;
13
- }
14
-
15
- .optionIconDark {
16
- color: $blue-30;
17
- }
18
-
19
- .unselectedOptionIcon {
20
- opacity: 0;
21
- }
@@ -0,0 +1,329 @@
1
+ /**
2
+ * Converts string to object { value, unit }.
3
+ *
4
+ * @param {string} cssUnit
5
+ * @return {Object} parsedUnit
6
+ */
7
+ function parseUnit( cssUnit ) {
8
+ const match = cssUnit
9
+ ?.trim()
10
+ .match(
11
+ /^(0?[-.]?\d*\.?\d+)(r?e[m|x]|v[h|w|min|max]+|p[x|t|c]|[c|m]m|%|in|ch|Q|lh)$/
12
+ );
13
+ if ( ! isNaN( cssUnit ) && ! isNaN( parseFloat( cssUnit ) ) ) {
14
+ return { value: parseFloat( cssUnit ), unit: 'px' };
15
+ }
16
+ return match
17
+ ? { value: parseFloat( match[ 1 ] ) || match[ 1 ], unit: match[ 2 ] }
18
+ : { value: cssUnit, unit: undefined };
19
+ }
20
+ /**
21
+ * Evaluate a math expression.
22
+ *
23
+ * @param {string} expression
24
+ * @return {number} evaluated expression.
25
+ */
26
+ function calculate( expression ) {
27
+ try {
28
+ return Function( `'use strict'; return (${ expression })` )();
29
+ } catch ( err ) {
30
+ return null;
31
+ }
32
+ }
33
+
34
+ /**
35
+ * Calculates the css function value for the supported css functions such as max, min, clamp and calc.
36
+ *
37
+ * @param {string} functionUnitValue string should be in a particular format (for example min(12px,12px) ) no nested loops.
38
+ * @param {Object} options
39
+ * @return {string} unit containing the unit in PX.
40
+ */
41
+ function getFunctionUnitValue( functionUnitValue, options ) {
42
+ const functionUnit = functionUnitValue.split( /[(),]/g ).filter( Boolean );
43
+
44
+ const units = functionUnit
45
+ .slice( 1 )
46
+ .map( ( unit ) => parseUnit( getPxFromCssUnit( unit, options ) ).value )
47
+ .filter( Boolean );
48
+
49
+ switch ( functionUnit[ 0 ] ) {
50
+ case 'min':
51
+ return Math.min( ...units ) + 'px';
52
+ case 'max':
53
+ return Math.max( ...units ) + 'px';
54
+ case 'clamp':
55
+ if ( units.length !== 3 ) {
56
+ return null;
57
+ }
58
+ if ( units[ 1 ] < units[ 0 ] ) {
59
+ return units[ 0 ] + 'px';
60
+ }
61
+ if ( units[ 1 ] > units[ 2 ] ) {
62
+ return units[ 2 ] + 'px';
63
+ }
64
+ return units[ 1 ] + 'px';
65
+ case 'calc':
66
+ return units[ 0 ] + 'px';
67
+ }
68
+ }
69
+
70
+ /**
71
+ * Take a css function such as min, max, calc, clamp and returns parsedUnit
72
+ *
73
+ * How this works for the nested function is that it first replaces the inner function call.
74
+ * Then it tackles the outer onces.
75
+ * So for example: min( max(25px, 35px), 40px )
76
+ * in the first pass we would replace max(25px, 35px) with 35px.
77
+ * then we would try to evaluate min( 35px, 40px )
78
+ * and then finally return 35px.
79
+ *
80
+ * @param {string} cssUnit
81
+ * @return {Object} parsedUnit object.
82
+ */
83
+ function parseUnitFunction( cssUnit ) {
84
+ while ( true ) {
85
+ const currentCssUnit = cssUnit;
86
+ const regExp = /(max|min|calc|clamp)\(([^()]*)\)/g;
87
+ const matches = regExp.exec( cssUnit ) || [];
88
+ if ( matches[ 0 ] ) {
89
+ const functionUnitValue = getFunctionUnitValue( matches[ 0 ] );
90
+ cssUnit = cssUnit.replace( matches[ 0 ], functionUnitValue );
91
+ }
92
+
93
+ // If the unit hasn't been modified or we have a single value break free.
94
+ if ( cssUnit === currentCssUnit || parseFloat( cssUnit ) ) {
95
+ break;
96
+ }
97
+ }
98
+
99
+ return parseUnit( cssUnit );
100
+ }
101
+ /**
102
+ * Return true if we think this is a math expression.
103
+ *
104
+ * @param {string} cssUnit the cssUnit value being evaluted.
105
+ * @return {boolean} Whether the cssUnit is a math expression.
106
+ */
107
+ function isMathExpression( cssUnit ) {
108
+ for ( let i = 0; i < cssUnit.length; i++ ) {
109
+ if ( [ '+', '-', '/', '*' ].includes( cssUnit[ i ] ) ) {
110
+ return true;
111
+ }
112
+ }
113
+ return false;
114
+ }
115
+ /**
116
+ * Evaluates the math expression and return a px value.
117
+ *
118
+ * @param {string} cssUnit the cssUnit value being evaluted.
119
+ * @return {string} return a converfted value to px.
120
+ */
121
+ function evalMathExpression( cssUnit ) {
122
+ let errorFound = false;
123
+ // Convert every part of the expression to px values.
124
+ // The following regex matches numbers that have a following unit
125
+ // E.g. 5.25rem, 1vw
126
+ const cssUnitsBits = cssUnit.match( /\d+\.?\d*[a-zA-Z]+|\.\d+[a-zA-Z]+/g );
127
+ if ( cssUnitsBits ) {
128
+ for ( const unit of cssUnitsBits ) {
129
+ // Standardize the unit to px and extract the value.
130
+ const parsedUnit = parseUnit( getPxFromCssUnit( unit ) );
131
+ if ( ! parseFloat( parsedUnit.value ) ) {
132
+ errorFound = true;
133
+ // End early since we are dealing with a null value.
134
+ break;
135
+ }
136
+ cssUnit = cssUnit.replace( unit, parsedUnit.value );
137
+ }
138
+ } else {
139
+ errorFound = true;
140
+ }
141
+
142
+ // For mixed math expressions wrapped within CSS expressions
143
+ const expressionsMatches = cssUnit.match( /(max|min|clamp)/g );
144
+ if ( ! errorFound && expressionsMatches ) {
145
+ const values = cssUnit.split( ',' );
146
+ for ( const currentValue of values ) {
147
+ // Check for nested calc() and remove them to calculate the value.
148
+ const rawCurrentValue = currentValue.replace( /\s|calc/g, '' );
149
+
150
+ if ( isMathExpression( rawCurrentValue ) ) {
151
+ const calculatedExpression = calculate( rawCurrentValue );
152
+
153
+ if ( calculatedExpression ) {
154
+ const calculatedValue =
155
+ calculatedExpression.toFixed( 0 ) + 'px';
156
+ cssUnit = cssUnit.replace( currentValue, calculatedValue );
157
+ }
158
+ }
159
+ }
160
+ const parsedValue = parseUnitFunction( cssUnit );
161
+ return ! parsedValue ? null : parsedValue.value + parsedValue.unit;
162
+ }
163
+
164
+ if ( errorFound ) {
165
+ return null;
166
+ }
167
+
168
+ const calculatedResult = calculate( cssUnit );
169
+ return calculatedResult ? calculatedResult.toFixed( 0 ) + 'px' : null;
170
+ }
171
+
172
+ /**
173
+ * Convert a parsedUnit object to px value.
174
+ *
175
+ * @param {Object} parsedUnit
176
+ * @param {Object} options
177
+ * @return {string} or {null} returns the converted with in a px value format.
178
+ */
179
+ function convertParsedUnitToPx( parsedUnit, options ) {
180
+ const PIXELS_PER_INCH = 96;
181
+ const ONE_PERCENT = 0.01;
182
+
183
+ const defaultProperties = {
184
+ fontSize: 16,
185
+ lineHeight: 16,
186
+ width: 375,
187
+ height: 812,
188
+ type: 'font',
189
+ };
190
+
191
+ const setOptions = Object.assign( {}, defaultProperties, options );
192
+
193
+ const relativeUnits = {
194
+ em: setOptions.fontSize,
195
+ rem: setOptions.fontSize,
196
+ vh: setOptions.height * ONE_PERCENT,
197
+ vw: setOptions.width * ONE_PERCENT,
198
+ vmin:
199
+ ( setOptions.width < setOptions.height
200
+ ? setOptions.width
201
+ : setOptions.height ) * ONE_PERCENT,
202
+ vmax:
203
+ ( setOptions.width > setOptions.height
204
+ ? setOptions.width
205
+ : setOptions.height ) * ONE_PERCENT,
206
+ '%':
207
+ ( setOptions.type === 'font'
208
+ ? setOptions.fontSize
209
+ : setOptions.width ) * ONE_PERCENT,
210
+ ch: 8, // The advance measure (width) of the glyph "0" of the element's font. Approximate
211
+ ex: 7.15625, // X-height of the element's font. Approximate.
212
+ lh: setOptions.lineHeight,
213
+ };
214
+ relativeUnits.svw = relativeUnits.vmin;
215
+ relativeUnits.lvw = relativeUnits.vmax;
216
+ relativeUnits.dvw = relativeUnits.vw;
217
+ relativeUnits.svh = relativeUnits.vmin;
218
+ relativeUnits.lvh = relativeUnits.vmax;
219
+ relativeUnits.dvh = relativeUnits.vh;
220
+ relativeUnits.vi = relativeUnits.vh;
221
+ relativeUnits.svi = relativeUnits.vmin;
222
+ relativeUnits.lvi = relativeUnits.vmax;
223
+ relativeUnits.dvi = relativeUnits.vw;
224
+ relativeUnits.vb = relativeUnits.vh;
225
+ relativeUnits.svb = relativeUnits.vmin;
226
+ relativeUnits.lvb = relativeUnits.vmax;
227
+ relativeUnits.dvb = relativeUnits.vh;
228
+ relativeUnits.svmin = relativeUnits.vmin;
229
+ relativeUnits.lvmin = relativeUnits.vmin;
230
+ relativeUnits.dvmin = relativeUnits.vmin;
231
+ relativeUnits.svmax = relativeUnits.vmax;
232
+ relativeUnits.lvmax = relativeUnits.vmax;
233
+ relativeUnits.dvmax = relativeUnits.vmax;
234
+
235
+ const absoluteUnits = {
236
+ in: PIXELS_PER_INCH,
237
+ cm: PIXELS_PER_INCH / 2.54,
238
+ mm: PIXELS_PER_INCH / 25.4,
239
+ pt: PIXELS_PER_INCH / 72,
240
+ pc: PIXELS_PER_INCH / 6,
241
+ px: 1,
242
+ Q: PIXELS_PER_INCH / 2.54 / 40,
243
+ };
244
+
245
+ if ( relativeUnits[ parsedUnit.unit ] ) {
246
+ return (
247
+ ( relativeUnits[ parsedUnit.unit ] * parsedUnit.value ).toFixed(
248
+ 0
249
+ ) + 'px'
250
+ );
251
+ }
252
+
253
+ if ( absoluteUnits[ parsedUnit.unit ] ) {
254
+ return (
255
+ ( absoluteUnits[ parsedUnit.unit ] * parsedUnit.value ).toFixed(
256
+ 0
257
+ ) + 'px'
258
+ );
259
+ }
260
+
261
+ return null;
262
+ }
263
+
264
+ /**
265
+ * Returns the px value of a cssUnit.
266
+ *
267
+ * @param {string} cssUnit
268
+ * @param {Object} options
269
+ * @return {string} returns the cssUnit value in a simple px format.
270
+ */
271
+ export function getPxFromCssUnit( cssUnit, options = {} ) {
272
+ if ( Number.isFinite( cssUnit ) ) {
273
+ return cssUnit.toFixed( 0 ) + 'px';
274
+ }
275
+ if ( cssUnit === undefined ) {
276
+ return null;
277
+ }
278
+ let parsedUnit = parseUnit( cssUnit );
279
+
280
+ if ( ! parsedUnit.unit ) {
281
+ parsedUnit = parseUnitFunction( cssUnit );
282
+ }
283
+
284
+ if ( isMathExpression( cssUnit ) && ! parsedUnit.unit ) {
285
+ return evalMathExpression( cssUnit );
286
+ }
287
+
288
+ return convertParsedUnitToPx( parsedUnit, options );
289
+ }
290
+
291
+ // Use simple cache.
292
+ const cache = {};
293
+ /**
294
+ * Returns the px value of a cssUnit. The memoized version of getPxFromCssUnit;
295
+ *
296
+ * @param {string} cssUnit
297
+ * @param {Object} options
298
+ * @return {string} returns the cssUnit value in a simple px format.
299
+ */
300
+ function memoizedGetPxFromCssUnit( cssUnit, options = {} ) {
301
+ const hash = cssUnit + hashOptions( options );
302
+
303
+ if ( ! cache[ hash ] ) {
304
+ cache[ hash ] = getPxFromCssUnit( cssUnit, options );
305
+ }
306
+ return cache[ hash ];
307
+ }
308
+
309
+ function hashOptions( options ) {
310
+ let hash = '';
311
+ if ( options.hasOwnProperty( 'fontSize' ) ) {
312
+ hash = ':' + options.width;
313
+ }
314
+ if ( options.hasOwnProperty( 'lineHeight' ) ) {
315
+ hash = ':' + options.lineHeight;
316
+ }
317
+ if ( options.hasOwnProperty( 'width' ) ) {
318
+ hash = ':' + options.width;
319
+ }
320
+ if ( options.hasOwnProperty( 'height' ) ) {
321
+ hash = ':' + options.height;
322
+ }
323
+ if ( options.hasOwnProperty( 'type' ) ) {
324
+ hash = ':' + options.type;
325
+ }
326
+ return hash;
327
+ }
328
+
329
+ export default memoizedGetPxFromCssUnit;