@wordpress/block-editor 7.0.1-next.5df0cd52b7.0 → 7.0.4

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 (905) hide show
  1. package/README.md +16 -4
  2. package/build/components/alignment-control/ui.js +2 -1
  3. package/build/components/alignment-control/ui.js.map +1 -1
  4. package/build/components/autocomplete/index.js +1 -1
  5. package/build/components/autocomplete/index.js.map +1 -1
  6. package/build/components/block-actions/index.js +8 -4
  7. package/build/components/block-actions/index.js.map +1 -1
  8. package/build/components/block-alignment-control/ui.js +61 -14
  9. package/build/components/block-alignment-control/ui.js.map +1 -1
  10. package/build/components/block-alignment-control/use-available-alignments.js +25 -3
  11. package/build/components/block-alignment-control/use-available-alignments.js.map +1 -1
  12. package/build/components/block-content-overlay/index.js +2 -4
  13. package/build/components/block-content-overlay/index.js.map +1 -1
  14. package/build/components/block-controls/fill.js +6 -6
  15. package/build/components/block-controls/fill.js.map +1 -1
  16. package/build/components/block-controls/groups.js +3 -1
  17. package/build/components/block-controls/groups.js.map +1 -1
  18. package/build/components/block-controls/hook.js +57 -0
  19. package/build/components/block-controls/hook.js.map +1 -0
  20. package/build/components/block-edit/context.js +6 -5
  21. package/build/components/block-edit/context.js.map +1 -1
  22. package/build/components/block-edit/edit.js +1 -1
  23. package/build/components/block-edit/edit.js.map +1 -1
  24. package/build/components/block-icon/index.native.js +13 -9
  25. package/build/components/block-icon/index.native.js.map +1 -1
  26. package/build/components/block-inspector/index.js +10 -7
  27. package/build/components/block-inspector/index.js.map +1 -1
  28. package/build/components/block-list/block-html.js +5 -0
  29. package/build/components/block-list/block-html.js.map +1 -1
  30. package/build/components/block-list/block-list-item.native.js +31 -12
  31. package/build/components/block-list/block-list-item.native.js.map +1 -1
  32. package/build/components/block-list/block-selection-button.native.js +4 -4
  33. package/build/components/block-list/block-selection-button.native.js.map +1 -1
  34. package/build/components/block-list/block.js +15 -9
  35. package/build/components/block-list/block.js.map +1 -1
  36. package/build/components/block-list/block.native.js +6 -7
  37. package/build/components/block-list/block.native.js.map +1 -1
  38. package/build/components/block-list/grid-item.native.js +68 -0
  39. package/build/components/block-list/grid-item.native.js.map +1 -0
  40. package/build/components/block-list/index.js +19 -15
  41. package/build/components/block-list/index.js.map +1 -1
  42. package/build/components/block-list/index.native.js +12 -8
  43. package/build/components/block-list/index.native.js.map +1 -1
  44. package/build/components/block-list/use-block-props/index.js +6 -6
  45. package/build/components/block-list/use-block-props/index.js.map +1 -1
  46. package/build/components/block-list/use-block-props/use-block-custom-class-name.js +4 -6
  47. package/build/components/block-list/use-block-props/use-block-custom-class-name.js.map +1 -1
  48. package/build/components/block-list/use-block-props/use-block-default-class-name.js +1 -1
  49. package/build/components/block-list/use-block-props/use-block-default-class-name.js.map +1 -1
  50. package/build/components/block-list/use-block-props/use-multi-selection.js +4 -2
  51. package/build/components/block-list/use-block-props/use-multi-selection.js.map +1 -1
  52. package/build/components/block-list/use-in-between-inserter.js +9 -1
  53. package/build/components/block-list/use-in-between-inserter.js.map +1 -1
  54. package/build/components/block-list-appender/index.js +9 -1
  55. package/build/components/block-list-appender/index.js.map +1 -1
  56. package/build/components/block-mover/index.js +4 -4
  57. package/build/components/block-mover/index.js.map +1 -1
  58. package/build/components/block-mover/index.native.js +4 -4
  59. package/build/components/block-mover/index.native.js.map +1 -1
  60. package/build/components/block-preview/auto.js +42 -14
  61. package/build/components/block-preview/auto.js.map +1 -1
  62. package/build/components/block-settings-menu/block-settings-dropdown.js +4 -3
  63. package/build/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  64. package/build/components/block-settings-menu-controls/index.js +10 -3
  65. package/build/components/block-settings-menu-controls/index.js.map +1 -1
  66. package/build/components/block-styles/index.js +5 -1
  67. package/build/components/block-styles/index.js.map +1 -1
  68. package/build/components/block-styles/preview.native.js +1 -1
  69. package/build/components/block-styles/preview.native.js.map +1 -1
  70. package/build/components/block-switcher/block-styles-menu.js +1 -1
  71. package/build/components/block-switcher/block-styles-menu.js.map +1 -1
  72. package/build/components/block-switcher/index.js +10 -3
  73. package/build/components/block-switcher/index.js.map +1 -1
  74. package/build/components/block-title/index.js +3 -2
  75. package/build/components/block-title/index.js.map +1 -1
  76. package/build/components/block-toolbar/index.js +3 -0
  77. package/build/components/block-toolbar/index.js.map +1 -1
  78. package/build/components/block-tools/block-contextual-toolbar.js +1 -1
  79. package/build/components/block-tools/block-contextual-toolbar.js.map +1 -1
  80. package/build/components/block-tools/block-popover.js +8 -7
  81. package/build/components/block-tools/block-popover.js.map +1 -1
  82. package/build/components/block-tools/block-selection-button.js +2 -4
  83. package/build/components/block-tools/block-selection-button.js.map +1 -1
  84. package/build/components/block-tools/index.js +4 -1
  85. package/build/components/block-tools/index.js.map +1 -1
  86. package/build/components/block-tools/insertion-point.js +96 -7
  87. package/build/components/block-tools/insertion-point.js.map +1 -1
  88. package/build/components/block-types-list/index.native.js +3 -2
  89. package/build/components/block-types-list/index.native.js.map +1 -1
  90. package/build/components/border-radius-control/index.js.map +1 -1
  91. package/build/components/border-radius-control/utils.js +17 -8
  92. package/build/components/border-radius-control/utils.js.map +1 -1
  93. package/build/components/colors/utils.js +11 -3
  94. package/build/components/colors/utils.js.map +1 -1
  95. package/build/components/colors-gradients/control.js +17 -13
  96. package/build/components/colors-gradients/control.js.map +1 -1
  97. package/build/components/colors-gradients/panel-color-gradient-settings.js +2 -1
  98. package/build/components/colors-gradients/panel-color-gradient-settings.js.map +1 -1
  99. package/build/components/contrast-checker/index.js +18 -12
  100. package/build/components/contrast-checker/index.js.map +1 -1
  101. package/build/components/copy-handler/index.js +9 -3
  102. package/build/components/copy-handler/index.js.map +1 -1
  103. package/build/components/default-block-appender/index.js +2 -2
  104. package/build/components/default-block-appender/index.js.map +1 -1
  105. package/build/components/duotone-control/index.js +38 -39
  106. package/build/components/duotone-control/index.js.map +1 -1
  107. package/build/components/editor-styles/index.js +9 -3
  108. package/build/components/editor-styles/index.js.map +1 -1
  109. package/build/components/font-appearance-control/index.js +27 -7
  110. package/build/components/font-appearance-control/index.js.map +1 -1
  111. package/build/components/font-sizes/index.native.js +24 -0
  112. package/build/components/font-sizes/index.native.js.map +1 -1
  113. package/build/components/iframe/index.js +45 -62
  114. package/build/components/iframe/index.js.map +1 -1
  115. package/build/components/image-editor/aspect-ratio-dropdown.js +126 -0
  116. package/build/components/image-editor/aspect-ratio-dropdown.js.map +1 -0
  117. package/build/components/image-editor/constants.js +16 -0
  118. package/build/components/image-editor/constants.js.map +1 -0
  119. package/build/components/image-editor/context.js +59 -0
  120. package/build/components/image-editor/context.js.map +1 -0
  121. package/build/components/image-editor/cropper.js +83 -0
  122. package/build/components/image-editor/cropper.js.map +1 -0
  123. package/build/components/image-editor/form-controls.js +36 -0
  124. package/build/components/image-editor/form-controls.js.map +1 -0
  125. package/build/components/image-editor/index.js +60 -0
  126. package/build/components/image-editor/index.js.map +1 -0
  127. package/build/components/image-editor/rotation-button.js +37 -0
  128. package/build/components/image-editor/rotation-button.js.map +1 -0
  129. package/build/components/image-editor/use-save-image.js +84 -0
  130. package/build/components/image-editor/use-save-image.js.map +1 -0
  131. package/build/components/image-editor/use-transform-image.js +135 -0
  132. package/build/components/image-editor/use-transform-image.js.map +1 -0
  133. package/build/components/image-editor/zoom-dropdown.js +55 -0
  134. package/build/components/image-editor/zoom-dropdown.js.map +1 -0
  135. package/build/components/image-size-control/use-dimension-handler.js +14 -3
  136. package/build/components/image-size-control/use-dimension-handler.js.map +1 -1
  137. package/build/components/index.js +22 -35
  138. package/build/components/index.js.map +1 -1
  139. package/build/components/index.native.js +12 -7
  140. package/build/components/index.native.js.map +1 -1
  141. package/build/components/inner-blocks/button-block-appender.js +11 -1
  142. package/build/components/inner-blocks/button-block-appender.js.map +1 -1
  143. package/build/components/inner-blocks/index.js +23 -6
  144. package/build/components/inner-blocks/index.js.map +1 -1
  145. package/build/components/inner-blocks/index.native.js +38 -1
  146. package/build/components/inner-blocks/index.native.js.map +1 -1
  147. package/build/components/inner-blocks/use-nested-settings-update.js +24 -13
  148. package/build/components/inner-blocks/use-nested-settings-update.js.map +1 -1
  149. package/build/components/inserter/block-patterns-tab.js +11 -1
  150. package/build/components/inserter/block-patterns-tab.js.map +1 -1
  151. package/build/components/inserter/block-types-tab.native.js +3 -6
  152. package/build/components/inserter/block-types-tab.native.js.map +1 -1
  153. package/build/components/inserter/hooks/use-clipboard-block.native.js +5 -4
  154. package/build/components/inserter/hooks/use-clipboard-block.native.js.map +1 -1
  155. package/build/components/inserter/index.js +12 -4
  156. package/build/components/inserter/index.js.map +1 -1
  157. package/build/components/inserter/index.native.js +1 -7
  158. package/build/components/inserter/index.native.js.map +1 -1
  159. package/build/components/inserter/library.js +2 -0
  160. package/build/components/inserter/library.js.map +1 -1
  161. package/build/components/inserter/menu.js +2 -1
  162. package/build/components/inserter/menu.js.map +1 -1
  163. package/build/components/inserter/menu.native.js +18 -17
  164. package/build/components/inserter/menu.native.js.map +1 -1
  165. package/build/components/inserter/preview-panel.js +1 -1
  166. package/build/components/inserter/preview-panel.js.map +1 -1
  167. package/build/components/inserter/quick-inserter.js +2 -1
  168. package/build/components/inserter/quick-inserter.js.map +1 -1
  169. package/build/components/inserter/reusable-blocks-tab.native.js +5 -6
  170. package/build/components/inserter/reusable-blocks-tab.native.js.map +1 -1
  171. package/build/components/inserter/search-results.native.js +9 -2
  172. package/build/components/inserter/search-results.native.js.map +1 -1
  173. package/build/components/inserter/tabs.native.js +1 -4
  174. package/build/components/inserter/tabs.native.js.map +1 -1
  175. package/build/components/inserter/utils.native.js +44 -0
  176. package/build/components/inserter/utils.native.js.map +1 -0
  177. package/build/components/inspector-controls/block-support-slot-container.js +28 -0
  178. package/build/components/inspector-controls/block-support-slot-container.js.map +1 -0
  179. package/build/components/inspector-controls/block-support-tools-panel.js +78 -0
  180. package/build/components/inspector-controls/block-support-tools-panel.js.map +1 -0
  181. package/build/components/inspector-controls/fill.js +64 -0
  182. package/build/components/inspector-controls/fill.js.map +1 -0
  183. package/build/components/inspector-controls/{index.native.js → fill.native.js} +20 -19
  184. package/build/components/inspector-controls/fill.native.js.map +1 -0
  185. package/build/components/inspector-controls/groups.js +23 -0
  186. package/build/components/inspector-controls/groups.js.map +1 -0
  187. package/build/components/inspector-controls/index.js +22 -20
  188. package/build/components/inspector-controls/index.js.map +1 -1
  189. package/build/components/inspector-controls/slot.js +67 -0
  190. package/build/components/inspector-controls/slot.js.map +1 -0
  191. package/build/components/inspector-controls/slot.native.js +38 -0
  192. package/build/components/inspector-controls/slot.native.js.map +1 -0
  193. package/build/components/line-height-control/index.native.js +39 -0
  194. package/build/components/line-height-control/index.native.js.map +1 -0
  195. package/build/components/link-control/index.js +11 -5
  196. package/build/components/link-control/index.js.map +1 -1
  197. package/build/components/link-control/link-preview.js +26 -9
  198. package/build/components/link-control/link-preview.js.map +1 -1
  199. package/build/components/link-control/search-input.js +13 -4
  200. package/build/components/link-control/search-input.js.map +1 -1
  201. package/build/components/list-view/block-contents.js +1 -20
  202. package/build/components/list-view/block-contents.js.map +1 -1
  203. package/build/components/list-view/block.js +7 -48
  204. package/build/components/list-view/block.js.map +1 -1
  205. package/build/components/list-view/branch.js +20 -13
  206. package/build/components/list-view/branch.js.map +1 -1
  207. package/build/components/list-view/index.js +21 -14
  208. package/build/components/list-view/index.js.map +1 -1
  209. package/build/components/list-view/leaf.js +1 -1
  210. package/build/components/list-view/leaf.js.map +1 -1
  211. package/build/components/list-view/list-item.js +3 -2
  212. package/build/components/list-view/list-item.js.map +1 -1
  213. package/build/components/list-view/use-list-view-client-ids.js +24 -15
  214. package/build/components/list-view/use-list-view-client-ids.js.map +1 -1
  215. package/build/components/media-placeholder/index.js +35 -21
  216. package/build/components/media-placeholder/index.js.map +1 -1
  217. package/build/components/media-placeholder/index.native.js +2 -1
  218. package/build/components/media-placeholder/index.native.js.map +1 -1
  219. package/build/components/media-replace-flow/index.js +5 -3
  220. package/build/components/media-replace-flow/index.js.map +1 -1
  221. package/build/components/navigable-toolbar/index.js +1 -4
  222. package/build/components/navigable-toolbar/index.js.map +1 -1
  223. package/build/components/observe-typing/index.js +1 -1
  224. package/build/components/observe-typing/index.js.map +1 -1
  225. package/build/components/plain-text/index.native.js +30 -1
  226. package/build/components/plain-text/index.native.js.map +1 -1
  227. package/build/components/rich-text/embed-handler-picker.native.js +65 -0
  228. package/build/components/rich-text/embed-handler-picker.native.js.map +1 -0
  229. package/build/components/rich-text/format-toolbar/index.js +31 -11
  230. package/build/components/rich-text/format-toolbar/index.js.map +1 -1
  231. package/build/components/rich-text/index.js +29 -7
  232. package/build/components/rich-text/index.js.map +1 -1
  233. package/build/components/rich-text/index.native.js +43 -5
  234. package/build/components/rich-text/index.native.js.map +1 -1
  235. package/build/components/rich-text/input-event.js +25 -24
  236. package/build/components/rich-text/input-event.js.map +1 -1
  237. package/build/components/rich-text/shortcut.js +23 -9
  238. package/build/components/rich-text/shortcut.js.map +1 -1
  239. package/build/components/rich-text/use-input-events.js +27 -0
  240. package/build/components/rich-text/use-input-events.js.map +1 -0
  241. package/build/components/rich-text/use-paste-handler.js +45 -10
  242. package/build/components/rich-text/use-paste-handler.js.map +1 -1
  243. package/build/components/rich-text/use-shortcuts.js +27 -0
  244. package/build/components/rich-text/use-shortcuts.js.map +1 -0
  245. package/build/components/rich-text/utils.js +22 -0
  246. package/build/components/rich-text/utils.js.map +1 -1
  247. package/build/components/typewriter/index.js +1 -1
  248. package/build/components/typewriter/index.js.map +1 -1
  249. package/build/components/url-input/index.js +14 -7
  250. package/build/components/url-input/index.js.map +1 -1
  251. package/build/components/use-display-block-controls/index.js +5 -7
  252. package/build/components/use-display-block-controls/index.js.map +1 -1
  253. package/build/components/use-moving-animation/index.js +13 -10
  254. package/build/components/use-moving-animation/index.js.map +1 -1
  255. package/build/components/use-on-block-drop/index.js +2 -1
  256. package/build/components/use-on-block-drop/index.js.map +1 -1
  257. package/build/components/use-resize-canvas/index.js +2 -13
  258. package/build/components/use-resize-canvas/index.js.map +1 -1
  259. package/build/components/use-setting/index.js +3 -7
  260. package/build/components/use-setting/index.js.map +1 -1
  261. package/build/components/writing-flow/use-multi-selection.js +6 -0
  262. package/build/components/writing-flow/use-multi-selection.js.map +1 -1
  263. package/build/components/writing-flow/use-tab-nav.js +18 -3
  264. package/build/components/writing-flow/use-tab-nav.js.map +1 -1
  265. package/build/hooks/align.js +14 -14
  266. package/build/hooks/align.js.map +1 -1
  267. package/build/hooks/anchor.js +4 -2
  268. package/build/hooks/anchor.js.map +1 -1
  269. package/build/hooks/border-color.js +9 -5
  270. package/build/hooks/border-color.js.map +1 -1
  271. package/build/hooks/color-panel.js +4 -2
  272. package/build/hooks/color-panel.js.map +1 -1
  273. package/build/hooks/color.js +6 -4
  274. package/build/hooks/color.js.map +1 -1
  275. package/build/hooks/compat.js +23 -0
  276. package/build/hooks/compat.js.map +1 -0
  277. package/build/hooks/custom-class-name.js +3 -1
  278. package/build/hooks/custom-class-name.js.map +1 -1
  279. package/build/hooks/dimensions.js +63 -28
  280. package/build/hooks/dimensions.js.map +1 -1
  281. package/build/hooks/duotone.js +47 -13
  282. package/build/hooks/duotone.js.map +1 -1
  283. package/build/hooks/font-family.js +93 -23
  284. package/build/hooks/font-family.js.map +1 -1
  285. package/build/hooks/gap.js +163 -0
  286. package/build/hooks/gap.js.map +1 -0
  287. package/build/hooks/index.js +4 -0
  288. package/build/hooks/index.js.map +1 -1
  289. package/build/hooks/index.native.js +2 -0
  290. package/build/hooks/index.native.js.map +1 -1
  291. package/build/hooks/layout.js +47 -30
  292. package/build/hooks/layout.js.map +1 -1
  293. package/build/hooks/letter-spacing.js +1 -1
  294. package/build/hooks/letter-spacing.js.map +1 -1
  295. package/build/hooks/lock.js +43 -0
  296. package/build/hooks/lock.js.map +1 -0
  297. package/build/hooks/margin.js +5 -2
  298. package/build/hooks/margin.js.map +1 -1
  299. package/build/hooks/padding.js +5 -2
  300. package/build/hooks/padding.js.map +1 -1
  301. package/build/hooks/style.js +39 -11
  302. package/build/hooks/style.js.map +1 -1
  303. package/build/hooks/typography.js +1 -1
  304. package/build/hooks/typography.js.map +1 -1
  305. package/build/hooks/typography.native.js +60 -0
  306. package/build/hooks/typography.native.js.map +1 -0
  307. package/build/layouts/flex.js +121 -9
  308. package/build/layouts/flex.js.map +1 -1
  309. package/build/layouts/flow.js +99 -6
  310. package/build/layouts/flow.js.map +1 -1
  311. package/build/store/actions.js +40 -13
  312. package/build/store/actions.js.map +1 -1
  313. package/build/store/defaults.js +2 -0
  314. package/build/store/defaults.js.map +1 -1
  315. package/build/store/defaults.native.js +16 -1
  316. package/build/store/defaults.native.js.map +1 -1
  317. package/build/store/reducer.js +164 -114
  318. package/build/store/reducer.js.map +1 -1
  319. package/build/store/selectors.js +161 -82
  320. package/build/store/selectors.js.map +1 -1
  321. package/build/utils/index.js +10 -1
  322. package/build/utils/index.js.map +1 -1
  323. package/build/utils/parse-css-unit-to-px.js +295 -0
  324. package/build/utils/parse-css-unit-to-px.js.map +1 -0
  325. package/build/utils/transform-styles/transforms/wrap.js +16 -0
  326. package/build/utils/transform-styles/transforms/wrap.js.map +1 -1
  327. package/build-module/components/alignment-control/ui.js +2 -1
  328. package/build-module/components/alignment-control/ui.js.map +1 -1
  329. package/build-module/components/autocomplete/index.js +2 -2
  330. package/build-module/components/autocomplete/index.js.map +1 -1
  331. package/build-module/components/block-actions/index.js +8 -4
  332. package/build-module/components/block-actions/index.js.map +1 -1
  333. package/build-module/components/block-alignment-control/ui.js +64 -17
  334. package/build-module/components/block-alignment-control/ui.js.map +1 -1
  335. package/build-module/components/block-alignment-control/use-available-alignments.js +25 -3
  336. package/build-module/components/block-alignment-control/use-available-alignments.js.map +1 -1
  337. package/build-module/components/block-content-overlay/index.js +2 -4
  338. package/build-module/components/block-content-overlay/index.js.map +1 -1
  339. package/build-module/components/block-controls/fill.js +6 -5
  340. package/build-module/components/block-controls/fill.js.map +1 -1
  341. package/build-module/components/block-controls/groups.js +3 -1
  342. package/build-module/components/block-controls/groups.js.map +1 -1
  343. package/build-module/components/block-controls/hook.js +42 -0
  344. package/build-module/components/block-controls/hook.js.map +1 -0
  345. package/build-module/components/block-edit/context.js +4 -4
  346. package/build-module/components/block-edit/context.js.map +1 -1
  347. package/build-module/components/block-edit/edit.js +1 -1
  348. package/build-module/components/block-edit/edit.js.map +1 -1
  349. package/build-module/components/block-icon/index.native.js +14 -9
  350. package/build-module/components/block-icon/index.native.js.map +1 -1
  351. package/build-module/components/block-inspector/index.js +8 -6
  352. package/build-module/components/block-inspector/index.js.map +1 -1
  353. package/build-module/components/block-list/block-html.js +5 -0
  354. package/build-module/components/block-list/block-html.js.map +1 -1
  355. package/build-module/components/block-list/block-list-item.native.js +30 -12
  356. package/build-module/components/block-list/block-list-item.native.js.map +1 -1
  357. package/build-module/components/block-list/block-selection-button.native.js +3 -4
  358. package/build-module/components/block-list/block-selection-button.native.js.map +1 -1
  359. package/build-module/components/block-list/block.js +16 -10
  360. package/build-module/components/block-list/block.js.map +1 -1
  361. package/build-module/components/block-list/block.native.js +6 -7
  362. package/build-module/components/block-list/block.native.js.map +1 -1
  363. package/build-module/components/block-list/grid-item.native.js +57 -0
  364. package/build-module/components/block-list/grid-item.native.js.map +1 -0
  365. package/build-module/components/block-list/index.js +17 -14
  366. package/build-module/components/block-list/index.js.map +1 -1
  367. package/build-module/components/block-list/index.native.js +12 -8
  368. package/build-module/components/block-list/index.native.js.map +1 -1
  369. package/build-module/components/block-list/use-block-props/index.js +7 -7
  370. package/build-module/components/block-list/use-block-props/index.js.map +1 -1
  371. package/build-module/components/block-list/use-block-props/use-block-custom-class-name.js +5 -7
  372. package/build-module/components/block-list/use-block-props/use-block-custom-class-name.js.map +1 -1
  373. package/build-module/components/block-list/use-block-props/use-block-default-class-name.js +2 -2
  374. package/build-module/components/block-list/use-block-props/use-block-default-class-name.js.map +1 -1
  375. package/build-module/components/block-list/use-block-props/use-multi-selection.js +4 -2
  376. package/build-module/components/block-list/use-block-props/use-multi-selection.js.map +1 -1
  377. package/build-module/components/block-list/use-in-between-inserter.js +9 -1
  378. package/build-module/components/block-list/use-in-between-inserter.js.map +1 -1
  379. package/build-module/components/block-list-appender/index.js +9 -1
  380. package/build-module/components/block-list-appender/index.js.map +1 -1
  381. package/build-module/components/block-mover/index.js +4 -4
  382. package/build-module/components/block-mover/index.js.map +1 -1
  383. package/build-module/components/block-mover/index.native.js +4 -4
  384. package/build-module/components/block-mover/index.native.js.map +1 -1
  385. package/build-module/components/block-preview/auto.js +40 -16
  386. package/build-module/components/block-preview/auto.js.map +1 -1
  387. package/build-module/components/block-settings-menu/block-settings-dropdown.js +4 -3
  388. package/build-module/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  389. package/build-module/components/block-settings-menu-controls/index.js +10 -3
  390. package/build-module/components/block-settings-menu-controls/index.js.map +1 -1
  391. package/build-module/components/block-styles/index.js +5 -1
  392. package/build-module/components/block-styles/index.js.map +1 -1
  393. package/build-module/components/block-styles/preview.native.js +1 -1
  394. package/build-module/components/block-styles/preview.native.js.map +1 -1
  395. package/build-module/components/block-switcher/block-styles-menu.js +1 -1
  396. package/build-module/components/block-switcher/block-styles-menu.js.map +1 -1
  397. package/build-module/components/block-switcher/index.js +10 -3
  398. package/build-module/components/block-switcher/index.js.map +1 -1
  399. package/build-module/components/block-title/index.js +3 -2
  400. package/build-module/components/block-title/index.js.map +1 -1
  401. package/build-module/components/block-toolbar/index.js +3 -0
  402. package/build-module/components/block-toolbar/index.js.map +1 -1
  403. package/build-module/components/block-tools/block-contextual-toolbar.js +1 -1
  404. package/build-module/components/block-tools/block-contextual-toolbar.js.map +1 -1
  405. package/build-module/components/block-tools/block-popover.js +9 -8
  406. package/build-module/components/block-tools/block-popover.js.map +1 -1
  407. package/build-module/components/block-tools/block-selection-button.js +2 -4
  408. package/build-module/components/block-tools/block-selection-button.js.map +1 -1
  409. package/build-module/components/block-tools/index.js +4 -1
  410. package/build-module/components/block-tools/index.js.map +1 -1
  411. package/build-module/components/block-tools/insertion-point.js +96 -8
  412. package/build-module/components/block-tools/insertion-point.js.map +1 -1
  413. package/build-module/components/block-types-list/index.native.js +3 -2
  414. package/build-module/components/block-types-list/index.native.js.map +1 -1
  415. package/build-module/components/border-radius-control/index.js.map +1 -1
  416. package/build-module/components/border-radius-control/utils.js +16 -9
  417. package/build-module/components/border-radius-control/utils.js.map +1 -1
  418. package/build-module/components/colors/utils.js +9 -3
  419. package/build-module/components/colors/utils.js.map +1 -1
  420. package/build-module/components/colors-gradients/control.js +18 -14
  421. package/build-module/components/colors-gradients/control.js.map +1 -1
  422. package/build-module/components/colors-gradients/panel-color-gradient-settings.js +2 -1
  423. package/build-module/components/colors-gradients/panel-color-gradient-settings.js.map +1 -1
  424. package/build-module/components/contrast-checker/index.js +13 -10
  425. package/build-module/components/contrast-checker/index.js.map +1 -1
  426. package/build-module/components/copy-handler/index.js +9 -3
  427. package/build-module/components/copy-handler/index.js.map +1 -1
  428. package/build-module/components/default-block-appender/index.js +2 -2
  429. package/build-module/components/default-block-appender/index.js.map +1 -1
  430. package/build-module/components/duotone-control/index.js +40 -39
  431. package/build-module/components/duotone-control/index.js.map +1 -1
  432. package/build-module/components/editor-styles/index.js +7 -3
  433. package/build-module/components/editor-styles/index.js.map +1 -1
  434. package/build-module/components/font-appearance-control/index.js +27 -7
  435. package/build-module/components/font-appearance-control/index.js.map +1 -1
  436. package/build-module/components/font-sizes/index.native.js +3 -1
  437. package/build-module/components/font-sizes/index.native.js.map +1 -1
  438. package/build-module/components/iframe/index.js +46 -64
  439. package/build-module/components/iframe/index.js.map +1 -1
  440. package/build-module/components/image-editor/aspect-ratio-dropdown.js +115 -0
  441. package/build-module/components/image-editor/aspect-ratio-dropdown.js.map +1 -0
  442. package/build-module/components/image-editor/constants.js +7 -0
  443. package/build-module/components/image-editor/constants.js.map +1 -0
  444. package/build-module/components/image-editor/context.js +44 -0
  445. package/build-module/components/image-editor/context.js.map +1 -0
  446. package/build-module/components/image-editor/cropper.js +69 -0
  447. package/build-module/components/image-editor/cropper.js.map +1 -0
  448. package/build-module/components/image-editor/form-controls.js +26 -0
  449. package/build-module/components/image-editor/form-controls.js.map +1 -0
  450. package/build-module/components/image-editor/index.js +37 -0
  451. package/build-module/components/image-editor/index.js.map +1 -0
  452. package/build-module/components/image-editor/rotation-button.js +26 -0
  453. package/build-module/components/image-editor/rotation-button.js.map +1 -0
  454. package/build-module/components/image-editor/use-save-image.js +70 -0
  455. package/build-module/components/image-editor/use-save-image.js.map +1 -0
  456. package/build-module/components/image-editor/use-transform-image.js +127 -0
  457. package/build-module/components/image-editor/use-transform-image.js.map +1 -0
  458. package/build-module/components/image-editor/zoom-dropdown.js +43 -0
  459. package/build-module/components/image-editor/zoom-dropdown.js.map +1 -0
  460. package/build-module/components/image-size-control/use-dimension-handler.js +13 -2
  461. package/build-module/components/image-size-control/use-dimension-handler.js.map +1 -1
  462. package/build-module/components/index.js +2 -5
  463. package/build-module/components/index.js.map +1 -1
  464. package/build-module/components/index.native.js +2 -3
  465. package/build-module/components/index.native.js.map +1 -1
  466. package/build-module/components/inner-blocks/button-block-appender.js +10 -1
  467. package/build-module/components/inner-blocks/button-block-appender.js.map +1 -1
  468. package/build-module/components/inner-blocks/index.js +24 -7
  469. package/build-module/components/inner-blocks/index.js.map +1 -1
  470. package/build-module/components/inner-blocks/index.native.js +36 -1
  471. package/build-module/components/inner-blocks/index.native.js.map +1 -1
  472. package/build-module/components/inner-blocks/use-nested-settings-update.js +24 -13
  473. package/build-module/components/inner-blocks/use-nested-settings-update.js.map +1 -1
  474. package/build-module/components/inserter/block-patterns-tab.js +11 -1
  475. package/build-module/components/inserter/block-patterns-tab.js.map +1 -1
  476. package/build-module/components/inserter/block-types-tab.native.js +2 -5
  477. package/build-module/components/inserter/block-types-tab.native.js.map +1 -1
  478. package/build-module/components/inserter/hooks/use-clipboard-block.native.js +5 -4
  479. package/build-module/components/inserter/hooks/use-clipboard-block.native.js.map +1 -1
  480. package/build-module/components/inserter/index.js +12 -4
  481. package/build-module/components/inserter/index.js.map +1 -1
  482. package/build-module/components/inserter/index.native.js +1 -7
  483. package/build-module/components/inserter/index.native.js.map +1 -1
  484. package/build-module/components/inserter/library.js +2 -0
  485. package/build-module/components/inserter/library.js.map +1 -1
  486. package/build-module/components/inserter/menu.js +2 -1
  487. package/build-module/components/inserter/menu.js.map +1 -1
  488. package/build-module/components/inserter/menu.native.js +17 -17
  489. package/build-module/components/inserter/menu.native.js.map +1 -1
  490. package/build-module/components/inserter/preview-panel.js +1 -1
  491. package/build-module/components/inserter/preview-panel.js.map +1 -1
  492. package/build-module/components/inserter/quick-inserter.js +2 -1
  493. package/build-module/components/inserter/quick-inserter.js.map +1 -1
  494. package/build-module/components/inserter/reusable-blocks-tab.native.js +4 -5
  495. package/build-module/components/inserter/reusable-blocks-tab.native.js.map +1 -1
  496. package/build-module/components/inserter/search-results.native.js +8 -2
  497. package/build-module/components/inserter/search-results.native.js.map +1 -1
  498. package/build-module/components/inserter/tabs.native.js +1 -4
  499. package/build-module/components/inserter/tabs.native.js.map +1 -1
  500. package/build-module/components/inserter/utils.native.js +35 -0
  501. package/build-module/components/inserter/utils.native.js.map +1 -0
  502. package/build-module/components/inspector-controls/block-support-slot-container.js +18 -0
  503. package/build-module/components/inspector-controls/block-support-slot-container.js.map +1 -0
  504. package/build-module/components/inspector-controls/block-support-tools-panel.js +67 -0
  505. package/build-module/components/inspector-controls/block-support-tools-panel.js.map +1 -0
  506. package/build-module/components/inspector-controls/fill.js +50 -0
  507. package/build-module/components/inspector-controls/fill.js.map +1 -0
  508. package/build-module/components/inspector-controls/{index.native.js → fill.native.js} +16 -18
  509. package/build-module/components/inspector-controls/fill.native.js.map +1 -0
  510. package/build-module/components/inspector-controls/groups.js +14 -0
  511. package/build-module/components/inspector-controls/groups.js.map +1 -0
  512. package/build-module/components/inspector-controls/index.js +16 -17
  513. package/build-module/components/inspector-controls/index.js.map +1 -1
  514. package/build-module/components/inspector-controls/slot.js +52 -0
  515. package/build-module/components/inspector-controls/slot.js.map +1 -0
  516. package/build-module/components/inspector-controls/slot.native.js +27 -0
  517. package/build-module/components/inspector-controls/slot.native.js.map +1 -0
  518. package/build-module/components/line-height-control/index.native.js +29 -0
  519. package/build-module/components/line-height-control/index.native.js.map +1 -0
  520. package/build-module/components/link-control/index.js +11 -5
  521. package/build-module/components/link-control/index.js.map +1 -1
  522. package/build-module/components/link-control/link-preview.js +28 -11
  523. package/build-module/components/link-control/link-preview.js.map +1 -1
  524. package/build-module/components/link-control/search-input.js +13 -4
  525. package/build-module/components/link-control/search-input.js.map +1 -1
  526. package/build-module/components/list-view/block-contents.js +1 -18
  527. package/build-module/components/list-view/block-contents.js.map +1 -1
  528. package/build-module/components/list-view/block.js +9 -49
  529. package/build-module/components/list-view/block.js.map +1 -1
  530. package/build-module/components/list-view/branch.js +20 -15
  531. package/build-module/components/list-view/branch.js.map +1 -1
  532. package/build-module/components/list-view/index.js +22 -17
  533. package/build-module/components/list-view/index.js.map +1 -1
  534. package/build-module/components/list-view/leaf.js +1 -1
  535. package/build-module/components/list-view/leaf.js.map +1 -1
  536. package/build-module/components/list-view/list-item.js +3 -2
  537. package/build-module/components/list-view/list-item.js.map +1 -1
  538. package/build-module/components/list-view/use-list-view-client-ids.js +24 -15
  539. package/build-module/components/list-view/use-list-view-client-ids.js.map +1 -1
  540. package/build-module/components/media-placeholder/index.js +35 -21
  541. package/build-module/components/media-placeholder/index.js.map +1 -1
  542. package/build-module/components/media-placeholder/index.native.js +2 -1
  543. package/build-module/components/media-placeholder/index.native.js.map +1 -1
  544. package/build-module/components/media-replace-flow/index.js +5 -3
  545. package/build-module/components/media-replace-flow/index.js.map +1 -1
  546. package/build-module/components/navigable-toolbar/index.js +1 -4
  547. package/build-module/components/navigable-toolbar/index.js.map +1 -1
  548. package/build-module/components/observe-typing/index.js +1 -1
  549. package/build-module/components/observe-typing/index.js.map +1 -1
  550. package/build-module/components/plain-text/index.native.js +29 -2
  551. package/build-module/components/plain-text/index.native.js.map +1 -1
  552. package/build-module/components/rich-text/embed-handler-picker.native.js +53 -0
  553. package/build-module/components/rich-text/embed-handler-picker.native.js.map +1 -0
  554. package/build-module/components/rich-text/format-toolbar/index.js +28 -11
  555. package/build-module/components/rich-text/format-toolbar/index.js.map +1 -1
  556. package/build-module/components/rich-text/index.js +22 -6
  557. package/build-module/components/rich-text/index.js.map +1 -1
  558. package/build-module/components/rich-text/index.native.js +43 -6
  559. package/build-module/components/rich-text/index.native.js.map +1 -1
  560. package/build-module/components/rich-text/input-event.js +24 -22
  561. package/build-module/components/rich-text/input-event.js.map +1 -1
  562. package/build-module/components/rich-text/shortcut.js +22 -9
  563. package/build-module/components/rich-text/shortcut.js.map +1 -1
  564. package/build-module/components/rich-text/use-input-events.js +19 -0
  565. package/build-module/components/rich-text/use-input-events.js.map +1 -0
  566. package/build-module/components/rich-text/use-paste-handler.js +44 -10
  567. package/build-module/components/rich-text/use-paste-handler.js.map +1 -1
  568. package/build-module/components/rich-text/use-shortcuts.js +19 -0
  569. package/build-module/components/rich-text/use-shortcuts.js.map +1 -0
  570. package/build-module/components/rich-text/utils.js +20 -0
  571. package/build-module/components/rich-text/utils.js.map +1 -1
  572. package/build-module/components/typewriter/index.js +1 -1
  573. package/build-module/components/typewriter/index.js.map +1 -1
  574. package/build-module/components/url-input/index.js +14 -7
  575. package/build-module/components/url-input/index.js.map +1 -1
  576. package/build-module/components/use-display-block-controls/index.js +5 -7
  577. package/build-module/components/use-display-block-controls/index.js.map +1 -1
  578. package/build-module/components/use-moving-animation/index.js +13 -10
  579. package/build-module/components/use-moving-animation/index.js.map +1 -1
  580. package/build-module/components/use-on-block-drop/index.js +3 -2
  581. package/build-module/components/use-on-block-drop/index.js.map +1 -1
  582. package/build-module/components/use-resize-canvas/index.js +2 -10
  583. package/build-module/components/use-resize-canvas/index.js.map +1 -1
  584. package/build-module/components/use-setting/index.js +1 -6
  585. package/build-module/components/use-setting/index.js.map +1 -1
  586. package/build-module/components/writing-flow/use-multi-selection.js +6 -0
  587. package/build-module/components/writing-flow/use-multi-selection.js.map +1 -1
  588. package/build-module/components/writing-flow/use-tab-nav.js +18 -3
  589. package/build-module/components/writing-flow/use-tab-nav.js.map +1 -1
  590. package/build-module/hooks/align.js +15 -15
  591. package/build-module/hooks/align.js.map +1 -1
  592. package/build-module/hooks/anchor.js +5 -3
  593. package/build-module/hooks/anchor.js.map +1 -1
  594. package/build-module/hooks/border-color.js +10 -5
  595. package/build-module/hooks/border-color.js.map +1 -1
  596. package/build-module/hooks/color-panel.js +5 -3
  597. package/build-module/hooks/color-panel.js.map +1 -1
  598. package/build-module/hooks/color.js +6 -4
  599. package/build-module/hooks/color.js.map +1 -1
  600. package/build-module/hooks/compat.js +20 -0
  601. package/build-module/hooks/compat.js.map +1 -0
  602. package/build-module/hooks/custom-class-name.js +4 -2
  603. package/build-module/hooks/custom-class-name.js.map +1 -1
  604. package/build-module/hooks/dimensions.js +57 -26
  605. package/build-module/hooks/dimensions.js.map +1 -1
  606. package/build-module/hooks/duotone.js +46 -13
  607. package/build-module/hooks/duotone.js.map +1 -1
  608. package/build-module/hooks/font-family.js +91 -24
  609. package/build-module/hooks/font-family.js.map +1 -1
  610. package/build-module/hooks/gap.js +140 -0
  611. package/build-module/hooks/gap.js.map +1 -0
  612. package/build-module/hooks/index.js +2 -0
  613. package/build-module/hooks/index.js.map +1 -1
  614. package/build-module/hooks/index.native.js +1 -0
  615. package/build-module/hooks/index.native.js.map +1 -1
  616. package/build-module/hooks/layout.js +47 -30
  617. package/build-module/hooks/layout.js.map +1 -1
  618. package/build-module/hooks/letter-spacing.js +1 -1
  619. package/build-module/hooks/letter-spacing.js.map +1 -1
  620. package/build-module/hooks/lock.js +33 -0
  621. package/build-module/hooks/lock.js.map +1 -0
  622. package/build-module/hooks/margin.js +6 -3
  623. package/build-module/hooks/margin.js.map +1 -1
  624. package/build-module/hooks/padding.js +6 -3
  625. package/build-module/hooks/padding.js.map +1 -1
  626. package/build-module/hooks/style.js +39 -11
  627. package/build-module/hooks/style.js.map +1 -1
  628. package/build-module/hooks/typography.js +1 -2
  629. package/build-module/hooks/typography.js.map +1 -1
  630. package/build-module/hooks/typography.native.js +41 -0
  631. package/build-module/hooks/typography.native.js.map +1 -0
  632. package/build-module/layouts/flex.js +115 -9
  633. package/build-module/layouts/flex.js.map +1 -1
  634. package/build-module/layouts/flow.js +99 -7
  635. package/build-module/layouts/flow.js.map +1 -1
  636. package/build-module/store/actions.js +40 -13
  637. package/build-module/store/actions.js.map +1 -1
  638. package/build-module/store/defaults.js +2 -0
  639. package/build-module/store/defaults.js.map +1 -1
  640. package/build-module/store/defaults.native.js +15 -1
  641. package/build-module/store/defaults.native.js.map +1 -1
  642. package/build-module/store/reducer.js +166 -115
  643. package/build-module/store/reducer.js.map +1 -1
  644. package/build-module/store/selectors.js +148 -75
  645. package/build-module/store/selectors.js.map +1 -1
  646. package/build-module/utils/index.js +1 -0
  647. package/build-module/utils/index.js.map +1 -1
  648. package/build-module/utils/parse-css-unit-to-px.js +285 -0
  649. package/build-module/utils/parse-css-unit-to-px.js.map +1 -0
  650. package/build-module/utils/transform-styles/transforms/wrap.js +16 -0
  651. package/build-module/utils/transform-styles/transforms/wrap.js.map +1 -1
  652. package/build-style/default-editor-styles-rtl.css +114 -0
  653. package/build-style/default-editor-styles.css +114 -0
  654. package/build-style/style-rtl.css +136 -128
  655. package/build-style/style.css +136 -128
  656. package/build-types/components/block-context/index.d.ts +1 -1
  657. package/build-types/components/block-context/index.d.ts.map +1 -1
  658. package/package.json +31 -29
  659. package/src/components/alignment-control/test/__snapshots__/index.js.snap +2 -0
  660. package/src/components/alignment-control/ui.js +4 -1
  661. package/src/components/autocomplete/index.js +5 -2
  662. package/src/components/block-actions/index.js +9 -5
  663. package/src/components/block-alignment-control/style.scss +5 -0
  664. package/src/components/block-alignment-control/test/__snapshots__/index.js.snap +15 -1
  665. package/src/components/block-alignment-control/test/index.native.js +37 -0
  666. package/src/components/block-alignment-control/ui.js +98 -27
  667. package/src/components/block-alignment-control/use-available-alignments.js +31 -10
  668. package/src/components/block-content-overlay/index.js +3 -6
  669. package/src/components/block-content-overlay/style.scss +9 -21
  670. package/src/components/block-controls/fill.js +7 -4
  671. package/src/components/block-controls/groups.js +2 -0
  672. package/src/components/block-controls/hook.js +44 -0
  673. package/src/components/block-edit/context.js +4 -3
  674. package/src/components/block-edit/edit.js +1 -4
  675. package/src/components/block-icon/index.native.js +11 -12
  676. package/src/components/block-inspector/index.js +14 -9
  677. package/src/components/block-list/block-html.js +5 -0
  678. package/src/components/block-list/block-list-item.native.js +34 -11
  679. package/src/components/block-list/block-list-item.native.scss +4 -0
  680. package/src/components/block-list/block-selection-button.native.js +8 -5
  681. package/src/components/block-list/block.js +13 -9
  682. package/src/components/block-list/block.native.js +7 -5
  683. package/src/components/block-list/grid-item.native.js +58 -0
  684. package/src/components/block-list/index.js +33 -27
  685. package/src/components/block-list/index.native.js +9 -3
  686. package/src/components/block-list/style.native.scss +0 -1
  687. package/src/components/block-list/style.scss +15 -0
  688. package/src/components/block-list/use-block-props/index.js +4 -7
  689. package/src/components/block-list/use-block-props/use-block-custom-class-name.js +5 -7
  690. package/src/components/block-list/use-block-props/use-block-default-class-name.js +2 -8
  691. package/src/components/block-list/use-block-props/use-multi-selection.js +7 -1
  692. package/src/components/block-list/use-in-between-inserter.js +9 -0
  693. package/src/components/block-list-appender/index.js +8 -0
  694. package/src/components/block-mover/index.js +4 -4
  695. package/src/components/block-mover/index.native.js +4 -4
  696. package/src/components/block-mover/test/__snapshots__/index.native.js.snap +10 -6
  697. package/src/components/block-mover/test/index.native.js +26 -28
  698. package/src/components/block-preview/README.md +1 -1
  699. package/src/components/block-preview/auto.js +36 -18
  700. package/src/components/block-preview/style.scss +0 -20
  701. package/src/components/block-settings-menu/block-settings-dropdown.js +7 -6
  702. package/src/components/block-settings-menu-controls/index.js +9 -6
  703. package/src/components/block-styles/index.js +6 -1
  704. package/src/components/block-styles/preview.native.js +1 -1
  705. package/src/components/block-switcher/block-styles-menu.js +1 -1
  706. package/src/components/block-switcher/index.js +7 -3
  707. package/src/components/block-switcher/test/index.js +3 -0
  708. package/src/components/block-title/index.js +5 -2
  709. package/src/components/block-toolbar/index.js +4 -0
  710. package/src/components/block-tools/block-contextual-toolbar.js +7 -5
  711. package/src/components/block-tools/block-popover.js +8 -8
  712. package/src/components/block-tools/block-selection-button.js +2 -4
  713. package/src/components/block-tools/index.js +5 -2
  714. package/src/components/block-tools/insertion-point.js +97 -9
  715. package/src/components/block-tools/style.scss +4 -35
  716. package/src/components/block-types-list/index.native.js +8 -2
  717. package/src/components/block-types-list/style.scss +0 -3
  718. package/src/components/block-variation-picker/README.md +47 -14
  719. package/src/components/block-variation-picker/style.native.scss +4 -0
  720. package/src/components/border-radius-control/index.js +1 -0
  721. package/src/components/border-radius-control/test/utils.js +216 -0
  722. package/src/components/border-radius-control/utils.js +18 -10
  723. package/src/components/color-palette/test/__snapshots__/control.js.snap +103 -71
  724. package/src/components/colors/test/utils.js +41 -0
  725. package/src/components/colors/utils.js +9 -5
  726. package/src/components/colors-gradients/control.js +64 -61
  727. package/src/components/colors-gradients/panel-color-gradient-settings.js +3 -1
  728. package/src/components/colors-gradients/style.scss +8 -5
  729. package/src/components/colors-gradients/test/control.js +43 -52
  730. package/src/components/contrast-checker/index.js +14 -10
  731. package/src/components/copy-handler/index.js +6 -1
  732. package/src/components/default-block-appender/index.js +2 -2
  733. package/src/components/default-block-appender/test/__snapshots__/index.js.snap +3 -3
  734. package/src/components/duotone-control/index.js +43 -41
  735. package/src/components/editor-styles/index.js +8 -4
  736. package/src/components/font-appearance-control/index.js +49 -19
  737. package/src/components/font-appearance-control/style.scss +1 -1
  738. package/src/components/font-sizes/index.native.js +7 -1
  739. package/src/components/iframe/index.js +63 -74
  740. package/src/components/image-editor/aspect-ratio-dropdown.js +129 -0
  741. package/src/components/image-editor/constants.js +6 -0
  742. package/src/components/image-editor/context.js +56 -0
  743. package/src/components/image-editor/cropper.js +74 -0
  744. package/src/components/image-editor/form-controls.js +22 -0
  745. package/src/components/image-editor/index.js +52 -0
  746. package/src/components/image-editor/rotation-button.js +24 -0
  747. package/src/components/image-editor/use-save-image.js +97 -0
  748. package/src/components/image-editor/use-transform-image.js +162 -0
  749. package/src/components/image-editor/zoom-dropdown.js +40 -0
  750. package/src/components/image-size-control/use-dimension-handler.js +18 -1
  751. package/src/components/index.js +8 -5
  752. package/src/components/index.native.js +8 -3
  753. package/src/components/inner-blocks/button-block-appender.js +9 -0
  754. package/src/components/inner-blocks/index.js +40 -11
  755. package/src/components/inner-blocks/index.native.js +41 -0
  756. package/src/components/inner-blocks/use-nested-settings-update.js +26 -11
  757. package/src/components/inserter/block-patterns-tab.js +11 -4
  758. package/src/components/inserter/block-types-tab.native.js +3 -6
  759. package/src/components/inserter/hooks/use-clipboard-block.native.js +3 -2
  760. package/src/components/inserter/index.js +15 -3
  761. package/src/components/inserter/index.native.js +2 -19
  762. package/src/components/inserter/library.js +2 -0
  763. package/src/components/inserter/menu.js +4 -1
  764. package/src/components/inserter/menu.native.js +18 -15
  765. package/src/components/inserter/preview-panel.js +1 -1
  766. package/src/components/inserter/quick-inserter.js +1 -1
  767. package/src/components/inserter/reusable-blocks-tab.native.js +4 -6
  768. package/src/components/inserter/search-results.native.js +8 -1
  769. package/src/components/inserter/style.native.scss +8 -5
  770. package/src/components/inserter/style.scss +16 -15
  771. package/src/components/inserter/tabs.native.js +1 -7
  772. package/src/components/inserter/test/block-types-tab.native.js +2 -1
  773. package/src/components/inserter/utils.native.js +35 -0
  774. package/src/components/inserter-list-item/style.scss +4 -2
  775. package/src/components/inspector-controls/README.md +43 -198
  776. package/src/components/inspector-controls/block-support-slot-container.js +10 -0
  777. package/src/components/inspector-controls/block-support-tools-panel.js +60 -0
  778. package/src/components/inspector-controls/fill.js +53 -0
  779. package/src/components/inspector-controls/{index.native.js → fill.native.js} +14 -14
  780. package/src/components/inspector-controls/groups.js +18 -0
  781. package/src/components/inspector-controls/index.js +16 -18
  782. package/src/components/inspector-controls/slot.js +45 -0
  783. package/src/components/inspector-controls/slot.native.js +22 -0
  784. package/src/components/line-height-control/index.native.js +25 -0
  785. package/src/components/link-control/README.md +40 -14
  786. package/src/components/link-control/index.js +7 -1
  787. package/src/components/link-control/link-preview.js +36 -15
  788. package/src/components/link-control/search-input.js +12 -4
  789. package/src/components/link-control/style.scss +36 -5
  790. package/src/components/link-control/test/index.js +132 -0
  791. package/src/components/list-view/block-contents.js +17 -38
  792. package/src/components/list-view/block.js +8 -63
  793. package/src/components/list-view/branch.js +19 -12
  794. package/src/components/list-view/index.js +45 -26
  795. package/src/components/list-view/leaf.js +1 -1
  796. package/src/components/list-view/list-item.js +5 -4
  797. package/src/components/list-view/style.scss +56 -30
  798. package/src/components/list-view/use-list-view-client-ids.js +22 -22
  799. package/src/components/media-placeholder/README.md +9 -0
  800. package/src/components/media-placeholder/index.js +31 -20
  801. package/src/components/media-placeholder/index.native.js +2 -1
  802. package/src/components/media-placeholder/style.scss +2 -0
  803. package/src/components/media-replace-flow/README.md +7 -0
  804. package/src/components/media-replace-flow/index.js +4 -1
  805. package/src/components/media-replace-flow/style.scss +11 -12
  806. package/src/components/media-upload/README.md +1 -1
  807. package/src/components/navigable-toolbar/index.js +1 -4
  808. package/src/components/observe-typing/index.js +3 -2
  809. package/src/components/plain-text/index.native.js +26 -4
  810. package/src/components/rich-text/embed-handler-picker.native.js +67 -0
  811. package/src/components/rich-text/format-toolbar/index.js +22 -6
  812. package/src/components/rich-text/index.js +38 -12
  813. package/src/components/rich-text/index.native.js +37 -4
  814. package/src/components/rich-text/input-event.js +21 -20
  815. package/src/components/rich-text/shortcut.js +24 -9
  816. package/src/components/rich-text/style.scss +7 -5
  817. package/src/components/rich-text/use-input-events.js +19 -0
  818. package/src/components/rich-text/use-paste-handler.js +47 -12
  819. package/src/components/rich-text/use-shortcuts.js +19 -0
  820. package/src/components/rich-text/utils.js +16 -0
  821. package/src/components/skip-to-selected-block/README.md +39 -0
  822. package/src/components/tool-selector/style.scss +5 -5
  823. package/src/components/typewriter/index.js +3 -2
  824. package/src/components/url-input/index.js +12 -6
  825. package/src/components/use-display-block-controls/index.js +7 -10
  826. package/src/components/use-moving-animation/index.js +9 -8
  827. package/src/components/use-on-block-drop/index.js +5 -1
  828. package/src/components/use-resize-canvas/index.js +2 -17
  829. package/src/components/use-setting/index.js +1 -7
  830. package/src/components/writing-flow/use-multi-selection.js +6 -0
  831. package/src/components/writing-flow/use-tab-nav.js +21 -11
  832. package/src/default-editor-styles.scss +24 -0
  833. package/src/hooks/align.js +28 -20
  834. package/src/hooks/anchor.js +5 -5
  835. package/src/hooks/border-color.js +12 -1
  836. package/src/hooks/color-panel.js +3 -1
  837. package/src/hooks/color.js +11 -4
  838. package/src/hooks/compat.js +23 -0
  839. package/src/hooks/custom-class-name.js +3 -3
  840. package/src/hooks/dimensions.js +94 -50
  841. package/src/hooks/duotone.js +49 -14
  842. package/src/hooks/font-family.js +107 -27
  843. package/src/hooks/gap.js +146 -0
  844. package/src/hooks/index.js +2 -0
  845. package/src/hooks/index.native.js +1 -0
  846. package/src/hooks/layout.js +82 -56
  847. package/src/hooks/layout.scss +6 -0
  848. package/src/hooks/letter-spacing.js +2 -1
  849. package/src/hooks/lock.js +34 -0
  850. package/src/hooks/margin.js +12 -2
  851. package/src/hooks/padding.js +12 -2
  852. package/src/hooks/style.js +57 -18
  853. package/src/hooks/test/style.js +4 -0
  854. package/src/hooks/typography.js +2 -6
  855. package/src/hooks/typography.native.js +64 -0
  856. package/src/layouts/flex.js +139 -12
  857. package/src/layouts/flow.js +81 -14
  858. package/src/store/actions.js +54 -16
  859. package/src/store/defaults.js +2 -0
  860. package/src/store/defaults.native.js +15 -0
  861. package/src/store/reducer.js +230 -145
  862. package/src/store/selectors.js +164 -115
  863. package/src/store/test/actions.js +89 -88
  864. package/src/store/test/reducer.js +184 -146
  865. package/src/store/test/selectors.js +118 -156
  866. package/src/style.scss +1 -14
  867. package/src/utils/index.js +1 -0
  868. package/src/utils/parse-css-unit-to-px.js +272 -0
  869. package/src/utils/test/parse-css-unit-to-px.js +206 -0
  870. package/src/utils/transform-styles/transforms/test/wrap.js +1 -1
  871. package/src/utils/transform-styles/transforms/wrap.js +16 -0
  872. package/tsconfig.tsbuildinfo +1 -466
  873. package/build/components/block-list/head.js +0 -27
  874. package/build/components/block-list/head.js.map +0 -1
  875. package/build/components/duotone-control/duotone-picker-popover.js +0 -44
  876. package/build/components/duotone-control/duotone-picker-popover.js.map +0 -1
  877. package/build/components/inspector-advanced-controls/index.js +0 -46
  878. package/build/components/inspector-advanced-controls/index.js.map +0 -1
  879. package/build/components/inspector-controls/index.native.js.map +0 -1
  880. package/build/components/list-view/block-slot.js +0 -121
  881. package/build/components/list-view/block-slot.js.map +0 -1
  882. package/build/components/list-view/editor.js +0 -35
  883. package/build/components/list-view/editor.js.map +0 -1
  884. package/build/components/use-simulated-media-query/index.js +0 -137
  885. package/build/components/use-simulated-media-query/index.js.map +0 -1
  886. package/build-module/components/block-list/head.js +0 -19
  887. package/build-module/components/block-list/head.js.map +0 -1
  888. package/build-module/components/duotone-control/duotone-picker-popover.js +0 -35
  889. package/build-module/components/duotone-control/duotone-picker-popover.js.map +0 -1
  890. package/build-module/components/inspector-advanced-controls/index.js +0 -36
  891. package/build-module/components/inspector-advanced-controls/index.js.map +0 -1
  892. package/build-module/components/inspector-controls/index.native.js.map +0 -1
  893. package/build-module/components/list-view/block-slot.js +0 -96
  894. package/build-module/components/list-view/block-slot.js.map +0 -1
  895. package/build-module/components/list-view/editor.js +0 -25
  896. package/build-module/components/list-view/editor.js.map +0 -1
  897. package/build-module/components/use-simulated-media-query/index.js +0 -126
  898. package/build-module/components/use-simulated-media-query/index.js.map +0 -1
  899. package/src/components/block-list/head.js +0 -18
  900. package/src/components/duotone-control/duotone-picker-popover.js +0 -36
  901. package/src/components/inspector-advanced-controls/README.md +0 -72
  902. package/src/components/inspector-advanced-controls/index.js +0 -32
  903. package/src/components/list-view/block-slot.js +0 -120
  904. package/src/components/list-view/editor.js +0 -29
  905. package/src/components/use-simulated-media-query/index.js +0 -144
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/block-editor/src/components/inserter/menu.native.js"],"names":["MIN_ITEMS_FOR_SEARCH","REUSABLE_BLOCKS_CATEGORY","InserterMenu","onSelect","onDismiss","rootClientId","clientId","isAppender","shouldReplaceBlock","insertionIndex","filterValue","setFilterValue","showTabs","setShowTabs","showSearchForm","setShowSearchForm","__DEV__","tabIndex","setTabIndex","showInsertionPoint","hideInsertionPoint","clearSelectedBlock","insertBlock","removeBlock","resetBlocks","insertDefaultBlock","blockEditorStore","items","destinationRootClientId","showReusableBlocks","select","getInserterItems","getBlockRootClientId","getBlockSelectionEnd","targetRootClientId","end","undefined","allItems","reusableBlockItems","filter","category","length","getBlockOrder","getBlockCount","count","blockToReplace","onClose","onInsert","item","name","initialAttributes","innerBlocks","newBlock","source","onSelectItem","Platform","OS","AccessibilityInfo","isScreenReaderEnabled","then","enabled","timeout","setTimeout","onChangeSearch","value","onKeyboardShow","onKeyboardHide","styles","list","listProps"],"mappings":";;;;;;;;;AAQA;;AALA;;AAMA;;AACA;;AACA;;AASA;;AACA;;AACA;;AACA;;AAvBA;AACA;AACA;;AAGA;AACA;AACA;;AAUA;AACA;AACA;AAMA,MAAMA,oBAAoB,GAAG,CAA7B;AACA,MAAMC,wBAAwB,GAAG,UAAjC;;AAEA,SAASC,YAAT,CAAuB;AACtBC,EAAAA,QADsB;AAEtBC,EAAAA,SAFsB;AAGtBC,EAAAA,YAHsB;AAItBC,EAAAA,QAJsB;AAKtBC,EAAAA,UALsB;AAMtBC,EAAAA,kBANsB;AAOtBC,EAAAA;AAPsB,CAAvB,EAQI;AACH,QAAM,CAAEC,WAAF,EAAeC,cAAf,IAAkC,uBAAU,EAAV,CAAxC;AACA,QAAM,CAAEC,QAAF,EAAYC,WAAZ,IAA4B,uBAAU,IAAV,CAAlC,CAFG,CAGH;;AACA,QAAM,CAAEC,cAAF,EAAkBC,iBAAlB,IAAwC,uBAAUC,OAAV,CAA9C;AACA,QAAM,CAAEC,QAAF,EAAYC,WAAZ,IAA4B,uBAAU,CAAV,CAAlC;AAEA,QAAM;AACLC,IAAAA,kBADK;AAELC,IAAAA,kBAFK;AAGLC,IAAAA,kBAHK;AAILC,IAAAA,WAJK;AAKLC,IAAAA,WALK;AAMLC,IAAAA,WANK;AAOLC,IAAAA;AAPK,MAQF,uBAAaC,YAAb,CARJ;AAUA,QAAM;AAAEC,IAAAA,KAAF;AAASC,IAAAA,uBAAT;AAAkCC,IAAAA;AAAlC,MAAyD,qBAC5DC,MAAF,IAAc;AACb,UAAM;AACLC,MAAAA,gBADK;AAELC,MAAAA,oBAFK;AAGLC,MAAAA;AAHK,QAIFH,MAAM,CAAEJ,YAAF,CAJV;AAMA,QAAIQ,kBAAkB,GAAG7B,YAAzB;;AACA,QAAK,CAAE6B,kBAAF,IAAwB,CAAE5B,QAA1B,IAAsC,CAAEC,UAA7C,EAA0D;AACzD,YAAM4B,GAAG,GAAGF,oBAAoB,EAAhC;;AACA,UAAKE,GAAL,EAAW;AACVD,QAAAA,kBAAkB,GACjBF,oBAAoB,CAAEG,GAAF,CAApB,IAA+BC,SADhC;AAEA;AACD;;AAED,UAAMC,QAAQ,GAAGN,gBAAgB,CAAEG,kBAAF,CAAjC;AACA,UAAMI,kBAAkB,GAAGD,QAAQ,CAACE,MAAT,CAC1B,CAAE;AAAEC,MAAAA;AAAF,KAAF,KAAoBA,QAAQ,KAAKvC,wBADP,CAA3B;AAIA,WAAO;AACN0B,MAAAA,KAAK,EAAEU,QADD;AAENT,MAAAA,uBAAuB,EAAEM,kBAFnB;AAGNL,MAAAA,kBAAkB,EAAE,CAAC,CAAES,kBAAkB,CAACG;AAHpC,KAAP;AAKA,GA3B6D,CAA/D;AA8BA,QAAM;AAAEC,IAAAA,aAAF;AAAiBC,IAAAA;AAAjB,MAAmC,qBAAWjB,YAAX,CAAzC;AAEA,0BAAW,MAAM;AAChB;AACA,QAAKlB,kBAAL,EAA0B;AACzB,YAAMoC,KAAK,GAAGD,aAAa,EAA3B,CADyB,CAEzB;AACA;;AACA,UAAKC,KAAK,KAAK,CAAV,IAAe,CAAEvC,YAAtB,EAAqC;AACpC;AACA;AACAgB,QAAAA,kBAAkB;AAClBG,QAAAA,WAAW,CAAE,EAAF,CAAX;AACA,OALD,MAKO;AACN,cAAMqB,cAAc,GAAGH,aAAa,CAAEd,uBAAF,CAAb,CACtBnB,cADsB,CAAvB;AAGAc,QAAAA,WAAW,CAAEsB,cAAF,EAAkB,KAAlB,CAAX;AACA;AACD;;AACD1B,IAAAA,kBAAkB,CAAES,uBAAF,EAA2BnB,cAA3B,CAAlB,CAlBgB,CAoBhB;;AACA,QAAKkB,KAAK,CAACc,MAAN,GAAezC,oBAApB,EAA2C;AAC1Ce,MAAAA,iBAAiB,CAAE,KAAF,CAAjB;AACA;;AAED,WAAOK,kBAAP;AACA,GA1BD,EA0BG,EA1BH;AA4BA,QAAM0B,OAAO,GAAG,0BAAa,MAAM;AAClC;AACA;AACA,QAAKtC,kBAAL,EAA0B;AACzBiB,MAAAA,kBAAkB,CAAE,EAAF,EAAMG,uBAAN,EAA+BnB,cAA/B,CAAlB;AACA;;AACDL,IAAAA,SAAS;AACT,GAPe,EAOb,CAAEI,kBAAF,EAAsBoB,uBAAtB,EAA+CnB,cAA/C,CAPa,CAAhB;AASA,QAAMsC,QAAQ,GAAG,0BACdC,IAAF,IAAY;AACX,UAAM;AAAEC,MAAAA,IAAF;AAAQC,MAAAA,iBAAR;AAA2BC,MAAAA;AAA3B,QAA2CH,IAAjD;AAEA,UAAMI,QAAQ,GAAG,yBAChBH,IADgB,EAEhBC,iBAFgB,EAGhBC,WAHgB,CAAjB;AAMA7B,IAAAA,WAAW,CACV8B,QADU,EAEV3C,cAFU,EAGVmB,uBAHU,EAIV,IAJU,EAKV;AAAEyB,MAAAA,MAAM,EAAE;AAAV,KALU,CAAX;AAOA,GAjBe,EAkBhB,CAAE/B,WAAF,EAAeM,uBAAf,EAAwCnB,cAAxC,CAlBgB,CAAjB;AAqBA,QAAM6C,YAAY,GAAG,0BAClBN,IAAF,IAAY;AACX;AACA,QAAKO,sBAASC,EAAT,KAAgB,KAArB,EAA6B;AAC5BC,qCAAkBC,qBAAlB,GAA0CC,IAA1C,CAAkDC,OAAF,IAAe;AAC9D;AACA,cAAMC,OAAO,GAAGD,OAAO,GAAG,GAAH,GAAS,GAAhC,CAF8D,CAG9D;;AACAE,QAAAA,UAAU,CAAE,MAAM;AACjBf,UAAAA,QAAQ,CAAEC,IAAF,CAAR;AACA,SAFS,EAEPa,OAFO,CAAV;AAGA,OAPD;AAQA,KATD,MASO;AACNd,MAAAA,QAAQ,CAAEC,IAAF,CAAR;AACA;;AACD7C,IAAAA,QAAQ,CAAE6C,IAAF,CAAR;AACA,GAhBmB,EAiBpB,CAAED,QAAF,EAAY5C,QAAZ,CAjBoB,CAArB;AAoBA,QAAM4D,cAAc,GAAG,0BACpBC,KAAF,IAAa;AACZrD,IAAAA,cAAc,CAAEqD,KAAF,CAAd;AACA,GAHqB,EAItB,CAAErD,cAAF,CAJsB,CAAvB;AAOA,QAAMsD,cAAc,GAAG,0BAAa,MAAMpD,WAAW,CAAE,KAAF,CAA9B,EAAyC,CAC/DA,WAD+D,CAAzC,CAAvB;AAIA,QAAMqD,cAAc,GAAG,0BAAa,MAAMrD,WAAW,CAAE,IAAF,CAA9B,EAAwC,CAC9DA,WAD8D,CAAxC,CAAvB;AAIA,SACC,4BAAC,uBAAD;AACC,IAAA,SAAS,EAAG,IADb;AAEC,IAAA,OAAO,EAAGiC,OAFX;AAGC,IAAA,cAAc,EAAGmB,cAHlB;AAIC,IAAA,cAAc,EAAGC,cAJlB;AAKC,IAAA,MAAM,EACL,qDACGpD,cAAc,IACf,4BAAC,yBAAD;AACC,MAAA,QAAQ,EAAGiD,cADZ;AAEC,MAAA,KAAK,EAAGrD;AAFT,MAFF,EAOGE,QAAQ,IAAI,CAAEF,WAAd,IACD,4BAAC,aAAD,CAAc,OAAd;AACC,MAAA,WAAW,EAAGQ,WADf;AAEC,MAAA,kBAAkB,EAAGW;AAFtB,MARF,CANF;AAqBC,IAAA,aAAa,MArBd;AAsBC,IAAA,uBAAuB,EAAGf,cAtB3B;AAuBC,IAAA,YAAY,EAAGqD,eAAOC;AAvBvB,KAyBC,4BAAC,+BAAD,QACG,CAAE;AAAEC,IAAAA;AAAF,GAAF,KACD,4BAAC,+BAAD;AAAoB,IAAA,UAAU,EAAG;AAAjC,KACG,CAAEzD,QAAF,IAAcF,WAAd,GACD,4BAAC,sBAAD;AACC,IAAA,YAAY,EAAGL,YADhB;AAEC,IAAA,WAAW,EAAGK,WAFf;AAGC,IAAA,QAAQ,EAAG4C,YAHZ;AAIC,IAAA,SAAS,EAAGe;AAJb,IADC,GAQD,4BAAC,aAAD;AACC,IAAA,YAAY,EAAGhE,YADhB;AAEC,IAAA,SAAS,EAAGgE,SAFb;AAGC,IAAA,QAAQ,EAAGpD,QAHZ;AAIC,IAAA,QAAQ,EAAGqC,YAJZ;AAKC,IAAA,kBAAkB,EAAGzB;AALtB,IATF,CAFF,CAzBD,CADD;AAkDA;;eAEc3B,Y","sourcesContent":["/**\n * External dependencies\n */\nimport { AccessibilityInfo, TouchableHighlight, Platform } from 'react-native';\n\n/**\n * WordPress dependencies\n */\nimport { useEffect, useState, useCallback } from '@wordpress/element';\nimport { useSelect, useDispatch } from '@wordpress/data';\nimport { createBlock } from '@wordpress/blocks';\nimport {\n\tBottomSheet,\n\tBottomSheetConsumer,\n\tSearchControl,\n} from '@wordpress/components';\n\n/**\n * Internal dependencies\n */\nimport InserterSearchResults from './search-results';\nimport { store as blockEditorStore } from '../../store';\nimport InserterTabs from './tabs';\nimport styles from './style.scss';\n\nconst MIN_ITEMS_FOR_SEARCH = 2;\nconst REUSABLE_BLOCKS_CATEGORY = 'reusable';\n\nfunction InserterMenu( {\n\tonSelect,\n\tonDismiss,\n\trootClientId,\n\tclientId,\n\tisAppender,\n\tshouldReplaceBlock,\n\tinsertionIndex,\n} ) {\n\tconst [ filterValue, setFilterValue ] = useState( '' );\n\tconst [ showTabs, setShowTabs ] = useState( true );\n\t// eslint-disable-next-line no-undef\n\tconst [ showSearchForm, setShowSearchForm ] = useState( __DEV__ );\n\tconst [ tabIndex, setTabIndex ] = useState( 0 );\n\n\tconst {\n\t\tshowInsertionPoint,\n\t\thideInsertionPoint,\n\t\tclearSelectedBlock,\n\t\tinsertBlock,\n\t\tremoveBlock,\n\t\tresetBlocks,\n\t\tinsertDefaultBlock,\n\t} = useDispatch( blockEditorStore );\n\n\tconst { items, destinationRootClientId, showReusableBlocks } = useSelect(\n\t\t( select ) => {\n\t\t\tconst {\n\t\t\t\tgetInserterItems,\n\t\t\t\tgetBlockRootClientId,\n\t\t\t\tgetBlockSelectionEnd,\n\t\t\t} = select( blockEditorStore );\n\n\t\t\tlet targetRootClientId = rootClientId;\n\t\t\tif ( ! targetRootClientId && ! clientId && ! isAppender ) {\n\t\t\t\tconst end = getBlockSelectionEnd();\n\t\t\t\tif ( end ) {\n\t\t\t\t\ttargetRootClientId =\n\t\t\t\t\t\tgetBlockRootClientId( end ) || undefined;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst allItems = getInserterItems( targetRootClientId );\n\t\t\tconst reusableBlockItems = allItems.filter(\n\t\t\t\t( { category } ) => category === REUSABLE_BLOCKS_CATEGORY\n\t\t\t);\n\n\t\t\treturn {\n\t\t\t\titems: allItems,\n\t\t\t\tdestinationRootClientId: targetRootClientId,\n\t\t\t\tshowReusableBlocks: !! reusableBlockItems.length,\n\t\t\t};\n\t\t}\n\t);\n\n\tconst { getBlockOrder, getBlockCount } = useSelect( blockEditorStore );\n\n\tuseEffect( () => {\n\t\t// Show/Hide insertion point on Mount/Dismount\n\t\tif ( shouldReplaceBlock ) {\n\t\t\tconst count = getBlockCount();\n\t\t\t// Check if there is a rootClientId because that means it is a nested replaceable block\n\t\t\t// and we don't want to clear/reset all blocks.\n\t\t\tif ( count === 1 && ! rootClientId ) {\n\t\t\t\t// Removing the last block is not possilble with `removeBlock` action.\n\t\t\t\t// It always inserts a default block if the last of the blocks have been removed.\n\t\t\t\tclearSelectedBlock();\n\t\t\t\tresetBlocks( [] );\n\t\t\t} else {\n\t\t\t\tconst blockToReplace = getBlockOrder( destinationRootClientId )[\n\t\t\t\t\tinsertionIndex\n\t\t\t\t];\n\t\t\t\tremoveBlock( blockToReplace, false );\n\t\t\t}\n\t\t}\n\t\tshowInsertionPoint( destinationRootClientId, insertionIndex );\n\n\t\t// Show search form if there are enough items to filter.\n\t\tif ( items.length < MIN_ITEMS_FOR_SEARCH ) {\n\t\t\tsetShowSearchForm( false );\n\t\t}\n\n\t\treturn hideInsertionPoint;\n\t}, [] );\n\n\tconst onClose = useCallback( () => {\n\t\t// if should replace but didn't insert any block\n\t\t// re-insert default block\n\t\tif ( shouldReplaceBlock ) {\n\t\t\tinsertDefaultBlock( {}, destinationRootClientId, insertionIndex );\n\t\t}\n\t\tonDismiss();\n\t}, [ shouldReplaceBlock, destinationRootClientId, insertionIndex ] );\n\n\tconst onInsert = useCallback(\n\t\t( item ) => {\n\t\t\tconst { name, initialAttributes, innerBlocks } = item;\n\n\t\t\tconst newBlock = createBlock(\n\t\t\t\tname,\n\t\t\t\tinitialAttributes,\n\t\t\t\tinnerBlocks\n\t\t\t);\n\n\t\t\tinsertBlock(\n\t\t\t\tnewBlock,\n\t\t\t\tinsertionIndex,\n\t\t\t\tdestinationRootClientId,\n\t\t\t\ttrue,\n\t\t\t\t{ source: 'inserter_menu' }\n\t\t\t);\n\t\t},\n\t\t[ insertBlock, destinationRootClientId, insertionIndex ]\n\t);\n\n\tconst onSelectItem = useCallback(\n\t\t( item ) => {\n\t\t\t// Avoid a focus loop, see https://github.com/WordPress/gutenberg/issues/30562\n\t\t\tif ( Platform.OS === 'ios' ) {\n\t\t\t\tAccessibilityInfo.isScreenReaderEnabled().then( ( enabled ) => {\n\t\t\t\t\t// In testing, the bug focus loop needed a longer timeout when VoiceOver was enabled\n\t\t\t\t\tconst timeout = enabled ? 200 : 100;\n\t\t\t\t\t// eslint-disable-next-line @wordpress/react-no-unsafe-timeout\n\t\t\t\t\tsetTimeout( () => {\n\t\t\t\t\t\tonInsert( item );\n\t\t\t\t\t}, timeout );\n\t\t\t\t} );\n\t\t\t} else {\n\t\t\t\tonInsert( item );\n\t\t\t}\n\t\t\tonSelect( item );\n\t\t},\n\t\t[ onInsert, onSelect ]\n\t);\n\n\tconst onChangeSearch = useCallback(\n\t\t( value ) => {\n\t\t\tsetFilterValue( value );\n\t\t},\n\t\t[ setFilterValue ]\n\t);\n\n\tconst onKeyboardShow = useCallback( () => setShowTabs( false ), [\n\t\tsetShowTabs,\n\t] );\n\n\tconst onKeyboardHide = useCallback( () => setShowTabs( true ), [\n\t\tsetShowTabs,\n\t] );\n\n\treturn (\n\t\t<BottomSheet\n\t\t\tisVisible={ true }\n\t\t\tonClose={ onClose }\n\t\t\tonKeyboardShow={ onKeyboardShow }\n\t\t\tonKeyboardHide={ onKeyboardHide }\n\t\t\theader={\n\t\t\t\t<>\n\t\t\t\t\t{ showSearchForm && (\n\t\t\t\t\t\t<SearchControl\n\t\t\t\t\t\t\tonChange={ onChangeSearch }\n\t\t\t\t\t\t\tvalue={ filterValue }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t\t{ showTabs && ! filterValue && (\n\t\t\t\t\t\t<InserterTabs.Control\n\t\t\t\t\t\t\tonChangeTab={ setTabIndex }\n\t\t\t\t\t\t\tshowReusableBlocks={ showReusableBlocks }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t</>\n\t\t\t}\n\t\t\thasNavigation\n\t\t\tsetMinHeightToMaxHeight={ showSearchForm }\n\t\t\tcontentStyle={ styles.list }\n\t\t>\n\t\t\t<BottomSheetConsumer>\n\t\t\t\t{ ( { listProps } ) => (\n\t\t\t\t\t<TouchableHighlight accessible={ false }>\n\t\t\t\t\t\t{ ! showTabs || filterValue ? (\n\t\t\t\t\t\t\t<InserterSearchResults\n\t\t\t\t\t\t\t\trootClientId={ rootClientId }\n\t\t\t\t\t\t\t\tfilterValue={ filterValue }\n\t\t\t\t\t\t\t\tonSelect={ onSelectItem }\n\t\t\t\t\t\t\t\tlistProps={ listProps }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\t<InserterTabs\n\t\t\t\t\t\t\t\trootClientId={ rootClientId }\n\t\t\t\t\t\t\t\tlistProps={ listProps }\n\t\t\t\t\t\t\t\ttabIndex={ tabIndex }\n\t\t\t\t\t\t\t\tonSelect={ onSelectItem }\n\t\t\t\t\t\t\t\tshowReusableBlocks={ showReusableBlocks }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t) }\n\t\t\t\t\t</TouchableHighlight>\n\t\t\t\t) }\n\t\t\t</BottomSheetConsumer>\n\t\t</BottomSheet>\n\t);\n}\n\nexport default InserterMenu;\n"]}
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/inserter/menu.native.js"],"names":["MIN_ITEMS_FOR_SEARCH","InserterMenu","onSelect","onDismiss","rootClientId","clientId","isAppender","shouldReplaceBlock","insertionIndex","filterValue","setFilterValue","showTabs","setShowTabs","tabIndex","setTabIndex","isIOS","Platform","OS","showInsertionPoint","hideInsertionPoint","clearSelectedBlock","insertBlock","removeBlock","resetBlocks","insertDefaultBlock","blockEditorStore","items","destinationRootClientId","showReusableBlocks","select","getInserterItems","getBlockRootClientId","getBlockSelectionEnd","targetRootClientId","end","undefined","allItems","reusableBlockItems","onlyReusable","length","getBlockOrder","getBlockCount","count","blockToReplace","onClose","onInsert","item","name","initialAttributes","innerBlocks","newBlock","source","onSelectItem","AccessibilityInfo","isScreenReaderEnabled","then","enabled","timeout","setTimeout","onChangeSearch","value","onKeyboardShow","onKeyboardHide","showSearchForm","isFullScreen","styles","listProps"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { AccessibilityInfo, TouchableHighlight, Platform } from 'react-native';\n\n/**\n * WordPress dependencies\n */\nimport { useEffect, useState, useCallback } from '@wordpress/element';\nimport { useSelect, useDispatch } from '@wordpress/data';\nimport { createBlock } from '@wordpress/blocks';\nimport {\n\tBottomSheet,\n\tBottomSheetConsumer,\n\tSearchControl,\n} from '@wordpress/components';\n\n/**\n * Internal dependencies\n */\nimport InserterSearchResults from './search-results';\nimport { store as blockEditorStore } from '../../store';\nimport InserterTabs from './tabs';\nimport styles from './style.scss';\nimport { filterInserterItems } from './utils';\n\nconst MIN_ITEMS_FOR_SEARCH = 2;\nfunction InserterMenu( {\n\tonSelect,\n\tonDismiss,\n\trootClientId,\n\tclientId,\n\tisAppender,\n\tshouldReplaceBlock,\n\tinsertionIndex,\n} ) {\n\tconst [ filterValue, setFilterValue ] = useState( '' );\n\tconst [ showTabs, setShowTabs ] = useState( true );\n\tconst [ tabIndex, setTabIndex ] = useState( 0 );\n\n\tconst isIOS = Platform.OS === 'ios';\n\n\tconst {\n\t\tshowInsertionPoint,\n\t\thideInsertionPoint,\n\t\tclearSelectedBlock,\n\t\tinsertBlock,\n\t\tremoveBlock,\n\t\tresetBlocks,\n\t\tinsertDefaultBlock,\n\t} = useDispatch( blockEditorStore );\n\n\tconst { items, destinationRootClientId, showReusableBlocks } = useSelect(\n\t\t( select ) => {\n\t\t\tconst {\n\t\t\t\tgetInserterItems,\n\t\t\t\tgetBlockRootClientId,\n\t\t\t\tgetBlockSelectionEnd,\n\t\t\t} = select( blockEditorStore );\n\n\t\t\tlet targetRootClientId = rootClientId;\n\t\t\tif ( ! targetRootClientId && ! clientId && ! isAppender ) {\n\t\t\t\tconst end = getBlockSelectionEnd();\n\t\t\t\tif ( end ) {\n\t\t\t\t\ttargetRootClientId =\n\t\t\t\t\t\tgetBlockRootClientId( end ) || undefined;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst allItems = getInserterItems( targetRootClientId );\n\t\t\tconst reusableBlockItems = filterInserterItems( allItems, {\n\t\t\t\tonlyReusable: true,\n\t\t\t} );\n\n\t\t\treturn {\n\t\t\t\titems: allItems,\n\t\t\t\tdestinationRootClientId: targetRootClientId,\n\t\t\t\tshowReusableBlocks: !! reusableBlockItems.length,\n\t\t\t};\n\t\t}\n\t);\n\n\tconst { getBlockOrder, getBlockCount } = useSelect( blockEditorStore );\n\n\tuseEffect( () => {\n\t\t// Show/Hide insertion point on Mount/Dismount\n\t\tif ( shouldReplaceBlock ) {\n\t\t\tconst count = getBlockCount();\n\t\t\t// Check if there is a rootClientId because that means it is a nested replaceable block\n\t\t\t// and we don't want to clear/reset all blocks.\n\t\t\tif ( count === 1 && ! rootClientId ) {\n\t\t\t\t// Removing the last block is not possilble with `removeBlock` action.\n\t\t\t\t// It always inserts a default block if the last of the blocks have been removed.\n\t\t\t\tclearSelectedBlock();\n\t\t\t\tresetBlocks( [] );\n\t\t\t} else {\n\t\t\t\tconst blockToReplace = getBlockOrder( destinationRootClientId )[\n\t\t\t\t\tinsertionIndex\n\t\t\t\t];\n\t\t\t\tremoveBlock( blockToReplace, false );\n\t\t\t}\n\t\t}\n\t\tshowInsertionPoint( destinationRootClientId, insertionIndex );\n\n\t\treturn hideInsertionPoint;\n\t}, [] );\n\n\tconst onClose = useCallback( () => {\n\t\t// if should replace but didn't insert any block\n\t\t// re-insert default block\n\t\tif ( shouldReplaceBlock ) {\n\t\t\tinsertDefaultBlock( {}, destinationRootClientId, insertionIndex );\n\t\t}\n\t\tonDismiss();\n\t}, [ shouldReplaceBlock, destinationRootClientId, insertionIndex ] );\n\n\tconst onInsert = useCallback(\n\t\t( item ) => {\n\t\t\tconst { name, initialAttributes, innerBlocks } = item;\n\n\t\t\tconst newBlock = createBlock(\n\t\t\t\tname,\n\t\t\t\tinitialAttributes,\n\t\t\t\tinnerBlocks\n\t\t\t);\n\n\t\t\tinsertBlock(\n\t\t\t\tnewBlock,\n\t\t\t\tinsertionIndex,\n\t\t\t\tdestinationRootClientId,\n\t\t\t\ttrue,\n\t\t\t\t{ source: 'inserter_menu' }\n\t\t\t);\n\t\t},\n\t\t[ insertBlock, destinationRootClientId, insertionIndex ]\n\t);\n\n\tconst onSelectItem = useCallback(\n\t\t( item ) => {\n\t\t\t// Avoid a focus loop, see https://github.com/WordPress/gutenberg/issues/30562\n\t\t\tif ( Platform.OS === 'ios' ) {\n\t\t\t\tAccessibilityInfo.isScreenReaderEnabled().then( ( enabled ) => {\n\t\t\t\t\t// In testing, the bug focus loop needed a longer timeout when VoiceOver was enabled\n\t\t\t\t\tconst timeout = enabled ? 200 : 100;\n\t\t\t\t\t// eslint-disable-next-line @wordpress/react-no-unsafe-timeout\n\t\t\t\t\tsetTimeout( () => {\n\t\t\t\t\t\tonInsert( item );\n\t\t\t\t\t}, timeout );\n\t\t\t\t} );\n\t\t\t} else {\n\t\t\t\tonInsert( item );\n\t\t\t}\n\t\t\tonSelect( item );\n\t\t},\n\t\t[ onInsert, onSelect ]\n\t);\n\n\tconst onChangeSearch = useCallback(\n\t\t( value ) => {\n\t\t\tsetFilterValue( value );\n\t\t},\n\t\t[ setFilterValue ]\n\t);\n\n\tconst onKeyboardShow = useCallback( () => setShowTabs( false ), [\n\t\tsetShowTabs,\n\t] );\n\n\tconst onKeyboardHide = useCallback( () => setShowTabs( true ), [\n\t\tsetShowTabs,\n\t] );\n\n\tconst showSearchForm = items.length > MIN_ITEMS_FOR_SEARCH;\n\tconst isFullScreen = ! isIOS && showSearchForm;\n\n\treturn (\n\t\t<BottomSheet\n\t\t\tisVisible={ true }\n\t\t\tonClose={ onClose }\n\t\t\tonKeyboardShow={ onKeyboardShow }\n\t\t\tonKeyboardHide={ onKeyboardHide }\n\t\t\theader={\n\t\t\t\t<>\n\t\t\t\t\t{ showSearchForm && (\n\t\t\t\t\t\t<SearchControl\n\t\t\t\t\t\t\tonChange={ onChangeSearch }\n\t\t\t\t\t\t\tvalue={ filterValue }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t\t{ showTabs && ! filterValue && (\n\t\t\t\t\t\t<InserterTabs.Control\n\t\t\t\t\t\t\tonChangeTab={ setTabIndex }\n\t\t\t\t\t\t\tshowReusableBlocks={ showReusableBlocks }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t</>\n\t\t\t}\n\t\t\thasNavigation\n\t\t\tsetMinHeightToMaxHeight={ true }\n\t\t\tcontentStyle={ styles[ 'inserter-menu__list' ] }\n\t\t\tisFullScreen={ isFullScreen }\n\t\t\tallowDragIndicator={ true }\n\t\t>\n\t\t\t<BottomSheetConsumer>\n\t\t\t\t{ ( { listProps } ) => (\n\t\t\t\t\t<TouchableHighlight\n\t\t\t\t\t\taccessible={ false }\n\t\t\t\t\t\tstyle={ styles[ 'inserter-menu__list-wrapper' ] }\n\t\t\t\t\t>\n\t\t\t\t\t\t{ ! showTabs || filterValue ? (\n\t\t\t\t\t\t\t<InserterSearchResults\n\t\t\t\t\t\t\t\trootClientId={ rootClientId }\n\t\t\t\t\t\t\t\tfilterValue={ filterValue }\n\t\t\t\t\t\t\t\tonSelect={ onSelectItem }\n\t\t\t\t\t\t\t\tlistProps={ listProps }\n\t\t\t\t\t\t\t\tisFullScreen={ isFullScreen }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\t<InserterTabs\n\t\t\t\t\t\t\t\trootClientId={ rootClientId }\n\t\t\t\t\t\t\t\tlistProps={ listProps }\n\t\t\t\t\t\t\t\ttabIndex={ tabIndex }\n\t\t\t\t\t\t\t\tonSelect={ onSelectItem }\n\t\t\t\t\t\t\t\tshowReusableBlocks={ showReusableBlocks }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t) }\n\t\t\t\t\t</TouchableHighlight>\n\t\t\t\t) }\n\t\t\t</BottomSheetConsumer>\n\t\t</BottomSheet>\n\t);\n}\n\nexport default InserterMenu;\n"]}
@@ -42,7 +42,7 @@ function InserterPreviewPanel({
42
42
  className: "block-editor-inserter__preview-container"
43
43
  }, (0, _element.createElement)("div", {
44
44
  className: "block-editor-inserter__preview"
45
- }, isReusable || hoveredItemBlockType.example ? (0, _element.createElement)("div", {
45
+ }, isReusable || hoveredItemBlockType !== null && hoveredItemBlockType !== void 0 && hoveredItemBlockType.example ? (0, _element.createElement)("div", {
46
46
  className: "block-editor-inserter__preview-content"
47
47
  }, (0, _element.createElement)(_blockPreview.default, {
48
48
  __experimentalPadding: 16,
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/block-editor/src/components/inserter/preview-panel.js"],"names":["InserterPreviewPanel","item","name","title","icon","description","initialAttributes","hoveredItemBlockType","isReusable","example","viewportWidth","attributes","innerBlocks"],"mappings":";;;;;;;;;;;AAGA;;AAMA;;AAKA;;AACA;;AAfA;AACA;AACA;;AASA;AACA;AACA;AAIA,SAASA,oBAAT,CAA+B;AAAEC,EAAAA;AAAF,CAA/B,EAA0C;AAAA;;AACzC,QAAM;AAAEC,IAAAA,IAAF;AAAQC,IAAAA,KAAR;AAAeC,IAAAA,IAAf;AAAqBC,IAAAA,WAArB;AAAkCC,IAAAA;AAAlC,MAAwDL,IAA9D;AACA,QAAMM,oBAAoB,GAAG,0BAAcL,IAAd,CAA7B;AACA,QAAMM,UAAU,GAAG,6BAAiBP,IAAjB,CAAnB;AACA,SACC;AAAK,IAAA,SAAS,EAAC;AAAf,KACC;AAAK,IAAA,SAAS,EAAC;AAAf,KACGO,UAAU,IAAID,oBAAoB,CAACE,OAAnC,GACD;AAAK,IAAA,SAAS,EAAC;AAAf,KACC,4BAAC,qBAAD;AACC,IAAA,qBAAqB,EAAG,EADzB;AAEC,IAAA,aAAa,qDACZF,oBAAoB,CAACE,OADT,2DACZ,uBAA8BC,aADlB,yEAEZ,GAJF;AAMC,IAAA,MAAM,EACLH,oBAAoB,CAACE,OAArB,GACG,iCAAqBR,IAAI,CAACC,IAA1B,EAAgC;AAChCS,MAAAA,UAAU,EAAE,EACX,GAAGJ,oBAAoB,CAACE,OAArB,CACDE,UAFS;AAGX,WAAGL;AAHQ,OADoB;AAMhCM,MAAAA,WAAW,EACVL,oBAAoB,CAACE,OAArB,CACEG;AAR6B,KAAhC,CADH,GAWG,yBAAaV,IAAb,EAAmBI,iBAAnB;AAlBL,IADD,CADC,GAyBD;AAAK,IAAA,SAAS,EAAC;AAAf,KACG,cAAI,uBAAJ,CADH,CA1BF,CADD,EAgCG,CAAEE,UAAF,IACD,4BAAC,kBAAD;AACC,IAAA,KAAK,EAAGL,KADT;AAEC,IAAA,IAAI,EAAGC,IAFR;AAGC,IAAA,WAAW,EAAGC;AAHf,IAjCF,CADD;AA0CA;;eAEcL,oB","sourcesContent":["/**\n * WordPress dependencies\n */\nimport {\n\tisReusableBlock,\n\tcreateBlock,\n\tgetBlockFromExample,\n\tgetBlockType,\n} from '@wordpress/blocks';\nimport { __ } from '@wordpress/i18n';\n\n/**\n * Internal dependencies\n */\nimport BlockCard from '../block-card';\nimport BlockPreview from '../block-preview';\n\nfunction InserterPreviewPanel( { item } ) {\n\tconst { name, title, icon, description, initialAttributes } = item;\n\tconst hoveredItemBlockType = getBlockType( name );\n\tconst isReusable = isReusableBlock( item );\n\treturn (\n\t\t<div className=\"block-editor-inserter__preview-container\">\n\t\t\t<div className=\"block-editor-inserter__preview\">\n\t\t\t\t{ isReusable || hoveredItemBlockType.example ? (\n\t\t\t\t\t<div className=\"block-editor-inserter__preview-content\">\n\t\t\t\t\t\t<BlockPreview\n\t\t\t\t\t\t\t__experimentalPadding={ 16 }\n\t\t\t\t\t\t\tviewportWidth={\n\t\t\t\t\t\t\t\thoveredItemBlockType.example?.viewportWidth ??\n\t\t\t\t\t\t\t\t500\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tblocks={\n\t\t\t\t\t\t\t\thoveredItemBlockType.example\n\t\t\t\t\t\t\t\t\t? getBlockFromExample( item.name, {\n\t\t\t\t\t\t\t\t\t\t\tattributes: {\n\t\t\t\t\t\t\t\t\t\t\t\t...hoveredItemBlockType.example\n\t\t\t\t\t\t\t\t\t\t\t\t\t.attributes,\n\t\t\t\t\t\t\t\t\t\t\t\t...initialAttributes,\n\t\t\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t\t\tinnerBlocks:\n\t\t\t\t\t\t\t\t\t\t\t\thoveredItemBlockType.example\n\t\t\t\t\t\t\t\t\t\t\t\t\t.innerBlocks,\n\t\t\t\t\t\t\t\t\t } )\n\t\t\t\t\t\t\t\t\t: createBlock( name, initialAttributes )\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t/>\n\t\t\t\t\t</div>\n\t\t\t\t) : (\n\t\t\t\t\t<div className=\"block-editor-inserter__preview-content-missing\">\n\t\t\t\t\t\t{ __( 'No Preview Available.' ) }\n\t\t\t\t\t</div>\n\t\t\t\t) }\n\t\t\t</div>\n\t\t\t{ ! isReusable && (\n\t\t\t\t<BlockCard\n\t\t\t\t\ttitle={ title }\n\t\t\t\t\ticon={ icon }\n\t\t\t\t\tdescription={ description }\n\t\t\t\t/>\n\t\t\t) }\n\t\t</div>\n\t);\n}\n\nexport default InserterPreviewPanel;\n"]}
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/inserter/preview-panel.js"],"names":["InserterPreviewPanel","item","name","title","icon","description","initialAttributes","hoveredItemBlockType","isReusable","example","viewportWidth","attributes","innerBlocks"],"mappings":";;;;;;;;;;;AAGA;;AAMA;;AAKA;;AACA;;AAfA;AACA;AACA;;AASA;AACA;AACA;AAIA,SAASA,oBAAT,CAA+B;AAAEC,EAAAA;AAAF,CAA/B,EAA0C;AAAA;;AACzC,QAAM;AAAEC,IAAAA,IAAF;AAAQC,IAAAA,KAAR;AAAeC,IAAAA,IAAf;AAAqBC,IAAAA,WAArB;AAAkCC,IAAAA;AAAlC,MAAwDL,IAA9D;AACA,QAAMM,oBAAoB,GAAG,0BAAcL,IAAd,CAA7B;AACA,QAAMM,UAAU,GAAG,6BAAiBP,IAAjB,CAAnB;AACA,SACC;AAAK,IAAA,SAAS,EAAC;AAAf,KACC;AAAK,IAAA,SAAS,EAAC;AAAf,KACGO,UAAU,IAAID,oBAAJ,aAAIA,oBAAJ,eAAIA,oBAAoB,CAAEE,OAApC,GACD;AAAK,IAAA,SAAS,EAAC;AAAf,KACC,4BAAC,qBAAD;AACC,IAAA,qBAAqB,EAAG,EADzB;AAEC,IAAA,aAAa,qDACZF,oBAAoB,CAACE,OADT,2DACZ,uBAA8BC,aADlB,yEAEZ,GAJF;AAMC,IAAA,MAAM,EACLH,oBAAoB,CAACE,OAArB,GACG,iCAAqBR,IAAI,CAACC,IAA1B,EAAgC;AAChCS,MAAAA,UAAU,EAAE,EACX,GAAGJ,oBAAoB,CAACE,OAArB,CACDE,UAFS;AAGX,WAAGL;AAHQ,OADoB;AAMhCM,MAAAA,WAAW,EACVL,oBAAoB,CAACE,OAArB,CACEG;AAR6B,KAAhC,CADH,GAWG,yBAAaV,IAAb,EAAmBI,iBAAnB;AAlBL,IADD,CADC,GAyBD;AAAK,IAAA,SAAS,EAAC;AAAf,KACG,cAAI,uBAAJ,CADH,CA1BF,CADD,EAgCG,CAAEE,UAAF,IACD,4BAAC,kBAAD;AACC,IAAA,KAAK,EAAGL,KADT;AAEC,IAAA,IAAI,EAAGC,IAFR;AAGC,IAAA,WAAW,EAAGC;AAHf,IAjCF,CADD;AA0CA;;eAEcL,oB","sourcesContent":["/**\n * WordPress dependencies\n */\nimport {\n\tisReusableBlock,\n\tcreateBlock,\n\tgetBlockFromExample,\n\tgetBlockType,\n} from '@wordpress/blocks';\nimport { __ } from '@wordpress/i18n';\n\n/**\n * Internal dependencies\n */\nimport BlockCard from '../block-card';\nimport BlockPreview from '../block-preview';\n\nfunction InserterPreviewPanel( { item } ) {\n\tconst { name, title, icon, description, initialAttributes } = item;\n\tconst hoveredItemBlockType = getBlockType( name );\n\tconst isReusable = isReusableBlock( item );\n\treturn (\n\t\t<div className=\"block-editor-inserter__preview-container\">\n\t\t\t<div className=\"block-editor-inserter__preview\">\n\t\t\t\t{ isReusable || hoveredItemBlockType?.example ? (\n\t\t\t\t\t<div className=\"block-editor-inserter__preview-content\">\n\t\t\t\t\t\t<BlockPreview\n\t\t\t\t\t\t\t__experimentalPadding={ 16 }\n\t\t\t\t\t\t\tviewportWidth={\n\t\t\t\t\t\t\t\thoveredItemBlockType.example?.viewportWidth ??\n\t\t\t\t\t\t\t\t500\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tblocks={\n\t\t\t\t\t\t\t\thoveredItemBlockType.example\n\t\t\t\t\t\t\t\t\t? getBlockFromExample( item.name, {\n\t\t\t\t\t\t\t\t\t\t\tattributes: {\n\t\t\t\t\t\t\t\t\t\t\t\t...hoveredItemBlockType.example\n\t\t\t\t\t\t\t\t\t\t\t\t\t.attributes,\n\t\t\t\t\t\t\t\t\t\t\t\t...initialAttributes,\n\t\t\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t\t\tinnerBlocks:\n\t\t\t\t\t\t\t\t\t\t\t\thoveredItemBlockType.example\n\t\t\t\t\t\t\t\t\t\t\t\t\t.innerBlocks,\n\t\t\t\t\t\t\t\t\t } )\n\t\t\t\t\t\t\t\t\t: createBlock( name, initialAttributes )\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t/>\n\t\t\t\t\t</div>\n\t\t\t\t) : (\n\t\t\t\t\t<div className=\"block-editor-inserter__preview-content-missing\">\n\t\t\t\t\t\t{ __( 'No Preview Available.' ) }\n\t\t\t\t\t</div>\n\t\t\t\t) }\n\t\t\t</div>\n\t\t\t{ ! isReusable && (\n\t\t\t\t<BlockCard\n\t\t\t\t\ttitle={ title }\n\t\t\t\t\ticon={ icon }\n\t\t\t\t\tdescription={ description }\n\t\t\t\t/>\n\t\t\t) }\n\t\t</div>\n\t);\n}\n\nexport default InserterPreviewPanel;\n"]}
@@ -84,7 +84,8 @@ function QuickInserter({
84
84
  const onBrowseAll = () => {
85
85
  setInserterIsOpened({
86
86
  rootClientId,
87
- insertionIndex
87
+ insertionIndex,
88
+ filterValue
88
89
  });
89
90
  };
90
91
 
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/block-editor/src/components/inserter/quick-inserter.js"],"names":["SEARCH_THRESHOLD","SHOWN_BLOCK_TYPES","SHOWN_BLOCK_PATTERNS","QuickInserter","onSelect","rootClientId","clientId","isAppender","filterValue","setFilterValue","destinationRootClientId","onInsertBlocks","blockTypes","patterns","showPatterns","length","showSearch","setInserterIsOpened","insertionIndex","select","getSettings","getBlockIndex","getBlockCount","blockEditorStore","index","__experimentalSetIsInserterOpened","onBrowseAll","value"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport classnames from 'classnames';\n\n/**\n * WordPress dependencies\n */\nimport { useState, useEffect } from '@wordpress/element';\nimport { __ } from '@wordpress/i18n';\nimport { Button, SearchControl } from '@wordpress/components';\nimport { useSelect } from '@wordpress/data';\n\n/**\n * Internal dependencies\n */\nimport InserterSearchResults from './search-results';\nimport useInsertionPoint from './hooks/use-insertion-point';\nimport usePatternsState from './hooks/use-patterns-state';\nimport useBlockTypesState from './hooks/use-block-types-state';\nimport { store as blockEditorStore } from '../../store';\n\nconst SEARCH_THRESHOLD = 6;\nconst SHOWN_BLOCK_TYPES = 6;\nconst SHOWN_BLOCK_PATTERNS = 2;\n\nexport default function QuickInserter( {\n\tonSelect,\n\trootClientId,\n\tclientId,\n\tisAppender,\n} ) {\n\tconst [ filterValue, setFilterValue ] = useState( '' );\n\tconst [ destinationRootClientId, onInsertBlocks ] = useInsertionPoint( {\n\t\tonSelect,\n\t\trootClientId,\n\t\tclientId,\n\t\tisAppender,\n\t} );\n\tconst [ blockTypes ] = useBlockTypesState(\n\t\tdestinationRootClientId,\n\t\tonInsertBlocks\n\t);\n\n\tconst [ patterns ] = usePatternsState(\n\t\tonInsertBlocks,\n\t\tdestinationRootClientId\n\t);\n\tconst showPatterns = patterns.length && !! filterValue;\n\tconst showSearch =\n\t\t( showPatterns && patterns.length > SEARCH_THRESHOLD ) ||\n\t\tblockTypes.length > SEARCH_THRESHOLD;\n\n\tconst { setInserterIsOpened, insertionIndex } = useSelect(\n\t\t( select ) => {\n\t\t\tconst { getSettings, getBlockIndex, getBlockCount } = select(\n\t\t\t\tblockEditorStore\n\t\t\t);\n\t\t\tconst index = getBlockIndex( clientId, rootClientId );\n\t\t\treturn {\n\t\t\t\tsetInserterIsOpened: getSettings()\n\t\t\t\t\t.__experimentalSetIsInserterOpened,\n\t\t\t\tinsertionIndex: index === -1 ? getBlockCount() : index,\n\t\t\t};\n\t\t},\n\t\t[ clientId, rootClientId ]\n\t);\n\n\tuseEffect( () => {\n\t\tif ( setInserterIsOpened ) {\n\t\t\tsetInserterIsOpened( false );\n\t\t}\n\t}, [ setInserterIsOpened ] );\n\n\t// When clicking Browse All select the appropriate block so as\n\t// the insertion point can work as expected\n\tconst onBrowseAll = () => {\n\t\tsetInserterIsOpened( { rootClientId, insertionIndex } );\n\t};\n\n\treturn (\n\t\t<div\n\t\t\tclassName={ classnames( 'block-editor-inserter__quick-inserter', {\n\t\t\t\t'has-search': showSearch,\n\t\t\t\t'has-expand': setInserterIsOpened,\n\t\t\t} ) }\n\t\t>\n\t\t\t{ showSearch && (\n\t\t\t\t<SearchControl\n\t\t\t\t\tclassName=\"block-editor-inserter__search\"\n\t\t\t\t\tvalue={ filterValue }\n\t\t\t\t\tonChange={ ( value ) => {\n\t\t\t\t\t\tsetFilterValue( value );\n\t\t\t\t\t} }\n\t\t\t\t\tlabel={ __( 'Search for blocks and patterns' ) }\n\t\t\t\t\tplaceholder={ __( 'Search' ) }\n\t\t\t\t/>\n\t\t\t) }\n\n\t\t\t<div className=\"block-editor-inserter__quick-inserter-results\">\n\t\t\t\t<InserterSearchResults\n\t\t\t\t\tfilterValue={ filterValue }\n\t\t\t\t\tonSelect={ onSelect }\n\t\t\t\t\trootClientId={ rootClientId }\n\t\t\t\t\tclientId={ clientId }\n\t\t\t\t\tisAppender={ isAppender }\n\t\t\t\t\tmaxBlockPatterns={ showPatterns ? SHOWN_BLOCK_PATTERNS : 0 }\n\t\t\t\t\tmaxBlockTypes={ SHOWN_BLOCK_TYPES }\n\t\t\t\t\tisDraggable={ false }\n\t\t\t\t/>\n\t\t\t</div>\n\n\t\t\t{ setInserterIsOpened && (\n\t\t\t\t<Button\n\t\t\t\t\tclassName=\"block-editor-inserter__quick-inserter-expand\"\n\t\t\t\t\tonClick={ onBrowseAll }\n\t\t\t\t\taria-label={ __(\n\t\t\t\t\t\t'Browse all. This will open the main inserter panel in the editor toolbar.'\n\t\t\t\t\t) }\n\t\t\t\t>\n\t\t\t\t\t{ __( 'Browse all' ) }\n\t\t\t\t</Button>\n\t\t\t) }\n\t\t</div>\n\t);\n}\n"]}
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/inserter/quick-inserter.js"],"names":["SEARCH_THRESHOLD","SHOWN_BLOCK_TYPES","SHOWN_BLOCK_PATTERNS","QuickInserter","onSelect","rootClientId","clientId","isAppender","filterValue","setFilterValue","destinationRootClientId","onInsertBlocks","blockTypes","patterns","showPatterns","length","showSearch","setInserterIsOpened","insertionIndex","select","getSettings","getBlockIndex","getBlockCount","blockEditorStore","index","__experimentalSetIsInserterOpened","onBrowseAll","value"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport classnames from 'classnames';\n\n/**\n * WordPress dependencies\n */\nimport { useState, useEffect } from '@wordpress/element';\nimport { __ } from '@wordpress/i18n';\nimport { Button, SearchControl } from '@wordpress/components';\nimport { useSelect } from '@wordpress/data';\n\n/**\n * Internal dependencies\n */\nimport InserterSearchResults from './search-results';\nimport useInsertionPoint from './hooks/use-insertion-point';\nimport usePatternsState from './hooks/use-patterns-state';\nimport useBlockTypesState from './hooks/use-block-types-state';\nimport { store as blockEditorStore } from '../../store';\n\nconst SEARCH_THRESHOLD = 6;\nconst SHOWN_BLOCK_TYPES = 6;\nconst SHOWN_BLOCK_PATTERNS = 2;\n\nexport default function QuickInserter( {\n\tonSelect,\n\trootClientId,\n\tclientId,\n\tisAppender,\n} ) {\n\tconst [ filterValue, setFilterValue ] = useState( '' );\n\tconst [ destinationRootClientId, onInsertBlocks ] = useInsertionPoint( {\n\t\tonSelect,\n\t\trootClientId,\n\t\tclientId,\n\t\tisAppender,\n\t} );\n\tconst [ blockTypes ] = useBlockTypesState(\n\t\tdestinationRootClientId,\n\t\tonInsertBlocks\n\t);\n\n\tconst [ patterns ] = usePatternsState(\n\t\tonInsertBlocks,\n\t\tdestinationRootClientId\n\t);\n\tconst showPatterns = patterns.length && !! filterValue;\n\tconst showSearch =\n\t\t( showPatterns && patterns.length > SEARCH_THRESHOLD ) ||\n\t\tblockTypes.length > SEARCH_THRESHOLD;\n\n\tconst { setInserterIsOpened, insertionIndex } = useSelect(\n\t\t( select ) => {\n\t\t\tconst { getSettings, getBlockIndex, getBlockCount } = select(\n\t\t\t\tblockEditorStore\n\t\t\t);\n\t\t\tconst index = getBlockIndex( clientId, rootClientId );\n\t\t\treturn {\n\t\t\t\tsetInserterIsOpened: getSettings()\n\t\t\t\t\t.__experimentalSetIsInserterOpened,\n\t\t\t\tinsertionIndex: index === -1 ? getBlockCount() : index,\n\t\t\t};\n\t\t},\n\t\t[ clientId, rootClientId ]\n\t);\n\n\tuseEffect( () => {\n\t\tif ( setInserterIsOpened ) {\n\t\t\tsetInserterIsOpened( false );\n\t\t}\n\t}, [ setInserterIsOpened ] );\n\n\t// When clicking Browse All select the appropriate block so as\n\t// the insertion point can work as expected\n\tconst onBrowseAll = () => {\n\t\tsetInserterIsOpened( { rootClientId, insertionIndex, filterValue } );\n\t};\n\n\treturn (\n\t\t<div\n\t\t\tclassName={ classnames( 'block-editor-inserter__quick-inserter', {\n\t\t\t\t'has-search': showSearch,\n\t\t\t\t'has-expand': setInserterIsOpened,\n\t\t\t} ) }\n\t\t>\n\t\t\t{ showSearch && (\n\t\t\t\t<SearchControl\n\t\t\t\t\tclassName=\"block-editor-inserter__search\"\n\t\t\t\t\tvalue={ filterValue }\n\t\t\t\t\tonChange={ ( value ) => {\n\t\t\t\t\t\tsetFilterValue( value );\n\t\t\t\t\t} }\n\t\t\t\t\tlabel={ __( 'Search for blocks and patterns' ) }\n\t\t\t\t\tplaceholder={ __( 'Search' ) }\n\t\t\t\t/>\n\t\t\t) }\n\n\t\t\t<div className=\"block-editor-inserter__quick-inserter-results\">\n\t\t\t\t<InserterSearchResults\n\t\t\t\t\tfilterValue={ filterValue }\n\t\t\t\t\tonSelect={ onSelect }\n\t\t\t\t\trootClientId={ rootClientId }\n\t\t\t\t\tclientId={ clientId }\n\t\t\t\t\tisAppender={ isAppender }\n\t\t\t\t\tmaxBlockPatterns={ showPatterns ? SHOWN_BLOCK_PATTERNS : 0 }\n\t\t\t\t\tmaxBlockTypes={ SHOWN_BLOCK_TYPES }\n\t\t\t\t\tisDraggable={ false }\n\t\t\t\t/>\n\t\t\t</div>\n\n\t\t\t{ setInserterIsOpened && (\n\t\t\t\t<Button\n\t\t\t\t\tclassName=\"block-editor-inserter__quick-inserter-expand\"\n\t\t\t\t\tonClick={ onBrowseAll }\n\t\t\t\t\taria-label={ __(\n\t\t\t\t\t\t'Browse all. This will open the main inserter panel in the editor toolbar.'\n\t\t\t\t\t) }\n\t\t\t\t>\n\t\t\t\t\t{ __( 'Browse all' ) }\n\t\t\t\t</Button>\n\t\t\t) }\n\t\t</div>\n\t);\n}\n"]}
@@ -15,6 +15,8 @@ var _blockTypesList = _interopRequireDefault(require("../block-types-list"));
15
15
 
16
16
  var _store = require("../../store");
17
17
 
18
+ var _utils = require("./utils");
19
+
18
20
  /**
19
21
  * WordPress dependencies
20
22
  */
@@ -22,8 +24,6 @@ var _store = require("../../store");
22
24
  /**
23
25
  * Internal dependencies
24
26
  */
25
- const REUSABLE_BLOCKS_CATEGORY = 'reusable';
26
-
27
27
  function ReusableBlocksTab({
28
28
  onSelect,
29
29
  rootClientId,
@@ -36,11 +36,10 @@ function ReusableBlocksTab({
36
36
  getInserterItems
37
37
  } = select(_store.store);
38
38
  const allItems = getInserterItems(rootClientId);
39
- const reusableBlockItems = allItems.filter(({
40
- category
41
- }) => category === REUSABLE_BLOCKS_CATEGORY);
42
39
  return {
43
- items: reusableBlockItems
40
+ items: (0, _utils.filterInserterItems)(allItems, {
41
+ onlyReusable: true
42
+ })
44
43
  };
45
44
  }, [rootClientId]);
46
45
  return (0, _element.createElement)(_blockTypesList.default, {
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/block-editor/src/components/inserter/reusable-blocks-tab.native.js"],"names":["REUSABLE_BLOCKS_CATEGORY","ReusableBlocksTab","onSelect","rootClientId","listProps","items","select","getInserterItems","blockEditorStore","allItems","reusableBlockItems","filter","category"],"mappings":";;;;;;;;;;;AAGA;;AAKA;;AACA;;AATA;AACA;AACA;;AAGA;AACA;AACA;AAIA,MAAMA,wBAAwB,GAAG,UAAjC;;AAEA,SAASC,iBAAT,CAA4B;AAAEC,EAAAA,QAAF;AAAYC,EAAAA,YAAZ;AAA0BC,EAAAA;AAA1B,CAA5B,EAAoE;AACnE,QAAM;AAAEC,IAAAA;AAAF,MAAY,qBACfC,MAAF,IAAc;AACb,UAAM;AAAEC,MAAAA;AAAF,QAAuBD,MAAM,CAAEE,YAAF,CAAnC;AACA,UAAMC,QAAQ,GAAGF,gBAAgB,CAAEJ,YAAF,CAAjC;AACA,UAAMO,kBAAkB,GAAGD,QAAQ,CAACE,MAAT,CAC1B,CAAE;AAAEC,MAAAA;AAAF,KAAF,KAAoBA,QAAQ,KAAKZ,wBADP,CAA3B;AAIA,WAAO;AAAEK,MAAAA,KAAK,EAAEK;AAAT,KAAP;AACA,GATgB,EAUjB,CAAEP,YAAF,CAViB,CAAlB;AAaA,SACC,4BAAC,uBAAD;AACC,IAAA,IAAI,EAAC,gBADN;AAEC,IAAA,KAAK,EAAGE,KAFT;AAGC,IAAA,QAAQ,EAAGH,QAHZ;AAIC,IAAA,SAAS,EAAGE;AAJb,IADD;AAQA;;eAEcH,iB","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { useSelect } from '@wordpress/data';\n\n/**\n * Internal dependencies\n */\nimport BlockTypesList from '../block-types-list';\nimport { store as blockEditorStore } from '../../store';\n\nconst REUSABLE_BLOCKS_CATEGORY = 'reusable';\n\nfunction ReusableBlocksTab( { onSelect, rootClientId, listProps } ) {\n\tconst { items } = useSelect(\n\t\t( select ) => {\n\t\t\tconst { getInserterItems } = select( blockEditorStore );\n\t\t\tconst allItems = getInserterItems( rootClientId );\n\t\t\tconst reusableBlockItems = allItems.filter(\n\t\t\t\t( { category } ) => category === REUSABLE_BLOCKS_CATEGORY\n\t\t\t);\n\n\t\t\treturn { items: reusableBlockItems };\n\t\t},\n\t\t[ rootClientId ]\n\t);\n\n\treturn (\n\t\t<BlockTypesList\n\t\t\tname=\"ReusableBlocks\"\n\t\t\titems={ items }\n\t\t\tonSelect={ onSelect }\n\t\t\tlistProps={ listProps }\n\t\t/>\n\t);\n}\n\nexport default ReusableBlocksTab;\n"]}
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/inserter/reusable-blocks-tab.native.js"],"names":["ReusableBlocksTab","onSelect","rootClientId","listProps","items","select","getInserterItems","blockEditorStore","allItems","onlyReusable"],"mappings":";;;;;;;;;;;AAGA;;AAKA;;AACA;;AACA;;AAVA;AACA;AACA;;AAGA;AACA;AACA;AAKA,SAASA,iBAAT,CAA4B;AAAEC,EAAAA,QAAF;AAAYC,EAAAA,YAAZ;AAA0BC,EAAAA;AAA1B,CAA5B,EAAoE;AACnE,QAAM;AAAEC,IAAAA;AAAF,MAAY,qBACfC,MAAF,IAAc;AACb,UAAM;AAAEC,MAAAA;AAAF,QAAuBD,MAAM,CAAEE,YAAF,CAAnC;AACA,UAAMC,QAAQ,GAAGF,gBAAgB,CAAEJ,YAAF,CAAjC;AAEA,WAAO;AACNE,MAAAA,KAAK,EAAE,gCAAqBI,QAArB,EAA+B;AAAEC,QAAAA,YAAY,EAAE;AAAhB,OAA/B;AADD,KAAP;AAGA,GARgB,EASjB,CAAEP,YAAF,CATiB,CAAlB;AAYA,SACC,4BAAC,uBAAD;AACC,IAAA,IAAI,EAAC,gBADN;AAEC,IAAA,KAAK,EAAGE,KAFT;AAGC,IAAA,QAAQ,EAAGH,QAHZ;AAIC,IAAA,SAAS,EAAGE;AAJb,IADD;AAQA;;eAEcH,iB","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { useSelect } from '@wordpress/data';\n\n/**\n * Internal dependencies\n */\nimport BlockTypesList from '../block-types-list';\nimport { store as blockEditorStore } from '../../store';\nimport { filterInserterItems } from './utils';\n\nfunction ReusableBlocksTab( { onSelect, rootClientId, listProps } ) {\n\tconst { items } = useSelect(\n\t\t( select ) => {\n\t\t\tconst { getInserterItems } = select( blockEditorStore );\n\t\t\tconst allItems = getInserterItems( rootClientId );\n\n\t\t\treturn {\n\t\t\t\titems: filterInserterItems( allItems, { onlyReusable: true } ),\n\t\t\t};\n\t\t},\n\t\t[ rootClientId ]\n\t);\n\n\treturn (\n\t\t<BlockTypesList\n\t\t\tname=\"ReusableBlocks\"\n\t\t\titems={ items }\n\t\t\tonSelect={ onSelect }\n\t\t\tlistProps={ listProps }\n\t\t/>\n\t);\n}\n\nexport default ReusableBlocksTab;\n"]}
@@ -21,6 +21,8 @@ var _store = require("../../store");
21
21
 
22
22
  var _useBlockTypeImpressions = _interopRequireDefault(require("./hooks/use-block-type-impressions"));
23
23
 
24
+ var _utils = require("./utils");
25
+
24
26
  /**
25
27
  * WordPress dependencies
26
28
  */
@@ -32,13 +34,17 @@ function InserterSearchResults({
32
34
  filterValue,
33
35
  onSelect,
34
36
  listProps,
35
- rootClientId
37
+ rootClientId,
38
+ isFullScreen
36
39
  }) {
37
40
  const {
38
41
  blockTypes
39
42
  } = (0, _data.useSelect)(select => {
40
43
  const allItems = select(_store.store).getInserterItems(rootClientId);
41
- const filteredItems = (0, _searchItems.searchItems)(allItems, filterValue);
44
+ const availableItems = (0, _utils.filterInserterItems)(allItems, {
45
+ allowReusable: true
46
+ });
47
+ const filteredItems = (0, _searchItems.searchItems)(availableItems, filterValue);
42
48
  return {
43
49
  blockTypes: filteredItems
44
50
  };
@@ -59,6 +65,7 @@ function InserterSearchResults({
59
65
 
60
66
  return (0, _element.createElement)(_blockTypesList.default, {
61
67
  name: "Blocks",
68
+ initialNumToRender: isFullScreen ? 10 : 3,
62
69
  items,
63
70
  onSelect: handleSelect,
64
71
  listProps
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/block-editor/src/components/inserter/search-results.native.js"],"names":["InserterSearchResults","filterValue","onSelect","listProps","rootClientId","blockTypes","select","allItems","blockEditorStore","getInserterItems","filteredItems","items","trackBlockTypeSelected","length","handleSelect","args"],"mappings":";;;;;;;;;;;AAGA;;AAKA;;AACA;;AACA;;AACA;;AACA;;AAZA;AACA;AACA;;AAGA;AACA;AACA;AAOA,SAASA,qBAAT,CAAgC;AAC/BC,EAAAA,WAD+B;AAE/BC,EAAAA,QAF+B;AAG/BC,EAAAA,SAH+B;AAI/BC,EAAAA;AAJ+B,CAAhC,EAKI;AACH,QAAM;AAAEC,IAAAA;AAAF,MAAiB,qBACpBC,MAAF,IAAc;AACb,UAAMC,QAAQ,GAAGD,MAAM,CAAEE,YAAF,CAAN,CAA2BC,gBAA3B,CAChBL,YADgB,CAAjB;AAGA,UAAMM,aAAa,GAAG,8BAAaH,QAAb,EAAuBN,WAAvB,CAAtB;AAEA,WAAO;AAAEI,MAAAA,UAAU,EAAEK;AAAd,KAAP;AACA,GARqB,EAStB,CAAEN,YAAF,EAAgBH,WAAhB,CATsB,CAAvB;AAYA,QAAM;AAAEU,IAAAA,KAAF;AAASC,IAAAA;AAAT,MAAoC,sCACzCP,UADyC,CAA1C;;AAIA,MAAK,CAAEM,KAAF,IAAW,CAAAA,KAAK,SAAL,IAAAA,KAAK,WAAL,YAAAA,KAAK,CAAEE,MAAP,MAAkB,CAAlC,EAAsC;AACrC,WAAO,4BAAC,kBAAD,OAAP;AACA;;AAED,QAAMC,YAAY,GAAG,CAAE,GAAGC,IAAL,KAAe;AACnCH,IAAAA,sBAAsB,CAAE,GAAGG,IAAL,CAAtB;AACAb,IAAAA,QAAQ,CAAE,GAAGa,IAAL,CAAR;AACA,GAHD;;AAKA,SACC,4BAAC,uBAAD;AACC,IAAA,IAAI,EAAC,QADN;AAEQJ,IAAAA,KAFR;AAEeT,IAAAA,QAAQ,EAAEY,YAFzB;AAEuCX,IAAAA;AAFvC,IADD;AAMA;;eAEcH,qB","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { useSelect } from '@wordpress/data';\n\n/**\n * Internal dependencies\n */\nimport { searchItems } from './search-items';\nimport BlockTypesList from '../block-types-list';\nimport InserterNoResults from './no-results';\nimport { store as blockEditorStore } from '../../store';\nimport useBlockTypeImpressions from './hooks/use-block-type-impressions';\n\nfunction InserterSearchResults( {\n\tfilterValue,\n\tonSelect,\n\tlistProps,\n\trootClientId,\n} ) {\n\tconst { blockTypes } = useSelect(\n\t\t( select ) => {\n\t\t\tconst allItems = select( blockEditorStore ).getInserterItems(\n\t\t\t\trootClientId\n\t\t\t);\n\t\t\tconst filteredItems = searchItems( allItems, filterValue );\n\n\t\t\treturn { blockTypes: filteredItems };\n\t\t},\n\t\t[ rootClientId, filterValue ]\n\t);\n\n\tconst { items, trackBlockTypeSelected } = useBlockTypeImpressions(\n\t\tblockTypes\n\t);\n\n\tif ( ! items || items?.length === 0 ) {\n\t\treturn <InserterNoResults />;\n\t}\n\n\tconst handleSelect = ( ...args ) => {\n\t\ttrackBlockTypeSelected( ...args );\n\t\tonSelect( ...args );\n\t};\n\n\treturn (\n\t\t<BlockTypesList\n\t\t\tname=\"Blocks\"\n\t\t\t{ ...{ items, onSelect: handleSelect, listProps } }\n\t\t/>\n\t);\n}\n\nexport default InserterSearchResults;\n"]}
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/inserter/search-results.native.js"],"names":["InserterSearchResults","filterValue","onSelect","listProps","rootClientId","isFullScreen","blockTypes","select","allItems","blockEditorStore","getInserterItems","availableItems","allowReusable","filteredItems","items","trackBlockTypeSelected","length","handleSelect","args"],"mappings":";;;;;;;;;;;AAGA;;AAKA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAbA;AACA;AACA;;AAGA;AACA;AACA;AAQA,SAASA,qBAAT,CAAgC;AAC/BC,EAAAA,WAD+B;AAE/BC,EAAAA,QAF+B;AAG/BC,EAAAA,SAH+B;AAI/BC,EAAAA,YAJ+B;AAK/BC,EAAAA;AAL+B,CAAhC,EAMI;AACH,QAAM;AAAEC,IAAAA;AAAF,MAAiB,qBACpBC,MAAF,IAAc;AACb,UAAMC,QAAQ,GAAGD,MAAM,CAAEE,YAAF,CAAN,CAA2BC,gBAA3B,CAChBN,YADgB,CAAjB;AAIA,UAAMO,cAAc,GAAG,gCAAqBH,QAArB,EAA+B;AACrDI,MAAAA,aAAa,EAAE;AADsC,KAA/B,CAAvB;AAGA,UAAMC,aAAa,GAAG,8BAAaF,cAAb,EAA6BV,WAA7B,CAAtB;AAEA,WAAO;AAAEK,MAAAA,UAAU,EAAEO;AAAd,KAAP;AACA,GAZqB,EAatB,CAAET,YAAF,EAAgBH,WAAhB,CAbsB,CAAvB;AAgBA,QAAM;AAAEa,IAAAA,KAAF;AAASC,IAAAA;AAAT,MAAoC,sCACzCT,UADyC,CAA1C;;AAIA,MAAK,CAAEQ,KAAF,IAAW,CAAAA,KAAK,SAAL,IAAAA,KAAK,WAAL,YAAAA,KAAK,CAAEE,MAAP,MAAkB,CAAlC,EAAsC;AACrC,WAAO,4BAAC,kBAAD,OAAP;AACA;;AAED,QAAMC,YAAY,GAAG,CAAE,GAAGC,IAAL,KAAe;AACnCH,IAAAA,sBAAsB,CAAE,GAAGG,IAAL,CAAtB;AACAhB,IAAAA,QAAQ,CAAE,GAAGgB,IAAL,CAAR;AACA,GAHD;;AAKA,SACC,4BAAC,uBAAD;AACC,IAAA,IAAI,EAAC,QADN;AAEC,IAAA,kBAAkB,EAAGb,YAAY,GAAG,EAAH,GAAQ,CAF1C;AAGQS,IAAAA,KAHR;AAGeZ,IAAAA,QAAQ,EAAEe,YAHzB;AAGuCd,IAAAA;AAHvC,IADD;AAOA;;eAEcH,qB","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { useSelect } from '@wordpress/data';\n\n/**\n * Internal dependencies\n */\nimport { searchItems } from './search-items';\nimport BlockTypesList from '../block-types-list';\nimport InserterNoResults from './no-results';\nimport { store as blockEditorStore } from '../../store';\nimport useBlockTypeImpressions from './hooks/use-block-type-impressions';\nimport { filterInserterItems } from './utils';\n\nfunction InserterSearchResults( {\n\tfilterValue,\n\tonSelect,\n\tlistProps,\n\trootClientId,\n\tisFullScreen,\n} ) {\n\tconst { blockTypes } = useSelect(\n\t\t( select ) => {\n\t\t\tconst allItems = select( blockEditorStore ).getInserterItems(\n\t\t\t\trootClientId\n\t\t\t);\n\n\t\t\tconst availableItems = filterInserterItems( allItems, {\n\t\t\t\tallowReusable: true,\n\t\t\t} );\n\t\t\tconst filteredItems = searchItems( availableItems, filterValue );\n\n\t\t\treturn { blockTypes: filteredItems };\n\t\t},\n\t\t[ rootClientId, filterValue ]\n\t);\n\n\tconst { items, trackBlockTypeSelected } = useBlockTypeImpressions(\n\t\tblockTypes\n\t);\n\n\tif ( ! items || items?.length === 0 ) {\n\t\treturn <InserterNoResults />;\n\t}\n\n\tconst handleSelect = ( ...args ) => {\n\t\ttrackBlockTypeSelected( ...args );\n\t\tonSelect( ...args );\n\t};\n\n\treturn (\n\t\t<BlockTypesList\n\t\t\tname=\"Blocks\"\n\t\t\tinitialNumToRender={ isFullScreen ? 10 : 3 }\n\t\t\t{ ...{ items, onSelect: handleSelect, listProps } }\n\t\t/>\n\t);\n}\n\nexport default InserterSearchResults;\n"]}
@@ -101,10 +101,7 @@ function InserterTabs({
101
101
  }, tabs.map(({
102
102
  component: TabComponent
103
103
  }, index) => (0, _element.createElement)(_reactNative.View, {
104
- key: `tab-${index}`,
105
- style: [_style.default['inserter-tabs__item'], {
106
- left: index * wrapperWidth
107
- }]
104
+ key: `tab-${index}`
108
105
  }, (0, _element.createElement)(TabComponent, {
109
106
  rootClientId: rootClientId,
110
107
  onSelect: onSelect,
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/block-editor/src/components/inserter/tabs.native.js"],"names":["TAB_ANIMATION_DURATION","InserterTabs","listProps","onSelect","rootClientId","showReusableBlocks","tabIndex","tabAnimation","Animated","Value","current","lastScrollEvents","wrapperWidth","setWrapperWidth","onScroll","event","nativeEvent","onWrapperLayout","layout","width","timing","duration","toValue","useNativeDriver","start","lastScrollEvent","tabs","tabKeys","filteredTabs","TABS","filter","name","keys","translateX","length","interpolate","inputRange","outputRange","map","key","containerStyle","styles","transform","component","TabComponent","index","left","TabsControl","onChangeTab","segments","title","segmentHandler","selectedTab","tabTitles","indexOf","Control","BlockTypesTab","ReusableBlocksTab"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport { Animated, View } from 'react-native';\n\n/**\n * WordPress dependencies\n */\nimport {\n\tuseCallback,\n\tuseEffect,\n\tuseMemo,\n\tuseRef,\n\tuseState,\n} from '@wordpress/element';\nimport { __ } from '@wordpress/i18n';\nimport { SegmentedControl } from '@wordpress/components';\n\n/**\n * Internal dependencies\n */\nimport BlockTypesTab from './block-types-tab';\nimport ReusableBlocksTab from './reusable-blocks-tab';\nimport styles from './style.scss';\n\nconst TAB_ANIMATION_DURATION = 250;\n\nfunction InserterTabs( {\n\tlistProps,\n\tonSelect,\n\trootClientId,\n\tshowReusableBlocks,\n\ttabIndex,\n} ) {\n\tconst tabAnimation = useRef( new Animated.Value( 0 ) ).current;\n\tconst lastScrollEvents = useRef( [] ).current;\n\tconst [ wrapperWidth, setWrapperWidth ] = useState( 0 );\n\n\tfunction onScroll( event ) {\n\t\tlastScrollEvents[ tabIndex ] = event.nativeEvent;\n\t\tlistProps.onScroll( event );\n\t}\n\n\tconst onWrapperLayout = useCallback(\n\t\t( { nativeEvent } ) => {\n\t\t\tsetWrapperWidth( nativeEvent.layout.width );\n\t\t},\n\t\t[ setWrapperWidth ]\n\t);\n\n\tuseEffect( () => {\n\t\tAnimated.timing( tabAnimation, {\n\t\t\tduration: TAB_ANIMATION_DURATION,\n\t\t\ttoValue: tabIndex,\n\t\t\tuseNativeDriver: true,\n\t\t} ).start();\n\n\t\t// Notify upstream with the last scroll event of the current tab.\n\t\tconst lastScrollEvent = lastScrollEvents[ tabIndex ];\n\t\tif ( lastScrollEvent ) {\n\t\t\tlistProps.onScroll( { nativeEvent: lastScrollEvent } );\n\t\t}\n\t}, [ tabIndex ] );\n\n\tconst { tabs, tabKeys } = useMemo( () => {\n\t\tconst filteredTabs = InserterTabs.TABS.filter(\n\t\t\t( { name } ) => showReusableBlocks || name !== 'reusable'\n\t\t);\n\t\treturn {\n\t\t\ttabs: filteredTabs,\n\t\t\ttabKeys: [ ...filteredTabs.keys() ],\n\t\t};\n\t}, [ showReusableBlocks ] );\n\n\tconst translateX = useMemo(\n\t\t() =>\n\t\t\ttabKeys.length > 1\n\t\t\t\t? tabAnimation.interpolate( {\n\t\t\t\t\t\tinputRange: tabKeys,\n\t\t\t\t\t\toutputRange: tabKeys.map(\n\t\t\t\t\t\t\t( key ) => key * -wrapperWidth\n\t\t\t\t\t\t),\n\t\t\t\t } )\n\t\t\t\t: tabAnimation,\n\t\t[ tabAnimation, tabKeys, wrapperWidth ]\n\t);\n\n\tconst containerStyle = [\n\t\tstyles[ 'inserter-tabs__container' ],\n\t\t{\n\t\t\twidth: wrapperWidth * tabKeys.length,\n\t\t\ttransform: [ { translateX } ],\n\t\t},\n\t];\n\n\treturn (\n\t\t<View\n\t\t\tstyle={ styles[ 'inserter-tabs__wrapper' ] }\n\t\t\tonLayout={ onWrapperLayout }\n\t\t>\n\t\t\t<Animated.View style={ containerStyle }>\n\t\t\t\t{ tabs.map( ( { component: TabComponent }, index ) => (\n\t\t\t\t\t<View\n\t\t\t\t\t\tkey={ `tab-${ index }` }\n\t\t\t\t\t\tstyle={ [\n\t\t\t\t\t\t\tstyles[ 'inserter-tabs__item' ],\n\t\t\t\t\t\t\t{ left: index * wrapperWidth },\n\t\t\t\t\t\t] }\n\t\t\t\t\t>\n\t\t\t\t\t\t<TabComponent\n\t\t\t\t\t\t\trootClientId={ rootClientId }\n\t\t\t\t\t\t\tonSelect={ onSelect }\n\t\t\t\t\t\t\tlistProps={ { ...listProps, onScroll } }\n\t\t\t\t\t\t/>\n\t\t\t\t\t</View>\n\t\t\t\t) ) }\n\t\t\t</Animated.View>\n\t\t</View>\n\t);\n}\n\nfunction TabsControl( { onChangeTab, showReusableBlocks } ) {\n\tconst segments = useMemo( () => {\n\t\tconst filteredTabs = InserterTabs.TABS.filter(\n\t\t\t( { name } ) => showReusableBlocks || name !== 'reusable'\n\t\t);\n\t\treturn filteredTabs.map( ( { title } ) => title );\n\t}, [ showReusableBlocks ] );\n\n\tconst segmentHandler = useCallback(\n\t\t( selectedTab ) => {\n\t\t\tconst tabTitles = InserterTabs.TABS.map( ( { title } ) => title );\n\t\t\tonChangeTab( tabTitles.indexOf( selectedTab ) );\n\t\t},\n\t\t[ onChangeTab ]\n\t);\n\n\treturn segments.length > 1 ? (\n\t\t<SegmentedControl\n\t\t\tsegments={ segments }\n\t\t\tsegmentHandler={ segmentHandler }\n\t\t/>\n\t) : null;\n}\n\nInserterTabs.Control = TabsControl;\n\nInserterTabs.TABS = [\n\t{ name: 'blocks', title: __( 'Blocks' ), component: BlockTypesTab },\n\t{ name: 'reusable', title: __( 'Reusable' ), component: ReusableBlocksTab },\n];\n\nexport default InserterTabs;\n"]}
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/inserter/tabs.native.js"],"names":["TAB_ANIMATION_DURATION","InserterTabs","listProps","onSelect","rootClientId","showReusableBlocks","tabIndex","tabAnimation","Animated","Value","current","lastScrollEvents","wrapperWidth","setWrapperWidth","onScroll","event","nativeEvent","onWrapperLayout","layout","width","timing","duration","toValue","useNativeDriver","start","lastScrollEvent","tabs","tabKeys","filteredTabs","TABS","filter","name","keys","translateX","length","interpolate","inputRange","outputRange","map","key","containerStyle","styles","transform","component","TabComponent","index","TabsControl","onChangeTab","segments","title","segmentHandler","selectedTab","tabTitles","indexOf","Control","BlockTypesTab","ReusableBlocksTab"],"mappings":";;;;;;;;;AAQA;;AALA;;AAYA;;AACA;;AAKA;;AACA;;AACA;;AAvBA;AACA;AACA;;AAGA;AACA;AACA;;AAWA;AACA;AACA;AAKA,MAAMA,sBAAsB,GAAG,GAA/B;;AAEA,SAASC,YAAT,CAAuB;AACtBC,EAAAA,SADsB;AAEtBC,EAAAA,QAFsB;AAGtBC,EAAAA,YAHsB;AAItBC,EAAAA,kBAJsB;AAKtBC,EAAAA;AALsB,CAAvB,EAMI;AACH,QAAMC,YAAY,GAAG,qBAAQ,IAAIC,sBAASC,KAAb,CAAoB,CAApB,CAAR,EAAkCC,OAAvD;AACA,QAAMC,gBAAgB,GAAG,qBAAQ,EAAR,EAAaD,OAAtC;AACA,QAAM,CAAEE,YAAF,EAAgBC,eAAhB,IAAoC,uBAAU,CAAV,CAA1C;;AAEA,WAASC,QAAT,CAAmBC,KAAnB,EAA2B;AAC1BJ,IAAAA,gBAAgB,CAAEL,QAAF,CAAhB,GAA+BS,KAAK,CAACC,WAArC;AACAd,IAAAA,SAAS,CAACY,QAAV,CAAoBC,KAApB;AACA;;AAED,QAAME,eAAe,GAAG,0BACvB,CAAE;AAAED,IAAAA;AAAF,GAAF,KAAuB;AACtBH,IAAAA,eAAe,CAAEG,WAAW,CAACE,MAAZ,CAAmBC,KAArB,CAAf;AACA,GAHsB,EAIvB,CAAEN,eAAF,CAJuB,CAAxB;AAOA,0BAAW,MAAM;AAChBL,0BAASY,MAAT,CAAiBb,YAAjB,EAA+B;AAC9Bc,MAAAA,QAAQ,EAAErB,sBADoB;AAE9BsB,MAAAA,OAAO,EAAEhB,QAFqB;AAG9BiB,MAAAA,eAAe,EAAE;AAHa,KAA/B,EAIIC,KAJJ,GADgB,CAOhB;;;AACA,UAAMC,eAAe,GAAGd,gBAAgB,CAAEL,QAAF,CAAxC;;AACA,QAAKmB,eAAL,EAAuB;AACtBvB,MAAAA,SAAS,CAACY,QAAV,CAAoB;AAAEE,QAAAA,WAAW,EAAES;AAAf,OAApB;AACA;AACD,GAZD,EAYG,CAAEnB,QAAF,CAZH;AAcA,QAAM;AAAEoB,IAAAA,IAAF;AAAQC,IAAAA;AAAR,MAAoB,sBAAS,MAAM;AACxC,UAAMC,YAAY,GAAG3B,YAAY,CAAC4B,IAAb,CAAkBC,MAAlB,CACpB,CAAE;AAAEC,MAAAA;AAAF,KAAF,KAAgB1B,kBAAkB,IAAI0B,IAAI,KAAK,UAD3B,CAArB;AAGA,WAAO;AACNL,MAAAA,IAAI,EAAEE,YADA;AAEND,MAAAA,OAAO,EAAE,CAAE,GAAGC,YAAY,CAACI,IAAb,EAAL;AAFH,KAAP;AAIA,GARyB,EAQvB,CAAE3B,kBAAF,CARuB,CAA1B;AAUA,QAAM4B,UAAU,GAAG,sBAClB,MACCN,OAAO,CAACO,MAAR,GAAiB,CAAjB,GACG3B,YAAY,CAAC4B,WAAb,CAA0B;AAC1BC,IAAAA,UAAU,EAAET,OADc;AAE1BU,IAAAA,WAAW,EAAEV,OAAO,CAACW,GAAR,CACVC,GAAF,IAAWA,GAAG,GAAG,CAAC3B,YADN;AAFa,GAA1B,CADH,GAOGL,YATc,EAUlB,CAAEA,YAAF,EAAgBoB,OAAhB,EAAyBf,YAAzB,CAVkB,CAAnB;AAaA,QAAM4B,cAAc,GAAG,CACtBC,eAAQ,0BAAR,CADsB,EAEtB;AACCtB,IAAAA,KAAK,EAAEP,YAAY,GAAGe,OAAO,CAACO,MAD/B;AAECQ,IAAAA,SAAS,EAAE,CAAE;AAAET,MAAAA;AAAF,KAAF;AAFZ,GAFsB,CAAvB;AAQA,SACC,4BAAC,iBAAD;AACC,IAAA,KAAK,EAAGQ,eAAQ,wBAAR,CADT;AAEC,IAAA,QAAQ,EAAGxB;AAFZ,KAIC,4BAAC,qBAAD,CAAU,IAAV;AAAe,IAAA,KAAK,EAAGuB;AAAvB,KACGd,IAAI,CAACY,GAAL,CAAU,CAAE;AAAEK,IAAAA,SAAS,EAAEC;AAAb,GAAF,EAA+BC,KAA/B,KACX,4BAAC,iBAAD;AAAM,IAAA,GAAG,EAAI,OAAOA,KAAO;AAA3B,KACC,4BAAC,YAAD;AACC,IAAA,YAAY,EAAGzC,YADhB;AAEC,IAAA,QAAQ,EAAGD,QAFZ;AAGC,IAAA,SAAS,EAAG,EAAE,GAAGD,SAAL;AAAgBY,MAAAA;AAAhB;AAHb,IADD,CADC,CADH,CAJD,CADD;AAkBA;;AAED,SAASgC,WAAT,CAAsB;AAAEC,EAAAA,WAAF;AAAe1C,EAAAA;AAAf,CAAtB,EAA4D;AAC3D,QAAM2C,QAAQ,GAAG,sBAAS,MAAM;AAC/B,UAAMpB,YAAY,GAAG3B,YAAY,CAAC4B,IAAb,CAAkBC,MAAlB,CACpB,CAAE;AAAEC,MAAAA;AAAF,KAAF,KAAgB1B,kBAAkB,IAAI0B,IAAI,KAAK,UAD3B,CAArB;AAGA,WAAOH,YAAY,CAACU,GAAb,CAAkB,CAAE;AAAEW,MAAAA;AAAF,KAAF,KAAiBA,KAAnC,CAAP;AACA,GALgB,EAKd,CAAE5C,kBAAF,CALc,CAAjB;AAOA,QAAM6C,cAAc,GAAG,0BACpBC,WAAF,IAAmB;AAClB,UAAMC,SAAS,GAAGnD,YAAY,CAAC4B,IAAb,CAAkBS,GAAlB,CAAuB,CAAE;AAAEW,MAAAA;AAAF,KAAF,KAAiBA,KAAxC,CAAlB;AACAF,IAAAA,WAAW,CAAEK,SAAS,CAACC,OAAV,CAAmBF,WAAnB,CAAF,CAAX;AACA,GAJqB,EAKtB,CAAEJ,WAAF,CALsB,CAAvB;AAQA,SAAOC,QAAQ,CAACd,MAAT,GAAkB,CAAlB,GACN,4BAAC,4BAAD;AACC,IAAA,QAAQ,EAAGc,QADZ;AAEC,IAAA,cAAc,EAAGE;AAFlB,IADM,GAKH,IALJ;AAMA;;AAEDjD,YAAY,CAACqD,OAAb,GAAuBR,WAAvB;AAEA7C,YAAY,CAAC4B,IAAb,GAAoB,CACnB;AAAEE,EAAAA,IAAI,EAAE,QAAR;AAAkBkB,EAAAA,KAAK,EAAE,cAAI,QAAJ,CAAzB;AAAyCN,EAAAA,SAAS,EAAEY;AAApD,CADmB,EAEnB;AAAExB,EAAAA,IAAI,EAAE,UAAR;AAAoBkB,EAAAA,KAAK,EAAE,cAAI,UAAJ,CAA3B;AAA6CN,EAAAA,SAAS,EAAEa;AAAxD,CAFmB,CAApB;eAKevD,Y","sourcesContent":["/**\n * External dependencies\n */\nimport { Animated, View } from 'react-native';\n\n/**\n * WordPress dependencies\n */\nimport {\n\tuseCallback,\n\tuseEffect,\n\tuseMemo,\n\tuseRef,\n\tuseState,\n} from '@wordpress/element';\nimport { __ } from '@wordpress/i18n';\nimport { SegmentedControl } from '@wordpress/components';\n\n/**\n * Internal dependencies\n */\nimport BlockTypesTab from './block-types-tab';\nimport ReusableBlocksTab from './reusable-blocks-tab';\nimport styles from './style.scss';\n\nconst TAB_ANIMATION_DURATION = 250;\n\nfunction InserterTabs( {\n\tlistProps,\n\tonSelect,\n\trootClientId,\n\tshowReusableBlocks,\n\ttabIndex,\n} ) {\n\tconst tabAnimation = useRef( new Animated.Value( 0 ) ).current;\n\tconst lastScrollEvents = useRef( [] ).current;\n\tconst [ wrapperWidth, setWrapperWidth ] = useState( 0 );\n\n\tfunction onScroll( event ) {\n\t\tlastScrollEvents[ tabIndex ] = event.nativeEvent;\n\t\tlistProps.onScroll( event );\n\t}\n\n\tconst onWrapperLayout = useCallback(\n\t\t( { nativeEvent } ) => {\n\t\t\tsetWrapperWidth( nativeEvent.layout.width );\n\t\t},\n\t\t[ setWrapperWidth ]\n\t);\n\n\tuseEffect( () => {\n\t\tAnimated.timing( tabAnimation, {\n\t\t\tduration: TAB_ANIMATION_DURATION,\n\t\t\ttoValue: tabIndex,\n\t\t\tuseNativeDriver: true,\n\t\t} ).start();\n\n\t\t// Notify upstream with the last scroll event of the current tab.\n\t\tconst lastScrollEvent = lastScrollEvents[ tabIndex ];\n\t\tif ( lastScrollEvent ) {\n\t\t\tlistProps.onScroll( { nativeEvent: lastScrollEvent } );\n\t\t}\n\t}, [ tabIndex ] );\n\n\tconst { tabs, tabKeys } = useMemo( () => {\n\t\tconst filteredTabs = InserterTabs.TABS.filter(\n\t\t\t( { name } ) => showReusableBlocks || name !== 'reusable'\n\t\t);\n\t\treturn {\n\t\t\ttabs: filteredTabs,\n\t\t\ttabKeys: [ ...filteredTabs.keys() ],\n\t\t};\n\t}, [ showReusableBlocks ] );\n\n\tconst translateX = useMemo(\n\t\t() =>\n\t\t\ttabKeys.length > 1\n\t\t\t\t? tabAnimation.interpolate( {\n\t\t\t\t\t\tinputRange: tabKeys,\n\t\t\t\t\t\toutputRange: tabKeys.map(\n\t\t\t\t\t\t\t( key ) => key * -wrapperWidth\n\t\t\t\t\t\t),\n\t\t\t\t } )\n\t\t\t\t: tabAnimation,\n\t\t[ tabAnimation, tabKeys, wrapperWidth ]\n\t);\n\n\tconst containerStyle = [\n\t\tstyles[ 'inserter-tabs__container' ],\n\t\t{\n\t\t\twidth: wrapperWidth * tabKeys.length,\n\t\t\ttransform: [ { translateX } ],\n\t\t},\n\t];\n\n\treturn (\n\t\t<View\n\t\t\tstyle={ styles[ 'inserter-tabs__wrapper' ] }\n\t\t\tonLayout={ onWrapperLayout }\n\t\t>\n\t\t\t<Animated.View style={ containerStyle }>\n\t\t\t\t{ tabs.map( ( { component: TabComponent }, index ) => (\n\t\t\t\t\t<View key={ `tab-${ index }` }>\n\t\t\t\t\t\t<TabComponent\n\t\t\t\t\t\t\trootClientId={ rootClientId }\n\t\t\t\t\t\t\tonSelect={ onSelect }\n\t\t\t\t\t\t\tlistProps={ { ...listProps, onScroll } }\n\t\t\t\t\t\t/>\n\t\t\t\t\t</View>\n\t\t\t\t) ) }\n\t\t\t</Animated.View>\n\t\t</View>\n\t);\n}\n\nfunction TabsControl( { onChangeTab, showReusableBlocks } ) {\n\tconst segments = useMemo( () => {\n\t\tconst filteredTabs = InserterTabs.TABS.filter(\n\t\t\t( { name } ) => showReusableBlocks || name !== 'reusable'\n\t\t);\n\t\treturn filteredTabs.map( ( { title } ) => title );\n\t}, [ showReusableBlocks ] );\n\n\tconst segmentHandler = useCallback(\n\t\t( selectedTab ) => {\n\t\t\tconst tabTitles = InserterTabs.TABS.map( ( { title } ) => title );\n\t\t\tonChangeTab( tabTitles.indexOf( selectedTab ) );\n\t\t},\n\t\t[ onChangeTab ]\n\t);\n\n\treturn segments.length > 1 ? (\n\t\t<SegmentedControl\n\t\t\tsegments={ segments }\n\t\t\tsegmentHandler={ segmentHandler }\n\t\t/>\n\t) : null;\n}\n\nInserterTabs.Control = TabsControl;\n\nInserterTabs.TABS = [\n\t{ name: 'blocks', title: __( 'Blocks' ), component: BlockTypesTab },\n\t{ name: 'reusable', title: __( 'Reusable' ), component: ReusableBlocksTab },\n];\n\nexport default InserterTabs;\n"]}
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.blockAllowed = blockAllowed;
7
+ exports.filterInserterItems = filterInserterItems;
8
+ const REUSABLE_BLOCKS_CATEGORY = 'reusable';
9
+ const ALLOWED_EMBED_VARIATIONS = ['core/embed', 'core/embed/youtube', 'core/embed/twitter', 'core/embed/wordpress', 'core/embed/instagram', 'core/embed/vimeo'];
10
+
11
+ function blockAllowed(block, {
12
+ onlyReusable,
13
+ allowReusable
14
+ }) {
15
+ const {
16
+ id,
17
+ category
18
+ } = block;
19
+ const isReusable = category === REUSABLE_BLOCKS_CATEGORY;
20
+
21
+ if (onlyReusable) {
22
+ return isReusable;
23
+ }
24
+
25
+ if (isReusable) {
26
+ return allowReusable;
27
+ } // We don't want to show all possible embed variations
28
+ // as different blocks in the inserter. We'll only show a
29
+ // few popular ones.
30
+
31
+
32
+ return category !== 'embed' || ALLOWED_EMBED_VARIATIONS.includes(id);
33
+ }
34
+
35
+ function filterInserterItems(items, {
36
+ onlyReusable = false,
37
+ allowReusable = false
38
+ } = {}) {
39
+ return items.filter(block => blockAllowed(block, {
40
+ onlyReusable,
41
+ allowReusable
42
+ }));
43
+ }
44
+ //# sourceMappingURL=utils.native.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/inserter/utils.native.js"],"names":["REUSABLE_BLOCKS_CATEGORY","ALLOWED_EMBED_VARIATIONS","blockAllowed","block","onlyReusable","allowReusable","id","category","isReusable","includes","filterInserterItems","items","filter"],"mappings":";;;;;;;AAAA,MAAMA,wBAAwB,GAAG,UAAjC;AACA,MAAMC,wBAAwB,GAAG,CAChC,YADgC,EAEhC,oBAFgC,EAGhC,oBAHgC,EAIhC,sBAJgC,EAKhC,sBALgC,EAMhC,kBANgC,CAAjC;;AASO,SAASC,YAAT,CAAuBC,KAAvB,EAA8B;AAAEC,EAAAA,YAAF;AAAgBC,EAAAA;AAAhB,CAA9B,EAAgE;AACtE,QAAM;AAAEC,IAAAA,EAAF;AAAMC,IAAAA;AAAN,MAAmBJ,KAAzB;AACA,QAAMK,UAAU,GAAGD,QAAQ,KAAKP,wBAAhC;;AAEA,MAAKI,YAAL,EAAoB;AACnB,WAAOI,UAAP;AACA;;AAED,MAAKA,UAAL,EAAkB;AACjB,WAAOH,aAAP;AACA,GAVqE,CAWtE;AACA;AACA;;;AACA,SAAOE,QAAQ,KAAK,OAAb,IAAwBN,wBAAwB,CAACQ,QAAzB,CAAmCH,EAAnC,CAA/B;AACA;;AAEM,SAASI,mBAAT,CACNC,KADM,EAEN;AAAEP,EAAAA,YAAY,GAAG,KAAjB;AAAwBC,EAAAA,aAAa,GAAG;AAAxC,IAAkD,EAF5C,EAGL;AACD,SAAOM,KAAK,CAACC,MAAN,CAAgBT,KAAF,IACpBD,YAAY,CAAEC,KAAF,EAAS;AAAEC,IAAAA,YAAF;AAAgBC,IAAAA;AAAhB,GAAT,CADN,CAAP;AAGA","sourcesContent":["const REUSABLE_BLOCKS_CATEGORY = 'reusable';\nconst ALLOWED_EMBED_VARIATIONS = [\n\t'core/embed',\n\t'core/embed/youtube',\n\t'core/embed/twitter',\n\t'core/embed/wordpress',\n\t'core/embed/instagram',\n\t'core/embed/vimeo',\n];\n\nexport function blockAllowed( block, { onlyReusable, allowReusable } ) {\n\tconst { id, category } = block;\n\tconst isReusable = category === REUSABLE_BLOCKS_CATEGORY;\n\n\tif ( onlyReusable ) {\n\t\treturn isReusable;\n\t}\n\n\tif ( isReusable ) {\n\t\treturn allowReusable;\n\t}\n\t// We don't want to show all possible embed variations\n\t// as different blocks in the inserter. We'll only show a\n\t// few popular ones.\n\treturn category !== 'embed' || ALLOWED_EMBED_VARIATIONS.includes( id );\n}\n\nexport function filterInserterItems(\n\titems,\n\t{ onlyReusable = false, allowReusable = false } = {}\n) {\n\treturn items.filter( ( block ) =>\n\t\tblockAllowed( block, { onlyReusable, allowReusable } )\n\t);\n}\n"]}
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = BlockSupportSlotContainer;
9
+
10
+ var _element = require("@wordpress/element");
11
+
12
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
+
14
+ var _components = require("@wordpress/components");
15
+
16
+ /**
17
+ * WordPress dependencies
18
+ */
19
+ function BlockSupportSlotContainer({
20
+ Slot,
21
+ ...props
22
+ }) {
23
+ const toolsPanelContext = (0, _element.useContext)(_components.__experimentalToolsPanelContext);
24
+ return (0, _element.createElement)(Slot, (0, _extends2.default)({}, props, {
25
+ fillProps: toolsPanelContext
26
+ }));
27
+ }
28
+ //# sourceMappingURL=block-support-slot-container.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/inspector-controls/block-support-slot-container.js"],"names":["BlockSupportSlotContainer","Slot","props","toolsPanelContext","ToolsPanelContext"],"mappings":";;;;;;;;;AAIA;;;;AADA;;AAHA;AACA;AACA;AAIe,SAASA,yBAAT,CAAoC;AAAEC,EAAAA,IAAF;AAAQ,KAAGC;AAAX,CAApC,EAAyD;AACvE,QAAMC,iBAAiB,GAAG,yBAAYC,2CAAZ,CAA1B;AACA,SAAO,4BAAC,IAAD,6BAAWF,KAAX;AAAmB,IAAA,SAAS,EAAGC;AAA/B,KAAP;AACA","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { __experimentalToolsPanelContext as ToolsPanelContext } from '@wordpress/components';\nimport { useContext } from '@wordpress/element';\n\nexport default function BlockSupportSlotContainer( { Slot, ...props } ) {\n\tconst toolsPanelContext = useContext( ToolsPanelContext );\n\treturn <Slot { ...props } fillProps={ toolsPanelContext } />;\n}\n"]}
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = BlockSupportToolsPanel;
7
+
8
+ var _element = require("@wordpress/element");
9
+
10
+ var _components = require("@wordpress/components");
11
+
12
+ var _data = require("@wordpress/data");
13
+
14
+ var _store = require("../../store");
15
+
16
+ var _utils = require("../../hooks/utils");
17
+
18
+ /**
19
+ * WordPress dependencies
20
+ */
21
+
22
+ /**
23
+ * Internal dependencies
24
+ */
25
+ function BlockSupportToolsPanel({
26
+ children,
27
+ group,
28
+ label
29
+ }) {
30
+ const {
31
+ clientId,
32
+ attributes
33
+ } = (0, _data.useSelect)(select => {
34
+ const {
35
+ getBlockAttributes,
36
+ getSelectedBlockClientId
37
+ } = select(_store.store);
38
+ const selectedBlockClientId = getSelectedBlockClientId();
39
+ return {
40
+ clientId: selectedBlockClientId,
41
+ attributes: getBlockAttributes(selectedBlockClientId)
42
+ };
43
+ }, []);
44
+ const {
45
+ updateBlockAttributes
46
+ } = (0, _data.useDispatch)(_store.store);
47
+
48
+ const resetAll = (resetFilters = []) => {
49
+ const {
50
+ style
51
+ } = attributes;
52
+ let newAttributes = {
53
+ style
54
+ };
55
+ resetFilters.forEach(resetFilter => {
56
+ newAttributes = { ...newAttributes,
57
+ ...resetFilter(newAttributes)
58
+ };
59
+ }); // Enforce a cleaned style object.
60
+
61
+ newAttributes = { ...newAttributes,
62
+ style: (0, _utils.cleanEmptyObject)(newAttributes.style)
63
+ };
64
+ updateBlockAttributes(clientId, newAttributes);
65
+ };
66
+
67
+ return (0, _element.createElement)(_components.__experimentalToolsPanel, {
68
+ className: `${group}-block-support-panel`,
69
+ label: label,
70
+ resetAll: resetAll,
71
+ key: clientId,
72
+ panelId: clientId,
73
+ hasInnerWrapper: true,
74
+ shouldRenderPlaceholderItems: true // Required to maintain fills ordering.
75
+
76
+ }, children);
77
+ }
78
+ //# sourceMappingURL=block-support-tools-panel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/inspector-controls/block-support-tools-panel.js"],"names":["BlockSupportToolsPanel","children","group","label","clientId","attributes","select","getBlockAttributes","getSelectedBlockClientId","blockEditorStore","selectedBlockClientId","updateBlockAttributes","resetAll","resetFilters","style","newAttributes","forEach","resetFilter"],"mappings":";;;;;;;;;AAGA;;AACA;;AAKA;;AACA;;AAVA;AACA;AACA;;AAIA;AACA;AACA;AAIe,SAASA,sBAAT,CAAiC;AAAEC,EAAAA,QAAF;AAAYC,EAAAA,KAAZ;AAAmBC,EAAAA;AAAnB,CAAjC,EAA8D;AAC5E,QAAM;AAAEC,IAAAA,QAAF;AAAYC,IAAAA;AAAZ,MAA2B,qBAAaC,MAAF,IAAc;AACzD,UAAM;AAAEC,MAAAA,kBAAF;AAAsBC,MAAAA;AAAtB,QAAmDF,MAAM,CAC9DG,YAD8D,CAA/D;AAGA,UAAMC,qBAAqB,GAAGF,wBAAwB,EAAtD;AAEA,WAAO;AACNJ,MAAAA,QAAQ,EAAEM,qBADJ;AAENL,MAAAA,UAAU,EAAEE,kBAAkB,CAAEG,qBAAF;AAFxB,KAAP;AAIA,GAVgC,EAU9B,EAV8B,CAAjC;AAWA,QAAM;AAAEC,IAAAA;AAAF,MAA4B,uBAAaF,YAAb,CAAlC;;AAEA,QAAMG,QAAQ,GAAG,CAAEC,YAAY,GAAG,EAAjB,KAAyB;AACzC,UAAM;AAAEC,MAAAA;AAAF,QAAYT,UAAlB;AACA,QAAIU,aAAa,GAAG;AAAED,MAAAA;AAAF,KAApB;AAEAD,IAAAA,YAAY,CAACG,OAAb,CAAwBC,WAAF,IAAmB;AACxCF,MAAAA,aAAa,GAAG,EACf,GAAGA,aADY;AAEf,WAAGE,WAAW,CAAEF,aAAF;AAFC,OAAhB;AAIA,KALD,EAJyC,CAWzC;;AACAA,IAAAA,aAAa,GAAG,EACf,GAAGA,aADY;AAEfD,MAAAA,KAAK,EAAE,6BAAkBC,aAAa,CAACD,KAAhC;AAFQ,KAAhB;AAKAH,IAAAA,qBAAqB,CAAEP,QAAF,EAAYW,aAAZ,CAArB;AACA,GAlBD;;AAoBA,SACC,4BAAC,oCAAD;AACC,IAAA,SAAS,EAAI,GAAGb,KAAO,sBADxB;AAEC,IAAA,KAAK,EAAGC,KAFT;AAGC,IAAA,QAAQ,EAAGS,QAHZ;AAIC,IAAA,GAAG,EAAGR,QAJP;AAKC,IAAA,OAAO,EAAGA,QALX;AAMC,IAAA,eAAe,EAAG,IANnB;AAOC,IAAA,4BAA4B,EAAG,IAPhC,CAOuC;;AAPvC,KASGH,QATH,CADD;AAaA","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { __experimentalToolsPanel as ToolsPanel } from '@wordpress/components';\nimport { useDispatch, useSelect } from '@wordpress/data';\n\n/**\n * Internal dependencies\n */\nimport { store as blockEditorStore } from '../../store';\nimport { cleanEmptyObject } from '../../hooks/utils';\n\nexport default function BlockSupportToolsPanel( { children, group, label } ) {\n\tconst { clientId, attributes } = useSelect( ( select ) => {\n\t\tconst { getBlockAttributes, getSelectedBlockClientId } = select(\n\t\t\tblockEditorStore\n\t\t);\n\t\tconst selectedBlockClientId = getSelectedBlockClientId();\n\n\t\treturn {\n\t\t\tclientId: selectedBlockClientId,\n\t\t\tattributes: getBlockAttributes( selectedBlockClientId ),\n\t\t};\n\t}, [] );\n\tconst { updateBlockAttributes } = useDispatch( blockEditorStore );\n\n\tconst resetAll = ( resetFilters = [] ) => {\n\t\tconst { style } = attributes;\n\t\tlet newAttributes = { style };\n\n\t\tresetFilters.forEach( ( resetFilter ) => {\n\t\t\tnewAttributes = {\n\t\t\t\t...newAttributes,\n\t\t\t\t...resetFilter( newAttributes ),\n\t\t\t};\n\t\t} );\n\n\t\t// Enforce a cleaned style object.\n\t\tnewAttributes = {\n\t\t\t...newAttributes,\n\t\t\tstyle: cleanEmptyObject( newAttributes.style ),\n\t\t};\n\n\t\tupdateBlockAttributes( clientId, newAttributes );\n\t};\n\n\treturn (\n\t\t<ToolsPanel\n\t\t\tclassName={ `${ group }-block-support-panel` }\n\t\t\tlabel={ label }\n\t\t\tresetAll={ resetAll }\n\t\t\tkey={ clientId }\n\t\t\tpanelId={ clientId }\n\t\t\thasInnerWrapper={ true }\n\t\t\tshouldRenderPlaceholderItems={ true } // Required to maintain fills ordering.\n\t\t>\n\t\t\t{ children }\n\t\t</ToolsPanel>\n\t);\n}\n"]}
@@ -0,0 +1,64 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = InspectorControlsFill;
9
+
10
+ var _element = require("@wordpress/element");
11
+
12
+ var _lodash = require("lodash");
13
+
14
+ var _components = require("@wordpress/components");
15
+
16
+ var _warning = _interopRequireDefault(require("@wordpress/warning"));
17
+
18
+ var _useDisplayBlockControls = _interopRequireDefault(require("../use-display-block-controls"));
19
+
20
+ var _groups = _interopRequireDefault(require("./groups"));
21
+
22
+ /**
23
+ * External dependencies
24
+ */
25
+
26
+ /**
27
+ * WordPress dependencies
28
+ */
29
+
30
+ /**
31
+ * Internal dependencies
32
+ */
33
+ function InspectorControlsFill({
34
+ __experimentalGroup: group = 'default',
35
+ children
36
+ }) {
37
+ var _groups$group;
38
+
39
+ const isDisplayed = (0, _useDisplayBlockControls.default)();
40
+ const Fill = (_groups$group = _groups.default[group]) === null || _groups$group === void 0 ? void 0 : _groups$group.Fill;
41
+
42
+ if (!Fill) {
43
+ typeof process !== "undefined" && process.env && process.env.NODE_ENV !== "production" ? (0, _warning.default)(`Unknown InspectorControl group "${group}" provided.`) : void 0;
44
+ return null;
45
+ }
46
+
47
+ if (!isDisplayed) {
48
+ return null;
49
+ }
50
+
51
+ return (0, _element.createElement)(_components.__experimentalStyleProvider, {
52
+ document: document
53
+ }, (0, _element.createElement)(Fill, null, fillProps => {
54
+ // Children passed to InspectorControlsFill will not have
55
+ // access to any React Context whose Provider is part of
56
+ // the InspectorControlsSlot tree. So we re-create the
57
+ // Provider in this subtree.
58
+ const value = !(0, _lodash.isEmpty)(fillProps) ? fillProps : null;
59
+ return (0, _element.createElement)(_components.__experimentalToolsPanelContext.Provider, {
60
+ value: value
61
+ }, children);
62
+ }));
63
+ }
64
+ //# sourceMappingURL=fill.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/inspector-controls/fill.js"],"names":["InspectorControlsFill","__experimentalGroup","group","children","isDisplayed","Fill","groups","document","fillProps","value"],"mappings":";;;;;;;;;;;AAGA;;AAKA;;AAIA;;AAKA;;AACA;;AAlBA;AACA;AACA;;AAGA;AACA;AACA;;AAOA;AACA;AACA;AAIe,SAASA,qBAAT,CAAgC;AAC9CC,EAAAA,mBAAmB,EAAEC,KAAK,GAAG,SADiB;AAE9CC,EAAAA;AAF8C,CAAhC,EAGX;AAAA;;AACH,QAAMC,WAAW,GAAG,uCAApB;AACA,QAAMC,IAAI,oBAAGC,gBAAQJ,KAAR,CAAH,kDAAG,cAAiBG,IAA9B;;AACA,MAAK,CAAEA,IAAP,EAAc;AACb,mHAAU,mCAAmCH,KAAO,aAApD;AACA,WAAO,IAAP;AACA;;AACD,MAAK,CAAEE,WAAP,EAAqB;AACpB,WAAO,IAAP;AACA;;AAED,SACC,4BAAC,uCAAD;AAAe,IAAA,QAAQ,EAAGG;AAA1B,KACC,4BAAC,IAAD,QACKC,SAAF,IAAiB;AAClB;AACA;AACA;AACA;AACA,UAAMC,KAAK,GAAG,CAAE,qBAASD,SAAT,CAAF,GAAyBA,SAAzB,GAAqC,IAAnD;AACA,WACC,4BAAC,2CAAD,CAAmB,QAAnB;AAA4B,MAAA,KAAK,EAAGC;AAApC,OACGN,QADH,CADD;AAKA,GAZF,CADD,CADD;AAkBA","sourcesContent":["/**\n * External dependencies\n */\nimport { isEmpty } from 'lodash';\n\n/**\n * WordPress dependencies\n */\nimport {\n\t__experimentalStyleProvider as StyleProvider,\n\t__experimentalToolsPanelContext as ToolsPanelContext,\n} from '@wordpress/components';\nimport warning from '@wordpress/warning';\n\n/**\n * Internal dependencies\n */\nimport useDisplayBlockControls from '../use-display-block-controls';\nimport groups from './groups';\n\nexport default function InspectorControlsFill( {\n\t__experimentalGroup: group = 'default',\n\tchildren,\n} ) {\n\tconst isDisplayed = useDisplayBlockControls();\n\tconst Fill = groups[ group ]?.Fill;\n\tif ( ! Fill ) {\n\t\twarning( `Unknown InspectorControl group \"${ group }\" provided.` );\n\t\treturn null;\n\t}\n\tif ( ! isDisplayed ) {\n\t\treturn null;\n\t}\n\n\treturn (\n\t\t<StyleProvider document={ document }>\n\t\t\t<Fill>\n\t\t\t\t{ ( fillProps ) => {\n\t\t\t\t\t// Children passed to InspectorControlsFill will not have\n\t\t\t\t\t// access to any React Context whose Provider is part of\n\t\t\t\t\t// the InspectorControlsSlot tree. So we re-create the\n\t\t\t\t\t// Provider in this subtree.\n\t\t\t\t\tconst value = ! isEmpty( fillProps ) ? fillProps : null;\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<ToolsPanelContext.Provider value={ value }>\n\t\t\t\t\t\t\t{ children }\n\t\t\t\t\t\t</ToolsPanelContext.Provider>\n\t\t\t\t\t);\n\t\t\t\t} }\n\t\t\t</Fill>\n\t\t</StyleProvider>\n\t);\n}\n"]}
@@ -1,9 +1,11 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
6
- exports.default = void 0;
8
+ exports.default = InspectorControlsFill;
7
9
 
8
10
  var _element = require("@wordpress/element");
9
11
 
@@ -11,6 +13,10 @@ var _reactNative = require("react-native");
11
13
 
12
14
  var _components = require("@wordpress/components");
13
15
 
16
+ var _warning = _interopRequireDefault(require("@wordpress/warning"));
17
+
18
+ var _groups = _interopRequireDefault(require("./groups"));
19
+
14
20
  var _context = require("../block-edit/context");
15
21
 
16
22
  var _blockSettings = require("../block-settings");
@@ -26,32 +32,27 @@ var _blockSettings = require("../block-settings");
26
32
  /**
27
33
  * Internal dependencies
28
34
  */
29
- const {
30
- Fill,
31
- Slot
32
- } = (0, _components.createSlotFill)('InspectorControls');
33
-
34
- const FillWithSettingsButton = ({
35
+ function InspectorControlsFill({
35
36
  children,
37
+ __experimentalGroup: group = 'default',
36
38
  ...props
37
- }) => {
39
+ }) {
40
+ var _groups$group;
41
+
38
42
  const {
39
43
  isSelected
40
44
  } = (0, _context.useBlockEditContext)();
45
+ const Fill = (_groups$group = _groups.default[group]) === null || _groups$group === void 0 ? void 0 : _groups$group.Fill;
46
+
47
+ if (!Fill) {
48
+ typeof process !== "undefined" && process.env && process.env.NODE_ENV !== "production" ? (0, _warning.default)(`Unknown InspectorControl group "${group}" provided.`) : void 0;
49
+ return null;
50
+ }
41
51
 
42
52
  if (!isSelected) {
43
53
  return null;
44
54
  }
45
55
 
46
56
  return (0, _element.createElement)(_element.Fragment, null, (0, _element.createElement)(Fill, props, (0, _element.createElement)(_components.BottomSheetConsumer, null, () => (0, _element.createElement)(_reactNative.View, null, children))), _element.Children.count(children) > 0 && (0, _element.createElement)(_blockSettings.BlockSettingsButton, null));
47
- };
48
-
49
- const InspectorControls = FillWithSettingsButton;
50
- InspectorControls.Slot = Slot;
51
- /**
52
- * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/inspector-controls/README.md
53
- */
54
-
55
- var _default = InspectorControls;
56
- exports.default = _default;
57
- //# sourceMappingURL=index.native.js.map
57
+ }
58
+ //# sourceMappingURL=fill.native.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/inspector-controls/fill.native.js"],"names":["InspectorControlsFill","children","__experimentalGroup","group","props","isSelected","Fill","groups","Children","count"],"mappings":";;;;;;;;;AAQA;;AALA;;AAMA;;AACA;;AAKA;;AACA;;AACA;;AAjBA;AACA;AACA;;AAGA;AACA;AACA;;AAKA;AACA;AACA;AAKe,SAASA,qBAAT,CAAgC;AAC9CC,EAAAA,QAD8C;AAE9CC,EAAAA,mBAAmB,EAAEC,KAAK,GAAG,SAFiB;AAG9C,KAAGC;AAH2C,CAAhC,EAIX;AAAA;;AACH,QAAM;AAAEC,IAAAA;AAAF,MAAiB,mCAAvB;AACA,QAAMC,IAAI,oBAAGC,gBAAQJ,KAAR,CAAH,kDAAG,cAAiBG,IAA9B;;AACA,MAAK,CAAEA,IAAP,EAAc;AACb,mHAAU,mCAAmCH,KAAO,aAApD;AACA,WAAO,IAAP;AACA;;AACD,MAAK,CAAEE,UAAP,EAAoB;AACnB,WAAO,IAAP;AACA;;AAED,SACC,qDACC,4BAAC,IAAD,EAAWD,KAAX,EAEE,4BAAC,+BAAD,QACG,MAAM,4BAAC,iBAAD,QAAQH,QAAR,CADT,CAFF,CADD,EAQGO,kBAASC,KAAT,CAAgBR,QAAhB,IAA6B,CAA7B,IAAkC,4BAAC,kCAAD,OARrC,CADD;AAYA","sourcesContent":["/**\n * External dependencies\n */\nimport { View } from 'react-native';\n\n/**\n * WordPress dependencies\n */\nimport { Children } from '@wordpress/element';\nimport { BottomSheetConsumer } from '@wordpress/components';\nimport warning from '@wordpress/warning';\n\n/**\n * Internal dependencies\n */\nimport groups from './groups';\nimport { useBlockEditContext } from '../block-edit/context';\nimport { BlockSettingsButton } from '../block-settings';\n\nexport default function InspectorControlsFill( {\n\tchildren,\n\t__experimentalGroup: group = 'default',\n\t...props\n} ) {\n\tconst { isSelected } = useBlockEditContext();\n\tconst Fill = groups[ group ]?.Fill;\n\tif ( ! Fill ) {\n\t\twarning( `Unknown InspectorControl group \"${ group }\" provided.` );\n\t\treturn null;\n\t}\n\tif ( ! isSelected ) {\n\t\treturn null;\n\t}\n\n\treturn (\n\t\t<>\n\t\t\t<Fill { ...props }>\n\t\t\t\t{\n\t\t\t\t\t<BottomSheetConsumer>\n\t\t\t\t\t\t{ () => <View>{ children }</View> }\n\t\t\t\t\t</BottomSheetConsumer>\n\t\t\t\t}\n\t\t\t</Fill>\n\t\t\t{ Children.count( children ) > 0 && <BlockSettingsButton /> }\n\t\t</>\n\t);\n}\n"]}