@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
@@ -9,7 +9,7 @@ import { __experimentalItemGroup as ItemGroup } from '@wordpress/components';
9
9
  * Internal dependencies
10
10
  */
11
11
  import DataViewItem from '../sidebar-dataviews/dataview-item';
12
- import { useAddedBy } from '../list/added-by';
12
+ import { useAddedBy } from '../page-templates-template-parts/hooks';
13
13
  import { layout } from '@wordpress/icons';
14
14
 
15
15
  const EMPTY_ARRAY = [];
@@ -23,7 +23,7 @@ function TemplateDataviewItem( { template, isActive } ) {
23
23
  title={ text }
24
24
  icon={ icon }
25
25
  isActive={ isActive }
26
- isCustom="false"
26
+ isCustom={ false }
27
27
  />
28
28
  );
29
29
  }
@@ -31,7 +31,7 @@ function TemplateDataviewItem( { template, isActive } ) {
31
31
  export default function DataviewsTemplatesSidebarContent( {
32
32
  activeView,
33
33
  postType,
34
- config,
34
+ title,
35
35
  } ) {
36
36
  const { records } = useEntityRecords( 'postType', postType, {
37
37
  per_page: -1,
@@ -54,10 +54,10 @@ export default function DataviewsTemplatesSidebarContent( {
54
54
  <ItemGroup>
55
55
  <DataViewItem
56
56
  slug={ 'all' }
57
- title={ config[ postType ].title }
57
+ title={ title }
58
58
  icon={ layout }
59
59
  isActive={ activeView === 'all' }
60
- isCustom="false"
60
+ isCustom={ false }
61
61
  />
62
62
  { firstItemPerAuthorText.map( ( template ) => {
63
63
  return (
@@ -21,17 +21,19 @@ import DataviewsTemplatesSidebarContent from './content';
21
21
 
22
22
  const config = {
23
23
  [ TEMPLATE_POST_TYPE ]: {
24
- title: __( 'All templates' ),
24
+ title: __( 'Manage templates' ),
25
25
  description: __(
26
26
  'Create new templates, or reset any customizations made to the templates supplied by your theme.'
27
27
  ),
28
+ contentTitle: __( 'All templates' ),
28
29
  },
29
30
  [ TEMPLATE_PART_POST_TYPE ]: {
30
- title: __( 'All template parts' ),
31
+ title: __( 'Manage template parts' ),
31
32
  description: __(
32
33
  'Create new template parts, or reset any customizations made to the template parts supplied by your theme.'
33
34
  ),
34
35
  backPath: '/patterns',
36
+ contentTitle: __( 'All template parts' ),
35
37
  },
36
38
  };
37
39
 
@@ -62,7 +64,7 @@ export default function SidebarNavigationScreenTemplatesBrowse() {
62
64
  <DataviewsTemplatesSidebarContent
63
65
  activeView={ activeView }
64
66
  postType={ postType }
65
- config={ config }
67
+ title={ config[ postType ].contentTitle }
66
68
  />
67
69
  }
68
70
  />
@@ -137,7 +137,7 @@ function StartModal( { slug, isCustom, onClose, postType } ) {
137
137
  closeLabel={ __( 'Cancel' ) }
138
138
  focusOnMount="firstElement"
139
139
  onRequestClose={ onClose }
140
- isFullScreen={ true }
140
+ isFullScreen
141
141
  >
142
142
  <div className="edit-site-start-template-options__modal-content">
143
143
  <PatternSelection
@@ -207,7 +207,7 @@ function useResolveEditedEntityAndContext( { path, postId, postType } ) {
207
207
  return {};
208
208
  }, [ homepageId, postType, postId, path ] );
209
209
 
210
- if ( path === '/wp_template/all' && postId ) {
210
+ if ( path === '/wp_template' && postId ) {
211
211
  return { isReady: true, postType: 'wp_template', postId, context };
212
212
  }
213
213
 
@@ -101,28 +101,12 @@ export default function useSyncPathWithURL() {
101
101
  canvas: undefined,
102
102
  path: navigatorLocation.path,
103
103
  } );
104
- } else if (
105
- navigatorLocation.path === '/wp_template/all' &&
106
- ! window?.__experimentalAdminViews
107
- ) {
108
- // When the experiment is disabled, we only support table layout.
109
- // Clear it out from the URL, so layouts other than table cannot be accessed.
110
- updateUrlParams( {
111
- postType: undefined,
112
- categoryType: undefined,
113
- categoryId: undefined,
114
- path: navigatorLocation.path,
115
- layout: undefined,
116
- } );
117
104
  } else if (
118
105
  // These sidebar paths are special in the sense that the url in these pages may or may not have a postId and we need to retain it if it has.
119
106
  // The "type" property should be kept as well.
120
- ( navigatorLocation.path === '/pages' &&
121
- window?.__experimentalAdminViews ) ||
122
- ( navigatorLocation.path === '/wp_template/all' &&
123
- window?.__experimentalAdminViews ) ||
124
- ( navigatorLocation.path === '/wp_template_part/all' &&
125
- window?.__experimentalAdminViews )
107
+ navigatorLocation.path === '/pages' ||
108
+ navigatorLocation.path === '/wp_template' ||
109
+ navigatorLocation.path === '/wp_template_part/all'
126
110
  ) {
127
111
  updateUrlParams( {
128
112
  postType: undefined,
@@ -36,10 +36,7 @@ export default function TemplateActions( {
36
36
  select( coreStore ).getEntityRecord( 'postType', postType, postId ),
37
37
  [ postType, postId ]
38
38
  );
39
- const { removeTemplate, revertTemplate } = useDispatch( editSiteStore );
40
- const { saveEditedEntityRecord } = useDispatch( coreStore );
41
- const { createSuccessNotice, createErrorNotice } =
42
- useDispatch( noticesStore );
39
+ const { removeTemplate } = useDispatch( editSiteStore );
43
40
  const isRemovable = isTemplateRemovable( template );
44
41
  const isRevertable = isTemplateRevertable( template );
45
42
 
@@ -47,6 +44,49 @@ export default function TemplateActions( {
47
44
  return null;
48
45
  }
49
46
 
47
+ return (
48
+ <DropdownMenu
49
+ icon={ moreVertical }
50
+ label={ __( 'Actions' ) }
51
+ className={ className }
52
+ toggleProps={ toggleProps }
53
+ >
54
+ { ( { onClose } ) => (
55
+ <MenuGroup>
56
+ { isRemovable && (
57
+ <>
58
+ <RenameMenuItem
59
+ template={ template }
60
+ onClose={ onClose }
61
+ />
62
+ <DeleteMenuItem
63
+ onRemove={ () => {
64
+ removeTemplate( template );
65
+ onRemove?.();
66
+ onClose();
67
+ } }
68
+ title={ template.title.rendered }
69
+ />
70
+ </>
71
+ ) }
72
+ { isRevertable && (
73
+ <ResetMenuItem
74
+ template={ template }
75
+ onClose={ onClose }
76
+ />
77
+ ) }
78
+ </MenuGroup>
79
+ ) }
80
+ </DropdownMenu>
81
+ );
82
+ }
83
+
84
+ function ResetMenuItem( { template, onClose } ) {
85
+ const [ isModalOpen, setIsModalOpen ] = useState( false );
86
+ const { revertTemplate } = useDispatch( editSiteStore );
87
+ const { saveEditedEntityRecord } = useDispatch( coreStore );
88
+ const { createSuccessNotice, createErrorNotice } =
89
+ useDispatch( noticesStore );
50
90
  async function revertAndSaveTemplate() {
51
91
  try {
52
92
  await revertTemplate( template, { allowUndo: false } );
@@ -55,7 +95,6 @@ export default function TemplateActions( {
55
95
  template.type,
56
96
  template.id
57
97
  );
58
-
59
98
  createSuccessNotice(
60
99
  sprintf(
61
100
  /* translators: The template/part's name. */
@@ -82,48 +121,26 @@ export default function TemplateActions( {
82
121
  createErrorNotice( errorMessage, { type: 'snackbar' } );
83
122
  }
84
123
  }
85
-
86
124
  return (
87
- <DropdownMenu
88
- icon={ moreVertical }
89
- label={ __( 'Actions' ) }
90
- className={ className }
91
- toggleProps={ toggleProps }
92
- >
93
- { ( { onClose } ) => (
94
- <MenuGroup>
95
- { isRemovable && (
96
- <>
97
- <RenameMenuItem
98
- template={ template }
99
- onClose={ onClose }
100
- />
101
- <DeleteMenuItem
102
- onRemove={ () => {
103
- removeTemplate( template );
104
- onRemove?.();
105
- onClose();
106
- } }
107
- title={ template.title.rendered }
108
- />
109
- </>
110
- ) }
111
- { isRevertable && (
112
- <MenuItem
113
- info={ __(
114
- 'Use the template as supplied by the theme.'
115
- ) }
116
- onClick={ () => {
117
- revertAndSaveTemplate();
118
- onClose();
119
- } }
120
- >
121
- { __( 'Clear customizations' ) }
122
- </MenuItem>
123
- ) }
124
- </MenuGroup>
125
- ) }
126
- </DropdownMenu>
125
+ <>
126
+ <MenuItem
127
+ info={ __( 'Use the template as supplied by the theme.' ) }
128
+ onClick={ () => setIsModalOpen( true ) }
129
+ >
130
+ { __( 'Clear customizations' ) }
131
+ </MenuItem>
132
+ <ConfirmDialog
133
+ isOpen={ isModalOpen }
134
+ onConfirm={ () => {
135
+ revertAndSaveTemplate();
136
+ onClose();
137
+ } }
138
+ onCancel={ () => setIsModalOpen( false ) }
139
+ confirmButtonText={ __( 'Clear' ) }
140
+ >
141
+ { __( 'Are you sure you want to clear these customizations?' ) }
142
+ </ConfirmDialog>
143
+ </>
127
144
  );
128
145
  }
129
146
 
@@ -6,6 +6,7 @@ import { Guide } from '@wordpress/components';
6
6
  import { __ } from '@wordpress/i18n';
7
7
  import { createInterpolateElement } from '@wordpress/element';
8
8
  import { store as preferencesStore } from '@wordpress/preferences';
9
+ import { store as coreStore } from '@wordpress/core-data';
9
10
 
10
11
  /**
11
12
  * Internal dependencies
@@ -15,16 +16,18 @@ import WelcomeGuideImage from './image';
15
16
  export default function WelcomeGuideEditor() {
16
17
  const { toggle } = useDispatch( preferencesStore );
17
18
 
18
- const isActive = useSelect(
19
- ( select ) =>
20
- !! select( preferencesStore ).get(
19
+ const { isActive, isBlockBasedTheme } = useSelect( ( select ) => {
20
+ return {
21
+ isActive: !! select( preferencesStore ).get(
21
22
  'core/edit-site',
22
23
  'welcomeGuide'
23
24
  ),
24
- []
25
- );
25
+ isBlockBasedTheme:
26
+ select( coreStore ).getCurrentTheme()?.is_block_theme,
27
+ };
28
+ }, [] );
26
29
 
27
- if ( ! isActive ) {
30
+ if ( ! isActive || ! isBlockBasedTheme ) {
28
31
  return null;
29
32
  }
30
33
 
@@ -8,6 +8,7 @@ import { renderHook } from '@testing-library/react';
8
8
  */
9
9
  import useThemeStyleVariationsByProperty, {
10
10
  filterObjectByProperty,
11
+ removePropertyFromObject,
11
12
  } from '../use-theme-style-variations-by-property';
12
13
 
13
14
  describe( 'filterObjectByProperty', () => {
@@ -962,3 +963,175 @@ describe( 'useThemeStyleVariationsByProperty', () => {
962
963
  ] );
963
964
  } );
964
965
  } );
966
+
967
+ describe( 'removePropertyFromObject', () => {
968
+ const mockBaseVariation = {
969
+ settings: {
970
+ typography: {
971
+ fontFamilies: {
972
+ custom: [
973
+ {
974
+ name: 'ADLaM Display',
975
+ fontFamily: 'ADLaM Display, system-ui',
976
+ slug: 'adlam-display',
977
+ fontFace: [
978
+ {
979
+ src: 'adlam.woff2',
980
+ fontWeight: '400',
981
+ fontStyle: 'normal',
982
+ fontFamily: 'ADLaM Display',
983
+ },
984
+ ],
985
+ },
986
+ ],
987
+ },
988
+ fontSizes: [
989
+ {
990
+ name: 'Base small',
991
+ slug: 'base-small',
992
+ size: '1px',
993
+ },
994
+ {
995
+ name: 'Base medium',
996
+ slug: 'base-medium',
997
+ size: '2px',
998
+ },
999
+ {
1000
+ name: 'Base large',
1001
+ slug: 'base-large',
1002
+ size: '3px',
1003
+ },
1004
+ ],
1005
+ },
1006
+ color: {
1007
+ palette: {
1008
+ custom: [
1009
+ {
1010
+ color: '#c42727',
1011
+ name: 'Color 1',
1012
+ slug: 'custom-color-1',
1013
+ },
1014
+ {
1015
+ color: '#3b0f0f',
1016
+ name: 'Color 2',
1017
+ slug: 'custom-color-2',
1018
+ },
1019
+ ],
1020
+ },
1021
+ },
1022
+ layout: {
1023
+ wideSize: '1137px',
1024
+ contentSize: '400px',
1025
+ },
1026
+ },
1027
+ styles: {
1028
+ typography: {
1029
+ fontSize: '12px',
1030
+ lineHeight: '1.5',
1031
+ },
1032
+ color: {
1033
+ backgroundColor: 'cheese',
1034
+ color: 'lettuce',
1035
+ },
1036
+ elements: {
1037
+ cite: {
1038
+ color: {
1039
+ text: 'white',
1040
+ },
1041
+ typography: {
1042
+ letterSpacing: 'white',
1043
+ },
1044
+ },
1045
+ },
1046
+ blocks: {
1047
+ 'core/quote': {
1048
+ color: {
1049
+ text: 'hello',
1050
+ background: 'dolly',
1051
+ },
1052
+ typography: {
1053
+ fontSize: '111111px',
1054
+ },
1055
+ },
1056
+ 'core/group': {
1057
+ typography: {
1058
+ fontFamily: 'var:preset|font-family|system-sans-serif',
1059
+ },
1060
+ },
1061
+ },
1062
+ },
1063
+ };
1064
+
1065
+ it( 'should return with no property', () => {
1066
+ const object = { test: 'me' };
1067
+ expect( removePropertyFromObject( object, undefined ) ).toEqual(
1068
+ object
1069
+ );
1070
+ } );
1071
+
1072
+ it( 'should return with non-string property', () => {
1073
+ const object = { test: 'you' };
1074
+ expect( removePropertyFromObject( object, true ) ).toEqual( object );
1075
+ } );
1076
+
1077
+ it( 'should return with empty object', () => {
1078
+ const object = {};
1079
+ expect( removePropertyFromObject( object, 'color' ) ).toEqual( object );
1080
+ } );
1081
+
1082
+ it( 'should remove the specified property from the object', () => {
1083
+ expect(
1084
+ removePropertyFromObject(
1085
+ {
1086
+ ...mockBaseVariation,
1087
+ },
1088
+ 'typography'
1089
+ )
1090
+ ).toEqual( {
1091
+ settings: {
1092
+ color: {
1093
+ palette: {
1094
+ custom: [
1095
+ {
1096
+ color: '#c42727',
1097
+ name: 'Color 1',
1098
+ slug: 'custom-color-1',
1099
+ },
1100
+ {
1101
+ color: '#3b0f0f',
1102
+ name: 'Color 2',
1103
+ slug: 'custom-color-2',
1104
+ },
1105
+ ],
1106
+ },
1107
+ },
1108
+ layout: {
1109
+ wideSize: '1137px',
1110
+ contentSize: '400px',
1111
+ },
1112
+ },
1113
+ styles: {
1114
+ color: {
1115
+ backgroundColor: 'cheese',
1116
+ color: 'lettuce',
1117
+ },
1118
+ elements: {
1119
+ cite: {
1120
+ color: {
1121
+ text: 'white',
1122
+ },
1123
+ },
1124
+ },
1125
+ blocks: {
1126
+ 'core/quote': {
1127
+ color: {
1128
+ text: 'hello',
1129
+ background: 'dolly',
1130
+ },
1131
+ },
1132
+ 'core/group': {},
1133
+ },
1134
+ },
1135
+ } );
1136
+ } );
1137
+ } );
@@ -1,13 +1,93 @@
1
1
  /**
2
2
  * WordPress dependencies
3
3
  */
4
- import { useMemo } from '@wordpress/element';
4
+ import { useSelect } from '@wordpress/data';
5
+ import { store as coreStore } from '@wordpress/core-data';
6
+ import { useContext, useMemo } from '@wordpress/element';
7
+ import { privateApis as blockEditorPrivateApis } from '@wordpress/block-editor';
8
+ import { __ } from '@wordpress/i18n';
5
9
 
6
10
  /**
7
11
  * Internal dependencies
8
12
  */
9
13
  import { mergeBaseAndUserConfigs } from '../../components/global-styles/global-styles-provider';
10
14
  import cloneDeep from '../../utils/clone-deep';
15
+ import { unlock } from '../../lock-unlock';
16
+
17
+ const { GlobalStylesContext } = unlock( blockEditorPrivateApis );
18
+
19
+ /**
20
+ * Removes all instances of a property from an object.
21
+ *
22
+ * @param {Object} object The object to remove the property from.
23
+ * @param {string} property The property to remove.
24
+ * @return {Object} The modified object.
25
+ */
26
+ export function removePropertyFromObject( object, property ) {
27
+ if ( ! property || typeof property !== 'string' ) {
28
+ return object;
29
+ }
30
+
31
+ if ( typeof object !== 'object' || ! Object.keys( object ).length ) {
32
+ return object;
33
+ }
34
+
35
+ for ( const key in object ) {
36
+ if ( key === property ) {
37
+ delete object[ key ];
38
+ } else if ( typeof object[ key ] === 'object' ) {
39
+ removePropertyFromObject( object[ key ], property );
40
+ }
41
+ }
42
+ return object;
43
+ }
44
+
45
+ /**
46
+ * A convenience wrapper for `useThemeStyleVariationsByProperty()` that fetches the current theme style variations,
47
+ * and user-defined global style/settings object.
48
+ *
49
+ * @param {Object} props Object of hook args.
50
+ * @param {string} props.property The property to filter by.
51
+ * @param {Function} props.filter Optional. The filter function to apply to the variations.
52
+ * @return {Object[]|*} The merged object.
53
+ */
54
+ export function useCurrentMergeThemeStyleVariationsWithUserConfig( {
55
+ property,
56
+ filter,
57
+ } ) {
58
+ const { variationsFromTheme } = useSelect( ( select ) => {
59
+ const _variationsFromTheme =
60
+ select(
61
+ coreStore
62
+ ).__experimentalGetCurrentThemeGlobalStylesVariations();
63
+
64
+ return {
65
+ variationsFromTheme: _variationsFromTheme || [],
66
+ };
67
+ }, [] );
68
+ const { user: baseVariation } = useContext( GlobalStylesContext );
69
+
70
+ const variations = useMemo( () => {
71
+ return [
72
+ {
73
+ title: __( 'Default' ),
74
+ settings: {},
75
+ styles: {},
76
+ },
77
+ ...variationsFromTheme,
78
+ ];
79
+ }, [ variationsFromTheme ] );
80
+
81
+ return useThemeStyleVariationsByProperty( {
82
+ variations,
83
+ property,
84
+ filter,
85
+ baseVariation: removePropertyFromObject(
86
+ cloneDeep( baseVariation ),
87
+ property
88
+ ),
89
+ } );
90
+ }
11
91
 
12
92
  /**
13
93
  * Returns a new object, with properties specified in `property`,
@@ -40,6 +120,10 @@ export const filterObjectByProperty = ( object, property ) => {
40
120
 
41
121
  /**
42
122
  * Returns a new object with only the properties specified in `property`.
123
+ * Optional merges the baseVariation object with the variation object.
124
+ * Note: this function will only overwrite the specified property in baseVariation if it exists.
125
+ * The baseVariation will not be otherwise modified. To strip a property from the baseVariation object, use `removePropertyFromObject`.
126
+ * See useCurrentMergeThemeStyleVariationsWithUserConfig for an example of how to use this function.
43
127
  *
44
128
  * @param {Object} props Object of hook args.
45
129
  * @param {Object[]} props.variations The theme style variations to filter.
package/src/style.scss CHANGED
@@ -8,7 +8,6 @@
8
8
  @import "./components/global-styles/style.scss";
9
9
  @import "./components/global-styles/screen-revisions/style.scss";
10
10
  @import "./components/header-edit-mode/style.scss";
11
- @import "./components/list/style.scss";
12
11
  @import "./components/page/style.scss";
13
12
  @import "./components/page-pages/style.scss";
14
13
  @import "./components/page-patterns/style.scss";
@@ -34,7 +33,6 @@
34
33
  @import "./components/sidebar-navigation-screen-details-footer/style.scss";
35
34
  @import "./components/sidebar-navigation-screen-navigation-menu/style.scss";
36
35
  @import "./components/sidebar-navigation-screen-page/style.scss";
37
- @import "./components/sidebar-navigation-screen-templates/style.scss";
38
36
  @import "components/sidebar-navigation-screen-details-panel/style.scss";
39
37
  @import "./components/sidebar-navigation-screen-pattern/style.scss";
40
38
  @import "./components/sidebar-navigation-screen-patterns/style.scss";
@@ -49,6 +47,7 @@
49
47
  @import "./hooks/push-changes-to-global-styles/style.scss";
50
48
  @import "./components/global-styles/font-library-modal/style.scss";
51
49
  @import "./components/pagination/style.scss";
50
+ @import "./components/global-styles/variations/style.scss";
52
51
 
53
52
  body.js #wpadminbar {
54
53
  display: none;
@@ -98,7 +97,7 @@ body.js.site-editor-php {
98
97
  }
99
98
 
100
99
  .interface-interface-skeleton__content {
101
- background-color: $gray-900;
100
+ background-color: $gray-300;
102
101
  }
103
102
  }
104
103
 
@@ -50,5 +50,7 @@ export const LAYOUT_GRID = 'grid';
50
50
  export const LAYOUT_TABLE = 'table';
51
51
  export const LAYOUT_LIST = 'list';
52
52
  export const ENUMERATION_TYPE = 'enumeration';
53
- export const OPERATOR_IN = 'in';
54
- export const OPERATOR_NOT_IN = 'notIn';
53
+ export const OPERATOR_IS = 'is';
54
+ export const OPERATOR_IS_NOT = 'isNot';
55
+ export const OPERATOR_IS_ANY = 'isAny';
56
+ export const OPERATOR_IS_NONE = 'isNone';
@@ -14,7 +14,7 @@ export default function getIsListPage(
14
14
  isMobileViewport
15
15
  ) {
16
16
  return (
17
- [ '/wp_template/all', '/wp_template_part/all', '/pages' ].includes(
17
+ [ '/wp_template', '/wp_template_part/all', '/pages' ].includes(
18
18
  path
19
19
  ) ||
20
20
  ( path === '/patterns' &&