@wordpress/components 25.13.0 → 25.15.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 (656) hide show
  1. package/CHANGELOG.md +88 -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-picker/color-copy-button.js +1 -1
  26. package/build/color-picker/color-copy-button.js.map +1 -1
  27. package/build/context/wordpress-component.js.map +1 -1
  28. package/build/custom-select-control-v2/index.js +11 -10
  29. package/build/custom-select-control-v2/index.js.map +1 -1
  30. package/build/date-time/date/styles.js +8 -8
  31. package/build/date-time/date/styles.js.map +1 -1
  32. package/build/date-time/time/timezone.js +11 -2
  33. package/build/date-time/time/timezone.js.map +1 -1
  34. package/build/dimension-control/index.js +2 -0
  35. package/build/dimension-control/index.js.map +1 -1
  36. package/build/dimension-control/types.js.map +1 -1
  37. package/build/dropdown-menu-v2/index.js +205 -159
  38. package/build/dropdown-menu-v2/index.js.map +1 -1
  39. package/build/dropdown-menu-v2/styles.js +86 -77
  40. package/build/dropdown-menu-v2/styles.js.map +1 -1
  41. package/build/dropdown-menu-v2/types.js.map +1 -1
  42. package/build/duotone-picker/duotone-picker.js +4 -3
  43. package/build/duotone-picker/duotone-picker.js.map +1 -1
  44. package/build/focal-point-picker/controls.js +5 -1
  45. package/build/focal-point-picker/controls.js.map +1 -1
  46. package/build/focal-point-picker/index.js +2 -0
  47. package/build/focal-point-picker/index.js.map +1 -1
  48. package/build/focal-point-picker/styles/focal-point-picker-style.js +15 -15
  49. package/build/focal-point-picker/styles/focal-point-picker-style.js.map +1 -1
  50. package/build/focal-point-picker/types.js.map +1 -1
  51. package/build/font-size-picker/font-size-picker-select.js +2 -0
  52. package/build/font-size-picker/font-size-picker-select.js.map +1 -1
  53. package/build/font-size-picker/font-size-picker-toggle-group.js +2 -0
  54. package/build/font-size-picker/font-size-picker-toggle-group.js.map +1 -1
  55. package/build/font-size-picker/index.js +10 -3
  56. package/build/font-size-picker/index.js.map +1 -1
  57. package/build/font-size-picker/index.native.js +6 -3
  58. package/build/font-size-picker/index.native.js.map +1 -1
  59. package/build/font-size-picker/types.js.map +1 -1
  60. package/build/form-token-field/index.js +10 -5
  61. package/build/form-token-field/index.js.map +1 -1
  62. package/build/form-token-field/token.js +1 -0
  63. package/build/form-token-field/token.js.map +1 -1
  64. package/build/gradient-picker/index.js +3 -2
  65. package/build/gradient-picker/index.js.map +1 -1
  66. package/build/index.native.js +20 -19
  67. package/build/index.native.js.map +1 -1
  68. package/build/input-control/styles/input-control-styles.js +32 -29
  69. package/build/input-control/styles/input-control-styles.js.map +1 -1
  70. package/build/input-control/types.js.map +1 -1
  71. package/build/lock-unlock.js +18 -0
  72. package/build/lock-unlock.js.map +1 -0
  73. package/build/mobile/bottom-sheet/index.native.js +8 -0
  74. package/build/mobile/bottom-sheet/index.native.js.map +1 -1
  75. package/build/mobile/global-styles-context/utils.native.js +39 -13
  76. package/build/mobile/global-styles-context/utils.native.js.map +1 -1
  77. package/build/mobile/image/constants.js +12 -0
  78. package/build/mobile/image/constants.js.map +1 -0
  79. package/build/mobile/image/index.native.js +26 -18
  80. package/build/mobile/image/index.native.js.map +1 -1
  81. package/build/mobile/keyboard-aware-flat-list/index.android.js +40 -8
  82. package/build/mobile/keyboard-aware-flat-list/index.android.js.map +1 -1
  83. package/build/mobile/keyboard-aware-flat-list/index.ios.js +44 -68
  84. package/build/mobile/keyboard-aware-flat-list/index.ios.js.map +1 -1
  85. package/build/mobile/keyboard-aware-flat-list/use-scroll-to-element.native.js +39 -0
  86. package/build/mobile/keyboard-aware-flat-list/use-scroll-to-element.native.js.map +1 -0
  87. package/build/mobile/keyboard-aware-flat-list/{use-scroll-to-text-input.native.js → use-scroll-to-section.native.js} +22 -29
  88. package/build/mobile/keyboard-aware-flat-list/use-scroll-to-section.native.js.map +1 -0
  89. package/build/mobile/keyboard-aware-flat-list/use-scroll.native.js +93 -0
  90. package/build/mobile/keyboard-aware-flat-list/use-scroll.native.js.map +1 -0
  91. package/build/mobile/utils/get-px-from-css-unit.native.js +302 -0
  92. package/build/mobile/utils/get-px-from-css-unit.native.js.map +1 -0
  93. package/build/modal/index.js +18 -13
  94. package/build/modal/index.js.map +1 -1
  95. package/build/navigation/menu/menu-title.js +1 -1
  96. package/build/navigation/menu/menu-title.js.map +1 -1
  97. package/build/navigator/navigator-provider/component.js +13 -15
  98. package/build/navigator/navigator-provider/component.js.map +1 -1
  99. package/build/navigator/navigator-screen/component.js +23 -63
  100. package/build/navigator/navigator-screen/component.js.map +1 -1
  101. package/build/navigator/styles.js +52 -0
  102. package/build/navigator/styles.js.map +1 -0
  103. package/build/number-control/index.js +4 -8
  104. package/build/number-control/index.js.map +1 -1
  105. package/build/number-control/types.js.map +1 -1
  106. package/build/palette-edit/index.js +15 -34
  107. package/build/palette-edit/index.js.map +1 -1
  108. package/build/private-apis.js +11 -26
  109. package/build/private-apis.js.map +1 -1
  110. package/build/private-apis.native.js +21 -0
  111. package/build/private-apis.native.js.map +1 -0
  112. package/build/query-controls/author-select.js +3 -1
  113. package/build/query-controls/author-select.js.map +1 -1
  114. package/build/query-controls/category-select.js +3 -1
  115. package/build/query-controls/category-select.js.map +1 -1
  116. package/build/query-controls/index.js +6 -1
  117. package/build/query-controls/index.js.map +1 -1
  118. package/build/query-controls/types.js.map +1 -1
  119. package/build/radio-control/index.js +1 -0
  120. package/build/radio-control/index.js.map +1 -1
  121. package/build/range-control/index.js +1 -1
  122. package/build/range-control/index.js.map +1 -1
  123. package/build/select-control/styles/select-control-styles.js +15 -25
  124. package/build/select-control/styles/select-control-styles.js.map +1 -1
  125. package/build/slot-fill/index.js +3 -2
  126. package/build/slot-fill/index.js.map +1 -1
  127. package/build/slot-fill/types.js.map +1 -1
  128. package/build/snackbar/types.js.map +1 -1
  129. package/build/tabs/index.js +18 -1
  130. package/build/tabs/index.js.map +1 -1
  131. package/build/tabs/styles.js +3 -3
  132. package/build/tabs/styles.js.map +1 -1
  133. package/build/tabs/tab.js +2 -2
  134. package/build/tabs/tab.js.map +1 -1
  135. package/build/tabs/tabpanel.js +11 -8
  136. package/build/tabs/tabpanel.js.map +1 -1
  137. package/build/tabs/types.js.map +1 -1
  138. package/build/toggle-group-control/toggle-group-control/component.js +4 -4
  139. package/build/toggle-group-control/toggle-group-control/component.js.map +1 -1
  140. package/build/toggle-group-control/toggle-group-control/styles.js +29 -15
  141. package/build/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  142. package/build/toggle-group-control/toggle-group-control/utils.js +17 -17
  143. package/build/toggle-group-control/toggle-group-control/utils.js.map +1 -1
  144. package/build/toggle-group-control/toggle-group-control-option-base/styles.js +9 -9
  145. package/build/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  146. package/build/tools-panel/tools-panel/component.js +3 -1
  147. package/build/tools-panel/tools-panel/component.js.map +1 -1
  148. package/build/tools-panel/tools-panel-header/component.js +9 -8
  149. package/build/tools-panel/tools-panel-header/component.js.map +1 -1
  150. package/build/tools-panel/tools-panel-item/hook.js +11 -11
  151. package/build/tools-panel/tools-panel-item/hook.js.map +1 -1
  152. package/build/tools-panel/types.js.map +1 -1
  153. package/build/tooltip/index.js +1 -1
  154. package/build/tooltip/index.js.map +1 -1
  155. package/build/truncate/hook.js +10 -4
  156. package/build/truncate/hook.js.map +1 -1
  157. package/build/truncate/types.js.map +1 -1
  158. package/build/unit-control/index.js +1 -1
  159. package/build/unit-control/index.js.map +1 -1
  160. package/build/utils/strings.js +34 -3
  161. package/build/utils/strings.js.map +1 -1
  162. package/build-module/base-control/index.js +16 -12
  163. package/build-module/base-control/index.js.map +1 -1
  164. package/build-module/border-box-control/border-box-control-linked-button/component.js +1 -1
  165. package/build-module/border-box-control/border-box-control-linked-button/component.js.map +1 -1
  166. package/build-module/border-control/border-control-dropdown/component.js +4 -2
  167. package/build-module/border-control/border-control-dropdown/component.js.map +1 -1
  168. package/build-module/border-control/border-control-dropdown/hook.js +3 -2
  169. package/build-module/border-control/border-control-dropdown/hook.js.map +1 -1
  170. package/build-module/border-control/border-control-style-picker/component.js +1 -1
  171. package/build-module/border-control/border-control-style-picker/component.js.map +1 -1
  172. package/build-module/border-control/styles.js +17 -17
  173. package/build-module/border-control/styles.js.map +1 -1
  174. package/build-module/box-control/index.js +1 -1
  175. package/build-module/box-control/index.js.map +1 -1
  176. package/build-module/box-control/linked-button.js +1 -1
  177. package/build-module/box-control/linked-button.js.map +1 -1
  178. package/build-module/button/index.js +1 -1
  179. package/build-module/button/index.js.map +1 -1
  180. package/build-module/checkbox-control/index.js +1 -1
  181. package/build-module/checkbox-control/index.js.map +1 -1
  182. package/build-module/checkbox-control/types.js.map +1 -1
  183. package/build-module/color-picker/color-copy-button.js +1 -1
  184. package/build-module/color-picker/color-copy-button.js.map +1 -1
  185. package/build-module/context/wordpress-component.js.map +1 -1
  186. package/build-module/custom-select-control-v2/index.js +11 -10
  187. package/build-module/custom-select-control-v2/index.js.map +1 -1
  188. package/build-module/date-time/date/styles.js +8 -8
  189. package/build-module/date-time/date/styles.js.map +1 -1
  190. package/build-module/date-time/time/timezone.js +11 -2
  191. package/build-module/date-time/time/timezone.js.map +1 -1
  192. package/build-module/dimension-control/index.js +2 -0
  193. package/build-module/dimension-control/index.js.map +1 -1
  194. package/build-module/dimension-control/types.js.map +1 -1
  195. package/build-module/dropdown-menu-v2/index.js +201 -154
  196. package/build-module/dropdown-menu-v2/index.js.map +1 -1
  197. package/build-module/dropdown-menu-v2/styles.js +68 -61
  198. package/build-module/dropdown-menu-v2/styles.js.map +1 -1
  199. package/build-module/dropdown-menu-v2/types.js.map +1 -1
  200. package/build-module/duotone-picker/duotone-picker.js +4 -3
  201. package/build-module/duotone-picker/duotone-picker.js.map +1 -1
  202. package/build-module/focal-point-picker/controls.js +5 -1
  203. package/build-module/focal-point-picker/controls.js.map +1 -1
  204. package/build-module/focal-point-picker/index.js +2 -0
  205. package/build-module/focal-point-picker/index.js.map +1 -1
  206. package/build-module/focal-point-picker/styles/focal-point-picker-style.js +15 -15
  207. package/build-module/focal-point-picker/styles/focal-point-picker-style.js.map +1 -1
  208. package/build-module/focal-point-picker/types.js.map +1 -1
  209. package/build-module/font-size-picker/font-size-picker-select.js +2 -0
  210. package/build-module/font-size-picker/font-size-picker-select.js.map +1 -1
  211. package/build-module/font-size-picker/font-size-picker-toggle-group.js +2 -0
  212. package/build-module/font-size-picker/font-size-picker-toggle-group.js.map +1 -1
  213. package/build-module/font-size-picker/index.js +10 -3
  214. package/build-module/font-size-picker/index.js.map +1 -1
  215. package/build-module/font-size-picker/index.native.js +5 -2
  216. package/build-module/font-size-picker/index.native.js.map +1 -1
  217. package/build-module/font-size-picker/types.js.map +1 -1
  218. package/build-module/form-token-field/index.js +10 -5
  219. package/build-module/form-token-field/index.js.map +1 -1
  220. package/build-module/form-token-field/token.js +1 -0
  221. package/build-module/form-token-field/token.js.map +1 -1
  222. package/build-module/gradient-picker/index.js +3 -2
  223. package/build-module/gradient-picker/index.js.map +1 -1
  224. package/build-module/index.native.js +6 -3
  225. package/build-module/index.native.js.map +1 -1
  226. package/build-module/input-control/styles/input-control-styles.js +31 -29
  227. package/build-module/input-control/styles/input-control-styles.js.map +1 -1
  228. package/build-module/input-control/types.js.map +1 -1
  229. package/build-module/lock-unlock.js +9 -0
  230. package/build-module/lock-unlock.js.map +1 -0
  231. package/build-module/mobile/bottom-sheet/index.native.js +9 -1
  232. package/build-module/mobile/bottom-sheet/index.native.js.map +1 -1
  233. package/build-module/mobile/global-styles-context/utils.native.js +38 -13
  234. package/build-module/mobile/global-styles-context/utils.native.js.map +1 -1
  235. package/build-module/mobile/image/constants.js +5 -0
  236. package/build-module/mobile/image/constants.js.map +1 -0
  237. package/build-module/mobile/image/index.native.js +25 -16
  238. package/build-module/mobile/image/index.native.js.map +1 -1
  239. package/build-module/mobile/keyboard-aware-flat-list/index.android.js +40 -6
  240. package/build-module/mobile/keyboard-aware-flat-list/index.android.js.map +1 -1
  241. package/build-module/mobile/keyboard-aware-flat-list/index.ios.js +46 -68
  242. package/build-module/mobile/keyboard-aware-flat-list/index.ios.js.map +1 -1
  243. package/build-module/mobile/keyboard-aware-flat-list/use-scroll-to-element.native.js +33 -0
  244. package/build-module/mobile/keyboard-aware-flat-list/use-scroll-to-element.native.js.map +1 -0
  245. package/build-module/mobile/keyboard-aware-flat-list/{use-scroll-to-text-input.native.js → use-scroll-to-section.native.js} +21 -27
  246. package/build-module/mobile/keyboard-aware-flat-list/use-scroll-to-section.native.js.map +1 -0
  247. package/build-module/mobile/keyboard-aware-flat-list/use-scroll.native.js +86 -0
  248. package/build-module/mobile/keyboard-aware-flat-list/use-scroll.native.js.map +1 -0
  249. package/build-module/mobile/utils/get-px-from-css-unit.native.js +294 -0
  250. package/build-module/mobile/utils/get-px-from-css-unit.native.js.map +1 -0
  251. package/build-module/modal/index.js +18 -13
  252. package/build-module/modal/index.js.map +1 -1
  253. package/build-module/navigation/menu/menu-title.js +1 -1
  254. package/build-module/navigation/menu/menu-title.js.map +1 -1
  255. package/build-module/navigator/navigator-provider/component.js +3 -16
  256. package/build-module/navigator/navigator-provider/component.js.map +1 -1
  257. package/build-module/navigator/navigator-screen/component.js +16 -70
  258. package/build-module/navigator/navigator-screen/component.js.map +1 -1
  259. package/build-module/navigator/styles.js +47 -0
  260. package/build-module/navigator/styles.js.map +1 -0
  261. package/build-module/number-control/index.js +4 -8
  262. package/build-module/number-control/index.js.map +1 -1
  263. package/build-module/number-control/types.js.map +1 -1
  264. package/build-module/palette-edit/index.js +14 -33
  265. package/build-module/palette-edit/index.js.map +1 -1
  266. package/build-module/private-apis.js +10 -23
  267. package/build-module/private-apis.js.map +1 -1
  268. package/build-module/private-apis.native.js +14 -0
  269. package/build-module/private-apis.native.js.map +1 -0
  270. package/build-module/query-controls/author-select.js +3 -1
  271. package/build-module/query-controls/author-select.js.map +1 -1
  272. package/build-module/query-controls/category-select.js +3 -1
  273. package/build-module/query-controls/category-select.js.map +1 -1
  274. package/build-module/query-controls/index.js +6 -1
  275. package/build-module/query-controls/index.js.map +1 -1
  276. package/build-module/query-controls/types.js.map +1 -1
  277. package/build-module/radio-control/index.js +1 -0
  278. package/build-module/radio-control/index.js.map +1 -1
  279. package/build-module/range-control/index.js +1 -1
  280. package/build-module/range-control/index.js.map +1 -1
  281. package/build-module/select-control/styles/select-control-styles.js +15 -25
  282. package/build-module/select-control/styles/select-control-styles.js.map +1 -1
  283. package/build-module/slot-fill/index.js +3 -2
  284. package/build-module/slot-fill/index.js.map +1 -1
  285. package/build-module/slot-fill/types.js.map +1 -1
  286. package/build-module/snackbar/types.js.map +1 -1
  287. package/build-module/tabs/index.js +18 -1
  288. package/build-module/tabs/index.js.map +1 -1
  289. package/build-module/tabs/styles.js +3 -3
  290. package/build-module/tabs/styles.js.map +1 -1
  291. package/build-module/tabs/tab.js +2 -2
  292. package/build-module/tabs/tab.js.map +1 -1
  293. package/build-module/tabs/tabpanel.js +11 -8
  294. package/build-module/tabs/tabpanel.js.map +1 -1
  295. package/build-module/tabs/types.js.map +1 -1
  296. package/build-module/toggle-group-control/toggle-group-control/component.js +4 -4
  297. package/build-module/toggle-group-control/toggle-group-control/component.js.map +1 -1
  298. package/build-module/toggle-group-control/toggle-group-control/styles.js +29 -15
  299. package/build-module/toggle-group-control/toggle-group-control/styles.js.map +1 -1
  300. package/build-module/toggle-group-control/toggle-group-control/utils.js +17 -17
  301. package/build-module/toggle-group-control/toggle-group-control/utils.js.map +1 -1
  302. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js +9 -9
  303. package/build-module/toggle-group-control/toggle-group-control-option-base/styles.js.map +1 -1
  304. package/build-module/tools-panel/tools-panel/component.js +3 -1
  305. package/build-module/tools-panel/tools-panel/component.js.map +1 -1
  306. package/build-module/tools-panel/tools-panel-header/component.js +9 -8
  307. package/build-module/tools-panel/tools-panel-header/component.js.map +1 -1
  308. package/build-module/tools-panel/tools-panel-item/hook.js +11 -11
  309. package/build-module/tools-panel/tools-panel-item/hook.js.map +1 -1
  310. package/build-module/tools-panel/types.js.map +1 -1
  311. package/build-module/tooltip/index.js +1 -1
  312. package/build-module/tooltip/index.js.map +1 -1
  313. package/build-module/truncate/hook.js +10 -4
  314. package/build-module/truncate/hook.js.map +1 -1
  315. package/build-module/truncate/types.js.map +1 -1
  316. package/build-module/unit-control/index.js +1 -1
  317. package/build-module/unit-control/index.js.map +1 -1
  318. package/build-module/utils/strings.js +32 -2
  319. package/build-module/utils/strings.js.map +1 -1
  320. package/build-style/style-rtl.css +30 -6
  321. package/build-style/style.css +30 -6
  322. package/build-types/base-control/index.d.ts +3 -27
  323. package/build-types/base-control/index.d.ts.map +1 -1
  324. package/build-types/base-control/stories/index.story.d.ts +4 -1
  325. package/build-types/base-control/stories/index.story.d.ts.map +1 -1
  326. package/build-types/border-control/border-control-dropdown/component.d.ts.map +1 -1
  327. package/build-types/border-control/border-control-dropdown/hook.d.ts +1 -0
  328. package/build-types/border-control/border-control-dropdown/hook.d.ts.map +1 -1
  329. package/build-types/border-control/styles.d.ts +1 -1
  330. package/build-types/border-control/styles.d.ts.map +1 -1
  331. package/build-types/checkbox-control/index.d.ts.map +1 -1
  332. package/build-types/checkbox-control/types.d.ts +3 -2
  333. package/build-types/checkbox-control/types.d.ts.map +1 -1
  334. package/build-types/color-picker/component.d.ts +1 -1
  335. package/build-types/color-picker/stories/index.story.d.ts +1 -1
  336. package/build-types/color-picker/stories/index.story.d.ts.map +1 -1
  337. package/build-types/composite/test/index.d.ts.map +1 -0
  338. package/build-types/context/wordpress-component.d.ts +3 -3
  339. package/build-types/context/wordpress-component.d.ts.map +1 -1
  340. package/build-types/custom-select-control-v2/index.d.ts +3 -2
  341. package/build-types/custom-select-control-v2/index.d.ts.map +1 -1
  342. package/build-types/custom-select-control-v2/stories/index.story.d.ts +4 -3
  343. package/build-types/custom-select-control-v2/stories/index.story.d.ts.map +1 -1
  344. package/build-types/date-time/time/timezone.d.ts.map +1 -1
  345. package/build-types/dimension-control/index.d.ts.map +1 -1
  346. package/build-types/dimension-control/types.d.ts +6 -0
  347. package/build-types/dimension-control/types.d.ts.map +1 -1
  348. package/build-types/dropdown/index.d.ts +1 -1
  349. package/build-types/dropdown/index.d.ts.map +1 -1
  350. package/build-types/dropdown/stories/index.story.d.ts +3 -3
  351. package/build-types/dropdown/stories/index.story.d.ts.map +1 -1
  352. package/build-types/dropdown-menu/index.d.ts +1 -1
  353. package/build-types/dropdown-menu/index.d.ts.map +1 -1
  354. package/build-types/dropdown-menu/stories/index.story.d.ts +2 -2
  355. package/build-types/dropdown-menu/stories/index.story.d.ts.map +1 -1
  356. package/build-types/dropdown-menu-v2/index.d.ts +18 -15
  357. package/build-types/dropdown-menu-v2/index.d.ts.map +1 -1
  358. package/build-types/dropdown-menu-v2/stories/index.story.d.ts +7 -2
  359. package/build-types/dropdown-menu-v2/stories/index.story.d.ts.map +1 -1
  360. package/build-types/dropdown-menu-v2/styles.d.ts +77 -23
  361. package/build-types/dropdown-menu-v2/styles.d.ts.map +1 -1
  362. package/build-types/dropdown-menu-v2/types.d.ts +89 -173
  363. package/build-types/dropdown-menu-v2/types.d.ts.map +1 -1
  364. package/build-types/duotone-picker/duotone-picker.d.ts.map +1 -1
  365. package/build-types/focal-point-picker/controls.d.ts +1 -1
  366. package/build-types/focal-point-picker/controls.d.ts.map +1 -1
  367. package/build-types/focal-point-picker/index.d.ts +1 -1
  368. package/build-types/focal-point-picker/index.d.ts.map +1 -1
  369. package/build-types/focal-point-picker/stories/index.story.d.ts +8 -4
  370. package/build-types/focal-point-picker/stories/index.story.d.ts.map +1 -1
  371. package/build-types/focal-point-picker/types.d.ts +7 -0
  372. package/build-types/focal-point-picker/types.d.ts.map +1 -1
  373. package/build-types/font-size-picker/font-size-picker-select.d.ts.map +1 -1
  374. package/build-types/font-size-picker/font-size-picker-toggle-group.d.ts.map +1 -1
  375. package/build-types/font-size-picker/index.d.ts.map +1 -1
  376. package/build-types/font-size-picker/types.d.ts +8 -1
  377. package/build-types/font-size-picker/types.d.ts.map +1 -1
  378. package/build-types/form-token-field/index.d.ts.map +1 -1
  379. package/build-types/form-token-field/token.d.ts.map +1 -1
  380. package/build-types/input-control/styles/input-control-styles.d.ts +11 -0
  381. package/build-types/input-control/styles/input-control-styles.d.ts.map +1 -1
  382. package/build-types/input-control/types.d.ts +1 -1
  383. package/build-types/input-control/types.d.ts.map +1 -1
  384. package/build-types/lock-unlock.d.ts +3 -0
  385. package/build-types/lock-unlock.d.ts.map +1 -0
  386. package/build-types/mobile/image/constants.d.ts +5 -0
  387. package/build-types/mobile/image/constants.d.ts.map +1 -0
  388. package/build-types/modal/index.d.ts.map +1 -1
  389. package/build-types/navigator/navigator-provider/component.d.ts.map +1 -1
  390. package/build-types/navigator/navigator-screen/component.d.ts +1 -7
  391. package/build-types/navigator/navigator-screen/component.d.ts.map +1 -1
  392. package/build-types/navigator/styles.d.ts +9 -0
  393. package/build-types/navigator/styles.d.ts.map +1 -0
  394. package/build-types/number-control/index.d.ts.map +1 -1
  395. package/build-types/number-control/types.d.ts +1 -1
  396. package/build-types/palette-edit/index.d.ts +2 -2
  397. package/build-types/palette-edit/index.d.ts.map +1 -1
  398. package/build-types/popover/index.d.ts +1 -1
  399. package/build-types/popover/index.d.ts.map +1 -1
  400. package/build-types/popover/stories/e2e/index.story.d.ts +1 -1
  401. package/build-types/private-apis.d.ts +0 -1
  402. package/build-types/private-apis.d.ts.map +1 -1
  403. package/build-types/query-controls/author-select.d.ts +1 -1
  404. package/build-types/query-controls/author-select.d.ts.map +1 -1
  405. package/build-types/query-controls/category-select.d.ts +1 -1
  406. package/build-types/query-controls/category-select.d.ts.map +1 -1
  407. package/build-types/query-controls/index.d.ts +1 -1
  408. package/build-types/query-controls/index.d.ts.map +1 -1
  409. package/build-types/query-controls/types.d.ts +9 -0
  410. package/build-types/query-controls/types.d.ts.map +1 -1
  411. package/build-types/radio-control/index.d.ts.map +1 -1
  412. package/build-types/select-control/styles/select-control-styles.d.ts.map +1 -1
  413. package/build-types/slot-fill/index.d.ts +1 -1
  414. package/build-types/slot-fill/index.d.ts.map +1 -1
  415. package/build-types/slot-fill/types.d.ts +4 -0
  416. package/build-types/slot-fill/types.d.ts.map +1 -1
  417. package/build-types/snackbar/index.d.ts +2 -2
  418. package/build-types/snackbar/stories/index.story.d.ts +0 -3
  419. package/build-types/snackbar/stories/index.story.d.ts.map +1 -1
  420. package/build-types/snackbar/types.d.ts +1 -1
  421. package/build-types/snackbar/types.d.ts.map +1 -1
  422. package/build-types/tabs/index.d.ts +2 -2
  423. package/build-types/tabs/index.d.ts.map +1 -1
  424. package/build-types/tabs/styles.d.ts.map +1 -1
  425. package/build-types/tabs/tab.d.ts +2 -1
  426. package/build-types/tabs/tab.d.ts.map +1 -1
  427. package/build-types/tabs/tabpanel.d.ts +3 -2
  428. package/build-types/tabs/tabpanel.d.ts.map +1 -1
  429. package/build-types/tabs/types.d.ts +8 -3
  430. package/build-types/tabs/types.d.ts.map +1 -1
  431. package/build-types/toggle-group-control/toggle-group-control/component.d.ts.map +1 -1
  432. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts +2 -2
  433. package/build-types/toggle-group-control/toggle-group-control/styles.d.ts.map +1 -1
  434. package/build-types/toggle-group-control/toggle-group-control/utils.d.ts.map +1 -1
  435. package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts +1 -1
  436. package/build-types/toggle-group-control/toggle-group-control-option-base/component.d.ts.map +1 -1
  437. package/build-types/toggle-group-control/toggle-group-control-option-base/styles.d.ts.map +1 -1
  438. package/build-types/tools-panel/tools-panel/component.d.ts.map +1 -1
  439. package/build-types/tools-panel/tools-panel/hook.d.ts +1 -0
  440. package/build-types/tools-panel/tools-panel/hook.d.ts.map +1 -1
  441. package/build-types/tools-panel/tools-panel-header/component.d.ts.map +1 -1
  442. package/build-types/tools-panel/tools-panel-header/hook.d.ts +1 -0
  443. package/build-types/tools-panel/tools-panel-header/hook.d.ts.map +1 -1
  444. package/build-types/tools-panel/tools-panel-item/hook.d.ts.map +1 -1
  445. package/build-types/tools-panel/types.d.ts +9 -0
  446. package/build-types/tools-panel/types.d.ts.map +1 -1
  447. package/build-types/truncate/hook.d.ts +1 -1
  448. package/build-types/truncate/hook.d.ts.map +1 -1
  449. package/build-types/truncate/types.d.ts +4 -0
  450. package/build-types/truncate/types.d.ts.map +1 -1
  451. package/build-types/utils/strings.d.ts +14 -2
  452. package/build-types/utils/strings.d.ts.map +1 -1
  453. package/package.json +20 -21
  454. package/src/alignment-matrix-control/test/index.tsx +10 -16
  455. package/src/base-control/index.tsx +21 -16
  456. package/src/border-box-control/border-box-control-linked-button/component.tsx +1 -1
  457. package/src/border-control/border-control-dropdown/component.tsx +3 -1
  458. package/src/border-control/border-control-dropdown/hook.ts +3 -2
  459. package/src/border-control/border-control-style-picker/component.tsx +1 -1
  460. package/src/border-control/styles.ts +2 -9
  461. package/src/box-control/index.tsx +1 -1
  462. package/src/box-control/linked-button.tsx +1 -1
  463. package/src/button/README.md +32 -6
  464. package/src/button/index.tsx +1 -1
  465. package/src/button-group/README.md +0 -6
  466. package/src/card/card/README.md +1 -1
  467. package/src/checkbox-control/README.md +3 -10
  468. package/src/checkbox-control/index.tsx +8 -6
  469. package/src/checkbox-control/test/__snapshots__/index.tsx.snap +3 -8
  470. package/src/checkbox-control/test/index.tsx +7 -0
  471. package/src/checkbox-control/types.ts +3 -2
  472. package/src/color-picker/color-copy-button.tsx +1 -1
  473. package/src/combobox-control/README.md +0 -6
  474. package/src/composite/test/index.tsx +576 -0
  475. package/src/context/wordpress-component.ts +11 -6
  476. package/src/custom-select-control/README.md +0 -6
  477. package/src/custom-select-control/test/index.js +367 -35
  478. package/src/custom-select-control-v2/index.tsx +13 -12
  479. package/src/date-time/date/styles.ts +3 -3
  480. package/src/date-time/time/timezone.tsx +15 -3
  481. package/src/dimension-control/index.tsx +2 -0
  482. package/src/dimension-control/test/__snapshots__/index.test.js.snap +2 -2
  483. package/src/dimension-control/types.ts +6 -0
  484. package/src/dropdown-menu/README.md +0 -5
  485. package/src/dropdown-menu-v2/README.md +75 -136
  486. package/src/dropdown-menu-v2/index.tsx +321 -231
  487. package/src/dropdown-menu-v2/stories/index.story.tsx +522 -126
  488. package/src/dropdown-menu-v2/styles.ts +226 -151
  489. package/src/dropdown-menu-v2/test/index.tsx +480 -188
  490. package/src/dropdown-menu-v2/types.ts +98 -184
  491. package/src/duotone-picker/duotone-picker.tsx +7 -3
  492. package/src/focal-point-picker/controls.tsx +4 -0
  493. package/src/focal-point-picker/index.tsx +2 -0
  494. package/src/focal-point-picker/styles/focal-point-picker-style.ts +1 -1
  495. package/src/focal-point-picker/types.ts +7 -0
  496. package/src/font-size-picker/font-size-picker-select.tsx +2 -0
  497. package/src/font-size-picker/font-size-picker-toggle-group.tsx +9 -1
  498. package/src/font-size-picker/index.native.js +8 -2
  499. package/src/font-size-picker/index.tsx +15 -5
  500. package/src/font-size-picker/types.ts +8 -1
  501. package/src/form-toggle/README.md +0 -6
  502. package/src/form-toggle/style.scss +4 -2
  503. package/src/form-token-field/index.tsx +11 -7
  504. package/src/form-token-field/test/index.tsx +97 -0
  505. package/src/form-token-field/token.tsx +1 -0
  506. package/src/gradient-picker/index.tsx +2 -2
  507. package/src/index.native.js +6 -3
  508. package/src/input-control/styles/input-control-styles.tsx +10 -8
  509. package/src/input-control/types.ts +1 -1
  510. package/src/lock-unlock.js +10 -0
  511. package/src/menu-group/README.md +0 -8
  512. package/src/menu-items-choice/README.md +0 -7
  513. package/src/mobile/bottom-sheet/index.native.js +15 -1
  514. package/src/mobile/global-styles-context/test/fixtures/theme.native.js +0 -20
  515. package/src/mobile/global-styles-context/test/utils.native.js +22 -0
  516. package/src/mobile/global-styles-context/utils.native.js +42 -19
  517. package/src/mobile/image/constants.js +1 -0
  518. package/src/mobile/image/index.native.js +55 -18
  519. package/src/mobile/image/style.native.scss +35 -9
  520. package/src/mobile/keyboard-aware-flat-list/index.android.js +50 -5
  521. package/src/mobile/keyboard-aware-flat-list/index.ios.js +65 -91
  522. package/src/mobile/keyboard-aware-flat-list/test/{use-scroll-to-text-input.native.js → use-scroll-to-section.native.js} +27 -25
  523. package/src/mobile/keyboard-aware-flat-list/test/use-scroll.native.js +71 -0
  524. package/src/mobile/keyboard-aware-flat-list/use-scroll-to-element.native.js +41 -0
  525. package/src/mobile/keyboard-aware-flat-list/{use-scroll-to-text-input.native.js → use-scroll-to-section.native.js} +22 -27
  526. package/src/mobile/keyboard-aware-flat-list/use-scroll.native.js +100 -0
  527. package/src/mobile/link-settings/style.native.scss +0 -17
  528. package/src/mobile/utils/get-px-from-css-unit.native.js +329 -0
  529. package/src/mobile/utils/test/get-px-from-css-unit.native.js +172 -0
  530. package/src/modal/README.md +0 -6
  531. package/src/modal/index.tsx +18 -16
  532. package/src/modal/test/index.tsx +90 -1
  533. package/src/navigation/menu/menu-title.tsx +1 -1
  534. package/src/navigator/navigator-provider/component.tsx +3 -4
  535. package/src/navigator/navigator-screen/component.tsx +15 -93
  536. package/src/navigator/styles.ts +71 -0
  537. package/src/navigator/test/index.tsx +0 -64
  538. package/src/notice/README.md +0 -6
  539. package/src/number-control/README.md +2 -2
  540. package/src/number-control/index.tsx +4 -8
  541. package/src/number-control/types.ts +1 -1
  542. package/src/palette-edit/index.tsx +14 -43
  543. package/src/palette-edit/style.scss +2 -2
  544. package/src/panel/README.md +0 -6
  545. package/src/private-apis.native.js +13 -0
  546. package/src/private-apis.ts +12 -37
  547. package/src/query-controls/author-select.tsx +2 -0
  548. package/src/query-controls/category-select.tsx +2 -0
  549. package/src/query-controls/index.tsx +6 -1
  550. package/src/query-controls/types.ts +9 -0
  551. package/src/radio-control/README.md +0 -6
  552. package/src/radio-control/index.tsx +4 -1
  553. package/src/radio-control/style.scss +29 -2
  554. package/src/radio-group/README.md +0 -6
  555. package/src/range-control/README.md +1 -9
  556. package/src/range-control/index.tsx +1 -1
  557. package/src/search-control/README.md +1 -5
  558. package/src/select-control/README.md +0 -6
  559. package/src/select-control/styles/select-control-styles.ts +10 -28
  560. package/src/slot-fill/index.tsx +5 -2
  561. package/src/slot-fill/types.ts +5 -0
  562. package/src/snackbar/README.md +0 -6
  563. package/src/snackbar/stories/index.story.tsx +7 -5
  564. package/src/snackbar/style.scss +4 -3
  565. package/src/snackbar/types.ts +2 -1
  566. package/src/spacer/README.md +0 -2
  567. package/src/spinner/README.md +2 -0
  568. package/src/tab-panel/README.md +0 -5
  569. package/src/tab-panel/test/index.tsx +39 -56
  570. package/src/tabs/README.md +4 -4
  571. package/src/tabs/index.tsx +22 -1
  572. package/src/tabs/stories/index.story.tsx +48 -48
  573. package/src/tabs/styles.ts +7 -1
  574. package/src/tabs/tab.tsx +3 -3
  575. package/src/tabs/tabpanel.tsx +13 -8
  576. package/src/tabs/test/index.tsx +236 -106
  577. package/src/tabs/types.ts +8 -3
  578. package/src/text-control/README.md +0 -6
  579. package/src/textarea-control/README.md +0 -6
  580. package/src/toggle-group-control/test/__snapshots__/index.tsx.snap +12 -16
  581. package/src/toggle-group-control/test/index.tsx +107 -41
  582. package/src/toggle-group-control/toggle-group-control/component.tsx +5 -4
  583. package/src/toggle-group-control/toggle-group-control/styles.ts +13 -19
  584. package/src/toggle-group-control/toggle-group-control/utils.ts +15 -20
  585. package/src/toggle-group-control/toggle-group-control-option/README.md +1 -1
  586. package/src/toggle-group-control/toggle-group-control-option-base/README.md +1 -1
  587. package/src/toggle-group-control/toggle-group-control-option-base/styles.ts +3 -2
  588. package/src/toggle-group-control/toggle-group-control-option-icon/README.md +1 -1
  589. package/src/toolbar/toolbar/README.md +0 -6
  590. package/src/tools-panel/test/index.tsx +12 -20
  591. package/src/tools-panel/tools-panel/README.md +7 -0
  592. package/src/tools-panel/tools-panel/component.tsx +2 -0
  593. package/src/tools-panel/tools-panel-header/README.md +7 -0
  594. package/src/tools-panel/tools-panel-header/component.tsx +20 -13
  595. package/src/tools-panel/tools-panel-item/hook.ts +10 -21
  596. package/src/tools-panel/types.ts +9 -0
  597. package/src/tooltip/index.tsx +1 -1
  598. package/src/tooltip/test/index.tsx +360 -256
  599. package/src/tree-grid/README.md +0 -4
  600. package/src/truncate/README.md +8 -0
  601. package/src/truncate/hook.ts +17 -10
  602. package/src/truncate/test/index.tsx +54 -27
  603. package/src/truncate/types.ts +4 -0
  604. package/src/unit-control/index.tsx +1 -1
  605. package/src/utils/strings.ts +30 -2
  606. package/src/utils/test/strings.js +96 -1
  607. package/tsconfig.tsbuildinfo +1 -1
  608. package/build/dropdown-menu-v2-ariakit/index.js +0 -256
  609. package/build/dropdown-menu-v2-ariakit/index.js.map +0 -1
  610. package/build/dropdown-menu-v2-ariakit/styles.js +0 -180
  611. package/build/dropdown-menu-v2-ariakit/styles.js.map +0 -1
  612. package/build/dropdown-menu-v2-ariakit/types.js +0 -6
  613. package/build/dropdown-menu-v2-ariakit/types.js.map +0 -1
  614. package/build/mobile/inserter-button/index.native.js +0 -98
  615. package/build/mobile/inserter-button/index.native.js.map +0 -1
  616. package/build/mobile/inserter-button/sparkles.js +0 -23
  617. package/build/mobile/inserter-button/sparkles.js.map +0 -1
  618. package/build/mobile/keyboard-aware-flat-list/use-scroll-to-text-input.native.js.map +0 -1
  619. package/build/mobile/link-settings/image-link-destinations-screen.native.js +0 -119
  620. package/build/mobile/link-settings/image-link-destinations-screen.native.js.map +0 -1
  621. package/build-module/dropdown-menu-v2-ariakit/index.js +0 -237
  622. package/build-module/dropdown-menu-v2-ariakit/index.js.map +0 -1
  623. package/build-module/dropdown-menu-v2-ariakit/styles.js +0 -165
  624. package/build-module/dropdown-menu-v2-ariakit/styles.js.map +0 -1
  625. package/build-module/dropdown-menu-v2-ariakit/types.js +0 -2
  626. package/build-module/dropdown-menu-v2-ariakit/types.js.map +0 -1
  627. package/build-module/mobile/inserter-button/index.native.js +0 -89
  628. package/build-module/mobile/inserter-button/index.native.js.map +0 -1
  629. package/build-module/mobile/inserter-button/sparkles.js +0 -15
  630. package/build-module/mobile/inserter-button/sparkles.js.map +0 -1
  631. package/build-module/mobile/keyboard-aware-flat-list/use-scroll-to-text-input.native.js.map +0 -1
  632. package/build-module/mobile/link-settings/image-link-destinations-screen.native.js +0 -110
  633. package/build-module/mobile/link-settings/image-link-destinations-screen.native.js.map +0 -1
  634. package/build-types/dropdown-menu-v2-ariakit/index.d.ts +0 -20
  635. package/build-types/dropdown-menu-v2-ariakit/index.d.ts.map +0 -1
  636. package/build-types/dropdown-menu-v2-ariakit/stories/index.story.d.ts +0 -16
  637. package/build-types/dropdown-menu-v2-ariakit/stories/index.story.d.ts.map +0 -1
  638. package/build-types/dropdown-menu-v2-ariakit/styles.d.ts +0 -96
  639. package/build-types/dropdown-menu-v2-ariakit/styles.d.ts.map +0 -1
  640. package/build-types/dropdown-menu-v2-ariakit/test/index.d.ts.map +0 -1
  641. package/build-types/dropdown-menu-v2-ariakit/types.d.ts +0 -168
  642. package/build-types/dropdown-menu-v2-ariakit/types.d.ts.map +0 -1
  643. package/build-types/mobile/inserter-button/sparkles.d.ts +0 -3
  644. package/build-types/mobile/inserter-button/sparkles.d.ts.map +0 -1
  645. package/src/dropdown-menu-v2-ariakit/README.md +0 -331
  646. package/src/dropdown-menu-v2-ariakit/index.tsx +0 -383
  647. package/src/dropdown-menu-v2-ariakit/stories/index.story.tsx +0 -617
  648. package/src/dropdown-menu-v2-ariakit/styles.ts +0 -333
  649. package/src/dropdown-menu-v2-ariakit/test/index.tsx +0 -1108
  650. package/src/dropdown-menu-v2-ariakit/types.ts +0 -179
  651. package/src/mobile/inserter-button/README.md +0 -62
  652. package/src/mobile/inserter-button/index.native.js +0 -116
  653. package/src/mobile/inserter-button/sparkles.js +0 -15
  654. package/src/mobile/inserter-button/style.native.scss +0 -72
  655. package/src/mobile/link-settings/image-link-destinations-screen.native.js +0 -152
  656. /package/build-types/{dropdown-menu-v2-ariakit → composite}/test/index.d.ts +0 -0
@@ -21,10 +21,23 @@
21
21
  }
22
22
 
23
23
  .retryIcon {
24
- width: 80px;
25
- height: 80px;
26
- justify-content: center;
27
- align-items: center;
24
+ background-color: $black;
25
+ border-radius: 200px;
26
+ padding: 8px;
27
+ }
28
+
29
+ .retryIconDark {
30
+ background-color: $white;
31
+ }
32
+
33
+ .iconOffline {
34
+ fill: $white;
35
+ width: 24px;
36
+ height: 24px;
37
+ }
38
+
39
+ .iconOfflineDark {
40
+ fill: $black;
28
41
  }
29
42
 
30
43
  .customRetryIcon {
@@ -33,9 +46,13 @@
33
46
  }
34
47
 
35
48
  .iconRetry {
36
- fill: #fff;
37
- width: 100%;
38
- height: 100%;
49
+ fill: $white;
50
+ width: 24px;
51
+ height: 24px;
52
+ }
53
+
54
+ .iconRetryDark {
55
+ fill: $black;
39
56
  }
40
57
 
41
58
  .iconPlaceholder {
@@ -90,12 +107,17 @@
90
107
  }
91
108
 
92
109
  .uploadFailedText {
93
- color: #fff;
110
+ color: $black;
111
+ font-weight: bold;
94
112
  font-size: 14;
95
113
  margin-top: 5;
96
114
  text-align: center;
97
115
  }
98
116
 
117
+ .uploadFailedTextDark {
118
+ color: $white;
119
+ }
120
+
99
121
  .editContainer {
100
122
  width: 44px;
101
123
  height: 44px;
@@ -116,7 +138,7 @@
116
138
  }
117
139
 
118
140
  .iconCustomise {
119
- fill: #fff;
141
+ fill: $white;
120
142
  position: absolute;
121
143
  top: 7px;
122
144
  left: 7px;
@@ -124,6 +146,10 @@
124
146
 
125
147
  .retryContainer {
126
148
  flex: 1;
149
+ background-color: "rgba(255, 255, 255, 0.8)";
150
+ }
151
+
152
+ .retryContainerDark {
127
153
  background-color: "rgba(0, 0, 0, 0.5)";
128
154
  }
129
155
 
@@ -2,26 +2,71 @@
2
2
  * External dependencies
3
3
  */
4
4
  import { FlatList } from 'react-native';
5
- import Animated, { useAnimatedScrollHandler } from 'react-native-reanimated';
5
+ import Animated from 'react-native-reanimated';
6
+
7
+ /**
8
+ * WordPress dependencies
9
+ */
10
+ import {
11
+ forwardRef,
12
+ useCallback,
13
+ useImperativeHandle,
14
+ } from '@wordpress/element';
6
15
 
7
16
  /**
8
17
  * Internal dependencies
9
18
  */
19
+ import useScroll from './use-scroll';
10
20
  import KeyboardAvoidingView from '../keyboard-avoiding-view';
11
21
 
12
22
  const AnimatedFlatList = Animated.createAnimatedComponent( FlatList );
13
23
 
14
- export const KeyboardAwareFlatList = ( { innerRef, onScroll, ...props } ) => {
15
- const scrollHandler = useAnimatedScrollHandler( { onScroll } );
24
+ export const KeyboardAwareFlatList = ( { onScroll, ...props }, ref ) => {
25
+ const { extraScrollHeight, scrollEnabled, shouldPreventAutomaticScroll } =
26
+ props;
27
+
28
+ const {
29
+ scrollViewRef,
30
+ scrollHandler,
31
+ scrollToSection,
32
+ scrollToElement,
33
+ onContentSizeChange,
34
+ lastScrollTo,
35
+ } = useScroll( {
36
+ scrollEnabled,
37
+ shouldPreventAutomaticScroll,
38
+ extraScrollHeight,
39
+ onScroll,
40
+ } );
41
+
42
+ const getFlatListRef = useCallback(
43
+ ( flatListRef ) => {
44
+ // On Android, we get the ref of the associated scroll
45
+ // view to the FlatList.
46
+ scrollViewRef.current = flatListRef?.getNativeScrollRef();
47
+ },
48
+ [ scrollViewRef ]
49
+ );
50
+
51
+ useImperativeHandle( ref, () => {
52
+ return {
53
+ scrollViewRef: scrollViewRef.current,
54
+ scrollToSection,
55
+ scrollToElement,
56
+ lastScrollTo,
57
+ };
58
+ } );
59
+
16
60
  return (
17
61
  <KeyboardAvoidingView style={ { flex: 1 } }>
18
62
  <AnimatedFlatList
19
- ref={ innerRef }
63
+ ref={ getFlatListRef }
20
64
  onScroll={ scrollHandler }
65
+ onContentSizeChange={ onContentSizeChange }
21
66
  { ...props }
22
67
  />
23
68
  </KeyboardAvoidingView>
24
69
  );
25
70
  };
26
71
 
27
- export default KeyboardAwareFlatList;
72
+ export default forwardRef( KeyboardAwareFlatList );
@@ -2,139 +2,104 @@
2
2
  * External dependencies
3
3
  */
4
4
 
5
- import { ScrollView, FlatList, useWindowDimensions } from 'react-native';
6
- import Animated, {
7
- useAnimatedScrollHandler,
8
- useSharedValue,
9
- } from 'react-native-reanimated';
5
+ import { ScrollView, FlatList } from 'react-native';
6
+ import Animated from 'react-native-reanimated';
10
7
 
11
8
  /**
12
9
  * WordPress dependencies
13
10
  */
14
- import { useCallback, useEffect, useRef } from '@wordpress/element';
11
+ import {
12
+ useCallback,
13
+ useEffect,
14
+ forwardRef,
15
+ useImperativeHandle,
16
+ } from '@wordpress/element';
15
17
  import { useThrottle } from '@wordpress/compose';
16
18
 
17
19
  /**
18
20
  * Internal dependencies
19
21
  */
22
+ import useScroll from './use-scroll';
20
23
  import useTextInputOffset from './use-text-input-offset';
21
- import useKeyboardOffset from './use-keyboard-offset';
22
- import useScrollToTextInput from './use-scroll-to-text-input';
23
24
  import useTextInputCaretPosition from './use-text-input-caret-position';
24
25
 
26
+ const DEFAULT_FONT_SIZE = 16;
25
27
  const AnimatedScrollView = Animated.createAnimatedComponent( ScrollView );
26
28
 
29
+ /** @typedef {import('@wordpress/element').RefObject} RefObject */
27
30
  /**
28
31
  * React component that provides a FlatList that is aware of the keyboard state and can scroll
29
32
  * to the currently focused TextInput.
30
33
  *
31
- * @param {Object} props Component props.
32
- * @param {number} props.extraScrollHeight Extra scroll height for the content.
33
- * @param {Function} props.innerRef Function to pass the ScrollView ref to the parent component.
34
- * @param {Function} props.onScroll Function to be called when the list is scrolled.
35
- * @param {boolean} props.scrollEnabled Whether the list can be scrolled.
36
- * @param {Object} props.scrollViewStyle Additional style for the ScrollView component.
37
- * @param {boolean} props.shouldPreventAutomaticScroll Whether to prevent scrolling when there's a Keyboard offset set.
38
- * @param {Object} props... Other props to pass to the FlatList component.
34
+ * @param {Object} props Component props.
35
+ * @param {number} props.extraScrollHeight Extra scroll height for the content.
36
+ * @param {Function} props.onScroll Function to be called when the list is scrolled.
37
+ * @param {boolean} props.scrollEnabled Whether the list can be scrolled.
38
+ * @param {Object} props.scrollViewStyle Additional style for the ScrollView component.
39
+ * @param {boolean} props.shouldPreventAutomaticScroll Whether to prevent scrolling when there's a Keyboard offset set.
40
+ * @param {Object} props... Other props to pass to the FlatList component.
41
+ * @param {RefObject} ref
39
42
  * @return {Component} KeyboardAwareFlatList component.
40
43
  */
41
- export const KeyboardAwareFlatList = ( {
42
- extraScrollHeight,
43
- innerRef,
44
- onScroll,
45
- scrollEnabled,
46
- scrollViewStyle,
47
- shouldPreventAutomaticScroll,
48
- ...props
49
- } ) => {
50
- const scrollViewRef = useRef();
51
- const scrollViewMeasurements = useRef();
52
- const scrollViewYOffset = useSharedValue( -1 );
53
-
54
- const { height: windowHeight, width: windowWidth } = useWindowDimensions();
55
- const isLandscape = windowWidth >= windowHeight;
56
-
57
- const [ keyboardOffset ] = useKeyboardOffset(
44
+ export const KeyboardAwareFlatList = (
45
+ {
46
+ extraScrollHeight,
47
+ onScroll,
58
48
  scrollEnabled,
59
- shouldPreventAutomaticScroll
60
- );
61
-
62
- const [ currentCaretData ] = useTextInputCaretPosition( scrollEnabled );
49
+ scrollViewStyle,
50
+ shouldPreventAutomaticScroll,
51
+ ...props
52
+ },
53
+ ref
54
+ ) => {
55
+ const {
56
+ scrollViewRef,
57
+ scrollHandler,
58
+ keyboardOffset,
59
+ scrollToSection,
60
+ scrollToElement,
61
+ onContentSizeChange,
62
+ lastScrollTo,
63
+ } = useScroll( {
64
+ scrollEnabled,
65
+ shouldPreventAutomaticScroll,
66
+ extraScrollHeight,
67
+ onScroll,
68
+ onSizeChange,
69
+ } );
63
70
 
64
71
  const [ getTextInputOffset ] = useTextInputOffset(
65
72
  scrollEnabled,
66
73
  scrollViewRef
67
74
  );
68
75
 
69
- const [ scrollToTextInputOffset ] = useScrollToTextInput(
70
- extraScrollHeight,
71
- keyboardOffset,
72
- scrollEnabled,
73
- scrollViewMeasurements,
74
- scrollViewRef,
75
- scrollViewYOffset
76
- );
77
-
78
76
  const onScrollToTextInput = useThrottle(
79
77
  useCallback(
80
78
  async ( caret ) => {
79
+ const { caretHeight = DEFAULT_FONT_SIZE } = caret ?? {};
81
80
  const textInputOffset = await getTextInputOffset( caret );
82
81
  const hasTextInputOffset = textInputOffset !== null;
83
82
 
84
83
  if ( hasTextInputOffset ) {
85
- scrollToTextInputOffset( caret, textInputOffset );
84
+ scrollToSection( textInputOffset, caretHeight );
86
85
  }
87
86
  },
88
- [ getTextInputOffset, scrollToTextInputOffset ]
87
+ [ getTextInputOffset, scrollToSection ]
89
88
  ),
90
89
  200,
91
90
  { leading: false }
92
91
  );
93
92
 
94
- useEffect( () => {
95
- onScrollToTextInput( currentCaretData );
96
- }, [ currentCaretData, onScrollToTextInput ] );
97
-
98
- // When the orientation changes, the ScrollView measurements
99
- // need to be re-calculated.
100
- useEffect( () => {
101
- scrollViewMeasurements.current = null;
102
- }, [ isLandscape ] );
103
-
104
- const scrollHandler = useAnimatedScrollHandler( {
105
- onScroll: ( event ) => {
106
- const { contentOffset } = event;
107
- scrollViewYOffset.value = contentOffset.y;
108
- onScroll( event );
109
- },
110
- } );
111
-
112
- const measureScrollView = useCallback( () => {
113
- if ( scrollViewRef.current ) {
114
- const scrollRef = scrollViewRef.current.getNativeScrollRef();
93
+ const [ currentCaretData ] = useTextInputCaretPosition( scrollEnabled );
115
94
 
116
- scrollRef.measureInWindow( ( _x, y, width, height ) => {
117
- scrollViewMeasurements.current = { y, width, height };
118
- } );
119
- }
120
- }, [] );
95
+ const onSizeChange = useCallback(
96
+ () => onScrollToTextInput( currentCaretData ),
97
+ [ currentCaretData, onScrollToTextInput ]
98
+ );
121
99
 
122
- const onContentSizeChange = useCallback( () => {
100
+ useEffect( () => {
123
101
  onScrollToTextInput( currentCaretData );
124
-
125
- // Sets the first values when the content size changes.
126
- if ( ! scrollViewMeasurements.current ) {
127
- measureScrollView();
128
- }
129
- }, [ measureScrollView, onScrollToTextInput, currentCaretData ] );
130
-
131
- const getRef = useCallback(
132
- ( ref ) => {
133
- scrollViewRef.current = ref;
134
- innerRef( ref );
135
- },
136
- [ innerRef ]
137
- );
102
+ }, [ currentCaretData, onScrollToTextInput ] );
138
103
 
139
104
  // Adds content insets when the keyboard is opened to have
140
105
  // extra padding at the bottom.
@@ -142,6 +107,15 @@ export const KeyboardAwareFlatList = ( {
142
107
 
143
108
  const style = [ { flex: 1 }, scrollViewStyle ];
144
109
 
110
+ useImperativeHandle( ref, () => {
111
+ return {
112
+ scrollViewRef: scrollViewRef.current,
113
+ scrollToSection,
114
+ scrollToElement,
115
+ lastScrollTo,
116
+ };
117
+ } );
118
+
145
119
  return (
146
120
  <AnimatedScrollView
147
121
  automaticallyAdjustContentInsets={ false }
@@ -149,7 +123,7 @@ export const KeyboardAwareFlatList = ( {
149
123
  keyboardShouldPersistTaps="handled"
150
124
  onContentSizeChange={ onContentSizeChange }
151
125
  onScroll={ scrollHandler }
152
- ref={ getRef }
126
+ ref={ scrollViewRef }
153
127
  scrollEnabled={ scrollEnabled }
154
128
  scrollEventThrottle={ 16 }
155
129
  style={ style }
@@ -159,4 +133,4 @@ export const KeyboardAwareFlatList = ( {
159
133
  );
160
134
  };
161
135
 
162
- export default KeyboardAwareFlatList;
136
+ export default forwardRef( KeyboardAwareFlatList );
@@ -7,22 +7,23 @@ import { renderHook } from '@testing-library/react-native';
7
7
  /**
8
8
  * Internal dependencies
9
9
  */
10
- import useScrollToTextInput from '../use-scroll-to-text-input';
10
+ import useScrollToSection from '../use-scroll-to-section';
11
11
 
12
- describe( 'useScrollToTextInput', () => {
13
- it( 'scrolls up to the current TextInput offset', () => {
12
+ describe( 'useScrollToSection', () => {
13
+ it( 'scrolls up to the section', () => {
14
14
  // Arrange
15
- const currentCaretData = { caretHeight: 10 };
15
+ const sectionY = 50;
16
+ const sectionHeight = 10;
17
+
16
18
  const extraScrollHeight = 50;
17
19
  const keyboardOffset = 100;
18
20
  const scrollEnabled = true;
19
21
  const scrollViewRef = { current: { scrollTo: jest.fn() } };
20
22
  const scrollViewMeasurements = { current: { height: 600 } };
21
23
  const scrollViewYOffset = { value: 150 };
22
- const textInputOffset = 50;
23
24
 
24
25
  const { result } = renderHook( () =>
25
- useScrollToTextInput(
26
+ useScrollToSection(
26
27
  extraScrollHeight,
27
28
  keyboardOffset,
28
29
  scrollEnabled,
@@ -33,28 +34,29 @@ describe( 'useScrollToTextInput', () => {
33
34
  );
34
35
 
35
36
  // Act
36
- result.current[ 0 ]( currentCaretData, textInputOffset );
37
+ result.current[ 0 ]( sectionY, sectionHeight );
37
38
 
38
39
  // Assert
39
40
  expect( scrollViewRef.current.scrollTo ).toHaveBeenCalledWith( {
40
- y: textInputOffset,
41
+ y: sectionY,
41
42
  animated: true,
42
43
  } );
43
44
  } );
44
45
 
45
- it( 'scrolls down to the current TextInput offset', () => {
46
+ it( 'scrolls down to the section', () => {
46
47
  // Arrange
47
- const currentCaretData = { caretHeight: 10 };
48
+ const sectionY = 750;
49
+ const sectionHeight = 10;
50
+
48
51
  const extraScrollHeight = 50;
49
52
  const keyboardOffset = 100;
50
53
  const scrollEnabled = true;
51
54
  const scrollViewRef = { current: { scrollTo: jest.fn() } };
52
55
  const scrollViewMeasurements = { current: { height: 600 } };
53
56
  const scrollViewYOffset = { value: 250 };
54
- const textInputOffset = 750;
55
57
 
56
58
  const { result } = renderHook( () =>
57
- useScrollToTextInput(
59
+ useScrollToSection(
58
60
  extraScrollHeight,
59
61
  keyboardOffset,
60
62
  scrollEnabled,
@@ -65,15 +67,13 @@ describe( 'useScrollToTextInput', () => {
65
67
  );
66
68
 
67
69
  // Act
68
- result.current[ 0 ]( currentCaretData, textInputOffset );
70
+ result.current[ 0 ]( sectionY, sectionHeight );
69
71
 
70
72
  // Assert
71
73
  const expectedYOffset =
72
- textInputOffset -
74
+ sectionY -
73
75
  ( scrollViewMeasurements.current.height -
74
- ( keyboardOffset +
75
- extraScrollHeight +
76
- currentCaretData.caretHeight ) );
76
+ ( keyboardOffset + extraScrollHeight + sectionHeight ) );
77
77
  expect( scrollViewRef.current.scrollTo ).toHaveBeenCalledWith( {
78
78
  y: expectedYOffset,
79
79
  animated: true,
@@ -82,17 +82,18 @@ describe( 'useScrollToTextInput', () => {
82
82
 
83
83
  it( 'does not scroll when the ScrollView ref is not available', () => {
84
84
  // Arrange
85
- const currentCaretData = { caretHeight: 10 };
85
+ const sectionY = 50;
86
+ const sectionHeight = 10;
87
+
86
88
  const extraScrollHeight = 50;
87
89
  const keyboardOffset = 100;
88
90
  const scrollEnabled = true;
89
91
  const scrollViewRef = { current: null };
90
92
  const scrollViewMeasurements = { current: { height: 600 } };
91
93
  const scrollViewYOffset = { value: 0 };
92
- const textInputOffset = 50;
93
94
 
94
95
  const { result } = renderHook( () =>
95
- useScrollToTextInput(
96
+ useScrollToSection(
96
97
  extraScrollHeight,
97
98
  keyboardOffset,
98
99
  scrollEnabled,
@@ -103,7 +104,7 @@ describe( 'useScrollToTextInput', () => {
103
104
  );
104
105
 
105
106
  // Act
106
- result.current[ 0 ]( currentCaretData, textInputOffset );
107
+ result.current[ 0 ]( sectionY, sectionHeight );
107
108
 
108
109
  // Assert
109
110
  expect( scrollViewRef.current ).toBeNull();
@@ -111,17 +112,18 @@ describe( 'useScrollToTextInput', () => {
111
112
 
112
113
  it( 'does not scroll when the scroll is not enabled', () => {
113
114
  // Arrange
114
- const currentCaretData = { caretHeight: 10 };
115
+ const sectionY = 50;
116
+ const sectionHeight = 10;
117
+
115
118
  const extraScrollHeight = 50;
116
119
  const keyboardOffset = 100;
117
120
  const scrollEnabled = false;
118
121
  const scrollViewRef = { current: { scrollTo: jest.fn() } };
119
122
  const scrollViewMeasurements = { current: { height: 600 } };
120
123
  const scrollViewYOffset = { value: 0 };
121
- const textInputOffset = 50;
122
124
 
123
125
  const { result } = renderHook( () =>
124
- useScrollToTextInput(
126
+ useScrollToSection(
125
127
  extraScrollHeight,
126
128
  keyboardOffset,
127
129
  scrollEnabled,
@@ -132,7 +134,7 @@ describe( 'useScrollToTextInput', () => {
132
134
  );
133
135
 
134
136
  // Act
135
- result.current[ 0 ]( currentCaretData, textInputOffset );
137
+ result.current[ 0 ]( sectionY, sectionHeight );
136
138
 
137
139
  // Assert
138
140
  expect( scrollViewRef.current.scrollTo ).not.toHaveBeenCalled();
@@ -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
+ }