@wordpress/block-editor 12.0.0 → 12.2.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 (627) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/README.md +1 -1
  3. package/build/autocompleters/block.js +13 -5
  4. package/build/autocompleters/block.js.map +1 -1
  5. package/build/components/block-breadcrumb/index.js +6 -3
  6. package/build/components/block-breadcrumb/index.js.map +1 -1
  7. package/build/components/block-controls/slot.js +12 -4
  8. package/build/components/block-controls/slot.js.map +1 -1
  9. package/build/components/block-controls/slot.native.js +10 -1
  10. package/build/components/block-controls/slot.native.js.map +1 -1
  11. package/build/components/block-draggable/index.js +11 -7
  12. package/build/components/block-draggable/index.js.map +1 -1
  13. package/build/components/block-draggable/use-scroll-when-dragging.js +2 -2
  14. package/build/components/block-draggable/use-scroll-when-dragging.js.map +1 -1
  15. package/build/components/block-editing-mode/index.js +84 -0
  16. package/build/components/block-editing-mode/index.js.map +1 -0
  17. package/build/components/block-list/block-invalid-warning.native.js +15 -7
  18. package/build/components/block-list/block-invalid-warning.native.js.map +1 -1
  19. package/build/components/block-list/block-list-block-context.js +15 -0
  20. package/build/components/block-list/block-list-block-context.js.map +1 -0
  21. package/build/components/block-list/block-list-item-cell.native.js +15 -2
  22. package/build/components/block-list/block-list-item-cell.native.js.map +1 -1
  23. package/build/components/block-list/block-list-item.native.js +158 -195
  24. package/build/components/block-list/block-list-item.native.js.map +1 -1
  25. package/build/components/block-list/block-outline.native.js +57 -0
  26. package/build/components/block-list/block-outline.native.js.map +1 -0
  27. package/build/components/block-list/block.js +29 -37
  28. package/build/components/block-list/block.js.map +1 -1
  29. package/build/components/block-list/block.native.js +347 -311
  30. package/build/components/block-list/block.native.js.map +1 -1
  31. package/build/components/block-list/index.native.js +260 -357
  32. package/build/components/block-list/index.native.js.map +1 -1
  33. package/build/components/block-list/insertion-point.native.js +4 -2
  34. package/build/components/block-list/insertion-point.native.js.map +1 -1
  35. package/build/components/block-list/use-block-props/index.js +2 -2
  36. package/build/components/block-list/use-block-props/index.js.map +1 -1
  37. package/build/components/block-list/use-in-between-inserter.js +7 -5
  38. package/build/components/block-list/use-in-between-inserter.js.map +1 -1
  39. package/build/components/block-list-appender/index.js +15 -1
  40. package/build/components/block-list-appender/index.js.map +1 -1
  41. package/build/components/block-mobile-toolbar/block-actions-menu.native.js +19 -4
  42. package/build/components/block-mobile-toolbar/block-actions-menu.native.js.map +1 -1
  43. package/build/components/block-settings-menu/block-settings-dropdown.js +8 -10
  44. package/build/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  45. package/build/components/block-settings-menu-controls/index.js +15 -4
  46. package/build/components/block-settings-menu-controls/index.js.map +1 -1
  47. package/build/components/block-styles/preview-panel.js +1 -2
  48. package/build/components/block-styles/preview-panel.js.map +1 -1
  49. package/build/components/block-switcher/block-transformations-menu.js +8 -0
  50. package/build/components/block-switcher/block-transformations-menu.js.map +1 -1
  51. package/build/components/block-switcher/block-variation-transformations.js +125 -0
  52. package/build/components/block-switcher/block-variation-transformations.js.map +1 -0
  53. package/build/components/block-switcher/index.js +34 -12
  54. package/build/components/block-switcher/index.js.map +1 -1
  55. package/build/components/block-switcher/pattern-transformations-menu.js +3 -3
  56. package/build/components/block-switcher/pattern-transformations-menu.js.map +1 -1
  57. package/build/components/block-toolbar/index.js +9 -7
  58. package/build/components/block-toolbar/index.js.map +1 -1
  59. package/build/components/block-tools/block-contextual-toolbar.js +22 -65
  60. package/build/components/block-tools/block-contextual-toolbar.js.map +1 -1
  61. package/build/components/block-tools/insertion-point.js +11 -5
  62. package/build/components/block-tools/insertion-point.js.map +1 -1
  63. package/build/components/block-tools/selected-block-popover.js +3 -8
  64. package/build/components/block-tools/selected-block-popover.js.map +1 -1
  65. package/build/components/colors-gradients/use-multiple-origin-colors-and-gradients.js +3 -2
  66. package/build/components/colors-gradients/use-multiple-origin-colors-and-gradients.js.map +1 -1
  67. package/build/components/convert-to-group-buttons/index.js +7 -2
  68. package/build/components/convert-to-group-buttons/index.js.map +1 -1
  69. package/build/components/convert-to-group-buttons/index.native.js +87 -3
  70. package/build/components/convert-to-group-buttons/index.native.js.map +1 -1
  71. package/build/components/convert-to-group-buttons/use-convert-to-group-button-props.js +23 -37
  72. package/build/components/convert-to-group-buttons/use-convert-to-group-button-props.js.map +1 -1
  73. package/build/components/global-styles/advanced-panel.js +86 -0
  74. package/build/components/global-styles/advanced-panel.js.map +1 -0
  75. package/build/components/global-styles/color-panel.js +4 -1
  76. package/build/components/global-styles/color-panel.js.map +1 -1
  77. package/build/components/global-styles/dimensions-panel.js +9 -8
  78. package/build/components/global-styles/dimensions-panel.js.map +1 -1
  79. package/build/components/global-styles/hooks.js +1 -2
  80. package/build/components/global-styles/hooks.js.map +1 -1
  81. package/build/components/global-styles/index.js +24 -0
  82. package/build/components/global-styles/index.js.map +1 -1
  83. package/build/components/global-styles/typography-panel.js +1 -1
  84. package/build/components/global-styles/typography-panel.js.map +1 -1
  85. package/build/components/global-styles/use-global-styles-output.js +27 -4
  86. package/build/components/global-styles/use-global-styles-output.js.map +1 -1
  87. package/build/components/global-styles/utils.js +30 -0
  88. package/build/components/global-styles/utils.js.map +1 -1
  89. package/build/components/iframe/index.js +14 -7
  90. package/build/components/iframe/index.js.map +1 -1
  91. package/build/components/image-editor/use-save-image.js +24 -8
  92. package/build/components/image-editor/use-save-image.js.map +1 -1
  93. package/build/components/inner-blocks/index.js +2 -1
  94. package/build/components/inner-blocks/index.js.map +1 -1
  95. package/build/components/inner-blocks/index.native.js +7 -7
  96. package/build/components/inner-blocks/index.native.js.map +1 -1
  97. package/build/components/inner-blocks/use-nested-settings-update.js +13 -5
  98. package/build/components/inner-blocks/use-nested-settings-update.js.map +1 -1
  99. package/build/components/inserter/index.js +3 -7
  100. package/build/components/inserter/index.js.map +1 -1
  101. package/build/components/inserter/quick-inserter.js +2 -4
  102. package/build/components/inserter/quick-inserter.js.map +1 -1
  103. package/build/components/inserter/search-results.js +19 -6
  104. package/build/components/inserter/search-results.js.map +1 -1
  105. package/build/components/inserter-draggable-blocks/index.js +5 -0
  106. package/build/components/inserter-draggable-blocks/index.js.map +1 -1
  107. package/build/components/inspector-controls/fill.js +1 -1
  108. package/build/components/inspector-controls/fill.js.map +1 -1
  109. package/build/components/inspector-controls/fill.native.js +1 -1
  110. package/build/components/inspector-controls/fill.native.js.map +1 -1
  111. package/build/components/inspector-controls/slot.js +3 -6
  112. package/build/components/inspector-controls/slot.js.map +1 -1
  113. package/build/components/inspector-controls/slot.native.js +1 -1
  114. package/build/components/inspector-controls/slot.native.js.map +1 -1
  115. package/build/components/line-height-control/index.js +7 -2
  116. package/build/components/line-height-control/index.js.map +1 -1
  117. package/build/components/link-control/use-internal-input-value.js +9 -8
  118. package/build/components/link-control/use-internal-input-value.js.map +1 -1
  119. package/build/components/list-view/appender.js +6 -1
  120. package/build/components/list-view/appender.js.map +1 -1
  121. package/build/components/list-view/block-contents.js +9 -2
  122. package/build/components/list-view/block-contents.js.map +1 -1
  123. package/build/components/list-view/block-select-button.js +2 -1
  124. package/build/components/list-view/block-select-button.js.map +1 -1
  125. package/build/components/list-view/block.js +25 -29
  126. package/build/components/list-view/block.js.map +1 -1
  127. package/build/components/list-view/branch.js +1 -3
  128. package/build/components/list-view/branch.js.map +1 -1
  129. package/build/components/list-view/index.js +43 -22
  130. package/build/components/list-view/index.js.map +1 -1
  131. package/build/components/list-view/use-list-view-client-ids.js +27 -3
  132. package/build/components/list-view/use-list-view-client-ids.js.map +1 -1
  133. package/build/components/list-view/use-list-view-drop-zone.js +163 -11
  134. package/build/components/list-view/use-list-view-drop-zone.js.map +1 -1
  135. package/build/components/media-placeholder/index.js +68 -7
  136. package/build/components/media-placeholder/index.js.map +1 -1
  137. package/build/components/multi-selection-inspector/index.js +2 -2
  138. package/build/components/multi-selection-inspector/index.js.map +1 -1
  139. package/build/components/preview-options/index.js +6 -1
  140. package/build/components/preview-options/index.js.map +1 -1
  141. package/build/components/publish-date-time-picker/index.js +0 -2
  142. package/build/components/publish-date-time-picker/index.js.map +1 -1
  143. package/build/components/spacing-sizes-control/spacing-input-control.js +1 -1
  144. package/build/components/spacing-sizes-control/spacing-input-control.js.map +1 -1
  145. package/build/components/url-input/index.js +4 -2
  146. package/build/components/url-input/index.js.map +1 -1
  147. package/build/components/use-block-drop-zone/index.js +25 -15
  148. package/build/components/use-block-drop-zone/index.js.map +1 -1
  149. package/build/components/use-resize-canvas/index.js +8 -1
  150. package/build/components/use-resize-canvas/index.js.map +1 -1
  151. package/build/components/writing-flow/use-arrow-nav.js +13 -7
  152. package/build/components/writing-flow/use-arrow-nav.js.map +1 -1
  153. package/build/hooks/align.js +4 -8
  154. package/build/hooks/align.js.map +1 -1
  155. package/build/hooks/behaviors.js +115 -0
  156. package/build/hooks/behaviors.js.map +1 -0
  157. package/build/hooks/border.js +1 -1
  158. package/build/hooks/border.js.map +1 -1
  159. package/build/hooks/color.js +1 -1
  160. package/build/hooks/color.js.map +1 -1
  161. package/build/hooks/content-lock-ui.js +8 -12
  162. package/build/hooks/content-lock-ui.js.map +1 -1
  163. package/build/hooks/dimensions.js +0 -30
  164. package/build/hooks/dimensions.js.map +1 -1
  165. package/build/hooks/duotone.js +5 -9
  166. package/build/hooks/duotone.js.map +1 -1
  167. package/build/hooks/index.js +2 -0
  168. package/build/hooks/index.js.map +1 -1
  169. package/build/hooks/index.native.js +8 -0
  170. package/build/hooks/index.native.js.map +1 -1
  171. package/build/hooks/layout.js +10 -11
  172. package/build/hooks/layout.js.map +1 -1
  173. package/build/hooks/position.js +1 -1
  174. package/build/hooks/position.js.map +1 -1
  175. package/build/hooks/style.js +1 -1
  176. package/build/hooks/style.js.map +1 -1
  177. package/build/hooks/use-editor-wrapper-styles.native.js +255 -0
  178. package/build/hooks/use-editor-wrapper-styles.native.js.map +1 -0
  179. package/build/hooks/use-typography-props.js +14 -10
  180. package/build/hooks/use-typography-props.js.map +1 -1
  181. package/build/index.native.js +31 -0
  182. package/build/index.native.js.map +1 -0
  183. package/build/private-apis.js +4 -7
  184. package/build/private-apis.js.map +1 -1
  185. package/build/store/private-actions.js +46 -0
  186. package/build/store/private-actions.js.map +1 -1
  187. package/build/store/private-selectors.js +88 -0
  188. package/build/store/private-selectors.js.map +1 -1
  189. package/build/store/reducer.js +36 -1
  190. package/build/store/reducer.js.map +1 -1
  191. package/build/store/selectors.js +28 -18
  192. package/build/store/selectors.js.map +1 -1
  193. package/build/utils/order-inserter-block-items.js +41 -0
  194. package/build/utils/order-inserter-block-items.js.map +1 -0
  195. package/build/utils/use-should-contextual-toolbar-show.js +16 -12
  196. package/build/utils/use-should-contextual-toolbar-show.js.map +1 -1
  197. package/build-module/autocompleters/block.js +12 -5
  198. package/build-module/autocompleters/block.js.map +1 -1
  199. package/build-module/components/block-breadcrumb/index.js +5 -3
  200. package/build-module/components/block-breadcrumb/index.js.map +1 -1
  201. package/build-module/components/block-controls/slot.js +11 -4
  202. package/build-module/components/block-controls/slot.js.map +1 -1
  203. package/build-module/components/block-controls/slot.native.js +9 -1
  204. package/build-module/components/block-controls/slot.native.js.map +1 -1
  205. package/build-module/components/block-draggable/index.js +10 -6
  206. package/build-module/components/block-draggable/index.js.map +1 -1
  207. package/build-module/components/block-draggable/use-scroll-when-dragging.js +2 -2
  208. package/build-module/components/block-draggable/use-scroll-when-dragging.js.map +1 -1
  209. package/build-module/components/block-editing-mode/index.js +72 -0
  210. package/build-module/components/block-editing-mode/index.js.map +1 -0
  211. package/build-module/components/block-list/block-invalid-warning.native.js +16 -8
  212. package/build-module/components/block-list/block-invalid-warning.native.js.map +1 -1
  213. package/build-module/components/block-list/block-list-block-context.js +6 -0
  214. package/build-module/components/block-list/block-list-block-context.js.map +1 -0
  215. package/build-module/components/block-list/block-list-item-cell.native.js +13 -2
  216. package/build-module/components/block-list/block-list-item-cell.native.js.map +1 -1
  217. package/build-module/components/block-list/block-list-item.native.js +160 -190
  218. package/build-module/components/block-list/block-list-item.native.js.map +1 -1
  219. package/build-module/components/block-list/block-outline.native.js +44 -0
  220. package/build-module/components/block-list/block-outline.native.js.map +1 -0
  221. package/build-module/components/block-list/block.js +26 -34
  222. package/build-module/components/block-list/block.js.map +1 -1
  223. package/build-module/components/block-list/block.native.js +345 -310
  224. package/build-module/components/block-list/block.native.js.map +1 -1
  225. package/build-module/components/block-list/index.native.js +263 -355
  226. package/build-module/components/block-list/index.native.js.map +1 -1
  227. package/build-module/components/block-list/insertion-point.native.js +4 -2
  228. package/build-module/components/block-list/insertion-point.native.js.map +1 -1
  229. package/build-module/components/block-list/use-block-props/index.js +1 -1
  230. package/build-module/components/block-list/use-block-props/index.js.map +1 -1
  231. package/build-module/components/block-list/use-in-between-inserter.js +6 -5
  232. package/build-module/components/block-list/use-in-between-inserter.js.map +1 -1
  233. package/build-module/components/block-list-appender/index.js +15 -1
  234. package/build-module/components/block-list-appender/index.js.map +1 -1
  235. package/build-module/components/block-mobile-toolbar/block-actions-menu.native.js +18 -4
  236. package/build-module/components/block-mobile-toolbar/block-actions-menu.native.js.map +1 -1
  237. package/build-module/components/block-settings-menu/block-settings-dropdown.js +8 -9
  238. package/build-module/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  239. package/build-module/components/block-settings-menu-controls/index.js +13 -5
  240. package/build-module/components/block-settings-menu-controls/index.js.map +1 -1
  241. package/build-module/components/block-styles/preview-panel.js +1 -2
  242. package/build-module/components/block-styles/preview-panel.js.map +1 -1
  243. package/build-module/components/block-switcher/block-transformations-menu.js +7 -0
  244. package/build-module/components/block-switcher/block-transformations-menu.js.map +1 -1
  245. package/build-module/components/block-switcher/block-variation-transformations.js +108 -0
  246. package/build-module/components/block-switcher/block-variation-transformations.js.map +1 -0
  247. package/build-module/components/block-switcher/index.js +33 -12
  248. package/build-module/components/block-switcher/index.js.map +1 -1
  249. package/build-module/components/block-switcher/pattern-transformations-menu.js +3 -3
  250. package/build-module/components/block-switcher/pattern-transformations-menu.js.map +1 -1
  251. package/build-module/components/block-toolbar/index.js +8 -7
  252. package/build-module/components/block-toolbar/index.js.map +1 -1
  253. package/build-module/components/block-tools/block-contextual-toolbar.js +22 -65
  254. package/build-module/components/block-tools/block-contextual-toolbar.js.map +1 -1
  255. package/build-module/components/block-tools/insertion-point.js +11 -5
  256. package/build-module/components/block-tools/insertion-point.js.map +1 -1
  257. package/build-module/components/block-tools/selected-block-popover.js +3 -7
  258. package/build-module/components/block-tools/selected-block-popover.js.map +1 -1
  259. package/build-module/components/colors-gradients/use-multiple-origin-colors-and-gradients.js +3 -2
  260. package/build-module/components/colors-gradients/use-multiple-origin-colors-and-gradients.js.map +1 -1
  261. package/build-module/components/convert-to-group-buttons/index.js +7 -2
  262. package/build-module/components/convert-to-group-buttons/index.js.map +1 -1
  263. package/build-module/components/convert-to-group-buttons/index.native.js +76 -1
  264. package/build-module/components/convert-to-group-buttons/index.native.js.map +1 -1
  265. package/build-module/components/convert-to-group-buttons/use-convert-to-group-button-props.js +22 -36
  266. package/build-module/components/convert-to-group-buttons/use-convert-to-group-button-props.js.map +1 -1
  267. package/build-module/components/global-styles/advanced-panel.js +74 -0
  268. package/build-module/components/global-styles/advanced-panel.js.map +1 -0
  269. package/build-module/components/global-styles/color-panel.js +5 -2
  270. package/build-module/components/global-styles/color-panel.js.map +1 -1
  271. package/build-module/components/global-styles/dimensions-panel.js +9 -8
  272. package/build-module/components/global-styles/dimensions-panel.js.map +1 -1
  273. package/build-module/components/global-styles/hooks.js +1 -2
  274. package/build-module/components/global-styles/hooks.js.map +1 -1
  275. package/build-module/components/global-styles/index.js +3 -1
  276. package/build-module/components/global-styles/index.js.map +1 -1
  277. package/build-module/components/global-styles/typography-panel.js +1 -1
  278. package/build-module/components/global-styles/typography-panel.js.map +1 -1
  279. package/build-module/components/global-styles/use-global-styles-output.js +25 -4
  280. package/build-module/components/global-styles/use-global-styles-output.js.map +1 -1
  281. package/build-module/components/global-styles/utils.js +25 -0
  282. package/build-module/components/global-styles/utils.js.map +1 -1
  283. package/build-module/components/iframe/index.js +15 -8
  284. package/build-module/components/iframe/index.js.map +1 -1
  285. package/build-module/components/image-editor/use-save-image.js +24 -8
  286. package/build-module/components/image-editor/use-save-image.js.map +1 -1
  287. package/build-module/components/inner-blocks/index.js +2 -1
  288. package/build-module/components/inner-blocks/index.js.map +1 -1
  289. package/build-module/components/inner-blocks/index.native.js +7 -6
  290. package/build-module/components/inner-blocks/index.native.js.map +1 -1
  291. package/build-module/components/inner-blocks/use-nested-settings-update.js +13 -5
  292. package/build-module/components/inner-blocks/use-nested-settings-update.js.map +1 -1
  293. package/build-module/components/inserter/index.js +3 -7
  294. package/build-module/components/inserter/index.js.map +1 -1
  295. package/build-module/components/inserter/quick-inserter.js +2 -4
  296. package/build-module/components/inserter/quick-inserter.js.map +1 -1
  297. package/build-module/components/inserter/search-results.js +16 -6
  298. package/build-module/components/inserter/search-results.js.map +1 -1
  299. package/build-module/components/inserter-draggable-blocks/index.js +4 -0
  300. package/build-module/components/inserter-draggable-blocks/index.js.map +1 -1
  301. package/build-module/components/inspector-controls/fill.js +1 -1
  302. package/build-module/components/inspector-controls/fill.js.map +1 -1
  303. package/build-module/components/inspector-controls/fill.native.js +1 -1
  304. package/build-module/components/inspector-controls/fill.native.js.map +1 -1
  305. package/build-module/components/inspector-controls/slot.js +4 -7
  306. package/build-module/components/inspector-controls/slot.js.map +1 -1
  307. package/build-module/components/inspector-controls/slot.native.js +1 -1
  308. package/build-module/components/inspector-controls/slot.native.js.map +1 -1
  309. package/build-module/components/line-height-control/index.js +7 -2
  310. package/build-module/components/line-height-control/index.js.map +1 -1
  311. package/build-module/components/link-control/use-internal-input-value.js +9 -8
  312. package/build-module/components/link-control/use-internal-input-value.js.map +1 -1
  313. package/build-module/components/list-view/appender.js +6 -2
  314. package/build-module/components/list-view/appender.js.map +1 -1
  315. package/build-module/components/list-view/block-contents.js +9 -3
  316. package/build-module/components/list-view/block-contents.js.map +1 -1
  317. package/build-module/components/list-view/block-select-button.js +2 -1
  318. package/build-module/components/list-view/block-select-button.js.map +1 -1
  319. package/build-module/components/list-view/block.js +24 -29
  320. package/build-module/components/list-view/block.js.map +1 -1
  321. package/build-module/components/list-view/branch.js +1 -3
  322. package/build-module/components/list-view/branch.js.map +1 -1
  323. package/build-module/components/list-view/index.js +44 -23
  324. package/build-module/components/list-view/index.js.map +1 -1
  325. package/build-module/components/list-view/use-list-view-client-ids.js +26 -3
  326. package/build-module/components/list-view/use-list-view-client-ids.js.map +1 -1
  327. package/build-module/components/list-view/use-list-view-drop-zone.js +160 -11
  328. package/build-module/components/list-view/use-list-view-drop-zone.js.map +1 -1
  329. package/build-module/components/media-placeholder/index.js +66 -7
  330. package/build-module/components/media-placeholder/index.js.map +1 -1
  331. package/build-module/components/multi-selection-inspector/index.js +2 -2
  332. package/build-module/components/multi-selection-inspector/index.js.map +1 -1
  333. package/build-module/components/preview-options/index.js +7 -2
  334. package/build-module/components/preview-options/index.js.map +1 -1
  335. package/build-module/components/publish-date-time-picker/index.js +0 -2
  336. package/build-module/components/publish-date-time-picker/index.js.map +1 -1
  337. package/build-module/components/spacing-sizes-control/spacing-input-control.js +1 -1
  338. package/build-module/components/spacing-sizes-control/spacing-input-control.js.map +1 -1
  339. package/build-module/components/url-input/index.js +4 -2
  340. package/build-module/components/url-input/index.js.map +1 -1
  341. package/build-module/components/use-block-drop-zone/index.js +25 -16
  342. package/build-module/components/use-block-drop-zone/index.js.map +1 -1
  343. package/build-module/components/use-resize-canvas/index.js +8 -1
  344. package/build-module/components/use-resize-canvas/index.js.map +1 -1
  345. package/build-module/components/writing-flow/use-arrow-nav.js +13 -7
  346. package/build-module/components/writing-flow/use-arrow-nav.js.map +1 -1
  347. package/build-module/hooks/align.js +4 -7
  348. package/build-module/hooks/align.js.map +1 -1
  349. package/build-module/hooks/behaviors.js +97 -0
  350. package/build-module/hooks/behaviors.js.map +1 -0
  351. package/build-module/hooks/border.js +1 -1
  352. package/build-module/hooks/border.js.map +1 -1
  353. package/build-module/hooks/color.js +1 -1
  354. package/build-module/hooks/color.js.map +1 -1
  355. package/build-module/hooks/content-lock-ui.js +8 -11
  356. package/build-module/hooks/content-lock-ui.js.map +1 -1
  357. package/build-module/hooks/dimensions.js +0 -28
  358. package/build-module/hooks/dimensions.js.map +1 -1
  359. package/build-module/hooks/duotone.js +4 -7
  360. package/build-module/hooks/duotone.js.map +1 -1
  361. package/build-module/hooks/index.js +1 -0
  362. package/build-module/hooks/index.js.map +1 -1
  363. package/build-module/hooks/index.native.js +1 -0
  364. package/build-module/hooks/index.native.js.map +1 -1
  365. package/build-module/hooks/layout.js +9 -11
  366. package/build-module/hooks/layout.js.map +1 -1
  367. package/build-module/hooks/position.js +1 -1
  368. package/build-module/hooks/position.js.map +1 -1
  369. package/build-module/hooks/style.js +1 -1
  370. package/build-module/hooks/style.js.map +1 -1
  371. package/build-module/hooks/use-editor-wrapper-styles.native.js +242 -0
  372. package/build-module/hooks/use-editor-wrapper-styles.native.js.map +1 -0
  373. package/build-module/hooks/use-typography-props.js +14 -10
  374. package/build-module/hooks/use-typography-props.js.map +1 -1
  375. package/build-module/index.native.js +6 -0
  376. package/build-module/index.native.js.map +1 -0
  377. package/build-module/private-apis.js +3 -5
  378. package/build-module/private-apis.js.map +1 -1
  379. package/build-module/store/private-actions.js +42 -0
  380. package/build-module/store/private-actions.js.map +1 -1
  381. package/build-module/store/private-selectors.js +79 -0
  382. package/build-module/store/private-selectors.js.map +1 -1
  383. package/build-module/store/reducer.js +34 -1
  384. package/build-module/store/reducer.js.map +1 -1
  385. package/build-module/store/selectors.js +26 -17
  386. package/build-module/store/selectors.js.map +1 -1
  387. package/build-module/utils/order-inserter-block-items.js +32 -0
  388. package/build-module/utils/order-inserter-block-items.js.map +1 -0
  389. package/build-module/utils/use-should-contextual-toolbar-show.js +16 -12
  390. package/build-module/utils/use-should-contextual-toolbar-show.js.map +1 -1
  391. package/build-style/content-rtl.css +32 -14
  392. package/build-style/content.css +32 -14
  393. package/build-style/default-editor-styles-rtl.css +1 -1
  394. package/build-style/default-editor-styles.css +1 -1
  395. package/build-style/style-rtl.css +56 -77
  396. package/build-style/style.css +57 -77
  397. package/package.json +32 -31
  398. package/src/autocompleters/block.js +15 -7
  399. package/src/components/block-breadcrumb/index.js +11 -3
  400. package/src/components/block-breadcrumb/style.scss +2 -1
  401. package/src/components/block-controls/slot.js +8 -4
  402. package/src/components/block-controls/slot.native.js +6 -1
  403. package/src/components/block-draggable/index.js +10 -6
  404. package/src/components/block-draggable/use-scroll-when-dragging.js +8 -2
  405. package/src/components/block-editing-mode/index.js +71 -0
  406. package/src/components/block-list/block-invalid-warning.native.js +17 -9
  407. package/src/components/block-list/block-list-block-context.js +6 -0
  408. package/src/components/block-list/block-list-item-cell.native.js +10 -1
  409. package/src/components/block-list/block-list-item.native.js +180 -208
  410. package/src/components/block-list/block-outline.native.js +58 -0
  411. package/src/components/block-list/block.js +38 -56
  412. package/src/components/block-list/block.native.js +531 -501
  413. package/src/components/block-list/content.scss +5 -6
  414. package/src/components/block-list/index.native.js +324 -382
  415. package/src/components/block-list/insertion-point.native.js +2 -2
  416. package/src/components/block-list/test/block-invalid-warning.native.js +48 -0
  417. package/src/components/block-list/test/index.native.js +205 -0
  418. package/src/components/block-list/use-block-props/index.js +1 -1
  419. package/src/components/block-list/use-in-between-inserter.js +7 -3
  420. package/src/components/block-list-appender/index.js +22 -4
  421. package/src/components/block-mobile-toolbar/block-actions-menu.native.js +26 -1
  422. package/src/components/block-mover/style.scss +1 -0
  423. package/src/components/block-pattern-setup/style.scss +1 -4
  424. package/src/components/block-patterns-list/style.scss +1 -4
  425. package/src/components/block-settings-menu/block-settings-dropdown.js +10 -17
  426. package/src/components/block-settings-menu-controls/index.js +24 -4
  427. package/src/components/block-styles/preview-panel.js +1 -3
  428. package/src/components/block-styles/style.scss +4 -4
  429. package/src/components/block-switcher/block-transformations-menu.js +12 -0
  430. package/src/components/block-switcher/block-variation-transformations.js +115 -0
  431. package/src/components/block-switcher/index.js +38 -5
  432. package/src/components/block-switcher/pattern-transformations-menu.js +5 -5
  433. package/src/components/block-switcher/style.scss +6 -5
  434. package/src/components/block-toolbar/index.js +10 -11
  435. package/src/components/block-tools/block-contextual-toolbar.js +32 -67
  436. package/src/components/block-tools/insertion-point.js +23 -9
  437. package/src/components/block-tools/selected-block-popover.js +3 -5
  438. package/src/components/block-tools/style.scss +8 -0
  439. package/src/components/button-block-appender/content.scss +22 -0
  440. package/src/components/colors-gradients/use-multiple-origin-colors-and-gradients.js +16 -2
  441. package/src/components/convert-to-group-buttons/index.js +9 -2
  442. package/src/components/convert-to-group-buttons/index.native.js +79 -1
  443. package/src/components/convert-to-group-buttons/use-convert-to-group-button-props.js +32 -38
  444. package/src/components/global-styles/advanced-panel.js +82 -0
  445. package/src/components/global-styles/color-panel.js +6 -1
  446. package/src/components/global-styles/dimensions-panel.js +9 -8
  447. package/src/components/global-styles/hooks.js +1 -5
  448. package/src/components/global-styles/index.js +6 -1
  449. package/src/components/global-styles/style.scss +17 -0
  450. package/src/components/global-styles/test/utils.js +57 -1
  451. package/src/components/global-styles/typography-panel.js +1 -1
  452. package/src/components/global-styles/use-global-styles-output.js +21 -3
  453. package/src/components/global-styles/utils.js +27 -0
  454. package/src/components/iframe/index.js +22 -12
  455. package/src/components/image-editor/use-save-image.js +20 -9
  456. package/src/components/inner-blocks/README.md +5 -0
  457. package/src/components/inner-blocks/index.js +2 -0
  458. package/src/components/inner-blocks/index.native.js +16 -6
  459. package/src/components/inner-blocks/use-nested-settings-update.js +20 -3
  460. package/src/components/inserter/index.js +1 -9
  461. package/src/components/inserter/quick-inserter.js +0 -2
  462. package/src/components/inserter/search-results.js +32 -6
  463. package/src/components/inserter-draggable-blocks/index.js +4 -0
  464. package/src/components/inspector-controls/fill.js +1 -1
  465. package/src/components/inspector-controls/fill.native.js +1 -1
  466. package/src/components/inspector-controls/slot.js +4 -9
  467. package/src/components/inspector-controls/slot.native.js +1 -1
  468. package/src/components/line-height-control/index.js +7 -2
  469. package/src/components/line-height-control/stories/index.js +1 -1
  470. package/src/components/link-control/test/index.js +42 -0
  471. package/src/components/link-control/use-internal-input-value.js +8 -7
  472. package/src/components/list-view/appender.js +3 -2
  473. package/src/components/list-view/block-contents.js +32 -20
  474. package/src/components/list-view/block-select-button.js +5 -1
  475. package/src/components/list-view/block.js +34 -37
  476. package/src/components/list-view/branch.js +1 -7
  477. package/src/components/list-view/index.js +42 -17
  478. package/src/components/list-view/style.scss +7 -7
  479. package/src/components/list-view/test/use-list-view-drop-zone.js +88 -12
  480. package/src/components/list-view/use-list-view-client-ids.js +21 -4
  481. package/src/components/list-view/use-list-view-drop-zone.js +194 -11
  482. package/src/components/media-placeholder/index.js +74 -1
  483. package/src/components/multi-selection-inspector/index.js +2 -2
  484. package/src/components/preview-options/index.js +9 -2
  485. package/src/components/publish-date-time-picker/index.js +0 -2
  486. package/src/components/spacing-sizes-control/spacing-input-control.js +1 -0
  487. package/src/components/url-input/README.md +6 -0
  488. package/src/components/url-input/index.js +2 -2
  489. package/src/components/use-block-drop-zone/index.js +31 -17
  490. package/src/components/use-resize-canvas/index.js +9 -1
  491. package/src/components/writing-flow/test/index.js +15 -0
  492. package/src/components/writing-flow/use-arrow-nav.js +17 -4
  493. package/src/hooks/align.js +5 -12
  494. package/src/hooks/behaviors.js +104 -0
  495. package/src/hooks/border.js +2 -1
  496. package/src/hooks/color.js +2 -1
  497. package/src/hooks/content-lock-ui.js +3 -15
  498. package/src/hooks/dimensions.js +0 -40
  499. package/src/hooks/duotone.js +4 -11
  500. package/src/hooks/index.js +1 -0
  501. package/src/hooks/index.native.js +1 -0
  502. package/src/hooks/layout.js +14 -20
  503. package/src/hooks/position.js +2 -1
  504. package/src/hooks/style.js +2 -1
  505. package/src/hooks/test/use-editor-wrapper-styles.native.js +282 -0
  506. package/src/hooks/test/use-typography-props.js +47 -2
  507. package/src/hooks/use-editor-wrapper-styles.native.js +250 -0
  508. package/src/hooks/use-editor-wrapper-styles.native.scss +11 -0
  509. package/src/hooks/use-typography-props.js +10 -11
  510. package/src/index.native.js +6 -0
  511. package/src/private-apis.js +2 -4
  512. package/src/store/private-actions.js +39 -0
  513. package/src/store/private-selectors.js +95 -0
  514. package/src/store/reducer.js +27 -0
  515. package/src/store/selectors.js +25 -15
  516. package/src/store/test/private-actions.js +32 -1
  517. package/src/store/test/private-selectors.js +158 -0
  518. package/src/store/test/reducer.js +48 -0
  519. package/src/style.scss +0 -3
  520. package/src/utils/order-inserter-block-items.js +26 -0
  521. package/src/utils/use-should-contextual-toolbar-show.js +19 -9
  522. package/tsconfig.json +1 -0
  523. package/tsconfig.tsbuildinfo +1 -1
  524. package/build/components/block-list/block-list-compact.native.js +0 -75
  525. package/build/components/block-list/block-list-compact.native.js.map +0 -1
  526. package/build/components/off-canvas-editor/appender.js +0 -125
  527. package/build/components/off-canvas-editor/appender.js.map +0 -1
  528. package/build/components/off-canvas-editor/block-contents.js +0 -141
  529. package/build/components/off-canvas-editor/block-contents.js.map +0 -1
  530. package/build/components/off-canvas-editor/block-select-button.js +0 -126
  531. package/build/components/off-canvas-editor/block-select-button.js.map +0 -1
  532. package/build/components/off-canvas-editor/block.js +0 -297
  533. package/build/components/off-canvas-editor/block.js.map +0 -1
  534. package/build/components/off-canvas-editor/branch.js +0 -197
  535. package/build/components/off-canvas-editor/branch.js.map +0 -1
  536. package/build/components/off-canvas-editor/context.js +0 -19
  537. package/build/components/off-canvas-editor/context.js.map +0 -1
  538. package/build/components/off-canvas-editor/drop-indicator.js +0 -118
  539. package/build/components/off-canvas-editor/drop-indicator.js.map +0 -1
  540. package/build/components/off-canvas-editor/expander.js +0 -41
  541. package/build/components/off-canvas-editor/expander.js.map +0 -1
  542. package/build/components/off-canvas-editor/index.js +0 -236
  543. package/build/components/off-canvas-editor/index.js.map +0 -1
  544. package/build/components/off-canvas-editor/leaf-more-menu.js +0 -146
  545. package/build/components/off-canvas-editor/leaf-more-menu.js.map +0 -1
  546. package/build/components/off-canvas-editor/leaf.js +0 -60
  547. package/build/components/off-canvas-editor/leaf.js.map +0 -1
  548. package/build/components/off-canvas-editor/link-ui.js +0 -186
  549. package/build/components/off-canvas-editor/link-ui.js.map +0 -1
  550. package/build/components/off-canvas-editor/update-attributes.js +0 -108
  551. package/build/components/off-canvas-editor/update-attributes.js.map +0 -1
  552. package/build/components/off-canvas-editor/use-block-selection.js +0 -139
  553. package/build/components/off-canvas-editor/use-block-selection.js.map +0 -1
  554. package/build/components/off-canvas-editor/use-inserted-block.js +0 -58
  555. package/build/components/off-canvas-editor/use-inserted-block.js.map +0 -1
  556. package/build/components/off-canvas-editor/use-list-view-client-ids.js +0 -33
  557. package/build/components/off-canvas-editor/use-list-view-client-ids.js.map +0 -1
  558. package/build/components/off-canvas-editor/use-list-view-drop-zone.js +0 -235
  559. package/build/components/off-canvas-editor/use-list-view-drop-zone.js.map +0 -1
  560. package/build/components/off-canvas-editor/use-list-view-expand-selected-item.js +0 -60
  561. package/build/components/off-canvas-editor/use-list-view-expand-selected-item.js.map +0 -1
  562. package/build/components/off-canvas-editor/utils.js +0 -60
  563. package/build/components/off-canvas-editor/utils.js.map +0 -1
  564. package/build-module/components/block-list/block-list-compact.native.js +0 -60
  565. package/build-module/components/block-list/block-list-compact.native.js.map +0 -1
  566. package/build-module/components/off-canvas-editor/appender.js +0 -108
  567. package/build-module/components/off-canvas-editor/appender.js.map +0 -1
  568. package/build-module/components/off-canvas-editor/block-contents.js +0 -121
  569. package/build-module/components/off-canvas-editor/block-contents.js.map +0 -1
  570. package/build-module/components/off-canvas-editor/block-select-button.js +0 -107
  571. package/build-module/components/off-canvas-editor/block-select-button.js.map +0 -1
  572. package/build-module/components/off-canvas-editor/block.js +0 -273
  573. package/build-module/components/off-canvas-editor/block.js.map +0 -1
  574. package/build-module/components/off-canvas-editor/branch.js +0 -179
  575. package/build-module/components/off-canvas-editor/branch.js.map +0 -1
  576. package/build-module/components/off-canvas-editor/context.js +0 -7
  577. package/build-module/components/off-canvas-editor/context.js.map +0 -1
  578. package/build-module/components/off-canvas-editor/drop-indicator.js +0 -111
  579. package/build-module/components/off-canvas-editor/drop-indicator.js.map +0 -1
  580. package/build-module/components/off-canvas-editor/expander.js +0 -32
  581. package/build-module/components/off-canvas-editor/expander.js.map +0 -1
  582. package/build-module/components/off-canvas-editor/index.js +0 -213
  583. package/build-module/components/off-canvas-editor/index.js.map +0 -1
  584. package/build-module/components/off-canvas-editor/leaf-more-menu.js +0 -128
  585. package/build-module/components/off-canvas-editor/leaf-more-menu.js.map +0 -1
  586. package/build-module/components/off-canvas-editor/leaf.js +0 -45
  587. package/build-module/components/off-canvas-editor/leaf.js.map +0 -1
  588. package/build-module/components/off-canvas-editor/link-ui.js +0 -166
  589. package/build-module/components/off-canvas-editor/link-ui.js.map +0 -1
  590. package/build-module/components/off-canvas-editor/update-attributes.js +0 -97
  591. package/build-module/components/off-canvas-editor/update-attributes.js.map +0 -1
  592. package/build-module/components/off-canvas-editor/use-block-selection.js +0 -124
  593. package/build-module/components/off-canvas-editor/use-block-selection.js.map +0 -1
  594. package/build-module/components/off-canvas-editor/use-inserted-block.js +0 -47
  595. package/build-module/components/off-canvas-editor/use-inserted-block.js.map +0 -1
  596. package/build-module/components/off-canvas-editor/use-list-view-client-ids.js +0 -24
  597. package/build-module/components/off-canvas-editor/use-list-view-client-ids.js.map +0 -1
  598. package/build-module/components/off-canvas-editor/use-list-view-drop-zone.js +0 -220
  599. package/build-module/components/off-canvas-editor/use-list-view-drop-zone.js.map +0 -1
  600. package/build-module/components/off-canvas-editor/use-list-view-expand-selected-item.js +0 -50
  601. package/build-module/components/off-canvas-editor/use-list-view-expand-selected-item.js.map +0 -1
  602. package/build-module/components/off-canvas-editor/utils.js +0 -44
  603. package/build-module/components/off-canvas-editor/utils.js.map +0 -1
  604. package/src/components/block-list/block-list-compact.native.js +0 -63
  605. package/src/components/off-canvas-editor/README.md +0 -5
  606. package/src/components/off-canvas-editor/appender.js +0 -124
  607. package/src/components/off-canvas-editor/block-contents.js +0 -156
  608. package/src/components/off-canvas-editor/block-select-button.js +0 -128
  609. package/src/components/off-canvas-editor/block.js +0 -347
  610. package/src/components/off-canvas-editor/branch.js +0 -238
  611. package/src/components/off-canvas-editor/context.js +0 -8
  612. package/src/components/off-canvas-editor/drop-indicator.js +0 -126
  613. package/src/components/off-canvas-editor/expander.js +0 -26
  614. package/src/components/off-canvas-editor/index.js +0 -271
  615. package/src/components/off-canvas-editor/leaf-more-menu.js +0 -157
  616. package/src/components/off-canvas-editor/leaf.js +0 -52
  617. package/src/components/off-canvas-editor/link-ui.js +0 -167
  618. package/src/components/off-canvas-editor/style.scss +0 -34
  619. package/src/components/off-canvas-editor/test/use-inserted-block.js +0 -108
  620. package/src/components/off-canvas-editor/test/utils.js +0 -50
  621. package/src/components/off-canvas-editor/update-attributes.js +0 -99
  622. package/src/components/off-canvas-editor/use-block-selection.js +0 -169
  623. package/src/components/off-canvas-editor/use-inserted-block.js +0 -47
  624. package/src/components/off-canvas-editor/use-list-view-client-ids.js +0 -29
  625. package/src/components/off-canvas-editor/use-list-view-drop-zone.js +0 -260
  626. package/src/components/off-canvas-editor/use-list-view-expand-selected-item.js +0 -58
  627. package/src/components/off-canvas-editor/utils.js +0 -58
@@ -9,11 +9,10 @@ import { View, Platform, TouchableWithoutFeedback } from 'react-native';
9
9
  * WordPress dependencies
10
10
  */
11
11
 
12
- import { Component } from '@wordpress/element';
13
- import { withDispatch, withSelect } from '@wordpress/data';
14
- import { compose, withPreferredColorScheme } from '@wordpress/compose';
12
+ import { useRef, useState } from '@wordpress/element';
13
+ import { useSelect, useDispatch } from '@wordpress/data';
15
14
  import { createBlock } from '@wordpress/blocks';
16
- import { KeyboardAwareFlatList, ReadableContentView, WIDE_ALIGNMENTS, alignmentHelpers } from '@wordpress/components';
15
+ import { KeyboardAwareFlatList, WIDE_ALIGNMENTS, alignmentHelpers } from '@wordpress/components';
17
16
  import { __ } from '@wordpress/i18n';
18
17
  /**
19
18
  * Internal dependencies
@@ -23,19 +22,16 @@ import styles from './style.scss';
23
22
  import BlockListAppender from '../block-list-appender';
24
23
  import BlockListItem from './block-list-item';
25
24
  import BlockListItemCell from './block-list-item-cell';
26
- import { BlockListProvider, BlockListConsumer, DEFAULT_BLOCK_LIST_CONTEXT } from './block-list-context';
25
+ import { BlockListProvider, DEFAULT_BLOCK_LIST_CONTEXT } from './block-list-context';
27
26
  import { BlockDraggableWrapper } from '../block-draggable';
27
+ import { useEditorWrapperStyles } from '../../hooks/use-editor-wrapper-styles';
28
28
  import { store as blockEditorStore } from '../../store';
29
29
 
30
30
  const identity = x => x;
31
31
 
32
32
  const stylesMemo = {};
33
33
 
34
- const getStyles = (isRootList, isStackedHorizontally, horizontalAlignment) => {
35
- if (isRootList) {
36
- return;
37
- }
38
-
34
+ const getStyles = (isStackedHorizontally, horizontalAlignment) => {
39
35
  const styleName = `${isStackedHorizontally}-${horizontalAlignment}`;
40
36
 
41
37
  if (stylesMemo[styleName]) {
@@ -47,74 +43,97 @@ const getStyles = (isRootList, isStackedHorizontally, horizontalAlignment) => {
47
43
  return computedStyles;
48
44
  };
49
45
 
50
- export class BlockList extends Component {
51
- constructor() {
52
- super(...arguments);
53
- this.extraData = {
54
- parentWidth: this.props.parentWidth,
55
- renderFooterAppender: this.props.renderFooterAppender,
56
- renderAppender: this.props.renderAppender,
57
- onDeleteBlock: this.props.onDeleteBlock,
58
- contentStyle: this.props.contentStyle
59
- };
60
- this.renderItem = this.renderItem.bind(this);
61
- this.renderBlockListFooter = this.renderBlockListFooter.bind(this);
62
- this.scrollViewInnerRef = this.scrollViewInnerRef.bind(this);
63
- this.addBlockToEndOfPost = this.addBlockToEndOfPost.bind(this);
64
- this.shouldFlatListPreventAutomaticScroll = this.shouldFlatListPreventAutomaticScroll.bind(this);
65
- this.shouldShowInnerBlockAppender = this.shouldShowInnerBlockAppender.bind(this);
66
- this.renderEmptyList = this.renderEmptyList.bind(this);
67
- this.getExtraData = this.getExtraData.bind(this);
68
- this.getCellRendererComponent = this.getCellRendererComponent.bind(this);
69
- this.onLayout = this.onLayout.bind(this);
70
- this.state = {
71
- blockWidth: this.props.blockWidth || 0
72
- };
73
- }
74
-
75
- addBlockToEndOfPost(newBlock) {
76
- this.props.insertBlock(newBlock, this.props.blockCount);
77
- }
78
-
79
- scrollViewInnerRef(ref) {
80
- this.scrollViewRef = ref;
81
- }
82
-
83
- shouldFlatListPreventAutomaticScroll() {
84
- return this.props.isBlockInsertionPointVisible;
85
- }
46
+ export default function BlockList(_ref) {
47
+ let {
48
+ blockWidth: initialBlockWidth,
49
+ contentResizeMode,
50
+ contentStyle,
51
+ filterInnerBlocks,
52
+ gridProperties,
53
+ header,
54
+ horizontal,
55
+ horizontalAlignment,
56
+ marginHorizontal = styles.defaultBlock.marginLeft,
57
+ marginVertical = styles.defaultBlock.marginTop,
58
+ onAddBlock,
59
+ onDeleteBlock,
60
+ orientation,
61
+ parentWidth,
62
+ renderAppender,
63
+ renderFooterAppender,
64
+ rootClientId,
65
+ withFooter = true
66
+ } = _ref;
67
+ const {
68
+ blockClientIds,
69
+ blockCount,
70
+ blockInsertionPointIsVisible,
71
+ isReadOnly,
72
+ isRootList,
73
+ isFloatingToolbarVisible,
74
+ isStackedHorizontally,
75
+ maxWidth,
76
+ isRTL
77
+ } = useSelect(select => {
78
+ const {
79
+ getBlockCount,
80
+ getBlockHierarchyRootClientId,
81
+ getBlockOrder,
82
+ getSelectedBlockClientId,
83
+ isBlockInsertionPointVisible,
84
+ getSettings
85
+ } = select(blockEditorStore);
86
+ const selectedBlockClientId = getSelectedBlockClientId();
87
+ const rootBlockId = getBlockHierarchyRootClientId(selectedBlockClientId);
88
+ let blockOrder = getBlockOrder(rootClientId); // Display only block which fulfill the condition in passed `filterInnerBlocks` function.
89
+
90
+ if (filterInnerBlocks) {
91
+ blockOrder = filterInnerBlocks(blockOrder);
92
+ }
86
93
 
87
- shouldShowInnerBlockAppender() {
88
94
  const {
89
- blockClientIds,
90
- renderAppender
91
- } = this.props;
92
- return renderAppender && blockClientIds.length > 0;
93
- }
95
+ isRTL: isRTLSetting,
96
+ maxWidth: maxWidthSetting,
97
+ readOnly
98
+ } = getSettings();
99
+ return {
100
+ blockClientIds: blockOrder,
101
+ blockCount: getBlockCount(),
102
+ blockInsertionPointIsVisible: Platform.OS === 'ios' && isBlockInsertionPointVisible(),
103
+ isReadOnly: readOnly,
104
+ isRootList: rootClientId === undefined,
105
+ isFloatingToolbarVisible: !!selectedBlockClientId && !!getBlockCount(rootBlockId),
106
+ isStackedHorizontally: orientation === 'horizontal',
107
+ maxWidth: maxWidthSetting,
108
+ isRTL: isRTLSetting
109
+ };
110
+ }, [filterInnerBlocks, orientation, rootClientId]);
111
+ const {
112
+ insertBlock,
113
+ clearSelectedBlock
114
+ } = useDispatch(blockEditorStore);
115
+ const extraData = useRef({
116
+ parentWidth,
117
+ renderFooterAppender,
118
+ renderAppender,
119
+ onDeleteBlock,
120
+ contentStyle
121
+ });
122
+ const [blockWidth, setBlockWidth] = useState(initialBlockWidth || 0);
123
+
124
+ const addBlockToEndOfPost = newBlock => {
125
+ insertBlock(newBlock, blockCount);
126
+ };
94
127
 
95
- renderEmptyList() {
96
- return createElement(EmptyListComponentCompose, {
97
- rootClientId: this.props.rootClientId,
98
- renderAppender: this.props.renderAppender,
99
- renderFooterAppender: this.props.renderFooterAppender
100
- });
101
- }
128
+ const scrollViewRef = useRef(null);
102
129
 
103
- getExtraData() {
104
- const {
105
- parentWidth,
106
- renderFooterAppender,
107
- onDeleteBlock,
108
- contentStyle,
109
- renderAppender,
110
- gridProperties
111
- } = this.props;
112
- const {
113
- blockWidth
114
- } = this.state;
130
+ const shouldFlatListPreventAutomaticScroll = () => blockInsertionPointIsVisible;
131
+
132
+ const shouldShowInnerBlockAppender = () => renderAppender && blockClientIds.length > 0;
115
133
 
116
- if (this.extraData.parentWidth !== parentWidth || this.extraData.renderFooterAppender !== renderFooterAppender || this.extraData.onDeleteBlock !== onDeleteBlock || this.extraData.contentStyle !== contentStyle || this.extraData.renderAppender !== renderAppender || this.extraData.blockWidth !== blockWidth || this.extraData.gridProperties !== gridProperties) {
117
- this.extraData = {
134
+ const getExtraData = () => {
135
+ if (extraData.current.parentWidth !== parentWidth || extraData.current.renderFooterAppender !== renderFooterAppender || extraData.current.onDeleteBlock !== onDeleteBlock || extraData.current.contentStyle !== contentStyle || extraData.current.renderAppender !== renderAppender || extraData.current.blockWidth !== blockWidth || extraData.current.gridProperties !== gridProperties) {
136
+ extraData.current = {
118
137
  parentWidth,
119
138
  renderFooterAppender,
120
139
  onDeleteBlock,
@@ -125,188 +144,32 @@ export class BlockList extends Component {
125
144
  };
126
145
  }
127
146
 
128
- return this.extraData;
129
- }
130
-
131
- getCellRendererComponent(_ref) {
132
- let {
133
- children,
134
- item,
135
- onLayout
136
- } = _ref;
137
- const {
138
- rootClientId
139
- } = this.props;
140
- return createElement(BlockListItemCell, {
141
- children: children,
142
- clientId: item,
143
- onLayout: onLayout,
144
- rootClientId: rootClientId
145
- });
146
- }
147
+ return extraData.current;
148
+ };
147
149
 
148
- onLayout(_ref2) {
150
+ const onLayout = _ref2 => {
149
151
  let {
150
152
  nativeEvent
151
153
  } = _ref2;
152
154
  const {
153
155
  layout
154
156
  } = nativeEvent;
155
- const {
156
- blockWidth
157
- } = this.state;
158
- const {
159
- isRootList,
160
- maxWidth
161
- } = this.props;
162
157
  const layoutWidth = Math.floor(layout.width);
163
158
 
164
159
  if (isRootList && blockWidth !== layoutWidth) {
165
- this.setState({
166
- blockWidth: Math.min(layoutWidth, maxWidth)
167
- });
160
+ setBlockWidth(Math.min(layoutWidth, maxWidth));
168
161
  } else if (!isRootList && !blockWidth) {
169
- this.setState({
170
- blockWidth: Math.min(layoutWidth, maxWidth)
171
- });
162
+ setBlockWidth(Math.min(layoutWidth, maxWidth));
172
163
  }
173
- }
174
-
175
- render() {
176
- const {
177
- isRootList,
178
- isRTL
179
- } = this.props; // Use of Context to propagate the main scroll ref to its children e.g InnerBlocks.
180
-
181
- const blockList = isRootList ? createElement(BlockListProvider, {
182
- value: { ...DEFAULT_BLOCK_LIST_CONTEXT,
183
- scrollRef: this.scrollViewRef
184
- }
185
- }, createElement(BlockDraggableWrapper, {
186
- isRTL: isRTL
187
- }, _ref3 => {
188
- let {
189
- onScroll
190
- } = _ref3;
191
- return this.renderList({
192
- onScroll
193
- });
194
- })) : createElement(BlockListConsumer, null, _ref4 => {
195
- let {
196
- scrollRef
197
- } = _ref4;
198
- return this.renderList({
199
- parentScrollRef: scrollRef
200
- });
201
- });
202
- return blockList;
203
- }
204
-
205
- renderList() {
206
- let extraProps = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
207
- const {
208
- clearSelectedBlock,
209
- blockClientIds,
210
- title,
211
- header,
212
- isReadOnly,
213
- isRootList,
214
- horizontal,
215
- marginVertical = styles.defaultBlock.marginTop,
216
- marginHorizontal = styles.defaultBlock.marginLeft,
217
- isFloatingToolbarVisible,
218
- isStackedHorizontally,
219
- horizontalAlignment,
220
- contentResizeMode,
221
- blockWidth
222
- } = this.props;
223
- const {
224
- parentScrollRef,
225
- onScroll
226
- } = extraProps;
227
- const {
228
- blockToolbar,
229
- headerToolbar,
230
- floatingToolbar
231
- } = styles;
232
- const containerStyle = {
233
- flex: isRootList ? 1 : 0,
234
- // We set negative margin in the parent to remove the edge spacing between parent block and child block in ineer blocks.
235
- marginVertical: isRootList ? 0 : -marginVertical,
236
- marginHorizontal: isRootList ? 0 : -marginHorizontal
237
- };
238
- const isContentStretch = contentResizeMode === 'stretch';
239
- const isMultiBlocks = blockClientIds.length > 1;
240
- const {
241
- isWider
242
- } = alignmentHelpers;
243
- const extraScrollHeight = headerToolbar.height + blockToolbar.height + (isFloatingToolbarVisible ? floatingToolbar.height : 0);
244
- const scrollViewStyle = [{
245
- flex: isRootList ? 1 : 0
246
- }, !isRootList && styles.overflowVisible];
247
- return createElement(View, {
248
- style: containerStyle,
249
- onAccessibilityEscape: clearSelectedBlock,
250
- onLayout: this.onLayout,
251
- testID: "block-list-wrapper"
252
- }, createElement(KeyboardAwareFlatList, _extends({}, Platform.OS === 'android' ? {
253
- removeClippedSubviews: false
254
- } : {}, {
255
- // Disable clipping on Android to fix focus losing. See https://github.com/wordpress-mobile/gutenberg-mobile/pull/741#issuecomment-472746541
256
- accessibilityLabel: "block-list",
257
- innerRef: ref => {
258
- this.scrollViewInnerRef(parentScrollRef || ref);
259
- },
260
- extraScrollHeight: extraScrollHeight,
261
- keyboardShouldPersistTaps: "always",
262
- scrollViewStyle: scrollViewStyle,
263
- extraData: this.getExtraData(),
264
- scrollEnabled: isRootList,
265
- contentContainerStyle: [horizontal && styles.horizontalContentContainer, isWider(blockWidth, 'medium') && (isContentStretch && isMultiBlocks ? styles.horizontalContentContainerStretch : styles.horizontalContentContainerCenter)],
266
- style: getStyles(isRootList, isStackedHorizontally, horizontalAlignment),
267
- data: blockClientIds,
268
- keyExtractor: identity,
269
- renderItem: this.renderItem,
270
- CellRendererComponent: this.getCellRendererComponent,
271
- shouldPreventAutomaticScroll: this.shouldFlatListPreventAutomaticScroll,
272
- title: title,
273
- ListHeaderComponent: header,
274
- ListEmptyComponent: !isReadOnly && this.renderEmptyList,
275
- ListFooterComponent: this.renderBlockListFooter,
276
- onScroll: onScroll
277
- })), this.shouldShowInnerBlockAppender() && createElement(View, {
278
- style: {
279
- marginHorizontal: marginHorizontal - styles.innerAppender.marginLeft
280
- }
281
- }, createElement(BlockListAppender, {
282
- rootClientId: this.props.rootClientId,
283
- renderAppender: this.props.renderAppender,
284
- showSeparator: true
285
- })));
286
- }
164
+ };
287
165
 
288
- renderItem(_ref5) {
166
+ const renderItem = _ref3 => {
289
167
  let {
290
- item: clientId
291
- } = _ref5;
292
- const {
293
- contentResizeMode,
294
- contentStyle,
295
- onAddBlock,
296
- onDeleteBlock,
297
- rootClientId,
298
- isStackedHorizontally,
299
- blockClientIds,
300
- parentWidth,
301
- marginVertical = styles.defaultBlock.marginTop,
302
- marginHorizontal = styles.defaultBlock.marginLeft,
303
- gridProperties
304
- } = this.props;
305
- const {
306
- blockWidth
307
- } = this.state; // Extracting the grid item properties here to avoid
168
+ item: clientId,
169
+ index
170
+ } = _ref3;
171
+ // Extracting the grid item properties here to avoid
308
172
  // re-renders in the blockListItem component.
309
-
310
173
  const isGridItem = !!gridProperties;
311
174
  const gridItemProps = gridProperties && {
312
175
  numOfColumns: gridProperties.numColumns,
@@ -314,6 +177,7 @@ export class BlockList extends Component {
314
177
  tileIndex: blockClientIds.indexOf(clientId)
315
178
  };
316
179
  return createElement(BlockListItem, _extends({
180
+ index: index,
317
181
  isStackedHorizontally: isStackedHorizontally,
318
182
  rootClientId: rootClientId,
319
183
  clientId: clientId,
@@ -324,137 +188,181 @@ export class BlockList extends Component {
324
188
  marginVertical: marginVertical,
325
189
  marginHorizontal: marginHorizontal,
326
190
  onDeleteBlock: onDeleteBlock,
327
- shouldShowInnerBlockAppender: this.shouldShowInnerBlockAppender,
191
+ shouldShowInnerBlockAppender: shouldShowInnerBlockAppender,
328
192
  blockWidth: blockWidth,
329
193
  isGridItem: isGridItem
330
194
  }, gridItemProps));
331
- }
332
-
333
- renderBlockListFooter() {
334
- const paragraphBlock = createBlock('core/paragraph');
335
- const {
336
- isReadOnly,
337
- withFooter = true,
338
- renderFooterAppender
339
- } = this.props;
195
+ };
340
196
 
341
- if (!isReadOnly && withFooter) {
342
- return createElement(Fragment, null, createElement(TouchableWithoutFeedback, {
343
- accessibilityLabel: __('Add paragraph block'),
344
- testID: __('Add paragraph block'),
345
- onPress: () => {
346
- this.addBlockToEndOfPost(paragraphBlock);
347
- }
348
- }, createElement(View, {
349
- style: styles.blockListFooter
350
- })));
351
- } else if (renderFooterAppender) {
352
- return renderFooterAppender();
197
+ const {
198
+ blockToolbar,
199
+ headerToolbar,
200
+ floatingToolbar
201
+ } = styles;
202
+ const containerStyle = {
203
+ flex: isRootList ? 1 : 0,
204
+ // We set negative margin in the parent to remove the edge spacing between parent block and child block in ineer blocks.
205
+ marginVertical: isRootList ? 0 : -marginVertical,
206
+ marginHorizontal: isRootList ? 0 : -marginHorizontal
207
+ };
208
+ const isContentStretch = contentResizeMode === 'stretch';
209
+ const isMultiBlocks = blockClientIds.length > 1;
210
+ const {
211
+ isWider
212
+ } = alignmentHelpers;
213
+ const extraScrollHeight = headerToolbar.height + blockToolbar.height + (isFloatingToolbarVisible ? floatingToolbar.height : 0);
214
+ return createElement(View, {
215
+ style: containerStyle,
216
+ onAccessibilityEscape: clearSelectedBlock,
217
+ onLayout: onLayout,
218
+ testID: "block-list-wrapper"
219
+ }, isRootList ? createElement(BlockListProvider, {
220
+ value: { ...DEFAULT_BLOCK_LIST_CONTEXT,
221
+ scrollRef: scrollViewRef.current
222
+ }
223
+ }, createElement(BlockDraggableWrapper, {
224
+ isRTL: isRTL
225
+ }, _ref4 => {
226
+ let {
227
+ onScroll
228
+ } = _ref4;
229
+ return createElement(KeyboardAwareFlatList, _extends({}, Platform.OS === 'android' ? {
230
+ removeClippedSubviews: false
231
+ } : {}, {
232
+ // Disable clipping on Android to fix focus losing. See https://github.com/wordpress-mobile/gutenberg-mobile/pull/741#issuecomment-472746541
233
+ accessibilityLabel: "block-list",
234
+ innerRef: ref => {
235
+ scrollViewRef.current = ref;
236
+ },
237
+ extraScrollHeight: extraScrollHeight,
238
+ keyboardShouldPersistTaps: "always",
239
+ scrollViewStyle: {
240
+ flex: 1
241
+ },
242
+ extraData: getExtraData(),
243
+ scrollEnabled: isRootList,
244
+ contentContainerStyle: [horizontal && styles.horizontalContentContainer, isWider(blockWidth, 'medium') && (isContentStretch && isMultiBlocks ? styles.horizontalContentContainerStretch : styles.horizontalContentContainerCenter)],
245
+ data: blockClientIds,
246
+ keyExtractor: identity,
247
+ renderItem: renderItem,
248
+ CellRendererComponent: BlockListItemCell,
249
+ shouldPreventAutomaticScroll: shouldFlatListPreventAutomaticScroll,
250
+ ListHeaderComponent: header,
251
+ ListEmptyComponent: !isReadOnly && createElement(EmptyList, {
252
+ orientation: orientation,
253
+ rootClientId: rootClientId,
254
+ renderAppender: renderAppender,
255
+ renderFooterAppender: renderFooterAppender
256
+ }),
257
+ ListFooterComponent: createElement(Footer, {
258
+ addBlockToEndOfPost: addBlockToEndOfPost,
259
+ isReadOnly: isReadOnly,
260
+ renderFooterAppender: renderFooterAppender,
261
+ withFooter: withFooter
262
+ }),
263
+ onScroll: onScroll
264
+ }));
265
+ })) : createElement(Fragment, null, blockClientIds.length > 0 ? createElement(View, {
266
+ style: [{
267
+ flex: 0
268
+ }, styles.overflowVisible]
269
+ }, createElement(View, {
270
+ style: [...getStyles(isStackedHorizontally, horizontalAlignment), horizontal && styles.horizontalContentContainer]
271
+ }, blockClientIds.map((currentClientId, index) => {
272
+ return createElement(View, {
273
+ key: currentClientId
274
+ }, renderItem({
275
+ item: currentClientId,
276
+ index
277
+ }));
278
+ }), createElement(Footer, {
279
+ addBlockToEndOfPost: addBlockToEndOfPost,
280
+ isReadOnly: isReadOnly,
281
+ renderFooterAppender: renderFooterAppender,
282
+ withFooter: withFooter
283
+ }))) : createElement(EmptyList, {
284
+ orientation: orientation,
285
+ rootClientId: rootClientId,
286
+ renderAppender: renderAppender,
287
+ renderFooterAppender: renderFooterAppender
288
+ })), shouldShowInnerBlockAppender() && createElement(View, {
289
+ style: {
290
+ marginHorizontal: marginHorizontal - styles.innerAppender.marginLeft
353
291
  }
292
+ }, createElement(BlockListAppender, {
293
+ rootClientId: rootClientId,
294
+ renderAppender: renderAppender,
295
+ showSeparator: true
296
+ })));
297
+ }
354
298
 
355
- return null;
299
+ function Footer(_ref5) {
300
+ let {
301
+ addBlockToEndOfPost,
302
+ isReadOnly,
303
+ renderFooterAppender,
304
+ withFooter
305
+ } = _ref5;
306
+
307
+ if (!isReadOnly && withFooter) {
308
+ return createElement(Fragment, null, createElement(TouchableWithoutFeedback, {
309
+ accessibilityLabel: __('Add paragraph block'),
310
+ testID: __('Add paragraph block'),
311
+ onPress: () => {
312
+ const paragraphBlock = createBlock('core/paragraph');
313
+ addBlockToEndOfPost(paragraphBlock);
314
+ }
315
+ }, createElement(View, {
316
+ style: styles.blockListFooter
317
+ })));
318
+ } else if (renderFooterAppender) {
319
+ return createElement(View, null, renderFooterAppender());
356
320
  }
357
321
 
322
+ return null;
358
323
  }
359
- export default compose([withSelect((select, _ref6) => {
324
+
325
+ function EmptyList(_ref6) {
360
326
  let {
361
- rootClientId,
362
327
  orientation,
363
- filterInnerBlocks
328
+ renderAppender,
329
+ renderFooterAppender,
330
+ rootClientId
364
331
  } = _ref6;
365
332
  const {
366
- getBlockCount,
367
- getBlockHierarchyRootClientId,
368
- getBlockOrder,
369
- getSelectedBlockClientId,
370
- isBlockInsertionPointVisible,
371
- getSettings
372
- } = select(blockEditorStore);
373
- const isStackedHorizontally = orientation === 'horizontal';
374
- const selectedBlockClientId = getSelectedBlockClientId();
375
- let blockClientIds = getBlockOrder(rootClientId); // Display only block which fulfill the condition in passed `filterInnerBlocks` function.
376
-
377
- if (filterInnerBlocks) {
378
- blockClientIds = filterInnerBlocks(blockClientIds);
379
- }
380
-
381
- const {
382
- maxWidth
383
- } = getSettings();
384
- const isReadOnly = getSettings().readOnly;
385
- const blockCount = getBlockCount();
386
- const rootBlockId = getBlockHierarchyRootClientId(selectedBlockClientId);
387
- const isFloatingToolbarVisible = !!selectedBlockClientId && !!getBlockCount(rootBlockId);
388
- const isRTL = getSettings().isRTL;
389
- return {
390
- blockClientIds,
391
- blockCount,
392
- isBlockInsertionPointVisible: Platform.OS === 'ios' && isBlockInsertionPointVisible(),
393
- isReadOnly,
394
- isRootList: rootClientId === undefined,
395
- isFloatingToolbarVisible,
396
- isStackedHorizontally,
397
- maxWidth,
398
- isRTL
399
- };
400
- }), withDispatch(dispatch => {
401
- const {
402
- insertBlock,
403
- replaceBlock,
404
- clearSelectedBlock
405
- } = dispatch(blockEditorStore);
406
- return {
407
- clearSelectedBlock,
408
- insertBlock,
409
- replaceBlock
410
- };
411
- }), withPreferredColorScheme])(BlockList);
412
-
413
- class EmptyListComponent extends Component {
414
- render() {
333
+ shouldShowInsertionPoint
334
+ } = useSelect(select => {
415
335
  const {
416
- shouldShowInsertionPoint,
417
- rootClientId,
418
- renderAppender,
419
- renderFooterAppender
420
- } = this.props;
421
-
422
- if (renderFooterAppender || renderAppender === false) {
423
- return null;
424
- }
336
+ getBlockOrder,
337
+ getBlockInsertionPoint,
338
+ isBlockInsertionPointVisible
339
+ } = select(blockEditorStore);
340
+ const isStackedHorizontally = orientation === 'horizontal';
341
+ const blockClientIds = getBlockOrder(rootClientId);
342
+ const insertionPoint = getBlockInsertionPoint();
343
+ const blockInsertionPointIsVisible = isBlockInsertionPointVisible();
344
+ return {
345
+ shouldShowInsertionPoint: !isStackedHorizontally && blockInsertionPointIsVisible && insertionPoint.rootClientId === rootClientId && ( // If list is empty, show the insertion point (via the default appender)
346
+ blockClientIds.length === 0 || // Or if the insertion point is right before the denoted block.
347
+ !blockClientIds[insertionPoint.index])
348
+ };
349
+ });
350
+ const align = renderAppender ? WIDE_ALIGNMENTS.alignments.full : undefined;
351
+ const [wrapperStyles] = useEditorWrapperStyles({
352
+ align
353
+ });
425
354
 
426
- return createElement(View, {
427
- style: styles.defaultAppender
428
- }, createElement(ReadableContentView, {
429
- align: renderAppender ? WIDE_ALIGNMENTS.alignments.full : undefined
430
- }, createElement(BlockListAppender, {
431
- rootClientId: rootClientId,
432
- renderAppender: renderAppender,
433
- showSeparator: shouldShowInsertionPoint
434
- })));
355
+ if (renderFooterAppender || renderAppender === false) {
356
+ return null;
435
357
  }
436
358
 
359
+ const containerStyles = [styles.defaultAppender, wrapperStyles];
360
+ return createElement(View, {
361
+ style: containerStyles
362
+ }, createElement(BlockListAppender, {
363
+ rootClientId: rootClientId,
364
+ renderAppender: renderAppender,
365
+ showSeparator: shouldShowInsertionPoint
366
+ }));
437
367
  }
438
-
439
- const EmptyListComponentCompose = compose([withSelect((select, _ref7) => {
440
- let {
441
- rootClientId,
442
- orientation
443
- } = _ref7;
444
- const {
445
- getBlockOrder,
446
- getBlockInsertionPoint,
447
- isBlockInsertionPointVisible
448
- } = select(blockEditorStore);
449
- const isStackedHorizontally = orientation === 'horizontal';
450
- const blockClientIds = getBlockOrder(rootClientId);
451
- const insertionPoint = getBlockInsertionPoint();
452
- const blockInsertionPointIsVisible = isBlockInsertionPointVisible();
453
- const shouldShowInsertionPoint = !isStackedHorizontally && blockInsertionPointIsVisible && insertionPoint.rootClientId === rootClientId && ( // If list is empty, show the insertion point (via the default appender)
454
- blockClientIds.length === 0 || // Or if the insertion point is right before the denoted block.
455
- !blockClientIds[insertionPoint.index]);
456
- return {
457
- shouldShowInsertionPoint
458
- };
459
- })])(EmptyListComponent);
460
368
  //# sourceMappingURL=index.native.js.map