@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/colors/utils.js"],"names":["find","kebabCase","map","tinycolor","getColorObjectByAttributeValues","colors","definedColor","customColor","colorObj","slug","color","getColorObjectByColorValue","colorValue","getColorClassName","colorContextName","colorSlug","undefined","getMostReadableColor","mostReadable","toHexString"],"mappings":"AAAA;AACA;AACA;AACA,SAASA,IAAT,EAAeC,SAAf,EAA0BC,GAA1B,QAAqC,QAArC;AACA,OAAOC,SAAP,MAAsB,YAAtB;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,MAAMC,+BAA+B,GAAG,CAC9CC,MAD8C,EAE9CC,YAF8C,EAG9CC,WAH8C,KAI1C;AACJ,MAAKD,YAAL,EAAoB;AACnB,UAAME,QAAQ,GAAGR,IAAI,CAAEK,MAAF,EAAU;AAAEI,MAAAA,IAAI,EAAEH;AAAR,KAAV,CAArB;;AAEA,QAAKE,QAAL,EAAgB;AACf,aAAOA,QAAP;AACA;AACD;;AACD,SAAO;AACNE,IAAAA,KAAK,EAAEH;AADD,GAAP;AAGA,CAfM;AAiBP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,MAAMI,0BAA0B,GAAG,CAAEN,MAAF,EAAUO,UAAV,KAA0B;AACnE,SAAOZ,IAAI,CAAEK,MAAF,EAAU;AAAEK,IAAAA,KAAK,EAAEE;AAAT,GAAV,CAAX;AACA,CAFM;AAIP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASC,iBAAT,CAA4BC,gBAA5B,EAA8CC,SAA9C,EAA0D;AAChE,MAAK,CAAED,gBAAF,IAAsB,CAAEC,SAA7B,EAAyC;AACxC,WAAOC,SAAP;AACA;;AAED,SAAQ,OAAOf,SAAS,CAAEc,SAAF,CAAe,IAAID,gBAAkB,EAA7D;AACA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASG,oBAAT,CAA+BZ,MAA/B,EAAuCO,UAAvC,EAAoD;AAC1D,SAAOT,SAAS,CACde,YADK,CACSN,UADT,EACqBV,GAAG,CAAEG,MAAF,EAAU,OAAV,CADxB,EAELc,WAFK,EAAP;AAGA","sourcesContent":["/**\n * External dependencies\n */\nimport { find, kebabCase, map } from 'lodash';\nimport tinycolor from 'tinycolor2';\n\n/**\n * Provided an array of color objects as set by the theme or by the editor defaults,\n * and the values of the defined color or custom color returns a color object describing the color.\n *\n * @param {Array} colors Array of color objects as set by the theme or by the editor defaults.\n * @param {?string} definedColor A string containing the color slug.\n * @param {?string} customColor A string containing the customColor value.\n *\n * @return {?Object} If definedColor is passed and the name is found in colors,\n * the color object exactly as set by the theme or editor defaults is returned.\n * Otherwise, an object that just sets the color is defined.\n */\nexport const getColorObjectByAttributeValues = (\n\tcolors,\n\tdefinedColor,\n\tcustomColor\n) => {\n\tif ( definedColor ) {\n\t\tconst colorObj = find( colors, { slug: definedColor } );\n\n\t\tif ( colorObj ) {\n\t\t\treturn colorObj;\n\t\t}\n\t}\n\treturn {\n\t\tcolor: customColor,\n\t};\n};\n\n/**\n * Provided an array of color objects as set by the theme or by the editor defaults, and a color value returns the color object matching that value or undefined.\n *\n * @param {Array} colors Array of color objects as set by the theme or by the editor defaults.\n * @param {?string} colorValue A string containing the color value.\n *\n * @return {?Object} Color object included in the colors array whose color property equals colorValue.\n * Returns undefined if no color object matches this requirement.\n */\nexport const getColorObjectByColorValue = ( colors, colorValue ) => {\n\treturn find( colors, { color: colorValue } );\n};\n\n/**\n * Returns a class based on the context a color is being used and its slug.\n *\n * @param {string} colorContextName Context/place where color is being used e.g: background, text etc...\n * @param {string} colorSlug Slug of the color.\n *\n * @return {?string} String with the class corresponding to the color in the provided context.\n * Returns undefined if either colorContextName or colorSlug are not provided.\n */\nexport function getColorClassName( colorContextName, colorSlug ) {\n\tif ( ! colorContextName || ! colorSlug ) {\n\t\treturn undefined;\n\t}\n\n\treturn `has-${ kebabCase( colorSlug ) }-${ colorContextName }`;\n}\n\n/**\n * Given an array of color objects and a color value returns the color value of the most readable color in the array.\n *\n * @param {Array} colors Array of color objects as set by the theme or by the editor defaults.\n * @param {?string} colorValue A string containing the color value.\n *\n * @return {string} String with the color value of the most readable color.\n */\nexport function getMostReadableColor( colors, colorValue ) {\n\treturn tinycolor\n\t\t.mostReadable( colorValue, map( colors, 'color' ) )\n\t\t.toHexString();\n}\n"]}
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/colors/utils.js"],"names":["find","kebabCase","maxBy","colord","extend","namesPlugin","a11yPlugin","getColorObjectByAttributeValues","colors","definedColor","customColor","colorObj","slug","color","getColorObjectByColorValue","colorValue","getColorClassName","colorContextName","colorSlug","undefined","getMostReadableColor","colordColor","contrast"],"mappings":"AAAA;AACA;AACA;AACA,SAASA,IAAT,EAAeC,SAAf,EAA0BC,KAA1B,QAAuC,QAAvC;AACA,SAASC,MAAT,EAAiBC,MAAjB,QAA+B,QAA/B;AACA,OAAOC,WAAP,MAAwB,sBAAxB;AACA,OAAOC,UAAP,MAAuB,qBAAvB;AAEAF,MAAM,CAAE,CAAEC,WAAF,EAAeC,UAAf,CAAF,CAAN;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,MAAMC,+BAA+B,GAAG,CAC9CC,MAD8C,EAE9CC,YAF8C,EAG9CC,WAH8C,KAI1C;AACJ,MAAKD,YAAL,EAAoB;AACnB,UAAME,QAAQ,GAAGX,IAAI,CAAEQ,MAAF,EAAU;AAAEI,MAAAA,IAAI,EAAEH;AAAR,KAAV,CAArB;;AAEA,QAAKE,QAAL,EAAgB;AACf,aAAOA,QAAP;AACA;AACD;;AACD,SAAO;AACNE,IAAAA,KAAK,EAAEH;AADD,GAAP;AAGA,CAfM;AAiBP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,MAAMI,0BAA0B,GAAG,CAAEN,MAAF,EAAUO,UAAV,KAA0B;AACnE,SAAOf,IAAI,CAAEQ,MAAF,EAAU;AAAEK,IAAAA,KAAK,EAAEE;AAAT,GAAV,CAAX;AACA,CAFM;AAIP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASC,iBAAT,CAA4BC,gBAA5B,EAA8CC,SAA9C,EAA0D;AAChE,MAAK,CAAED,gBAAF,IAAsB,CAAEC,SAA7B,EAAyC;AACxC,WAAOC,SAAP;AACA;;AAED,SAAQ,OAAOlB,SAAS,CAAEiB,SAAF,CAAe,IAAID,gBAAkB,EAA7D;AACA;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AACA,OAAO,SAASG,oBAAT,CAA+BZ,MAA/B,EAAuCO,UAAvC,EAAoD;AAC1D,QAAMM,WAAW,GAAGlB,MAAM,CAAEY,UAAF,CAA1B;AACA,SAAOb,KAAK,CAAEM,MAAF,EAAU,CAAE;AAAEK,IAAAA;AAAF,GAAF,KAAiBQ,WAAW,CAACC,QAAZ,CAAsBT,KAAtB,CAA3B,CAAL,CACLA,KADF;AAEA","sourcesContent":["/**\n * External dependencies\n */\nimport { find, kebabCase, maxBy } from 'lodash';\nimport { colord, extend } from 'colord';\nimport namesPlugin from 'colord/plugins/names';\nimport a11yPlugin from 'colord/plugins/a11y';\n\nextend( [ namesPlugin, a11yPlugin ] );\n\n/**\n * Provided an array of color objects as set by the theme or by the editor defaults,\n * and the values of the defined color or custom color returns a color object describing the color.\n *\n * @param {Array} colors Array of color objects as set by the theme or by the editor defaults.\n * @param {?string} definedColor A string containing the color slug.\n * @param {?string} customColor A string containing the customColor value.\n *\n * @return {?Object} If definedColor is passed and the name is found in colors,\n * the color object exactly as set by the theme or editor defaults is returned.\n * Otherwise, an object that just sets the color is defined.\n */\nexport const getColorObjectByAttributeValues = (\n\tcolors,\n\tdefinedColor,\n\tcustomColor\n) => {\n\tif ( definedColor ) {\n\t\tconst colorObj = find( colors, { slug: definedColor } );\n\n\t\tif ( colorObj ) {\n\t\t\treturn colorObj;\n\t\t}\n\t}\n\treturn {\n\t\tcolor: customColor,\n\t};\n};\n\n/**\n * Provided an array of color objects as set by the theme or by the editor defaults, and a color value returns the color object matching that value or undefined.\n *\n * @param {Array} colors Array of color objects as set by the theme or by the editor defaults.\n * @param {?string} colorValue A string containing the color value.\n *\n * @return {?Object} Color object included in the colors array whose color property equals colorValue.\n * Returns undefined if no color object matches this requirement.\n */\nexport const getColorObjectByColorValue = ( colors, colorValue ) => {\n\treturn find( colors, { color: colorValue } );\n};\n\n/**\n * Returns a class based on the context a color is being used and its slug.\n *\n * @param {string} colorContextName Context/place where color is being used e.g: background, text etc...\n * @param {string} colorSlug Slug of the color.\n *\n * @return {?string} String with the class corresponding to the color in the provided context.\n * Returns undefined if either colorContextName or colorSlug are not provided.\n */\nexport function getColorClassName( colorContextName, colorSlug ) {\n\tif ( ! colorContextName || ! colorSlug ) {\n\t\treturn undefined;\n\t}\n\n\treturn `has-${ kebabCase( colorSlug ) }-${ colorContextName }`;\n}\n\n/**\n * Given an array of color objects and a color value returns the color value of the most readable color in the array.\n *\n * @param {Array} colors Array of color objects as set by the theme or by the editor defaults.\n * @param {?string} colorValue A string containing the color value.\n *\n * @return {string} String with the color value of the most readable color.\n */\nexport function getMostReadableColor( colors, colorValue ) {\n\tconst colordColor = colord( colorValue );\n\treturn maxBy( colors, ( { color } ) => colordColor.contrast( color ) )\n\t\t.color;\n}\n"]}
@@ -11,7 +11,7 @@ import { every, isEmpty } from 'lodash';
11
11
  */
12
12
 
13
13
  import { useState } from '@wordpress/element';
14
- import { BaseControl, Button, ButtonGroup, ColorIndicator, ColorPalette, GradientPicker } from '@wordpress/components';
14
+ import { BaseControl, __experimentalVStack as VStack, __experimentalToggleGroupControl as ToggleGroupControl, __experimentalToggleGroupControlOption as ToggleGroupControlOption, ColorIndicator, ColorPalette, GradientPicker } from '@wordpress/components';
15
15
  import { sprintf, __ } from '@wordpress/i18n';
16
16
  /**
17
17
  * Internal dependencies
@@ -83,24 +83,28 @@ function ColorGradientControlInner({
83
83
 
84
84
  return createElement(BaseControl, {
85
85
  className: classnames('block-editor-color-gradient-control', className)
86
- }, createElement("fieldset", null, createElement("legend", null, createElement("div", {
86
+ }, createElement("fieldset", null, createElement(VStack, {
87
+ space: 3
88
+ }, createElement("legend", null, createElement("div", {
87
89
  className: "block-editor-color-gradient-control__color-indicator"
88
90
  }, createElement(BaseControl.VisualLabel, null, createElement(VisualLabel, {
89
91
  currentTab: currentTab,
90
92
  label: label,
91
93
  colorValue: colorValue,
92
94
  gradientValue: gradientValue
93
- })))), canChooseAColor && canChooseAGradient && createElement(ButtonGroup, {
94
- className: "block-editor-color-gradient-control__button-tabs"
95
- }, createElement(Button, {
96
- isSmall: true,
97
- isPressed: currentTab === 'color',
98
- onClick: () => setCurrentTab('color')
99
- }, __('Solid')), createElement(Button, {
100
- isSmall: true,
101
- isPressed: currentTab === 'gradient',
102
- onClick: () => setCurrentTab('gradient')
103
- }, __('Gradient'))), (currentTab === 'color' || !canChooseAGradient) && createElement(ColorPalette, {
95
+ })))), canChooseAColor && canChooseAGradient && createElement(ToggleGroupControl, {
96
+ value: currentTab,
97
+ onChange: setCurrentTab,
98
+ label: __('Select color type'),
99
+ hideLabelFromVision: true,
100
+ isBlock: true
101
+ }, createElement(ToggleGroupControlOption, {
102
+ value: "color",
103
+ label: __('Solid')
104
+ }), createElement(ToggleGroupControlOption, {
105
+ value: "gradient",
106
+ label: __('Gradient')
107
+ })), (currentTab === 'color' || !canChooseAGradient) && createElement(ColorPalette, {
104
108
  value: colorValue,
105
109
  onChange: canChooseAGradient ? newColor => {
106
110
  onColorChange(newColor);
@@ -118,7 +122,7 @@ function ColorGradientControlInner({
118
122
  gradients,
119
123
  disableCustomGradients,
120
124
  clearable: clearable
121
- })));
125
+ }))));
122
126
  }
123
127
 
124
128
  function ColorGradientControlSelect(props) {
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/block-editor/src/components/colors-gradients/control.js"],"names":["classnames","every","isEmpty","useState","BaseControl","Button","ButtonGroup","ColorIndicator","ColorPalette","GradientPicker","sprintf","__","getColorObjectByColorValue","__experimentalGetGradientObjectByGradientValue","useSetting","colorIndicatorAriaLabel","gradientIndicatorAriaLabel","colorsAndGradientKeys","VisualLabel","colors","gradients","label","currentTab","colorValue","gradientValue","value","ariaLabel","colorObject","colorName","name","gradientObject","gradientName","ColorGradientControlInner","disableCustomColors","disableCustomGradients","className","onColorChange","onGradientChange","clearable","canChooseAColor","canChooseAGradient","setCurrentTab","newColor","newGradient","ColorGradientControlSelect","props","colorGradientSettings","ColorGradientControl","key","hasOwnProperty"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport classnames from 'classnames';\nimport { every, isEmpty } from 'lodash';\n\n/**\n * WordPress dependencies\n */\nimport { useState } from '@wordpress/element';\nimport {\n\tBaseControl,\n\tButton,\n\tButtonGroup,\n\tColorIndicator,\n\tColorPalette,\n\tGradientPicker,\n} from '@wordpress/components';\nimport { sprintf, __ } from '@wordpress/i18n';\n\n/**\n * Internal dependencies\n */\nimport { getColorObjectByColorValue } from '../colors';\nimport { __experimentalGetGradientObjectByGradientValue } from '../gradients';\nimport useSetting from '../use-setting';\n\n// translators: first %s: the color name or value (e.g. red or #ff0000)\nconst colorIndicatorAriaLabel = __( '(Color: %s)' );\n\n// translators: first %s: the gradient name or value (e.g. red to green or linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%)\nconst gradientIndicatorAriaLabel = __( '(Gradient: %s)' );\n\nconst colorsAndGradientKeys = [\n\t'colors',\n\t'disableCustomColors',\n\t'gradients',\n\t'disableCustomGradients',\n];\n\nfunction VisualLabel( {\n\tcolors,\n\tgradients,\n\tlabel,\n\tcurrentTab,\n\tcolorValue,\n\tgradientValue,\n} ) {\n\tlet value, ariaLabel;\n\tif ( currentTab === 'color' ) {\n\t\tif ( colorValue ) {\n\t\t\tvalue = colorValue;\n\t\t\tconst colorObject = getColorObjectByColorValue( colors, value );\n\t\t\tconst colorName = colorObject && colorObject.name;\n\t\t\tariaLabel = sprintf( colorIndicatorAriaLabel, colorName || value );\n\t\t}\n\t} else if ( currentTab === 'gradient' && gradientValue ) {\n\t\tvalue = gradientValue;\n\t\tconst gradientObject = __experimentalGetGradientObjectByGradientValue(\n\t\t\tgradients,\n\t\t\tvalue\n\t\t);\n\t\tconst gradientName = gradientObject && gradientObject.name;\n\t\tariaLabel = sprintf(\n\t\t\tgradientIndicatorAriaLabel,\n\t\t\tgradientName || value\n\t\t);\n\t}\n\n\treturn (\n\t\t<>\n\t\t\t{ label }\n\t\t\t{ !! value && (\n\t\t\t\t<ColorIndicator colorValue={ value } aria-label={ ariaLabel } />\n\t\t\t) }\n\t\t</>\n\t);\n}\n\nfunction ColorGradientControlInner( {\n\tcolors,\n\tgradients,\n\tdisableCustomColors,\n\tdisableCustomGradients,\n\tclassName,\n\tlabel,\n\tonColorChange,\n\tonGradientChange,\n\tcolorValue,\n\tgradientValue,\n\tclearable,\n} ) {\n\tconst canChooseAColor =\n\t\tonColorChange && ( ! isEmpty( colors ) || ! disableCustomColors );\n\tconst canChooseAGradient =\n\t\tonGradientChange &&\n\t\t( ! isEmpty( gradients ) || ! disableCustomGradients );\n\tconst [ currentTab, setCurrentTab ] = useState(\n\t\tgradientValue ? 'gradient' : !! canChooseAColor && 'color'\n\t);\n\n\tif ( ! canChooseAColor && ! canChooseAGradient ) {\n\t\treturn null;\n\t}\n\treturn (\n\t\t<BaseControl\n\t\t\tclassName={ classnames(\n\t\t\t\t'block-editor-color-gradient-control',\n\t\t\t\tclassName\n\t\t\t) }\n\t\t>\n\t\t\t<fieldset>\n\t\t\t\t<legend>\n\t\t\t\t\t<div className=\"block-editor-color-gradient-control__color-indicator\">\n\t\t\t\t\t\t<BaseControl.VisualLabel>\n\t\t\t\t\t\t\t<VisualLabel\n\t\t\t\t\t\t\t\tcurrentTab={ currentTab }\n\t\t\t\t\t\t\t\tlabel={ label }\n\t\t\t\t\t\t\t\tcolorValue={ colorValue }\n\t\t\t\t\t\t\t\tgradientValue={ gradientValue }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</BaseControl.VisualLabel>\n\t\t\t\t\t</div>\n\t\t\t\t</legend>\n\t\t\t\t{ canChooseAColor && canChooseAGradient && (\n\t\t\t\t\t<ButtonGroup className=\"block-editor-color-gradient-control__button-tabs\">\n\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\tisSmall\n\t\t\t\t\t\t\tisPressed={ currentTab === 'color' }\n\t\t\t\t\t\t\tonClick={ () => setCurrentTab( 'color' ) }\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{ __( 'Solid' ) }\n\t\t\t\t\t\t</Button>\n\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\tisSmall\n\t\t\t\t\t\t\tisPressed={ currentTab === 'gradient' }\n\t\t\t\t\t\t\tonClick={ () => setCurrentTab( 'gradient' ) }\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{ __( 'Gradient' ) }\n\t\t\t\t\t\t</Button>\n\t\t\t\t\t</ButtonGroup>\n\t\t\t\t) }\n\t\t\t\t{ ( currentTab === 'color' || ! canChooseAGradient ) && (\n\t\t\t\t\t<ColorPalette\n\t\t\t\t\t\tvalue={ colorValue }\n\t\t\t\t\t\tonChange={\n\t\t\t\t\t\t\tcanChooseAGradient\n\t\t\t\t\t\t\t\t? ( newColor ) => {\n\t\t\t\t\t\t\t\t\t\tonColorChange( newColor );\n\t\t\t\t\t\t\t\t\t\tonGradientChange();\n\t\t\t\t\t\t\t\t }\n\t\t\t\t\t\t\t\t: onColorChange\n\t\t\t\t\t\t}\n\t\t\t\t\t\t{ ...{ colors, disableCustomColors } }\n\t\t\t\t\t\tclearable={ clearable }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t\t{ ( currentTab === 'gradient' || ! canChooseAColor ) && (\n\t\t\t\t\t<GradientPicker\n\t\t\t\t\t\tvalue={ gradientValue }\n\t\t\t\t\t\tonChange={\n\t\t\t\t\t\t\tcanChooseAColor\n\t\t\t\t\t\t\t\t? ( newGradient ) => {\n\t\t\t\t\t\t\t\t\t\tonGradientChange( newGradient );\n\t\t\t\t\t\t\t\t\t\tonColorChange();\n\t\t\t\t\t\t\t\t }\n\t\t\t\t\t\t\t\t: onGradientChange\n\t\t\t\t\t\t}\n\t\t\t\t\t\t{ ...{ gradients, disableCustomGradients } }\n\t\t\t\t\t\tclearable={ clearable }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t</fieldset>\n\t\t</BaseControl>\n\t);\n}\n\nfunction ColorGradientControlSelect( props ) {\n\tconst colorGradientSettings = {};\n\tcolorGradientSettings.colors = useSetting( 'color.palette' );\n\tcolorGradientSettings.gradients = useSetting( 'color.gradients' );\n\tcolorGradientSettings.disableCustomColors = ! useSetting( 'color.custom' );\n\tcolorGradientSettings.disableCustomGradients = ! useSetting(\n\t\t'color.customGradient'\n\t);\n\n\treturn (\n\t\t<ColorGradientControlInner\n\t\t\t{ ...{ ...colorGradientSettings, ...props } }\n\t\t/>\n\t);\n}\n\nfunction ColorGradientControl( props ) {\n\tif (\n\t\tevery( colorsAndGradientKeys, ( key ) => props.hasOwnProperty( key ) )\n\t) {\n\t\treturn <ColorGradientControlInner { ...props } />;\n\t}\n\treturn <ColorGradientControlSelect { ...props } />;\n}\n\nexport default ColorGradientControl;\n"]}
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/colors-gradients/control.js"],"names":["classnames","every","isEmpty","useState","BaseControl","__experimentalVStack","VStack","__experimentalToggleGroupControl","ToggleGroupControl","__experimentalToggleGroupControlOption","ToggleGroupControlOption","ColorIndicator","ColorPalette","GradientPicker","sprintf","__","getColorObjectByColorValue","__experimentalGetGradientObjectByGradientValue","useSetting","colorIndicatorAriaLabel","gradientIndicatorAriaLabel","colorsAndGradientKeys","VisualLabel","colors","gradients","label","currentTab","colorValue","gradientValue","value","ariaLabel","colorObject","colorName","name","gradientObject","gradientName","ColorGradientControlInner","disableCustomColors","disableCustomGradients","className","onColorChange","onGradientChange","clearable","canChooseAColor","canChooseAGradient","setCurrentTab","newColor","newGradient","ColorGradientControlSelect","props","colorGradientSettings","ColorGradientControl","key","hasOwnProperty"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport classnames from 'classnames';\nimport { every, isEmpty } from 'lodash';\n\n/**\n * WordPress dependencies\n */\nimport { useState } from '@wordpress/element';\nimport {\n\tBaseControl,\n\t__experimentalVStack as VStack,\n\t__experimentalToggleGroupControl as ToggleGroupControl,\n\t__experimentalToggleGroupControlOption as ToggleGroupControlOption,\n\tColorIndicator,\n\tColorPalette,\n\tGradientPicker,\n} from '@wordpress/components';\nimport { sprintf, __ } from '@wordpress/i18n';\n\n/**\n * Internal dependencies\n */\nimport { getColorObjectByColorValue } from '../colors';\nimport { __experimentalGetGradientObjectByGradientValue } from '../gradients';\nimport useSetting from '../use-setting';\n\n// translators: first %s: the color name or value (e.g. red or #ff0000)\nconst colorIndicatorAriaLabel = __( '(Color: %s)' );\n\n// translators: first %s: the gradient name or value (e.g. red to green or linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%)\nconst gradientIndicatorAriaLabel = __( '(Gradient: %s)' );\n\nconst colorsAndGradientKeys = [\n\t'colors',\n\t'disableCustomColors',\n\t'gradients',\n\t'disableCustomGradients',\n];\n\nfunction VisualLabel( {\n\tcolors,\n\tgradients,\n\tlabel,\n\tcurrentTab,\n\tcolorValue,\n\tgradientValue,\n} ) {\n\tlet value, ariaLabel;\n\tif ( currentTab === 'color' ) {\n\t\tif ( colorValue ) {\n\t\t\tvalue = colorValue;\n\t\t\tconst colorObject = getColorObjectByColorValue( colors, value );\n\t\t\tconst colorName = colorObject && colorObject.name;\n\t\t\tariaLabel = sprintf( colorIndicatorAriaLabel, colorName || value );\n\t\t}\n\t} else if ( currentTab === 'gradient' && gradientValue ) {\n\t\tvalue = gradientValue;\n\t\tconst gradientObject = __experimentalGetGradientObjectByGradientValue(\n\t\t\tgradients,\n\t\t\tvalue\n\t\t);\n\t\tconst gradientName = gradientObject && gradientObject.name;\n\t\tariaLabel = sprintf(\n\t\t\tgradientIndicatorAriaLabel,\n\t\t\tgradientName || value\n\t\t);\n\t}\n\n\treturn (\n\t\t<>\n\t\t\t{ label }\n\t\t\t{ !! value && (\n\t\t\t\t<ColorIndicator colorValue={ value } aria-label={ ariaLabel } />\n\t\t\t) }\n\t\t</>\n\t);\n}\n\nfunction ColorGradientControlInner( {\n\tcolors,\n\tgradients,\n\tdisableCustomColors,\n\tdisableCustomGradients,\n\tclassName,\n\tlabel,\n\tonColorChange,\n\tonGradientChange,\n\tcolorValue,\n\tgradientValue,\n\tclearable,\n} ) {\n\tconst canChooseAColor =\n\t\tonColorChange && ( ! isEmpty( colors ) || ! disableCustomColors );\n\tconst canChooseAGradient =\n\t\tonGradientChange &&\n\t\t( ! isEmpty( gradients ) || ! disableCustomGradients );\n\tconst [ currentTab, setCurrentTab ] = useState(\n\t\tgradientValue ? 'gradient' : !! canChooseAColor && 'color'\n\t);\n\n\tif ( ! canChooseAColor && ! canChooseAGradient ) {\n\t\treturn null;\n\t}\n\treturn (\n\t\t<BaseControl\n\t\t\tclassName={ classnames(\n\t\t\t\t'block-editor-color-gradient-control',\n\t\t\t\tclassName\n\t\t\t) }\n\t\t>\n\t\t\t<fieldset>\n\t\t\t\t<VStack space={ 3 }>\n\t\t\t\t\t<legend>\n\t\t\t\t\t\t<div className=\"block-editor-color-gradient-control__color-indicator\">\n\t\t\t\t\t\t\t<BaseControl.VisualLabel>\n\t\t\t\t\t\t\t\t<VisualLabel\n\t\t\t\t\t\t\t\t\tcurrentTab={ currentTab }\n\t\t\t\t\t\t\t\t\tlabel={ label }\n\t\t\t\t\t\t\t\t\tcolorValue={ colorValue }\n\t\t\t\t\t\t\t\t\tgradientValue={ gradientValue }\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</BaseControl.VisualLabel>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</legend>\n\t\t\t\t\t{ canChooseAColor && canChooseAGradient && (\n\t\t\t\t\t\t<ToggleGroupControl\n\t\t\t\t\t\t\tvalue={ currentTab }\n\t\t\t\t\t\t\tonChange={ setCurrentTab }\n\t\t\t\t\t\t\tlabel={ __( 'Select color type' ) }\n\t\t\t\t\t\t\thideLabelFromVision\n\t\t\t\t\t\t\tisBlock\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<ToggleGroupControlOption\n\t\t\t\t\t\t\t\tvalue=\"color\"\n\t\t\t\t\t\t\t\tlabel={ __( 'Solid' ) }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t<ToggleGroupControlOption\n\t\t\t\t\t\t\t\tvalue=\"gradient\"\n\t\t\t\t\t\t\t\tlabel={ __( 'Gradient' ) }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</ToggleGroupControl>\n\t\t\t\t\t) }\n\t\t\t\t\t{ ( currentTab === 'color' || ! canChooseAGradient ) && (\n\t\t\t\t\t\t<ColorPalette\n\t\t\t\t\t\t\tvalue={ colorValue }\n\t\t\t\t\t\t\tonChange={\n\t\t\t\t\t\t\t\tcanChooseAGradient\n\t\t\t\t\t\t\t\t\t? ( newColor ) => {\n\t\t\t\t\t\t\t\t\t\t\tonColorChange( newColor );\n\t\t\t\t\t\t\t\t\t\t\tonGradientChange();\n\t\t\t\t\t\t\t\t\t }\n\t\t\t\t\t\t\t\t\t: onColorChange\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t{ ...{ colors, disableCustomColors } }\n\t\t\t\t\t\t\tclearable={ clearable }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t\t{ ( currentTab === 'gradient' || ! canChooseAColor ) && (\n\t\t\t\t\t\t<GradientPicker\n\t\t\t\t\t\t\tvalue={ gradientValue }\n\t\t\t\t\t\t\tonChange={\n\t\t\t\t\t\t\t\tcanChooseAColor\n\t\t\t\t\t\t\t\t\t? ( newGradient ) => {\n\t\t\t\t\t\t\t\t\t\t\tonGradientChange( newGradient );\n\t\t\t\t\t\t\t\t\t\t\tonColorChange();\n\t\t\t\t\t\t\t\t\t }\n\t\t\t\t\t\t\t\t\t: onGradientChange\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t{ ...{ gradients, disableCustomGradients } }\n\t\t\t\t\t\t\tclearable={ clearable }\n\t\t\t\t\t\t/>\n\t\t\t\t\t) }\n\t\t\t\t</VStack>\n\t\t\t</fieldset>\n\t\t</BaseControl>\n\t);\n}\n\nfunction ColorGradientControlSelect( props ) {\n\tconst colorGradientSettings = {};\n\tcolorGradientSettings.colors = useSetting( 'color.palette' );\n\tcolorGradientSettings.gradients = useSetting( 'color.gradients' );\n\tcolorGradientSettings.disableCustomColors = ! useSetting( 'color.custom' );\n\tcolorGradientSettings.disableCustomGradients = ! useSetting(\n\t\t'color.customGradient'\n\t);\n\n\treturn (\n\t\t<ColorGradientControlInner\n\t\t\t{ ...{ ...colorGradientSettings, ...props } }\n\t\t/>\n\t);\n}\n\nfunction ColorGradientControl( props ) {\n\tif (\n\t\tevery( colorsAndGradientKeys, ( key ) => props.hasOwnProperty( key ) )\n\t) {\n\t\treturn <ColorGradientControlInner { ...props } />;\n\t}\n\treturn <ColorGradientControlSelect { ...props } />;\n}\n\nexport default ColorGradientControl;\n"]}
@@ -72,6 +72,7 @@ export const PanelColorGradientSettingsInner = ({
72
72
  children,
73
73
  settings,
74
74
  title,
75
+ showTitle = true,
75
76
  ...props
76
77
  }) => {
77
78
  if (isEmpty(colors) && isEmpty(gradients) && disableCustomColors && disableCustomGradients && every(settings, setting => isEmpty(setting.colors) && isEmpty(setting.gradients) && (setting.disableCustomColors === undefined || setting.disableCustomColors) && (setting.disableCustomGradients === undefined || setting.disableCustomGradients))) {
@@ -87,7 +88,7 @@ export const PanelColorGradientSettingsInner = ({
87
88
  }));
88
89
  return createElement(PanelBody, _extends({
89
90
  className: classnames('block-editor-panel-color-gradient-settings', className),
90
- title: titleElement
91
+ title: showTitle ? titleElement : undefined
91
92
  }, props), settings.map((setting, index) => createElement(ColorGradientControl, _extends({
92
93
  key: index,
93
94
  colors,
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/block-editor/src/components/colors-gradients/panel-color-gradient-settings.js"],"names":["classnames","every","isEmpty","PanelBody","ColorIndicator","sprintf","__","ColorGradientControl","getColorObjectByColorValue","__experimentalGetGradientObjectByGradientValue","useSetting","colorIndicatorAriaLabel","gradientIndicatorAriaLabel","colorsAndGradientKeys","Indicators","colors","gradients","settings","map","colorValue","gradientValue","label","availableColors","availableGradients","index","ariaLabel","colorObject","toLowerCase","name","gradientObject","PanelColorGradientSettingsInner","className","disableCustomColors","disableCustomGradients","children","title","props","setting","undefined","titleElement","PanelColorGradientSettingsSelect","colorGradientSettings","PanelColorGradientSettings","key","hasOwnProperty"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport classnames from 'classnames';\nimport { every, isEmpty } from 'lodash';\n\n/**\n * WordPress dependencies\n */\nimport { PanelBody, ColorIndicator } from '@wordpress/components';\nimport { sprintf, __ } from '@wordpress/i18n';\n\n/**\n * Internal dependencies\n */\nimport ColorGradientControl from './control';\nimport { getColorObjectByColorValue } from '../colors';\nimport { __experimentalGetGradientObjectByGradientValue } from '../gradients';\nimport useSetting from '../use-setting';\n\n// translators: first %s: The type of color or gradient (e.g. background, overlay...), second %s: the color name or value (e.g. red or #ff0000)\nconst colorIndicatorAriaLabel = __( '(%s: color %s)' );\n\n// translators: first %s: The type of color or gradient (e.g. background, overlay...), second %s: the color name or value (e.g. red or #ff0000)\nconst gradientIndicatorAriaLabel = __( '(%s: gradient %s)' );\n\nconst colorsAndGradientKeys = [\n\t'colors',\n\t'disableCustomColors',\n\t'gradients',\n\t'disableCustomGradients',\n];\n\nconst Indicators = ( { colors, gradients, settings } ) => {\n\treturn settings.map(\n\t\t(\n\t\t\t{\n\t\t\t\tcolorValue,\n\t\t\t\tgradientValue,\n\t\t\t\tlabel,\n\t\t\t\tcolors: availableColors,\n\t\t\t\tgradients: availableGradients,\n\t\t\t},\n\t\t\tindex\n\t\t) => {\n\t\t\tif ( ! colorValue && ! gradientValue ) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\tlet ariaLabel;\n\t\t\tif ( colorValue ) {\n\t\t\t\tconst colorObject = getColorObjectByColorValue(\n\t\t\t\t\tavailableColors || colors,\n\t\t\t\t\tcolorValue\n\t\t\t\t);\n\t\t\t\tariaLabel = sprintf(\n\t\t\t\t\tcolorIndicatorAriaLabel,\n\t\t\t\t\tlabel.toLowerCase(),\n\t\t\t\t\t( colorObject && colorObject.name ) || colorValue\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tconst gradientObject = __experimentalGetGradientObjectByGradientValue(\n\t\t\t\t\tavailableGradients || gradients,\n\t\t\t\t\tcolorValue\n\t\t\t\t);\n\t\t\t\tariaLabel = sprintf(\n\t\t\t\t\tgradientIndicatorAriaLabel,\n\t\t\t\t\tlabel.toLowerCase(),\n\t\t\t\t\t( gradientObject && gradientObject.name ) || gradientValue\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn (\n\t\t\t\t<ColorIndicator\n\t\t\t\t\tkey={ index }\n\t\t\t\t\tcolorValue={ colorValue || gradientValue }\n\t\t\t\t\taria-label={ ariaLabel }\n\t\t\t\t/>\n\t\t\t);\n\t\t}\n\t);\n};\n\nexport const PanelColorGradientSettingsInner = ( {\n\tclassName,\n\tcolors,\n\tgradients,\n\tdisableCustomColors,\n\tdisableCustomGradients,\n\tchildren,\n\tsettings,\n\ttitle,\n\t...props\n} ) => {\n\tif (\n\t\tisEmpty( colors ) &&\n\t\tisEmpty( gradients ) &&\n\t\tdisableCustomColors &&\n\t\tdisableCustomGradients &&\n\t\tevery(\n\t\t\tsettings,\n\t\t\t( setting ) =>\n\t\t\t\tisEmpty( setting.colors ) &&\n\t\t\t\tisEmpty( setting.gradients ) &&\n\t\t\t\t( setting.disableCustomColors === undefined ||\n\t\t\t\t\tsetting.disableCustomColors ) &&\n\t\t\t\t( setting.disableCustomGradients === undefined ||\n\t\t\t\t\tsetting.disableCustomGradients )\n\t\t)\n\t) {\n\t\treturn null;\n\t}\n\n\tconst titleElement = (\n\t\t<span className=\"block-editor-panel-color-gradient-settings__panel-title\">\n\t\t\t{ title }\n\t\t\t<Indicators\n\t\t\t\tcolors={ colors }\n\t\t\t\tgradients={ gradients }\n\t\t\t\tsettings={ settings }\n\t\t\t/>\n\t\t</span>\n\t);\n\treturn (\n\t\t<PanelBody\n\t\t\tclassName={ classnames(\n\t\t\t\t'block-editor-panel-color-gradient-settings',\n\t\t\t\tclassName\n\t\t\t) }\n\t\t\ttitle={ titleElement }\n\t\t\t{ ...props }\n\t\t>\n\t\t\t{ settings.map( ( setting, index ) => (\n\t\t\t\t<ColorGradientControl\n\t\t\t\t\tkey={ index }\n\t\t\t\t\t{ ...{\n\t\t\t\t\t\tcolors,\n\t\t\t\t\t\tgradients,\n\t\t\t\t\t\tdisableCustomColors,\n\t\t\t\t\t\tdisableCustomGradients,\n\t\t\t\t\t\t...setting,\n\t\t\t\t\t} }\n\t\t\t\t/>\n\t\t\t) ) }\n\t\t\t{ children }\n\t\t</PanelBody>\n\t);\n};\n\nconst PanelColorGradientSettingsSelect = ( props ) => {\n\tconst colorGradientSettings = {};\n\tcolorGradientSettings.colors = useSetting( 'color.palette' );\n\tcolorGradientSettings.gradients = useSetting( 'color.gradients' );\n\tcolorGradientSettings.disableCustomColors = ! useSetting( 'color.custom' );\n\tcolorGradientSettings.disableCustomGradients = ! useSetting(\n\t\t'color.customGradient'\n\t);\n\treturn (\n\t\t<PanelColorGradientSettingsInner\n\t\t\t{ ...{ ...colorGradientSettings, ...props } }\n\t\t/>\n\t);\n};\n\nconst PanelColorGradientSettings = ( props ) => {\n\tif (\n\t\tevery( colorsAndGradientKeys, ( key ) => props.hasOwnProperty( key ) )\n\t) {\n\t\treturn <PanelColorGradientSettingsInner { ...props } />;\n\t}\n\treturn <PanelColorGradientSettingsSelect { ...props } />;\n};\n\nexport default PanelColorGradientSettings;\n"]}
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/colors-gradients/panel-color-gradient-settings.js"],"names":["classnames","every","isEmpty","PanelBody","ColorIndicator","sprintf","__","ColorGradientControl","getColorObjectByColorValue","__experimentalGetGradientObjectByGradientValue","useSetting","colorIndicatorAriaLabel","gradientIndicatorAriaLabel","colorsAndGradientKeys","Indicators","colors","gradients","settings","map","colorValue","gradientValue","label","availableColors","availableGradients","index","ariaLabel","colorObject","toLowerCase","name","gradientObject","PanelColorGradientSettingsInner","className","disableCustomColors","disableCustomGradients","children","title","showTitle","props","setting","undefined","titleElement","PanelColorGradientSettingsSelect","colorGradientSettings","PanelColorGradientSettings","key","hasOwnProperty"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport classnames from 'classnames';\nimport { every, isEmpty } from 'lodash';\n\n/**\n * WordPress dependencies\n */\nimport { PanelBody, ColorIndicator } from '@wordpress/components';\nimport { sprintf, __ } from '@wordpress/i18n';\n\n/**\n * Internal dependencies\n */\nimport ColorGradientControl from './control';\nimport { getColorObjectByColorValue } from '../colors';\nimport { __experimentalGetGradientObjectByGradientValue } from '../gradients';\nimport useSetting from '../use-setting';\n\n// translators: first %s: The type of color or gradient (e.g. background, overlay...), second %s: the color name or value (e.g. red or #ff0000)\nconst colorIndicatorAriaLabel = __( '(%s: color %s)' );\n\n// translators: first %s: The type of color or gradient (e.g. background, overlay...), second %s: the color name or value (e.g. red or #ff0000)\nconst gradientIndicatorAriaLabel = __( '(%s: gradient %s)' );\n\nconst colorsAndGradientKeys = [\n\t'colors',\n\t'disableCustomColors',\n\t'gradients',\n\t'disableCustomGradients',\n];\n\nconst Indicators = ( { colors, gradients, settings } ) => {\n\treturn settings.map(\n\t\t(\n\t\t\t{\n\t\t\t\tcolorValue,\n\t\t\t\tgradientValue,\n\t\t\t\tlabel,\n\t\t\t\tcolors: availableColors,\n\t\t\t\tgradients: availableGradients,\n\t\t\t},\n\t\t\tindex\n\t\t) => {\n\t\t\tif ( ! colorValue && ! gradientValue ) {\n\t\t\t\treturn null;\n\t\t\t}\n\t\t\tlet ariaLabel;\n\t\t\tif ( colorValue ) {\n\t\t\t\tconst colorObject = getColorObjectByColorValue(\n\t\t\t\t\tavailableColors || colors,\n\t\t\t\t\tcolorValue\n\t\t\t\t);\n\t\t\t\tariaLabel = sprintf(\n\t\t\t\t\tcolorIndicatorAriaLabel,\n\t\t\t\t\tlabel.toLowerCase(),\n\t\t\t\t\t( colorObject && colorObject.name ) || colorValue\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tconst gradientObject = __experimentalGetGradientObjectByGradientValue(\n\t\t\t\t\tavailableGradients || gradients,\n\t\t\t\t\tcolorValue\n\t\t\t\t);\n\t\t\t\tariaLabel = sprintf(\n\t\t\t\t\tgradientIndicatorAriaLabel,\n\t\t\t\t\tlabel.toLowerCase(),\n\t\t\t\t\t( gradientObject && gradientObject.name ) || gradientValue\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn (\n\t\t\t\t<ColorIndicator\n\t\t\t\t\tkey={ index }\n\t\t\t\t\tcolorValue={ colorValue || gradientValue }\n\t\t\t\t\taria-label={ ariaLabel }\n\t\t\t\t/>\n\t\t\t);\n\t\t}\n\t);\n};\n\nexport const PanelColorGradientSettingsInner = ( {\n\tclassName,\n\tcolors,\n\tgradients,\n\tdisableCustomColors,\n\tdisableCustomGradients,\n\tchildren,\n\tsettings,\n\ttitle,\n\tshowTitle = true,\n\t...props\n} ) => {\n\tif (\n\t\tisEmpty( colors ) &&\n\t\tisEmpty( gradients ) &&\n\t\tdisableCustomColors &&\n\t\tdisableCustomGradients &&\n\t\tevery(\n\t\t\tsettings,\n\t\t\t( setting ) =>\n\t\t\t\tisEmpty( setting.colors ) &&\n\t\t\t\tisEmpty( setting.gradients ) &&\n\t\t\t\t( setting.disableCustomColors === undefined ||\n\t\t\t\t\tsetting.disableCustomColors ) &&\n\t\t\t\t( setting.disableCustomGradients === undefined ||\n\t\t\t\t\tsetting.disableCustomGradients )\n\t\t)\n\t) {\n\t\treturn null;\n\t}\n\n\tconst titleElement = (\n\t\t<span className=\"block-editor-panel-color-gradient-settings__panel-title\">\n\t\t\t{ title }\n\t\t\t<Indicators\n\t\t\t\tcolors={ colors }\n\t\t\t\tgradients={ gradients }\n\t\t\t\tsettings={ settings }\n\t\t\t/>\n\t\t</span>\n\t);\n\n\treturn (\n\t\t<PanelBody\n\t\t\tclassName={ classnames(\n\t\t\t\t'block-editor-panel-color-gradient-settings',\n\t\t\t\tclassName\n\t\t\t) }\n\t\t\ttitle={ showTitle ? titleElement : undefined }\n\t\t\t{ ...props }\n\t\t>\n\t\t\t{ settings.map( ( setting, index ) => (\n\t\t\t\t<ColorGradientControl\n\t\t\t\t\tkey={ index }\n\t\t\t\t\t{ ...{\n\t\t\t\t\t\tcolors,\n\t\t\t\t\t\tgradients,\n\t\t\t\t\t\tdisableCustomColors,\n\t\t\t\t\t\tdisableCustomGradients,\n\t\t\t\t\t\t...setting,\n\t\t\t\t\t} }\n\t\t\t\t/>\n\t\t\t) ) }\n\t\t\t{ children }\n\t\t</PanelBody>\n\t);\n};\n\nconst PanelColorGradientSettingsSelect = ( props ) => {\n\tconst colorGradientSettings = {};\n\tcolorGradientSettings.colors = useSetting( 'color.palette' );\n\tcolorGradientSettings.gradients = useSetting( 'color.gradients' );\n\tcolorGradientSettings.disableCustomColors = ! useSetting( 'color.custom' );\n\tcolorGradientSettings.disableCustomGradients = ! useSetting(\n\t\t'color.customGradient'\n\t);\n\treturn (\n\t\t<PanelColorGradientSettingsInner\n\t\t\t{ ...{ ...colorGradientSettings, ...props } }\n\t\t/>\n\t);\n};\n\nconst PanelColorGradientSettings = ( props ) => {\n\tif (\n\t\tevery( colorsAndGradientKeys, ( key ) => props.hasOwnProperty( key ) )\n\t) {\n\t\treturn <PanelColorGradientSettingsInner { ...props } />;\n\t}\n\treturn <PanelColorGradientSettingsSelect { ...props } />;\n};\n\nexport default PanelColorGradientSettings;\n"]}
@@ -3,7 +3,9 @@ import { createElement } from "@wordpress/element";
3
3
  /**
4
4
  * External dependencies
5
5
  */
6
- import tinycolor from 'tinycolor2';
6
+ import { colord, extend } from 'colord';
7
+ import namesPlugin from 'colord/plugins/names';
8
+ import a11yPlugin from 'colord/plugins/a11y';
7
9
  /**
8
10
  * WordPress dependencies
9
11
  */
@@ -12,14 +14,15 @@ import { speak } from '@wordpress/a11y';
12
14
  import { __ } from '@wordpress/i18n';
13
15
  import { Notice } from '@wordpress/components';
14
16
  import { useEffect } from '@wordpress/element';
17
+ extend([namesPlugin, a11yPlugin]);
15
18
 
16
19
  function ContrastCheckerMessage({
17
- tinyBackgroundColor,
18
- tinyTextColor,
20
+ colordBackgroundColor,
21
+ colordTextColor,
19
22
  backgroundColor,
20
23
  textColor
21
24
  }) {
22
- const msg = tinyBackgroundColor.getBrightness() < tinyTextColor.getBrightness() ? __('This color combination may be hard for people to read. Try using a darker background color and/or a brighter text color.') : __('This color combination may be hard for people to read. Try using a brighter background color and/or a darker text color.'); // Note: The `Notice` component can speak messages via its `spokenMessage`
25
+ const msg = colordBackgroundColor.brightness() < colordTextColor.brightness() ? __('This color combination may be hard for people to read. Try using a darker background color and/or a brighter text color.') : __('This color combination may be hard for people to read. Try using a brighter background color and/or a darker text color.'); // Note: The `Notice` component can speak messages via its `spokenMessage`
23
26
  // prop, but the contrast checker requires granular control over when the
24
27
  // announcements are made. Notably, the message will be re-announced if a
25
28
  // new color combination is selected and the contrast is still insufficient.
@@ -49,11 +52,11 @@ function ContrastChecker({
49
52
  return null;
50
53
  }
51
54
 
52
- const tinyBackgroundColor = tinycolor(backgroundColor || fallbackBackgroundColor);
53
- const tinyTextColor = tinycolor(textColor || fallbackTextColor);
54
- const hasTransparency = tinyBackgroundColor.getAlpha() !== 1 || tinyTextColor.getAlpha() !== 1;
55
+ const colordBackgroundColor = colord(backgroundColor || fallbackBackgroundColor);
56
+ const colordTextColor = colord(textColor || fallbackTextColor);
57
+ const hasTransparency = colordBackgroundColor.alpha() !== 1 || colordTextColor.alpha() !== 1;
55
58
 
56
- if (hasTransparency || tinycolor.isReadable(tinyBackgroundColor, tinyTextColor, {
59
+ if (hasTransparency || colordTextColor.isReadable(colordBackgroundColor, {
57
60
  level: 'AA',
58
61
  size: isLargeText || isLargeText !== false && fontSize >= 24 ? 'large' : 'small'
59
62
  })) {
@@ -63,8 +66,8 @@ function ContrastChecker({
63
66
  return createElement(ContrastCheckerMessage, {
64
67
  backgroundColor: backgroundColor,
65
68
  textColor: textColor,
66
- tinyBackgroundColor: tinyBackgroundColor,
67
- tinyTextColor: tinyTextColor
69
+ colordBackgroundColor: colordBackgroundColor,
70
+ colordTextColor: colordTextColor
68
71
  });
69
72
  }
70
73
 
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/block-editor/src/components/contrast-checker/index.js"],"names":["tinycolor","speak","__","Notice","useEffect","ContrastCheckerMessage","tinyBackgroundColor","tinyTextColor","backgroundColor","textColor","msg","getBrightness","ContrastChecker","fallbackBackgroundColor","fallbackTextColor","fontSize","isLargeText","hasTransparency","getAlpha","isReadable","level","size"],"mappings":";;AAAA;AACA;AACA;AACA,OAAOA,SAAP,MAAsB,YAAtB;AAEA;AACA;AACA;;AACA,SAASC,KAAT,QAAsB,iBAAtB;AACA,SAASC,EAAT,QAAmB,iBAAnB;AACA,SAASC,MAAT,QAAuB,uBAAvB;AACA,SAASC,SAAT,QAA0B,oBAA1B;;AAEA,SAASC,sBAAT,CAAiC;AAChCC,EAAAA,mBADgC;AAEhCC,EAAAA,aAFgC;AAGhCC,EAAAA,eAHgC;AAIhCC,EAAAA;AAJgC,CAAjC,EAKI;AACH,QAAMC,GAAG,GACRJ,mBAAmB,CAACK,aAApB,KAAsCJ,aAAa,CAACI,aAAd,EAAtC,GACGT,EAAE,CACF,0HADE,CADL,GAIGA,EAAE,CACF,0HADE,CALN,CADG,CAUH;AACA;AACA;AACA;;AACAE,EAAAA,SAAS,CAAE,MAAM;AAChBH,IAAAA,KAAK,CAAEC,EAAE,CAAE,wDAAF,CAAJ,CAAL;AACA,GAFQ,EAEN,CAAEM,eAAF,EAAmBC,SAAnB,CAFM,CAAT;AAIA,SACC;AAAK,IAAA,SAAS,EAAC;AAAf,KACC,cAAC,MAAD;AACC,IAAA,aAAa,EAAG,IADjB;AAEC,IAAA,MAAM,EAAC,SAFR;AAGC,IAAA,aAAa,EAAG;AAHjB,KAKGC,GALH,CADD,CADD;AAWA;;AAED,SAASE,eAAT,CAA0B;AACzBJ,EAAAA,eADyB;AAEzBK,EAAAA,uBAFyB;AAGzBC,EAAAA,iBAHyB;AAIzBC,EAAAA,QAJyB;AAIf;AACVC,EAAAA,WALyB;AAMzBP,EAAAA;AANyB,CAA1B,EAOI;AACH,MACC,EAAID,eAAe,IAAIK,uBAAvB,KACA,EAAIJ,SAAS,IAAIK,iBAAjB,CAFD,EAGE;AACD,WAAO,IAAP;AACA;;AACD,QAAMR,mBAAmB,GAAGN,SAAS,CACpCQ,eAAe,IAAIK,uBADiB,CAArC;AAGA,QAAMN,aAAa,GAAGP,SAAS,CAAES,SAAS,IAAIK,iBAAf,CAA/B;AACA,QAAMG,eAAe,GACpBX,mBAAmB,CAACY,QAApB,OAAmC,CAAnC,IAAwCX,aAAa,CAACW,QAAd,OAA6B,CADtE;;AAGA,MACCD,eAAe,IACfjB,SAAS,CAACmB,UAAV,CAAsBb,mBAAtB,EAA2CC,aAA3C,EAA0D;AACzDa,IAAAA,KAAK,EAAE,IADkD;AAEzDC,IAAAA,IAAI,EACHL,WAAW,IAAMA,WAAW,KAAK,KAAhB,IAAyBD,QAAQ,IAAI,EAAtD,GACG,OADH,GAEG;AALqD,GAA1D,CAFD,EASE;AACD,WAAO,IAAP;AACA;;AAED,SACC,cAAC,sBAAD;AACC,IAAA,eAAe,EAAGP,eADnB;AAEC,IAAA,SAAS,EAAGC,SAFb;AAGC,IAAA,mBAAmB,EAAGH,mBAHvB;AAIC,IAAA,aAAa,EAAGC;AAJjB,IADD;AAQA;;AAED,eAAeK,eAAf","sourcesContent":["/**\n * External dependencies\n */\nimport tinycolor from 'tinycolor2';\n\n/**\n * WordPress dependencies\n */\nimport { speak } from '@wordpress/a11y';\nimport { __ } from '@wordpress/i18n';\nimport { Notice } from '@wordpress/components';\nimport { useEffect } from '@wordpress/element';\n\nfunction ContrastCheckerMessage( {\n\ttinyBackgroundColor,\n\ttinyTextColor,\n\tbackgroundColor,\n\ttextColor,\n} ) {\n\tconst msg =\n\t\ttinyBackgroundColor.getBrightness() < tinyTextColor.getBrightness()\n\t\t\t? __(\n\t\t\t\t\t'This color combination may be hard for people to read. Try using a darker background color and/or a brighter text color.'\n\t\t\t )\n\t\t\t: __(\n\t\t\t\t\t'This color combination may be hard for people to read. Try using a brighter background color and/or a darker text color.'\n\t\t\t );\n\n\t// Note: The `Notice` component can speak messages via its `spokenMessage`\n\t// prop, but the contrast checker requires granular control over when the\n\t// announcements are made. Notably, the message will be re-announced if a\n\t// new color combination is selected and the contrast is still insufficient.\n\tuseEffect( () => {\n\t\tspeak( __( 'This color combination may be hard for people to read.' ) );\n\t}, [ backgroundColor, textColor ] );\n\n\treturn (\n\t\t<div className=\"block-editor-contrast-checker\">\n\t\t\t<Notice\n\t\t\t\tspokenMessage={ null }\n\t\t\t\tstatus=\"warning\"\n\t\t\t\tisDismissible={ false }\n\t\t\t>\n\t\t\t\t{ msg }\n\t\t\t</Notice>\n\t\t</div>\n\t);\n}\n\nfunction ContrastChecker( {\n\tbackgroundColor,\n\tfallbackBackgroundColor,\n\tfallbackTextColor,\n\tfontSize, // font size value in pixels\n\tisLargeText,\n\ttextColor,\n} ) {\n\tif (\n\t\t! ( backgroundColor || fallbackBackgroundColor ) ||\n\t\t! ( textColor || fallbackTextColor )\n\t) {\n\t\treturn null;\n\t}\n\tconst tinyBackgroundColor = tinycolor(\n\t\tbackgroundColor || fallbackBackgroundColor\n\t);\n\tconst tinyTextColor = tinycolor( textColor || fallbackTextColor );\n\tconst hasTransparency =\n\t\ttinyBackgroundColor.getAlpha() !== 1 || tinyTextColor.getAlpha() !== 1;\n\n\tif (\n\t\thasTransparency ||\n\t\ttinycolor.isReadable( tinyBackgroundColor, tinyTextColor, {\n\t\t\tlevel: 'AA',\n\t\t\tsize:\n\t\t\t\tisLargeText || ( isLargeText !== false && fontSize >= 24 )\n\t\t\t\t\t? 'large'\n\t\t\t\t\t: 'small',\n\t\t} )\n\t) {\n\t\treturn null;\n\t}\n\n\treturn (\n\t\t<ContrastCheckerMessage\n\t\t\tbackgroundColor={ backgroundColor }\n\t\t\ttextColor={ textColor }\n\t\t\ttinyBackgroundColor={ tinyBackgroundColor }\n\t\t\ttinyTextColor={ tinyTextColor }\n\t\t/>\n\t);\n}\n\nexport default ContrastChecker;\n"]}
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/contrast-checker/index.js"],"names":["colord","extend","namesPlugin","a11yPlugin","speak","__","Notice","useEffect","ContrastCheckerMessage","colordBackgroundColor","colordTextColor","backgroundColor","textColor","msg","brightness","ContrastChecker","fallbackBackgroundColor","fallbackTextColor","fontSize","isLargeText","hasTransparency","alpha","isReadable","level","size"],"mappings":";;AAAA;AACA;AACA;AACA,SAASA,MAAT,EAAiBC,MAAjB,QAA+B,QAA/B;AACA,OAAOC,WAAP,MAAwB,sBAAxB;AACA,OAAOC,UAAP,MAAuB,qBAAvB;AAEA;AACA;AACA;;AACA,SAASC,KAAT,QAAsB,iBAAtB;AACA,SAASC,EAAT,QAAmB,iBAAnB;AACA,SAASC,MAAT,QAAuB,uBAAvB;AACA,SAASC,SAAT,QAA0B,oBAA1B;AAEAN,MAAM,CAAE,CAAEC,WAAF,EAAeC,UAAf,CAAF,CAAN;;AAEA,SAASK,sBAAT,CAAiC;AAChCC,EAAAA,qBADgC;AAEhCC,EAAAA,eAFgC;AAGhCC,EAAAA,eAHgC;AAIhCC,EAAAA;AAJgC,CAAjC,EAKI;AACH,QAAMC,GAAG,GACRJ,qBAAqB,CAACK,UAAtB,KAAqCJ,eAAe,CAACI,UAAhB,EAArC,GACGT,EAAE,CACF,0HADE,CADL,GAIGA,EAAE,CACF,0HADE,CALN,CADG,CAUH;AACA;AACA;AACA;;AACAE,EAAAA,SAAS,CAAE,MAAM;AAChBH,IAAAA,KAAK,CAAEC,EAAE,CAAE,wDAAF,CAAJ,CAAL;AACA,GAFQ,EAEN,CAAEM,eAAF,EAAmBC,SAAnB,CAFM,CAAT;AAIA,SACC;AAAK,IAAA,SAAS,EAAC;AAAf,KACC,cAAC,MAAD;AACC,IAAA,aAAa,EAAG,IADjB;AAEC,IAAA,MAAM,EAAC,SAFR;AAGC,IAAA,aAAa,EAAG;AAHjB,KAKGC,GALH,CADD,CADD;AAWA;;AAED,SAASE,eAAT,CAA0B;AACzBJ,EAAAA,eADyB;AAEzBK,EAAAA,uBAFyB;AAGzBC,EAAAA,iBAHyB;AAIzBC,EAAAA,QAJyB;AAIf;AACVC,EAAAA,WALyB;AAMzBP,EAAAA;AANyB,CAA1B,EAOI;AACH,MACC,EAAID,eAAe,IAAIK,uBAAvB,KACA,EAAIJ,SAAS,IAAIK,iBAAjB,CAFD,EAGE;AACD,WAAO,IAAP;AACA;;AACD,QAAMR,qBAAqB,GAAGT,MAAM,CACnCW,eAAe,IAAIK,uBADgB,CAApC;AAGA,QAAMN,eAAe,GAAGV,MAAM,CAAEY,SAAS,IAAIK,iBAAf,CAA9B;AACA,QAAMG,eAAe,GACpBX,qBAAqB,CAACY,KAAtB,OAAkC,CAAlC,IAAuCX,eAAe,CAACW,KAAhB,OAA4B,CADpE;;AAGA,MACCD,eAAe,IACfV,eAAe,CAACY,UAAhB,CAA4Bb,qBAA5B,EAAmD;AAClDc,IAAAA,KAAK,EAAE,IAD2C;AAElDC,IAAAA,IAAI,EACHL,WAAW,IAAMA,WAAW,KAAK,KAAhB,IAAyBD,QAAQ,IAAI,EAAtD,GACG,OADH,GAEG;AAL8C,GAAnD,CAFD,EASE;AACD,WAAO,IAAP;AACA;;AAED,SACC,cAAC,sBAAD;AACC,IAAA,eAAe,EAAGP,eADnB;AAEC,IAAA,SAAS,EAAGC,SAFb;AAGC,IAAA,qBAAqB,EAAGH,qBAHzB;AAIC,IAAA,eAAe,EAAGC;AAJnB,IADD;AAQA;;AAED,eAAeK,eAAf","sourcesContent":["/**\n * External dependencies\n */\nimport { colord, extend } from 'colord';\nimport namesPlugin from 'colord/plugins/names';\nimport a11yPlugin from 'colord/plugins/a11y';\n\n/**\n * WordPress dependencies\n */\nimport { speak } from '@wordpress/a11y';\nimport { __ } from '@wordpress/i18n';\nimport { Notice } from '@wordpress/components';\nimport { useEffect } from '@wordpress/element';\n\nextend( [ namesPlugin, a11yPlugin ] );\n\nfunction ContrastCheckerMessage( {\n\tcolordBackgroundColor,\n\tcolordTextColor,\n\tbackgroundColor,\n\ttextColor,\n} ) {\n\tconst msg =\n\t\tcolordBackgroundColor.brightness() < colordTextColor.brightness()\n\t\t\t? __(\n\t\t\t\t\t'This color combination may be hard for people to read. Try using a darker background color and/or a brighter text color.'\n\t\t\t )\n\t\t\t: __(\n\t\t\t\t\t'This color combination may be hard for people to read. Try using a brighter background color and/or a darker text color.'\n\t\t\t );\n\n\t// Note: The `Notice` component can speak messages via its `spokenMessage`\n\t// prop, but the contrast checker requires granular control over when the\n\t// announcements are made. Notably, the message will be re-announced if a\n\t// new color combination is selected and the contrast is still insufficient.\n\tuseEffect( () => {\n\t\tspeak( __( 'This color combination may be hard for people to read.' ) );\n\t}, [ backgroundColor, textColor ] );\n\n\treturn (\n\t\t<div className=\"block-editor-contrast-checker\">\n\t\t\t<Notice\n\t\t\t\tspokenMessage={ null }\n\t\t\t\tstatus=\"warning\"\n\t\t\t\tisDismissible={ false }\n\t\t\t>\n\t\t\t\t{ msg }\n\t\t\t</Notice>\n\t\t</div>\n\t);\n}\n\nfunction ContrastChecker( {\n\tbackgroundColor,\n\tfallbackBackgroundColor,\n\tfallbackTextColor,\n\tfontSize, // font size value in pixels\n\tisLargeText,\n\ttextColor,\n} ) {\n\tif (\n\t\t! ( backgroundColor || fallbackBackgroundColor ) ||\n\t\t! ( textColor || fallbackTextColor )\n\t) {\n\t\treturn null;\n\t}\n\tconst colordBackgroundColor = colord(\n\t\tbackgroundColor || fallbackBackgroundColor\n\t);\n\tconst colordTextColor = colord( textColor || fallbackTextColor );\n\tconst hasTransparency =\n\t\tcolordBackgroundColor.alpha() !== 1 || colordTextColor.alpha() !== 1;\n\n\tif (\n\t\thasTransparency ||\n\t\tcolordTextColor.isReadable( colordBackgroundColor, {\n\t\t\tlevel: 'AA',\n\t\t\tsize:\n\t\t\t\tisLargeText || ( isLargeText !== false && fontSize >= 24 )\n\t\t\t\t\t? 'large'\n\t\t\t\t\t: 'small',\n\t\t} )\n\t) {\n\t\treturn null;\n\t}\n\n\treturn (\n\t\t<ContrastCheckerMessage\n\t\t\tbackgroundColor={ backgroundColor }\n\t\t\ttextColor={ textColor }\n\t\t\tcolordBackgroundColor={ colordBackgroundColor }\n\t\t\tcolordTextColor={ colordTextColor }\n\t\t/>\n\t);\n}\n\nexport default ContrastChecker;\n"]}
@@ -30,10 +30,10 @@ export function useNotifyCopy() {
30
30
  let notice = '';
31
31
 
32
32
  if (selectedBlockClientIds.length === 1) {
33
+ var _getBlockType;
34
+
33
35
  const clientId = selectedBlockClientIds[0];
34
- const {
35
- title
36
- } = getBlockType(getBlockName(clientId));
36
+ const title = (_getBlockType = getBlockType(getBlockName(clientId))) === null || _getBlockType === void 0 ? void 0 : _getBlockType.title;
37
37
  notice = eventType === 'copy' ? sprintf( // Translators: Name of the block being copied, e.g. "Paragraph".
38
38
  __('Copied "%s" to clipboard.'), title) : sprintf( // Translators: Name of the block being cut, e.g. "Paragraph".
39
39
  __('Moved "%s" to clipboard.'), title);
@@ -90,6 +90,7 @@ export function useClipboardHandler() {
90
90
  return;
91
91
  }
92
92
 
93
+ const eventDefaultPrevented = event.defaultPrevented;
93
94
  event.preventDefault();
94
95
 
95
96
  if (event.type === 'copy' || event.type === 'cut') {
@@ -107,6 +108,11 @@ export function useClipboardHandler() {
107
108
  if (event.type === 'cut') {
108
109
  removeBlocks(selectedBlockClientIds);
109
110
  } else if (event.type === 'paste') {
111
+ if (eventDefaultPrevented) {
112
+ // This was likely already handled in rich-text/use-paste-handler.js
113
+ return;
114
+ }
115
+
110
116
  const {
111
117
  __experimentalCanUserUseUnfilteredHTML: canUserUseUnfilteredHTML
112
118
  } = getSettings();
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/block-editor/src/components/copy-handler/index.js"],"names":["useCallback","serialize","pasteHandler","store","blocksStore","documentHasSelection","documentHasUncollapsedSelection","useDispatch","useSelect","__","_n","sprintf","noticesStore","useRefEffect","getPasteEventData","blockEditorStore","useNotifyCopy","getBlockName","getBlockType","createSuccessNotice","eventType","selectedBlockClientIds","notice","length","clientId","title","type","useClipboardHandler","getBlocksByClientId","getSelectedBlockClientIds","hasMultiSelection","getSettings","flashBlock","removeBlocks","replaceBlocks","notifyCopy","node","handler","event","target","ownerDocument","hasSelection","contains","activeElement","preventDefault","blocks","serialized","clipboardData","setData","__experimentalCanUserUseUnfilteredHTML","canUserUseUnfilteredHTML","plainText","html","HTML","mode","addEventListener","removeEventListener","CopyHandler","children"],"mappings":"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","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { useCallback } from '@wordpress/element';\nimport {\n\tserialize,\n\tpasteHandler,\n\tstore as blocksStore,\n} from '@wordpress/blocks';\nimport {\n\tdocumentHasSelection,\n\tdocumentHasUncollapsedSelection,\n} from '@wordpress/dom';\nimport { useDispatch, useSelect } from '@wordpress/data';\nimport { __, _n, sprintf } from '@wordpress/i18n';\nimport { store as noticesStore } from '@wordpress/notices';\nimport { useRefEffect } from '@wordpress/compose';\n\n/**\n * Internal dependencies\n */\nimport { getPasteEventData } from '../../utils/get-paste-event-data';\nimport { store as blockEditorStore } from '../../store';\n\nexport function useNotifyCopy() {\n\tconst { getBlockName } = useSelect( blockEditorStore );\n\tconst { getBlockType } = useSelect( blocksStore );\n\tconst { createSuccessNotice } = useDispatch( noticesStore );\n\n\treturn useCallback( ( eventType, selectedBlockClientIds ) => {\n\t\tlet notice = '';\n\t\tif ( selectedBlockClientIds.length === 1 ) {\n\t\t\tconst clientId = selectedBlockClientIds[ 0 ];\n\t\t\tconst { title } = getBlockType( getBlockName( clientId ) );\n\t\t\tnotice =\n\t\t\t\teventType === 'copy'\n\t\t\t\t\t? sprintf(\n\t\t\t\t\t\t\t// Translators: Name of the block being copied, e.g. \"Paragraph\".\n\t\t\t\t\t\t\t__( 'Copied \"%s\" to clipboard.' ),\n\t\t\t\t\t\t\ttitle\n\t\t\t\t\t )\n\t\t\t\t\t: sprintf(\n\t\t\t\t\t\t\t// Translators: Name of the block being cut, e.g. \"Paragraph\".\n\t\t\t\t\t\t\t__( 'Moved \"%s\" to clipboard.' ),\n\t\t\t\t\t\t\ttitle\n\t\t\t\t\t );\n\t\t} else {\n\t\t\tnotice =\n\t\t\t\teventType === 'copy'\n\t\t\t\t\t? sprintf(\n\t\t\t\t\t\t\t// Translators: %d: Number of blocks being copied.\n\t\t\t\t\t\t\t_n(\n\t\t\t\t\t\t\t\t'Copied %d block to clipboard.',\n\t\t\t\t\t\t\t\t'Copied %d blocks to clipboard.',\n\t\t\t\t\t\t\t\tselectedBlockClientIds.length\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\tselectedBlockClientIds.length\n\t\t\t\t\t )\n\t\t\t\t\t: sprintf(\n\t\t\t\t\t\t\t// Translators: %d: Number of blocks being cut.\n\t\t\t\t\t\t\t_n(\n\t\t\t\t\t\t\t\t'Moved %d block to clipboard.',\n\t\t\t\t\t\t\t\t'Moved %d blocks to clipboard.',\n\t\t\t\t\t\t\t\tselectedBlockClientIds.length\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\tselectedBlockClientIds.length\n\t\t\t\t\t );\n\t\t}\n\t\tcreateSuccessNotice( notice, {\n\t\t\ttype: 'snackbar',\n\t\t} );\n\t}, [] );\n}\n\nexport function useClipboardHandler() {\n\tconst {\n\t\tgetBlocksByClientId,\n\t\tgetSelectedBlockClientIds,\n\t\thasMultiSelection,\n\t\tgetSettings,\n\t} = useSelect( blockEditorStore );\n\tconst { flashBlock, removeBlocks, replaceBlocks } = useDispatch(\n\t\tblockEditorStore\n\t);\n\tconst notifyCopy = useNotifyCopy();\n\n\treturn useRefEffect( ( node ) => {\n\t\tfunction handler( event ) {\n\t\t\tconst selectedBlockClientIds = getSelectedBlockClientIds();\n\n\t\t\tif ( selectedBlockClientIds.length === 0 ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Always handle multiple selected blocks.\n\t\t\tif ( ! hasMultiSelection() ) {\n\t\t\t\tconst { target } = event;\n\t\t\t\tconst { ownerDocument } = target;\n\t\t\t\t// If copying, only consider actual text selection as selection.\n\t\t\t\t// Otherwise, any focus on an input field is considered.\n\t\t\t\tconst hasSelection =\n\t\t\t\t\tevent.type === 'copy' || event.type === 'cut'\n\t\t\t\t\t\t? documentHasUncollapsedSelection( ownerDocument )\n\t\t\t\t\t\t: documentHasSelection( ownerDocument );\n\n\t\t\t\t// Let native copy behaviour take over in input fields.\n\t\t\t\tif ( hasSelection ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif ( ! node.contains( event.target.ownerDocument.activeElement ) ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tevent.preventDefault();\n\n\t\t\tif ( event.type === 'copy' || event.type === 'cut' ) {\n\t\t\t\tif ( selectedBlockClientIds.length === 1 ) {\n\t\t\t\t\tflashBlock( selectedBlockClientIds[ 0 ] );\n\t\t\t\t}\n\t\t\t\tnotifyCopy( event.type, selectedBlockClientIds );\n\t\t\t\tconst blocks = getBlocksByClientId( selectedBlockClientIds );\n\t\t\t\tconst serialized = serialize( blocks );\n\n\t\t\t\tevent.clipboardData.setData( 'text/plain', serialized );\n\t\t\t\tevent.clipboardData.setData( 'text/html', serialized );\n\t\t\t}\n\n\t\t\tif ( event.type === 'cut' ) {\n\t\t\t\tremoveBlocks( selectedBlockClientIds );\n\t\t\t} else if ( event.type === 'paste' ) {\n\t\t\t\tconst {\n\t\t\t\t\t__experimentalCanUserUseUnfilteredHTML: canUserUseUnfilteredHTML,\n\t\t\t\t} = getSettings();\n\t\t\t\tconst { plainText, html } = getPasteEventData( event );\n\t\t\t\tconst blocks = pasteHandler( {\n\t\t\t\t\tHTML: html,\n\t\t\t\t\tplainText,\n\t\t\t\t\tmode: 'BLOCKS',\n\t\t\t\t\tcanUserUseUnfilteredHTML,\n\t\t\t\t} );\n\n\t\t\t\treplaceBlocks(\n\t\t\t\t\tselectedBlockClientIds,\n\t\t\t\t\tblocks,\n\t\t\t\t\tblocks.length - 1,\n\t\t\t\t\t-1\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\n\t\tnode.ownerDocument.addEventListener( 'copy', handler );\n\t\tnode.ownerDocument.addEventListener( 'cut', handler );\n\t\tnode.ownerDocument.addEventListener( 'paste', handler );\n\n\t\treturn () => {\n\t\t\tnode.ownerDocument.removeEventListener( 'copy', handler );\n\t\t\tnode.ownerDocument.removeEventListener( 'cut', handler );\n\t\t\tnode.ownerDocument.removeEventListener( 'paste', handler );\n\t\t};\n\t}, [] );\n}\n\nfunction CopyHandler( { children } ) {\n\treturn <div ref={ useClipboardHandler() }>{ children }</div>;\n}\n\nexport default CopyHandler;\n"]}
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/copy-handler/index.js"],"names":["useCallback","serialize","pasteHandler","store","blocksStore","documentHasSelection","documentHasUncollapsedSelection","useDispatch","useSelect","__","_n","sprintf","noticesStore","useRefEffect","getPasteEventData","blockEditorStore","useNotifyCopy","getBlockName","getBlockType","createSuccessNotice","eventType","selectedBlockClientIds","notice","length","clientId","title","type","useClipboardHandler","getBlocksByClientId","getSelectedBlockClientIds","hasMultiSelection","getSettings","flashBlock","removeBlocks","replaceBlocks","notifyCopy","node","handler","event","target","ownerDocument","hasSelection","contains","activeElement","eventDefaultPrevented","defaultPrevented","preventDefault","blocks","serialized","clipboardData","setData","__experimentalCanUserUseUnfilteredHTML","canUserUseUnfilteredHTML","plainText","html","HTML","mode","addEventListener","removeEventListener","CopyHandler","children"],"mappings":"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","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { useCallback } from '@wordpress/element';\nimport {\n\tserialize,\n\tpasteHandler,\n\tstore as blocksStore,\n} from '@wordpress/blocks';\nimport {\n\tdocumentHasSelection,\n\tdocumentHasUncollapsedSelection,\n} from '@wordpress/dom';\nimport { useDispatch, useSelect } from '@wordpress/data';\nimport { __, _n, sprintf } from '@wordpress/i18n';\nimport { store as noticesStore } from '@wordpress/notices';\nimport { useRefEffect } from '@wordpress/compose';\n\n/**\n * Internal dependencies\n */\nimport { getPasteEventData } from '../../utils/get-paste-event-data';\nimport { store as blockEditorStore } from '../../store';\n\nexport function useNotifyCopy() {\n\tconst { getBlockName } = useSelect( blockEditorStore );\n\tconst { getBlockType } = useSelect( blocksStore );\n\tconst { createSuccessNotice } = useDispatch( noticesStore );\n\n\treturn useCallback( ( eventType, selectedBlockClientIds ) => {\n\t\tlet notice = '';\n\t\tif ( selectedBlockClientIds.length === 1 ) {\n\t\t\tconst clientId = selectedBlockClientIds[ 0 ];\n\t\t\tconst title = getBlockType( getBlockName( clientId ) )?.title;\n\t\t\tnotice =\n\t\t\t\teventType === 'copy'\n\t\t\t\t\t? sprintf(\n\t\t\t\t\t\t\t// Translators: Name of the block being copied, e.g. \"Paragraph\".\n\t\t\t\t\t\t\t__( 'Copied \"%s\" to clipboard.' ),\n\t\t\t\t\t\t\ttitle\n\t\t\t\t\t )\n\t\t\t\t\t: sprintf(\n\t\t\t\t\t\t\t// Translators: Name of the block being cut, e.g. \"Paragraph\".\n\t\t\t\t\t\t\t__( 'Moved \"%s\" to clipboard.' ),\n\t\t\t\t\t\t\ttitle\n\t\t\t\t\t );\n\t\t} else {\n\t\t\tnotice =\n\t\t\t\teventType === 'copy'\n\t\t\t\t\t? sprintf(\n\t\t\t\t\t\t\t// Translators: %d: Number of blocks being copied.\n\t\t\t\t\t\t\t_n(\n\t\t\t\t\t\t\t\t'Copied %d block to clipboard.',\n\t\t\t\t\t\t\t\t'Copied %d blocks to clipboard.',\n\t\t\t\t\t\t\t\tselectedBlockClientIds.length\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\tselectedBlockClientIds.length\n\t\t\t\t\t )\n\t\t\t\t\t: sprintf(\n\t\t\t\t\t\t\t// Translators: %d: Number of blocks being cut.\n\t\t\t\t\t\t\t_n(\n\t\t\t\t\t\t\t\t'Moved %d block to clipboard.',\n\t\t\t\t\t\t\t\t'Moved %d blocks to clipboard.',\n\t\t\t\t\t\t\t\tselectedBlockClientIds.length\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\tselectedBlockClientIds.length\n\t\t\t\t\t );\n\t\t}\n\t\tcreateSuccessNotice( notice, {\n\t\t\ttype: 'snackbar',\n\t\t} );\n\t}, [] );\n}\n\nexport function useClipboardHandler() {\n\tconst {\n\t\tgetBlocksByClientId,\n\t\tgetSelectedBlockClientIds,\n\t\thasMultiSelection,\n\t\tgetSettings,\n\t} = useSelect( blockEditorStore );\n\tconst { flashBlock, removeBlocks, replaceBlocks } = useDispatch(\n\t\tblockEditorStore\n\t);\n\tconst notifyCopy = useNotifyCopy();\n\n\treturn useRefEffect( ( node ) => {\n\t\tfunction handler( event ) {\n\t\t\tconst selectedBlockClientIds = getSelectedBlockClientIds();\n\n\t\t\tif ( selectedBlockClientIds.length === 0 ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Always handle multiple selected blocks.\n\t\t\tif ( ! hasMultiSelection() ) {\n\t\t\t\tconst { target } = event;\n\t\t\t\tconst { ownerDocument } = target;\n\t\t\t\t// If copying, only consider actual text selection as selection.\n\t\t\t\t// Otherwise, any focus on an input field is considered.\n\t\t\t\tconst hasSelection =\n\t\t\t\t\tevent.type === 'copy' || event.type === 'cut'\n\t\t\t\t\t\t? documentHasUncollapsedSelection( ownerDocument )\n\t\t\t\t\t\t: documentHasSelection( ownerDocument );\n\n\t\t\t\t// Let native copy behaviour take over in input fields.\n\t\t\t\tif ( hasSelection ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif ( ! node.contains( event.target.ownerDocument.activeElement ) ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst eventDefaultPrevented = event.defaultPrevented;\n\t\t\tevent.preventDefault();\n\n\t\t\tif ( event.type === 'copy' || event.type === 'cut' ) {\n\t\t\t\tif ( selectedBlockClientIds.length === 1 ) {\n\t\t\t\t\tflashBlock( selectedBlockClientIds[ 0 ] );\n\t\t\t\t}\n\t\t\t\tnotifyCopy( event.type, selectedBlockClientIds );\n\t\t\t\tconst blocks = getBlocksByClientId( selectedBlockClientIds );\n\t\t\t\tconst serialized = serialize( blocks );\n\n\t\t\t\tevent.clipboardData.setData( 'text/plain', serialized );\n\t\t\t\tevent.clipboardData.setData( 'text/html', serialized );\n\t\t\t}\n\n\t\t\tif ( event.type === 'cut' ) {\n\t\t\t\tremoveBlocks( selectedBlockClientIds );\n\t\t\t} else if ( event.type === 'paste' ) {\n\t\t\t\tif ( eventDefaultPrevented ) {\n\t\t\t\t\t// This was likely already handled in rich-text/use-paste-handler.js\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tconst {\n\t\t\t\t\t__experimentalCanUserUseUnfilteredHTML: canUserUseUnfilteredHTML,\n\t\t\t\t} = getSettings();\n\t\t\t\tconst { plainText, html } = getPasteEventData( event );\n\t\t\t\tconst blocks = pasteHandler( {\n\t\t\t\t\tHTML: html,\n\t\t\t\t\tplainText,\n\t\t\t\t\tmode: 'BLOCKS',\n\t\t\t\t\tcanUserUseUnfilteredHTML,\n\t\t\t\t} );\n\n\t\t\t\treplaceBlocks(\n\t\t\t\t\tselectedBlockClientIds,\n\t\t\t\t\tblocks,\n\t\t\t\t\tblocks.length - 1,\n\t\t\t\t\t-1\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\n\t\tnode.ownerDocument.addEventListener( 'copy', handler );\n\t\tnode.ownerDocument.addEventListener( 'cut', handler );\n\t\tnode.ownerDocument.addEventListener( 'paste', handler );\n\n\t\treturn () => {\n\t\t\tnode.ownerDocument.removeEventListener( 'copy', handler );\n\t\t\tnode.ownerDocument.removeEventListener( 'cut', handler );\n\t\t\tnode.ownerDocument.removeEventListener( 'paste', handler );\n\t\t};\n\t}, [] );\n}\n\nfunction CopyHandler( { children } ) {\n\treturn <div ref={ useClipboardHandler() }>{ children }</div>;\n}\n\nexport default CopyHandler;\n"]}
@@ -56,9 +56,9 @@ export function DefaultBlockAppender({
56
56
  // eslint-disable-next-line jsx-a11y/no-noninteractive-element-to-interactive-role
57
57
  ,
58
58
  role: "button",
59
- "aria-label": __('Add block') // The wp-block className is important for editor styles.
59
+ "aria-label": __('Add block') // A wrapping container for this one already has the wp-block className.
60
60
  ,
61
- className: "wp-block block-editor-default-block-appender__content",
61
+ className: "block-editor-default-block-appender__content",
62
62
  onFocus: onAppend
63
63
  }, showPrompt ? value : ZWNBSP), createElement(Inserter, {
64
64
  rootClientId: rootClientId,
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/block-editor/src/components/default-block-appender/index.js"],"names":["classnames","__","compose","getDefaultBlockName","decodeEntities","withSelect","withDispatch","Inserter","store","blockEditorStore","ZWNBSP","DefaultBlockAppender","isLocked","isVisible","onAppend","showPrompt","placeholder","rootClientId","value","select","ownProps","getBlockCount","getBlockName","isBlockValid","getSettings","getTemplateLock","isEmpty","isLastBlockDefault","lastBlockClientId","isLastBlockValid","bodyPlaceholder","dispatch","insertDefaultBlock","startTyping","undefined"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport classnames from 'classnames';\n\n/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\nimport { compose } from '@wordpress/compose';\nimport { getDefaultBlockName } from '@wordpress/blocks';\nimport { decodeEntities } from '@wordpress/html-entities';\nimport { withSelect, withDispatch } from '@wordpress/data';\n\n/**\n * Internal dependencies\n */\nimport Inserter from '../inserter';\nimport { store as blockEditorStore } from '../../store';\n\n/**\n * Zero width non-breaking space, used as padding for the paragraph when it is\n * empty.\n */\nexport const ZWNBSP = '\\ufeff';\n\nexport function DefaultBlockAppender( {\n\tisLocked,\n\tisVisible,\n\tonAppend,\n\tshowPrompt,\n\tplaceholder,\n\trootClientId,\n} ) {\n\tif ( isLocked || ! isVisible ) {\n\t\treturn null;\n\t}\n\n\tconst value =\n\t\tdecodeEntities( placeholder ) || __( 'Type / to choose a block' );\n\n\treturn (\n\t\t<div\n\t\t\tdata-root-client-id={ rootClientId || '' }\n\t\t\tclassName={ classnames( 'block-editor-default-block-appender', {\n\t\t\t\t'has-visible-prompt': showPrompt,\n\t\t\t} ) }\n\t\t>\n\t\t\t<p\n\t\t\t\ttabIndex=\"0\"\n\t\t\t\t// Only necessary for `useCanvasClickRedirect` to consider it\n\t\t\t\t// as a target. Ideally it should consider any tabbable target,\n\t\t\t\t// but the inserter is rendered in place while it should be\n\t\t\t\t// rendered in a popover, just like it does for an empty\n\t\t\t\t// paragraph block.\n\t\t\t\tcontentEditable\n\t\t\t\tsuppressContentEditableWarning\n\t\t\t\t// We want this element to be styled as a paragraph by themes.\n\t\t\t\t// eslint-disable-next-line jsx-a11y/no-noninteractive-element-to-interactive-role\n\t\t\t\trole=\"button\"\n\t\t\t\taria-label={ __( 'Add block' ) }\n\t\t\t\t// The wp-block className is important for editor styles.\n\t\t\t\tclassName=\"wp-block block-editor-default-block-appender__content\"\n\t\t\t\tonFocus={ onAppend }\n\t\t\t>\n\t\t\t\t{ showPrompt ? value : ZWNBSP }\n\t\t\t</p>\n\t\t\t<Inserter\n\t\t\t\trootClientId={ rootClientId }\n\t\t\t\tposition=\"bottom right\"\n\t\t\t\tisAppender\n\t\t\t\t__experimentalIsQuick\n\t\t\t/>\n\t\t</div>\n\t);\n}\n\nexport default compose(\n\twithSelect( ( select, ownProps ) => {\n\t\tconst {\n\t\t\tgetBlockCount,\n\t\t\tgetBlockName,\n\t\t\tisBlockValid,\n\t\t\tgetSettings,\n\t\t\tgetTemplateLock,\n\t\t} = select( blockEditorStore );\n\n\t\tconst isEmpty = ! getBlockCount( ownProps.rootClientId );\n\t\tconst isLastBlockDefault =\n\t\t\tgetBlockName( ownProps.lastBlockClientId ) ===\n\t\t\tgetDefaultBlockName();\n\t\tconst isLastBlockValid = isBlockValid( ownProps.lastBlockClientId );\n\t\tconst { bodyPlaceholder } = getSettings();\n\n\t\treturn {\n\t\t\tisVisible: isEmpty || ! isLastBlockDefault || ! isLastBlockValid,\n\t\t\tshowPrompt: isEmpty,\n\t\t\tisLocked: !! getTemplateLock( ownProps.rootClientId ),\n\t\t\tplaceholder: bodyPlaceholder,\n\t\t};\n\t} ),\n\twithDispatch( ( dispatch, ownProps ) => {\n\t\tconst { insertDefaultBlock, startTyping } = dispatch(\n\t\t\tblockEditorStore\n\t\t);\n\n\t\treturn {\n\t\t\tonAppend() {\n\t\t\t\tconst { rootClientId } = ownProps;\n\n\t\t\t\tinsertDefaultBlock( undefined, rootClientId );\n\t\t\t\tstartTyping();\n\t\t\t},\n\t\t};\n\t} )\n)( DefaultBlockAppender );\n"]}
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/default-block-appender/index.js"],"names":["classnames","__","compose","getDefaultBlockName","decodeEntities","withSelect","withDispatch","Inserter","store","blockEditorStore","ZWNBSP","DefaultBlockAppender","isLocked","isVisible","onAppend","showPrompt","placeholder","rootClientId","value","select","ownProps","getBlockCount","getBlockName","isBlockValid","getSettings","getTemplateLock","isEmpty","isLastBlockDefault","lastBlockClientId","isLastBlockValid","bodyPlaceholder","dispatch","insertDefaultBlock","startTyping","undefined"],"mappings":"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","sourcesContent":["/**\n * External dependencies\n */\nimport classnames from 'classnames';\n\n/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\nimport { compose } from '@wordpress/compose';\nimport { getDefaultBlockName } from '@wordpress/blocks';\nimport { decodeEntities } from '@wordpress/html-entities';\nimport { withSelect, withDispatch } from '@wordpress/data';\n\n/**\n * Internal dependencies\n */\nimport Inserter from '../inserter';\nimport { store as blockEditorStore } from '../../store';\n\n/**\n * Zero width non-breaking space, used as padding for the paragraph when it is\n * empty.\n */\nexport const ZWNBSP = '\\ufeff';\n\nexport function DefaultBlockAppender( {\n\tisLocked,\n\tisVisible,\n\tonAppend,\n\tshowPrompt,\n\tplaceholder,\n\trootClientId,\n} ) {\n\tif ( isLocked || ! isVisible ) {\n\t\treturn null;\n\t}\n\n\tconst value =\n\t\tdecodeEntities( placeholder ) || __( 'Type / to choose a block' );\n\n\treturn (\n\t\t<div\n\t\t\tdata-root-client-id={ rootClientId || '' }\n\t\t\tclassName={ classnames( 'block-editor-default-block-appender', {\n\t\t\t\t'has-visible-prompt': showPrompt,\n\t\t\t} ) }\n\t\t>\n\t\t\t<p\n\t\t\t\ttabIndex=\"0\"\n\t\t\t\t// Only necessary for `useCanvasClickRedirect` to consider it\n\t\t\t\t// as a target. Ideally it should consider any tabbable target,\n\t\t\t\t// but the inserter is rendered in place while it should be\n\t\t\t\t// rendered in a popover, just like it does for an empty\n\t\t\t\t// paragraph block.\n\t\t\t\tcontentEditable\n\t\t\t\tsuppressContentEditableWarning\n\t\t\t\t// We want this element to be styled as a paragraph by themes.\n\t\t\t\t// eslint-disable-next-line jsx-a11y/no-noninteractive-element-to-interactive-role\n\t\t\t\trole=\"button\"\n\t\t\t\taria-label={ __( 'Add block' ) }\n\t\t\t\t// A wrapping container for this one already has the wp-block className.\n\t\t\t\tclassName=\"block-editor-default-block-appender__content\"\n\t\t\t\tonFocus={ onAppend }\n\t\t\t>\n\t\t\t\t{ showPrompt ? value : ZWNBSP }\n\t\t\t</p>\n\t\t\t<Inserter\n\t\t\t\trootClientId={ rootClientId }\n\t\t\t\tposition=\"bottom right\"\n\t\t\t\tisAppender\n\t\t\t\t__experimentalIsQuick\n\t\t\t/>\n\t\t</div>\n\t);\n}\n\nexport default compose(\n\twithSelect( ( select, ownProps ) => {\n\t\tconst {\n\t\t\tgetBlockCount,\n\t\t\tgetBlockName,\n\t\t\tisBlockValid,\n\t\t\tgetSettings,\n\t\t\tgetTemplateLock,\n\t\t} = select( blockEditorStore );\n\n\t\tconst isEmpty = ! getBlockCount( ownProps.rootClientId );\n\t\tconst isLastBlockDefault =\n\t\t\tgetBlockName( ownProps.lastBlockClientId ) ===\n\t\t\tgetDefaultBlockName();\n\t\tconst isLastBlockValid = isBlockValid( ownProps.lastBlockClientId );\n\t\tconst { bodyPlaceholder } = getSettings();\n\n\t\treturn {\n\t\t\tisVisible: isEmpty || ! isLastBlockDefault || ! isLastBlockValid,\n\t\t\tshowPrompt: isEmpty,\n\t\t\tisLocked: !! getTemplateLock( ownProps.rootClientId ),\n\t\t\tplaceholder: bodyPlaceholder,\n\t\t};\n\t} ),\n\twithDispatch( ( dispatch, ownProps ) => {\n\t\tconst { insertDefaultBlock, startTyping } = dispatch(\n\t\t\tblockEditorStore\n\t\t);\n\n\t\treturn {\n\t\t\tonAppend() {\n\t\t\t\tconst { rootClientId } = ownProps;\n\n\t\t\t\tinsertDefaultBlock( undefined, rootClientId );\n\t\t\t\tstartTyping();\n\t\t\t},\n\t\t};\n\t} )\n)( DefaultBlockAppender );\n"]}
@@ -1,17 +1,11 @@
1
- import { createElement, Fragment } from "@wordpress/element";
1
+ import { createElement } from "@wordpress/element";
2
2
 
3
3
  /**
4
4
  * WordPress dependencies
5
5
  */
6
- import { ToolbarButton, DuotoneSwatch } from '@wordpress/components';
7
- import { useState } from '@wordpress/element';
6
+ import { Dropdown, DuotonePicker, DuotoneSwatch, MenuGroup, ToolbarButton } from '@wordpress/components';
8
7
  import { __ } from '@wordpress/i18n';
9
8
  import { DOWN } from '@wordpress/keycodes';
10
- /**
11
- * Internal dependencies
12
- */
13
-
14
- import DuotonePickerPopover from './duotone-picker-popover';
15
9
 
16
10
  function DuotoneControl({
17
11
  colorPalette,
@@ -21,38 +15,45 @@ function DuotoneControl({
21
15
  value,
22
16
  onChange
23
17
  }) {
24
- const [isOpen, setIsOpen] = useState(false);
25
-
26
- const onToggle = () => {
27
- setIsOpen(prev => !prev);
28
- };
29
-
30
- const openOnArrowDown = event => {
31
- if (!isOpen && event.keyCode === DOWN) {
32
- event.preventDefault();
33
- onToggle();
34
- }
35
- };
18
+ return createElement(Dropdown, {
19
+ popoverProps: {
20
+ className: 'block-editor-duotone-control__popover',
21
+ headerTitle: __('Duotone')
22
+ },
23
+ renderToggle: ({
24
+ isOpen,
25
+ onToggle
26
+ }) => {
27
+ const openOnArrowDown = event => {
28
+ if (!isOpen && event.keyCode === DOWN) {
29
+ event.preventDefault();
30
+ onToggle();
31
+ }
32
+ };
36
33
 
37
- return createElement(Fragment, null, createElement(ToolbarButton, {
38
- showTooltip: true,
39
- onClick: onToggle,
40
- "aria-haspopup": "true",
41
- "aria-expanded": isOpen,
42
- onKeyDown: openOnArrowDown,
43
- label: __('Apply duotone filter'),
44
- icon: createElement(DuotoneSwatch, {
45
- values: value
46
- })
47
- }), isOpen && createElement(DuotonePickerPopover, {
48
- value: value,
49
- onChange: onChange,
50
- onToggle: onToggle,
51
- duotonePalette: duotonePalette,
52
- colorPalette: colorPalette,
53
- disableCustomColors: disableCustomColors,
54
- disableCustomDuotone: disableCustomDuotone
55
- }));
34
+ return createElement(ToolbarButton, {
35
+ showTooltip: true,
36
+ onClick: onToggle,
37
+ "aria-haspopup": "true",
38
+ "aria-expanded": isOpen,
39
+ onKeyDown: openOnArrowDown,
40
+ label: __('Apply duotone filter'),
41
+ icon: createElement(DuotoneSwatch, {
42
+ values: value
43
+ })
44
+ });
45
+ },
46
+ renderContent: () => createElement(MenuGroup, {
47
+ label: __('Duotone')
48
+ }, createElement(DuotonePicker, {
49
+ colorPalette: colorPalette,
50
+ duotonePalette: duotonePalette,
51
+ disableCustomColors: disableCustomColors,
52
+ disableCustomDuotone: disableCustomDuotone,
53
+ value: value,
54
+ onChange: onChange
55
+ }))
56
+ });
56
57
  }
57
58
 
58
59
  export default DuotoneControl;
@@ -1 +1 @@
1
- {"version":3,"sources":["@wordpress/block-editor/src/components/duotone-control/index.js"],"names":["ToolbarButton","DuotoneSwatch","useState","__","DOWN","DuotonePickerPopover","DuotoneControl","colorPalette","duotonePalette","disableCustomColors","disableCustomDuotone","value","onChange","isOpen","setIsOpen","onToggle","prev","openOnArrowDown","event","keyCode","preventDefault"],"mappings":";;AAAA;AACA;AACA;AACA,SAASA,aAAT,EAAwBC,aAAxB,QAA6C,uBAA7C;AACA,SAASC,QAAT,QAAyB,oBAAzB;AACA,SAASC,EAAT,QAAmB,iBAAnB;AACA,SAASC,IAAT,QAAqB,qBAArB;AAEA;AACA;AACA;;AACA,OAAOC,oBAAP,MAAiC,0BAAjC;;AAEA,SAASC,cAAT,CAAyB;AACxBC,EAAAA,YADwB;AAExBC,EAAAA,cAFwB;AAGxBC,EAAAA,mBAHwB;AAIxBC,EAAAA,oBAJwB;AAKxBC,EAAAA,KALwB;AAMxBC,EAAAA;AANwB,CAAzB,EAOI;AACH,QAAM,CAAEC,MAAF,EAAUC,SAAV,IAAwBZ,QAAQ,CAAE,KAAF,CAAtC;;AAEA,QAAMa,QAAQ,GAAG,MAAM;AACtBD,IAAAA,SAAS,CAAIE,IAAF,IAAY,CAAEA,IAAhB,CAAT;AACA,GAFD;;AAIA,QAAMC,eAAe,GAAKC,KAAF,IAAa;AACpC,QAAK,CAAEL,MAAF,IAAYK,KAAK,CAACC,OAAN,KAAkBf,IAAnC,EAA0C;AACzCc,MAAAA,KAAK,CAACE,cAAN;AACAL,MAAAA,QAAQ;AACR;AACD,GALD;;AAOA,SACC,8BACC,cAAC,aAAD;AACC,IAAA,WAAW,MADZ;AAEC,IAAA,OAAO,EAAGA,QAFX;AAGC,qBAAc,MAHf;AAIC,qBAAgBF,MAJjB;AAKC,IAAA,SAAS,EAAGI,eALb;AAMC,IAAA,KAAK,EAAGd,EAAE,CAAE,sBAAF,CANX;AAOC,IAAA,IAAI,EAAG,cAAC,aAAD;AAAe,MAAA,MAAM,EAAGQ;AAAxB;AAPR,IADD,EAUGE,MAAM,IACP,cAAC,oBAAD;AACC,IAAA,KAAK,EAAGF,KADT;AAEC,IAAA,QAAQ,EAAGC,QAFZ;AAGC,IAAA,QAAQ,EAAGG,QAHZ;AAIC,IAAA,cAAc,EAAGP,cAJlB;AAKC,IAAA,YAAY,EAAGD,YALhB;AAMC,IAAA,mBAAmB,EAAGE,mBANvB;AAOC,IAAA,oBAAoB,EAAGC;AAPxB,IAXF,CADD;AAwBA;;AAED,eAAeJ,cAAf","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { ToolbarButton, DuotoneSwatch } from '@wordpress/components';\nimport { useState } from '@wordpress/element';\nimport { __ } from '@wordpress/i18n';\nimport { DOWN } from '@wordpress/keycodes';\n\n/**\n * Internal dependencies\n */\nimport DuotonePickerPopover from './duotone-picker-popover';\n\nfunction DuotoneControl( {\n\tcolorPalette,\n\tduotonePalette,\n\tdisableCustomColors,\n\tdisableCustomDuotone,\n\tvalue,\n\tonChange,\n} ) {\n\tconst [ isOpen, setIsOpen ] = useState( false );\n\n\tconst onToggle = () => {\n\t\tsetIsOpen( ( prev ) => ! prev );\n\t};\n\n\tconst openOnArrowDown = ( event ) => {\n\t\tif ( ! isOpen && event.keyCode === DOWN ) {\n\t\t\tevent.preventDefault();\n\t\t\tonToggle();\n\t\t}\n\t};\n\n\treturn (\n\t\t<>\n\t\t\t<ToolbarButton\n\t\t\t\tshowTooltip\n\t\t\t\tonClick={ onToggle }\n\t\t\t\taria-haspopup=\"true\"\n\t\t\t\taria-expanded={ isOpen }\n\t\t\t\tonKeyDown={ openOnArrowDown }\n\t\t\t\tlabel={ __( 'Apply duotone filter' ) }\n\t\t\t\ticon={ <DuotoneSwatch values={ value } /> }\n\t\t\t/>\n\t\t\t{ isOpen && (\n\t\t\t\t<DuotonePickerPopover\n\t\t\t\t\tvalue={ value }\n\t\t\t\t\tonChange={ onChange }\n\t\t\t\t\tonToggle={ onToggle }\n\t\t\t\t\tduotonePalette={ duotonePalette }\n\t\t\t\t\tcolorPalette={ colorPalette }\n\t\t\t\t\tdisableCustomColors={ disableCustomColors }\n\t\t\t\t\tdisableCustomDuotone={ disableCustomDuotone }\n\t\t\t\t/>\n\t\t\t) }\n\t\t</>\n\t);\n}\n\nexport default DuotoneControl;\n"]}
1
+ {"version":3,"sources":["@wordpress/block-editor/src/components/duotone-control/index.js"],"names":["Dropdown","DuotonePicker","DuotoneSwatch","MenuGroup","ToolbarButton","__","DOWN","DuotoneControl","colorPalette","duotonePalette","disableCustomColors","disableCustomDuotone","value","onChange","className","headerTitle","isOpen","onToggle","openOnArrowDown","event","keyCode","preventDefault"],"mappings":";;AAAA;AACA;AACA;AACA,SACCA,QADD,EAECC,aAFD,EAGCC,aAHD,EAICC,SAJD,EAKCC,aALD,QAMO,uBANP;AAOA,SAASC,EAAT,QAAmB,iBAAnB;AACA,SAASC,IAAT,QAAqB,qBAArB;;AAEA,SAASC,cAAT,CAAyB;AACxBC,EAAAA,YADwB;AAExBC,EAAAA,cAFwB;AAGxBC,EAAAA,mBAHwB;AAIxBC,EAAAA,oBAJwB;AAKxBC,EAAAA,KALwB;AAMxBC,EAAAA;AANwB,CAAzB,EAOI;AACH,SACC,cAAC,QAAD;AACC,IAAA,YAAY,EAAG;AACdC,MAAAA,SAAS,EAAE,uCADG;AAEdC,MAAAA,WAAW,EAAEV,EAAE,CAAE,SAAF;AAFD,KADhB;AAKC,IAAA,YAAY,EAAG,CAAE;AAAEW,MAAAA,MAAF;AAAUC,MAAAA;AAAV,KAAF,KAA4B;AAC1C,YAAMC,eAAe,GAAKC,KAAF,IAAa;AACpC,YAAK,CAAEH,MAAF,IAAYG,KAAK,CAACC,OAAN,KAAkBd,IAAnC,EAA0C;AACzCa,UAAAA,KAAK,CAACE,cAAN;AACAJ,UAAAA,QAAQ;AACR;AACD,OALD;;AAMA,aACC,cAAC,aAAD;AACC,QAAA,WAAW,MADZ;AAEC,QAAA,OAAO,EAAGA,QAFX;AAGC,yBAAc,MAHf;AAIC,yBAAgBD,MAJjB;AAKC,QAAA,SAAS,EAAGE,eALb;AAMC,QAAA,KAAK,EAAGb,EAAE,CAAE,sBAAF,CANX;AAOC,QAAA,IAAI,EAAG,cAAC,aAAD;AAAe,UAAA,MAAM,EAAGO;AAAxB;AAPR,QADD;AAWA,KAvBF;AAwBC,IAAA,aAAa,EAAG,MACf,cAAC,SAAD;AAAW,MAAA,KAAK,EAAGP,EAAE,CAAE,SAAF;AAArB,OACC,cAAC,aAAD;AACC,MAAA,YAAY,EAAGG,YADhB;AAEC,MAAA,cAAc,EAAGC,cAFlB;AAGC,MAAA,mBAAmB,EAAGC,mBAHvB;AAIC,MAAA,oBAAoB,EAAGC,oBAJxB;AAKC,MAAA,KAAK,EAAGC,KALT;AAMC,MAAA,QAAQ,EAAGC;AANZ,MADD;AAzBF,IADD;AAuCA;;AAED,eAAeN,cAAf","sourcesContent":["/**\n * WordPress dependencies\n */\nimport {\n\tDropdown,\n\tDuotonePicker,\n\tDuotoneSwatch,\n\tMenuGroup,\n\tToolbarButton,\n} from '@wordpress/components';\nimport { __ } from '@wordpress/i18n';\nimport { DOWN } from '@wordpress/keycodes';\n\nfunction DuotoneControl( {\n\tcolorPalette,\n\tduotonePalette,\n\tdisableCustomColors,\n\tdisableCustomDuotone,\n\tvalue,\n\tonChange,\n} ) {\n\treturn (\n\t\t<Dropdown\n\t\t\tpopoverProps={ {\n\t\t\t\tclassName: 'block-editor-duotone-control__popover',\n\t\t\t\theaderTitle: __( 'Duotone' ),\n\t\t\t} }\n\t\t\trenderToggle={ ( { isOpen, onToggle } ) => {\n\t\t\t\tconst openOnArrowDown = ( event ) => {\n\t\t\t\t\tif ( ! isOpen && event.keyCode === DOWN ) {\n\t\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\t\tonToggle();\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t\treturn (\n\t\t\t\t\t<ToolbarButton\n\t\t\t\t\t\tshowTooltip\n\t\t\t\t\t\tonClick={ onToggle }\n\t\t\t\t\t\taria-haspopup=\"true\"\n\t\t\t\t\t\taria-expanded={ isOpen }\n\t\t\t\t\t\tonKeyDown={ openOnArrowDown }\n\t\t\t\t\t\tlabel={ __( 'Apply duotone filter' ) }\n\t\t\t\t\t\ticon={ <DuotoneSwatch values={ value } /> }\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\t} }\n\t\t\trenderContent={ () => (\n\t\t\t\t<MenuGroup label={ __( 'Duotone' ) }>\n\t\t\t\t\t<DuotonePicker\n\t\t\t\t\t\tcolorPalette={ colorPalette }\n\t\t\t\t\t\tduotonePalette={ duotonePalette }\n\t\t\t\t\t\tdisableCustomColors={ disableCustomColors }\n\t\t\t\t\t\tdisableCustomDuotone={ disableCustomDuotone }\n\t\t\t\t\t\tvalue={ value }\n\t\t\t\t\t\tonChange={ onChange }\n\t\t\t\t\t/>\n\t\t\t\t</MenuGroup>\n\t\t\t) }\n\t\t/>\n\t);\n}\n\nexport default DuotoneControl;\n"]}
@@ -3,7 +3,9 @@ import { createElement, Fragment } from "@wordpress/element";
3
3
  /**
4
4
  * External dependencies
5
5
  */
6
- import tinycolor from 'tinycolor2';
6
+ import { colord, extend } from 'colord';
7
+ import namesPlugin from 'colord/plugins/names';
8
+ import a11yPlugin from 'colord/plugins/a11y';
7
9
  /**
8
10
  * WordPress dependencies
9
11
  */
@@ -15,6 +17,7 @@ import { useCallback, useMemo } from '@wordpress/element';
15
17
 
16
18
  import transformStyles from '../../utils/transform-styles';
17
19
  const EDITOR_STYLES_SELECTOR = '.editor-styles-wrapper';
20
+ extend([namesPlugin, a11yPlugin]);
18
21
 
19
22
  function useDarkThemeBodyClassName(styles) {
20
23
  return useCallback(node => {
@@ -43,10 +46,11 @@ function useDarkThemeBodyClassName(styles) {
43
46
  body.removeChild(tempCanvas);
44
47
  } else {
45
48
  backgroundColor = defaultView.getComputedStyle(canvas, null).getPropertyValue('background-color');
46
- } // If background is transparent, it should be treated as light color.
49
+ }
47
50
 
51
+ const colordBackgroundColor = colord(backgroundColor); // If background is transparent, it should be treated as light color.
48
52
 
49
- if (tinycolor(backgroundColor).getLuminance() > 0.5 || tinycolor(backgroundColor).getAlpha() === 0) {
53
+ if (colordBackgroundColor.luminance() > 0.5 || colordBackgroundColor.alpha() === 0) {
50
54
  body.classList.remove('is-dark-theme');
51
55
  } else {
52
56
  body.classList.add('is-dark-theme');