@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
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.default = exports.BlockList = void 0;
8
+ exports.default = BlockList;
9
9
 
10
10
  var _element = require("@wordpress/element");
11
11
 
@@ -15,8 +15,6 @@ var _reactNative = require("react-native");
15
15
 
16
16
  var _data = require("@wordpress/data");
17
17
 
18
- var _compose = require("@wordpress/compose");
19
-
20
18
  var _blocks = require("@wordpress/blocks");
21
19
 
22
20
  var _components = require("@wordpress/components");
@@ -35,6 +33,8 @@ var _blockListContext = require("./block-list-context");
35
33
 
36
34
  var _blockDraggable = require("../block-draggable");
37
35
 
36
+ var _useEditorWrapperStyles = require("../../hooks/use-editor-wrapper-styles");
37
+
38
38
  var _store = require("../../store");
39
39
 
40
40
  /**
@@ -52,11 +52,7 @@ const identity = x => x;
52
52
 
53
53
  const stylesMemo = {};
54
54
 
55
- const getStyles = (isRootList, isStackedHorizontally, horizontalAlignment) => {
56
- if (isRootList) {
57
- return;
58
- }
59
-
55
+ const getStyles = (isStackedHorizontally, horizontalAlignment) => {
60
56
  const styleName = `${isStackedHorizontally}-${horizontalAlignment}`;
61
57
 
62
58
  if (stylesMemo[styleName]) {
@@ -68,74 +64,97 @@ const getStyles = (isRootList, isStackedHorizontally, horizontalAlignment) => {
68
64
  return computedStyles;
69
65
  };
70
66
 
71
- class BlockList extends _element.Component {
72
- constructor() {
73
- super(...arguments);
74
- this.extraData = {
75
- parentWidth: this.props.parentWidth,
76
- renderFooterAppender: this.props.renderFooterAppender,
77
- renderAppender: this.props.renderAppender,
78
- onDeleteBlock: this.props.onDeleteBlock,
79
- contentStyle: this.props.contentStyle
80
- };
81
- this.renderItem = this.renderItem.bind(this);
82
- this.renderBlockListFooter = this.renderBlockListFooter.bind(this);
83
- this.scrollViewInnerRef = this.scrollViewInnerRef.bind(this);
84
- this.addBlockToEndOfPost = this.addBlockToEndOfPost.bind(this);
85
- this.shouldFlatListPreventAutomaticScroll = this.shouldFlatListPreventAutomaticScroll.bind(this);
86
- this.shouldShowInnerBlockAppender = this.shouldShowInnerBlockAppender.bind(this);
87
- this.renderEmptyList = this.renderEmptyList.bind(this);
88
- this.getExtraData = this.getExtraData.bind(this);
89
- this.getCellRendererComponent = this.getCellRendererComponent.bind(this);
90
- this.onLayout = this.onLayout.bind(this);
91
- this.state = {
92
- blockWidth: this.props.blockWidth || 0
93
- };
94
- }
95
-
96
- addBlockToEndOfPost(newBlock) {
97
- this.props.insertBlock(newBlock, this.props.blockCount);
98
- }
99
-
100
- scrollViewInnerRef(ref) {
101
- this.scrollViewRef = ref;
102
- }
103
-
104
- shouldFlatListPreventAutomaticScroll() {
105
- return this.props.isBlockInsertionPointVisible;
106
- }
67
+ function BlockList(_ref) {
68
+ let {
69
+ blockWidth: initialBlockWidth,
70
+ contentResizeMode,
71
+ contentStyle,
72
+ filterInnerBlocks,
73
+ gridProperties,
74
+ header,
75
+ horizontal,
76
+ horizontalAlignment,
77
+ marginHorizontal = _style.default.defaultBlock.marginLeft,
78
+ marginVertical = _style.default.defaultBlock.marginTop,
79
+ onAddBlock,
80
+ onDeleteBlock,
81
+ orientation,
82
+ parentWidth,
83
+ renderAppender,
84
+ renderFooterAppender,
85
+ rootClientId,
86
+ withFooter = true
87
+ } = _ref;
88
+ const {
89
+ blockClientIds,
90
+ blockCount,
91
+ blockInsertionPointIsVisible,
92
+ isReadOnly,
93
+ isRootList,
94
+ isFloatingToolbarVisible,
95
+ isStackedHorizontally,
96
+ maxWidth,
97
+ isRTL
98
+ } = (0, _data.useSelect)(select => {
99
+ const {
100
+ getBlockCount,
101
+ getBlockHierarchyRootClientId,
102
+ getBlockOrder,
103
+ getSelectedBlockClientId,
104
+ isBlockInsertionPointVisible,
105
+ getSettings
106
+ } = select(_store.store);
107
+ const selectedBlockClientId = getSelectedBlockClientId();
108
+ const rootBlockId = getBlockHierarchyRootClientId(selectedBlockClientId);
109
+ let blockOrder = getBlockOrder(rootClientId); // Display only block which fulfill the condition in passed `filterInnerBlocks` function.
110
+
111
+ if (filterInnerBlocks) {
112
+ blockOrder = filterInnerBlocks(blockOrder);
113
+ }
107
114
 
108
- shouldShowInnerBlockAppender() {
109
115
  const {
110
- blockClientIds,
111
- renderAppender
112
- } = this.props;
113
- return renderAppender && blockClientIds.length > 0;
114
- }
116
+ isRTL: isRTLSetting,
117
+ maxWidth: maxWidthSetting,
118
+ readOnly
119
+ } = getSettings();
120
+ return {
121
+ blockClientIds: blockOrder,
122
+ blockCount: getBlockCount(),
123
+ blockInsertionPointIsVisible: _reactNative.Platform.OS === 'ios' && isBlockInsertionPointVisible(),
124
+ isReadOnly: readOnly,
125
+ isRootList: rootClientId === undefined,
126
+ isFloatingToolbarVisible: !!selectedBlockClientId && !!getBlockCount(rootBlockId),
127
+ isStackedHorizontally: orientation === 'horizontal',
128
+ maxWidth: maxWidthSetting,
129
+ isRTL: isRTLSetting
130
+ };
131
+ }, [filterInnerBlocks, orientation, rootClientId]);
132
+ const {
133
+ insertBlock,
134
+ clearSelectedBlock
135
+ } = (0, _data.useDispatch)(_store.store);
136
+ const extraData = (0, _element.useRef)({
137
+ parentWidth,
138
+ renderFooterAppender,
139
+ renderAppender,
140
+ onDeleteBlock,
141
+ contentStyle
142
+ });
143
+ const [blockWidth, setBlockWidth] = (0, _element.useState)(initialBlockWidth || 0);
144
+
145
+ const addBlockToEndOfPost = newBlock => {
146
+ insertBlock(newBlock, blockCount);
147
+ };
115
148
 
116
- renderEmptyList() {
117
- return (0, _element.createElement)(EmptyListComponentCompose, {
118
- rootClientId: this.props.rootClientId,
119
- renderAppender: this.props.renderAppender,
120
- renderFooterAppender: this.props.renderFooterAppender
121
- });
122
- }
149
+ const scrollViewRef = (0, _element.useRef)(null);
123
150
 
124
- getExtraData() {
125
- const {
126
- parentWidth,
127
- renderFooterAppender,
128
- onDeleteBlock,
129
- contentStyle,
130
- renderAppender,
131
- gridProperties
132
- } = this.props;
133
- const {
134
- blockWidth
135
- } = this.state;
151
+ const shouldFlatListPreventAutomaticScroll = () => blockInsertionPointIsVisible;
152
+
153
+ const shouldShowInnerBlockAppender = () => renderAppender && blockClientIds.length > 0;
136
154
 
137
- 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) {
138
- this.extraData = {
155
+ const getExtraData = () => {
156
+ 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) {
157
+ extraData.current = {
139
158
  parentWidth,
140
159
  renderFooterAppender,
141
160
  onDeleteBlock,
@@ -146,188 +165,32 @@ class BlockList extends _element.Component {
146
165
  };
147
166
  }
148
167
 
149
- return this.extraData;
150
- }
151
-
152
- getCellRendererComponent(_ref) {
153
- let {
154
- children,
155
- item,
156
- onLayout
157
- } = _ref;
158
- const {
159
- rootClientId
160
- } = this.props;
161
- return (0, _element.createElement)(_blockListItemCell.default, {
162
- children: children,
163
- clientId: item,
164
- onLayout: onLayout,
165
- rootClientId: rootClientId
166
- });
167
- }
168
+ return extraData.current;
169
+ };
168
170
 
169
- onLayout(_ref2) {
171
+ const onLayout = _ref2 => {
170
172
  let {
171
173
  nativeEvent
172
174
  } = _ref2;
173
175
  const {
174
176
  layout
175
177
  } = nativeEvent;
176
- const {
177
- blockWidth
178
- } = this.state;
179
- const {
180
- isRootList,
181
- maxWidth
182
- } = this.props;
183
178
  const layoutWidth = Math.floor(layout.width);
184
179
 
185
180
  if (isRootList && blockWidth !== layoutWidth) {
186
- this.setState({
187
- blockWidth: Math.min(layoutWidth, maxWidth)
188
- });
181
+ setBlockWidth(Math.min(layoutWidth, maxWidth));
189
182
  } else if (!isRootList && !blockWidth) {
190
- this.setState({
191
- blockWidth: Math.min(layoutWidth, maxWidth)
192
- });
183
+ setBlockWidth(Math.min(layoutWidth, maxWidth));
193
184
  }
194
- }
195
-
196
- render() {
197
- const {
198
- isRootList,
199
- isRTL
200
- } = this.props; // Use of Context to propagate the main scroll ref to its children e.g InnerBlocks.
201
-
202
- const blockList = isRootList ? (0, _element.createElement)(_blockListContext.BlockListProvider, {
203
- value: { ..._blockListContext.DEFAULT_BLOCK_LIST_CONTEXT,
204
- scrollRef: this.scrollViewRef
205
- }
206
- }, (0, _element.createElement)(_blockDraggable.BlockDraggableWrapper, {
207
- isRTL: isRTL
208
- }, _ref3 => {
209
- let {
210
- onScroll
211
- } = _ref3;
212
- return this.renderList({
213
- onScroll
214
- });
215
- })) : (0, _element.createElement)(_blockListContext.BlockListConsumer, null, _ref4 => {
216
- let {
217
- scrollRef
218
- } = _ref4;
219
- return this.renderList({
220
- parentScrollRef: scrollRef
221
- });
222
- });
223
- return blockList;
224
- }
225
-
226
- renderList() {
227
- let extraProps = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
228
- const {
229
- clearSelectedBlock,
230
- blockClientIds,
231
- title,
232
- header,
233
- isReadOnly,
234
- isRootList,
235
- horizontal,
236
- marginVertical = _style.default.defaultBlock.marginTop,
237
- marginHorizontal = _style.default.defaultBlock.marginLeft,
238
- isFloatingToolbarVisible,
239
- isStackedHorizontally,
240
- horizontalAlignment,
241
- contentResizeMode,
242
- blockWidth
243
- } = this.props;
244
- const {
245
- parentScrollRef,
246
- onScroll
247
- } = extraProps;
248
- const {
249
- blockToolbar,
250
- headerToolbar,
251
- floatingToolbar
252
- } = _style.default;
253
- const containerStyle = {
254
- flex: isRootList ? 1 : 0,
255
- // We set negative margin in the parent to remove the edge spacing between parent block and child block in ineer blocks.
256
- marginVertical: isRootList ? 0 : -marginVertical,
257
- marginHorizontal: isRootList ? 0 : -marginHorizontal
258
- };
259
- const isContentStretch = contentResizeMode === 'stretch';
260
- const isMultiBlocks = blockClientIds.length > 1;
261
- const {
262
- isWider
263
- } = _components.alignmentHelpers;
264
- const extraScrollHeight = headerToolbar.height + blockToolbar.height + (isFloatingToolbarVisible ? floatingToolbar.height : 0);
265
- const scrollViewStyle = [{
266
- flex: isRootList ? 1 : 0
267
- }, !isRootList && _style.default.overflowVisible];
268
- return (0, _element.createElement)(_reactNative.View, {
269
- style: containerStyle,
270
- onAccessibilityEscape: clearSelectedBlock,
271
- onLayout: this.onLayout,
272
- testID: "block-list-wrapper"
273
- }, (0, _element.createElement)(_components.KeyboardAwareFlatList, (0, _extends2.default)({}, _reactNative.Platform.OS === 'android' ? {
274
- removeClippedSubviews: false
275
- } : {}, {
276
- // Disable clipping on Android to fix focus losing. See https://github.com/wordpress-mobile/gutenberg-mobile/pull/741#issuecomment-472746541
277
- accessibilityLabel: "block-list",
278
- innerRef: ref => {
279
- this.scrollViewInnerRef(parentScrollRef || ref);
280
- },
281
- extraScrollHeight: extraScrollHeight,
282
- keyboardShouldPersistTaps: "always",
283
- scrollViewStyle: scrollViewStyle,
284
- extraData: this.getExtraData(),
285
- scrollEnabled: isRootList,
286
- contentContainerStyle: [horizontal && _style.default.horizontalContentContainer, isWider(blockWidth, 'medium') && (isContentStretch && isMultiBlocks ? _style.default.horizontalContentContainerStretch : _style.default.horizontalContentContainerCenter)],
287
- style: getStyles(isRootList, isStackedHorizontally, horizontalAlignment),
288
- data: blockClientIds,
289
- keyExtractor: identity,
290
- renderItem: this.renderItem,
291
- CellRendererComponent: this.getCellRendererComponent,
292
- shouldPreventAutomaticScroll: this.shouldFlatListPreventAutomaticScroll,
293
- title: title,
294
- ListHeaderComponent: header,
295
- ListEmptyComponent: !isReadOnly && this.renderEmptyList,
296
- ListFooterComponent: this.renderBlockListFooter,
297
- onScroll: onScroll
298
- })), this.shouldShowInnerBlockAppender() && (0, _element.createElement)(_reactNative.View, {
299
- style: {
300
- marginHorizontal: marginHorizontal - _style.default.innerAppender.marginLeft
301
- }
302
- }, (0, _element.createElement)(_blockListAppender.default, {
303
- rootClientId: this.props.rootClientId,
304
- renderAppender: this.props.renderAppender,
305
- showSeparator: true
306
- })));
307
- }
185
+ };
308
186
 
309
- renderItem(_ref5) {
187
+ const renderItem = _ref3 => {
310
188
  let {
311
- item: clientId
312
- } = _ref5;
313
- const {
314
- contentResizeMode,
315
- contentStyle,
316
- onAddBlock,
317
- onDeleteBlock,
318
- rootClientId,
319
- isStackedHorizontally,
320
- blockClientIds,
321
- parentWidth,
322
- marginVertical = _style.default.defaultBlock.marginTop,
323
- marginHorizontal = _style.default.defaultBlock.marginLeft,
324
- gridProperties
325
- } = this.props;
326
- const {
327
- blockWidth
328
- } = this.state; // Extracting the grid item properties here to avoid
189
+ item: clientId,
190
+ index
191
+ } = _ref3;
192
+ // Extracting the grid item properties here to avoid
329
193
  // re-renders in the blockListItem component.
330
-
331
194
  const isGridItem = !!gridProperties;
332
195
  const gridItemProps = gridProperties && {
333
196
  numOfColumns: gridProperties.numColumns,
@@ -335,6 +198,7 @@ class BlockList extends _element.Component {
335
198
  tileIndex: blockClientIds.indexOf(clientId)
336
199
  };
337
200
  return (0, _element.createElement)(_blockListItem.default, (0, _extends2.default)({
201
+ index: index,
338
202
  isStackedHorizontally: isStackedHorizontally,
339
203
  rootClientId: rootClientId,
340
204
  clientId: clientId,
@@ -345,142 +209,181 @@ class BlockList extends _element.Component {
345
209
  marginVertical: marginVertical,
346
210
  marginHorizontal: marginHorizontal,
347
211
  onDeleteBlock: onDeleteBlock,
348
- shouldShowInnerBlockAppender: this.shouldShowInnerBlockAppender,
212
+ shouldShowInnerBlockAppender: shouldShowInnerBlockAppender,
349
213
  blockWidth: blockWidth,
350
214
  isGridItem: isGridItem
351
215
  }, gridItemProps));
352
- }
216
+ };
353
217
 
354
- renderBlockListFooter() {
355
- const paragraphBlock = (0, _blocks.createBlock)('core/paragraph');
356
- const {
357
- isReadOnly,
358
- withFooter = true,
359
- renderFooterAppender
360
- } = this.props;
361
-
362
- if (!isReadOnly && withFooter) {
363
- return (0, _element.createElement)(_element.Fragment, null, (0, _element.createElement)(_reactNative.TouchableWithoutFeedback, {
364
- accessibilityLabel: (0, _i18n.__)('Add paragraph block'),
365
- testID: (0, _i18n.__)('Add paragraph block'),
366
- onPress: () => {
367
- this.addBlockToEndOfPost(paragraphBlock);
368
- }
369
- }, (0, _element.createElement)(_reactNative.View, {
370
- style: _style.default.blockListFooter
371
- })));
372
- } else if (renderFooterAppender) {
373
- return renderFooterAppender();
218
+ const {
219
+ blockToolbar,
220
+ headerToolbar,
221
+ floatingToolbar
222
+ } = _style.default;
223
+ const containerStyle = {
224
+ flex: isRootList ? 1 : 0,
225
+ // We set negative margin in the parent to remove the edge spacing between parent block and child block in ineer blocks.
226
+ marginVertical: isRootList ? 0 : -marginVertical,
227
+ marginHorizontal: isRootList ? 0 : -marginHorizontal
228
+ };
229
+ const isContentStretch = contentResizeMode === 'stretch';
230
+ const isMultiBlocks = blockClientIds.length > 1;
231
+ const {
232
+ isWider
233
+ } = _components.alignmentHelpers;
234
+ const extraScrollHeight = headerToolbar.height + blockToolbar.height + (isFloatingToolbarVisible ? floatingToolbar.height : 0);
235
+ return (0, _element.createElement)(_reactNative.View, {
236
+ style: containerStyle,
237
+ onAccessibilityEscape: clearSelectedBlock,
238
+ onLayout: onLayout,
239
+ testID: "block-list-wrapper"
240
+ }, isRootList ? (0, _element.createElement)(_blockListContext.BlockListProvider, {
241
+ value: { ..._blockListContext.DEFAULT_BLOCK_LIST_CONTEXT,
242
+ scrollRef: scrollViewRef.current
243
+ }
244
+ }, (0, _element.createElement)(_blockDraggable.BlockDraggableWrapper, {
245
+ isRTL: isRTL
246
+ }, _ref4 => {
247
+ let {
248
+ onScroll
249
+ } = _ref4;
250
+ return (0, _element.createElement)(_components.KeyboardAwareFlatList, (0, _extends2.default)({}, _reactNative.Platform.OS === 'android' ? {
251
+ removeClippedSubviews: false
252
+ } : {}, {
253
+ // Disable clipping on Android to fix focus losing. See https://github.com/wordpress-mobile/gutenberg-mobile/pull/741#issuecomment-472746541
254
+ accessibilityLabel: "block-list",
255
+ innerRef: ref => {
256
+ scrollViewRef.current = ref;
257
+ },
258
+ extraScrollHeight: extraScrollHeight,
259
+ keyboardShouldPersistTaps: "always",
260
+ scrollViewStyle: {
261
+ flex: 1
262
+ },
263
+ extraData: getExtraData(),
264
+ scrollEnabled: isRootList,
265
+ contentContainerStyle: [horizontal && _style.default.horizontalContentContainer, isWider(blockWidth, 'medium') && (isContentStretch && isMultiBlocks ? _style.default.horizontalContentContainerStretch : _style.default.horizontalContentContainerCenter)],
266
+ data: blockClientIds,
267
+ keyExtractor: identity,
268
+ renderItem: renderItem,
269
+ CellRendererComponent: _blockListItemCell.default,
270
+ shouldPreventAutomaticScroll: shouldFlatListPreventAutomaticScroll,
271
+ ListHeaderComponent: header,
272
+ ListEmptyComponent: !isReadOnly && (0, _element.createElement)(EmptyList, {
273
+ orientation: orientation,
274
+ rootClientId: rootClientId,
275
+ renderAppender: renderAppender,
276
+ renderFooterAppender: renderFooterAppender
277
+ }),
278
+ ListFooterComponent: (0, _element.createElement)(Footer, {
279
+ addBlockToEndOfPost: addBlockToEndOfPost,
280
+ isReadOnly: isReadOnly,
281
+ renderFooterAppender: renderFooterAppender,
282
+ withFooter: withFooter
283
+ }),
284
+ onScroll: onScroll
285
+ }));
286
+ })) : (0, _element.createElement)(_element.Fragment, null, blockClientIds.length > 0 ? (0, _element.createElement)(_reactNative.View, {
287
+ style: [{
288
+ flex: 0
289
+ }, _style.default.overflowVisible]
290
+ }, (0, _element.createElement)(_reactNative.View, {
291
+ style: [...getStyles(isStackedHorizontally, horizontalAlignment), horizontal && _style.default.horizontalContentContainer]
292
+ }, blockClientIds.map((currentClientId, index) => {
293
+ return (0, _element.createElement)(_reactNative.View, {
294
+ key: currentClientId
295
+ }, renderItem({
296
+ item: currentClientId,
297
+ index
298
+ }));
299
+ }), (0, _element.createElement)(Footer, {
300
+ addBlockToEndOfPost: addBlockToEndOfPost,
301
+ isReadOnly: isReadOnly,
302
+ renderFooterAppender: renderFooterAppender,
303
+ withFooter: withFooter
304
+ }))) : (0, _element.createElement)(EmptyList, {
305
+ orientation: orientation,
306
+ rootClientId: rootClientId,
307
+ renderAppender: renderAppender,
308
+ renderFooterAppender: renderFooterAppender
309
+ })), shouldShowInnerBlockAppender() && (0, _element.createElement)(_reactNative.View, {
310
+ style: {
311
+ marginHorizontal: marginHorizontal - _style.default.innerAppender.marginLeft
374
312
  }
313
+ }, (0, _element.createElement)(_blockListAppender.default, {
314
+ rootClientId: rootClientId,
315
+ renderAppender: renderAppender,
316
+ showSeparator: true
317
+ })));
318
+ }
375
319
 
376
- return null;
320
+ function Footer(_ref5) {
321
+ let {
322
+ addBlockToEndOfPost,
323
+ isReadOnly,
324
+ renderFooterAppender,
325
+ withFooter
326
+ } = _ref5;
327
+
328
+ if (!isReadOnly && withFooter) {
329
+ return (0, _element.createElement)(_element.Fragment, null, (0, _element.createElement)(_reactNative.TouchableWithoutFeedback, {
330
+ accessibilityLabel: (0, _i18n.__)('Add paragraph block'),
331
+ testID: (0, _i18n.__)('Add paragraph block'),
332
+ onPress: () => {
333
+ const paragraphBlock = (0, _blocks.createBlock)('core/paragraph');
334
+ addBlockToEndOfPost(paragraphBlock);
335
+ }
336
+ }, (0, _element.createElement)(_reactNative.View, {
337
+ style: _style.default.blockListFooter
338
+ })));
339
+ } else if (renderFooterAppender) {
340
+ return (0, _element.createElement)(_reactNative.View, null, renderFooterAppender());
377
341
  }
378
342
 
343
+ return null;
379
344
  }
380
345
 
381
- exports.BlockList = BlockList;
382
-
383
- var _default = (0, _compose.compose)([(0, _data.withSelect)((select, _ref6) => {
346
+ function EmptyList(_ref6) {
384
347
  let {
385
- rootClientId,
386
348
  orientation,
387
- filterInnerBlocks
349
+ renderAppender,
350
+ renderFooterAppender,
351
+ rootClientId
388
352
  } = _ref6;
389
353
  const {
390
- getBlockCount,
391
- getBlockHierarchyRootClientId,
392
- getBlockOrder,
393
- getSelectedBlockClientId,
394
- isBlockInsertionPointVisible,
395
- getSettings
396
- } = select(_store.store);
397
- const isStackedHorizontally = orientation === 'horizontal';
398
- const selectedBlockClientId = getSelectedBlockClientId();
399
- let blockClientIds = getBlockOrder(rootClientId); // Display only block which fulfill the condition in passed `filterInnerBlocks` function.
400
-
401
- if (filterInnerBlocks) {
402
- blockClientIds = filterInnerBlocks(blockClientIds);
403
- }
404
-
405
- const {
406
- maxWidth
407
- } = getSettings();
408
- const isReadOnly = getSettings().readOnly;
409
- const blockCount = getBlockCount();
410
- const rootBlockId = getBlockHierarchyRootClientId(selectedBlockClientId);
411
- const isFloatingToolbarVisible = !!selectedBlockClientId && !!getBlockCount(rootBlockId);
412
- const isRTL = getSettings().isRTL;
413
- return {
414
- blockClientIds,
415
- blockCount,
416
- isBlockInsertionPointVisible: _reactNative.Platform.OS === 'ios' && isBlockInsertionPointVisible(),
417
- isReadOnly,
418
- isRootList: rootClientId === undefined,
419
- isFloatingToolbarVisible,
420
- isStackedHorizontally,
421
- maxWidth,
422
- isRTL
423
- };
424
- }), (0, _data.withDispatch)(dispatch => {
425
- const {
426
- insertBlock,
427
- replaceBlock,
428
- clearSelectedBlock
429
- } = dispatch(_store.store);
430
- return {
431
- clearSelectedBlock,
432
- insertBlock,
433
- replaceBlock
434
- };
435
- }), _compose.withPreferredColorScheme])(BlockList);
436
-
437
- exports.default = _default;
438
-
439
- class EmptyListComponent extends _element.Component {
440
- render() {
354
+ shouldShowInsertionPoint
355
+ } = (0, _data.useSelect)(select => {
441
356
  const {
442
- shouldShowInsertionPoint,
443
- rootClientId,
444
- renderAppender,
445
- renderFooterAppender
446
- } = this.props;
447
-
448
- if (renderFooterAppender || renderAppender === false) {
449
- return null;
450
- }
357
+ getBlockOrder,
358
+ getBlockInsertionPoint,
359
+ isBlockInsertionPointVisible
360
+ } = select(_store.store);
361
+ const isStackedHorizontally = orientation === 'horizontal';
362
+ const blockClientIds = getBlockOrder(rootClientId);
363
+ const insertionPoint = getBlockInsertionPoint();
364
+ const blockInsertionPointIsVisible = isBlockInsertionPointVisible();
365
+ return {
366
+ shouldShowInsertionPoint: !isStackedHorizontally && blockInsertionPointIsVisible && insertionPoint.rootClientId === rootClientId && ( // If list is empty, show the insertion point (via the default appender)
367
+ blockClientIds.length === 0 || // Or if the insertion point is right before the denoted block.
368
+ !blockClientIds[insertionPoint.index])
369
+ };
370
+ });
371
+ const align = renderAppender ? _components.WIDE_ALIGNMENTS.alignments.full : undefined;
372
+ const [wrapperStyles] = (0, _useEditorWrapperStyles.useEditorWrapperStyles)({
373
+ align
374
+ });
451
375
 
452
- return (0, _element.createElement)(_reactNative.View, {
453
- style: _style.default.defaultAppender
454
- }, (0, _element.createElement)(_components.ReadableContentView, {
455
- align: renderAppender ? _components.WIDE_ALIGNMENTS.alignments.full : undefined
456
- }, (0, _element.createElement)(_blockListAppender.default, {
457
- rootClientId: rootClientId,
458
- renderAppender: renderAppender,
459
- showSeparator: shouldShowInsertionPoint
460
- })));
376
+ if (renderFooterAppender || renderAppender === false) {
377
+ return null;
461
378
  }
462
379
 
380
+ const containerStyles = [_style.default.defaultAppender, wrapperStyles];
381
+ return (0, _element.createElement)(_reactNative.View, {
382
+ style: containerStyles
383
+ }, (0, _element.createElement)(_blockListAppender.default, {
384
+ rootClientId: rootClientId,
385
+ renderAppender: renderAppender,
386
+ showSeparator: shouldShowInsertionPoint
387
+ }));
463
388
  }
464
-
465
- const EmptyListComponentCompose = (0, _compose.compose)([(0, _data.withSelect)((select, _ref7) => {
466
- let {
467
- rootClientId,
468
- orientation
469
- } = _ref7;
470
- const {
471
- getBlockOrder,
472
- getBlockInsertionPoint,
473
- isBlockInsertionPointVisible
474
- } = select(_store.store);
475
- const isStackedHorizontally = orientation === 'horizontal';
476
- const blockClientIds = getBlockOrder(rootClientId);
477
- const insertionPoint = getBlockInsertionPoint();
478
- const blockInsertionPointIsVisible = isBlockInsertionPointVisible();
479
- const shouldShowInsertionPoint = !isStackedHorizontally && blockInsertionPointIsVisible && insertionPoint.rootClientId === rootClientId && ( // If list is empty, show the insertion point (via the default appender)
480
- blockClientIds.length === 0 || // Or if the insertion point is right before the denoted block.
481
- !blockClientIds[insertionPoint.index]);
482
- return {
483
- shouldShowInsertionPoint
484
- };
485
- })])(EmptyListComponent);
486
389
  //# sourceMappingURL=index.native.js.map