@wordpress/edit-site 5.18.0 → 5.19.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 (427) hide show
  1. package/CHANGELOG.md +2 -0
  2. package/build/components/add-new-pattern/index.js +62 -1
  3. package/build/components/add-new-pattern/index.js.map +1 -1
  4. package/build/components/add-new-template/index.js +3 -2
  5. package/build/components/add-new-template/index.js.map +1 -1
  6. package/build/components/add-new-template/new-template.js +6 -1
  7. package/build/components/add-new-template/new-template.js.map +1 -1
  8. package/build/components/add-new-template/utils.js +6 -1
  9. package/build/components/add-new-template/utils.js.map +1 -1
  10. package/build/components/app/index.js +2 -7
  11. package/build/components/app/index.js.map +1 -1
  12. package/build/components/block-editor/back-button.js +3 -2
  13. package/build/components/block-editor/back-button.js.map +1 -1
  14. package/build/components/block-editor/editor-canvas.js +20 -16
  15. package/build/components/block-editor/editor-canvas.js.map +1 -1
  16. package/build/components/block-editor/site-editor-canvas.js +1 -3
  17. package/build/components/block-editor/site-editor-canvas.js.map +1 -1
  18. package/build/components/block-editor/use-site-editor-settings.js +8 -4
  19. package/build/components/block-editor/use-site-editor-settings.js.map +1 -1
  20. package/build/components/canvas-loader/index.js +18 -1
  21. package/build/components/canvas-loader/index.js.map +1 -1
  22. package/build/components/editor/index.js +3 -8
  23. package/build/components/editor/index.js.map +1 -1
  24. package/build/components/global-styles/dimensions-panel.js +5 -4
  25. package/build/components/global-styles/dimensions-panel.js.map +1 -1
  26. package/build/components/global-styles/font-families.js +68 -0
  27. package/build/components/global-styles/font-families.js.map +1 -0
  28. package/build/components/global-styles/font-family-item.js +47 -0
  29. package/build/components/global-styles/font-family-item.js.map +1 -0
  30. package/build/components/global-styles/font-library-modal/confirm-delete-dialog.js +31 -0
  31. package/build/components/global-styles/font-library-modal/confirm-delete-dialog.js.map +1 -0
  32. package/build/components/global-styles/font-library-modal/context.js +285 -0
  33. package/build/components/global-styles/font-library-modal/context.js.map +1 -0
  34. package/build/components/global-styles/font-library-modal/font-card.js +58 -0
  35. package/build/components/global-styles/font-library-modal/font-card.js.map +1 -0
  36. package/build/components/global-styles/font-library-modal/font-demo.js +69 -0
  37. package/build/components/global-styles/font-library-modal/font-demo.js.map +1 -0
  38. package/build/components/global-styles/font-library-modal/font-variant.js +51 -0
  39. package/build/components/global-styles/font-library-modal/font-variant.js.map +1 -0
  40. package/build/components/global-styles/font-library-modal/fonts-grid.js +54 -0
  41. package/build/components/global-styles/font-library-modal/fonts-grid.js.map +1 -0
  42. package/build/components/global-styles/font-library-modal/index.js +47 -0
  43. package/build/components/global-styles/font-library-modal/index.js.map +1 -0
  44. package/build/components/global-styles/font-library-modal/installed-fonts.js +128 -0
  45. package/build/components/global-styles/font-library-modal/installed-fonts.js.map +1 -0
  46. package/build/components/global-styles/font-library-modal/library-font-card.js +44 -0
  47. package/build/components/global-styles/font-library-modal/library-font-card.js.map +1 -0
  48. package/build/components/global-styles/font-library-modal/library-font-details.js +43 -0
  49. package/build/components/global-styles/font-library-modal/library-font-details.js.map +1 -0
  50. package/build/components/global-styles/font-library-modal/library-font-variant.js +59 -0
  51. package/build/components/global-styles/font-library-modal/library-font-variant.js.map +1 -0
  52. package/build/components/global-styles/font-library-modal/local-fonts.js +143 -0
  53. package/build/components/global-styles/font-library-modal/local-fonts.js.map +1 -0
  54. package/build/components/global-styles/font-library-modal/resolvers.js +37 -0
  55. package/build/components/global-styles/font-library-modal/resolvers.js.map +1 -0
  56. package/build/components/global-styles/font-library-modal/tab-layout.js +45 -0
  57. package/build/components/global-styles/font-library-modal/tab-layout.js.map +1 -0
  58. package/build/components/global-styles/font-library-modal/utils/constants.js +37 -0
  59. package/build/components/global-styles/font-library-modal/utils/constants.js.map +1 -0
  60. package/build/components/global-styles/font-library-modal/utils/get-intersecting-font-faces.js +58 -0
  61. package/build/components/global-styles/font-library-modal/utils/get-intersecting-font-faces.js.map +1 -0
  62. package/build/components/global-styles/font-library-modal/utils/index.js +205 -0
  63. package/build/components/global-styles/font-library-modal/utils/index.js.map +1 -0
  64. package/build/components/global-styles/font-library-modal/utils/make-families-from-faces.js +22 -0
  65. package/build/components/global-styles/font-library-modal/utils/make-families-from-faces.js.map +1 -0
  66. package/build/components/global-styles/font-library-modal/utils/toggleFont.js +92 -0
  67. package/build/components/global-styles/font-library-modal/utils/toggleFont.js.map +1 -0
  68. package/build/components/global-styles/global-styles-provider.js +7 -12
  69. package/build/components/global-styles/global-styles-provider.js.map +1 -1
  70. package/build/components/global-styles/screen-block.js +34 -21
  71. package/build/components/global-styles/screen-block.js.map +1 -1
  72. package/build/components/global-styles/screen-revisions/index.js +1 -3
  73. package/build/components/global-styles/screen-revisions/index.js.map +1 -1
  74. package/build/components/global-styles/screen-revisions/use-global-styles-revisions.js +0 -1
  75. package/build/components/global-styles/screen-revisions/use-global-styles-revisions.js.map +1 -1
  76. package/build/components/global-styles/screen-typography.js +4 -72
  77. package/build/components/global-styles/screen-typography.js.map +1 -1
  78. package/build/components/global-styles/style-variations-container.js +3 -5
  79. package/build/components/global-styles/style-variations-container.js.map +1 -1
  80. package/build/components/global-styles/typogrphy-elements.js +96 -0
  81. package/build/components/global-styles/typogrphy-elements.js.map +1 -0
  82. package/build/components/page-patterns/duplicate-menu-item.js +52 -16
  83. package/build/components/page-patterns/duplicate-menu-item.js.map +1 -1
  84. package/build/components/page-patterns/grid-item.js +46 -20
  85. package/build/components/page-patterns/grid-item.js.map +1 -1
  86. package/build/components/page-patterns/header.js +3 -7
  87. package/build/components/page-patterns/header.js.map +1 -1
  88. package/build/components/page-patterns/index.js +3 -3
  89. package/build/components/page-patterns/index.js.map +1 -1
  90. package/build/components/page-patterns/patterns-list.js +7 -7
  91. package/build/components/page-patterns/patterns-list.js.map +1 -1
  92. package/build/components/page-patterns/rename-menu-item.js +6 -5
  93. package/build/components/page-patterns/rename-menu-item.js.map +1 -1
  94. package/build/components/page-patterns/search-items.js +8 -2
  95. package/build/components/page-patterns/search-items.js.map +1 -1
  96. package/build/components/page-patterns/use-patterns.js +53 -27
  97. package/build/components/page-patterns/use-patterns.js.map +1 -1
  98. package/build/components/page-patterns/utils.js +1 -20
  99. package/build/components/page-patterns/utils.js.map +1 -1
  100. package/build/components/sidebar-edit-mode/page-panels/edit-template.js +33 -24
  101. package/build/components/sidebar-edit-mode/page-panels/edit-template.js.map +1 -1
  102. package/build/components/sidebar-edit-mode/page-panels/hooks.js +64 -0
  103. package/build/components/sidebar-edit-mode/page-panels/hooks.js.map +1 -0
  104. package/build/components/sidebar-edit-mode/page-panels/index.js +1 -4
  105. package/build/components/sidebar-edit-mode/page-panels/index.js.map +1 -1
  106. package/build/components/sidebar-edit-mode/page-panels/page-summary.js +2 -1
  107. package/build/components/sidebar-edit-mode/page-panels/page-summary.js.map +1 -1
  108. package/build/components/sidebar-edit-mode/page-panels/reset-default-template.js +56 -0
  109. package/build/components/sidebar-edit-mode/page-panels/reset-default-template.js.map +1 -0
  110. package/build/components/sidebar-edit-mode/page-panels/swap-template-button.js +91 -0
  111. package/build/components/sidebar-edit-mode/page-panels/swap-template-button.js.map +1 -0
  112. package/build/components/sidebar-edit-mode/template-panel/index.js +11 -9
  113. package/build/components/sidebar-edit-mode/template-panel/index.js.map +1 -1
  114. package/build/components/sidebar-edit-mode/template-panel/last-revision.js +6 -4
  115. package/build/components/sidebar-edit-mode/template-panel/last-revision.js.map +1 -1
  116. package/build/components/sidebar-edit-mode/template-panel/pattern-categories.js +211 -0
  117. package/build/components/sidebar-edit-mode/template-panel/pattern-categories.js.map +1 -0
  118. package/build/components/sidebar-navigation-screen/index.js +6 -4
  119. package/build/components/sidebar-navigation-screen/index.js.map +1 -1
  120. package/build/components/sidebar-navigation-screen-details-footer/index.js +32 -4
  121. package/build/components/sidebar-navigation-screen-details-footer/index.js.map +1 -1
  122. package/build/components/sidebar-navigation-screen-details-panel/sidebar-navigation-screen-details-panel-row.js +4 -2
  123. package/build/components/sidebar-navigation-screen-details-panel/sidebar-navigation-screen-details-panel-row.js.map +1 -1
  124. package/build/components/sidebar-navigation-screen-global-styles/index.js +4 -31
  125. package/build/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  126. package/build/components/sidebar-navigation-screen-page/index.js +3 -3
  127. package/build/components/sidebar-navigation-screen-page/index.js.map +1 -1
  128. package/build/components/sidebar-navigation-screen-pattern/index.js +18 -8
  129. package/build/components/sidebar-navigation-screen-pattern/index.js.map +1 -1
  130. package/build/components/sidebar-navigation-screen-pattern/use-pattern-details.js +34 -5
  131. package/build/components/sidebar-navigation-screen-pattern/use-pattern-details.js.map +1 -1
  132. package/build/components/sidebar-navigation-screen-patterns/index.js +7 -35
  133. package/build/components/sidebar-navigation-screen-patterns/index.js.map +1 -1
  134. package/build/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +38 -4
  135. package/build/components/sidebar-navigation-screen-patterns/use-pattern-categories.js.map +1 -1
  136. package/build/components/sidebar-navigation-screen-patterns/use-theme-patterns.js +2 -1
  137. package/build/components/sidebar-navigation-screen-patterns/use-theme-patterns.js.map +1 -1
  138. package/build/components/sidebar-navigation-screen-template/index.js +2 -2
  139. package/build/components/sidebar-navigation-screen-template/index.js.map +1 -1
  140. package/build/components/sidebar-navigation-screen-templates/index.js +1 -1
  141. package/build/components/sidebar-navigation-screen-templates/index.js.map +1 -1
  142. package/build/components/template-actions/index.js +7 -4
  143. package/build/components/template-actions/index.js.map +1 -1
  144. package/build/components/template-actions/rename-menu-item.js +3 -2
  145. package/build/components/template-actions/rename-menu-item.js.map +1 -1
  146. package/build/components/welcome-guide/styles.js +2 -2
  147. package/build/components/welcome-guide/styles.js.map +1 -1
  148. package/build/hooks/push-changes-to-global-styles/index.js +5 -37
  149. package/build/hooks/push-changes-to-global-styles/index.js.map +1 -1
  150. package/build/store/actions.js +29 -6
  151. package/build/store/actions.js.map +1 -1
  152. package/build/utils/constants.js +45 -2
  153. package/build/utils/constants.js.map +1 -1
  154. package/build/utils/is-template-removable.js +6 -1
  155. package/build/utils/is-template-removable.js.map +1 -1
  156. package/build/utils/is-template-revertable.js +6 -1
  157. package/build/utils/is-template-revertable.js.map +1 -1
  158. package/build-module/components/add-new-pattern/index.js +66 -5
  159. package/build-module/components/add-new-pattern/index.js.map +1 -1
  160. package/build-module/components/add-new-template/index.js +3 -2
  161. package/build-module/components/add-new-template/index.js.map +1 -1
  162. package/build-module/components/add-new-template/new-template.js +6 -1
  163. package/build-module/components/add-new-template/new-template.js.map +1 -1
  164. package/build-module/components/add-new-template/utils.js +6 -1
  165. package/build-module/components/add-new-template/utils.js.map +1 -1
  166. package/build-module/components/app/index.js +2 -7
  167. package/build-module/components/app/index.js.map +1 -1
  168. package/build-module/components/block-editor/back-button.js +3 -2
  169. package/build-module/components/block-editor/back-button.js.map +1 -1
  170. package/build-module/components/block-editor/editor-canvas.js +21 -17
  171. package/build-module/components/block-editor/editor-canvas.js.map +1 -1
  172. package/build-module/components/block-editor/site-editor-canvas.js +3 -5
  173. package/build-module/components/block-editor/site-editor-canvas.js.map +1 -1
  174. package/build-module/components/block-editor/use-site-editor-settings.js +8 -4
  175. package/build-module/components/block-editor/use-site-editor-settings.js.map +1 -1
  176. package/build-module/components/canvas-loader/index.js +18 -1
  177. package/build-module/components/canvas-loader/index.js.map +1 -1
  178. package/build-module/components/editor/index.js +3 -8
  179. package/build-module/components/editor/index.js.map +1 -1
  180. package/build-module/components/global-styles/dimensions-panel.js +5 -4
  181. package/build-module/components/global-styles/dimensions-panel.js.map +1 -1
  182. package/build-module/components/global-styles/font-families.js +58 -0
  183. package/build-module/components/global-styles/font-families.js.map +1 -0
  184. package/build-module/components/global-styles/font-family-item.js +40 -0
  185. package/build-module/components/global-styles/font-family-item.js.map +1 -0
  186. package/build-module/components/global-styles/font-library-modal/confirm-delete-dialog.js +23 -0
  187. package/build-module/components/global-styles/font-library-modal/confirm-delete-dialog.js.map +1 -0
  188. package/build-module/components/global-styles/font-library-modal/context.js +276 -0
  189. package/build-module/components/global-styles/font-library-modal/context.js.map +1 -0
  190. package/build-module/components/global-styles/font-library-modal/font-card.js +49 -0
  191. package/build-module/components/global-styles/font-library-modal/font-card.js.map +1 -0
  192. package/build-module/components/global-styles/font-library-modal/font-demo.js +62 -0
  193. package/build-module/components/global-styles/font-library-modal/font-demo.js.map +1 -0
  194. package/build-module/components/global-styles/font-library-modal/font-variant.js +42 -0
  195. package/build-module/components/global-styles/font-library-modal/font-variant.js.map +1 -0
  196. package/build-module/components/global-styles/font-library-modal/fonts-grid.js +47 -0
  197. package/build-module/components/global-styles/font-library-modal/fonts-grid.js.map +1 -0
  198. package/build-module/components/global-styles/font-library-modal/index.js +38 -0
  199. package/build-module/components/global-styles/font-library-modal/index.js.map +1 -0
  200. package/build-module/components/global-styles/font-library-modal/installed-fonts.js +120 -0
  201. package/build-module/components/global-styles/font-library-modal/installed-fonts.js.map +1 -0
  202. package/build-module/components/global-styles/font-library-modal/library-font-card.js +36 -0
  203. package/build-module/components/global-styles/font-library-modal/library-font-card.js.map +1 -0
  204. package/build-module/components/global-styles/font-library-modal/library-font-details.js +34 -0
  205. package/build-module/components/global-styles/font-library-modal/library-font-details.js.map +1 -0
  206. package/build-module/components/global-styles/font-library-modal/library-font-variant.js +50 -0
  207. package/build-module/components/global-styles/font-library-modal/library-font-variant.js.map +1 -0
  208. package/build-module/components/global-styles/font-library-modal/local-fonts.js +135 -0
  209. package/build-module/components/global-styles/font-library-modal/local-fonts.js.map +1 -0
  210. package/build-module/components/global-styles/font-library-modal/resolvers.js +28 -0
  211. package/build-module/components/global-styles/font-library-modal/resolvers.js.map +1 -0
  212. package/build-module/components/global-styles/font-library-modal/tab-layout.js +37 -0
  213. package/build-module/components/global-styles/font-library-modal/tab-layout.js.map +1 -0
  214. package/build-module/components/global-styles/font-library-modal/utils/constants.js +26 -0
  215. package/build-module/components/global-styles/font-library-modal/utils/constants.js.map +1 -0
  216. package/build-module/components/global-styles/font-library-modal/utils/get-intersecting-font-faces.js +52 -0
  217. package/build-module/components/global-styles/font-library-modal/utils/get-intersecting-font-faces.js.map +1 -0
  218. package/build-module/components/global-styles/font-library-modal/utils/index.js +190 -0
  219. package/build-module/components/global-styles/font-library-modal/utils/index.js.map +1 -0
  220. package/build-module/components/global-styles/font-library-modal/utils/make-families-from-faces.js +16 -0
  221. package/build-module/components/global-styles/font-library-modal/utils/make-families-from-faces.js.map +1 -0
  222. package/build-module/components/global-styles/font-library-modal/utils/toggleFont.js +86 -0
  223. package/build-module/components/global-styles/font-library-modal/utils/toggleFont.js.map +1 -0
  224. package/build-module/components/global-styles/global-styles-provider.js +7 -12
  225. package/build-module/components/global-styles/global-styles-provider.js.map +1 -1
  226. package/build-module/components/global-styles/screen-block.js +34 -21
  227. package/build-module/components/global-styles/screen-block.js.map +1 -1
  228. package/build-module/components/global-styles/screen-revisions/index.js +1 -3
  229. package/build-module/components/global-styles/screen-revisions/index.js.map +1 -1
  230. package/build-module/components/global-styles/screen-revisions/use-global-styles-revisions.js +0 -1
  231. package/build-module/components/global-styles/screen-revisions/use-global-styles-revisions.js.map +1 -1
  232. package/build-module/components/global-styles/screen-typography.js +6 -74
  233. package/build-module/components/global-styles/screen-typography.js.map +1 -1
  234. package/build-module/components/global-styles/style-variations-container.js +3 -5
  235. package/build-module/components/global-styles/style-variations-container.js.map +1 -1
  236. package/build-module/components/global-styles/typogrphy-elements.js +87 -0
  237. package/build-module/components/global-styles/typogrphy-elements.js.map +1 -0
  238. package/build-module/components/page-patterns/duplicate-menu-item.js +51 -16
  239. package/build-module/components/page-patterns/duplicate-menu-item.js.map +1 -1
  240. package/build-module/components/page-patterns/grid-item.js +47 -21
  241. package/build-module/components/page-patterns/grid-item.js.map +1 -1
  242. package/build-module/components/page-patterns/header.js +3 -7
  243. package/build-module/components/page-patterns/header.js.map +1 -1
  244. package/build-module/components/page-patterns/index.js +3 -3
  245. package/build-module/components/page-patterns/index.js.map +1 -1
  246. package/build-module/components/page-patterns/patterns-list.js +7 -7
  247. package/build-module/components/page-patterns/patterns-list.js.map +1 -1
  248. package/build-module/components/page-patterns/rename-menu-item.js +6 -5
  249. package/build-module/components/page-patterns/rename-menu-item.js.map +1 -1
  250. package/build-module/components/page-patterns/search-items.js +8 -2
  251. package/build-module/components/page-patterns/search-items.js.map +1 -1
  252. package/build-module/components/page-patterns/use-patterns.js +54 -28
  253. package/build-module/components/page-patterns/use-patterns.js.map +1 -1
  254. package/build-module/components/page-patterns/utils.js +0 -11
  255. package/build-module/components/page-patterns/utils.js.map +1 -1
  256. package/build-module/components/sidebar-edit-mode/page-panels/edit-template.js +34 -27
  257. package/build-module/components/sidebar-edit-mode/page-panels/edit-template.js.map +1 -1
  258. package/build-module/components/sidebar-edit-mode/page-panels/hooks.js +54 -0
  259. package/build-module/components/sidebar-edit-mode/page-panels/hooks.js.map +1 -0
  260. package/build-module/components/sidebar-edit-mode/page-panels/index.js +1 -4
  261. package/build-module/components/sidebar-edit-mode/page-panels/index.js.map +1 -1
  262. package/build-module/components/sidebar-edit-mode/page-panels/page-summary.js +2 -1
  263. package/build-module/components/sidebar-edit-mode/page-panels/page-summary.js.map +1 -1
  264. package/build-module/components/sidebar-edit-mode/page-panels/reset-default-template.js +49 -0
  265. package/build-module/components/sidebar-edit-mode/page-panels/reset-default-template.js.map +1 -0
  266. package/build-module/components/sidebar-edit-mode/page-panels/swap-template-button.js +85 -0
  267. package/build-module/components/sidebar-edit-mode/page-panels/swap-template-button.js.map +1 -0
  268. package/build-module/components/sidebar-edit-mode/template-panel/index.js +12 -10
  269. package/build-module/components/sidebar-edit-mode/template-panel/index.js.map +1 -1
  270. package/build-module/components/sidebar-edit-mode/template-panel/last-revision.js +8 -6
  271. package/build-module/components/sidebar-edit-mode/template-panel/last-revision.js.map +1 -1
  272. package/build-module/components/sidebar-edit-mode/template-panel/pattern-categories.js +202 -0
  273. package/build-module/components/sidebar-edit-mode/template-panel/pattern-categories.js.map +1 -0
  274. package/build-module/components/sidebar-navigation-screen/index.js +6 -4
  275. package/build-module/components/sidebar-navigation-screen/index.js.map +1 -1
  276. package/build-module/components/sidebar-navigation-screen-details-footer/index.js +32 -5
  277. package/build-module/components/sidebar-navigation-screen-details-footer/index.js.map +1 -1
  278. package/build-module/components/sidebar-navigation-screen-details-panel/sidebar-navigation-screen-details-panel-row.js +4 -2
  279. package/build-module/components/sidebar-navigation-screen-details-panel/sidebar-navigation-screen-details-panel-row.js.map +1 -1
  280. package/build-module/components/sidebar-navigation-screen-global-styles/index.js +6 -33
  281. package/build-module/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  282. package/build-module/components/sidebar-navigation-screen-page/index.js +3 -3
  283. package/build-module/components/sidebar-navigation-screen-page/index.js.map +1 -1
  284. package/build-module/components/sidebar-navigation-screen-pattern/index.js +19 -9
  285. package/build-module/components/sidebar-navigation-screen-pattern/index.js.map +1 -1
  286. package/build-module/components/sidebar-navigation-screen-pattern/use-pattern-details.js +34 -5
  287. package/build-module/components/sidebar-navigation-screen-pattern/use-pattern-details.js.map +1 -1
  288. package/build-module/components/sidebar-navigation-screen-patterns/index.js +10 -38
  289. package/build-module/components/sidebar-navigation-screen-patterns/index.js.map +1 -1
  290. package/build-module/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +38 -4
  291. package/build-module/components/sidebar-navigation-screen-patterns/use-pattern-categories.js.map +1 -1
  292. package/build-module/components/sidebar-navigation-screen-patterns/use-theme-patterns.js +3 -2
  293. package/build-module/components/sidebar-navigation-screen-patterns/use-theme-patterns.js.map +1 -1
  294. package/build-module/components/sidebar-navigation-screen-template/index.js +2 -2
  295. package/build-module/components/sidebar-navigation-screen-template/index.js.map +1 -1
  296. package/build-module/components/sidebar-navigation-screen-templates/index.js +1 -1
  297. package/build-module/components/sidebar-navigation-screen-templates/index.js.map +1 -1
  298. package/build-module/components/template-actions/index.js +7 -4
  299. package/build-module/components/template-actions/index.js.map +1 -1
  300. package/build-module/components/template-actions/rename-menu-item.js +3 -2
  301. package/build-module/components/template-actions/rename-menu-item.js.map +1 -1
  302. package/build-module/components/welcome-guide/styles.js +2 -2
  303. package/build-module/components/welcome-guide/styles.js.map +1 -1
  304. package/build-module/hooks/push-changes-to-global-styles/index.js +5 -37
  305. package/build-module/hooks/push-changes-to-global-styles/index.js.map +1 -1
  306. package/build-module/store/actions.js +30 -7
  307. package/build-module/store/actions.js.map +1 -1
  308. package/build-module/utils/constants.js +35 -1
  309. package/build-module/utils/constants.js.map +1 -1
  310. package/build-module/utils/is-template-removable.js +6 -1
  311. package/build-module/utils/is-template-removable.js.map +1 -1
  312. package/build-module/utils/is-template-revertable.js +6 -1
  313. package/build-module/utils/is-template-revertable.js.map +1 -1
  314. package/build-style/style-rtl.css +244 -37
  315. package/build-style/style.css +244 -37
  316. package/lib/inflate.js +4082 -0
  317. package/lib/lib-font.browser.js +3831 -0
  318. package/lib/unbrotli.js +2679 -0
  319. package/package.json +40 -40
  320. package/src/components/add-new-pattern/index.js +83 -5
  321. package/src/components/add-new-template/index.js +3 -2
  322. package/src/components/add-new-template/new-template.js +6 -1
  323. package/src/components/add-new-template/utils.js +12 -3
  324. package/src/components/app/index.js +9 -12
  325. package/src/components/block-editor/back-button.js +6 -2
  326. package/src/components/block-editor/editor-canvas.js +31 -19
  327. package/src/components/block-editor/site-editor-canvas.js +2 -10
  328. package/src/components/block-editor/style.scss +88 -1
  329. package/src/components/block-editor/use-site-editor-settings.js +26 -19
  330. package/src/components/canvas-loader/index.js +12 -1
  331. package/src/components/canvas-loader/style.scss +1 -1
  332. package/src/components/editor/index.js +3 -8
  333. package/src/components/global-styles/dimensions-panel.js +8 -4
  334. package/src/components/global-styles/font-families.js +71 -0
  335. package/src/components/global-styles/font-family-item.js +44 -0
  336. package/src/components/global-styles/font-library-modal/confirm-delete-dialog.js +33 -0
  337. package/src/components/global-styles/font-library-modal/context.js +347 -0
  338. package/src/components/global-styles/font-library-modal/font-card.js +70 -0
  339. package/src/components/global-styles/font-library-modal/font-demo.js +57 -0
  340. package/src/components/global-styles/font-library-modal/font-variant.js +53 -0
  341. package/src/components/global-styles/font-library-modal/fonts-grid.js +55 -0
  342. package/src/components/global-styles/font-library-modal/index.js +42 -0
  343. package/src/components/global-styles/font-library-modal/installed-fonts.js +174 -0
  344. package/src/components/global-styles/font-library-modal/library-font-card.js +40 -0
  345. package/src/components/global-styles/font-library-modal/library-font-details.js +46 -0
  346. package/src/components/global-styles/font-library-modal/library-font-variant.js +54 -0
  347. package/src/components/global-styles/font-library-modal/local-fonts.js +160 -0
  348. package/src/components/global-styles/font-library-modal/resolvers.js +29 -0
  349. package/src/components/global-styles/font-library-modal/style.scss +113 -0
  350. package/src/components/global-styles/font-library-modal/tab-layout.js +50 -0
  351. package/src/components/global-styles/font-library-modal/utils/constants.js +31 -0
  352. package/src/components/global-styles/font-library-modal/utils/get-intersecting-font-faces.js +58 -0
  353. package/src/components/global-styles/font-library-modal/utils/index.js +213 -0
  354. package/src/components/global-styles/font-library-modal/utils/make-families-from-faces.js +15 -0
  355. package/src/components/global-styles/font-library-modal/utils/test/getDisplaySrcFromFontFace.spec.js +53 -0
  356. package/src/components/global-styles/font-library-modal/utils/test/getFontFaceVariantName.spec.js +30 -0
  357. package/src/components/global-styles/font-library-modal/utils/test/getIntersectingFontFaces.spec.js +240 -0
  358. package/src/components/global-styles/font-library-modal/utils/test/getPreviewStyle.spec.js +121 -0
  359. package/src/components/global-styles/font-library-modal/utils/test/isUrlEncoded.spec.js +31 -0
  360. package/src/components/global-styles/font-library-modal/utils/test/makeFamiliesFromFaces.spec.js +57 -0
  361. package/src/components/global-styles/font-library-modal/utils/test/makeFormDataFromFontFamilies.spec.js +62 -0
  362. package/src/components/global-styles/font-library-modal/utils/test/mergeFontFaces.spec.js +56 -0
  363. package/src/components/global-styles/font-library-modal/utils/test/mergeFontFamilies.spec.js +108 -0
  364. package/src/components/global-styles/font-library-modal/utils/test/setUIValuesNeeded.spec.js +41 -0
  365. package/src/components/global-styles/font-library-modal/utils/test/toggleFont.spec.js +141 -0
  366. package/src/components/global-styles/font-library-modal/utils/toggleFont.js +90 -0
  367. package/src/components/global-styles/global-styles-provider.js +2 -7
  368. package/src/components/global-styles/screen-block.js +42 -20
  369. package/src/components/global-styles/screen-revisions/index.js +0 -2
  370. package/src/components/global-styles/screen-revisions/use-global-styles-revisions.js +0 -1
  371. package/src/components/global-styles/screen-typography.js +7 -95
  372. package/src/components/global-styles/style-variations-container.js +0 -2
  373. package/src/components/global-styles/typogrphy-elements.js +110 -0
  374. package/src/components/list/style.scss +2 -0
  375. package/src/components/page-patterns/duplicate-menu-item.js +63 -20
  376. package/src/components/page-patterns/grid-item.js +77 -30
  377. package/src/components/page-patterns/header.js +3 -12
  378. package/src/components/page-patterns/index.js +3 -3
  379. package/src/components/page-patterns/patterns-list.js +7 -7
  380. package/src/components/page-patterns/rename-menu-item.js +18 -7
  381. package/src/components/page-patterns/search-items.js +14 -2
  382. package/src/components/page-patterns/style.scss +1 -5
  383. package/src/components/page-patterns/use-patterns.js +67 -33
  384. package/src/components/page-patterns/utils.js +0 -19
  385. package/src/components/sidebar-edit-mode/page-panels/edit-template.js +47 -33
  386. package/src/components/sidebar-edit-mode/page-panels/hooks.js +83 -0
  387. package/src/components/sidebar-edit-mode/page-panels/index.js +0 -4
  388. package/src/components/sidebar-edit-mode/page-panels/page-summary.js +2 -0
  389. package/src/components/sidebar-edit-mode/page-panels/reset-default-template.js +44 -0
  390. package/src/components/sidebar-edit-mode/page-panels/style.scss +41 -10
  391. package/src/components/sidebar-edit-mode/page-panels/swap-template-button.js +82 -0
  392. package/src/components/sidebar-edit-mode/template-panel/index.js +28 -24
  393. package/src/components/sidebar-edit-mode/template-panel/last-revision.js +19 -15
  394. package/src/components/sidebar-edit-mode/template-panel/pattern-categories.js +270 -0
  395. package/src/components/sidebar-navigation-screen/index.js +4 -9
  396. package/src/components/sidebar-navigation-screen/style.scss +7 -1
  397. package/src/components/sidebar-navigation-screen-details-footer/index.js +38 -10
  398. package/src/components/sidebar-navigation-screen-details-footer/style.scss +10 -3
  399. package/src/components/sidebar-navigation-screen-details-panel/sidebar-navigation-screen-details-panel-row.js +2 -0
  400. package/src/components/sidebar-navigation-screen-global-styles/index.js +6 -44
  401. package/src/components/sidebar-navigation-screen-navigation-menus/style.scss +0 -4
  402. package/src/components/sidebar-navigation-screen-page/index.js +3 -3
  403. package/src/components/sidebar-navigation-screen-pattern/index.js +20 -7
  404. package/src/components/sidebar-navigation-screen-pattern/style.scss +0 -3
  405. package/src/components/sidebar-navigation-screen-pattern/use-pattern-details.js +46 -13
  406. package/src/components/sidebar-navigation-screen-patterns/index.js +14 -49
  407. package/src/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +48 -6
  408. package/src/components/sidebar-navigation-screen-patterns/use-theme-patterns.js +3 -5
  409. package/src/components/sidebar-navigation-screen-template/index.js +2 -4
  410. package/src/components/sidebar-navigation-screen-templates/index.js +1 -1
  411. package/src/components/template-actions/index.js +14 -8
  412. package/src/components/template-actions/rename-menu-item.js +15 -4
  413. package/src/components/welcome-guide/styles.js +2 -2
  414. package/src/hooks/push-changes-to-global-styles/index.js +6 -49
  415. package/src/store/actions.js +39 -13
  416. package/src/store/test/actions.js +0 -1
  417. package/src/store/test/reducer.js +0 -1
  418. package/src/style.scss +1 -1
  419. package/src/utils/constants.js +38 -3
  420. package/src/utils/is-template-removable.js +8 -1
  421. package/src/utils/is-template-revertable.js +8 -1
  422. package/build/components/sidebar-navigation-screen-patterns/use-my-patterns.js +0 -30
  423. package/build/components/sidebar-navigation-screen-patterns/use-my-patterns.js.map +0 -1
  424. package/build-module/components/sidebar-navigation-screen-patterns/use-my-patterns.js +0 -23
  425. package/build-module/components/sidebar-navigation-screen-patterns/use-my-patterns.js.map +0 -1
  426. package/src/components/sidebar-navigation-screen-global-styles/style.scss +0 -12
  427. package/src/components/sidebar-navigation-screen-patterns/use-my-patterns.js +0 -24
@@ -2,11 +2,10 @@
2
2
  * WordPress dependencies
3
3
  */
4
4
  import { useSelect } from '@wordpress/data';
5
- import { PanelRow, PanelBody } from '@wordpress/components';
5
+ import { PanelBody } from '@wordpress/components';
6
6
  import { store as editorStore } from '@wordpress/editor';
7
7
  import { store as coreStore } from '@wordpress/core-data';
8
8
  import { decodeEntities } from '@wordpress/html-entities';
9
- import { __ } from '@wordpress/i18n';
10
9
  import { navigation, symbol } from '@wordpress/icons';
11
10
 
12
11
  /**
@@ -17,6 +16,8 @@ import TemplateActions from './template-actions';
17
16
  import TemplateAreas from './template-areas';
18
17
  import LastRevision from './last-revision';
19
18
  import SidebarCard from '../sidebar-card';
19
+ import PatternCategories from './pattern-categories';
20
+ import { PATTERN_TYPES } from '../../../utils/constants';
20
21
 
21
22
  const CARD_ICONS = {
22
23
  wp_block: symbol,
@@ -24,24 +25,29 @@ const CARD_ICONS = {
24
25
  };
25
26
 
26
27
  export default function TemplatePanel() {
27
- const { title, description, icon, record } = useSelect( ( select ) => {
28
- const { getEditedPostType, getEditedPostId } = select( editSiteStore );
29
- const { getEditedEntityRecord } = select( coreStore );
30
- const { __experimentalGetTemplateInfo: getTemplateInfo } =
31
- select( editorStore );
28
+ const { title, description, icon, record, postType } = useSelect(
29
+ ( select ) => {
30
+ const { getEditedPostType, getEditedPostId } =
31
+ select( editSiteStore );
32
+ const { getEditedEntityRecord } = select( coreStore );
33
+ const { __experimentalGetTemplateInfo: getTemplateInfo } =
34
+ select( editorStore );
32
35
 
33
- const postType = getEditedPostType();
34
- const postId = getEditedPostId();
35
- const _record = getEditedEntityRecord( 'postType', postType, postId );
36
- const info = getTemplateInfo( _record );
36
+ const type = getEditedPostType();
37
+ const postId = getEditedPostId();
38
+ const _record = getEditedEntityRecord( 'postType', type, postId );
39
+ const info = getTemplateInfo( _record );
37
40
 
38
- return {
39
- title: info.title,
40
- description: info.description,
41
- icon: info.icon,
42
- record: _record,
43
- };
44
- }, [] );
41
+ return {
42
+ title: info.title,
43
+ description: info.description,
44
+ icon: info.icon,
45
+ record: _record,
46
+ postType: type,
47
+ };
48
+ },
49
+ []
50
+ );
45
51
 
46
52
  if ( ! title && ! description ) {
47
53
  return null;
@@ -58,12 +64,10 @@ export default function TemplatePanel() {
58
64
  >
59
65
  <TemplateAreas />
60
66
  </SidebarCard>
61
- <PanelRow
62
- header={ __( 'Editing history' ) }
63
- className="edit-site-template-revisions"
64
- >
65
- <LastRevision />
66
- </PanelRow>
67
+ <LastRevision />
68
+ { postType === PATTERN_TYPES.user && (
69
+ <PatternCategories post={ record } />
70
+ ) }
67
71
  </PanelBody>
68
72
  );
69
73
  }
@@ -1,8 +1,8 @@
1
1
  /**
2
2
  * WordPress dependencies
3
3
  */
4
- import { Button } from '@wordpress/components';
5
- import { sprintf, _n } from '@wordpress/i18n';
4
+ import { Button, PanelRow } from '@wordpress/components';
5
+ import { sprintf, _n, __ } from '@wordpress/i18n';
6
6
  import { backup } from '@wordpress/icons';
7
7
  import { addQueryArgs } from '@wordpress/url';
8
8
  import { PostTypeSupportCheck } from '@wordpress/editor';
@@ -47,20 +47,24 @@ const PostLastRevision = () => {
47
47
 
48
48
  return (
49
49
  <PostLastRevisionCheck>
50
- <Button
51
- href={ addQueryArgs( 'revision.php', {
52
- revision: lastRevisionId,
53
- gutenberg: true,
54
- } ) }
55
- className="edit-site-template-last-revision__title"
56
- icon={ backup }
50
+ <PanelRow
51
+ header={ __( 'Editing history' ) }
52
+ className="edit-site-template-revisions"
57
53
  >
58
- { sprintf(
59
- /* translators: %d: number of revisions */
60
- _n( '%d Revision', '%d Revisions', revisionsCount ),
61
- revisionsCount
62
- ) }
63
- </Button>
54
+ <Button
55
+ href={ addQueryArgs( 'revision.php', {
56
+ revision: lastRevisionId,
57
+ } ) }
58
+ className="edit-site-template-last-revision__title"
59
+ icon={ backup }
60
+ >
61
+ { sprintf(
62
+ /* translators: %d: number of revisions */
63
+ _n( '%d Revision', '%d Revisions', revisionsCount ),
64
+ revisionsCount
65
+ ) }
66
+ </Button>
67
+ </PanelRow>
64
68
  </PostLastRevisionCheck>
65
69
  );
66
70
  };
@@ -0,0 +1,270 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { __, _x, sprintf } from '@wordpress/i18n';
5
+ import { useEffect, useMemo, useState } from '@wordpress/element';
6
+ import { FormTokenField, PanelRow } from '@wordpress/components';
7
+ import { useSelect, useDispatch } from '@wordpress/data';
8
+ import { store as coreStore } from '@wordpress/core-data';
9
+ import { useDebounce } from '@wordpress/compose';
10
+ import { store as noticesStore } from '@wordpress/notices';
11
+ import { decodeEntities } from '@wordpress/html-entities';
12
+
13
+ export const unescapeString = ( arg ) => {
14
+ return decodeEntities( arg );
15
+ };
16
+
17
+ /**
18
+ * Returns a term object with name unescaped.
19
+ *
20
+ * @param {Object} term The term object to unescape.
21
+ *
22
+ * @return {Object} Term object with name property unescaped.
23
+ */
24
+ export const unescapeTerm = ( term ) => {
25
+ return {
26
+ ...term,
27
+ name: unescapeString( term.name ),
28
+ };
29
+ };
30
+
31
+ /**
32
+ * Shared reference to an empty array for cases where it is important to avoid
33
+ * returning a new array reference on every invocation.
34
+ *
35
+ * @type {Array<any>}
36
+ */
37
+ const EMPTY_ARRAY = [];
38
+
39
+ /**
40
+ * Module constants
41
+ */
42
+ const MAX_TERMS_SUGGESTIONS = 20;
43
+ const DEFAULT_QUERY = {
44
+ per_page: MAX_TERMS_SUGGESTIONS,
45
+ _fields: 'id,name',
46
+ context: 'view',
47
+ };
48
+
49
+ const isSameTermName = ( termA, termB ) =>
50
+ unescapeString( termA ).toLowerCase() ===
51
+ unescapeString( termB ).toLowerCase();
52
+
53
+ const termNamesToIds = ( names, terms ) => {
54
+ return names.map(
55
+ ( termName ) =>
56
+ terms.find( ( term ) => isSameTermName( term.name, termName ) ).id
57
+ );
58
+ };
59
+
60
+ export default function PatternCategories( { post } ) {
61
+ const slug = 'wp_pattern_category';
62
+ const [ values, setValues ] = useState( [] );
63
+ const [ search, setSearch ] = useState( '' );
64
+ const debouncedSearch = useDebounce( setSearch, 500 );
65
+
66
+ const {
67
+ terms,
68
+ taxonomy,
69
+ hasAssignAction,
70
+ hasCreateAction,
71
+ hasResolvedTerms,
72
+ } = useSelect(
73
+ ( select ) => {
74
+ const { getEntityRecords, getTaxonomy, hasFinishedResolution } =
75
+ select( coreStore );
76
+ const _taxonomy = getTaxonomy( slug );
77
+ const _termIds =
78
+ post?.wp_pattern_category?.length > 0
79
+ ? post?.wp_pattern_category
80
+ : EMPTY_ARRAY;
81
+ const query = {
82
+ ...DEFAULT_QUERY,
83
+ include: _termIds?.join( ',' ),
84
+ per_page: -1,
85
+ };
86
+
87
+ return {
88
+ hasCreateAction: _taxonomy
89
+ ? post._links?.[
90
+ 'wp:action-create-' + _taxonomy.rest_base
91
+ ] ?? false
92
+ : false,
93
+ hasAssignAction: _taxonomy
94
+ ? post._links?.[
95
+ 'wp:action-assign-' + _taxonomy.rest_base
96
+ ] ?? false
97
+ : false,
98
+ taxonomy: _taxonomy,
99
+ termIds: _termIds,
100
+ terms: _termIds?.length
101
+ ? getEntityRecords( 'taxonomy', slug, query )
102
+ : EMPTY_ARRAY,
103
+ hasResolvedTerms: hasFinishedResolution( 'getEntityRecords', [
104
+ 'taxonomy',
105
+ slug,
106
+ query,
107
+ ] ),
108
+ };
109
+ },
110
+ [ slug, post ]
111
+ );
112
+
113
+ const { searchResults } = useSelect(
114
+ ( select ) => {
115
+ const { getEntityRecords } = select( coreStore );
116
+
117
+ return {
118
+ searchResults: !! search
119
+ ? getEntityRecords( 'taxonomy', slug, {
120
+ ...DEFAULT_QUERY,
121
+ search,
122
+ } )
123
+ : EMPTY_ARRAY,
124
+ };
125
+ },
126
+ [ search, slug ]
127
+ );
128
+
129
+ // Update terms state only after the selectors are resolved.
130
+ // We're using this to avoid terms temporarily disappearing on slow networks
131
+ // while core data makes REST API requests.
132
+ useEffect( () => {
133
+ if ( hasResolvedTerms ) {
134
+ const newValues = ( terms ?? [] ).map( ( term ) =>
135
+ unescapeString( term.name )
136
+ );
137
+
138
+ setValues( newValues );
139
+ }
140
+ }, [ terms, hasResolvedTerms ] );
141
+
142
+ const suggestions = useMemo( () => {
143
+ return ( searchResults ?? [] ).map( ( term ) =>
144
+ unescapeString( term.name )
145
+ );
146
+ }, [ searchResults ] );
147
+
148
+ const { saveEntityRecord, editEntityRecord } = useDispatch( coreStore );
149
+ const { createErrorNotice } = useDispatch( noticesStore );
150
+
151
+ if ( ! hasAssignAction ) {
152
+ return null;
153
+ }
154
+
155
+ async function findOrCreateTerm( term ) {
156
+ try {
157
+ const newTerm = await saveEntityRecord( 'taxonomy', slug, term, {
158
+ throwOnError: true,
159
+ } );
160
+ return unescapeTerm( newTerm );
161
+ } catch ( error ) {
162
+ if ( error.code !== 'term_exists' ) {
163
+ throw error;
164
+ }
165
+
166
+ return {
167
+ id: error.data.term_id,
168
+ name: term.name,
169
+ };
170
+ }
171
+ }
172
+
173
+ function onUpdateTerms( newTermIds ) {
174
+ editEntityRecord( 'postType', 'wp_block', post.id, {
175
+ wp_pattern_category: newTermIds,
176
+ } );
177
+ }
178
+
179
+ function onChange( termNames ) {
180
+ const availableTerms = [
181
+ ...( terms ?? [] ),
182
+ ...( searchResults ?? [] ),
183
+ ];
184
+ const uniqueTerms = termNames.reduce( ( acc, name ) => {
185
+ if (
186
+ ! acc.some( ( n ) => n.toLowerCase() === name.toLowerCase() )
187
+ ) {
188
+ acc.push( name );
189
+ }
190
+ return acc;
191
+ }, [] );
192
+
193
+ const newTermNames = uniqueTerms.filter(
194
+ ( termName ) =>
195
+ ! availableTerms.find( ( term ) =>
196
+ isSameTermName( term.name, termName )
197
+ )
198
+ );
199
+
200
+ // Optimistically update term values.
201
+ // The selector will always re-fetch terms later.
202
+ setValues( uniqueTerms );
203
+
204
+ if ( newTermNames.length === 0 ) {
205
+ return onUpdateTerms(
206
+ termNamesToIds( uniqueTerms, availableTerms )
207
+ );
208
+ }
209
+
210
+ if ( ! hasCreateAction ) {
211
+ return;
212
+ }
213
+
214
+ Promise.all(
215
+ newTermNames.map( ( termName ) =>
216
+ findOrCreateTerm( { name: termName } )
217
+ )
218
+ )
219
+ .then( ( newTerms ) => {
220
+ const newAvailableTerms = availableTerms.concat( newTerms );
221
+ return onUpdateTerms(
222
+ termNamesToIds( uniqueTerms, newAvailableTerms )
223
+ );
224
+ } )
225
+ .catch( ( error ) => {
226
+ createErrorNotice( error.message, {
227
+ type: 'snackbar',
228
+ } );
229
+ } );
230
+ }
231
+
232
+ const singularName =
233
+ taxonomy?.labels?.singular_name ??
234
+ ( slug === 'post_tag' ? __( 'Tag' ) : __( 'Term' ) );
235
+ const termAddedLabel = sprintf(
236
+ /* translators: %s: term name. */
237
+ _x( '%s added', 'term' ),
238
+ singularName
239
+ );
240
+ const termRemovedLabel = sprintf(
241
+ /* translators: %s: term name. */
242
+ _x( '%s removed', 'term' ),
243
+ singularName
244
+ );
245
+ const removeTermLabel = sprintf(
246
+ /* translators: %s: term name. */
247
+ _x( 'Remove %s', 'term' ),
248
+ singularName
249
+ );
250
+
251
+ return (
252
+ <PanelRow initialOpen={ true } title={ __( 'Categories' ) }>
253
+ <FormTokenField
254
+ __next40pxDefaultSize
255
+ value={ values }
256
+ suggestions={ suggestions }
257
+ onChange={ onChange }
258
+ onInputChange={ debouncedSearch }
259
+ maxSuggestions={ MAX_TERMS_SUGGESTIONS }
260
+ label={ __( 'Pattern categories' ) }
261
+ messages={ {
262
+ added: termAddedLabel,
263
+ removed: termRemovedLabel,
264
+ remove: removeTermLabel,
265
+ } }
266
+ tokenizeOnBlur
267
+ />
268
+ </PanelRow>
269
+ );
270
+ }
@@ -41,10 +41,11 @@ export default function SidebarNavigationScreen( {
41
41
  description,
42
42
  backPath: backPathProp,
43
43
  } ) {
44
- const { dashboardLink } = useSelect( ( select ) => {
44
+ const { dashboardLink, dashboardLinkText } = useSelect( ( select ) => {
45
45
  const { getSettings } = unlock( select( editSiteStore ) );
46
46
  return {
47
47
  dashboardLink: getSettings().__experimentalDashboardLink,
48
+ dashboardLinkText: getSettings().__experimentalDashboardLinkText,
48
49
  };
49
50
  }, [] );
50
51
  const { getTheme } = useSelect( coreStore );
@@ -92,15 +93,9 @@ export default function SidebarNavigationScreen( {
92
93
  <SidebarButton
93
94
  icon={ icon }
94
95
  label={
95
- ! isPreviewingTheme()
96
- ? __( 'Go to the Dashboard' )
97
- : __( 'Go back to the theme showcase' )
98
- }
99
- href={
100
- ! isPreviewingTheme()
101
- ? dashboardLink || 'index.php'
102
- : 'themes.php'
96
+ dashboardLinkText || __( 'Go to the Dashboard' )
103
97
  }
98
+ href={ dashboardLink || 'index.php' }
104
99
  />
105
100
  ) }
106
101
  <Heading
@@ -109,10 +109,15 @@
109
109
  &.is-dismissible {
110
110
  padding-right: $grid-unit-10;
111
111
  }
112
+
113
+ .components-notice__dismiss:not(:disabled):not([aria-disabled="true"]) {
114
+ color: $gray-400;
115
+ }
116
+
112
117
  .components-notice__dismiss:not(:disabled):not([aria-disabled="true"]):focus,
113
118
  .components-notice__dismiss:not(:disabled):not([aria-disabled="true"]):not(.is-secondary):active,
114
119
  .components-notice__dismiss:not(:disabled):not([aria-disabled="true"]):not(.is-secondary):hover {
115
- color: $gray-100;
120
+ color: $white;
116
121
  }
117
122
  }
118
123
 
@@ -134,6 +139,7 @@
134
139
  .components-input-control__input {
135
140
  color: $gray-200 !important;
136
141
  background: $gray-800 !important;
142
+ border-radius: $radius-block-ui;
137
143
  }
138
144
  .components-input-control__backdrop {
139
145
  border: 4px !important;
@@ -4,6 +4,12 @@
4
4
  import { __, sprintf } from '@wordpress/i18n';
5
5
  import { humanTimeDiff } from '@wordpress/date';
6
6
  import { createInterpolateElement } from '@wordpress/element';
7
+ import { addQueryArgs } from '@wordpress/url';
8
+ import {
9
+ Icon,
10
+ __experimentalItemGroup as ItemGroup,
11
+ } from '@wordpress/components';
12
+ import { backup } from '@wordpress/icons';
7
13
 
8
14
  /**
9
15
  * Internal dependencies
@@ -13,14 +19,34 @@ import {
13
19
  SidebarNavigationScreenDetailsPanelLabel,
14
20
  SidebarNavigationScreenDetailsPanelValue,
15
21
  } from '../sidebar-navigation-screen-details-panel';
22
+ import SidebarNavigationItem from '../sidebar-navigation-item';
16
23
 
17
24
  export default function SidebarNavigationScreenDetailsFooter( {
18
- lastModifiedDateTime,
25
+ record,
26
+ ...otherProps
19
27
  } ) {
28
+ /*
29
+ * There might be other items in the future,
30
+ * but for now it's just modified date.
31
+ * Later we might render a list of items and isolate
32
+ * the following logic.
33
+ */
34
+ const hrefProps = {};
35
+ if ( record?._links?.[ 'predecessor-version' ]?.[ 0 ]?.id ) {
36
+ hrefProps.href = addQueryArgs( 'revision.php', {
37
+ revision: record?._links[ 'predecessor-version' ][ 0 ].id,
38
+ } );
39
+ hrefProps.as = 'a';
40
+ }
41
+
20
42
  return (
21
- <>
22
- { lastModifiedDateTime && (
23
- <SidebarNavigationScreenDetailsPanelRow className="edit-site-sidebar-navigation-screen-details-footer">
43
+ <ItemGroup className="edit-site-sidebar-navigation-screen-details-footer">
44
+ <SidebarNavigationItem
45
+ label={ __( 'Revisions' ) }
46
+ { ...hrefProps }
47
+ { ...otherProps }
48
+ >
49
+ <SidebarNavigationScreenDetailsPanelRow justify="space-between">
24
50
  <SidebarNavigationScreenDetailsPanelLabel>
25
51
  { __( 'Last modified' ) }
26
52
  </SidebarNavigationScreenDetailsPanelLabel>
@@ -29,17 +55,19 @@ export default function SidebarNavigationScreenDetailsFooter( {
29
55
  sprintf(
30
56
  /* translators: %s: is the relative time when the post was last modified. */
31
57
  __( '<time>%s</time>' ),
32
- humanTimeDiff( lastModifiedDateTime )
58
+ humanTimeDiff( record.modified )
33
59
  ),
34
60
  {
35
- time: (
36
- <time dateTime={ lastModifiedDateTime } />
37
- ),
61
+ time: <time dateTime={ record.modified } />,
38
62
  }
39
63
  ) }
40
64
  </SidebarNavigationScreenDetailsPanelValue>
65
+ <Icon
66
+ className="edit-site-sidebar-navigation-screen-details-footer__icon"
67
+ icon={ backup }
68
+ />
41
69
  </SidebarNavigationScreenDetailsPanelRow>
42
- ) }
43
- </>
70
+ </SidebarNavigationItem>
71
+ </ItemGroup>
44
72
  );
45
73
  }
@@ -1,5 +1,12 @@
1
1
  .edit-site-sidebar-navigation-screen-details-footer {
2
- padding-top: $grid-unit-10;
3
- padding-bottom: $grid-unit-10;
4
- padding-left: $grid-unit-20;
2
+ // Default background color (no link or button).
3
+ div.edit-site-sidebar-navigation-item.components-item:focus,
4
+ div.edit-site-sidebar-navigation-item.components-item:hover,
5
+ div.edit-site-sidebar-navigation-item.components-item[aria-current] {
6
+ background: none;
7
+ }
8
+ .edit-site-sidebar-navigation-screen-details-footer__icon {
9
+ margin-left: auto;
10
+ fill: $gray-600;
11
+ }
5
12
  }
@@ -12,6 +12,7 @@ export default function SidebarNavigationScreenDetailsPanelRow( {
12
12
  label,
13
13
  children,
14
14
  className,
15
+ ...extraProps
15
16
  } ) {
16
17
  return (
17
18
  <HStack
@@ -22,6 +23,7 @@ export default function SidebarNavigationScreenDetailsPanelRow( {
22
23
  'edit-site-sidebar-navigation-details-screen-panel__row',
23
24
  className
24
25
  ) }
26
+ { ...extraProps }
25
27
  >
26
28
  { children }
27
29
  </HStack>
@@ -2,18 +2,12 @@
2
2
  * WordPress dependencies
3
3
  */
4
4
  import { __ } from '@wordpress/i18n';
5
- import { backup, edit, seen } from '@wordpress/icons';
5
+ import { edit, seen } from '@wordpress/icons';
6
6
  import { useSelect, useDispatch } from '@wordpress/data';
7
7
  import { store as coreStore } from '@wordpress/core-data';
8
- import {
9
- Icon,
10
- __experimentalNavigatorButton as NavigatorButton,
11
- __experimentalVStack as HStack,
12
- __experimentalVStack as VStack,
13
- } from '@wordpress/components';
8
+ import { __experimentalNavigatorButton as NavigatorButton } from '@wordpress/components';
14
9
  import { useViewportMatch } from '@wordpress/compose';
15
10
  import { BlockEditorProvider } from '@wordpress/block-editor';
16
- import { humanTimeDiff } from '@wordpress/date';
17
11
  import { useCallback } from '@wordpress/element';
18
12
 
19
13
  /**
@@ -27,6 +21,7 @@ import SidebarButton from '../sidebar-button';
27
21
  import SidebarNavigationItem from '../sidebar-navigation-item';
28
22
  import StyleBook from '../style-book';
29
23
  import useGlobalStylesRevisions from '../global-styles/screen-revisions/use-global-styles-revisions';
24
+ import SidebarNavigationScreenDetailsFooter from '../sidebar-navigation-screen-details-footer';
30
25
 
31
26
  const noop = () => {};
32
27
 
@@ -88,39 +83,6 @@ function SidebarNavigationScreenGlobalStylesContent() {
88
83
  );
89
84
  }
90
85
 
91
- function SidebarNavigationScreenGlobalStylesFooter( {
92
- modifiedDateTime,
93
- onClickRevisions,
94
- } ) {
95
- return (
96
- <VStack className="edit-site-sidebar-navigation-screen-global-styles__footer">
97
- <SidebarNavigationItem
98
- className="edit-site-sidebar-navigation-screen-global-styles__revisions"
99
- label={ __( 'Revisions' ) }
100
- onClick={ onClickRevisions }
101
- >
102
- <HStack
103
- as="span"
104
- alignment="center"
105
- spacing={ 5 }
106
- direction="row"
107
- justify="space-between"
108
- >
109
- <span className="edit-site-sidebar-navigation-screen-global-styles__revisions__label">
110
- { __( 'Last modified' ) }
111
- </span>
112
- <span>
113
- <time dateTime={ modifiedDateTime }>
114
- { humanTimeDiff( modifiedDateTime ) }
115
- </time>
116
- </span>
117
- <Icon icon={ backup } style={ { fill: 'currentcolor' } } />
118
- </HStack>
119
- </SidebarNavigationItem>
120
- </VStack>
121
- );
122
- }
123
-
124
86
  export default function SidebarNavigationScreenGlobalStyles() {
125
87
  const { revisions, isLoading: isLoadingRevisions } =
126
88
  useGlobalStylesRevisions();
@@ -198,9 +160,9 @@ export default function SidebarNavigationScreenGlobalStyles() {
198
160
  content={ <SidebarNavigationScreenGlobalStylesContent /> }
199
161
  footer={
200
162
  shouldShowGlobalStylesFooter && (
201
- <SidebarNavigationScreenGlobalStylesFooter
202
- modifiedDateTime={ modifiedDateTime }
203
- onClickRevisions={ openRevisions }
163
+ <SidebarNavigationScreenDetailsFooter
164
+ record={ revisions?.[ 0 ] }
165
+ onClick={ openRevisions }
204
166
  />
205
167
  )
206
168
  }
@@ -90,10 +90,6 @@
90
90
  }
91
91
  }
92
92
 
93
- .edit-site-sidebar-navigation-screen-navigation-menus__content .popover-slot .wp-block-navigation-submenu {
94
- display: none;
95
- }
96
-
97
93
  .edit-site-sidebar-navigation-screen-navigation-menus__loading.components-spinner {
98
94
  margin-left: auto;
99
95
  margin-right: auto;
@@ -124,9 +124,9 @@ export default function SidebarNavigationScreenPage() {
124
124
  </>
125
125
  }
126
126
  footer={
127
- <SidebarNavigationScreenDetailsFooter
128
- lastModifiedDateTime={ record?.modified }
129
- />
127
+ record?.modified ? (
128
+ <SidebarNavigationScreenDetailsFooter record={ record } />
129
+ ) : null
130
130
  }
131
131
  />
132
132
  ) : null;