@wordpress/edit-site 5.29.0 → 5.31.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 (511) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/build/components/actions/index.js +3 -5
  3. package/build/components/actions/index.js.map +1 -1
  4. package/build/components/block-editor/editor-canvas.js +18 -6
  5. package/build/components/block-editor/editor-canvas.js.map +1 -1
  6. package/build/components/block-editor/use-site-editor-settings.js +1 -1
  7. package/build/components/block-editor/use-site-editor-settings.js.map +1 -1
  8. package/build/components/editor/index.js +1 -15
  9. package/build/components/editor/index.js.map +1 -1
  10. package/build/components/global-styles/color-palette-panel.js.map +1 -1
  11. package/build/components/global-styles/font-families.js +1 -1
  12. package/build/components/global-styles/font-families.js.map +1 -1
  13. package/build/components/global-styles/font-library-modal/collection-font-variant.js +2 -2
  14. package/build/components/global-styles/font-library-modal/collection-font-variant.js.map +1 -1
  15. package/build/components/global-styles/font-library-modal/context.js +70 -59
  16. package/build/components/global-styles/font-library-modal/context.js.map +1 -1
  17. package/build/components/global-styles/font-library-modal/font-card.js +10 -15
  18. package/build/components/global-styles/font-library-modal/font-card.js.map +1 -1
  19. package/build/components/global-styles/font-library-modal/font-collection.js +121 -78
  20. package/build/components/global-styles/font-library-modal/font-collection.js.map +1 -1
  21. package/build/components/global-styles/font-library-modal/font-demo.js +29 -8
  22. package/build/components/global-styles/font-library-modal/font-demo.js.map +1 -1
  23. package/build/components/global-styles/font-library-modal/google-fonts-confirm-dialog.js +3 -2
  24. package/build/components/global-styles/font-library-modal/google-fonts-confirm-dialog.js.map +1 -1
  25. package/build/components/global-styles/font-library-modal/index.js +19 -6
  26. package/build/components/global-styles/font-library-modal/index.js.map +1 -1
  27. package/build/components/global-styles/font-library-modal/installed-fonts.js +151 -79
  28. package/build/components/global-styles/font-library-modal/installed-fonts.js.map +1 -1
  29. package/build/components/global-styles/font-library-modal/library-font-variant.js +2 -2
  30. package/build/components/global-styles/font-library-modal/library-font-variant.js.map +1 -1
  31. package/build/components/global-styles/font-library-modal/upload-fonts.js +51 -23
  32. package/build/components/global-styles/font-library-modal/upload-fonts.js.map +1 -1
  33. package/build/components/global-styles/font-library-modal/utils/index.js +39 -5
  34. package/build/components/global-styles/font-library-modal/utils/index.js.map +1 -1
  35. package/build/components/global-styles/font-library-modal/utils/preview-styles.js +4 -1
  36. package/build/components/global-styles/font-library-modal/utils/preview-styles.js.map +1 -1
  37. package/build/components/global-styles/gradients-palette-panel.js.map +1 -1
  38. package/build/components/global-styles/header.js +2 -2
  39. package/build/components/global-styles/header.js.map +1 -1
  40. package/build/components/global-styles/highlighted-colors.js +50 -0
  41. package/build/components/global-styles/highlighted-colors.js.map +1 -0
  42. package/build/components/global-styles/hooks.js +50 -1
  43. package/build/components/global-styles/hooks.js.map +1 -1
  44. package/build/components/global-styles/preview-colors.js +62 -0
  45. package/build/components/global-styles/preview-colors.js.map +1 -0
  46. package/build/components/global-styles/preview-iframe.js +130 -0
  47. package/build/components/global-styles/preview-iframe.js.map +1 -0
  48. package/build/components/global-styles/preview-styles.js +163 -0
  49. package/build/components/global-styles/preview-styles.js.map +1 -0
  50. package/build/components/global-styles/screen-block-list.js +1 -1
  51. package/build/components/global-styles/screen-block-list.js.map +1 -1
  52. package/build/components/global-styles/screen-block.js +1 -1
  53. package/build/components/global-styles/screen-block.js.map +1 -1
  54. package/build/components/global-styles/screen-colors.js +3 -2
  55. package/build/components/global-styles/screen-colors.js.map +1 -1
  56. package/build/components/global-styles/screen-revisions/index.js +2 -2
  57. package/build/components/global-styles/screen-revisions/index.js.map +1 -1
  58. package/build/components/global-styles/screen-root.js +2 -2
  59. package/build/components/global-styles/screen-root.js.map +1 -1
  60. package/build/components/global-styles/screen-typography.js +5 -2
  61. package/build/components/global-styles/screen-typography.js.map +1 -1
  62. package/build/components/global-styles/style-variations-container.js +12 -84
  63. package/build/components/global-styles/style-variations-container.js.map +1 -1
  64. package/build/components/global-styles/{typogrphy-elements.js → typography-elements.js} +4 -2
  65. package/build/components/global-styles/typography-elements.js.map +1 -0
  66. package/build/components/global-styles/typography-example.js +67 -0
  67. package/build/components/global-styles/typography-example.js.map +1 -0
  68. package/build/components/global-styles/typography-preview.js +3 -1
  69. package/build/components/global-styles/typography-preview.js.map +1 -1
  70. package/build/components/global-styles/ui.js +27 -2
  71. package/build/components/global-styles/ui.js.map +1 -1
  72. package/build/components/global-styles/utils.js +22 -0
  73. package/build/components/global-styles/utils.js.map +1 -1
  74. package/build/components/global-styles/variations/variation.js +90 -0
  75. package/build/components/global-styles/variations/variation.js.map +1 -0
  76. package/build/components/global-styles/variations/variations-color.js +35 -0
  77. package/build/components/global-styles/variations/variations-color.js.map +1 -0
  78. package/build/components/global-styles/{variations-panel.js → variations/variations-panel.js} +1 -1
  79. package/build/components/global-styles/variations/variations-panel.js.map +1 -0
  80. package/build/components/global-styles/variations/variations-typography.js +54 -0
  81. package/build/components/global-styles/variations/variations-typography.js.map +1 -0
  82. package/build/components/header-edit-mode/index.js +14 -12
  83. package/build/components/header-edit-mode/index.js.map +1 -1
  84. package/build/components/header-edit-mode/more-menu/index.js +10 -2
  85. package/build/components/header-edit-mode/more-menu/index.js.map +1 -1
  86. package/build/components/keyboard-shortcut-help-modal/config.js +6 -0
  87. package/build/components/keyboard-shortcut-help-modal/config.js.map +1 -1
  88. package/build/components/keyboard-shortcuts/global.js +17 -3
  89. package/build/components/keyboard-shortcuts/global.js.map +1 -1
  90. package/build/components/layout/index.js +4 -1
  91. package/build/components/layout/index.js.map +1 -1
  92. package/build/components/layout/router.js +2 -5
  93. package/build/components/layout/router.js.map +1 -1
  94. package/build/components/page-pages/index.js +6 -11
  95. package/build/components/page-pages/index.js.map +1 -1
  96. package/build/components/page-patterns/delete-category-menu-item.js +6 -1
  97. package/build/components/page-patterns/delete-category-menu-item.js.map +1 -1
  98. package/build/components/page-patterns/index.js +15 -18
  99. package/build/components/page-patterns/index.js.map +1 -1
  100. package/build/components/page-patterns/use-patterns.js +9 -9
  101. package/build/components/page-patterns/use-patterns.js.map +1 -1
  102. package/build/components/{list/added-by.js → page-templates-template-parts/hooks.js} +1 -61
  103. package/build/components/page-templates-template-parts/hooks.js.map +1 -0
  104. package/build/components/page-templates-template-parts/index.js +25 -22
  105. package/build/components/page-templates-template-parts/index.js.map +1 -1
  106. package/build/components/resizable-frame/index.js +2 -1
  107. package/build/components/resizable-frame/index.js.map +1 -1
  108. package/build/components/revisions/index.js.map +1 -1
  109. package/build/components/save-panel/index.js +31 -11
  110. package/build/components/save-panel/index.js.map +1 -1
  111. package/build/components/sidebar/index.js +3 -4
  112. package/build/components/sidebar/index.js.map +1 -1
  113. package/build/components/sidebar-dataviews/custom-dataviews-list.js +2 -2
  114. package/build/components/sidebar-dataviews/custom-dataviews-list.js.map +1 -1
  115. package/build/components/sidebar-dataviews/dataview-item.js +2 -2
  116. package/build/components/sidebar-dataviews/dataview-item.js.map +1 -1
  117. package/build/components/sidebar-dataviews/default-views.js +4 -2
  118. package/build/components/sidebar-dataviews/default-views.js.map +1 -1
  119. package/build/components/sidebar-dataviews/index.js +4 -3
  120. package/build/components/sidebar-dataviews/index.js.map +1 -1
  121. package/build/components/sidebar-edit-mode/page-panels/index.js +2 -2
  122. package/build/components/sidebar-edit-mode/page-panels/index.js.map +1 -1
  123. package/build/components/sidebar-edit-mode/page-panels/page-status.js.map +1 -1
  124. package/build/components/sidebar-edit-mode/page-panels/page-summary.js +3 -1
  125. package/build/components/sidebar-edit-mode/page-panels/page-summary.js.map +1 -1
  126. package/build/components/sidebar-edit-mode/sidebar-card/index.js +12 -6
  127. package/build/components/sidebar-edit-mode/sidebar-card/index.js.map +1 -1
  128. package/build/components/sidebar-edit-mode/template-panel/index.js +23 -3
  129. package/build/components/sidebar-edit-mode/template-panel/index.js.map +1 -1
  130. package/build/components/sidebar-navigation-screen-global-styles/index.js +13 -1
  131. package/build/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  132. package/build/components/sidebar-navigation-screen-main/index.js +1 -2
  133. package/build/components/sidebar-navigation-screen-main/index.js.map +1 -1
  134. package/build/components/sidebar-navigation-screen-navigation-menu/{delete-modal.js → delete-confirm-dialog.js} +4 -5
  135. package/build/components/sidebar-navigation-screen-navigation-menu/delete-confirm-dialog.js.map +1 -0
  136. package/build/components/sidebar-navigation-screen-navigation-menu/more-menu.js +6 -6
  137. package/build/components/sidebar-navigation-screen-navigation-menu/more-menu.js.map +1 -1
  138. package/build/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js +0 -3
  139. package/build/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js.map +1 -1
  140. package/build/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js +1 -1
  141. package/build/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js.map +1 -1
  142. package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js.map +1 -1
  143. package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menus.js.map +1 -1
  144. package/build/components/sidebar-navigation-screen-pattern/use-pattern-details.js +2 -2
  145. package/build/components/sidebar-navigation-screen-pattern/use-pattern-details.js.map +1 -1
  146. package/build/components/sidebar-navigation-screen-template/index.js +7 -3
  147. package/build/components/sidebar-navigation-screen-template/index.js.map +1 -1
  148. package/build/components/sidebar-navigation-screen-templates-browse/content.js +6 -6
  149. package/build/components/sidebar-navigation-screen-templates-browse/content.js.map +1 -1
  150. package/build/components/sidebar-navigation-screen-templates-browse/index.js +7 -5
  151. package/build/components/sidebar-navigation-screen-templates-browse/index.js.map +1 -1
  152. package/build/components/start-template-options/index.js.map +1 -1
  153. package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js +1 -1
  154. package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
  155. package/build/components/sync-state-with-url/use-sync-path-with-url.js +1 -11
  156. package/build/components/sync-state-with-url/use-sync-path-with-url.js.map +1 -1
  157. package/build/components/template-actions/index.js +44 -27
  158. package/build/components/template-actions/index.js.map +1 -1
  159. package/build/components/welcome-guide/editor.js +11 -2
  160. package/build/components/welcome-guide/editor.js.map +1 -1
  161. package/build/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js +78 -0
  162. package/build/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js.map +1 -1
  163. package/build/utils/constants.js +5 -3
  164. package/build/utils/constants.js.map +1 -1
  165. package/build/utils/get-is-list-page.js +1 -1
  166. package/build/utils/get-is-list-page.js.map +1 -1
  167. package/build/utils/math.js +98 -0
  168. package/build/utils/math.js.map +1 -0
  169. package/build-module/components/actions/index.js +4 -6
  170. package/build-module/components/actions/index.js.map +1 -1
  171. package/build-module/components/block-editor/editor-canvas.js +18 -6
  172. package/build-module/components/block-editor/editor-canvas.js.map +1 -1
  173. package/build-module/components/block-editor/use-site-editor-settings.js +1 -1
  174. package/build-module/components/block-editor/use-site-editor-settings.js.map +1 -1
  175. package/build-module/components/editor/index.js +2 -16
  176. package/build-module/components/editor/index.js.map +1 -1
  177. package/build-module/components/global-styles/color-palette-panel.js.map +1 -1
  178. package/build-module/components/global-styles/font-families.js +1 -1
  179. package/build-module/components/global-styles/font-families.js.map +1 -1
  180. package/build-module/components/global-styles/font-library-modal/collection-font-variant.js +4 -4
  181. package/build-module/components/global-styles/font-library-modal/collection-font-variant.js.map +1 -1
  182. package/build-module/components/global-styles/font-library-modal/context.js +72 -61
  183. package/build-module/components/global-styles/font-library-modal/context.js.map +1 -1
  184. package/build-module/components/global-styles/font-library-modal/font-card.js +11 -16
  185. package/build-module/components/global-styles/font-library-modal/font-card.js.map +1 -1
  186. package/build-module/components/global-styles/font-library-modal/font-collection.js +124 -81
  187. package/build-module/components/global-styles/font-library-modal/font-collection.js.map +1 -1
  188. package/build-module/components/global-styles/font-library-modal/font-demo.js +30 -9
  189. package/build-module/components/global-styles/font-library-modal/font-demo.js.map +1 -1
  190. package/build-module/components/global-styles/font-library-modal/google-fonts-confirm-dialog.js +4 -3
  191. package/build-module/components/global-styles/font-library-modal/google-fonts-confirm-dialog.js.map +1 -1
  192. package/build-module/components/global-styles/font-library-modal/index.js +19 -6
  193. package/build-module/components/global-styles/font-library-modal/index.js.map +1 -1
  194. package/build-module/components/global-styles/font-library-modal/installed-fonts.js +151 -79
  195. package/build-module/components/global-styles/font-library-modal/installed-fonts.js.map +1 -1
  196. package/build-module/components/global-styles/font-library-modal/library-font-variant.js +4 -4
  197. package/build-module/components/global-styles/font-library-modal/library-font-variant.js.map +1 -1
  198. package/build-module/components/global-styles/font-library-modal/upload-fonts.js +52 -24
  199. package/build-module/components/global-styles/font-library-modal/upload-fonts.js.map +1 -1
  200. package/build-module/components/global-styles/font-library-modal/utils/index.js +38 -5
  201. package/build-module/components/global-styles/font-library-modal/utils/index.js.map +1 -1
  202. package/build-module/components/global-styles/font-library-modal/utils/preview-styles.js +4 -1
  203. package/build-module/components/global-styles/font-library-modal/utils/preview-styles.js.map +1 -1
  204. package/build-module/components/global-styles/gradients-palette-panel.js.map +1 -1
  205. package/build-module/components/global-styles/header.js +2 -2
  206. package/build-module/components/global-styles/header.js.map +1 -1
  207. package/build-module/components/global-styles/highlighted-colors.js +43 -0
  208. package/build-module/components/global-styles/highlighted-colors.js.map +1 -0
  209. package/build-module/components/global-styles/hooks.js +48 -1
  210. package/build-module/components/global-styles/hooks.js.map +1 -1
  211. package/build-module/components/global-styles/preview-colors.js +54 -0
  212. package/build-module/components/global-styles/preview-colors.js.map +1 -0
  213. package/build-module/components/global-styles/preview-iframe.js +123 -0
  214. package/build-module/components/global-styles/preview-iframe.js.map +1 -0
  215. package/build-module/components/global-styles/preview-styles.js +155 -0
  216. package/build-module/components/global-styles/preview-styles.js.map +1 -0
  217. package/build-module/components/global-styles/screen-block-list.js +1 -1
  218. package/build-module/components/global-styles/screen-block-list.js.map +1 -1
  219. package/build-module/components/global-styles/screen-block.js +1 -1
  220. package/build-module/components/global-styles/screen-block.js.map +1 -1
  221. package/build-module/components/global-styles/screen-colors.js +3 -2
  222. package/build-module/components/global-styles/screen-colors.js.map +1 -1
  223. package/build-module/components/global-styles/screen-revisions/index.js +2 -2
  224. package/build-module/components/global-styles/screen-revisions/index.js.map +1 -1
  225. package/build-module/components/global-styles/screen-root.js +2 -2
  226. package/build-module/components/global-styles/screen-root.js.map +1 -1
  227. package/build-module/components/global-styles/screen-typography.js +5 -2
  228. package/build-module/components/global-styles/screen-typography.js.map +1 -1
  229. package/build-module/components/global-styles/style-variations-container.js +13 -85
  230. package/build-module/components/global-styles/style-variations-container.js.map +1 -1
  231. package/build-module/components/global-styles/{typogrphy-elements.js → typography-elements.js} +4 -2
  232. package/build-module/components/global-styles/typography-elements.js.map +1 -0
  233. package/build-module/components/global-styles/typography-example.js +60 -0
  234. package/build-module/components/global-styles/typography-example.js.map +1 -0
  235. package/build-module/components/global-styles/typography-preview.js +3 -1
  236. package/build-module/components/global-styles/typography-preview.js.map +1 -1
  237. package/build-module/components/global-styles/ui.js +27 -2
  238. package/build-module/components/global-styles/ui.js.map +1 -1
  239. package/build-module/components/global-styles/utils.js +21 -0
  240. package/build-module/components/global-styles/utils.js.map +1 -1
  241. package/build-module/components/global-styles/variations/variation.js +82 -0
  242. package/build-module/components/global-styles/variations/variation.js.map +1 -0
  243. package/build-module/components/global-styles/variations/variations-color.js +27 -0
  244. package/build-module/components/global-styles/variations/variations-color.js.map +1 -0
  245. package/build-module/components/global-styles/{variations-panel.js → variations/variations-panel.js} +1 -1
  246. package/build-module/components/global-styles/variations/variations-panel.js.map +1 -0
  247. package/build-module/components/global-styles/variations/variations-typography.js +46 -0
  248. package/build-module/components/global-styles/variations/variations-typography.js.map +1 -0
  249. package/build-module/components/header-edit-mode/index.js +15 -13
  250. package/build-module/components/header-edit-mode/index.js.map +1 -1
  251. package/build-module/components/header-edit-mode/more-menu/index.js +13 -5
  252. package/build-module/components/header-edit-mode/more-menu/index.js.map +1 -1
  253. package/build-module/components/keyboard-shortcut-help-modal/config.js +6 -0
  254. package/build-module/components/keyboard-shortcut-help-modal/config.js.map +1 -1
  255. package/build-module/components/keyboard-shortcuts/global.js +17 -3
  256. package/build-module/components/keyboard-shortcuts/global.js.map +1 -1
  257. package/build-module/components/layout/index.js +4 -1
  258. package/build-module/components/layout/index.js.map +1 -1
  259. package/build-module/components/layout/router.js +2 -5
  260. package/build-module/components/layout/router.js.map +1 -1
  261. package/build-module/components/page-pages/index.js +7 -12
  262. package/build-module/components/page-pages/index.js.map +1 -1
  263. package/build-module/components/page-patterns/delete-category-menu-item.js +6 -1
  264. package/build-module/components/page-patterns/delete-category-menu-item.js.map +1 -1
  265. package/build-module/components/page-patterns/index.js +16 -19
  266. package/build-module/components/page-patterns/index.js.map +1 -1
  267. package/build-module/components/page-patterns/use-patterns.js +9 -9
  268. package/build-module/components/page-patterns/use-patterns.js.map +1 -1
  269. package/build-module/components/{list/added-by.js → page-templates-template-parts/hooks.js} +2 -59
  270. package/build-module/components/page-templates-template-parts/hooks.js.map +1 -0
  271. package/build-module/components/page-templates-template-parts/index.js +25 -22
  272. package/build-module/components/page-templates-template-parts/index.js.map +1 -1
  273. package/build-module/components/resizable-frame/index.js +2 -1
  274. package/build-module/components/resizable-frame/index.js.map +1 -1
  275. package/build-module/components/revisions/index.js.map +1 -1
  276. package/build-module/components/save-panel/index.js +31 -11
  277. package/build-module/components/save-panel/index.js.map +1 -1
  278. package/build-module/components/sidebar/index.js +3 -4
  279. package/build-module/components/sidebar/index.js.map +1 -1
  280. package/build-module/components/sidebar-dataviews/custom-dataviews-list.js +2 -2
  281. package/build-module/components/sidebar-dataviews/custom-dataviews-list.js.map +1 -1
  282. package/build-module/components/sidebar-dataviews/dataview-item.js +2 -2
  283. package/build-module/components/sidebar-dataviews/dataview-item.js.map +1 -1
  284. package/build-module/components/sidebar-dataviews/default-views.js +6 -4
  285. package/build-module/components/sidebar-dataviews/default-views.js.map +1 -1
  286. package/build-module/components/sidebar-dataviews/index.js +4 -3
  287. package/build-module/components/sidebar-dataviews/index.js.map +1 -1
  288. package/build-module/components/sidebar-edit-mode/page-panels/index.js +3 -3
  289. package/build-module/components/sidebar-edit-mode/page-panels/index.js.map +1 -1
  290. package/build-module/components/sidebar-edit-mode/page-panels/page-status.js.map +1 -1
  291. package/build-module/components/sidebar-edit-mode/page-panels/page-summary.js +4 -2
  292. package/build-module/components/sidebar-edit-mode/page-panels/page-summary.js.map +1 -1
  293. package/build-module/components/sidebar-edit-mode/sidebar-card/index.js +13 -7
  294. package/build-module/components/sidebar-edit-mode/sidebar-card/index.js.map +1 -1
  295. package/build-module/components/sidebar-edit-mode/template-panel/index.js +24 -4
  296. package/build-module/components/sidebar-edit-mode/template-panel/index.js.map +1 -1
  297. package/build-module/components/sidebar-navigation-screen-global-styles/index.js +14 -2
  298. package/build-module/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  299. package/build-module/components/sidebar-navigation-screen-main/index.js +1 -2
  300. package/build-module/components/sidebar-navigation-screen-main/index.js.map +1 -1
  301. package/build-module/components/sidebar-navigation-screen-navigation-menu/{delete-modal.js → delete-confirm-dialog.js} +3 -4
  302. package/build-module/components/sidebar-navigation-screen-navigation-menu/delete-confirm-dialog.js.map +1 -0
  303. package/build-module/components/sidebar-navigation-screen-navigation-menu/more-menu.js +6 -6
  304. package/build-module/components/sidebar-navigation-screen-navigation-menu/more-menu.js.map +1 -1
  305. package/build-module/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js +0 -3
  306. package/build-module/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js.map +1 -1
  307. package/build-module/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js +1 -1
  308. package/build-module/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js.map +1 -1
  309. package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js.map +1 -1
  310. package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menus.js.map +1 -1
  311. package/build-module/components/sidebar-navigation-screen-pattern/use-pattern-details.js +1 -1
  312. package/build-module/components/sidebar-navigation-screen-pattern/use-pattern-details.js.map +1 -1
  313. package/build-module/components/sidebar-navigation-screen-template/index.js +6 -2
  314. package/build-module/components/sidebar-navigation-screen-template/index.js.map +1 -1
  315. package/build-module/components/sidebar-navigation-screen-templates-browse/content.js +5 -5
  316. package/build-module/components/sidebar-navigation-screen-templates-browse/content.js.map +1 -1
  317. package/build-module/components/sidebar-navigation-screen-templates-browse/index.js +7 -5
  318. package/build-module/components/sidebar-navigation-screen-templates-browse/index.js.map +1 -1
  319. package/build-module/components/start-template-options/index.js.map +1 -1
  320. package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js +1 -1
  321. package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
  322. package/build-module/components/sync-state-with-url/use-sync-path-with-url.js +1 -11
  323. package/build-module/components/sync-state-with-url/use-sync-path-with-url.js.map +1 -1
  324. package/build-module/components/template-actions/index.js +44 -27
  325. package/build-module/components/template-actions/index.js.map +1 -1
  326. package/build-module/components/welcome-guide/editor.js +11 -2
  327. package/build-module/components/welcome-guide/editor.js.map +1 -1
  328. package/build-module/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js +76 -1
  329. package/build-module/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js.map +1 -1
  330. package/build-module/utils/constants.js +4 -2
  331. package/build-module/utils/constants.js.map +1 -1
  332. package/build-module/utils/get-is-list-page.js +1 -1
  333. package/build-module/utils/get-is-list-page.js.map +1 -1
  334. package/build-module/utils/math.js +92 -0
  335. package/build-module/utils/math.js.map +1 -0
  336. package/build-style/style-rtl.css +196 -315
  337. package/build-style/style.css +196 -315
  338. package/package.json +42 -42
  339. package/src/components/actions/index.js +4 -6
  340. package/src/components/block-editor/editor-canvas.js +20 -6
  341. package/src/components/block-editor/style.scss +0 -3
  342. package/src/components/block-editor/use-site-editor-settings.js +0 -2
  343. package/src/components/editor/index.js +0 -20
  344. package/src/components/global-styles/color-palette-panel.js +0 -1
  345. package/src/components/global-styles/font-families.js +1 -1
  346. package/src/components/global-styles/font-library-modal/collection-font-variant.js +5 -5
  347. package/src/components/global-styles/font-library-modal/context.js +136 -107
  348. package/src/components/global-styles/font-library-modal/font-card.js +11 -26
  349. package/src/components/global-styles/font-library-modal/font-collection.js +298 -218
  350. package/src/components/global-styles/font-library-modal/font-demo.js +38 -4
  351. package/src/components/global-styles/font-library-modal/google-fonts-confirm-dialog.js +9 -2
  352. package/src/components/global-styles/font-library-modal/index.js +23 -16
  353. package/src/components/global-styles/font-library-modal/installed-fonts.js +243 -114
  354. package/src/components/global-styles/font-library-modal/library-font-variant.js +5 -5
  355. package/src/components/global-styles/font-library-modal/style.scss +27 -11
  356. package/src/components/global-styles/font-library-modal/upload-fonts.js +70 -27
  357. package/src/components/global-styles/font-library-modal/utils/index.js +45 -5
  358. package/src/components/global-styles/font-library-modal/utils/preview-styles.js +6 -1
  359. package/src/components/global-styles/font-library-modal/utils/test/getDisplaySrcFromFontFace.spec.js +7 -18
  360. package/src/components/global-styles/gradients-palette-panel.js +2 -2
  361. package/src/components/global-styles/header.js +2 -2
  362. package/src/components/global-styles/highlighted-colors.js +39 -0
  363. package/src/components/global-styles/hooks.js +68 -1
  364. package/src/components/global-styles/preview-colors.js +61 -0
  365. package/src/components/global-styles/preview-iframe.js +152 -0
  366. package/src/components/global-styles/preview-styles.js +185 -0
  367. package/src/components/global-styles/screen-block-list.js +1 -1
  368. package/src/components/global-styles/screen-block.js +4 -1
  369. package/src/components/global-styles/screen-colors.js +3 -2
  370. package/src/components/global-styles/screen-revisions/index.js +5 -2
  371. package/src/components/global-styles/screen-root.js +2 -2
  372. package/src/components/global-styles/screen-typography.js +8 -2
  373. package/src/components/global-styles/style-variations-container.js +14 -92
  374. package/src/components/global-styles/style.scss +4 -35
  375. package/src/components/global-styles/{typogrphy-elements.js → typography-elements.js} +5 -1
  376. package/src/components/global-styles/typography-example.js +64 -0
  377. package/src/components/global-styles/typography-preview.js +3 -1
  378. package/src/components/global-styles/ui.js +26 -2
  379. package/src/components/global-styles/utils.js +37 -0
  380. package/src/components/global-styles/variations/style.scss +38 -0
  381. package/src/components/global-styles/variations/variation.js +93 -0
  382. package/src/components/global-styles/variations/variations-color.js +34 -0
  383. package/src/components/global-styles/{variations-panel.js → variations/variations-panel.js} +1 -1
  384. package/src/components/global-styles/variations/variations-typography.js +63 -0
  385. package/src/components/header-edit-mode/index.js +21 -27
  386. package/src/components/header-edit-mode/more-menu/index.js +17 -8
  387. package/src/components/header-edit-mode/style.scss +4 -0
  388. package/src/components/keyboard-shortcut-help-modal/config.js +4 -0
  389. package/src/components/keyboard-shortcuts/global.js +16 -4
  390. package/src/components/layout/index.js +5 -0
  391. package/src/components/layout/router.js +2 -7
  392. package/src/components/page-pages/index.js +8 -13
  393. package/src/components/page-patterns/delete-category-menu-item.js +7 -0
  394. package/src/components/page-patterns/index.js +23 -24
  395. package/src/components/page-patterns/use-patterns.js +17 -10
  396. package/src/components/{list/added-by.js → page-templates-template-parts/hooks.js} +1 -66
  397. package/src/components/page-templates-template-parts/index.js +34 -25
  398. package/src/components/page-templates-template-parts/style.scss +48 -0
  399. package/src/components/resizable-frame/index.js +1 -0
  400. package/src/components/revisions/index.js +1 -1
  401. package/src/components/save-panel/index.js +56 -27
  402. package/src/components/sidebar/index.js +3 -4
  403. package/src/components/sidebar-dataviews/custom-dataviews-list.js +2 -2
  404. package/src/components/sidebar-dataviews/dataview-item.js +2 -2
  405. package/src/components/sidebar-dataviews/default-views.js +14 -4
  406. package/src/components/sidebar-dataviews/index.js +4 -3
  407. package/src/components/sidebar-edit-mode/page-panels/index.js +2 -2
  408. package/src/components/sidebar-edit-mode/page-panels/page-status.js +1 -1
  409. package/src/components/sidebar-edit-mode/page-panels/page-summary.js +2 -0
  410. package/src/components/sidebar-edit-mode/sidebar-card/index.js +30 -11
  411. package/src/components/sidebar-edit-mode/sidebar-card/style.scss +10 -11
  412. package/src/components/sidebar-edit-mode/template-panel/index.js +25 -6
  413. package/src/components/sidebar-navigation-screen/style.scss +10 -1
  414. package/src/components/sidebar-navigation-screen-global-styles/index.js +35 -2
  415. package/src/components/sidebar-navigation-screen-main/index.js +0 -2
  416. package/src/components/sidebar-navigation-screen-navigation-menu/{delete-modal.js → delete-confirm-dialog.js} +3 -4
  417. package/src/components/sidebar-navigation-screen-navigation-menu/more-menu.js +11 -9
  418. package/src/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js +0 -2
  419. package/src/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js +6 -3
  420. package/src/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js +1 -1
  421. package/src/components/sidebar-navigation-screen-pattern/template-part-navigation-menus.js +1 -1
  422. package/src/components/sidebar-navigation-screen-pattern/use-pattern-details.js +1 -1
  423. package/src/components/sidebar-navigation-screen-template/index.js +7 -2
  424. package/src/components/sidebar-navigation-screen-templates-browse/content.js +5 -5
  425. package/src/components/sidebar-navigation-screen-templates-browse/index.js +5 -3
  426. package/src/components/start-template-options/index.js +1 -1
  427. package/src/components/sync-state-with-url/use-init-edited-entity-from-url.js +1 -1
  428. package/src/components/sync-state-with-url/use-sync-path-with-url.js +3 -19
  429. package/src/components/template-actions/index.js +63 -46
  430. package/src/components/welcome-guide/editor.js +9 -6
  431. package/src/hooks/use-theme-style-variations/test/use-theme-style-variations-by-property.js +173 -0
  432. package/src/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js +85 -1
  433. package/src/style.scss +2 -3
  434. package/src/utils/constants.js +4 -2
  435. package/src/utils/get-is-list-page.js +1 -1
  436. package/src/utils/math.js +93 -0
  437. package/build/components/global-styles/font-library-modal/collection-font-details.js +0 -50
  438. package/build/components/global-styles/font-library-modal/collection-font-details.js.map +0 -1
  439. package/build/components/global-styles/font-library-modal/confirm-delete-dialog.js +0 -30
  440. package/build/components/global-styles/font-library-modal/confirm-delete-dialog.js.map +0 -1
  441. package/build/components/global-styles/font-library-modal/library-font-card.js +0 -39
  442. package/build/components/global-styles/font-library-modal/library-font-card.js.map +0 -1
  443. package/build/components/global-styles/font-library-modal/tab-panel-layout.js +0 -67
  444. package/build/components/global-styles/font-library-modal/tab-panel-layout.js.map +0 -1
  445. package/build/components/global-styles/preview.js +0 -271
  446. package/build/components/global-styles/preview.js.map +0 -1
  447. package/build/components/global-styles/typogrphy-elements.js.map +0 -1
  448. package/build/components/global-styles/variations-panel.js.map +0 -1
  449. package/build/components/list/added-by.js.map +0 -1
  450. package/build/components/list/header.js +0 -55
  451. package/build/components/list/header.js.map +0 -1
  452. package/build/components/list/index.js +0 -80
  453. package/build/components/list/index.js.map +0 -1
  454. package/build/components/list/table.js +0 -94
  455. package/build/components/list/table.js.map +0 -1
  456. package/build/components/list/use-register-shortcuts.js +0 -51
  457. package/build/components/list/use-register-shortcuts.js.map +0 -1
  458. package/build/components/sidebar-edit-mode/template-panel/template-actions.js +0 -50
  459. package/build/components/sidebar-edit-mode/template-panel/template-actions.js.map +0 -1
  460. package/build/components/sidebar-navigation-screen-main/template-part-hint.js +0 -36
  461. package/build/components/sidebar-navigation-screen-main/template-part-hint.js.map +0 -1
  462. package/build/components/sidebar-navigation-screen-navigation-menu/delete-modal.js.map +0 -1
  463. package/build/components/sidebar-navigation-screen-navigation-menu/edit-button.js +0 -36
  464. package/build/components/sidebar-navigation-screen-navigation-menu/edit-button.js.map +0 -1
  465. package/build/components/sidebar-navigation-screen-templates/index.js +0 -132
  466. package/build/components/sidebar-navigation-screen-templates/index.js.map +0 -1
  467. package/build-module/components/global-styles/font-library-modal/collection-font-details.js +0 -42
  468. package/build-module/components/global-styles/font-library-modal/collection-font-details.js.map +0 -1
  469. package/build-module/components/global-styles/font-library-modal/confirm-delete-dialog.js +0 -23
  470. package/build-module/components/global-styles/font-library-modal/confirm-delete-dialog.js.map +0 -1
  471. package/build-module/components/global-styles/font-library-modal/library-font-card.js +0 -31
  472. package/build-module/components/global-styles/font-library-modal/library-font-card.js.map +0 -1
  473. package/build-module/components/global-styles/font-library-modal/tab-panel-layout.js +0 -60
  474. package/build-module/components/global-styles/font-library-modal/tab-panel-layout.js.map +0 -1
  475. package/build-module/components/global-styles/preview.js +0 -264
  476. package/build-module/components/global-styles/preview.js.map +0 -1
  477. package/build-module/components/global-styles/typogrphy-elements.js.map +0 -1
  478. package/build-module/components/global-styles/variations-panel.js.map +0 -1
  479. package/build-module/components/list/added-by.js.map +0 -1
  480. package/build-module/components/list/header.js +0 -47
  481. package/build-module/components/list/header.js.map +0 -1
  482. package/build-module/components/list/index.js +0 -72
  483. package/build-module/components/list/index.js.map +0 -1
  484. package/build-module/components/list/table.js +0 -86
  485. package/build-module/components/list/table.js.map +0 -1
  486. package/build-module/components/list/use-register-shortcuts.js +0 -45
  487. package/build-module/components/list/use-register-shortcuts.js.map +0 -1
  488. package/build-module/components/sidebar-edit-mode/template-panel/template-actions.js +0 -42
  489. package/build-module/components/sidebar-edit-mode/template-panel/template-actions.js.map +0 -1
  490. package/build-module/components/sidebar-navigation-screen-main/template-part-hint.js +0 -29
  491. package/build-module/components/sidebar-navigation-screen-main/template-part-hint.js.map +0 -1
  492. package/build-module/components/sidebar-navigation-screen-navigation-menu/delete-modal.js.map +0 -1
  493. package/build-module/components/sidebar-navigation-screen-navigation-menu/edit-button.js +0 -27
  494. package/build-module/components/sidebar-navigation-screen-navigation-menu/edit-button.js.map +0 -1
  495. package/build-module/components/sidebar-navigation-screen-templates/index.js +0 -124
  496. package/build-module/components/sidebar-navigation-screen-templates/index.js.map +0 -1
  497. package/src/components/global-styles/font-library-modal/collection-font-details.js +0 -56
  498. package/src/components/global-styles/font-library-modal/confirm-delete-dialog.js +0 -33
  499. package/src/components/global-styles/font-library-modal/library-font-card.js +0 -34
  500. package/src/components/global-styles/font-library-modal/tab-panel-layout.js +0 -85
  501. package/src/components/global-styles/preview.js +0 -327
  502. package/src/components/list/header.js +0 -48
  503. package/src/components/list/index.js +0 -87
  504. package/src/components/list/style.scss +0 -188
  505. package/src/components/list/table.js +0 -140
  506. package/src/components/list/use-register-shortcuts.js +0 -49
  507. package/src/components/sidebar-edit-mode/template-panel/template-actions.js +0 -49
  508. package/src/components/sidebar-navigation-screen-main/template-part-hint.js +0 -34
  509. package/src/components/sidebar-navigation-screen-navigation-menu/edit-button.js +0 -22
  510. package/src/components/sidebar-navigation-screen-templates/index.js +0 -156
  511. package/src/components/sidebar-navigation-screen-templates/style.scss +0 -9
@@ -0,0 +1,152 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import {
5
+ __unstableIframe as Iframe,
6
+ __unstableEditorStyles as EditorStyles,
7
+ privateApis as blockEditorPrivateApis,
8
+ } from '@wordpress/block-editor';
9
+ import { __unstableMotion as motion } from '@wordpress/components';
10
+ import {
11
+ useThrottle,
12
+ useReducedMotion,
13
+ useResizeObserver,
14
+ } from '@wordpress/compose';
15
+ import { useLayoutEffect, useState, useMemo } from '@wordpress/element';
16
+
17
+ /**
18
+ * Internal dependencies
19
+ */
20
+ import { unlock } from '../../lock-unlock';
21
+
22
+ const { useGlobalStyle, useGlobalStylesOutput } = unlock(
23
+ blockEditorPrivateApis
24
+ );
25
+
26
+ const normalizedWidth = 248;
27
+ const normalizedHeight = 152;
28
+
29
+ // Throttle options for useThrottle. Must be defined outside of the component,
30
+ // so that the object reference is the same on each render.
31
+ const THROTTLE_OPTIONS = {
32
+ leading: true,
33
+ trailing: true,
34
+ };
35
+
36
+ export default function PreviewIframe( {
37
+ children,
38
+ label,
39
+ isFocused,
40
+ withHoverView,
41
+ } ) {
42
+ const [ backgroundColor = 'white' ] = useGlobalStyle( 'color.background' );
43
+ const [ gradientValue ] = useGlobalStyle( 'color.gradient' );
44
+ const [ styles ] = useGlobalStylesOutput();
45
+ const disableMotion = useReducedMotion();
46
+ const [ isHovered, setIsHovered ] = useState( false );
47
+ const [ containerResizeListener, { width } ] = useResizeObserver();
48
+ const [ throttledWidth, setThrottledWidthState ] = useState( width );
49
+ const [ ratioState, setRatioState ] = useState();
50
+
51
+ const setThrottledWidth = useThrottle(
52
+ setThrottledWidthState,
53
+ 250,
54
+ THROTTLE_OPTIONS
55
+ );
56
+
57
+ // Must use useLayoutEffect to avoid a flash of the iframe at the wrong
58
+ // size before the width is set.
59
+ useLayoutEffect( () => {
60
+ if ( width ) {
61
+ setThrottledWidth( width );
62
+ }
63
+ }, [ width, setThrottledWidth ] );
64
+
65
+ // Must use useLayoutEffect to avoid a flash of the iframe at the wrong
66
+ // size before the width is set.
67
+ useLayoutEffect( () => {
68
+ const newRatio = throttledWidth ? throttledWidth / normalizedWidth : 1;
69
+ const ratioDiff = newRatio - ( ratioState || 0 );
70
+
71
+ // Only update the ratio state if the difference is big enough
72
+ // or if the ratio state is not yet set. This is to avoid an
73
+ // endless loop of updates at particular viewport heights when the
74
+ // presence of a scrollbar causes the width to change slightly.
75
+ const isRatioDiffBigEnough = Math.abs( ratioDiff ) > 0.1;
76
+
77
+ if ( isRatioDiffBigEnough || ! ratioState ) {
78
+ setRatioState( newRatio );
79
+ }
80
+ }, [ throttledWidth, ratioState ] );
81
+
82
+ // Set a fallbackRatio to use before the throttled ratio has been set.
83
+ const fallbackRatio = width ? width / normalizedWidth : 1;
84
+ /*
85
+ * Use the throttled ratio if it has been calculated, otherwise
86
+ * use the fallback ratio. The throttled ratio is used to avoid
87
+ * an endless loop of updates at particular viewport heights.
88
+ * See: https://github.com/WordPress/gutenberg/issues/55112
89
+ */
90
+ const ratio = ratioState ? ratioState : fallbackRatio;
91
+
92
+ /*
93
+ * Reset leaked styles from WP common.css and remove main content layout padding and border.
94
+ * Add pointer cursor to the body to indicate the iframe is interactive,
95
+ * similar to Typography variation previews.
96
+ */
97
+ const editorStyles = useMemo( () => {
98
+ if ( styles ) {
99
+ return [
100
+ ...styles,
101
+ {
102
+ css: 'html{overflow:hidden}body{min-width: 0;padding: 0;border: none;cursor: pointer;}',
103
+ isGlobalStyles: true,
104
+ },
105
+ ];
106
+ }
107
+
108
+ return styles;
109
+ }, [ styles ] );
110
+ const isReady = !! width;
111
+
112
+ return (
113
+ <>
114
+ <div style={ { position: 'relative' } }>
115
+ { containerResizeListener }
116
+ </div>
117
+ { isReady && (
118
+ <Iframe
119
+ className="edit-site-global-styles-preview__iframe"
120
+ style={ {
121
+ height: normalizedHeight * ratio,
122
+ } }
123
+ onMouseEnter={ () => setIsHovered( true ) }
124
+ onMouseLeave={ () => setIsHovered( false ) }
125
+ tabIndex={ -1 }
126
+ >
127
+ <EditorStyles styles={ editorStyles } />
128
+ <motion.div
129
+ style={ {
130
+ height: normalizedHeight * ratio,
131
+ width: '100%',
132
+ background: gradientValue ?? backgroundColor,
133
+ cursor: withHoverView ? 'pointer' : undefined,
134
+ } }
135
+ initial="start"
136
+ animate={
137
+ ( isHovered || isFocused ) &&
138
+ ! disableMotion &&
139
+ label
140
+ ? 'hover'
141
+ : 'start'
142
+ }
143
+ >
144
+ { []
145
+ .concat( children ) // This makes sure children is always an array.
146
+ .map( ( child, key ) => child( { ratio, key } ) ) }
147
+ </motion.div>
148
+ </Iframe>
149
+ ) }
150
+ </>
151
+ );
152
+ }
@@ -0,0 +1,185 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { privateApis as blockEditorPrivateApis } from '@wordpress/block-editor';
5
+ import {
6
+ __experimentalHStack as HStack,
7
+ __experimentalVStack as VStack,
8
+ __unstableMotion as motion,
9
+ } from '@wordpress/components';
10
+
11
+ /**
12
+ * Internal dependencies
13
+ */
14
+ import { unlock } from '../../lock-unlock';
15
+ import { useStylesPreviewColors } from './hooks';
16
+ import TypographyExample from './typography-example';
17
+ import HighlightedColors from './highlighted-colors';
18
+ import PreviewIframe from './preview-iframe';
19
+
20
+ const { useGlobalStyle } = unlock( blockEditorPrivateApis );
21
+
22
+ const firstFrameVariants = {
23
+ start: {
24
+ scale: 1,
25
+ opacity: 1,
26
+ },
27
+ hover: {
28
+ scale: 0,
29
+ opacity: 0,
30
+ },
31
+ };
32
+
33
+ const midFrameVariants = {
34
+ hover: {
35
+ opacity: 1,
36
+ },
37
+ start: {
38
+ opacity: 0.5,
39
+ },
40
+ };
41
+
42
+ const secondFrameVariants = {
43
+ hover: {
44
+ scale: 1,
45
+ opacity: 1,
46
+ },
47
+ start: {
48
+ scale: 0,
49
+ opacity: 0,
50
+ },
51
+ };
52
+
53
+ const PreviewStyles = ( { label, isFocused, withHoverView, variation } ) => {
54
+ const [ fontWeight ] = useGlobalStyle( 'typography.fontWeight' );
55
+ const [ fontFamily = 'serif' ] = useGlobalStyle( 'typography.fontFamily' );
56
+ const [ headingFontFamily = fontFamily ] = useGlobalStyle(
57
+ 'elements.h1.typography.fontFamily'
58
+ );
59
+ const [ headingFontWeight = fontWeight ] = useGlobalStyle(
60
+ 'elements.h1.typography.fontWeight'
61
+ );
62
+ const [ textColor = 'black' ] = useGlobalStyle( 'color.text' );
63
+ const [ headingColor = textColor ] = useGlobalStyle(
64
+ 'elements.h1.color.text'
65
+ );
66
+
67
+ const { paletteColors } = useStylesPreviewColors();
68
+
69
+ return (
70
+ <PreviewIframe
71
+ label={ label }
72
+ isFocused={ isFocused }
73
+ withHoverView={ withHoverView }
74
+ >
75
+ { ( { ratio, key } ) => (
76
+ <motion.div
77
+ key={ key }
78
+ variants={ firstFrameVariants }
79
+ style={ {
80
+ height: '100%',
81
+ overflow: 'hidden',
82
+ } }
83
+ >
84
+ <HStack
85
+ spacing={ 10 * ratio }
86
+ justify="center"
87
+ style={ {
88
+ height: '100%',
89
+ overflow: 'hidden',
90
+ } }
91
+ >
92
+ <TypographyExample
93
+ fontSize={ 65 * ratio }
94
+ variation={ variation }
95
+ />
96
+ <VStack spacing={ 4 * ratio }>
97
+ <HighlightedColors
98
+ normalizedColorSwatchSize={ 32 }
99
+ ratio={ ratio }
100
+ />
101
+ </VStack>
102
+ </HStack>
103
+ </motion.div>
104
+ ) }
105
+ { ( { key } ) => (
106
+ <motion.div
107
+ key={ key }
108
+ variants={ withHoverView && midFrameVariants }
109
+ style={ {
110
+ height: '100%',
111
+ width: '100%',
112
+ position: 'absolute',
113
+ top: 0,
114
+ overflow: 'hidden',
115
+ filter: 'blur(60px)',
116
+ opacity: 0.1,
117
+ } }
118
+ >
119
+ <HStack
120
+ spacing={ 0 }
121
+ justify="flex-start"
122
+ style={ {
123
+ height: '100%',
124
+ overflow: 'hidden',
125
+ } }
126
+ >
127
+ { paletteColors
128
+ .slice( 0, 4 )
129
+ .map( ( { color }, index ) => (
130
+ <div
131
+ key={ index }
132
+ style={ {
133
+ height: '100%',
134
+ background: color,
135
+ flexGrow: 1,
136
+ } }
137
+ />
138
+ ) ) }
139
+ </HStack>
140
+ </motion.div>
141
+ ) }
142
+ { ( { ratio, key } ) => (
143
+ <motion.div
144
+ key={ key }
145
+ variants={ secondFrameVariants }
146
+ style={ {
147
+ height: '100%',
148
+ width: '100%',
149
+ overflow: 'hidden',
150
+ position: 'absolute',
151
+ top: 0,
152
+ } }
153
+ >
154
+ <VStack
155
+ spacing={ 3 * ratio }
156
+ justify="center"
157
+ style={ {
158
+ height: '100%',
159
+ overflow: 'hidden',
160
+ padding: 10 * ratio,
161
+ boxSizing: 'border-box',
162
+ } }
163
+ >
164
+ { label && (
165
+ <div
166
+ style={ {
167
+ fontSize: 40 * ratio,
168
+ fontFamily: headingFontFamily,
169
+ color: headingColor,
170
+ fontWeight: headingFontWeight,
171
+ lineHeight: '1em',
172
+ textAlign: 'center',
173
+ } }
174
+ >
175
+ { label }
176
+ </div>
177
+ ) }
178
+ </VStack>
179
+ </motion.div>
180
+ ) }
181
+ </PreviewIframe>
182
+ );
183
+ };
184
+
185
+ export default PreviewStyles;
@@ -26,7 +26,7 @@ import { speak } from '@wordpress/a11y';
26
26
  /**
27
27
  * Internal dependencies
28
28
  */
29
- import { useBlockVariations } from './variations-panel';
29
+ import { useBlockVariations } from './variations/variations-panel';
30
30
  import ScreenHeader from './header';
31
31
  import { NavigationButtonAsItem } from './navigation-button';
32
32
  import { unlock } from '../../lock-unlock';
@@ -20,7 +20,10 @@ import ScreenHeader from './header';
20
20
  import BlockPreviewPanel from './block-preview-panel';
21
21
  import { unlock } from '../../lock-unlock';
22
22
  import Subtitle from './subtitle';
23
- import { useBlockVariations, VariationsPanel } from './variations-panel';
23
+ import {
24
+ useBlockVariations,
25
+ VariationsPanel,
26
+ } from './variations/variations-panel';
24
27
 
25
28
  function applyFallbackStyle( border ) {
26
29
  if ( ! border ) {
@@ -11,6 +11,7 @@ import { privateApis as blockEditorPrivateApis } from '@wordpress/block-editor';
11
11
  import ScreenHeader from './header';
12
12
  import Palette from './palette';
13
13
  import { unlock } from '../../lock-unlock';
14
+ import ColorVariations from './variations/variations-color';
14
15
 
15
16
  const {
16
17
  useGlobalStyle,
@@ -38,9 +39,9 @@ function ScreenColors() {
38
39
  ) }
39
40
  />
40
41
  <div className="edit-site-global-styles-screen-colors">
41
- <VStack spacing={ 10 }>
42
+ <VStack spacing={ 6 }>
43
+ <ColorVariations />
42
44
  <Palette />
43
-
44
45
  <StylesColorPanel
45
46
  inheritedValue={ inheritedStyle }
46
47
  value={ style }
@@ -73,7 +73,11 @@ function ScreenRevisions() {
73
73
 
74
74
  const onCloseRevisions = () => {
75
75
  goTo( '/' ); // Return to global styles main panel.
76
- setEditorCanvasContainerView( undefined );
76
+ const canvasContainerView =
77
+ editorCanvasContainerView === 'global-styles-revisions:style-book'
78
+ ? 'style-book'
79
+ : undefined;
80
+ setEditorCanvasContainerView( canvasContainerView );
77
81
  };
78
82
 
79
83
  const restoreRevision = ( revision ) => {
@@ -99,7 +103,6 @@ function ScreenRevisions() {
99
103
  ! editorCanvasContainerView.startsWith( 'global-styles-revisions' )
100
104
  ) {
101
105
  goTo( '/' ); // Return to global styles main panel.
102
- setEditorCanvasContainerView( editorCanvasContainerView );
103
106
  }
104
107
  }, [ editorCanvasContainerView ] );
105
108
 
@@ -24,7 +24,7 @@ import { privateApis as blockEditorPrivateApis } from '@wordpress/block-editor';
24
24
  import { IconWithCurrentColor } from './icon-with-current-color';
25
25
  import { NavigationButtonAsItem } from './navigation-button';
26
26
  import RootMenu from './root-menu';
27
- import StylesPreview from './preview';
27
+ import PreviewStyles from './preview-styles';
28
28
  import { unlock } from '../../lock-unlock';
29
29
 
30
30
  const { useGlobalStyle } = unlock( blockEditorPrivateApis );
@@ -58,7 +58,7 @@ function ScreenRoot() {
58
58
  <VStack spacing={ 4 }>
59
59
  <Card>
60
60
  <CardMedia>
61
- <StylesPreview />
61
+ <PreviewStyles />
62
62
  </CardMedia>
63
63
  </Card>
64
64
  { hasVariations && (
@@ -9,7 +9,8 @@ import { useSelect } from '@wordpress/data';
9
9
  /**
10
10
  * Internal dependencies
11
11
  */
12
- import TypographyElements from './typogrphy-elements';
12
+ import TypographyElements from './typography-elements';
13
+ import TypographyVariations from './variations/variations-typography';
13
14
  import FontFamilies from './font-families';
14
15
  import ScreenHeader from './header';
15
16
 
@@ -30,7 +31,12 @@ function ScreenTypography() {
30
31
  />
31
32
  <div className="edit-site-global-styles-screen-typography">
32
33
  <VStack spacing={ 6 }>
33
- { fontLibraryEnabled && <FontFamilies /> }
34
+ <TypographyVariations />
35
+ { ! window.__experimentalDisableFontLibrary && (
36
+ <VStack spacing={ 3 }>
37
+ { fontLibraryEnabled && <FontFamilies /> }
38
+ </VStack>
39
+ ) }
34
40
  <TypographyElements />
35
41
  </VStack>
36
42
  </div>
@@ -1,104 +1,17 @@
1
- /**
2
- * External dependencies
3
- */
4
- import classnames from 'classnames';
5
-
6
1
  /**
7
2
  * WordPress dependencies
8
3
  */
9
4
  import { store as coreStore } from '@wordpress/core-data';
10
5
  import { useSelect } from '@wordpress/data';
11
- import { useMemo, useContext, useState } from '@wordpress/element';
12
- import { ENTER } from '@wordpress/keycodes';
6
+ import { useMemo } from '@wordpress/element';
13
7
  import { __experimentalGrid as Grid } from '@wordpress/components';
14
- import { __, sprintf } from '@wordpress/i18n';
15
- import { privateApis as blockEditorPrivateApis } from '@wordpress/block-editor';
8
+ import { __ } from '@wordpress/i18n';
16
9
 
17
10
  /**
18
11
  * Internal dependencies
19
12
  */
20
- import { mergeBaseAndUserConfigs } from './global-styles-provider';
21
- import StylesPreview from './preview';
22
- import { unlock } from '../../lock-unlock';
23
-
24
- const { GlobalStylesContext, areGlobalStyleConfigsEqual } = unlock(
25
- blockEditorPrivateApis
26
- );
27
-
28
- function Variation( { variation } ) {
29
- const [ isFocused, setIsFocused ] = useState( false );
30
- const { base, user, setUserConfig } = useContext( GlobalStylesContext );
31
- const context = useMemo( () => {
32
- return {
33
- user: {
34
- settings: variation.settings ?? {},
35
- styles: variation.styles ?? {},
36
- },
37
- base,
38
- merged: mergeBaseAndUserConfigs( base, variation ),
39
- setUserConfig: () => {},
40
- };
41
- }, [ variation, base ] );
42
-
43
- const selectVariation = () => {
44
- setUserConfig( () => {
45
- return {
46
- settings: variation.settings,
47
- styles: variation.styles,
48
- };
49
- } );
50
- };
51
-
52
- const selectOnEnter = ( event ) => {
53
- if ( event.keyCode === ENTER ) {
54
- event.preventDefault();
55
- selectVariation();
56
- }
57
- };
58
-
59
- const isActive = useMemo( () => {
60
- return areGlobalStyleConfigsEqual( user, variation );
61
- }, [ user, variation ] );
62
-
63
- let label = variation?.title;
64
- if ( variation?.description ) {
65
- label = sprintf(
66
- /* translators: %1$s: variation title. %2$s variation description. */
67
- __( '%1$s (%2$s)' ),
68
- variation?.title,
69
- variation?.description
70
- );
71
- }
72
-
73
- return (
74
- <GlobalStylesContext.Provider value={ context }>
75
- <div
76
- className={ classnames(
77
- 'edit-site-global-styles-variations_item',
78
- {
79
- 'is-active': isActive,
80
- }
81
- ) }
82
- role="button"
83
- onClick={ selectVariation }
84
- onKeyDown={ selectOnEnter }
85
- tabIndex="0"
86
- aria-label={ label }
87
- aria-current={ isActive }
88
- onFocus={ () => setIsFocused( true ) }
89
- onBlur={ () => setIsFocused( false ) }
90
- >
91
- <div className="edit-site-global-styles-variations_item-preview">
92
- <StylesPreview
93
- label={ variation?.title }
94
- isFocused={ isFocused }
95
- withHoverView
96
- />
97
- </div>
98
- </div>
99
- </GlobalStylesContext.Provider>
100
- );
101
- }
13
+ import PreviewStyles from './preview-styles';
14
+ import Variation from './variations/variation';
102
15
 
103
16
  export default function StyleVariationsContainer() {
104
17
  const variations = useSelect( ( select ) => {
@@ -128,7 +41,16 @@ export default function StyleVariationsContainer() {
128
41
  className="edit-site-global-styles-style-variations-container"
129
42
  >
130
43
  { withEmptyVariation.map( ( variation, index ) => (
131
- <Variation key={ index } variation={ variation } />
44
+ <Variation key={ index } variation={ variation }>
45
+ { ( isFocused ) => (
46
+ <PreviewStyles
47
+ label={ variation?.title }
48
+ withHoverView
49
+ isFocused={ isFocused }
50
+ variation={ variation }
51
+ />
52
+ ) }
53
+ </Variation>
132
54
  ) ) }
133
55
  </Grid>
134
56
  );
@@ -7,8 +7,10 @@
7
7
  }
8
8
 
9
9
  .edit-site-global-styles-preview__iframe {
10
- max-width: 100%;
10
+ border-radius: $radius-block-ui;
11
11
  display: block;
12
+ max-width: 100%;
13
+ width: 100%;
12
14
  }
13
15
 
14
16
  .edit-site-typography-preview {
@@ -91,40 +93,6 @@
91
93
  margin: 0;
92
94
  }
93
95
 
94
- .edit-site-global-styles-variations_item {
95
- box-sizing: border-box;
96
- // To round the outline in Windows 10 high contrast mode.
97
- border-radius: $radius-block-ui;
98
-
99
- .edit-site-global-styles-variations_item-preview {
100
- padding: $border-width * 2;
101
- border-radius: $radius-block-ui;
102
- box-shadow: 0 0 0 $border-width $gray-200;
103
- // Shown in Windows 10 high contrast mode.
104
- outline: 1px solid transparent;
105
- }
106
-
107
- &.is-active .edit-site-global-styles-variations_item-preview {
108
- box-shadow: 0 0 0 $border-width $gray-900;
109
- // Shown in Windows 10 high contrast mode.
110
- outline-width: 3px;
111
- }
112
-
113
- &:hover .edit-site-global-styles-variations_item-preview {
114
- box-shadow: 0 0 0 $border-width var(--wp-admin-theme-color);
115
- }
116
-
117
- &:focus .edit-site-global-styles-variations_item-preview {
118
- box-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);
119
- }
120
-
121
- &:focus-visible {
122
- // Shown in Windows 10 high contrast mode.
123
- outline: 3px solid transparent;
124
- outline-offset: 0;
125
- }
126
- }
127
-
128
96
  .edit-site-global-styles-icon-with-current-color {
129
97
  fill: currentColor;
130
98
  }
@@ -199,3 +167,4 @@
199
167
  .edit-site-global-styles-sidebar__panel .block-editor-block-icon svg {
200
168
  fill: currentColor;
201
169
  }
170
+
@@ -35,6 +35,7 @@ function ElementItem( { parentMenu, element, label } ) {
35
35
  prefix + 'typography.letterSpacing'
36
36
  );
37
37
  const [ backgroundColor ] = useGlobalStyle( prefix + 'color.background' );
38
+ const [ fallbackBackgroundColor ] = useGlobalStyle( 'color.background' );
38
39
  const [ gradientValue ] = useGlobalStyle( prefix + 'color.gradient' );
39
40
  const [ color ] = useGlobalStyle( prefix + 'color.text' );
40
41
 
@@ -54,7 +55,10 @@ function ElementItem( { parentMenu, element, label } ) {
54
55
  className="edit-site-global-styles-screen-typography__indicator"
55
56
  style={ {
56
57
  fontFamily: fontFamily ?? 'serif',
57
- background: gradientValue ?? backgroundColor,
58
+ background:
59
+ gradientValue ??
60
+ backgroundColor ??
61
+ fallbackBackgroundColor,
58
62
  color,
59
63
  fontStyle,
60
64
  fontWeight,