@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
@@ -1,56 +0,0 @@
1
- /**
2
- * WordPress dependencies
3
- */
4
- import {
5
- __experimentalVStack as VStack,
6
- __experimentalSpacer as Spacer,
7
- } from '@wordpress/components';
8
-
9
- /**
10
- * Internal dependencies
11
- */
12
- import CollectionFontVariant from './collection-font-variant';
13
- import { isFontFontFaceInOutline } from './utils/fonts-outline';
14
- import { sortFontFaces } from './utils/sort-font-faces';
15
-
16
- function CollectionFontDetails( {
17
- font,
18
- handleToggleVariant,
19
- fontToInstallOutline,
20
- } ) {
21
- const fontFaces =
22
- font.fontFace && font.fontFace.length
23
- ? sortFontFaces( font.fontFace )
24
- : [
25
- {
26
- fontFamily: font.fontFamily,
27
- fontStyle: 'normal',
28
- fontWeight: '400',
29
- },
30
- ];
31
-
32
- return (
33
- <>
34
- <Spacer margin={ 4 } />
35
- <VStack spacing={ 0 }>
36
- <Spacer margin={ 8 } />
37
- { fontFaces.map( ( face, i ) => (
38
- <CollectionFontVariant
39
- font={ font }
40
- face={ face }
41
- key={ `face${ i }` }
42
- handleToggleVariant={ handleToggleVariant }
43
- selected={ isFontFontFaceInOutline(
44
- font.slug,
45
- font.fontFace ? face : null, // If the font has no fontFace, we want to check if the font is in the outline
46
- fontToInstallOutline
47
- ) }
48
- />
49
- ) ) }
50
- </VStack>
51
- <Spacer margin={ 16 } />
52
- </>
53
- );
54
- }
55
-
56
- export default CollectionFontDetails;
@@ -1,33 +0,0 @@
1
- /**
2
- * WordPress dependencies
3
- */
4
- import { __, sprintf } from '@wordpress/i18n';
5
- import { __experimentalConfirmDialog as ConfirmDialog } from '@wordpress/components';
6
-
7
- function ConfirmDeleteDialog( {
8
- font,
9
- isConfirmDeleteOpen,
10
- handleConfirmUninstall,
11
- handleCancelUninstall,
12
- } ) {
13
- return (
14
- <ConfirmDialog
15
- isOpen={ isConfirmDeleteOpen }
16
- cancelButtonText={ __( 'Cancel' ) }
17
- confirmButtonText={ __( 'Delete' ) }
18
- onCancel={ handleCancelUninstall }
19
- onConfirm={ handleConfirmUninstall }
20
- >
21
- { font &&
22
- sprintf(
23
- /* translators: %s: Name of the font. */
24
- __(
25
- 'Are you sure you want to delete "%s" font and all its variants and assets?'
26
- ),
27
- font.name
28
- ) }
29
- </ConfirmDialog>
30
- );
31
- }
32
-
33
- export default ConfirmDeleteDialog;
@@ -1,34 +0,0 @@
1
- /**
2
- * WordPress dependencies
3
- */
4
- import { __, sprintf } from '@wordpress/i18n';
5
- import { useContext } from '@wordpress/element';
6
-
7
- /**
8
- * Internal dependencies
9
- */
10
- import FontCard from './font-card';
11
- import { FontLibraryContext } from './context';
12
-
13
- function LibraryFontCard( { font, ...props } ) {
14
- const { getFontFacesActivated } = useContext( FontLibraryContext );
15
-
16
- const variantsInstalled =
17
- font?.fontFace?.length > 0 ? font.fontFace.length : 1;
18
- const variantsActive = getFontFacesActivated(
19
- font.slug,
20
- font.source
21
- ).length;
22
- const variantsText = sprintf(
23
- /* translators: 1: Active font variants, 2: Total font variants. */
24
- __( '%1$s/%2$s variants active' ),
25
- variantsActive,
26
- variantsInstalled
27
- );
28
-
29
- return (
30
- <FontCard font={ font } variantsText={ variantsText } { ...props } />
31
- );
32
- }
33
-
34
- export default LibraryFontCard;
@@ -1,85 +0,0 @@
1
- /**
2
- * WordPress dependencies
3
- */
4
- import { useContext } from '@wordpress/element';
5
- import {
6
- __experimentalText as Text,
7
- __experimentalHeading as Heading,
8
- __experimentalVStack as VStack,
9
- __experimentalSpacer as Spacer,
10
- __experimentalHStack as HStack,
11
- Button,
12
- Notice,
13
- FlexBlock,
14
- } from '@wordpress/components';
15
- import { chevronLeft } from '@wordpress/icons';
16
- import { __ } from '@wordpress/i18n';
17
-
18
- /**
19
- * Internal dependencies
20
- */
21
- import { FontLibraryContext } from './context';
22
-
23
- function TabPanelLayout( {
24
- title,
25
- description,
26
- notice,
27
- handleBack,
28
- children,
29
- footer,
30
- } ) {
31
- const { setNotice } = useContext( FontLibraryContext );
32
-
33
- return (
34
- <div className="font-library-modal__tabpanel-layout">
35
- <Spacer margin={ 4 } />
36
- <VStack spacing={ 4 } justify="space-between">
37
- <VStack spacing={ 2 }>
38
- <HStack justify="flex-start">
39
- { !! handleBack && (
40
- <Button
41
- variant="tertiary"
42
- onClick={ handleBack }
43
- icon={ chevronLeft }
44
- size="small"
45
- label={ __( 'Back' ) }
46
- />
47
- ) }
48
- { title && (
49
- <Heading
50
- level={ 2 }
51
- size={ 13 }
52
- className="edit-site-global-styles-header"
53
- >
54
- { title }
55
- </Heading>
56
- ) }
57
- </HStack>
58
- { description && <Text>{ description }</Text> }
59
- { notice && (
60
- <FlexBlock>
61
- <Spacer margin={ 1 } />
62
- <Notice
63
- status={ notice.type }
64
- onRemove={ () => setNotice( null ) }
65
- >
66
- { notice.message }
67
- </Notice>
68
- <Spacer margin={ 1 } />
69
- </FlexBlock>
70
- ) }
71
- </VStack>
72
- <div className="font-library-modal__tabpanel-layout__main">
73
- { children }
74
- </div>
75
- { footer && (
76
- <div className="font-library-modal__tabpanel-layout__footer">
77
- { footer }
78
- </div>
79
- ) }
80
- </VStack>
81
- </div>
82
- );
83
- }
84
-
85
- export default TabPanelLayout;
@@ -1,327 +0,0 @@
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 {
10
- __unstableMotion as motion,
11
- __experimentalHStack as HStack,
12
- __experimentalVStack as VStack,
13
- } from '@wordpress/components';
14
- import {
15
- useThrottle,
16
- useReducedMotion,
17
- useResizeObserver,
18
- } from '@wordpress/compose';
19
- import { useLayoutEffect, useState, useMemo } from '@wordpress/element';
20
-
21
- /**
22
- * Internal dependencies
23
- */
24
- import { unlock } from '../../lock-unlock';
25
- import { useStylesPreviewColors } from './hooks';
26
-
27
- const { useGlobalStyle, useGlobalStylesOutput } = unlock(
28
- blockEditorPrivateApis
29
- );
30
-
31
- const firstFrame = {
32
- start: {
33
- scale: 1,
34
- opacity: 1,
35
- },
36
- hover: {
37
- scale: 0,
38
- opacity: 0,
39
- },
40
- };
41
-
42
- const midFrame = {
43
- hover: {
44
- opacity: 1,
45
- },
46
- start: {
47
- opacity: 0.5,
48
- },
49
- };
50
-
51
- const secondFrame = {
52
- hover: {
53
- scale: 1,
54
- opacity: 1,
55
- },
56
- start: {
57
- scale: 0,
58
- opacity: 0,
59
- },
60
- };
61
-
62
- const normalizedWidth = 248;
63
- const normalizedHeight = 152;
64
-
65
- const normalizedColorSwatchSize = 32;
66
-
67
- // Throttle options for useThrottle. Must be defined outside of the component,
68
- // so that the object reference is the same on each render.
69
- const THROTTLE_OPTIONS = {
70
- leading: true,
71
- trailing: true,
72
- };
73
-
74
- const StylesPreview = ( { label, isFocused, withHoverView } ) => {
75
- const [ fontWeight ] = useGlobalStyle( 'typography.fontWeight' );
76
- const [ fontFamily = 'serif' ] = useGlobalStyle( 'typography.fontFamily' );
77
- const [ headingFontFamily = fontFamily ] = useGlobalStyle(
78
- 'elements.h1.typography.fontFamily'
79
- );
80
- const [ headingFontWeight = fontWeight ] = useGlobalStyle(
81
- 'elements.h1.typography.fontWeight'
82
- );
83
- const [ textColor = 'black' ] = useGlobalStyle( 'color.text' );
84
- const [ headingColor = textColor ] = useGlobalStyle(
85
- 'elements.h1.color.text'
86
- );
87
- const [ backgroundColor = 'white' ] = useGlobalStyle( 'color.background' );
88
- const [ gradientValue ] = useGlobalStyle( 'color.gradient' );
89
- const [ styles ] = useGlobalStylesOutput();
90
- const disableMotion = useReducedMotion();
91
- const [ isHovered, setIsHovered ] = useState( false );
92
- const [ containerResizeListener, { width } ] = useResizeObserver();
93
- const [ throttledWidth, setThrottledWidthState ] = useState( width );
94
- const [ ratioState, setRatioState ] = useState();
95
-
96
- const setThrottledWidth = useThrottle(
97
- setThrottledWidthState,
98
- 250,
99
- THROTTLE_OPTIONS
100
- );
101
-
102
- // Must use useLayoutEffect to avoid a flash of the iframe at the wrong
103
- // size before the width is set.
104
- useLayoutEffect( () => {
105
- if ( width ) {
106
- setThrottledWidth( width );
107
- }
108
- }, [ width, setThrottledWidth ] );
109
-
110
- // Must use useLayoutEffect to avoid a flash of the iframe at the wrong
111
- // size before the width is set.
112
- useLayoutEffect( () => {
113
- const newRatio = throttledWidth ? throttledWidth / normalizedWidth : 1;
114
- const ratioDiff = newRatio - ( ratioState || 0 );
115
-
116
- // Only update the ratio state if the difference is big enough
117
- // or if the ratio state is not yet set. This is to avoid an
118
- // endless loop of updates at particular viewport heights when the
119
- // presence of a scrollbar causes the width to change slightly.
120
- const isRatioDiffBigEnough = Math.abs( ratioDiff ) > 0.1;
121
-
122
- if ( isRatioDiffBigEnough || ! ratioState ) {
123
- setRatioState( newRatio );
124
- }
125
- }, [ throttledWidth, ratioState ] );
126
-
127
- // Set a fallbackRatio to use before the throttled ratio has been set.
128
- const fallbackRatio = width ? width / normalizedWidth : 1;
129
- // Use the throttled ratio if it has been calculated, otherwise
130
- // use the fallback ratio. The throttled ratio is used to avoid
131
- // an endless loop of updates at particular viewport heights.
132
- // See: https://github.com/WordPress/gutenberg/issues/55112
133
- const ratio = ratioState ? ratioState : fallbackRatio;
134
-
135
- const { paletteColors, highlightedColors } = useStylesPreviewColors();
136
-
137
- // Reset leaked styles from WP common.css and remove main content layout padding and border.
138
- const editorStyles = useMemo( () => {
139
- if ( styles ) {
140
- return [
141
- ...styles,
142
- {
143
- css: 'html{overflow:hidden}body{min-width: 0;padding: 0;border: none;}',
144
- isGlobalStyles: true,
145
- },
146
- ];
147
- }
148
-
149
- return styles;
150
- }, [ styles ] );
151
- const isReady = !! width;
152
-
153
- return (
154
- <>
155
- <div style={ { position: 'relative' } }>
156
- { containerResizeListener }
157
- </div>
158
- { isReady && (
159
- <Iframe
160
- className="edit-site-global-styles-preview__iframe"
161
- style={ {
162
- width: '100%',
163
- height: normalizedHeight * ratio,
164
- } }
165
- onMouseEnter={ () => setIsHovered( true ) }
166
- onMouseLeave={ () => setIsHovered( false ) }
167
- tabIndex={ -1 }
168
- >
169
- <EditorStyles styles={ editorStyles } />
170
- <motion.div
171
- style={ {
172
- height: normalizedHeight * ratio,
173
- width: '100%',
174
- background: gradientValue ?? backgroundColor,
175
- cursor: withHoverView ? 'pointer' : undefined,
176
- } }
177
- initial="start"
178
- animate={
179
- ( isHovered || isFocused ) &&
180
- ! disableMotion &&
181
- label
182
- ? 'hover'
183
- : 'start'
184
- }
185
- >
186
- <motion.div
187
- variants={ firstFrame }
188
- style={ {
189
- height: '100%',
190
- overflow: 'hidden',
191
- } }
192
- >
193
- <HStack
194
- spacing={ 10 * ratio }
195
- justify="center"
196
- style={ {
197
- height: '100%',
198
- overflow: 'hidden',
199
- } }
200
- >
201
- <motion.div
202
- style={ {
203
- fontFamily: headingFontFamily,
204
- fontSize: 65 * ratio,
205
- color: headingColor,
206
- fontWeight: headingFontWeight,
207
- } }
208
- animate={ { scale: 1, opacity: 1 } }
209
- initial={ { scale: 0.1, opacity: 0 } }
210
- transition={ { delay: 0.3, type: 'tween' } }
211
- >
212
- Aa
213
- </motion.div>
214
- <VStack spacing={ 4 * ratio }>
215
- { highlightedColors.map(
216
- ( { slug, color }, index ) => (
217
- <motion.div
218
- key={ slug }
219
- style={ {
220
- height:
221
- normalizedColorSwatchSize *
222
- ratio,
223
- width:
224
- normalizedColorSwatchSize *
225
- ratio,
226
- background: color,
227
- borderRadius:
228
- ( normalizedColorSwatchSize *
229
- ratio ) /
230
- 2,
231
- } }
232
- animate={ {
233
- scale: 1,
234
- opacity: 1,
235
- } }
236
- initial={ {
237
- scale: 0.1,
238
- opacity: 0,
239
- } }
240
- transition={ {
241
- delay:
242
- index === 1 ? 0.2 : 0.1,
243
- } }
244
- />
245
- )
246
- ) }
247
- </VStack>
248
- </HStack>
249
- </motion.div>
250
- <motion.div
251
- variants={ withHoverView && midFrame }
252
- style={ {
253
- height: '100%',
254
- width: '100%',
255
- position: 'absolute',
256
- top: 0,
257
- overflow: 'hidden',
258
- filter: 'blur(60px)',
259
- opacity: 0.1,
260
- } }
261
- >
262
- <HStack
263
- spacing={ 0 }
264
- justify="flex-start"
265
- style={ {
266
- height: '100%',
267
- overflow: 'hidden',
268
- } }
269
- >
270
- { paletteColors
271
- .slice( 0, 4 )
272
- .map( ( { color }, index ) => (
273
- <div
274
- key={ index }
275
- style={ {
276
- height: '100%',
277
- background: color,
278
- flexGrow: 1,
279
- } }
280
- />
281
- ) ) }
282
- </HStack>
283
- </motion.div>
284
- <motion.div
285
- variants={ secondFrame }
286
- style={ {
287
- height: '100%',
288
- width: '100%',
289
- overflow: 'hidden',
290
- position: 'absolute',
291
- top: 0,
292
- } }
293
- >
294
- <VStack
295
- spacing={ 3 * ratio }
296
- justify="center"
297
- style={ {
298
- height: '100%',
299
- overflow: 'hidden',
300
- padding: 10 * ratio,
301
- boxSizing: 'border-box',
302
- } }
303
- >
304
- { label && (
305
- <div
306
- style={ {
307
- fontSize: 40 * ratio,
308
- fontFamily: headingFontFamily,
309
- color: headingColor,
310
- fontWeight: headingFontWeight,
311
- lineHeight: '1em',
312
- textAlign: 'center',
313
- } }
314
- >
315
- { label }
316
- </div>
317
- ) }
318
- </VStack>
319
- </motion.div>
320
- </motion.div>
321
- </Iframe>
322
- ) }
323
- </>
324
- );
325
- };
326
-
327
- export default StylesPreview;
@@ -1,48 +0,0 @@
1
- /**
2
- * WordPress dependencies
3
- */
4
- import { useSelect } from '@wordpress/data';
5
- import { store as coreStore } from '@wordpress/core-data';
6
- import { __experimentalHeading as Heading } from '@wordpress/components';
7
-
8
- /**
9
- * Internal dependencies
10
- */
11
- import AddNewTemplate from '../add-new-template';
12
- import { store as editSiteStore } from '../../store';
13
-
14
- export default function Header( { templateType } ) {
15
- const { canCreate, postType } = useSelect(
16
- ( select ) => {
17
- const { supportsTemplatePartsMode } =
18
- select( editSiteStore ).getSettings();
19
- return {
20
- postType: select( coreStore ).getPostType( templateType ),
21
- canCreate: ! supportsTemplatePartsMode,
22
- };
23
- },
24
- [ templateType ]
25
- );
26
-
27
- if ( ! postType ) {
28
- return null;
29
- }
30
-
31
- return (
32
- <header className="edit-site-list-header">
33
- <Heading level={ 1 } className="edit-site-list-header__title">
34
- { postType.labels?.name }
35
- </Heading>
36
-
37
- { canCreate && (
38
- <div className="edit-site-list-header__right">
39
- <AddNewTemplate
40
- templateType={ templateType }
41
- showIcon={ false }
42
- toggleProps={ { variant: 'primary' } }
43
- />
44
- </div>
45
- ) }
46
- </header>
47
- );
48
- }
@@ -1,87 +0,0 @@
1
- /**
2
- * WordPress dependencies
3
- */
4
- import { store as coreStore } from '@wordpress/core-data';
5
- import { useSelect } from '@wordpress/data';
6
- import { InterfaceSkeleton } from '@wordpress/interface';
7
- import { __, sprintf } from '@wordpress/i18n';
8
- import { store as keyboardShortcutsStore } from '@wordpress/keyboard-shortcuts';
9
- import { EditorSnackbars } from '@wordpress/editor';
10
- import { privateApis as routerPrivateApis } from '@wordpress/router';
11
-
12
- /**
13
- * Internal dependencies
14
- */
15
- import useRegisterShortcuts from './use-register-shortcuts';
16
- import Header from './header';
17
- import Table from './table';
18
- import useTitle from '../routes/use-title';
19
- import { unlock } from '../../lock-unlock';
20
- import {
21
- TEMPLATE_POST_TYPE,
22
- TEMPLATE_PART_POST_TYPE,
23
- } from '../../utils/constants';
24
-
25
- const { useLocation } = unlock( routerPrivateApis );
26
-
27
- export default function List() {
28
- const {
29
- params: { path },
30
- } = useLocation();
31
- const templateType =
32
- path === '/wp_template/all'
33
- ? TEMPLATE_POST_TYPE
34
- : TEMPLATE_PART_POST_TYPE;
35
-
36
- useRegisterShortcuts();
37
-
38
- const { previousShortcut, nextShortcut } = useSelect( ( select ) => {
39
- return {
40
- previousShortcut: select(
41
- keyboardShortcutsStore
42
- ).getAllShortcutKeyCombinations( 'core/edit-site/previous-region' ),
43
- nextShortcut: select(
44
- keyboardShortcutsStore
45
- ).getAllShortcutKeyCombinations( 'core/edit-site/next-region' ),
46
- };
47
- }, [] );
48
-
49
- const postType = useSelect(
50
- ( select ) => select( coreStore ).getPostType( templateType ),
51
- [ templateType ]
52
- );
53
-
54
- useTitle( postType?.labels?.name );
55
-
56
- // `postType` could load in asynchronously. Only provide the detailed region labels if
57
- // the postType has loaded, otherwise `InterfaceSkeleton` will fallback to the defaults.
58
- const itemsListLabel = postType?.labels?.items_list;
59
- const detailedRegionLabels = postType
60
- ? {
61
- header: sprintf(
62
- // translators: %s - the name of the page, 'Header' as in the header area of that page.
63
- __( '%s - Header' ),
64
- itemsListLabel
65
- ),
66
- body: sprintf(
67
- // translators: %s - the name of the page, 'Content' as in the content area of that page.
68
- __( '%s - Content' ),
69
- itemsListLabel
70
- ),
71
- }
72
- : undefined;
73
-
74
- return (
75
- <InterfaceSkeleton
76
- className="edit-site-list"
77
- labels={ detailedRegionLabels }
78
- header={ <Header templateType={ templateType } /> }
79
- notices={ <EditorSnackbars /> }
80
- content={ <Table templateType={ templateType } /> }
81
- shortcuts={ {
82
- previous: previousShortcut,
83
- next: nextShortcut,
84
- } }
85
- />
86
- );
87
- }