@wordpress/block-editor 12.16.1-next.79a6196f.0 → 12.18.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (376) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/README.md +32 -0
  3. package/build/components/block-draggable/index.js +11 -3
  4. package/build/components/block-draggable/index.js.map +1 -1
  5. package/build/components/block-edit/context.js +3 -1
  6. package/build/components/block-edit/context.js.map +1 -1
  7. package/build/components/block-edit/index.js +4 -2
  8. package/build/components/block-edit/index.js.map +1 -1
  9. package/build/components/block-editing-mode/index.js +6 -3
  10. package/build/components/block-editing-mode/index.js.map +1 -1
  11. package/build/components/block-inspector/index.js +5 -2
  12. package/build/components/block-inspector/index.js.map +1 -1
  13. package/build/components/block-list/block.js +4 -3
  14. package/build/components/block-list/block.js.map +1 -1
  15. package/build/components/block-list/block.native.js +9 -5
  16. package/build/components/block-list/block.native.js.map +1 -1
  17. package/build/components/block-list/index.js +30 -4
  18. package/build/components/block-list/index.js.map +1 -1
  19. package/build/components/block-list/private-block-context.js +1 -1
  20. package/build/components/block-list/private-block-context.js.map +1 -1
  21. package/build/components/block-list/use-in-between-inserter.js +1 -1
  22. package/build/components/block-list/use-in-between-inserter.js.map +1 -1
  23. package/build/components/block-popover/inbetween.js +15 -3
  24. package/build/components/block-popover/inbetween.js.map +1 -1
  25. package/build/components/block-preview/auto.js +1 -1
  26. package/build/components/block-preview/auto.js.map +1 -1
  27. package/build/components/block-removal-warning-modal/index.js +3 -2
  28. package/build/components/block-removal-warning-modal/index.js.map +1 -1
  29. package/build/components/block-settings-menu/block-settings-dropdown.js +2 -4
  30. package/build/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  31. package/build/components/block-switcher/block-transformations-menu.js +12 -1
  32. package/build/components/block-switcher/block-transformations-menu.js.map +1 -1
  33. package/build/components/block-switcher/index.js +119 -90
  34. package/build/components/block-switcher/index.js.map +1 -1
  35. package/build/components/block-tools/insertion-point.js +10 -3
  36. package/build/components/block-tools/insertion-point.js.map +1 -1
  37. package/build/components/font-sizes/fluid-utils.js +7 -1
  38. package/build/components/font-sizes/fluid-utils.js.map +1 -1
  39. package/build/components/global-styles/border-panel.js +5 -14
  40. package/build/components/global-styles/border-panel.js.map +1 -1
  41. package/build/components/global-styles/effects-panel.js +7 -1
  42. package/build/components/global-styles/effects-panel.js.map +1 -1
  43. package/build/components/iframe/get-compatibility-styles.js +99 -0
  44. package/build/components/iframe/get-compatibility-styles.js.map +1 -0
  45. package/build/components/iframe/index.js +2 -3
  46. package/build/components/iframe/index.js.map +1 -1
  47. package/build/components/index.js +16 -2
  48. package/build/components/index.js.map +1 -1
  49. package/build/components/index.native.js +16 -2
  50. package/build/components/index.native.js.map +1 -1
  51. package/build/components/inspector-controls/groups.js +2 -0
  52. package/build/components/inspector-controls/groups.js.map +1 -1
  53. package/build/components/inspector-controls-tabs/styles-tab.js +3 -0
  54. package/build/components/inspector-controls-tabs/styles-tab.js.map +1 -1
  55. package/build/components/inspector-controls-tabs/use-inspector-controls-tabs.js +3 -2
  56. package/build/components/inspector-controls-tabs/use-inspector-controls-tabs.js.map +1 -1
  57. package/build/components/link-control/link-preview.js +30 -26
  58. package/build/components/link-control/link-preview.js.map +1 -1
  59. package/build/components/link-control/search-input.js +1 -9
  60. package/build/components/link-control/search-input.js.map +1 -1
  61. package/build/components/list-view/block-contents.js +3 -1
  62. package/build/components/list-view/block-contents.js.map +1 -1
  63. package/build/components/list-view/block.js +10 -1
  64. package/build/components/list-view/block.js.map +1 -1
  65. package/build/components/list-view/branch.js +29 -8
  66. package/build/components/list-view/branch.js.map +1 -1
  67. package/build/components/list-view/drop-indicator.js +100 -32
  68. package/build/components/list-view/drop-indicator.js.map +1 -1
  69. package/build/components/list-view/index.js +52 -4
  70. package/build/components/list-view/index.js.map +1 -1
  71. package/build/components/list-view/leaf.js +2 -2
  72. package/build/components/list-view/leaf.js.map +1 -1
  73. package/build/components/list-view/use-list-view-block-indexes.js +30 -0
  74. package/build/components/list-view/use-list-view-block-indexes.js.map +1 -0
  75. package/build/components/list-view/use-list-view-drop-zone.js +56 -5
  76. package/build/components/list-view/use-list-view-drop-zone.js.map +1 -1
  77. package/build/components/list-view/utils.js +92 -0
  78. package/build/components/list-view/utils.js.map +1 -1
  79. package/build/components/provider/index.js +1 -1
  80. package/build/components/provider/index.js.map +1 -1
  81. package/build/components/recursion-provider/index.js +21 -0
  82. package/build/components/recursion-provider/index.js.map +1 -1
  83. package/build/components/rich-text/index.js +30 -6
  84. package/build/components/rich-text/index.js.map +1 -1
  85. package/build/components/rich-text/native/index.native.js +9 -9
  86. package/build/components/rich-text/native/index.native.js.map +1 -1
  87. package/build/components/use-block-drop-zone/index.js +30 -7
  88. package/build/components/use-block-drop-zone/index.js.map +1 -1
  89. package/build/components/use-on-block-drop/index.js +50 -8
  90. package/build/components/use-on-block-drop/index.js.map +1 -1
  91. package/build/hooks/block-hooks.js +5 -14
  92. package/build/hooks/block-hooks.js.map +1 -1
  93. package/build/hooks/content-lock-ui.js +17 -42
  94. package/build/hooks/content-lock-ui.js.map +1 -1
  95. package/build/hooks/effects.js +66 -0
  96. package/build/hooks/effects.js.map +1 -0
  97. package/build/hooks/index.js +14 -0
  98. package/build/hooks/index.js.map +1 -1
  99. package/build/hooks/index.native.js +13 -0
  100. package/build/hooks/index.native.js.map +1 -1
  101. package/build/hooks/style.js +6 -2
  102. package/build/hooks/style.js.map +1 -1
  103. package/build/hooks/supports.js +2 -1
  104. package/build/hooks/supports.js.map +1 -1
  105. package/build/hooks/typography.native.js +2 -2
  106. package/build/hooks/typography.native.js.map +1 -1
  107. package/build/hooks/use-bindings-attributes.js +115 -0
  108. package/build/hooks/use-bindings-attributes.js.map +1 -0
  109. package/build/hooks/use-shadow-props.js +46 -0
  110. package/build/hooks/use-shadow-props.js.map +1 -0
  111. package/build/hooks/utils.js +7 -6
  112. package/build/hooks/utils.js.map +1 -1
  113. package/build/index.js +14 -0
  114. package/build/index.js.map +1 -1
  115. package/build/store/actions.js +10 -6
  116. package/build/store/actions.js.map +1 -1
  117. package/build/store/index.js +2 -0
  118. package/build/store/index.js.map +1 -1
  119. package/build/store/private-actions.js +37 -0
  120. package/build/store/private-actions.js.map +1 -1
  121. package/build/store/private-selectors.js +60 -9
  122. package/build/store/private-selectors.js.map +1 -1
  123. package/build/store/reducer.js +44 -3
  124. package/build/store/reducer.js.map +1 -1
  125. package/build/store/resolvers.js +27 -0
  126. package/build/store/resolvers.js.map +1 -0
  127. package/build/store/selectors.js +94 -56
  128. package/build/store/selectors.js.map +1 -1
  129. package/build/store/utils.js +5 -26
  130. package/build/store/utils.js.map +1 -1
  131. package/build/utils/index.js +0 -16
  132. package/build/utils/index.js.map +1 -1
  133. package/build/utils/math.js +13 -0
  134. package/build/utils/math.js.map +1 -1
  135. package/build/utils/transform-styles/index.js +37 -27
  136. package/build/utils/transform-styles/index.js.map +1 -1
  137. package/build-module/components/block-draggable/index.js +11 -3
  138. package/build-module/components/block-draggable/index.js.map +1 -1
  139. package/build-module/components/block-edit/context.js +1 -0
  140. package/build-module/components/block-edit/context.js.map +1 -1
  141. package/build-module/components/block-edit/index.js +5 -3
  142. package/build-module/components/block-edit/index.js.map +1 -1
  143. package/build-module/components/block-editing-mode/index.js +7 -4
  144. package/build-module/components/block-editing-mode/index.js.map +1 -1
  145. package/build-module/components/block-inspector/index.js +5 -2
  146. package/build-module/components/block-inspector/index.js.map +1 -1
  147. package/build-module/components/block-list/block.js +6 -5
  148. package/build-module/components/block-list/block.js.map +1 -1
  149. package/build-module/components/block-list/block.native.js +11 -7
  150. package/build-module/components/block-list/block.native.js.map +1 -1
  151. package/build-module/components/block-list/index.js +31 -5
  152. package/build-module/components/block-list/index.js.map +1 -1
  153. package/build-module/components/block-list/private-block-context.js +1 -1
  154. package/build-module/components/block-list/private-block-context.js.map +1 -1
  155. package/build-module/components/block-list/use-in-between-inserter.js +1 -1
  156. package/build-module/components/block-list/use-in-between-inserter.js.map +1 -1
  157. package/build-module/components/block-popover/inbetween.js +15 -3
  158. package/build-module/components/block-popover/inbetween.js.map +1 -1
  159. package/build-module/components/block-preview/auto.js +3 -3
  160. package/build-module/components/block-preview/auto.js.map +1 -1
  161. package/build-module/components/block-removal-warning-modal/index.js +3 -2
  162. package/build-module/components/block-removal-warning-modal/index.js.map +1 -1
  163. package/build-module/components/block-settings-menu/block-settings-dropdown.js +2 -4
  164. package/build-module/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  165. package/build-module/components/block-switcher/block-transformations-menu.js +12 -1
  166. package/build-module/components/block-switcher/block-transformations-menu.js.map +1 -1
  167. package/build-module/components/block-switcher/index.js +116 -86
  168. package/build-module/components/block-switcher/index.js.map +1 -1
  169. package/build-module/components/block-tools/insertion-point.js +10 -3
  170. package/build-module/components/block-tools/insertion-point.js.map +1 -1
  171. package/build-module/components/font-sizes/fluid-utils.js +7 -1
  172. package/build-module/components/font-sizes/fluid-utils.js.map +1 -1
  173. package/build-module/components/global-styles/border-panel.js +5 -14
  174. package/build-module/components/global-styles/border-panel.js.map +1 -1
  175. package/build-module/components/global-styles/effects-panel.js +7 -1
  176. package/build-module/components/global-styles/effects-panel.js.map +1 -1
  177. package/build-module/components/iframe/get-compatibility-styles.js +93 -0
  178. package/build-module/components/iframe/get-compatibility-styles.js.map +1 -0
  179. package/build-module/components/iframe/index.js +2 -3
  180. package/build-module/components/iframe/index.js.map +1 -1
  181. package/build-module/components/index.js +1 -1
  182. package/build-module/components/index.js.map +1 -1
  183. package/build-module/components/index.native.js +1 -1
  184. package/build-module/components/index.native.js.map +1 -1
  185. package/build-module/components/inspector-controls/groups.js +2 -0
  186. package/build-module/components/inspector-controls/groups.js.map +1 -1
  187. package/build-module/components/inspector-controls-tabs/styles-tab.js +3 -0
  188. package/build-module/components/inspector-controls-tabs/styles-tab.js.map +1 -1
  189. package/build-module/components/inspector-controls-tabs/use-inspector-controls-tabs.js +3 -2
  190. package/build-module/components/inspector-controls-tabs/use-inspector-controls-tabs.js.map +1 -1
  191. package/build-module/components/link-control/link-preview.js +32 -28
  192. package/build-module/components/link-control/link-preview.js.map +1 -1
  193. package/build-module/components/link-control/search-input.js +1 -8
  194. package/build-module/components/link-control/search-input.js.map +1 -1
  195. package/build-module/components/list-view/block-contents.js +3 -1
  196. package/build-module/components/list-view/block-contents.js.map +1 -1
  197. package/build-module/components/list-view/block.js +10 -1
  198. package/build-module/components/list-view/block.js.map +1 -1
  199. package/build-module/components/list-view/branch.js +30 -9
  200. package/build-module/components/list-view/branch.js.map +1 -1
  201. package/build-module/components/list-view/drop-indicator.js +99 -32
  202. package/build-module/components/list-view/drop-indicator.js.map +1 -1
  203. package/build-module/components/list-view/index.js +54 -6
  204. package/build-module/components/list-view/index.js.map +1 -1
  205. package/build-module/components/list-view/leaf.js +2 -2
  206. package/build-module/components/list-view/leaf.js.map +1 -1
  207. package/build-module/components/list-view/use-list-view-block-indexes.js +23 -0
  208. package/build-module/components/list-view/use-list-view-block-indexes.js.map +1 -0
  209. package/build-module/components/list-view/use-list-view-drop-zone.js +58 -7
  210. package/build-module/components/list-view/use-list-view-drop-zone.js.map +1 -1
  211. package/build-module/components/list-view/utils.js +91 -0
  212. package/build-module/components/list-view/utils.js.map +1 -1
  213. package/build-module/components/provider/index.js +1 -1
  214. package/build-module/components/provider/index.js.map +1 -1
  215. package/build-module/components/recursion-provider/index.js +17 -0
  216. package/build-module/components/recursion-provider/index.js.map +1 -1
  217. package/build-module/components/rich-text/index.js +30 -6
  218. package/build-module/components/rich-text/index.js.map +1 -1
  219. package/build-module/components/rich-text/native/index.native.js +9 -9
  220. package/build-module/components/rich-text/native/index.native.js.map +1 -1
  221. package/build-module/components/use-block-drop-zone/index.js +31 -8
  222. package/build-module/components/use-block-drop-zone/index.js.map +1 -1
  223. package/build-module/components/use-on-block-drop/index.js +51 -9
  224. package/build-module/components/use-on-block-drop/index.js.map +1 -1
  225. package/build-module/hooks/block-hooks.js +5 -14
  226. package/build-module/hooks/block-hooks.js.map +1 -1
  227. package/build-module/hooks/content-lock-ui.js +19 -43
  228. package/build-module/hooks/content-lock-ui.js.map +1 -1
  229. package/build-module/hooks/effects.js +51 -0
  230. package/build-module/hooks/effects.js.map +1 -0
  231. package/build-module/hooks/index.js +2 -0
  232. package/build-module/hooks/index.js.map +1 -1
  233. package/build-module/hooks/index.native.js +1 -0
  234. package/build-module/hooks/index.native.js.map +1 -1
  235. package/build-module/hooks/style.js +6 -2
  236. package/build-module/hooks/style.js.map +1 -1
  237. package/build-module/hooks/supports.js +2 -1
  238. package/build-module/hooks/supports.js.map +1 -1
  239. package/build-module/hooks/typography.native.js +2 -2
  240. package/build-module/hooks/typography.native.js.map +1 -1
  241. package/build-module/hooks/use-bindings-attributes.js +112 -0
  242. package/build-module/hooks/use-bindings-attributes.js.map +1 -0
  243. package/build-module/hooks/use-shadow-props.js +39 -0
  244. package/build-module/hooks/use-shadow-props.js.map +1 -0
  245. package/build-module/hooks/utils.js +9 -8
  246. package/build-module/hooks/utils.js.map +1 -1
  247. package/build-module/index.js +1 -1
  248. package/build-module/index.js.map +1 -1
  249. package/build-module/store/actions.js +10 -6
  250. package/build-module/store/actions.js.map +1 -1
  251. package/build-module/store/index.js +2 -0
  252. package/build-module/store/index.js.map +1 -1
  253. package/build-module/store/private-actions.js +35 -0
  254. package/build-module/store/private-actions.js.map +1 -1
  255. package/build-module/store/private-selectors.js +53 -8
  256. package/build-module/store/private-selectors.js.map +1 -1
  257. package/build-module/store/reducer.js +43 -3
  258. package/build-module/store/reducer.js.map +1 -1
  259. package/build-module/store/resolvers.js +20 -0
  260. package/build-module/store/resolvers.js.map +1 -0
  261. package/build-module/store/selectors.js +89 -52
  262. package/build-module/store/selectors.js.map +1 -1
  263. package/build-module/store/utils.js +3 -23
  264. package/build-module/store/utils.js.map +1 -1
  265. package/build-module/utils/index.js +0 -1
  266. package/build-module/utils/index.js.map +1 -1
  267. package/build-module/utils/math.js +12 -0
  268. package/build-module/utils/math.js.map +1 -1
  269. package/build-module/utils/transform-styles/index.js +36 -27
  270. package/build-module/utils/transform-styles/index.js.map +1 -1
  271. package/build-style/content-rtl.css +33 -16
  272. package/build-style/content.css +33 -16
  273. package/build-style/default-editor-styles-rtl.css +1 -1
  274. package/build-style/default-editor-styles.css +1 -1
  275. package/build-style/style-rtl.css +169 -114
  276. package/build-style/style.css +169 -114
  277. package/package.json +31 -31
  278. package/src/components/block-canvas/style.scss +8 -1
  279. package/src/components/block-draggable/index.js +16 -5
  280. package/src/components/block-edit/context.js +1 -0
  281. package/src/components/block-edit/index.js +4 -0
  282. package/src/components/block-editing-mode/index.js +12 -7
  283. package/src/components/block-inspector/index.js +5 -2
  284. package/src/components/block-list/block.js +5 -4
  285. package/src/components/block-list/block.native.js +13 -3
  286. package/src/components/block-list/content.scss +34 -5
  287. package/src/components/block-list/index.js +52 -16
  288. package/src/components/block-list/private-block-context.js +1 -1
  289. package/src/components/block-list/use-in-between-inserter.js +1 -2
  290. package/src/components/block-popover/inbetween.js +22 -2
  291. package/src/components/block-preview/auto.js +3 -3
  292. package/src/components/block-removal-warning-modal/index.js +3 -2
  293. package/src/components/block-settings-menu/block-settings-dropdown.js +2 -7
  294. package/src/components/block-switcher/block-transformations-menu.js +18 -1
  295. package/src/components/block-switcher/index.js +133 -111
  296. package/src/components/block-switcher/style.scss +6 -4
  297. package/src/components/block-switcher/test/index.js +113 -230
  298. package/src/components/block-toolbar/style.scss +22 -18
  299. package/src/components/block-tools/insertion-point.js +15 -2
  300. package/src/components/block-tools/style.scss +8 -7
  301. package/src/components/font-sizes/fluid-utils.js +8 -2
  302. package/src/components/font-sizes/test/fluid-utils.js +9 -0
  303. package/src/components/global-styles/border-panel.js +7 -17
  304. package/src/components/global-styles/effects-panel.js +16 -1
  305. package/src/components/iframe/get-compatibility-styles.js +120 -0
  306. package/src/components/iframe/index.js +2 -3
  307. package/src/components/index.js +4 -2
  308. package/src/components/index.native.js +4 -2
  309. package/src/components/inspector-controls/groups.js +2 -0
  310. package/src/components/inspector-controls-tabs/styles-tab.js +1 -0
  311. package/src/components/inspector-controls-tabs/use-inspector-controls-tabs.js +2 -0
  312. package/src/components/link-control/link-preview.js +31 -55
  313. package/src/components/link-control/search-input.js +1 -9
  314. package/src/components/link-control/style.scss +31 -85
  315. package/src/components/link-control/test/index.js +2 -1
  316. package/src/components/list-view/block-contents.js +5 -1
  317. package/src/components/list-view/block.js +9 -0
  318. package/src/components/list-view/branch.js +30 -10
  319. package/src/components/list-view/drop-indicator.js +139 -46
  320. package/src/components/list-view/index.js +74 -3
  321. package/src/components/list-view/leaf.js +2 -2
  322. package/src/components/list-view/style.scss +102 -13
  323. package/src/components/list-view/test/use-list-view-drop-zone.js +4 -0
  324. package/src/components/list-view/test/utils.js +218 -1
  325. package/src/components/list-view/use-list-view-block-indexes.js +29 -0
  326. package/src/components/list-view/use-list-view-drop-zone.js +78 -6
  327. package/src/components/list-view/utils.js +116 -0
  328. package/src/components/provider/index.js +3 -1
  329. package/src/components/recursion-provider/README.md +2 -2
  330. package/src/components/recursion-provider/index.js +17 -0
  331. package/src/components/rich-text/index.js +48 -10
  332. package/src/components/rich-text/native/index.native.js +10 -10
  333. package/src/components/use-block-drop-zone/index.js +60 -19
  334. package/src/components/use-block-drop-zone/test/index.js +32 -61
  335. package/src/components/use-on-block-drop/index.js +92 -11
  336. package/src/hooks/block-hooks.js +5 -17
  337. package/src/hooks/content-lock-ui.js +15 -55
  338. package/src/hooks/effects.js +57 -0
  339. package/src/hooks/index.js +2 -0
  340. package/src/hooks/index.native.js +1 -0
  341. package/src/hooks/style.js +8 -0
  342. package/src/hooks/supports.js +2 -0
  343. package/src/hooks/test/effects.js +39 -0
  344. package/src/hooks/typography.native.js +2 -2
  345. package/src/hooks/use-bindings-attributes.js +148 -0
  346. package/src/hooks/use-shadow-props.js +37 -0
  347. package/src/hooks/utils.js +10 -6
  348. package/src/index.js +2 -0
  349. package/src/store/actions.js +9 -4
  350. package/src/store/index.js +2 -0
  351. package/src/store/private-actions.js +32 -0
  352. package/src/store/private-selectors.js +78 -21
  353. package/src/store/reducer.js +49 -2
  354. package/src/store/resolvers.js +17 -0
  355. package/src/store/selectors.js +169 -161
  356. package/src/store/test/registry-selectors.js +431 -0
  357. package/src/store/test/selectors.js +14 -400
  358. package/src/store/utils.js +10 -33
  359. package/src/style.scss +0 -1
  360. package/src/utils/index.js +0 -1
  361. package/src/utils/math.js +12 -0
  362. package/src/utils/transform-styles/index.js +52 -37
  363. package/tsconfig.tsbuildinfo +1 -1
  364. package/build/components/iframe/use-compatibility-styles.js +0 -100
  365. package/build/components/iframe/use-compatibility-styles.js.map +0 -1
  366. package/build/utils/block-variation-transforms.js +0 -42
  367. package/build/utils/block-variation-transforms.js.map +0 -1
  368. package/build-module/components/iframe/use-compatibility-styles.js +0 -94
  369. package/build-module/components/iframe/use-compatibility-styles.js.map +0 -1
  370. package/build-module/utils/block-variation-transforms.js +0 -35
  371. package/build-module/utils/block-variation-transforms.js.map +0 -1
  372. package/src/components/block-switcher/test/__snapshots__/index.js.snap +0 -116
  373. package/src/components/contrast-checker/style.scss +0 -3
  374. package/src/components/iframe/use-compatibility-styles.js +0 -122
  375. package/src/utils/block-variation-transforms.js +0 -38
  376. package/src/utils/test/block-variation-transforms.js +0 -94
@@ -0,0 +1,431 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { registerBlockType, unregisterBlockType } from '@wordpress/blocks';
5
+ import { select, dispatch } from '@wordpress/data';
6
+
7
+ /**
8
+ * Internal dependencies
9
+ */
10
+ import { store } from '../';
11
+
12
+ describe( 'selectors', () => {
13
+ beforeEach( () => {
14
+ registerBlockType( 'core/test-block-a', {
15
+ save: ( props ) => props.attributes.text,
16
+ category: 'design',
17
+ title: 'Test Block A',
18
+ icon: 'test',
19
+ keywords: [ 'testing' ],
20
+ } );
21
+
22
+ registerBlockType( 'core/test-block-b', {
23
+ save: ( props ) => props.attributes.text,
24
+ category: 'text',
25
+ title: 'Test Block B',
26
+ icon: 'test',
27
+ keywords: [ 'testing' ],
28
+ supports: {
29
+ multiple: false,
30
+ },
31
+ } );
32
+ } );
33
+
34
+ afterEach( async () => {
35
+ unregisterBlockType( 'core/test-block-a' );
36
+ unregisterBlockType( 'core/test-block-b' );
37
+ } );
38
+
39
+ describe( '__experimentalGetAllowedPatterns', () => {
40
+ beforeAll( async () => {
41
+ await dispatch( store ).resetBlocks( [
42
+ {
43
+ clientId: 'block1',
44
+ name: 'core/test-block-a',
45
+ innerBlocks: [],
46
+ },
47
+ {
48
+ clientId: 'block2',
49
+ name: 'core/test-block-b',
50
+ innerBlocks: [],
51
+ },
52
+ ] );
53
+ await dispatch( store ).updateSettings( {
54
+ __experimentalBlockPatterns: [
55
+ {
56
+ name: 'pattern-a',
57
+ title: 'pattern with a',
58
+ content: `<!-- wp:test-block-a --><!-- /wp:test-block-a -->`,
59
+ },
60
+ {
61
+ name: 'pattern-b',
62
+ title: 'pattern with b',
63
+ content:
64
+ '<!-- wp:test-block-b --><!-- /wp:test-block-b -->',
65
+ },
66
+ {
67
+ name: 'pattern-c',
68
+ title: 'pattern hidden from UI',
69
+ inserter: false,
70
+ content:
71
+ '<!-- wp:test-block-a --><!-- /wp:test-block-a -->',
72
+ },
73
+ ],
74
+ } );
75
+ await dispatch( store ).updateBlockListSettings( 'block1', {
76
+ allowedBlocks: [ 'core/test-block-b' ],
77
+ } );
78
+ } );
79
+
80
+ afterAll( async () => {
81
+ await dispatch( store ).resetBlocks( [] );
82
+ await dispatch( store ).updateSettings( {
83
+ __experimentalBlockPatterns: [],
84
+ } );
85
+ await dispatch( store ).updateBlockListSettings( 'block1', {} );
86
+ } );
87
+
88
+ it( 'should return all patterns for root level', () => {
89
+ expect(
90
+ select( store ).__experimentalGetAllowedPatterns( null )
91
+ ).toHaveLength( 2 );
92
+ } );
93
+ it( 'should return patterns that consists of blocks allowed for the specified client ID', () => {
94
+ expect(
95
+ select( store ).__experimentalGetAllowedPatterns( 'block1' )
96
+ ).toHaveLength( 1 );
97
+ expect(
98
+ select( store ).__experimentalGetAllowedPatterns( 'block2' )
99
+ ).toHaveLength( 0 );
100
+ } );
101
+ it( 'should return empty array if only patterns hidden from UI exist', () => {
102
+ expect(
103
+ select( store ).__experimentalGetAllowedPatterns( {
104
+ blocks: { byClientId: new Map() },
105
+ blockListSettings: {},
106
+ settings: {
107
+ __experimentalBlockPatterns: [
108
+ {
109
+ name: 'pattern-c',
110
+ title: 'pattern hidden from UI',
111
+ inserter: false,
112
+ content:
113
+ '<!-- wp:test-block-a --><!-- /wp:test-block-a -->',
114
+ },
115
+ ],
116
+ },
117
+ } )
118
+ ).toHaveLength( 0 );
119
+ } );
120
+ } );
121
+
122
+ describe( '__experimentalGetParsedPattern', () => {
123
+ beforeAll( async () => {
124
+ await dispatch( store ).updateSettings( {
125
+ __experimentalBlockPatterns: [
126
+ {
127
+ name: 'pattern-a',
128
+ title: 'pattern with a',
129
+ content: `<!-- wp:test-block-a --><!-- /wp:test-block-a -->`,
130
+ },
131
+ {
132
+ name: 'pattern-hidden-from-ui',
133
+ title: 'pattern hidden from UI',
134
+ inserter: false,
135
+ content:
136
+ '<!-- wp:test-block-a --><!-- /wp:test-block-a --><!-- wp:test-block-b --><!-- /wp:test-block-b -->',
137
+ },
138
+ ],
139
+ } );
140
+ } );
141
+
142
+ afterAll( async () => {
143
+ await dispatch( store ).updateSettings( {
144
+ __experimentalBlockPatterns: [],
145
+ } );
146
+ } );
147
+
148
+ it( 'should return proper results when pattern does not exist', () => {
149
+ expect(
150
+ select( store ).__experimentalGetParsedPattern( 'not there' )
151
+ ).toBeNull();
152
+ } );
153
+ it( 'should return existing pattern properly parsed', () => {
154
+ const { name, blocks } =
155
+ select( store ).__experimentalGetParsedPattern( 'pattern-a' );
156
+ expect( name ).toEqual( 'pattern-a' );
157
+ expect( blocks ).toHaveLength( 1 );
158
+ expect( blocks[ 0 ] ).toEqual(
159
+ expect.objectContaining( {
160
+ name: 'core/test-block-a',
161
+ } )
162
+ );
163
+ } );
164
+ it( 'should return hidden from UI pattern when requested', () => {
165
+ const { name, blocks, inserter } = select(
166
+ store
167
+ ).__experimentalGetParsedPattern( 'pattern-hidden-from-ui' );
168
+ expect( name ).toEqual( 'pattern-hidden-from-ui' );
169
+ expect( inserter ).toBeFalsy();
170
+ expect( blocks ).toHaveLength( 2 );
171
+ expect( blocks[ 0 ] ).toEqual(
172
+ expect.objectContaining( {
173
+ name: 'core/test-block-a',
174
+ } )
175
+ );
176
+ } );
177
+ } );
178
+
179
+ describe( 'getPatternsByBlockTypes', () => {
180
+ beforeAll( async () => {
181
+ await dispatch( store ).resetBlocks( [
182
+ {
183
+ clientId: 'block1',
184
+ name: 'core/test-block-a',
185
+ innerBlocks: [],
186
+ },
187
+ ] );
188
+ await dispatch( store ).updateSettings( {
189
+ __experimentalBlockPatterns: [
190
+ {
191
+ name: 'pattern-a',
192
+ blockTypes: [ 'test/block-a' ],
193
+ title: 'pattern a',
194
+ content:
195
+ '<!-- wp:test-block-a --><!-- /wp:test-block-a -->',
196
+ },
197
+ {
198
+ name: 'pattern-b',
199
+ blockTypes: [ 'test/block-b' ],
200
+ title: 'pattern b',
201
+ content:
202
+ '<!-- wp:test-block-b --><!-- /wp:test-block-b -->',
203
+ },
204
+ {
205
+ title: 'pattern c',
206
+ blockTypes: [ 'test/block-a' ],
207
+ content:
208
+ '<!-- wp:test-block-b --><!-- /wp:test-block-b -->',
209
+ },
210
+ ],
211
+ } );
212
+ await dispatch( store ).updateBlockListSettings( 'block1', {
213
+ allowedBlocks: [ 'core/test-block-b' ],
214
+ } );
215
+ } );
216
+
217
+ afterAll( async () => {
218
+ await dispatch( store ).resetBlocks( [] );
219
+ await dispatch( store ).updateSettings( {
220
+ __experimentalBlockPatterns: [],
221
+ } );
222
+ await dispatch( store ).updateBlockListSettings( 'block1', {} );
223
+ } );
224
+
225
+ it( 'should return empty array if no block name is provided', () => {
226
+ expect( select( store ).getPatternsByBlockTypes() ).toEqual( [] );
227
+ } );
228
+ it( 'should return empty array if no match is found', () => {
229
+ const patterns = select( store ).getPatternsByBlockTypes(
230
+ 'test/block-not-exists'
231
+ );
232
+ expect( patterns ).toEqual( [] );
233
+ } );
234
+ it( 'should return the same empty array in both empty array cases', () => {
235
+ const patterns1 = select( store ).getPatternsByBlockTypes();
236
+ const patterns2 = select( store ).getPatternsByBlockTypes(
237
+ 'test/block-not-exists'
238
+ );
239
+ expect( patterns1 ).toBe( patterns2 );
240
+ } );
241
+ it( 'should return proper results when there are matched block patterns', () => {
242
+ const patterns =
243
+ select( store ).getPatternsByBlockTypes( 'test/block-a' );
244
+ expect( patterns ).toHaveLength( 2 );
245
+ expect( patterns ).toEqual(
246
+ expect.arrayContaining( [
247
+ expect.objectContaining( { title: 'pattern a' } ),
248
+ expect.objectContaining( { title: 'pattern c' } ),
249
+ ] )
250
+ );
251
+ } );
252
+ it( 'should return proper result with matched patterns and allowed blocks from rootClientId', () => {
253
+ const patterns = select( store ).getPatternsByBlockTypes(
254
+ 'test/block-a',
255
+ 'block1'
256
+ );
257
+ expect( patterns ).toHaveLength( 1 );
258
+ expect( patterns[ 0 ] ).toEqual(
259
+ expect.objectContaining( { title: 'pattern c' } )
260
+ );
261
+ } );
262
+ } );
263
+
264
+ describe( '__experimentalGetPatternTransformItems', () => {
265
+ beforeAll( async () => {
266
+ await dispatch( store ).resetBlocks( [
267
+ {
268
+ clientId: 'block1',
269
+ name: 'core/test-block-a',
270
+ innerBlocks: [],
271
+ },
272
+ {
273
+ clientId: 'block2',
274
+ name: 'core/test-block-b',
275
+ innerBlocks: [],
276
+ },
277
+ ] );
278
+ await dispatch( store ).setHasControlledInnerBlocks(
279
+ 'block2-clientId',
280
+ true
281
+ );
282
+ await dispatch( store ).updateSettings( {
283
+ __experimentalBlockPatterns: [
284
+ {
285
+ name: 'pattern-a',
286
+ blockTypes: [ 'test/block-a' ],
287
+ title: 'pattern a',
288
+ content:
289
+ '<!-- wp:test-block-a --><!-- /wp:test-block-a -->',
290
+ },
291
+ {
292
+ name: 'pattern-b',
293
+ blockTypes: [ 'test/block-b' ],
294
+ title: 'pattern b',
295
+ content:
296
+ '<!-- wp:test-block-b --><!-- /wp:test-block-b -->',
297
+ },
298
+ {
299
+ name: 'pattern-c',
300
+ title: 'pattern c',
301
+ blockTypes: [ 'test/block-a' ],
302
+ content:
303
+ '<!-- wp:test-block-b --><!-- /wp:test-block-b -->',
304
+ },
305
+ {
306
+ name: 'pattern-mix',
307
+ title: 'pattern mix',
308
+ blockTypes: [
309
+ 'core/test-block-a',
310
+ 'core/test-block-b',
311
+ ],
312
+ content:
313
+ '<!-- wp:test-block-b --><!-- /wp:test-block-b -->',
314
+ },
315
+ ],
316
+ } );
317
+ } );
318
+
319
+ afterAll( async () => {
320
+ await dispatch( store ).resetBlocks( [] );
321
+ await dispatch( store ).updateSettings( {
322
+ __experimentalBlockPatterns: [],
323
+ } );
324
+ await dispatch( store ).updateBlockListSettings( 'block1', {} );
325
+ } );
326
+
327
+ describe( 'should return empty array', () => {
328
+ it( 'when no blocks are selected', () => {
329
+ expect(
330
+ select( store ).__experimentalGetPatternTransformItems()
331
+ ).toEqual( [] );
332
+ } );
333
+ it( 'when a selected block has inner blocks', () => {
334
+ const blocks = [
335
+ { name: 'core/test-block-a', innerBlocks: [] },
336
+ {
337
+ name: 'core/test-block-b',
338
+ innerBlocks: [ { name: 'some inner block' } ],
339
+ },
340
+ ];
341
+ expect(
342
+ select( store ).__experimentalGetPatternTransformItems(
343
+ blocks
344
+ )
345
+ ).toEqual( [] );
346
+ } );
347
+ it( 'when a selected block has controlled inner blocks', () => {
348
+ const blocks = [
349
+ { name: 'core/test-block-a', innerBlocks: [] },
350
+ {
351
+ name: 'core/test-block-b',
352
+ clientId: 'block2-clientId',
353
+ innerBlocks: [],
354
+ },
355
+ ];
356
+ expect(
357
+ select( store ).__experimentalGetPatternTransformItems(
358
+ blocks
359
+ )
360
+ ).toEqual( [] );
361
+ } );
362
+ it( 'when no patterns are available based on the selected blocks', () => {
363
+ const blocks = [
364
+ { name: 'block-with-no-patterns', innerBlocks: [] },
365
+ ];
366
+ expect(
367
+ select( store ).__experimentalGetPatternTransformItems(
368
+ blocks
369
+ )
370
+ ).toEqual( [] );
371
+ } );
372
+ } );
373
+ describe( 'should return proper results', () => {
374
+ it( 'when a single block is selected', () => {
375
+ const blocks = [
376
+ { name: 'core/test-block-b', innerBlocks: [] },
377
+ ];
378
+ const patterns =
379
+ select( store ).__experimentalGetPatternTransformItems(
380
+ blocks
381
+ );
382
+ expect( patterns ).toHaveLength( 1 );
383
+ expect( patterns[ 0 ] ).toEqual(
384
+ expect.objectContaining( {
385
+ name: 'pattern-mix',
386
+ } )
387
+ );
388
+ } );
389
+ it( 'when different multiple blocks are selected', () => {
390
+ const blocks = [
391
+ { name: 'core/test-block-b', innerBlocks: [] },
392
+ { name: 'test/block-b', innerBlocks: [] },
393
+ { name: 'some other block', innerBlocks: [] },
394
+ ];
395
+ const patterns =
396
+ select( store ).__experimentalGetPatternTransformItems(
397
+ blocks
398
+ );
399
+ expect( patterns ).toHaveLength( 2 );
400
+ expect( patterns ).toEqual(
401
+ expect.arrayContaining( [
402
+ expect.objectContaining( {
403
+ name: 'pattern-mix',
404
+ } ),
405
+ expect.objectContaining( {
406
+ name: 'pattern-b',
407
+ } ),
408
+ ] )
409
+ );
410
+ } );
411
+ it( 'when multiple blocks are selected containing multiple times the same block', () => {
412
+ const blocks = [
413
+ { name: 'core/test-block-b', innerBlocks: [] },
414
+ { name: 'some other block', innerBlocks: [] },
415
+ { name: 'core/test-block-a', innerBlocks: [] },
416
+ { name: 'core/test-block-b', innerBlocks: [] },
417
+ ];
418
+ const patterns =
419
+ select( store ).__experimentalGetPatternTransformItems(
420
+ blocks
421
+ );
422
+ expect( patterns ).toHaveLength( 1 );
423
+ expect( patterns[ 0 ] ).toEqual(
424
+ expect.objectContaining( {
425
+ name: 'pattern-mix',
426
+ } )
427
+ );
428
+ } );
429
+ } );
430
+ } );
431
+ } );