@wordpress/block-editor 8.5.7 → 9.1.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 (462) hide show
  1. package/CHANGELOG.md +11 -0
  2. package/README.md +5 -2
  3. package/build/components/block-alignment-control/constants.js +48 -0
  4. package/build/components/block-alignment-control/constants.js.map +1 -0
  5. package/build/components/block-alignment-control/ui.js +9 -40
  6. package/build/components/block-alignment-control/ui.js.map +1 -1
  7. package/build/components/block-alignment-control/ui.native.js +92 -0
  8. package/build/components/block-alignment-control/ui.native.js.map +1 -0
  9. package/build/components/block-alignment-matrix-control/index.js +1 -6
  10. package/build/components/block-alignment-matrix-control/index.js.map +1 -1
  11. package/build/components/block-content-overlay/index.js +5 -74
  12. package/build/components/block-content-overlay/index.js.map +1 -1
  13. package/build/components/block-draggable/draggable-chip.native.js +64 -0
  14. package/build/components/block-draggable/draggable-chip.native.js.map +1 -0
  15. package/build/components/block-draggable/dropping-insertion-point.native.js +157 -0
  16. package/build/components/block-draggable/dropping-insertion-point.native.js.map +1 -0
  17. package/build/components/block-draggable/index.native.js +484 -0
  18. package/build/components/block-draggable/index.native.js.map +1 -0
  19. package/build/components/block-draggable/use-scroll-when-dragging.native.js +130 -0
  20. package/build/components/block-draggable/use-scroll-when-dragging.native.js.map +1 -0
  21. package/build/components/block-list/block-list-context.native.js +195 -0
  22. package/build/components/block-list/block-list-context.native.js.map +1 -0
  23. package/build/components/block-list/block-list-item-cell.native.js +67 -0
  24. package/build/components/block-list/block-list-item-cell.native.js.map +1 -0
  25. package/build/components/block-list/block-list-item.native.js +12 -9
  26. package/build/components/block-list/block-list-item.native.js.map +1 -1
  27. package/build/components/block-list/block.native.js +29 -6
  28. package/build/components/block-list/block.native.js.map +1 -1
  29. package/build/components/block-list/index.native.js +75 -23
  30. package/build/components/block-list/index.native.js.map +1 -1
  31. package/build/components/block-list/use-block-props/index.js +8 -4
  32. package/build/components/block-list/use-block-props/index.js.map +1 -1
  33. package/build/components/block-list/use-block-props/use-block-class-names.js +1 -7
  34. package/build/components/block-list/use-block-props/use-block-class-names.js.map +1 -1
  35. package/build/components/block-list/use-in-between-inserter.js +1 -1
  36. package/build/components/block-list/use-in-between-inserter.js.map +1 -1
  37. package/build/components/block-lock/modal.js +34 -4
  38. package/build/components/block-lock/modal.js.map +1 -1
  39. package/build/components/block-lock/toolbar.js +2 -1
  40. package/build/components/block-lock/toolbar.js.map +1 -1
  41. package/build/components/block-lock/use-block-lock.js +4 -1
  42. package/build/components/block-lock/use-block-lock.js.map +1 -1
  43. package/build/components/block-mobile-toolbar/index.native.js +9 -3
  44. package/build/components/block-mobile-toolbar/index.native.js.map +1 -1
  45. package/build/components/block-mover/button.js +4 -4
  46. package/build/components/block-mover/button.js.map +1 -1
  47. package/build/components/block-mover/index.js +39 -65
  48. package/build/components/block-mover/index.js.map +1 -1
  49. package/build/components/block-mover/index.native.js +17 -4
  50. package/build/components/block-mover/index.native.js.map +1 -1
  51. package/build/components/block-navigation/dropdown.js +11 -5
  52. package/build/components/block-navigation/dropdown.js.map +1 -1
  53. package/build/components/block-popover/inbetween.js +191 -0
  54. package/build/components/block-popover/inbetween.js.map +1 -0
  55. package/build/components/block-popover/index.js +85 -0
  56. package/build/components/block-popover/index.js.map +1 -0
  57. package/build/components/{block-tools → block-popover}/use-popover-scroll.js +4 -1
  58. package/build/components/block-popover/use-popover-scroll.js.map +1 -0
  59. package/build/components/block-preview/index.js +1 -1
  60. package/build/components/block-preview/index.js.map +1 -1
  61. package/build/components/block-styles/index.js +1 -10
  62. package/build/components/block-styles/index.js.map +1 -1
  63. package/build/components/block-tools/back-compat.js +2 -2
  64. package/build/components/block-tools/back-compat.js.map +1 -1
  65. package/build/components/block-tools/block-selection-button.js +4 -2
  66. package/build/components/block-tools/block-selection-button.js.map +1 -1
  67. package/build/components/block-tools/index.js +5 -5
  68. package/build/components/block-tools/index.js.map +1 -1
  69. package/build/components/block-tools/insertion-point.js +14 -121
  70. package/build/components/block-tools/insertion-point.js.map +1 -1
  71. package/build/components/block-tools/selected-block-popover.js +216 -0
  72. package/build/components/block-tools/selected-block-popover.js.map +1 -0
  73. package/build/components/border-radius-control/input-controls.js +10 -3
  74. package/build/components/border-radius-control/input-controls.js.map +1 -1
  75. package/build/components/color-style-selector/index.js +9 -0
  76. package/build/components/color-style-selector/index.js.map +1 -1
  77. package/build/components/colors-gradients/dropdown.js +149 -44
  78. package/build/components/colors-gradients/dropdown.js.map +1 -1
  79. package/build/components/duotone-control/index.js +5 -1
  80. package/build/components/duotone-control/index.js.map +1 -1
  81. package/build/components/image-editor/use-save-image.js +3 -1
  82. package/build/components/image-editor/use-save-image.js.map +1 -1
  83. package/build/components/index.js +5 -23
  84. package/build/components/index.js.map +1 -1
  85. package/build/components/inserter/index.native.js +31 -9
  86. package/build/components/inserter/index.native.js.map +1 -1
  87. package/build/components/link-control/constants.js +11 -1
  88. package/build/components/link-control/constants.js.map +1 -1
  89. package/build/components/link-control/search-results.js +4 -3
  90. package/build/components/link-control/search-results.js.map +1 -1
  91. package/build/components/link-control/use-search-handler.js +4 -4
  92. package/build/components/link-control/use-search-handler.js.map +1 -1
  93. package/build/components/list-view/block.js +15 -15
  94. package/build/components/list-view/block.js.map +1 -1
  95. package/build/components/list-view/branch.js +9 -13
  96. package/build/components/list-view/branch.js.map +1 -1
  97. package/build/components/list-view/context.js +1 -4
  98. package/build/components/list-view/context.js.map +1 -1
  99. package/build/components/list-view/drop-indicator.js +0 -1
  100. package/build/components/list-view/drop-indicator.js.map +1 -1
  101. package/build/components/list-view/index.js +15 -32
  102. package/build/components/list-view/index.js.map +1 -1
  103. package/build/components/navigable-toolbar/index.js +12 -2
  104. package/build/components/navigable-toolbar/index.js.map +1 -1
  105. package/build/components/rich-text/format-toolbar-container.js +0 -1
  106. package/build/components/rich-text/format-toolbar-container.js.map +1 -1
  107. package/build/components/rich-text/index.js +1 -6
  108. package/build/components/rich-text/index.js.map +1 -1
  109. package/build/components/rich-text/index.native.js +0 -4
  110. package/build/components/rich-text/index.native.js.map +1 -1
  111. package/build/components/url-input/index.js +11 -4
  112. package/build/components/url-input/index.js.map +1 -1
  113. package/build/components/use-block-display-information/index.js +3 -1
  114. package/build/components/use-block-display-information/index.js.map +1 -1
  115. package/build/components/use-block-drop-zone/index.native.js +167 -0
  116. package/build/components/use-block-drop-zone/index.native.js.map +1 -0
  117. package/build/components/use-on-block-drop/index.native.js +95 -0
  118. package/build/components/use-on-block-drop/index.native.js.map +1 -0
  119. package/build/components/use-setting/index.js +42 -18
  120. package/build/components/use-setting/index.js.map +1 -1
  121. package/build/hooks/anchor.js.map +1 -1
  122. package/build/hooks/border.js +463 -44
  123. package/build/hooks/border.js.map +1 -1
  124. package/build/hooks/color-panel.js +14 -7
  125. package/build/hooks/color-panel.js.map +1 -1
  126. package/build/hooks/dimensions.js +2 -2
  127. package/build/hooks/dimensions.js.map +1 -1
  128. package/build/hooks/index.js +3 -1
  129. package/build/hooks/index.js.map +1 -1
  130. package/build/hooks/margin.js +64 -12
  131. package/build/hooks/margin.js.map +1 -1
  132. package/build/hooks/padding.js +60 -12
  133. package/build/hooks/padding.js.map +1 -1
  134. package/build/hooks/settings.js +32 -0
  135. package/build/hooks/settings.js.map +1 -0
  136. package/build/hooks/style.js +14 -13
  137. package/build/hooks/style.js.map +1 -1
  138. package/build/hooks/typography.js +6 -2
  139. package/build/hooks/typography.js.map +1 -1
  140. package/build/hooks/use-border-props.js +22 -32
  141. package/build/hooks/use-border-props.js.map +1 -1
  142. package/build/store/actions.js +14 -2
  143. package/build/store/actions.js.map +1 -1
  144. package/build/store/defaults.js +0 -1
  145. package/build/store/defaults.js.map +1 -1
  146. package/build/store/reducer.js +0 -26
  147. package/build/store/reducer.js.map +1 -1
  148. package/build/store/selectors.js +47 -15
  149. package/build/store/selectors.js.map +1 -1
  150. package/build-module/components/block-alignment-control/constants.js +36 -0
  151. package/build-module/components/block-alignment-control/constants.js.map +1 -0
  152. package/build-module/components/block-alignment-control/ui.js +4 -35
  153. package/build-module/components/block-alignment-control/ui.js.map +1 -1
  154. package/build-module/components/block-alignment-control/ui.native.js +78 -0
  155. package/build-module/components/block-alignment-control/ui.native.js.map +1 -0
  156. package/build-module/components/block-alignment-matrix-control/index.js +1 -6
  157. package/build-module/components/block-alignment-matrix-control/index.js.map +1 -1
  158. package/build-module/components/block-content-overlay/index.js +4 -70
  159. package/build-module/components/block-content-overlay/index.js.map +1 -1
  160. package/build-module/components/block-draggable/draggable-chip.native.js +50 -0
  161. package/build-module/components/block-draggable/draggable-chip.native.js.map +1 -0
  162. package/build-module/components/block-draggable/dropping-insertion-point.native.js +137 -0
  163. package/build-module/components/block-draggable/dropping-insertion-point.native.js.map +1 -0
  164. package/build-module/components/block-draggable/index.native.js +449 -0
  165. package/build-module/components/block-draggable/index.native.js.map +1 -0
  166. package/build-module/components/block-draggable/use-scroll-when-dragging.native.js +120 -0
  167. package/build-module/components/block-draggable/use-scroll-when-dragging.native.js.map +1 -0
  168. package/build-module/components/block-list/block-list-context.native.js +179 -0
  169. package/build-module/components/block-list/block-list-context.native.js.map +1 -0
  170. package/build-module/components/block-list/block-list-item-cell.native.js +59 -0
  171. package/build-module/components/block-list/block-list-item-cell.native.js.map +1 -0
  172. package/build-module/components/block-list/block-list-item.native.js +12 -9
  173. package/build-module/components/block-list/block-list-item.native.js.map +1 -1
  174. package/build-module/components/block-list/block.native.js +28 -6
  175. package/build-module/components/block-list/block.native.js.map +1 -1
  176. package/build-module/components/block-list/index.native.js +72 -23
  177. package/build-module/components/block-list/index.native.js.map +1 -1
  178. package/build-module/components/block-list/use-block-props/index.js +9 -5
  179. package/build-module/components/block-list/use-block-props/index.js.map +1 -1
  180. package/build-module/components/block-list/use-block-props/use-block-class-names.js +1 -7
  181. package/build-module/components/block-list/use-block-props/use-block-class-names.js.map +1 -1
  182. package/build-module/components/block-list/use-in-between-inserter.js +1 -1
  183. package/build-module/components/block-list/use-in-between-inserter.js.map +1 -1
  184. package/build-module/components/block-lock/modal.js +34 -5
  185. package/build-module/components/block-lock/modal.js.map +1 -1
  186. package/build-module/components/block-lock/toolbar.js +2 -1
  187. package/build-module/components/block-lock/toolbar.js.map +1 -1
  188. package/build-module/components/block-lock/use-block-lock.js +4 -1
  189. package/build-module/components/block-lock/use-block-lock.js.map +1 -1
  190. package/build-module/components/block-mobile-toolbar/index.native.js +8 -3
  191. package/build-module/components/block-mobile-toolbar/index.native.js.map +1 -1
  192. package/build-module/components/block-mover/button.js +5 -5
  193. package/build-module/components/block-mover/button.js.map +1 -1
  194. package/build-module/components/block-mover/index.js +38 -63
  195. package/build-module/components/block-mover/index.js.map +1 -1
  196. package/build-module/components/block-mover/index.native.js +18 -5
  197. package/build-module/components/block-mover/index.native.js.map +1 -1
  198. package/build-module/components/block-navigation/dropdown.js +10 -5
  199. package/build-module/components/block-navigation/dropdown.js.map +1 -1
  200. package/build-module/components/block-popover/inbetween.js +173 -0
  201. package/build-module/components/block-popover/inbetween.js.map +1 -0
  202. package/build-module/components/block-popover/index.js +72 -0
  203. package/build-module/components/block-popover/index.js.map +1 -0
  204. package/build-module/components/{block-tools → block-popover}/use-popover-scroll.js +3 -1
  205. package/build-module/components/block-popover/use-popover-scroll.js.map +1 -0
  206. package/build-module/components/block-preview/index.js +1 -1
  207. package/build-module/components/block-preview/index.js.map +1 -1
  208. package/build-module/components/block-styles/index.js +1 -9
  209. package/build-module/components/block-styles/index.js.map +1 -1
  210. package/build-module/components/block-tools/back-compat.js +1 -1
  211. package/build-module/components/block-tools/back-compat.js.map +1 -1
  212. package/build-module/components/block-tools/block-selection-button.js +3 -2
  213. package/build-module/components/block-tools/block-selection-button.js.map +1 -1
  214. package/build-module/components/block-tools/index.js +3 -3
  215. package/build-module/components/block-tools/index.js.map +1 -1
  216. package/build-module/components/block-tools/insertion-point.js +16 -121
  217. package/build-module/components/block-tools/insertion-point.js.map +1 -1
  218. package/build-module/components/block-tools/selected-block-popover.js +199 -0
  219. package/build-module/components/block-tools/selected-block-popover.js.map +1 -0
  220. package/build-module/components/border-radius-control/input-controls.js +11 -4
  221. package/build-module/components/border-radius-control/input-controls.js.map +1 -1
  222. package/build-module/components/color-style-selector/index.js +6 -0
  223. package/build-module/components/color-style-selector/index.js.map +1 -1
  224. package/build-module/components/colors-gradients/dropdown.js +151 -46
  225. package/build-module/components/colors-gradients/dropdown.js.map +1 -1
  226. package/build-module/components/duotone-control/index.js +4 -1
  227. package/build-module/components/duotone-control/index.js.map +1 -1
  228. package/build-module/components/image-editor/use-save-image.js +2 -1
  229. package/build-module/components/image-editor/use-save-image.js.map +1 -1
  230. package/build-module/components/index.js +1 -3
  231. package/build-module/components/index.js.map +1 -1
  232. package/build-module/components/inserter/index.native.js +32 -11
  233. package/build-module/components/inserter/index.native.js.map +1 -1
  234. package/build-module/components/link-control/constants.js +5 -0
  235. package/build-module/components/link-control/constants.js.map +1 -1
  236. package/build-module/components/link-control/search-results.js +3 -4
  237. package/build-module/components/link-control/search-results.js.map +1 -1
  238. package/build-module/components/link-control/use-search-handler.js +5 -5
  239. package/build-module/components/link-control/use-search-handler.js.map +1 -1
  240. package/build-module/components/list-view/block.js +15 -16
  241. package/build-module/components/list-view/block.js.map +1 -1
  242. package/build-module/components/list-view/branch.js +9 -13
  243. package/build-module/components/list-view/branch.js.map +1 -1
  244. package/build-module/components/list-view/context.js +1 -4
  245. package/build-module/components/list-view/context.js.map +1 -1
  246. package/build-module/components/list-view/drop-indicator.js +0 -1
  247. package/build-module/components/list-view/drop-indicator.js.map +1 -1
  248. package/build-module/components/list-view/index.js +15 -31
  249. package/build-module/components/list-view/index.js.map +1 -1
  250. package/build-module/components/navigable-toolbar/index.js +12 -2
  251. package/build-module/components/navigable-toolbar/index.js.map +1 -1
  252. package/build-module/components/rich-text/format-toolbar-container.js +0 -1
  253. package/build-module/components/rich-text/format-toolbar-container.js.map +1 -1
  254. package/build-module/components/rich-text/index.js +1 -5
  255. package/build-module/components/rich-text/index.js.map +1 -1
  256. package/build-module/components/rich-text/index.native.js +0 -4
  257. package/build-module/components/rich-text/index.native.js.map +1 -1
  258. package/build-module/components/url-input/index.js +11 -4
  259. package/build-module/components/url-input/index.js.map +1 -1
  260. package/build-module/components/use-block-display-information/index.js +3 -1
  261. package/build-module/components/use-block-display-information/index.js.map +1 -1
  262. package/build-module/components/use-block-drop-zone/index.native.js +148 -0
  263. package/build-module/components/use-block-drop-zone/index.native.js.map +1 -0
  264. package/build-module/components/use-on-block-drop/index.native.js +83 -0
  265. package/build-module/components/use-on-block-drop/index.native.js.map +1 -0
  266. package/build-module/components/use-setting/index.js +43 -19
  267. package/build-module/components/use-setting/index.js.map +1 -1
  268. package/build-module/hooks/anchor.js.map +1 -1
  269. package/build-module/hooks/border.js +453 -44
  270. package/build-module/hooks/border.js.map +1 -1
  271. package/build-module/hooks/color-panel.js +11 -6
  272. package/build-module/hooks/color-panel.js.map +1 -1
  273. package/build-module/hooks/dimensions.js +5 -5
  274. package/build-module/hooks/dimensions.js.map +1 -1
  275. package/build-module/hooks/index.js +2 -1
  276. package/build-module/hooks/index.js.map +1 -1
  277. package/build-module/hooks/margin.js +61 -13
  278. package/build-module/hooks/margin.js.map +1 -1
  279. package/build-module/hooks/padding.js +57 -13
  280. package/build-module/hooks/padding.js.map +1 -1
  281. package/build-module/hooks/settings.js +29 -0
  282. package/build-module/hooks/settings.js.map +1 -0
  283. package/build-module/hooks/style.js +15 -14
  284. package/build-module/hooks/style.js.map +1 -1
  285. package/build-module/hooks/typography.js +6 -2
  286. package/build-module/hooks/typography.js.map +1 -1
  287. package/build-module/hooks/use-border-props.js +21 -30
  288. package/build-module/hooks/use-border-props.js.map +1 -1
  289. package/build-module/store/actions.js +14 -2
  290. package/build-module/store/actions.js.map +1 -1
  291. package/build-module/store/defaults.js +0 -1
  292. package/build-module/store/defaults.js.map +1 -1
  293. package/build-module/store/reducer.js +0 -24
  294. package/build-module/store/reducer.js.map +1 -1
  295. package/build-module/store/selectors.js +44 -15
  296. package/build-module/store/selectors.js.map +1 -1
  297. package/build-style/style-rtl.css +148 -410
  298. package/build-style/style.css +148 -410
  299. package/package.json +28 -28
  300. package/src/components/block-alignment-control/constants.js +45 -0
  301. package/src/components/block-alignment-control/ui.js +69 -109
  302. package/src/components/block-alignment-control/ui.native.js +86 -0
  303. package/src/components/block-alignment-matrix-control/index.js +1 -5
  304. package/src/components/block-content-overlay/index.js +9 -79
  305. package/src/components/block-content-overlay/style.scss +2 -11
  306. package/src/components/block-draggable/draggable-chip.native.js +49 -0
  307. package/src/components/block-draggable/dropping-insertion-point.native.js +181 -0
  308. package/src/components/block-draggable/dropping-insertion-point.native.scss +8 -0
  309. package/src/components/block-draggable/index.native.js +458 -0
  310. package/src/components/block-draggable/style.native.scss +19 -0
  311. package/src/components/block-draggable/use-scroll-when-dragging.native.js +135 -0
  312. package/src/components/block-list/block-list-context.native.js +175 -0
  313. package/src/components/block-list/block-list-item-cell.native.js +49 -0
  314. package/src/components/block-list/block-list-item.native.js +7 -11
  315. package/src/components/block-list/block.native.js +38 -8
  316. package/src/components/block-list/index.native.js +54 -13
  317. package/src/components/block-list/style.scss +7 -18
  318. package/src/components/block-list/test/block-list-context.native.js +253 -0
  319. package/src/components/block-list/test/fixtures/block-list-context.native.js +79 -0
  320. package/src/components/block-list/use-block-props/index.js +10 -5
  321. package/src/components/block-list/use-block-props/use-block-class-names.js +1 -11
  322. package/src/components/block-list/use-in-between-inserter.js +1 -1
  323. package/src/components/block-lock/modal.js +42 -3
  324. package/src/components/block-lock/toolbar.js +2 -2
  325. package/src/components/block-lock/use-block-lock.js +4 -1
  326. package/src/components/block-mobile-toolbar/index.native.js +8 -1
  327. package/src/components/block-mover/button.js +5 -7
  328. package/src/components/block-mover/index.js +37 -60
  329. package/src/components/block-mover/index.native.js +22 -6
  330. package/src/components/block-mover/stories/index.js +110 -0
  331. package/src/components/block-mover/style.scss +48 -138
  332. package/src/components/block-mover/test/__snapshots__/index.native.js.snap +6 -0
  333. package/src/components/block-navigation/dropdown.js +12 -8
  334. package/src/components/block-popover/README.md +41 -0
  335. package/src/components/block-popover/inbetween.js +188 -0
  336. package/src/components/block-popover/index.js +75 -0
  337. package/src/components/block-popover/style.scss +28 -0
  338. package/src/components/{block-tools → block-popover}/use-popover-scroll.js +3 -1
  339. package/src/components/block-preview/index.js +1 -4
  340. package/src/components/block-styles/index.js +1 -12
  341. package/src/components/block-switcher/style.scss +2 -43
  342. package/src/components/block-toolbar/style.scss +0 -12
  343. package/src/components/block-tools/back-compat.js +1 -1
  344. package/src/components/block-tools/block-selection-button.js +3 -1
  345. package/src/components/block-tools/index.js +6 -4
  346. package/src/components/block-tools/insertion-point.js +19 -152
  347. package/src/components/block-tools/{block-popover.js → selected-block-popover.js} +24 -151
  348. package/src/components/block-tools/style.scss +12 -135
  349. package/src/components/border-radius-control/input-controls.js +16 -8
  350. package/src/components/border-radius-control/style.scss +7 -3
  351. package/src/components/color-palette/test/__snapshots__/control.js.snap +1 -1
  352. package/src/components/color-style-selector/index.js +18 -9
  353. package/src/components/colors-gradients/dropdown.js +156 -62
  354. package/src/components/colors-gradients/style.scss +51 -23
  355. package/src/components/default-block-appender/style.scss +1 -2
  356. package/src/components/duotone-control/index.js +8 -1
  357. package/src/components/duotone-control/style.scss +1 -7
  358. package/src/components/gradients/README.md +29 -0
  359. package/src/components/image-editor/use-save-image.js +2 -1
  360. package/src/components/image-size-control/README.md +1 -1
  361. package/src/components/index.js +1 -3
  362. package/src/components/inserter/index.native.js +60 -25
  363. package/src/components/inserter/style.native.scss +25 -3
  364. package/src/components/inserter/style.scss +2 -1
  365. package/src/components/link-control/constants.js +11 -0
  366. package/src/components/link-control/search-results.js +4 -5
  367. package/src/components/link-control/use-search-handler.js +11 -5
  368. package/src/components/list-view/block.js +24 -34
  369. package/src/components/list-view/branch.js +10 -20
  370. package/src/components/list-view/context.js +1 -4
  371. package/src/components/list-view/drop-indicator.js +0 -1
  372. package/src/components/list-view/index.js +11 -41
  373. package/src/components/list-view/style.scss +2 -1
  374. package/src/components/navigable-toolbar/README.md +16 -0
  375. package/src/components/navigable-toolbar/index.js +12 -2
  376. package/src/components/preview-options/style.scss +0 -4
  377. package/src/components/rich-text/format-toolbar-container.js +0 -1
  378. package/src/components/rich-text/index.js +1 -3
  379. package/src/components/rich-text/index.native.js +0 -4
  380. package/src/components/rich-text/style.scss +2 -8
  381. package/src/components/url-input/index.js +9 -4
  382. package/src/components/use-block-display-information/index.js +2 -0
  383. package/src/components/use-block-drop-zone/index.native.js +173 -0
  384. package/src/components/use-on-block-drop/index.native.js +119 -0
  385. package/src/components/use-setting/index.js +57 -21
  386. package/src/hooks/anchor.js +1 -1
  387. package/src/hooks/border.js +429 -72
  388. package/src/hooks/color-panel.js +13 -9
  389. package/src/hooks/color.scss +0 -62
  390. package/src/hooks/dimensions.js +44 -38
  391. package/src/hooks/index.js +2 -1
  392. package/src/hooks/margin.js +64 -15
  393. package/src/hooks/padding.js +60 -15
  394. package/src/hooks/padding.scss +12 -0
  395. package/src/hooks/settings.js +32 -0
  396. package/src/hooks/style.js +25 -39
  397. package/src/hooks/test/settings.js +48 -0
  398. package/src/hooks/typography.js +2 -0
  399. package/src/hooks/use-border-props.js +15 -32
  400. package/src/store/actions.js +14 -2
  401. package/src/store/defaults.js +0 -1
  402. package/src/store/reducer.js +0 -21
  403. package/src/store/selectors.js +46 -15
  404. package/src/store/test/actions.js +0 -18
  405. package/src/store/test/reducer.js +0 -19
  406. package/src/store/test/selectors.js +17 -19
  407. package/src/style.scss +2 -3
  408. package/tsconfig.tsbuildinfo +1 -1
  409. package/build/components/block-mobile-toolbar/index.js +0 -42
  410. package/build/components/block-mobile-toolbar/index.js.map +0 -1
  411. package/build/components/block-tools/block-popover.js +0 -327
  412. package/build/components/block-tools/block-popover.js.map +0 -1
  413. package/build/components/block-tools/use-popover-scroll.js.map +0 -1
  414. package/build/components/border-style-control/index.js +0 -60
  415. package/build/components/border-style-control/index.js.map +0 -1
  416. package/build/components/colors-gradients/tools-panel-color-dropdown.js +0 -89
  417. package/build/components/colors-gradients/tools-panel-color-dropdown.js.map +0 -1
  418. package/build/components/list-view/appender.js +0 -93
  419. package/build/components/list-view/appender.js.map +0 -1
  420. package/build/components/list-view/list-item.js +0 -62
  421. package/build/components/list-view/list-item.js.map +0 -1
  422. package/build/components/rich-text/use-caret-in-format.js +0 -43
  423. package/build/components/rich-text/use-caret-in-format.js.map +0 -1
  424. package/build/hooks/border-color.js +0 -302
  425. package/build/hooks/border-color.js.map +0 -1
  426. package/build/hooks/border-style.js +0 -96
  427. package/build/hooks/border-style.js.map +0 -1
  428. package/build/hooks/border-width.js +0 -162
  429. package/build/hooks/border-width.js.map +0 -1
  430. package/build-module/components/block-mobile-toolbar/index.js +0 -31
  431. package/build-module/components/block-mobile-toolbar/index.js.map +0 -1
  432. package/build-module/components/block-tools/block-popover.js +0 -306
  433. package/build-module/components/block-tools/block-popover.js.map +0 -1
  434. package/build-module/components/block-tools/use-popover-scroll.js.map +0 -1
  435. package/build-module/components/border-style-control/index.js +0 -50
  436. package/build-module/components/border-style-control/index.js.map +0 -1
  437. package/build-module/components/colors-gradients/tools-panel-color-dropdown.js +0 -75
  438. package/build-module/components/colors-gradients/tools-panel-color-dropdown.js.map +0 -1
  439. package/build-module/components/list-view/appender.js +0 -76
  440. package/build-module/components/list-view/appender.js.map +0 -1
  441. package/build-module/components/list-view/list-item.js +0 -47
  442. package/build-module/components/list-view/list-item.js.map +0 -1
  443. package/build-module/components/rich-text/use-caret-in-format.js +0 -33
  444. package/build-module/components/rich-text/use-caret-in-format.js.map +0 -1
  445. package/build-module/hooks/border-color.js +0 -276
  446. package/build-module/hooks/border-color.js.map +0 -1
  447. package/build-module/hooks/border-style.js +0 -78
  448. package/build-module/hooks/border-style.js.map +0 -1
  449. package/build-module/hooks/border-width.js +0 -143
  450. package/build-module/hooks/border-width.js.map +0 -1
  451. package/src/components/block-alignment-matrix-control/style.scss +0 -10
  452. package/src/components/block-mobile-toolbar/index.js +0 -24
  453. package/src/components/block-mobile-toolbar/style.scss +0 -29
  454. package/src/components/border-style-control/index.js +0 -47
  455. package/src/components/border-style-control/style.scss +0 -18
  456. package/src/components/colors-gradients/tools-panel-color-dropdown.js +0 -85
  457. package/src/components/list-view/appender.js +0 -82
  458. package/src/components/list-view/list-item.js +0 -59
  459. package/src/components/rich-text/use-caret-in-format.js +0 -28
  460. package/src/hooks/border-color.js +0 -315
  461. package/src/hooks/border-style.js +0 -64
  462. package/src/hooks/border-width.js +0 -139
@@ -1,315 +0,0 @@
1
- /**
2
- * External dependencies
3
- */
4
- import classnames from 'classnames';
5
-
6
- /**
7
- * WordPress dependencies
8
- */
9
- import { addFilter } from '@wordpress/hooks';
10
- import { __ } from '@wordpress/i18n';
11
- import { createHigherOrderComponent } from '@wordpress/compose';
12
- import { useEffect, useState } from '@wordpress/element';
13
-
14
- /**
15
- * Internal dependencies
16
- */
17
- import ColorGradientSettingsDropdown from '../components/colors-gradients/dropdown';
18
- import useMultipleOriginColorsAndGradients from '../components/colors-gradients/use-multiple-origin-colors-and-gradients';
19
- import {
20
- getColorClassName,
21
- getColorObjectByColorValue,
22
- getColorObjectByAttributeValues,
23
- } from '../components/colors';
24
- import useSetting from '../components/use-setting';
25
- import {
26
- BORDER_SUPPORT_KEY,
27
- hasBorderSupport,
28
- removeBorderAttribute,
29
- } from './border';
30
- import { cleanEmptyObject, shouldSkipSerialization } from './utils';
31
-
32
- // Defining empty array here instead of inline avoids unnecessary re-renders of
33
- // color control.
34
- const EMPTY_ARRAY = [];
35
-
36
- /**
37
- * Inspector control panel containing the border color related configuration.
38
- *
39
- * There is deliberate overlap between the colors and borders block supports
40
- * relating to border color. It can be argued the border color controls could
41
- * be included within either, or both, the colors and borders panels in the
42
- * inspector controls. If they share the same block attributes it should not
43
- * matter.
44
- *
45
- * @param {Object} props Block properties.
46
- *
47
- * @return {WPElement} Border color edit element.
48
- */
49
- export function BorderColorEdit( props ) {
50
- const {
51
- attributes: { borderColor, style },
52
- setAttributes,
53
- } = props;
54
- const colorGradientSettings = useMultipleOriginColorsAndGradients();
55
- const availableColors = colorGradientSettings.colors.reduce(
56
- ( colors, origin ) => colors.concat( origin.colors ),
57
- []
58
- );
59
- const { color: customBorderColor } = style?.border || {};
60
- const [ colorValue, setColorValue ] = useState(
61
- () =>
62
- getColorObjectByAttributeValues(
63
- availableColors,
64
- borderColor,
65
- customBorderColor
66
- )?.color
67
- );
68
-
69
- // Detect changes in the color attributes and update the colorValue to keep the
70
- // UI in sync. This is necessary for situations when border controls interact with
71
- // each other: eg, setting the border width to zero causes the color and style
72
- // selections to be cleared.
73
- useEffect( () => {
74
- setColorValue(
75
- getColorObjectByAttributeValues(
76
- availableColors,
77
- borderColor,
78
- customBorderColor
79
- )?.color
80
- );
81
- }, [ borderColor, customBorderColor, availableColors ] );
82
-
83
- const onChangeColor = ( value ) => {
84
- setColorValue( value );
85
-
86
- const colorObject = getColorObjectByColorValue(
87
- availableColors,
88
- value
89
- );
90
- const newStyle = {
91
- ...style,
92
- border: {
93
- ...style?.border,
94
- color: colorObject?.slug ? undefined : value,
95
- },
96
- };
97
-
98
- // If empty slug, ensure undefined to remove attribute.
99
- const newNamedColor = colorObject?.slug ? colorObject.slug : undefined;
100
-
101
- setAttributes( {
102
- style: cleanEmptyObject( newStyle ),
103
- borderColor: newNamedColor,
104
- } );
105
- };
106
-
107
- const settings = [
108
- {
109
- label: __( 'Color' ),
110
- onColorChange: onChangeColor,
111
- colorValue,
112
- clearable: false,
113
- },
114
- ];
115
- return (
116
- <ColorGradientSettingsDropdown
117
- settings={ settings }
118
- disableCustomColors
119
- disableCustomGradients
120
- __experimentalHasMultipleOrigins
121
- __experimentalIsRenderedInSidebar
122
- enableAlpha
123
- { ...colorGradientSettings }
124
- />
125
- );
126
- }
127
-
128
- /**
129
- * Checks if there is a current value in the border color block support
130
- * attributes.
131
- *
132
- * @param {Object} props Block props.
133
- * @return {boolean} Whether or not the block has a border color value set.
134
- */
135
- export function hasBorderColorValue( props ) {
136
- const {
137
- attributes: { borderColor, style },
138
- } = props;
139
-
140
- return !! borderColor || !! style?.border?.color;
141
- }
142
-
143
- /**
144
- * Resets the border color block support attributes. This can be used when
145
- * disabling the border color support controls for a block via a progressive
146
- * discovery panel.
147
- *
148
- * @param {Object} props Block props.
149
- * @param {Object} props.attributes Block's attributes.
150
- * @param {Object} props.setAttributes Function to set block's attributes.
151
- */
152
- export function resetBorderColor( { attributes = {}, setAttributes } ) {
153
- const { style } = attributes;
154
-
155
- setAttributes( {
156
- borderColor: undefined,
157
- style: removeBorderAttribute( style, 'color' ),
158
- } );
159
- }
160
-
161
- /**
162
- * Filters registered block settings, extending attributes to include
163
- * `borderColor` if needed.
164
- *
165
- * @param {Object} settings Original block settings.
166
- *
167
- * @return {Object} Updated block settings.
168
- */
169
- function addAttributes( settings ) {
170
- if ( ! hasBorderSupport( settings, 'color' ) ) {
171
- return settings;
172
- }
173
-
174
- // Allow blocks to specify default value if needed.
175
- if ( settings.attributes.borderColor ) {
176
- return settings;
177
- }
178
-
179
- // Add new borderColor attribute to block settings.
180
- return {
181
- ...settings,
182
- attributes: {
183
- ...settings.attributes,
184
- borderColor: {
185
- type: 'string',
186
- },
187
- },
188
- };
189
- }
190
-
191
- /**
192
- * Override props assigned to save component to inject border color.
193
- *
194
- * @param {Object} props Additional props applied to save element.
195
- * @param {Object} blockType Block type definition.
196
- * @param {Object} attributes Block's attributes.
197
- *
198
- * @return {Object} Filtered props to apply to save element.
199
- */
200
- function addSaveProps( props, blockType, attributes ) {
201
- if (
202
- ! hasBorderSupport( blockType, 'color' ) ||
203
- shouldSkipSerialization( blockType, BORDER_SUPPORT_KEY, 'color' )
204
- ) {
205
- return props;
206
- }
207
-
208
- const { borderColor, style } = attributes;
209
- const borderColorClass = getColorClassName( 'border-color', borderColor );
210
-
211
- const newClassName = classnames( props.className, {
212
- 'has-border-color': borderColor || style?.border?.color,
213
- [ borderColorClass ]: !! borderColorClass,
214
- } );
215
-
216
- // If we are clearing the last of the previous classes in `className`
217
- // set it to `undefined` to avoid rendering empty DOM attributes.
218
- props.className = newClassName ? newClassName : undefined;
219
-
220
- return props;
221
- }
222
-
223
- /**
224
- * Filters the registered block settings to apply border color styles and
225
- * classnames to the block edit wrapper.
226
- *
227
- * @param {Object} settings Original block settings.
228
- *
229
- * @return {Object} Filtered block settings.
230
- */
231
- function addEditProps( settings ) {
232
- if (
233
- ! hasBorderSupport( settings, 'color' ) ||
234
- shouldSkipSerialization( settings, BORDER_SUPPORT_KEY, 'color' )
235
- ) {
236
- return settings;
237
- }
238
-
239
- const existingGetEditWrapperProps = settings.getEditWrapperProps;
240
- settings.getEditWrapperProps = ( attributes ) => {
241
- let props = {};
242
-
243
- if ( existingGetEditWrapperProps ) {
244
- props = existingGetEditWrapperProps( attributes );
245
- }
246
-
247
- return addSaveProps( props, settings, attributes );
248
- };
249
-
250
- return settings;
251
- }
252
-
253
- /**
254
- * This adds inline styles for color palette colors.
255
- * Ideally, this is not needed and themes should load their palettes on the editor.
256
- *
257
- * @param {Function} BlockListBlock Original component.
258
- *
259
- * @return {Function} Wrapped component.
260
- */
261
- export const withBorderColorPaletteStyles = createHigherOrderComponent(
262
- ( BlockListBlock ) => ( props ) => {
263
- const { name, attributes } = props;
264
- const { borderColor } = attributes;
265
- const colors = useSetting( 'color.palette' ) || EMPTY_ARRAY;
266
-
267
- if (
268
- ! hasBorderSupport( name, 'color' ) ||
269
- shouldSkipSerialization( name, BORDER_SUPPORT_KEY, 'color' )
270
- ) {
271
- return <BlockListBlock { ...props } />;
272
- }
273
-
274
- const extraStyles = {
275
- borderColor: borderColor
276
- ? getColorObjectByAttributeValues( colors, borderColor )?.color
277
- : undefined,
278
- };
279
-
280
- let wrapperProps = props.wrapperProps;
281
- wrapperProps = {
282
- ...props.wrapperProps,
283
- style: {
284
- ...extraStyles,
285
- ...props.wrapperProps?.style,
286
- },
287
- };
288
-
289
- return <BlockListBlock { ...props } wrapperProps={ wrapperProps } />;
290
- }
291
- );
292
-
293
- addFilter(
294
- 'blocks.registerBlockType',
295
- 'core/border/addAttributes',
296
- addAttributes
297
- );
298
-
299
- addFilter(
300
- 'blocks.getSaveContent.extraProps',
301
- 'core/border/addSaveProps',
302
- addSaveProps
303
- );
304
-
305
- addFilter(
306
- 'blocks.registerBlockType',
307
- 'core/border/addEditProps',
308
- addEditProps
309
- );
310
-
311
- addFilter(
312
- 'editor.BlockListBlock',
313
- 'core/border/with-border-color-palette-styles',
314
- withBorderColorPaletteStyles
315
- );
@@ -1,64 +0,0 @@
1
- /**
2
- * Internal dependencies
3
- */
4
- import BorderStyleControl from '../components/border-style-control';
5
- import { cleanEmptyObject } from './utils';
6
- import { removeBorderAttribute } from './border';
7
-
8
- /**
9
- * Inspector control for configuring border style property.
10
- *
11
- * @param {Object} props Block properties.
12
- *
13
- * @return {WPElement} Border style edit element.
14
- */
15
- export const BorderStyleEdit = ( props ) => {
16
- const {
17
- attributes: { style },
18
- setAttributes,
19
- } = props;
20
-
21
- const onChange = ( newBorderStyle ) => {
22
- const newStyleAttributes = {
23
- ...style,
24
- border: {
25
- ...style?.border,
26
- style: newBorderStyle,
27
- },
28
- };
29
-
30
- setAttributes( { style: cleanEmptyObject( newStyleAttributes ) } );
31
- };
32
-
33
- return (
34
- <BorderStyleControl
35
- value={ style?.border?.style }
36
- onChange={ onChange }
37
- />
38
- );
39
- };
40
-
41
- /**
42
- * Checks if there is a current value in the border style block support
43
- * attributes.
44
- *
45
- * @param {Object} props Block props.
46
- * @return {boolean} Whether or not the block has a border style value set.
47
- */
48
- export function hasBorderStyleValue( props ) {
49
- return !! props.attributes.style?.border?.style;
50
- }
51
-
52
- /**
53
- * Resets the border style block support attribute. This can be used when
54
- * disabling the border style support control for a block via a progressive
55
- * discovery panel.
56
- *
57
- * @param {Object} props Block props.
58
- * @param {Object} props.attributes Block's attributes.
59
- * @param {Object} props.setAttributes Function to set block's attributes.
60
- */
61
- export function resetBorderStyle( { attributes = {}, setAttributes } ) {
62
- const { style } = attributes;
63
- setAttributes( { style: removeBorderAttribute( style, 'style' ) } );
64
- }
@@ -1,139 +0,0 @@
1
- /**
2
- * WordPress dependencies
3
- */
4
- import {
5
- __experimentalUnitControl as UnitControl,
6
- __experimentalUseCustomUnits as useCustomUnits,
7
- } from '@wordpress/components';
8
- import { useState } from '@wordpress/element';
9
- import { __ } from '@wordpress/i18n';
10
-
11
- /**
12
- * Internal dependencies
13
- */
14
- import { cleanEmptyObject } from './utils';
15
- import { removeBorderAttribute } from './border';
16
- import useSetting from '../components/use-setting';
17
-
18
- const MIN_BORDER_WIDTH = 0;
19
-
20
- /**
21
- * Inspector control for configuring border width property.
22
- *
23
- * @param {Object} props Block properties.
24
- *
25
- * @return {WPElement} Border width edit element.
26
- */
27
- export const BorderWidthEdit = ( props ) => {
28
- const {
29
- attributes: { borderColor, style },
30
- setAttributes,
31
- } = props;
32
-
33
- const { width, color: customBorderColor, style: borderStyle } =
34
- style?.border || {};
35
-
36
- // Used to temporarily track previous border color & style selections to be
37
- // able to restore them when border width changes from zero value.
38
- const [ styleSelection, setStyleSelection ] = useState();
39
- const [ colorSelection, setColorSelection ] = useState();
40
- const [ customColorSelection, setCustomColorSelection ] = useState();
41
-
42
- const onChange = ( newWidth ) => {
43
- let newStyle = {
44
- ...style,
45
- border: {
46
- ...style?.border,
47
- width: newWidth,
48
- },
49
- };
50
-
51
- // Used to clear named border color attribute.
52
- let borderPaletteColor = borderColor;
53
-
54
- const hasZeroWidth = parseFloat( newWidth ) === 0;
55
- const hadPreviousZeroWidth = parseFloat( width ) === 0;
56
-
57
- // Setting the border width explicitly to zero will also set the
58
- // border style to `none` and clear border color attributes.
59
- if ( hasZeroWidth && ! hadPreviousZeroWidth ) {
60
- // Before clearing color and style selections, keep track of
61
- // the current selections so they can be restored when the width
62
- // changes to a non-zero value.
63
- setColorSelection( borderColor );
64
- setCustomColorSelection( customBorderColor );
65
- setStyleSelection( borderStyle );
66
-
67
- // Clear style and color attributes.
68
- borderPaletteColor = undefined;
69
- newStyle.border.color = undefined;
70
- newStyle.border.style = 'none';
71
- }
72
-
73
- if ( ! hasZeroWidth && hadPreviousZeroWidth ) {
74
- // Restore previous border style selection if width is now not zero and
75
- // border style was 'none'. This is to support changes to the UI which
76
- // change the border style UI to a segmented control without a "none"
77
- // option.
78
- if ( borderStyle === 'none' ) {
79
- newStyle.border.style = styleSelection;
80
- }
81
-
82
- // Restore previous border color selection if width is no longer zero
83
- // and current border color is undefined.
84
- if ( borderColor === undefined ) {
85
- borderPaletteColor = colorSelection;
86
- newStyle.border.color = customColorSelection;
87
- }
88
- }
89
-
90
- // If width was reset, clean out undefined styles.
91
- if ( newWidth === undefined || newWidth === '' ) {
92
- newStyle = cleanEmptyObject( newStyle );
93
- }
94
-
95
- setAttributes( {
96
- borderColor: borderPaletteColor,
97
- style: newStyle,
98
- } );
99
- };
100
-
101
- const units = useCustomUnits( {
102
- availableUnits: useSetting( 'spacing.units' ) || [ 'px', 'em', 'rem' ],
103
- } );
104
-
105
- return (
106
- <UnitControl
107
- value={ width }
108
- label={ __( 'Width' ) }
109
- min={ MIN_BORDER_WIDTH }
110
- onChange={ onChange }
111
- units={ units }
112
- />
113
- );
114
- };
115
-
116
- /**
117
- * Checks if there is a current value in the border width block support
118
- * attributes.
119
- *
120
- * @param {Object} props Block props.
121
- * @return {boolean} Whether or not the block has a border width value set.
122
- */
123
- export function hasBorderWidthValue( props ) {
124
- return !! props.attributes.style?.border?.width;
125
- }
126
-
127
- /**
128
- * Resets the border width block support attribute. This can be used when
129
- * disabling the border width support control for a block via a progressive
130
- * discovery panel.
131
- *
132
- * @param {Object} props Block props.
133
- * @param {Object} props.attributes Block's attributes.
134
- * @param {Object} props.setAttributes Function to set block's attributes.
135
- */
136
- export function resetBorderWidth( { attributes = {}, setAttributes } ) {
137
- const { style } = attributes;
138
- setAttributes( { style: removeBorderAttribute( style, 'width' ) } );
139
- }