@wordpress/editor 14.33.3 → 14.34.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (301) hide show
  1. package/CHANGELOG.md +2 -0
  2. package/build/components/collab-sidebar/comment-author-info.js +26 -14
  3. package/build/components/collab-sidebar/comment-author-info.js.map +2 -2
  4. package/build/components/document-bar/index.js +16 -3
  5. package/build/components/document-bar/index.js.map +2 -2
  6. package/build/components/editor/index.js +23 -4
  7. package/build/components/editor/index.js.map +3 -3
  8. package/build/components/editor-interface/index.js +15 -10
  9. package/build/components/editor-interface/index.js.map +3 -3
  10. package/build/components/entities-saved-states/entity-type-list.js +19 -15
  11. package/build/components/entities-saved-states/entity-type-list.js.map +3 -3
  12. package/build/components/global-styles/block-link.js +70 -0
  13. package/build/components/global-styles/block-link.js.map +7 -0
  14. package/build/components/global-styles/header.js +54 -0
  15. package/build/components/global-styles/header.js.map +7 -0
  16. package/build/components/global-styles/hooks.js +176 -0
  17. package/build/components/global-styles/hooks.js.map +7 -0
  18. package/build/components/global-styles/index.js +138 -0
  19. package/build/components/global-styles/index.js.map +7 -0
  20. package/build/components/global-styles/menu.js +95 -0
  21. package/build/components/global-styles/menu.js.map +7 -0
  22. package/build/components/global-styles-provider/index.js +3 -49
  23. package/build/components/global-styles-provider/index.js.map +3 -3
  24. package/build/components/global-styles-renderer/index.js +55 -0
  25. package/build/components/global-styles-renderer/index.js.map +7 -0
  26. package/build/components/global-styles-sidebar/default-sidebar.js +66 -0
  27. package/build/components/global-styles-sidebar/default-sidebar.js.map +7 -0
  28. package/build/components/global-styles-sidebar/index.js +182 -0
  29. package/build/components/global-styles-sidebar/index.js.map +7 -0
  30. package/build/components/global-styles-sidebar/welcome-guide-image.js +37 -0
  31. package/build/components/global-styles-sidebar/welcome-guide-image.js.map +7 -0
  32. package/build/components/global-styles-sidebar/welcome-guide.js +143 -0
  33. package/build/components/global-styles-sidebar/welcome-guide.js.map +7 -0
  34. package/build/components/header/index.js +12 -9
  35. package/build/components/header/index.js.map +2 -2
  36. package/build/components/post-featured-image/index.js +32 -1
  37. package/build/components/post-featured-image/index.js.map +3 -3
  38. package/build/components/provider/index.js +0 -2
  39. package/build/components/provider/index.js.map +3 -3
  40. package/build/components/style-book/categories.js +86 -0
  41. package/build/components/style-book/categories.js.map +7 -0
  42. package/build/components/style-book/color-examples.js +64 -0
  43. package/build/components/style-book/color-examples.js.map +7 -0
  44. package/build/components/style-book/constants.js +319 -0
  45. package/build/components/style-book/constants.js.map +7 -0
  46. package/build/components/style-book/duotone-examples.js +68 -0
  47. package/build/components/style-book/duotone-examples.js.map +7 -0
  48. package/build/components/style-book/examples.js +237 -0
  49. package/build/components/style-book/examples.js.map +7 -0
  50. package/build/components/style-book/index.js +627 -0
  51. package/build/components/style-book/index.js.map +7 -0
  52. package/build/components/style-book/types.js +17 -0
  53. package/build/components/style-book/types.js.map +7 -0
  54. package/build/components/styles-canvas/index.js +138 -0
  55. package/build/components/styles-canvas/index.js.map +7 -0
  56. package/build/components/styles-canvas/revisions.js +121 -0
  57. package/build/components/styles-canvas/revisions.js.map +7 -0
  58. package/build/components/styles-canvas/style-book.js +68 -0
  59. package/build/components/styles-canvas/style-book.js.map +7 -0
  60. package/build/components/visual-editor/index.js +4 -3
  61. package/build/components/visual-editor/index.js.map +2 -2
  62. package/build/dataviews/fields/content-preview/content-preview-view.js.map +2 -2
  63. package/build/hooks/index.js +1 -0
  64. package/build/hooks/index.js.map +2 -2
  65. package/build/hooks/media-upload.js +15 -4
  66. package/build/hooks/media-upload.js.map +3 -3
  67. package/build/hooks/push-changes-to-global-styles/index.js +322 -0
  68. package/build/hooks/push-changes-to-global-styles/index.js.map +7 -0
  69. package/build/hooks/use-global-styles-output.js +74 -0
  70. package/build/hooks/use-global-styles-output.js.map +7 -0
  71. package/build/private-apis.js +10 -5
  72. package/build/private-apis.js.map +3 -3
  73. package/build/store/private-actions.js +23 -0
  74. package/build/store/private-actions.js.map +2 -2
  75. package/build/store/private-selectors.js +10 -0
  76. package/build/store/private-selectors.js.map +2 -2
  77. package/build/store/reducer.js +24 -0
  78. package/build/store/reducer.js.map +2 -2
  79. package/build/{components/editor-interface/content-slot-fill.js → utils/set-nested-value.js} +24 -10
  80. package/build/utils/set-nested-value.js.map +7 -0
  81. package/build-module/components/collab-sidebar/comment-author-info.js +26 -14
  82. package/build-module/components/collab-sidebar/comment-author-info.js.map +2 -2
  83. package/build-module/components/document-bar/index.js +16 -3
  84. package/build-module/components/document-bar/index.js.map +2 -2
  85. package/build-module/components/editor/index.js +23 -4
  86. package/build-module/components/editor/index.js.map +2 -2
  87. package/build-module/components/editor-interface/index.js +15 -10
  88. package/build-module/components/editor-interface/index.js.map +2 -2
  89. package/build-module/components/entities-saved-states/entity-type-list.js +18 -14
  90. package/build-module/components/entities-saved-states/entity-type-list.js.map +2 -2
  91. package/build-module/components/global-styles/block-link.js +46 -0
  92. package/build-module/components/global-styles/block-link.js.map +7 -0
  93. package/build-module/components/global-styles/header.js +41 -0
  94. package/build-module/components/global-styles/header.js.map +7 -0
  95. package/build-module/components/global-styles/hooks.js +154 -0
  96. package/build-module/components/global-styles/hooks.js.map +7 -0
  97. package/build-module/components/global-styles/index.js +112 -0
  98. package/build-module/components/global-styles/index.js.map +7 -0
  99. package/build-module/components/global-styles/menu.js +71 -0
  100. package/build-module/components/global-styles/menu.js.map +7 -0
  101. package/build-module/components/global-styles-provider/index.js +3 -37
  102. package/build-module/components/global-styles-provider/index.js.map +2 -2
  103. package/build-module/components/global-styles-renderer/index.js +31 -0
  104. package/build-module/components/global-styles-renderer/index.js.map +7 -0
  105. package/build-module/components/global-styles-sidebar/default-sidebar.js +49 -0
  106. package/build-module/components/global-styles-sidebar/default-sidebar.js.map +7 -0
  107. package/build-module/components/global-styles-sidebar/index.js +152 -0
  108. package/build-module/components/global-styles-sidebar/index.js.map +7 -0
  109. package/build-module/components/global-styles-sidebar/welcome-guide-image.js +17 -0
  110. package/build-module/components/global-styles-sidebar/welcome-guide-image.js.map +7 -0
  111. package/build-module/components/global-styles-sidebar/welcome-guide.js +113 -0
  112. package/build-module/components/global-styles-sidebar/welcome-guide.js.map +7 -0
  113. package/build-module/components/header/index.js +12 -9
  114. package/build-module/components/header/index.js.map +2 -2
  115. package/build-module/components/post-featured-image/index.js +35 -3
  116. package/build-module/components/post-featured-image/index.js.map +2 -2
  117. package/build-module/components/provider/index.js +0 -2
  118. package/build-module/components/provider/index.js.map +2 -2
  119. package/build-module/components/style-book/categories.js +64 -0
  120. package/build-module/components/style-book/categories.js.map +7 -0
  121. package/build-module/components/style-book/color-examples.js +37 -0
  122. package/build-module/components/style-book/color-examples.js.map +7 -0
  123. package/build-module/components/style-book/constants.js +290 -0
  124. package/build-module/components/style-book/constants.js.map +7 -0
  125. package/build-module/components/style-book/duotone-examples.js +48 -0
  126. package/build-module/components/style-book/duotone-examples.js.map +7 -0
  127. package/build-module/components/style-book/examples.js +208 -0
  128. package/build-module/components/style-book/examples.js.map +7 -0
  129. package/build-module/components/style-book/index.js +618 -0
  130. package/build-module/components/style-book/index.js.map +7 -0
  131. package/build-module/components/style-book/types.js +1 -0
  132. package/build-module/components/style-book/types.js.map +7 -0
  133. package/build-module/components/styles-canvas/index.js +104 -0
  134. package/build-module/components/styles-canvas/index.js.map +7 -0
  135. package/build-module/components/styles-canvas/revisions.js +107 -0
  136. package/build-module/components/styles-canvas/revisions.js.map +7 -0
  137. package/build-module/components/styles-canvas/style-book.js +38 -0
  138. package/build-module/components/styles-canvas/style-book.js.map +7 -0
  139. package/build-module/components/visual-editor/index.js +4 -3
  140. package/build-module/components/visual-editor/index.js.map +2 -2
  141. package/build-module/dataviews/fields/content-preview/content-preview-view.js.map +2 -2
  142. package/build-module/hooks/index.js +1 -0
  143. package/build-module/hooks/index.js.map +2 -2
  144. package/build-module/hooks/media-upload.js +19 -5
  145. package/build-module/hooks/media-upload.js.map +2 -2
  146. package/build-module/hooks/push-changes-to-global-styles/index.js +309 -0
  147. package/build-module/hooks/push-changes-to-global-styles/index.js.map +7 -0
  148. package/build-module/hooks/use-global-styles-output.js +49 -0
  149. package/build-module/hooks/use-global-styles-output.js.map +7 -0
  150. package/build-module/private-apis.js +10 -8
  151. package/build-module/private-apis.js.map +2 -2
  152. package/build-module/store/private-actions.js +20 -0
  153. package/build-module/store/private-actions.js.map +2 -2
  154. package/build-module/store/private-selectors.js +8 -0
  155. package/build-module/store/private-selectors.js.map +2 -2
  156. package/build-module/store/reducer.js +22 -0
  157. package/build-module/store/reducer.js.map +2 -2
  158. package/build-module/utils/set-nested-value.js +23 -0
  159. package/build-module/utils/set-nested-value.js.map +7 -0
  160. package/build-style/style-rtl.css +3017 -11
  161. package/build-style/style.css +3018 -11
  162. package/build-types/components/collab-sidebar/comment-author-info.d.ts +5 -16
  163. package/build-types/components/collab-sidebar/comment-author-info.d.ts.map +1 -1
  164. package/build-types/components/document-bar/index.d.ts +2 -2
  165. package/build-types/components/document-bar/index.d.ts.map +1 -1
  166. package/build-types/components/editor/index.d.ts.map +1 -1
  167. package/build-types/components/editor-interface/index.d.ts +1 -3
  168. package/build-types/components/editor-interface/index.d.ts.map +1 -1
  169. package/build-types/components/entities-saved-states/entity-type-list.d.ts.map +1 -1
  170. package/build-types/components/global-styles/block-link.d.ts +12 -0
  171. package/build-types/components/global-styles/block-link.d.ts.map +1 -0
  172. package/build-types/components/global-styles/header.d.ts +7 -0
  173. package/build-types/components/global-styles/header.d.ts.map +1 -0
  174. package/build-types/components/global-styles/hooks.d.ts +24 -0
  175. package/build-types/components/global-styles/hooks.d.ts.map +1 -0
  176. package/build-types/components/global-styles/index.d.ts +6 -0
  177. package/build-types/components/global-styles/index.d.ts.map +1 -0
  178. package/build-types/components/global-styles/menu.d.ts +13 -0
  179. package/build-types/components/global-styles/menu.d.ts.map +1 -0
  180. package/build-types/components/global-styles-provider/index.d.ts +1 -5
  181. package/build-types/components/global-styles-provider/index.d.ts.map +1 -1
  182. package/build-types/components/global-styles-renderer/index.d.ts +4 -0
  183. package/build-types/components/global-styles-renderer/index.d.ts.map +1 -0
  184. package/build-types/components/global-styles-sidebar/default-sidebar.d.ts +13 -0
  185. package/build-types/components/global-styles-sidebar/default-sidebar.d.ts.map +1 -0
  186. package/build-types/components/global-styles-sidebar/index.d.ts +2 -0
  187. package/build-types/components/global-styles-sidebar/index.d.ts.map +1 -0
  188. package/build-types/components/global-styles-sidebar/welcome-guide-image.d.ts +5 -0
  189. package/build-types/components/global-styles-sidebar/welcome-guide-image.d.ts.map +1 -0
  190. package/build-types/components/global-styles-sidebar/welcome-guide.d.ts +2 -0
  191. package/build-types/components/global-styles-sidebar/welcome-guide.d.ts.map +1 -0
  192. package/build-types/components/header/index.d.ts +1 -3
  193. package/build-types/components/header/index.d.ts.map +1 -1
  194. package/build-types/components/provider/index.d.ts.map +1 -1
  195. package/build-types/components/style-book/categories.d.ts +18 -0
  196. package/build-types/components/style-book/categories.d.ts.map +1 -0
  197. package/build-types/components/style-book/color-examples.d.ts +7 -0
  198. package/build-types/components/style-book/color-examples.d.ts.map +1 -0
  199. package/build-types/components/style-book/constants.d.ts +11 -0
  200. package/build-types/components/style-book/constants.d.ts.map +1 -0
  201. package/build-types/components/style-book/duotone-examples.d.ts +9 -0
  202. package/build-types/components/style-book/duotone-examples.d.ts.map +1 -0
  203. package/build-types/components/style-book/examples.d.ts +12 -0
  204. package/build-types/components/style-book/examples.d.ts.map +1 -0
  205. package/build-types/components/style-book/index.d.ts +31 -0
  206. package/build-types/components/style-book/index.d.ts.map +1 -0
  207. package/build-types/components/style-book/types.d.ts +72 -0
  208. package/build-types/components/style-book/types.d.ts.map +1 -0
  209. package/build-types/components/styles-canvas/index.d.ts +16 -0
  210. package/build-types/components/styles-canvas/index.d.ts.map +1 -0
  211. package/build-types/components/styles-canvas/revisions.d.ts +5 -0
  212. package/build-types/components/styles-canvas/revisions.d.ts.map +1 -0
  213. package/build-types/components/styles-canvas/style-book.d.ts +6 -0
  214. package/build-types/components/styles-canvas/style-book.d.ts.map +1 -0
  215. package/build-types/components/visual-editor/index.d.ts +1 -2
  216. package/build-types/components/visual-editor/index.d.ts.map +1 -1
  217. package/build-types/dataviews/fields/content-preview/content-preview-view.d.ts.map +1 -1
  218. package/build-types/hooks/push-changes-to-global-styles/index.d.ts +2 -0
  219. package/build-types/hooks/push-changes-to-global-styles/index.d.ts.map +1 -0
  220. package/build-types/hooks/use-global-styles-output.d.ts +18 -0
  221. package/build-types/hooks/use-global-styles-output.d.ts.map +1 -0
  222. package/build-types/private-apis.d.ts.map +1 -1
  223. package/build-types/store/private-actions.d.ts +20 -0
  224. package/build-types/store/private-actions.d.ts.map +1 -1
  225. package/build-types/store/private-selectors.d.ts +14 -0
  226. package/build-types/store/private-selectors.d.ts.map +1 -1
  227. package/build-types/store/reducer.d.ts +20 -0
  228. package/build-types/store/reducer.d.ts.map +1 -1
  229. package/build-types/utils/set-nested-value.d.ts +20 -0
  230. package/build-types/utils/set-nested-value.d.ts.map +1 -0
  231. package/package.json +40 -40
  232. package/src/components/collab-sidebar/comment-author-info.js +32 -25
  233. package/src/components/collab-sidebar/style.scss +1 -1
  234. package/src/components/document-bar/index.js +18 -3
  235. package/src/components/editor/index.js +25 -1
  236. package/src/components/editor-help/style.scss +1 -1
  237. package/src/components/editor-interface/index.js +40 -39
  238. package/src/components/entities-saved-states/entity-type-list.js +19 -17
  239. package/src/components/global-styles/block-link.js +65 -0
  240. package/src/components/global-styles/header.js +48 -0
  241. package/src/components/global-styles/hooks.js +216 -0
  242. package/src/components/global-styles/index.js +125 -0
  243. package/src/components/global-styles/menu.js +101 -0
  244. package/src/components/global-styles/style.scss +11 -0
  245. package/src/components/global-styles-provider/index.js +3 -45
  246. package/src/components/global-styles-renderer/index.js +39 -0
  247. package/src/components/global-styles-sidebar/default-sidebar.js +46 -0
  248. package/src/components/global-styles-sidebar/index.js +177 -0
  249. package/src/components/global-styles-sidebar/style.scss +119 -0
  250. package/src/components/global-styles-sidebar/welcome-guide-image.js +11 -0
  251. package/src/components/global-styles-sidebar/welcome-guide.js +136 -0
  252. package/src/components/header/index.js +11 -6
  253. package/src/components/post-featured-image/index.js +44 -1
  254. package/src/components/post-last-revision/style.scss +1 -1
  255. package/src/components/post-panel-row/style.scss +1 -0
  256. package/src/components/post-publish-panel/style.scss +1 -1
  257. package/src/components/post-publish-panel/test/__snapshots__/index.js.snap +2 -2
  258. package/src/components/provider/index.js +0 -2
  259. package/src/components/style-book/categories.ts +97 -0
  260. package/src/components/style-book/color-examples.tsx +56 -0
  261. package/src/components/style-book/constants.ts +308 -0
  262. package/src/components/style-book/duotone-examples.tsx +56 -0
  263. package/src/components/style-book/examples.tsx +273 -0
  264. package/src/components/style-book/index.js +794 -0
  265. package/src/components/style-book/style.scss +44 -0
  266. package/src/components/style-book/test/categories.js +166 -0
  267. package/src/components/style-book/types.ts +80 -0
  268. package/src/components/styles-canvas/index.js +126 -0
  269. package/src/components/styles-canvas/revisions.js +144 -0
  270. package/src/components/styles-canvas/style-book.js +57 -0
  271. package/src/components/styles-canvas/style.scss +40 -0
  272. package/src/components/visual-editor/index.js +2 -1
  273. package/src/dataviews/fields/content-preview/content-preview-view.tsx +2 -0
  274. package/src/hooks/index.js +1 -0
  275. package/src/hooks/media-upload.js +25 -5
  276. package/src/hooks/push-changes-to-global-styles/index.js +391 -0
  277. package/src/hooks/push-changes-to-global-styles/style.scss +4 -0
  278. package/src/hooks/use-global-styles-output.js +76 -0
  279. package/src/private-apis.js +10 -8
  280. package/src/store/private-actions.js +37 -0
  281. package/src/store/private-selectors.js +20 -0
  282. package/src/store/reducer.js +36 -0
  283. package/src/style.scss +7 -1
  284. package/src/utils/set-nested-value.js +39 -0
  285. package/tsconfig.json +3 -0
  286. package/tsconfig.tsbuildinfo +1 -1
  287. package/build/components/block-settings-menu/content-only-settings-menu.js +0 -186
  288. package/build/components/block-settings-menu/content-only-settings-menu.js.map +0 -7
  289. package/build/components/editor-interface/content-slot-fill.js.map +0 -7
  290. package/build-module/components/block-settings-menu/content-only-settings-menu.js +0 -161
  291. package/build-module/components/block-settings-menu/content-only-settings-menu.js.map +0 -7
  292. package/build-module/components/editor-interface/content-slot-fill.js +0 -9
  293. package/build-module/components/editor-interface/content-slot-fill.js.map +0 -7
  294. package/build-types/components/block-settings-menu/content-only-settings-menu.d.ts +0 -2
  295. package/build-types/components/block-settings-menu/content-only-settings-menu.d.ts.map +0 -1
  296. package/build-types/components/editor-interface/content-slot-fill.d.ts +0 -14
  297. package/build-types/components/editor-interface/content-slot-fill.d.ts.map +0 -1
  298. package/src/components/block-settings-menu/content-only-settings-menu.js +0 -185
  299. package/src/components/block-settings-menu/content-only-settings-menu.native.js +0 -4
  300. package/src/components/block-settings-menu/style.scss +0 -6
  301. package/src/components/editor-interface/content-slot-fill.js +0 -10
@@ -0,0 +1,618 @@
1
+ import { jsx, jsxs } from "react/jsx-runtime";
2
+ import clsx from "clsx";
3
+ import {
4
+ Disabled,
5
+ Composite,
6
+ privateApis as componentsPrivateApis
7
+ } from "@wordpress/components";
8
+ import { __, _x, sprintf } from "@wordpress/i18n";
9
+ import {
10
+ BlockList,
11
+ privateApis as blockEditorPrivateApis,
12
+ store as blockEditorStore,
13
+ useSettings,
14
+ BlockEditorProvider,
15
+ __unstableEditorStyles as EditorStyles,
16
+ __unstableIframe as Iframe,
17
+ __experimentalUseMultipleOriginColorsAndGradients as useMultipleOriginColorsAndGradients
18
+ } from "@wordpress/block-editor";
19
+ import { useSelect, dispatch } from "@wordpress/data";
20
+ import { mergeGlobalStyles } from "@wordpress/global-styles-engine";
21
+ import {
22
+ useMemo,
23
+ useState,
24
+ memo,
25
+ useRef,
26
+ useLayoutEffect,
27
+ useEffect,
28
+ forwardRef
29
+ } from "@wordpress/element";
30
+ import { ENTER, SPACE } from "@wordpress/keycodes";
31
+ import { uploadMedia } from "@wordpress/media-utils";
32
+ import { store as coreStore } from "@wordpress/core-data";
33
+ import { unlock } from "../../lock-unlock";
34
+ import { STYLE_BOOK_IFRAME_STYLES } from "./constants";
35
+ import {
36
+ getExamplesByCategory,
37
+ getTopLevelStyleBookCategories
38
+ } from "./categories";
39
+ import { getExamples } from "./examples";
40
+ import { GlobalStylesRenderer } from "../global-styles-renderer";
41
+ import {
42
+ STYLE_BOOK_COLOR_GROUPS,
43
+ STYLE_BOOK_PREVIEW_CATEGORIES
44
+ } from "../style-book/constants";
45
+ import { useGlobalStylesOutputWithConfig } from "../../hooks/use-global-styles-output";
46
+ import { useStyle, useGlobalStyles } from "../global-styles";
47
+ import { store as editorStore } from "../../store";
48
+ const { ExperimentalBlockEditorProvider } = unlock(blockEditorPrivateApis);
49
+ const { Tabs } = unlock(componentsPrivateApis);
50
+ function isObjectEmpty(object) {
51
+ return !object || Object.keys(object).length === 0;
52
+ }
53
+ const scrollToSection = (anchorId, iframe) => {
54
+ if (!anchorId || !iframe || !iframe?.contentDocument) {
55
+ return;
56
+ }
57
+ const element = anchorId === "top" ? iframe.contentDocument.body : iframe.contentDocument.getElementById(anchorId);
58
+ if (element) {
59
+ element.scrollIntoView({
60
+ behavior: "smooth"
61
+ });
62
+ }
63
+ };
64
+ const getStyleBookNavigationFromPath = (path) => {
65
+ if (path && typeof path === "string") {
66
+ if (path === "/" || path.startsWith("/typography") || path.startsWith("/colors") || path.startsWith("/blocks")) {
67
+ return {
68
+ top: true
69
+ };
70
+ }
71
+ }
72
+ return null;
73
+ };
74
+ function useMultiOriginPalettes() {
75
+ const { colors, gradients } = useMultipleOriginColorsAndGradients();
76
+ const [
77
+ shouldDisplayDefaultDuotones,
78
+ customDuotones,
79
+ themeDuotones,
80
+ defaultDuotones
81
+ ] = useSettings(
82
+ "color.defaultDuotone",
83
+ "color.duotone.custom",
84
+ "color.duotone.theme",
85
+ "color.duotone.default"
86
+ );
87
+ const palettes = useMemo(() => {
88
+ const result = { colors, gradients, duotones: [] };
89
+ if (themeDuotones && themeDuotones.length) {
90
+ result.duotones.push({
91
+ name: _x(
92
+ "Theme",
93
+ "Indicates these duotone filters come from the theme."
94
+ ),
95
+ slug: "theme",
96
+ duotones: themeDuotones
97
+ });
98
+ }
99
+ if (shouldDisplayDefaultDuotones && defaultDuotones && defaultDuotones.length) {
100
+ result.duotones.push({
101
+ name: _x(
102
+ "Default",
103
+ "Indicates these duotone filters come from WordPress."
104
+ ),
105
+ slug: "default",
106
+ duotones: defaultDuotones
107
+ });
108
+ }
109
+ if (customDuotones && customDuotones.length) {
110
+ result.duotones.push({
111
+ name: _x(
112
+ "Custom",
113
+ "Indicates these doutone filters are created by the user."
114
+ ),
115
+ slug: "custom",
116
+ duotones: customDuotones
117
+ });
118
+ }
119
+ return result;
120
+ }, [
121
+ colors,
122
+ gradients,
123
+ customDuotones,
124
+ themeDuotones,
125
+ defaultDuotones,
126
+ shouldDisplayDefaultDuotones
127
+ ]);
128
+ return palettes;
129
+ }
130
+ function getExamplesForSinglePageUse(examples) {
131
+ const examplesForSinglePageUse = [];
132
+ const overviewCategoryExamples = getExamplesByCategory(
133
+ { slug: "overview" },
134
+ examples
135
+ );
136
+ examplesForSinglePageUse.push(...overviewCategoryExamples.examples);
137
+ const otherExamples = examples.filter((example) => {
138
+ return example.category !== "overview" && !overviewCategoryExamples.examples.find(
139
+ (overviewExample) => overviewExample.name === example.name
140
+ );
141
+ });
142
+ examplesForSinglePageUse.push(...otherExamples);
143
+ return examplesForSinglePageUse;
144
+ }
145
+ function applyBlockVariationsToExamples(examples, variation) {
146
+ if (!variation) {
147
+ return examples;
148
+ }
149
+ return examples.map((example) => {
150
+ return {
151
+ ...example,
152
+ variation,
153
+ blocks: Array.isArray(example.blocks) ? example.blocks.map((block) => ({
154
+ ...block,
155
+ attributes: {
156
+ ...block.attributes,
157
+ style: void 0,
158
+ className: `is-style-${variation}`
159
+ }
160
+ })) : {
161
+ ...example.blocks,
162
+ attributes: {
163
+ ...example.blocks.attributes,
164
+ style: void 0,
165
+ className: `is-style-${variation}`
166
+ }
167
+ }
168
+ };
169
+ });
170
+ }
171
+ function StyleBook({
172
+ isSelected,
173
+ onClick,
174
+ onSelect,
175
+ showTabs = true,
176
+ userConfig = {},
177
+ path = ""
178
+ }, ref) {
179
+ const textColor = useStyle("color.text");
180
+ const backgroundColor = useStyle("color.background");
181
+ const colors = useMultiOriginPalettes();
182
+ const examples = useMemo(() => getExamples(colors), [colors]);
183
+ const tabs = useMemo(
184
+ () => getTopLevelStyleBookCategories().filter(
185
+ (category) => examples.some(
186
+ (example) => example.category === category.slug
187
+ )
188
+ ),
189
+ [examples]
190
+ );
191
+ const examplesForSinglePageUse = getExamplesForSinglePageUse(examples);
192
+ const { base: baseConfig } = useGlobalStyles();
193
+ const goTo = getStyleBookNavigationFromPath(path);
194
+ const mergedConfig = useMemo(() => {
195
+ if (!isObjectEmpty(userConfig) && !isObjectEmpty(baseConfig)) {
196
+ return mergeGlobalStyles(baseConfig, userConfig);
197
+ }
198
+ return {};
199
+ }, [baseConfig, userConfig]);
200
+ const originalSettings = useSelect(
201
+ (select) => select(blockEditorStore).getSettings(),
202
+ []
203
+ );
204
+ const [globalStyles] = useGlobalStylesOutputWithConfig(mergedConfig);
205
+ const settings = useMemo(
206
+ () => ({
207
+ ...originalSettings,
208
+ styles: !isObjectEmpty(globalStyles) && !isObjectEmpty(userConfig) ? globalStyles : originalSettings.styles,
209
+ isPreviewMode: true
210
+ }),
211
+ [globalStyles, originalSettings, userConfig]
212
+ );
213
+ return /* @__PURE__ */ jsx(
214
+ "div",
215
+ {
216
+ ref,
217
+ className: clsx("editor-style-book", {
218
+ "is-button": !!onClick
219
+ }),
220
+ style: {
221
+ color: textColor,
222
+ background: backgroundColor
223
+ },
224
+ children: showTabs ? /* @__PURE__ */ jsxs(Tabs, { children: [
225
+ /* @__PURE__ */ jsx("div", { className: "editor-style-book__tablist-container", children: /* @__PURE__ */ jsx(Tabs.TabList, { children: tabs.map((tab) => /* @__PURE__ */ jsx(Tabs.Tab, { tabId: tab.slug, children: tab.title }, tab.slug)) }) }),
226
+ tabs.map((tab) => {
227
+ const categoryDefinition = tab.slug ? getTopLevelStyleBookCategories().find(
228
+ (_category) => _category.slug === tab.slug
229
+ ) : null;
230
+ const filteredExamples = categoryDefinition ? getExamplesByCategory(
231
+ categoryDefinition,
232
+ examples
233
+ ) : { examples };
234
+ return /* @__PURE__ */ jsx(
235
+ Tabs.TabPanel,
236
+ {
237
+ tabId: tab.slug,
238
+ focusable: false,
239
+ className: "editor-style-book__tabpanel",
240
+ children: /* @__PURE__ */ jsx(
241
+ StyleBookBody,
242
+ {
243
+ category: tab.slug,
244
+ examples: filteredExamples,
245
+ isSelected,
246
+ onSelect,
247
+ settings,
248
+ title: tab.title,
249
+ goTo
250
+ }
251
+ )
252
+ },
253
+ tab.slug
254
+ );
255
+ })
256
+ ] }) : /* @__PURE__ */ jsx(
257
+ StyleBookBody,
258
+ {
259
+ examples: { examples: examplesForSinglePageUse },
260
+ isSelected,
261
+ onClick,
262
+ onSelect,
263
+ settings,
264
+ goTo
265
+ }
266
+ )
267
+ }
268
+ );
269
+ }
270
+ const StyleBookPreview = ({
271
+ userConfig = {},
272
+ isStatic = false,
273
+ path,
274
+ onPathChange
275
+ }) => {
276
+ const editorSettings = useSelect(
277
+ (select) => select(editorStore).getEditorSettings(),
278
+ []
279
+ );
280
+ const canUserUploadMedia = useSelect(
281
+ (select) => select(coreStore).canUser("create", {
282
+ kind: "postType",
283
+ name: "attachment"
284
+ }),
285
+ []
286
+ );
287
+ useEffect(() => {
288
+ dispatch(blockEditorStore).updateSettings({
289
+ ...editorSettings,
290
+ mediaUpload: canUserUploadMedia ? uploadMedia : void 0
291
+ });
292
+ }, [editorSettings, canUserUploadMedia]);
293
+ const [internalPath, setInternalPath] = useState("/");
294
+ const section = path ?? internalPath;
295
+ const onChangeSection = onPathChange ?? setInternalPath;
296
+ const isSelected = (blockName) => {
297
+ return section === `/blocks/${encodeURIComponent(blockName)}` || section.startsWith(
298
+ `/blocks/${encodeURIComponent(blockName)}/`
299
+ );
300
+ };
301
+ const onSelect = (blockName, isBlockVariation = false) => {
302
+ if (STYLE_BOOK_COLOR_GROUPS.find(
303
+ (group) => group.slug === blockName
304
+ )) {
305
+ onChangeSection("/colors/palette");
306
+ return;
307
+ }
308
+ if (blockName === "typography") {
309
+ onChangeSection("/typography");
310
+ return;
311
+ }
312
+ if (isBlockVariation) {
313
+ return;
314
+ }
315
+ onChangeSection(`/blocks/${encodeURIComponent(blockName)}`);
316
+ };
317
+ const colors = useMultiOriginPalettes();
318
+ const examples = getExamples(colors);
319
+ const examplesForSinglePageUse = getExamplesForSinglePageUse(examples);
320
+ let previewCategory = null;
321
+ let blockVariation = null;
322
+ if (section.includes("/colors")) {
323
+ previewCategory = "colors";
324
+ } else if (section.includes("/typography")) {
325
+ previewCategory = "text";
326
+ } else if (section.includes("/blocks")) {
327
+ previewCategory = "blocks";
328
+ let blockName = decodeURIComponent(section).split("/blocks/")[1];
329
+ if (blockName?.includes("/variations")) {
330
+ [blockName, blockVariation] = blockName.split("/variations/");
331
+ }
332
+ if (blockName && examples.find((example) => example.name === blockName)) {
333
+ previewCategory = blockName;
334
+ }
335
+ } else if (!isStatic) {
336
+ previewCategory = "overview";
337
+ }
338
+ const categoryDefinition = STYLE_BOOK_PREVIEW_CATEGORIES.find(
339
+ (category) => category.slug === previewCategory
340
+ );
341
+ const filteredExamples = useMemo(() => {
342
+ if (!categoryDefinition) {
343
+ return {
344
+ examples: [
345
+ examples.find(
346
+ (example) => example.name === previewCategory
347
+ )
348
+ ]
349
+ };
350
+ }
351
+ return getExamplesByCategory(categoryDefinition, examples);
352
+ }, [categoryDefinition, examples, previewCategory]);
353
+ const displayedExamples = useMemo(() => {
354
+ if (!previewCategory) {
355
+ return { examples: examplesForSinglePageUse };
356
+ }
357
+ if (blockVariation) {
358
+ return {
359
+ examples: applyBlockVariationsToExamples(
360
+ filteredExamples.examples,
361
+ blockVariation
362
+ )
363
+ };
364
+ }
365
+ return filteredExamples;
366
+ }, [
367
+ previewCategory,
368
+ examplesForSinglePageUse,
369
+ blockVariation,
370
+ filteredExamples
371
+ ]);
372
+ const { base: baseConfig } = useGlobalStyles();
373
+ const goTo = getStyleBookNavigationFromPath(section);
374
+ const mergedConfig = useMemo(() => {
375
+ if (!isObjectEmpty(userConfig) && !isObjectEmpty(baseConfig)) {
376
+ return mergeGlobalStyles(baseConfig, userConfig);
377
+ }
378
+ return {};
379
+ }, [baseConfig, userConfig]);
380
+ const [globalStyles] = useGlobalStylesOutputWithConfig(mergedConfig);
381
+ const settings = useMemo(
382
+ () => ({
383
+ ...editorSettings,
384
+ styles: !isObjectEmpty(globalStyles) && !isObjectEmpty(userConfig) ? globalStyles : editorSettings.styles,
385
+ isPreviewMode: true
386
+ }),
387
+ [globalStyles, editorSettings, userConfig]
388
+ );
389
+ return /* @__PURE__ */ jsx("div", { className: "editor-style-book", children: /* @__PURE__ */ jsxs(BlockEditorProvider, { settings, children: [
390
+ /* @__PURE__ */ jsx(GlobalStylesRenderer, { disableRootPadding: true }),
391
+ /* @__PURE__ */ jsx(
392
+ StyleBookBody,
393
+ {
394
+ examples: displayedExamples,
395
+ settings,
396
+ goTo,
397
+ isSelected: !isStatic ? isSelected : null,
398
+ onSelect: !isStatic ? onSelect : null
399
+ }
400
+ )
401
+ ] }) });
402
+ };
403
+ const StyleBookBody = ({
404
+ examples,
405
+ isSelected,
406
+ onClick,
407
+ onSelect,
408
+ settings,
409
+ title,
410
+ goTo
411
+ }) => {
412
+ const [isFocused, setIsFocused] = useState(false);
413
+ const [hasIframeLoaded, setHasIframeLoaded] = useState(false);
414
+ const iframeRef = useRef(null);
415
+ const buttonModeProps = {
416
+ role: "button",
417
+ onFocus: () => setIsFocused(true),
418
+ onBlur: () => setIsFocused(false),
419
+ onKeyDown: (event) => {
420
+ if (event.defaultPrevented) {
421
+ return;
422
+ }
423
+ const { keyCode } = event;
424
+ if (onClick && (keyCode === ENTER || keyCode === SPACE)) {
425
+ event.preventDefault();
426
+ onClick(event);
427
+ }
428
+ },
429
+ onClick: (event) => {
430
+ if (event.defaultPrevented) {
431
+ return;
432
+ }
433
+ if (onClick) {
434
+ event.preventDefault();
435
+ onClick(event);
436
+ }
437
+ },
438
+ readonly: true
439
+ };
440
+ const handleLoad = () => setHasIframeLoaded(true);
441
+ useLayoutEffect(() => {
442
+ if (hasIframeLoaded && iframeRef?.current) {
443
+ if (goTo?.top) {
444
+ scrollToSection("top", iframeRef?.current);
445
+ }
446
+ }
447
+ }, [iframeRef?.current, goTo, scrollToSection, hasIframeLoaded]);
448
+ return /* @__PURE__ */ jsxs(
449
+ Iframe,
450
+ {
451
+ onLoad: handleLoad,
452
+ ref: iframeRef,
453
+ className: clsx("editor-style-book__iframe", {
454
+ "is-focused": isFocused && !!onClick,
455
+ "is-button": !!onClick
456
+ }),
457
+ name: "style-book-canvas",
458
+ tabIndex: 0,
459
+ ...onClick ? buttonModeProps : {},
460
+ children: [
461
+ /* @__PURE__ */ jsx(EditorStyles, { styles: settings.styles }),
462
+ /* @__PURE__ */ jsxs("style", { children: [
463
+ STYLE_BOOK_IFRAME_STYLES,
464
+ !!onClick && "body { cursor: pointer; } body * { pointer-events: none; }"
465
+ ] }),
466
+ /* @__PURE__ */ jsx(
467
+ Examples,
468
+ {
469
+ className: "editor-style-book__examples",
470
+ filteredExamples: examples,
471
+ label: title ? sprintf(
472
+ // translators: %s: Category of blocks, e.g. Text.
473
+ __("Examples of blocks in the %s category"),
474
+ title
475
+ ) : __("Examples of blocks"),
476
+ isSelected,
477
+ onSelect
478
+ },
479
+ title
480
+ )
481
+ ]
482
+ }
483
+ );
484
+ };
485
+ const Examples = memo(
486
+ ({ className, filteredExamples, label, isSelected, onSelect }) => {
487
+ return /* @__PURE__ */ jsxs(
488
+ Composite,
489
+ {
490
+ orientation: "vertical",
491
+ className,
492
+ "aria-label": label,
493
+ role: "grid",
494
+ children: [
495
+ !!filteredExamples?.examples?.length && filteredExamples.examples.map((example) => /* @__PURE__ */ jsx(
496
+ Example,
497
+ {
498
+ id: `example-${example.name}`,
499
+ title: example.title,
500
+ content: example.content,
501
+ blocks: example.blocks,
502
+ isSelected: isSelected?.(example.name),
503
+ onClick: !!onSelect ? () => onSelect(
504
+ example.name,
505
+ !!example.variation
506
+ ) : null
507
+ },
508
+ example.name
509
+ )),
510
+ !!filteredExamples?.subcategories?.length && filteredExamples.subcategories.map((subcategory) => /* @__PURE__ */ jsxs(
511
+ Composite.Group,
512
+ {
513
+ className: "editor-style-book__subcategory",
514
+ children: [
515
+ /* @__PURE__ */ jsx(Composite.GroupLabel, { children: /* @__PURE__ */ jsx("h2", { className: "editor-style-book__subcategory-title", children: subcategory.title }) }),
516
+ /* @__PURE__ */ jsx(
517
+ Subcategory,
518
+ {
519
+ examples: subcategory.examples,
520
+ isSelected,
521
+ onSelect
522
+ }
523
+ )
524
+ ]
525
+ },
526
+ `subcategory-${subcategory.slug}`
527
+ ))
528
+ ]
529
+ }
530
+ );
531
+ }
532
+ );
533
+ const Subcategory = ({ examples, isSelected, onSelect }) => {
534
+ return !!examples?.length && examples.map((example) => /* @__PURE__ */ jsx(
535
+ Example,
536
+ {
537
+ id: `example-${example.name}`,
538
+ title: example.title,
539
+ content: example.content,
540
+ blocks: example.blocks,
541
+ isSelected: isSelected?.(example.name),
542
+ onClick: !!onSelect ? () => onSelect(example.name) : null
543
+ },
544
+ example.name
545
+ ));
546
+ };
547
+ const disabledExamples = ["example-duotones"];
548
+ const Example = ({ id, title, blocks, isSelected, onClick, content }) => {
549
+ const originalSettings = useSelect(
550
+ (select) => select(blockEditorStore).getSettings(),
551
+ []
552
+ );
553
+ const settings = useMemo(
554
+ () => ({
555
+ ...originalSettings,
556
+ focusMode: false,
557
+ // Disable "Spotlight mode".
558
+ isPreviewMode: true
559
+ }),
560
+ [originalSettings]
561
+ );
562
+ const renderedBlocks = useMemo(
563
+ () => Array.isArray(blocks) ? blocks : [blocks],
564
+ [blocks]
565
+ );
566
+ const disabledProps = disabledExamples.includes(id) || !onClick ? {
567
+ disabled: true,
568
+ accessibleWhenDisabled: !!onClick
569
+ } : {};
570
+ return /* @__PURE__ */ jsx("div", { role: "row", children: /* @__PURE__ */ jsx("div", { role: "gridcell", children: /* @__PURE__ */ jsxs(
571
+ Composite.Item,
572
+ {
573
+ className: clsx("editor-style-book__example", {
574
+ "is-selected": isSelected,
575
+ "is-disabled-example": !!disabledProps?.disabled
576
+ }),
577
+ id,
578
+ "aria-label": !!onClick ? sprintf(
579
+ // translators: %s: Title of a block, e.g. Heading.
580
+ __("Open %s styles in Styles panel"),
581
+ title
582
+ ) : void 0,
583
+ render: /* @__PURE__ */ jsx("div", {}),
584
+ role: !!onClick ? "button" : null,
585
+ onClick,
586
+ ...disabledProps,
587
+ children: [
588
+ /* @__PURE__ */ jsx("span", { className: "editor-style-book__example-title", children: title }),
589
+ /* @__PURE__ */ jsx(
590
+ "div",
591
+ {
592
+ className: "editor-style-book__example-preview",
593
+ "aria-hidden": true,
594
+ children: /* @__PURE__ */ jsx(Disabled, { className: "editor-style-book__example-preview__content", children: content ? content : /* @__PURE__ */ jsxs(
595
+ ExperimentalBlockEditorProvider,
596
+ {
597
+ value: renderedBlocks,
598
+ settings,
599
+ children: [
600
+ /* @__PURE__ */ jsx(EditorStyles, {}),
601
+ /* @__PURE__ */ jsx(BlockList, { renderAppender: false })
602
+ ]
603
+ }
604
+ ) })
605
+ }
606
+ )
607
+ ]
608
+ }
609
+ ) }) });
610
+ };
611
+ var style_book_default = forwardRef(StyleBook);
612
+ export {
613
+ StyleBookBody,
614
+ StyleBookPreview,
615
+ style_book_default as default,
616
+ getExamplesForSinglePageUse
617
+ };
618
+ //# sourceMappingURL=index.js.map