@wordpress/edit-site 5.14.0 → 5.16.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 (461) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/build/components/add-new-page/index.js +1 -6
  3. package/build/components/add-new-page/index.js.map +1 -1
  4. package/build/components/add-new-pattern/index.js +22 -7
  5. package/build/components/add-new-pattern/index.js.map +1 -1
  6. package/build/components/add-new-template/utils.js +10 -8
  7. package/build/components/add-new-template/utils.js.map +1 -1
  8. package/build/components/block-editor/constants.js +1 -1
  9. package/build/components/block-editor/constants.js.map +1 -1
  10. package/build/components/block-editor/editor-canvas.js +1 -1
  11. package/build/components/block-editor/editor-canvas.js.map +1 -1
  12. package/build/components/block-editor/index.js +0 -4
  13. package/build/components/block-editor/index.js.map +1 -1
  14. package/build/components/block-editor/use-site-editor-settings.js +114 -13
  15. package/build/components/block-editor/use-site-editor-settings.js.map +1 -1
  16. package/build/components/code-editor/index.js +60 -28
  17. package/build/components/code-editor/index.js.map +1 -1
  18. package/build/components/create-pattern-modal/index.js +7 -3
  19. package/build/components/create-pattern-modal/index.js.map +1 -1
  20. package/build/components/editor/index.js +5 -5
  21. package/build/components/editor/index.js.map +1 -1
  22. package/build/components/global-styles/global-styles-provider.js +12 -7
  23. package/build/components/global-styles/global-styles-provider.js.map +1 -1
  24. package/build/components/global-styles/screen-block.js +16 -0
  25. package/build/components/global-styles/screen-block.js.map +1 -1
  26. package/build/components/global-styles/screen-revisions/index.js +12 -5
  27. package/build/components/global-styles/screen-revisions/index.js.map +1 -1
  28. package/build/components/global-styles/screen-revisions/revisions-buttons.js +10 -22
  29. package/build/components/global-styles/screen-revisions/revisions-buttons.js.map +1 -1
  30. package/build/components/global-styles/screen-revisions/use-global-styles-revisions.js +32 -25
  31. package/build/components/global-styles/screen-revisions/use-global-styles-revisions.js.map +1 -1
  32. package/build/components/global-styles/style-variations-container.js +5 -3
  33. package/build/components/global-styles/style-variations-container.js.map +1 -1
  34. package/build/components/header-edit-mode/document-actions/index.js +4 -2
  35. package/build/components/header-edit-mode/document-actions/index.js.map +1 -1
  36. package/build/components/header-edit-mode/index.js +13 -9
  37. package/build/components/header-edit-mode/index.js.map +1 -1
  38. package/build/components/keyboard-shortcuts/edit-mode.js +7 -5
  39. package/build/components/keyboard-shortcuts/edit-mode.js.map +1 -1
  40. package/build/components/layout/index.js +17 -5
  41. package/build/components/layout/index.js.map +1 -1
  42. package/build/components/page/index.js +3 -3
  43. package/build/components/page/index.js.map +1 -1
  44. package/build/components/page-actions/index.js +2 -2
  45. package/build/components/page-actions/index.js.map +1 -1
  46. package/build/components/page-actions/{delete-page-menu-item.js → trash-page-menu-item.js} +8 -16
  47. package/build/components/page-actions/trash-page-menu-item.js.map +1 -0
  48. package/build/components/page-content-focus-manager/disable-non-page-content-blocks.js +5 -5
  49. package/build/components/page-content-focus-manager/disable-non-page-content-blocks.js.map +1 -1
  50. package/build/components/page-patterns/duplicate-menu-item.js +163 -0
  51. package/build/components/page-patterns/duplicate-menu-item.js.map +1 -0
  52. package/build/components/page-patterns/grid-item.js +83 -58
  53. package/build/components/page-patterns/grid-item.js.map +1 -1
  54. package/build/components/page-patterns/grid.js +5 -18
  55. package/build/components/page-patterns/grid.js.map +1 -1
  56. package/build/components/page-patterns/header.js +69 -0
  57. package/build/components/page-patterns/header.js.map +1 -0
  58. package/build/components/page-patterns/index.js +3 -1
  59. package/build/components/page-patterns/index.js.map +1 -1
  60. package/build/components/page-patterns/pagination.js +63 -0
  61. package/build/components/page-patterns/pagination.js.map +1 -0
  62. package/build/components/page-patterns/patterns-list.js +110 -31
  63. package/build/components/page-patterns/patterns-list.js.map +1 -1
  64. package/build/components/page-patterns/rename-menu-item.js +109 -0
  65. package/build/components/page-patterns/rename-menu-item.js.map +1 -0
  66. package/build/components/page-patterns/use-patterns.js +116 -118
  67. package/build/components/page-patterns/use-patterns.js.map +1 -1
  68. package/build/components/page-template-parts/add-new-template-part.js +74 -0
  69. package/build/components/page-template-parts/add-new-template-part.js.map +1 -0
  70. package/build/components/page-template-parts/index.js +3 -25
  71. package/build/components/page-template-parts/index.js.map +1 -1
  72. package/build/components/page-templates/index.js +1 -16
  73. package/build/components/page-templates/index.js.map +1 -1
  74. package/build/components/resizable-frame/index.js +85 -51
  75. package/build/components/resizable-frame/index.js.map +1 -1
  76. package/build/components/save-button/index.js +4 -2
  77. package/build/components/save-button/index.js.map +1 -1
  78. package/build/components/save-hub/index.js +10 -4
  79. package/build/components/save-hub/index.js.map +1 -1
  80. package/build/components/save-panel/index.js +5 -5
  81. package/build/components/save-panel/index.js.map +1 -1
  82. package/build/components/sidebar-edit-mode/page-panels/page-content.js +4 -3
  83. package/build/components/sidebar-edit-mode/page-panels/page-content.js.map +1 -1
  84. package/build/components/sidebar-edit-mode/page-panels/page-status.js +3 -8
  85. package/build/components/sidebar-edit-mode/page-panels/page-status.js.map +1 -1
  86. package/build/components/sidebar-edit-mode/template-panel/index.js +15 -8
  87. package/build/components/sidebar-edit-mode/template-panel/index.js.map +1 -1
  88. package/build/components/sidebar-navigation-screen/index.js +31 -15
  89. package/build/components/sidebar-navigation-screen/index.js.map +1 -1
  90. package/build/components/sidebar-navigation-screen-global-styles/index.js +34 -40
  91. package/build/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  92. package/build/components/sidebar-navigation-screen-main/index.js +4 -2
  93. package/build/components/sidebar-navigation-screen-main/index.js.map +1 -1
  94. package/build/components/sidebar-navigation-screen-main/template-part-hint.js +45 -0
  95. package/build/components/sidebar-navigation-screen-main/template-part-hint.js.map +1 -0
  96. package/build/components/sidebar-navigation-screen-navigation-menu/index.js +4 -4
  97. package/build/components/sidebar-navigation-screen-navigation-menu/index.js.map +1 -1
  98. package/build/components/sidebar-navigation-screen-navigation-menu/more-menu.js +1 -0
  99. package/build/components/sidebar-navigation-screen-navigation-menu/more-menu.js.map +1 -1
  100. package/build/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js +3 -3
  101. package/build/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js.map +1 -1
  102. package/build/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js +5 -4
  103. package/build/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js.map +1 -1
  104. package/build/components/sidebar-navigation-screen-navigation-menus/constants.js +2 -0
  105. package/build/components/sidebar-navigation-screen-navigation-menus/constants.js.map +1 -1
  106. package/build/components/sidebar-navigation-screen-navigation-menus/index.js +4 -4
  107. package/build/components/sidebar-navigation-screen-navigation-menus/index.js.map +1 -1
  108. package/build/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js +8 -0
  109. package/build/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js.map +1 -1
  110. package/build/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js +1 -1
  111. package/build/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js.map +1 -1
  112. package/build/components/sidebar-navigation-screen-page/index.js +2 -3
  113. package/build/components/sidebar-navigation-screen-page/index.js.map +1 -1
  114. package/build/components/sidebar-navigation-screen-page/status-label.js +1 -34
  115. package/build/components/sidebar-navigation-screen-page/status-label.js.map +1 -1
  116. package/build/components/sidebar-navigation-screen-pages/index.js +35 -25
  117. package/build/components/sidebar-navigation-screen-pages/index.js.map +1 -1
  118. package/build/components/sidebar-navigation-screen-pattern/index.js +9 -7
  119. package/build/components/sidebar-navigation-screen-pattern/index.js.map +1 -1
  120. package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js +4 -3
  121. package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js.map +1 -1
  122. package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menus.js +3 -2
  123. package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menus.js.map +1 -1
  124. package/build/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js +19 -4
  125. package/build/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js.map +1 -1
  126. package/build/components/sidebar-navigation-screen-pattern/use-pattern-details.js +55 -28
  127. package/build/components/sidebar-navigation-screen-pattern/use-pattern-details.js.map +1 -1
  128. package/build/components/sidebar-navigation-screen-patterns/category-item.js +0 -5
  129. package/build/components/sidebar-navigation-screen-patterns/category-item.js.map +1 -1
  130. package/build/components/sidebar-navigation-screen-patterns/index.js +72 -60
  131. package/build/components/sidebar-navigation-screen-patterns/index.js.map +1 -1
  132. package/build/components/sidebar-navigation-screen-patterns/use-my-patterns.js +9 -5
  133. package/build/components/sidebar-navigation-screen-patterns/use-my-patterns.js.map +1 -1
  134. package/build/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +11 -1
  135. package/build/components/sidebar-navigation-screen-patterns/use-pattern-categories.js.map +1 -1
  136. package/build/components/sidebar-navigation-screen-patterns/use-template-part-areas.js +20 -9
  137. package/build/components/sidebar-navigation-screen-patterns/use-template-part-areas.js.map +1 -1
  138. package/build/components/sidebar-navigation-screen-patterns/use-theme-patterns.js +1 -1
  139. package/build/components/sidebar-navigation-screen-patterns/use-theme-patterns.js.map +1 -1
  140. package/build/components/sidebar-navigation-screen-templates/index.js +1 -10
  141. package/build/components/sidebar-navigation-screen-templates/index.js.map +1 -1
  142. package/build/components/sidebar-navigation-screen-templates-browse/index.js +9 -0
  143. package/build/components/sidebar-navigation-screen-templates-browse/index.js.map +1 -1
  144. package/build/components/site-hub/index.js +29 -13
  145. package/build/components/site-hub/index.js.map +1 -1
  146. package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js +10 -5
  147. package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
  148. package/build/components/sync-state-with-url/use-sync-canvas-mode-with-url.js +1 -1
  149. package/build/components/sync-state-with-url/use-sync-canvas-mode-with-url.js.map +1 -1
  150. package/build/components/sync-state-with-url/use-sync-path-with-url.js +15 -12
  151. package/build/components/sync-state-with-url/use-sync-path-with-url.js.map +1 -1
  152. package/build/components/template-actions/index.js +3 -1
  153. package/build/components/template-actions/index.js.map +1 -1
  154. package/build/components/template-actions/rename-menu-item.js +12 -8
  155. package/build/components/template-actions/rename-menu-item.js.map +1 -1
  156. package/build/components/use-edited-entity-record/index.js +6 -1
  157. package/build/components/use-edited-entity-record/index.js.map +1 -1
  158. package/build/hooks/commands/use-common-commands.js +120 -32
  159. package/build/hooks/commands/use-common-commands.js.map +1 -1
  160. package/build/hooks/commands/use-edit-mode-commands.js +65 -7
  161. package/build/hooks/commands/use-edit-mode-commands.js.map +1 -1
  162. package/build/hooks/push-changes-to-global-styles/index.js +138 -57
  163. package/build/hooks/push-changes-to-global-styles/index.js.map +1 -1
  164. package/build/store/private-actions.js +9 -2
  165. package/build/store/private-actions.js.map +1 -1
  166. package/build/utils/normalize-record-key.js +19 -0
  167. package/build/utils/normalize-record-key.js.map +1 -0
  168. package/build/utils/use-activate-theme.js +1 -1
  169. package/build/utils/use-activate-theme.js.map +1 -1
  170. package/build/utils/use-debounced-input.js +5 -7
  171. package/build/utils/use-debounced-input.js.map +1 -1
  172. package/build-module/components/add-new-page/index.js +1 -6
  173. package/build-module/components/add-new-page/index.js.map +1 -1
  174. package/build-module/components/add-new-pattern/index.js +20 -7
  175. package/build-module/components/add-new-pattern/index.js.map +1 -1
  176. package/build-module/components/add-new-template/utils.js +9 -6
  177. package/build-module/components/add-new-template/utils.js.map +1 -1
  178. package/build-module/components/block-editor/constants.js +1 -1
  179. package/build-module/components/block-editor/constants.js.map +1 -1
  180. package/build-module/components/block-editor/editor-canvas.js +1 -1
  181. package/build-module/components/block-editor/editor-canvas.js.map +1 -1
  182. package/build-module/components/block-editor/index.js +0 -4
  183. package/build-module/components/block-editor/index.js.map +1 -1
  184. package/build-module/components/block-editor/use-site-editor-settings.js +116 -14
  185. package/build-module/components/block-editor/use-site-editor-settings.js.map +1 -1
  186. package/build-module/components/code-editor/index.js +62 -30
  187. package/build-module/components/code-editor/index.js.map +1 -1
  188. package/build-module/components/create-pattern-modal/index.js +6 -3
  189. package/build-module/components/create-pattern-modal/index.js.map +1 -1
  190. package/build-module/components/editor/index.js +5 -5
  191. package/build-module/components/editor/index.js.map +1 -1
  192. package/build-module/components/global-styles/global-styles-provider.js +12 -7
  193. package/build-module/components/global-styles/global-styles-provider.js.map +1 -1
  194. package/build-module/components/global-styles/screen-block.js +16 -0
  195. package/build-module/components/global-styles/screen-block.js.map +1 -1
  196. package/build-module/components/global-styles/screen-revisions/index.js +13 -6
  197. package/build-module/components/global-styles/screen-revisions/index.js.map +1 -1
  198. package/build-module/components/global-styles/screen-revisions/revisions-buttons.js +10 -22
  199. package/build-module/components/global-styles/screen-revisions/revisions-buttons.js.map +1 -1
  200. package/build-module/components/global-styles/screen-revisions/use-global-styles-revisions.js +28 -21
  201. package/build-module/components/global-styles/screen-revisions/use-global-styles-revisions.js.map +1 -1
  202. package/build-module/components/global-styles/style-variations-container.js +5 -3
  203. package/build-module/components/global-styles/style-variations-container.js.map +1 -1
  204. package/build-module/components/header-edit-mode/document-actions/index.js +6 -4
  205. package/build-module/components/header-edit-mode/document-actions/index.js.map +1 -1
  206. package/build-module/components/header-edit-mode/index.js +13 -9
  207. package/build-module/components/header-edit-mode/index.js.map +1 -1
  208. package/build-module/components/keyboard-shortcuts/edit-mode.js +7 -5
  209. package/build-module/components/keyboard-shortcuts/edit-mode.js.map +1 -1
  210. package/build-module/components/layout/index.js +17 -5
  211. package/build-module/components/layout/index.js.map +1 -1
  212. package/build-module/components/page/index.js +3 -3
  213. package/build-module/components/page/index.js.map +1 -1
  214. package/build-module/components/page-actions/index.js +2 -2
  215. package/build-module/components/page-actions/index.js.map +1 -1
  216. package/build-module/components/page-actions/{delete-page-menu-item.js → trash-page-menu-item.js} +8 -17
  217. package/build-module/components/page-actions/trash-page-menu-item.js.map +1 -0
  218. package/build-module/components/page-content-focus-manager/disable-non-page-content-blocks.js +5 -3
  219. package/build-module/components/page-content-focus-manager/disable-non-page-content-blocks.js.map +1 -1
  220. package/build-module/components/page-patterns/duplicate-menu-item.js +147 -0
  221. package/build-module/components/page-patterns/duplicate-menu-item.js.map +1 -0
  222. package/build-module/components/page-patterns/grid-item.js +84 -64
  223. package/build-module/components/page-patterns/grid-item.js.map +1 -1
  224. package/build-module/components/page-patterns/grid.js +5 -17
  225. package/build-module/components/page-patterns/grid.js.map +1 -1
  226. package/build-module/components/page-patterns/header.js +54 -0
  227. package/build-module/components/page-patterns/header.js.map +1 -0
  228. package/build-module/components/page-patterns/index.js +3 -1
  229. package/build-module/components/page-patterns/index.js.map +1 -1
  230. package/build-module/components/page-patterns/pagination.js +54 -0
  231. package/build-module/components/page-patterns/pagination.js.map +1 -0
  232. package/build-module/components/page-patterns/patterns-list.js +111 -34
  233. package/build-module/components/page-patterns/patterns-list.js.map +1 -1
  234. package/build-module/components/page-patterns/rename-menu-item.js +97 -0
  235. package/build-module/components/page-patterns/rename-menu-item.js.map +1 -0
  236. package/build-module/components/page-patterns/use-patterns.js +116 -119
  237. package/build-module/components/page-patterns/use-patterns.js.map +1 -1
  238. package/build-module/components/page-template-parts/add-new-template-part.js +58 -0
  239. package/build-module/components/page-template-parts/add-new-template-part.js.map +1 -0
  240. package/build-module/components/page-template-parts/index.js +4 -24
  241. package/build-module/components/page-template-parts/index.js.map +1 -1
  242. package/build-module/components/page-templates/index.js +2 -15
  243. package/build-module/components/page-templates/index.js.map +1 -1
  244. package/build-module/components/resizable-frame/index.js +87 -55
  245. package/build-module/components/resizable-frame/index.js.map +1 -1
  246. package/build-module/components/save-button/index.js +4 -2
  247. package/build-module/components/save-button/index.js.map +1 -1
  248. package/build-module/components/save-hub/index.js +10 -4
  249. package/build-module/components/save-hub/index.js.map +1 -1
  250. package/build-module/components/save-panel/index.js +5 -5
  251. package/build-module/components/save-panel/index.js.map +1 -1
  252. package/build-module/components/sidebar-edit-mode/page-panels/page-content.js +5 -2
  253. package/build-module/components/sidebar-edit-mode/page-panels/page-content.js.map +1 -1
  254. package/build-module/components/sidebar-edit-mode/page-panels/page-status.js +3 -8
  255. package/build-module/components/sidebar-edit-mode/page-panels/page-status.js.map +1 -1
  256. package/build-module/components/sidebar-edit-mode/template-panel/index.js +15 -9
  257. package/build-module/components/sidebar-edit-mode/template-panel/index.js.map +1 -1
  258. package/build-module/components/sidebar-navigation-screen/index.js +29 -16
  259. package/build-module/components/sidebar-navigation-screen/index.js.map +1 -1
  260. package/build-module/components/sidebar-navigation-screen-global-styles/index.js +34 -40
  261. package/build-module/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  262. package/build-module/components/sidebar-navigation-screen-main/index.js +4 -3
  263. package/build-module/components/sidebar-navigation-screen-main/index.js.map +1 -1
  264. package/build-module/components/sidebar-navigation-screen-main/template-part-hint.js +33 -0
  265. package/build-module/components/sidebar-navigation-screen-main/template-part-hint.js.map +1 -0
  266. package/build-module/components/sidebar-navigation-screen-navigation-menu/index.js +4 -4
  267. package/build-module/components/sidebar-navigation-screen-navigation-menu/index.js.map +1 -1
  268. package/build-module/components/sidebar-navigation-screen-navigation-menu/more-menu.js +1 -0
  269. package/build-module/components/sidebar-navigation-screen-navigation-menu/more-menu.js.map +1 -1
  270. package/build-module/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js +3 -3
  271. package/build-module/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js.map +1 -1
  272. package/build-module/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js +5 -4
  273. package/build-module/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js.map +1 -1
  274. package/build-module/components/sidebar-navigation-screen-navigation-menus/constants.js +2 -0
  275. package/build-module/components/sidebar-navigation-screen-navigation-menus/constants.js.map +1 -1
  276. package/build-module/components/sidebar-navigation-screen-navigation-menus/index.js +4 -4
  277. package/build-module/components/sidebar-navigation-screen-navigation-menus/index.js.map +1 -1
  278. package/build-module/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js +7 -0
  279. package/build-module/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js.map +1 -1
  280. package/build-module/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js +2 -2
  281. package/build-module/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js.map +1 -1
  282. package/build-module/components/sidebar-navigation-screen-page/index.js +2 -3
  283. package/build-module/components/sidebar-navigation-screen-page/index.js.map +1 -1
  284. package/build-module/components/sidebar-navigation-screen-page/status-label.js +1 -32
  285. package/build-module/components/sidebar-navigation-screen-page/status-label.js.map +1 -1
  286. package/build-module/components/sidebar-navigation-screen-pages/index.js +35 -25
  287. package/build-module/components/sidebar-navigation-screen-pages/index.js.map +1 -1
  288. package/build-module/components/sidebar-navigation-screen-pattern/index.js +8 -7
  289. package/build-module/components/sidebar-navigation-screen-pattern/index.js.map +1 -1
  290. package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js +4 -3
  291. package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js.map +1 -1
  292. package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menus.js +3 -2
  293. package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menus.js.map +1 -1
  294. package/build-module/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js +18 -4
  295. package/build-module/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js.map +1 -1
  296. package/build-module/components/sidebar-navigation-screen-pattern/use-pattern-details.js +53 -28
  297. package/build-module/components/sidebar-navigation-screen-pattern/use-pattern-details.js.map +1 -1
  298. package/build-module/components/sidebar-navigation-screen-patterns/category-item.js +0 -5
  299. package/build-module/components/sidebar-navigation-screen-patterns/category-item.js.map +1 -1
  300. package/build-module/components/sidebar-navigation-screen-patterns/index.js +76 -60
  301. package/build-module/components/sidebar-navigation-screen-patterns/index.js.map +1 -1
  302. package/build-module/components/sidebar-navigation-screen-patterns/use-my-patterns.js +9 -5
  303. package/build-module/components/sidebar-navigation-screen-patterns/use-my-patterns.js.map +1 -1
  304. package/build-module/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +10 -1
  305. package/build-module/components/sidebar-navigation-screen-patterns/use-pattern-categories.js.map +1 -1
  306. package/build-module/components/sidebar-navigation-screen-patterns/use-template-part-areas.js +18 -9
  307. package/build-module/components/sidebar-navigation-screen-patterns/use-template-part-areas.js.map +1 -1
  308. package/build-module/components/sidebar-navigation-screen-patterns/use-theme-patterns.js +1 -1
  309. package/build-module/components/sidebar-navigation-screen-patterns/use-theme-patterns.js.map +1 -1
  310. package/build-module/components/sidebar-navigation-screen-templates/index.js +1 -8
  311. package/build-module/components/sidebar-navigation-screen-templates/index.js.map +1 -1
  312. package/build-module/components/sidebar-navigation-screen-templates-browse/index.js +7 -0
  313. package/build-module/components/sidebar-navigation-screen-templates-browse/index.js.map +1 -1
  314. package/build-module/components/site-hub/index.js +28 -13
  315. package/build-module/components/site-hub/index.js.map +1 -1
  316. package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js +7 -5
  317. package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
  318. package/build-module/components/sync-state-with-url/use-sync-canvas-mode-with-url.js +1 -1
  319. package/build-module/components/sync-state-with-url/use-sync-canvas-mode-with-url.js.map +1 -1
  320. package/build-module/components/sync-state-with-url/use-sync-path-with-url.js +16 -12
  321. package/build-module/components/sync-state-with-url/use-sync-path-with-url.js.map +1 -1
  322. package/build-module/components/template-actions/index.js +2 -1
  323. package/build-module/components/template-actions/index.js.map +1 -1
  324. package/build-module/components/template-actions/rename-menu-item.js +11 -8
  325. package/build-module/components/template-actions/rename-menu-item.js.map +1 -1
  326. package/build-module/components/use-edited-entity-record/index.js +3 -1
  327. package/build-module/components/use-edited-entity-record/index.js.map +1 -1
  328. package/build-module/hooks/commands/use-common-commands.js +116 -32
  329. package/build-module/hooks/commands/use-common-commands.js.map +1 -1
  330. package/build-module/hooks/commands/use-edit-mode-commands.js +65 -9
  331. package/build-module/hooks/commands/use-edit-mode-commands.js.map +1 -1
  332. package/build-module/hooks/push-changes-to-global-styles/index.js +139 -57
  333. package/build-module/hooks/push-changes-to-global-styles/index.js.map +1 -1
  334. package/build-module/store/private-actions.js +9 -2
  335. package/build-module/store/private-actions.js.map +1 -1
  336. package/build-module/utils/normalize-record-key.js +12 -0
  337. package/build-module/utils/normalize-record-key.js.map +1 -0
  338. package/build-module/utils/use-activate-theme.js +1 -1
  339. package/build-module/utils/use-activate-theme.js.map +1 -1
  340. package/build-module/utils/use-debounced-input.js +5 -7
  341. package/build-module/utils/use-debounced-input.js.map +1 -1
  342. package/build-style/style-rtl.css +281 -103
  343. package/build-style/style.css +281 -103
  344. package/package.json +39 -40
  345. package/src/components/add-new-page/index.js +0 -3
  346. package/src/components/add-new-pattern/index.js +25 -12
  347. package/src/components/add-new-template/utils.js +9 -6
  348. package/src/components/block-editor/constants.js +5 -1
  349. package/src/components/block-editor/editor-canvas.js +1 -1
  350. package/src/components/block-editor/index.js +0 -4
  351. package/src/components/block-editor/use-site-editor-settings.js +119 -20
  352. package/src/components/canvas-spinner/style.scss +14 -0
  353. package/src/components/code-editor/index.js +51 -33
  354. package/src/components/create-pattern-modal/index.js +5 -2
  355. package/src/components/editor/index.js +5 -5
  356. package/src/components/global-styles/global-styles-provider.js +7 -2
  357. package/src/components/global-styles/screen-block.js +15 -0
  358. package/src/components/global-styles/screen-revisions/index.js +64 -58
  359. package/src/components/global-styles/screen-revisions/revisions-buttons.js +17 -31
  360. package/src/components/global-styles/screen-revisions/test/use-global-styles-revisions.js +14 -1
  361. package/src/components/global-styles/screen-revisions/use-global-styles-revisions.js +64 -48
  362. package/src/components/global-styles/style-variations-container.js +2 -0
  363. package/src/components/header-edit-mode/document-actions/index.js +8 -4
  364. package/src/components/header-edit-mode/document-actions/style.scss +45 -28
  365. package/src/components/header-edit-mode/index.js +29 -22
  366. package/src/components/keyboard-shortcuts/edit-mode.js +4 -5
  367. package/src/components/layout/index.js +49 -22
  368. package/src/components/layout/style.scss +4 -3
  369. package/src/components/page/index.js +8 -8
  370. package/src/components/page/style.scss +8 -5
  371. package/src/components/page-actions/index.js +2 -2
  372. package/src/components/page-actions/{delete-page-menu-item.js → trash-page-menu-item.js} +9 -22
  373. package/src/components/page-content-focus-manager/disable-non-page-content-blocks.js +12 -3
  374. package/src/components/page-patterns/duplicate-menu-item.js +196 -0
  375. package/src/components/page-patterns/grid-item.js +189 -133
  376. package/src/components/page-patterns/grid.js +3 -20
  377. package/src/components/page-patterns/header.js +69 -0
  378. package/src/components/page-patterns/index.js +6 -1
  379. package/src/components/page-patterns/pagination.js +80 -0
  380. package/src/components/page-patterns/patterns-list.js +172 -71
  381. package/src/components/page-patterns/rename-menu-item.js +115 -0
  382. package/src/components/page-patterns/style.scss +141 -30
  383. package/src/components/page-patterns/use-patterns.js +115 -169
  384. package/src/components/page-template-parts/add-new-template-part.js +57 -0
  385. package/src/components/page-template-parts/index.js +3 -23
  386. package/src/components/page-templates/index.js +6 -19
  387. package/src/components/resizable-frame/index.js +104 -51
  388. package/src/components/resizable-frame/style.scss +9 -9
  389. package/src/components/save-button/index.js +2 -0
  390. package/src/components/save-hub/index.js +6 -1
  391. package/src/components/save-hub/style.scss +1 -1
  392. package/src/components/save-panel/index.js +10 -4
  393. package/src/components/sidebar-edit-mode/page-panels/page-content.js +7 -5
  394. package/src/components/sidebar-edit-mode/page-panels/page-status.js +2 -5
  395. package/src/components/sidebar-edit-mode/template-panel/index.js +15 -11
  396. package/src/components/sidebar-navigation-item/style.scss +5 -12
  397. package/src/components/sidebar-navigation-screen/index.js +30 -15
  398. package/src/components/sidebar-navigation-screen/style.scss +18 -0
  399. package/src/components/sidebar-navigation-screen-details-panel/style.scss +1 -0
  400. package/src/components/sidebar-navigation-screen-global-styles/index.js +48 -44
  401. package/src/components/sidebar-navigation-screen-main/index.js +44 -40
  402. package/src/components/sidebar-navigation-screen-main/template-part-hint.js +34 -0
  403. package/src/components/sidebar-navigation-screen-navigation-menu/index.js +4 -3
  404. package/src/components/sidebar-navigation-screen-navigation-menu/more-menu.js +1 -0
  405. package/src/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js +1 -1
  406. package/src/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js +16 -7
  407. package/src/components/sidebar-navigation-screen-navigation-menus/constants.js +2 -0
  408. package/src/components/sidebar-navigation-screen-navigation-menus/index.js +4 -4
  409. package/src/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js +27 -15
  410. package/src/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js +1 -4
  411. package/src/components/sidebar-navigation-screen-page/index.js +3 -3
  412. package/src/components/sidebar-navigation-screen-page/status-label.js +1 -35
  413. package/src/components/sidebar-navigation-screen-pages/index.js +48 -33
  414. package/src/components/sidebar-navigation-screen-pattern/index.js +5 -2
  415. package/src/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js +3 -2
  416. package/src/components/sidebar-navigation-screen-pattern/template-part-navigation-menus.js +2 -1
  417. package/src/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js +23 -3
  418. package/src/components/sidebar-navigation-screen-pattern/use-pattern-details.js +74 -43
  419. package/src/components/sidebar-navigation-screen-patterns/category-item.js +5 -13
  420. package/src/components/sidebar-navigation-screen-patterns/index.js +103 -106
  421. package/src/components/sidebar-navigation-screen-patterns/style.scss +20 -0
  422. package/src/components/sidebar-navigation-screen-patterns/use-my-patterns.js +7 -6
  423. package/src/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +9 -0
  424. package/src/components/sidebar-navigation-screen-patterns/use-template-part-areas.js +31 -9
  425. package/src/components/sidebar-navigation-screen-patterns/use-theme-patterns.js +2 -1
  426. package/src/components/sidebar-navigation-screen-templates/index.js +1 -9
  427. package/src/components/sidebar-navigation-screen-templates-browse/index.js +10 -0
  428. package/src/components/site-hub/index.js +48 -29
  429. package/src/components/site-hub/style.scss +14 -2
  430. package/src/components/sync-state-with-url/use-init-edited-entity-from-url.js +8 -2
  431. package/src/components/sync-state-with-url/use-sync-canvas-mode-with-url.js +1 -4
  432. package/src/components/sync-state-with-url/use-sync-path-with-url.js +73 -66
  433. package/src/components/table/style.scss +1 -0
  434. package/src/components/template-actions/index.js +2 -1
  435. package/src/components/template-actions/rename-menu-item.js +17 -10
  436. package/src/components/use-edited-entity-record/index.js +6 -1
  437. package/src/hooks/commands/use-common-commands.js +105 -32
  438. package/src/hooks/commands/use-edit-mode-commands.js +94 -23
  439. package/src/hooks/push-changes-to-global-styles/index.js +141 -50
  440. package/src/store/private-actions.js +10 -2
  441. package/src/style.scss +10 -12
  442. package/src/utils/normalize-record-key.js +11 -0
  443. package/src/utils/use-activate-theme.js +1 -1
  444. package/src/utils/use-debounced-input.js +8 -7
  445. package/build/components/code-editor/code-editor-text-area.js +0 -96
  446. package/build/components/code-editor/code-editor-text-area.js.map +0 -1
  447. package/build/components/keyboard-shortcuts/index.js +0 -148
  448. package/build/components/keyboard-shortcuts/index.js.map +0 -1
  449. package/build/components/page-actions/delete-page-menu-item.js.map +0 -1
  450. package/build/components/page-content-focus-manager/constants.js +0 -9
  451. package/build/components/page-content-focus-manager/constants.js.map +0 -1
  452. package/build-module/components/code-editor/code-editor-text-area.js +0 -84
  453. package/build-module/components/code-editor/code-editor-text-area.js.map +0 -1
  454. package/build-module/components/keyboard-shortcuts/index.js +0 -132
  455. package/build-module/components/keyboard-shortcuts/index.js.map +0 -1
  456. package/build-module/components/page-actions/delete-page-menu-item.js.map +0 -1
  457. package/build-module/components/page-content-focus-manager/constants.js +0 -2
  458. package/build-module/components/page-content-focus-manager/constants.js.map +0 -1
  459. package/src/components/code-editor/code-editor-text-area.js +0 -84
  460. package/src/components/keyboard-shortcuts/index.js +0 -137
  461. package/src/components/page-content-focus-manager/constants.js +0 -5
@@ -61,12 +61,15 @@ const {
61
61
  useHasDimensionsPanel,
62
62
  useHasTypographyPanel,
63
63
  useHasBorderPanel,
64
+ __experimentalUseHasBehaviorsPanel: useHasBehaviorsPanel,
64
65
  useGlobalSetting,
65
66
  useSettingsForBlockElement,
66
67
  useHasColorPanel,
67
68
  useHasEffectsPanel,
68
69
  useHasFiltersPanel,
69
70
  useGlobalStyle,
71
+ __experimentalUseGlobalBehaviors: useGlobalBehaviors,
72
+ __experimentalBehaviorsPanel: StylesBehaviorsPanel,
70
73
  BorderPanel: StylesBorderPanel,
71
74
  ColorPanel: StylesColorPanel,
72
75
  TypographyPanel: StylesTypographyPanel,
@@ -91,10 +94,14 @@ function ScreenBlock( { name, variation } ) {
91
94
  } );
92
95
  const [ rawSettings, setSettings ] = useGlobalSetting( '', name );
93
96
  const settings = useSettingsForBlockElement( rawSettings, name );
97
+ const { inheritedBehaviors, setBehavior } = useGlobalBehaviors( name );
98
+ const { behavior } = useGlobalBehaviors( name, 'user' );
99
+
94
100
  const blockType = getBlockType( name );
95
101
  const blockVariations = useBlockVariations( name );
96
102
  const hasTypographyPanel = useHasTypographyPanel( settings );
97
103
  const hasColorPanel = useHasColorPanel( settings );
104
+ const hasBehaviorsPanel = useHasBehaviorsPanel( rawSettings, name );
98
105
  const hasBorderPanel = useHasBorderPanel( settings );
99
106
  const hasDimensionsPanel = useHasDimensionsPanel( settings );
100
107
  const hasEffectsPanel = useHasEffectsPanel( settings );
@@ -267,6 +274,14 @@ function ScreenBlock( { name, variation } ) {
267
274
  onChange={ setStyle }
268
275
  inheritedValue={ inheritedStyle }
269
276
  />
277
+ { hasBehaviorsPanel && (
278
+ <StylesBehaviorsPanel
279
+ value={ behavior }
280
+ onChange={ setBehavior }
281
+ behaviors={ inheritedBehaviors }
282
+ blockName={ name }
283
+ ></StylesBehaviorsPanel>
284
+ ) }
270
285
  </PanelBody>
271
286
  ) }
272
287
  </>
@@ -7,6 +7,7 @@ import {
7
7
  __experimentalUseNavigator as useNavigator,
8
8
  __experimentalConfirmDialog as ConfirmDialog,
9
9
  Spinner,
10
+ __experimentalSpacer as Spacer,
10
11
  } from '@wordpress/components';
11
12
  import { useSelect, useDispatch } from '@wordpress/data';
12
13
  import { useContext, useState, useEffect } from '@wordpress/element';
@@ -70,6 +71,7 @@ function ScreenRevisions() {
70
71
  setUserConfig( () => ( {
71
72
  styles: revision?.styles,
72
73
  settings: revision?.settings,
74
+ behaviors: revision?.behaviors,
73
75
  } ) );
74
76
  setIsLoadingRevisionWithUnsavedChanges( false );
75
77
  onCloseRevisions();
@@ -79,6 +81,7 @@ function ScreenRevisions() {
79
81
  setGlobalStylesRevision( {
80
82
  styles: revision?.styles,
81
83
  settings: revision?.settings,
84
+ behaviors: revision?.behaviors,
82
85
  id: revision?.id,
83
86
  } );
84
87
  setSelectedRevisionId( revision?.id );
@@ -87,6 +90,7 @@ function ScreenRevisions() {
87
90
  const isLoadButtonEnabled =
88
91
  !! globalStylesRevision?.id &&
89
92
  ! areGlobalStyleConfigsEqual( globalStylesRevision, userConfig );
93
+ const shouldShowRevisions = ! isLoading && revisions.length;
90
94
 
91
95
  return (
92
96
  <>
@@ -99,68 +103,70 @@ function ScreenRevisions() {
99
103
  { isLoading && (
100
104
  <Spinner className="edit-site-global-styles-screen-revisions__loading" />
101
105
  ) }
102
- { ! isLoading && (
103
- <Revisions
104
- blocks={ blocks }
105
- userConfig={ globalStylesRevision }
106
- onClose={ onCloseRevisions }
107
- />
108
- ) }
109
- <div className="edit-site-global-styles-screen-revisions">
110
- <RevisionsButtons
111
- onChange={ selectRevision }
112
- selectedRevisionId={ selectedRevisionId }
113
- userRevisions={ revisions }
114
- />
115
- { isLoadButtonEnabled && (
116
- <SidebarFixedBottom>
117
- <Button
118
- variant="primary"
119
- className="edit-site-global-styles-screen-revisions__button"
120
- disabled={
121
- ! globalStylesRevision?.id ||
122
- globalStylesRevision?.id === 'unsaved'
106
+ { shouldShowRevisions ? (
107
+ <>
108
+ <Revisions
109
+ blocks={ blocks }
110
+ userConfig={ globalStylesRevision }
111
+ onClose={ onCloseRevisions }
112
+ />
113
+ <div className="edit-site-global-styles-screen-revisions">
114
+ <RevisionsButtons
115
+ onChange={ selectRevision }
116
+ selectedRevisionId={ selectedRevisionId }
117
+ userRevisions={ revisions }
118
+ />
119
+ { isLoadButtonEnabled && (
120
+ <SidebarFixedBottom>
121
+ <Button
122
+ variant="primary"
123
+ className="edit-site-global-styles-screen-revisions__button"
124
+ disabled={
125
+ ! globalStylesRevision?.id ||
126
+ globalStylesRevision?.id === 'unsaved'
127
+ }
128
+ onClick={ () => {
129
+ if ( hasUnsavedChanges ) {
130
+ setIsLoadingRevisionWithUnsavedChanges(
131
+ true
132
+ );
133
+ } else {
134
+ restoreRevision(
135
+ globalStylesRevision
136
+ );
137
+ }
138
+ } }
139
+ >
140
+ { __( 'Apply' ) }
141
+ </Button>
142
+ </SidebarFixedBottom>
143
+ ) }
144
+ </div>
145
+ { isLoadingRevisionWithUnsavedChanges && (
146
+ <ConfirmDialog
147
+ isOpen={ isLoadingRevisionWithUnsavedChanges }
148
+ confirmButtonText={ __( 'Apply' ) }
149
+ onConfirm={ () =>
150
+ restoreRevision( globalStylesRevision )
151
+ }
152
+ onCancel={ () =>
153
+ setIsLoadingRevisionWithUnsavedChanges( false )
123
154
  }
124
- onClick={ () => {
125
- if ( hasUnsavedChanges ) {
126
- setIsLoadingRevisionWithUnsavedChanges(
127
- true
128
- );
129
- } else {
130
- restoreRevision( globalStylesRevision );
131
- }
132
- } }
133
155
  >
134
- { __( 'Apply' ) }
135
- </Button>
136
- </SidebarFixedBottom>
137
- ) }
138
- </div>
139
- { isLoadingRevisionWithUnsavedChanges && (
140
- <ConfirmDialog
141
- title={ __(
142
- 'Loading this revision will discard all unsaved changes.'
143
- ) }
144
- isOpen={ isLoadingRevisionWithUnsavedChanges }
145
- confirmButtonText={ __( ' Discard unsaved changes' ) }
146
- onConfirm={ () => restoreRevision( globalStylesRevision ) }
147
- onCancel={ () =>
148
- setIsLoadingRevisionWithUnsavedChanges( false )
149
- }
150
- >
151
- <>
152
- <h2>
153
156
  { __(
154
- 'Loading this revision will discard all unsaved changes.'
157
+ 'Any unsaved changes will be lost when you apply this revision.'
155
158
  ) }
156
- </h2>
157
- <p>
158
- { __(
159
- 'Do you want to replace your unsaved changes in the editor?'
160
- ) }
161
- </p>
162
- </>
163
- </ConfirmDialog>
159
+ </ConfirmDialog>
160
+ ) }
161
+ </>
162
+ ) : (
163
+ <Spacer marginX={ 4 } data-testid="global-styles-no-revisions">
164
+ {
165
+ // Adding an existing translation here in case these changes are shipped to WordPress 6.3.
166
+ // Later we could update to something better, e.g., "There are currently no style revisions.".
167
+ __( 'No results found.' )
168
+ }
169
+ </Spacer>
164
170
  ) }
165
171
  </>
166
172
  );
@@ -21,11 +21,9 @@ function getRevisionLabel( revision ) {
21
21
 
22
22
  if ( 'unsaved' === revision?.id ) {
23
23
  return sprintf(
24
- /* translators: %(name)s author display name */
25
- __( 'Unsaved changes by %(name)s' ),
26
- {
27
- name: authorDisplayName,
28
- }
24
+ /* translators: %s author display name */
25
+ __( 'Unsaved changes by %s' ),
26
+ authorDisplayName
29
27
  );
30
28
  }
31
29
  const formattedDate = dateI18n(
@@ -35,20 +33,16 @@ function getRevisionLabel( revision ) {
35
33
 
36
34
  return revision?.isLatest
37
35
  ? sprintf(
38
- /* translators: %(name)s author display name, %(date)s: revision creation date */
39
- __( 'Changes saved by %(name)s on %(date)s (current)' ),
40
- {
41
- name: authorDisplayName,
42
- date: formattedDate,
43
- }
36
+ /* translators: %1$s author display name, %2$s: revision creation date */
37
+ __( 'Changes saved by %1$s on %2$s (current)' ),
38
+ authorDisplayName,
39
+ formattedDate
44
40
  )
45
41
  : sprintf(
46
- /* translators: %(name)s author display name, %(date)s: revision creation date */
47
- __( 'Changes saved by %(name)s on %(date)s' ),
48
- {
49
- name: authorDisplayName,
50
- date: formattedDate,
51
- }
42
+ /* translators: %1$s author display name, %2$s: revision creation date */
43
+ __( 'Changes saved by %1$s on %2$s' ),
44
+ authorDisplayName,
45
+ formattedDate
52
46
  );
53
47
  }
54
48
 
@@ -104,22 +98,14 @@ function RevisionsButtons( { userRevisions, selectedRevisionId, onChange } ) {
104
98
  <span className="edit-site-global-styles-screen-revisions__meta">
105
99
  { isUnsaved
106
100
  ? sprintf(
107
- /* translators: %(name)s author display name */
108
- __(
109
- 'Unsaved changes by %(name)s'
110
- ),
111
- {
112
- name: authorDisplayName,
113
- }
101
+ /* translators: %s author display name */
102
+ __( 'Unsaved changes by %s' ),
103
+ authorDisplayName
114
104
  )
115
105
  : sprintf(
116
- /* translators: %(name)s author display name */
117
- __(
118
- 'Changes saved by %(name)s'
119
- ),
120
- {
121
- name: authorDisplayName,
122
- }
106
+ /* translators: %s author display name */
107
+ __( 'Changes saved by %s' ),
108
+ authorDisplayName
123
109
  ) }
124
110
 
125
111
  <img
@@ -49,6 +49,7 @@ describe( 'useGlobalStylesRevisions', () => {
49
49
  styles: {},
50
50
  },
51
51
  ],
52
+ isLoadingGlobalStylesRevisions: false,
52
53
  };
53
54
 
54
55
  it( 'returns loaded revisions with no unsaved changes', () => {
@@ -117,11 +118,23 @@ describe( 'useGlobalStylesRevisions', () => {
117
118
  const { result } = renderHook( () => useGlobalStylesRevisions() );
118
119
  const { revisions, isLoading, hasUnsavedChanges } = result.current;
119
120
 
120
- expect( isLoading ).toBe( true );
121
+ expect( isLoading ).toBe( false );
121
122
  expect( hasUnsavedChanges ).toBe( false );
122
123
  expect( revisions ).toEqual( [] );
123
124
  } );
124
125
 
126
+ it( 'returns loading status when resolving global revisions', () => {
127
+ useSelect.mockImplementation( () => ( {
128
+ ...selectValue,
129
+ isLoadingGlobalStylesRevisions: true,
130
+ } ) );
131
+
132
+ const { result } = renderHook( () => useGlobalStylesRevisions() );
133
+ const { isLoading } = result.current;
134
+
135
+ expect( isLoading ).toBe( true );
136
+ } );
137
+
125
138
  it( 'returns empty revisions when authors are not yet available', () => {
126
139
  useSelect.mockImplementation( () => ( {
127
140
  ...selectValue,
@@ -21,34 +21,40 @@ const EMPTY_ARRAY = [];
21
21
  const { GlobalStylesContext } = unlock( blockEditorPrivateApis );
22
22
  export default function useGlobalStylesRevisions() {
23
23
  const { user: userConfig } = useContext( GlobalStylesContext );
24
- const { authors, currentUser, isDirty, revisions } = useSelect(
25
- ( select ) => {
26
- const {
27
- __experimentalGetDirtyEntityRecords,
28
- getCurrentUser,
29
- getUsers,
30
- getCurrentThemeGlobalStylesRevisions,
31
- } = select( coreStore );
32
- const dirtyEntityRecords = __experimentalGetDirtyEntityRecords();
33
- const _currentUser = getCurrentUser();
34
- const _isDirty = dirtyEntityRecords.length > 0;
35
- const globalStylesRevisions =
36
- getCurrentThemeGlobalStylesRevisions() || EMPTY_ARRAY;
37
- const _authors =
38
- getUsers( SITE_EDITOR_AUTHORS_QUERY ) || EMPTY_ARRAY;
24
+ const {
25
+ authors,
26
+ currentUser,
27
+ isDirty,
28
+ revisions,
29
+ isLoadingGlobalStylesRevisions,
30
+ } = useSelect( ( select ) => {
31
+ const {
32
+ __experimentalGetDirtyEntityRecords,
33
+ getCurrentUser,
34
+ getUsers,
35
+ getCurrentThemeGlobalStylesRevisions,
36
+ isResolving,
37
+ } = select( coreStore );
38
+ const dirtyEntityRecords = __experimentalGetDirtyEntityRecords();
39
+ const _currentUser = getCurrentUser();
40
+ const _isDirty = dirtyEntityRecords.length > 0;
41
+ const globalStylesRevisions =
42
+ getCurrentThemeGlobalStylesRevisions() || EMPTY_ARRAY;
43
+ const _authors = getUsers( SITE_EDITOR_AUTHORS_QUERY ) || EMPTY_ARRAY;
39
44
 
40
- return {
41
- authors: _authors,
42
- currentUser: _currentUser,
43
- isDirty: _isDirty,
44
- revisions: globalStylesRevisions,
45
- };
46
- },
47
- []
48
- );
45
+ return {
46
+ authors: _authors,
47
+ currentUser: _currentUser,
48
+ isDirty: _isDirty,
49
+ revisions: globalStylesRevisions,
50
+ isLoadingGlobalStylesRevisions: isResolving(
51
+ 'getCurrentThemeGlobalStylesRevisions'
52
+ ),
53
+ };
54
+ }, [] );
49
55
  return useMemo( () => {
50
56
  let _modifiedRevisions = [];
51
- if ( ! authors.length || ! revisions.length ) {
57
+ if ( ! authors.length || isLoadingGlobalStylesRevisions ) {
52
58
  return {
53
59
  revisions: _modifiedRevisions,
54
60
  hasUnsavedChanges: isDirty,
@@ -66,30 +72,33 @@ export default function useGlobalStylesRevisions() {
66
72
  };
67
73
  } );
68
74
 
69
- // Flags the most current saved revision.
70
- if ( _modifiedRevisions[ 0 ].id !== 'unsaved' ) {
71
- _modifiedRevisions[ 0 ].isLatest = true;
72
- }
75
+ if ( _modifiedRevisions.length ) {
76
+ // Flags the most current saved revision.
77
+ if ( _modifiedRevisions[ 0 ].id !== 'unsaved' ) {
78
+ _modifiedRevisions[ 0 ].isLatest = true;
79
+ }
73
80
 
74
- // Adds an item for unsaved changes.
75
- if (
76
- isDirty &&
77
- userConfig &&
78
- Object.keys( userConfig ).length > 0 &&
79
- currentUser
80
- ) {
81
- const unsavedRevision = {
82
- id: 'unsaved',
83
- styles: userConfig?.styles,
84
- settings: userConfig?.settings,
85
- author: {
86
- name: currentUser?.name,
87
- avatar_urls: currentUser?.avatar_urls,
88
- },
89
- modified: new Date(),
90
- };
81
+ // Adds an item for unsaved changes.
82
+ if (
83
+ isDirty &&
84
+ userConfig &&
85
+ Object.keys( userConfig ).length > 0 &&
86
+ currentUser
87
+ ) {
88
+ const unsavedRevision = {
89
+ id: 'unsaved',
90
+ styles: userConfig?.styles,
91
+ settings: userConfig?.settings,
92
+ behaviors: userConfig?.behaviors,
93
+ author: {
94
+ name: currentUser?.name,
95
+ avatar_urls: currentUser?.avatar_urls,
96
+ },
97
+ modified: new Date(),
98
+ };
91
99
 
92
- _modifiedRevisions.unshift( unsavedRevision );
100
+ _modifiedRevisions.unshift( unsavedRevision );
101
+ }
93
102
  }
94
103
 
95
104
  return {
@@ -97,5 +106,12 @@ export default function useGlobalStylesRevisions() {
97
106
  hasUnsavedChanges: isDirty,
98
107
  isLoading: false,
99
108
  };
100
- }, [ isDirty, revisions, currentUser, authors, userConfig ] );
109
+ }, [
110
+ isDirty,
111
+ revisions,
112
+ currentUser,
113
+ authors,
114
+ userConfig,
115
+ isLoadingGlobalStylesRevisions,
116
+ ] );
101
117
  }
@@ -113,11 +113,13 @@ export default function StyleVariationsContainer() {
113
113
  title: __( 'Default' ),
114
114
  settings: {},
115
115
  styles: {},
116
+ behaviors: {},
116
117
  },
117
118
  ...( variations ?? [] ).map( ( variation ) => ( {
118
119
  ...variation,
119
120
  settings: variation.settings ?? {},
120
121
  styles: variation.styles ?? {},
122
+ behaviors: variation.behaviors ?? {},
121
123
  } ) ),
122
124
  ];
123
125
  }, [ variations ] );
@@ -6,7 +6,7 @@ import classnames from 'classnames';
6
6
  /**
7
7
  * WordPress dependencies
8
8
  */
9
- import { sprintf, __ } from '@wordpress/i18n';
9
+ import { sprintf, __, isRTL } from '@wordpress/i18n';
10
10
  import { useSelect, useDispatch } from '@wordpress/data';
11
11
  import {
12
12
  Button,
@@ -17,7 +17,8 @@ import {
17
17
  import { BlockIcon } from '@wordpress/block-editor';
18
18
  import { store as commandsStore } from '@wordpress/commands';
19
19
  import {
20
- chevronLeftSmall as chevronLeftSmallIcon,
20
+ chevronLeftSmall,
21
+ chevronRightSmall,
21
22
  page as pageIcon,
22
23
  navigation as navigationIcon,
23
24
  symbol,
@@ -128,7 +129,10 @@ function TemplateDocumentActions( { className, onBack } ) {
128
129
 
129
130
  return (
130
131
  <BaseDocumentActions
131
- className={ className }
132
+ className={ classnames( className, {
133
+ 'is-synced-entity':
134
+ record.wp_pattern_sync_status !== 'unsynced',
135
+ } ) }
132
136
  icon={ typeIcon }
133
137
  onBack={ onBack }
134
138
  >
@@ -153,7 +157,7 @@ function BaseDocumentActions( { className, icon, children, onBack } ) {
153
157
  { onBack && (
154
158
  <Button
155
159
  className="edit-site-document-actions__back"
156
- icon={ chevronLeftSmallIcon }
160
+ icon={ isRTL() ? chevronRightSmall : chevronLeftSmall }
157
161
  onClick={ ( event ) => {
158
162
  event.stopPropagation();
159
163
  onBack();
@@ -1,20 +1,29 @@
1
1
  .edit-site-document-actions {
2
- display: grid;
3
- grid-template-columns: 1fr 2fr 1fr;
2
+ display: flex;
3
+ align-items: center;
4
4
  height: $button-size;
5
+ justify-content: space-between;
5
6
  // Flex items will, by default, refuse to shrink below a minimum
6
7
  // intrinsic width. In order to shrink this flexbox item, and
7
8
  // subsequently truncate child text, we set an explicit min-width.
8
9
  // See https://dev.w3.org/csswg/css-flexbox/#min-size-auto
9
10
  min-width: 0;
10
11
  background: $gray-100;
11
- border-radius: 4px;
12
+ border-radius: $grid-unit-05;
12
13
  width: min(100%, 450px);
13
- overflow: hidden;
14
14
 
15
- &:hover {
16
- color: currentColor;
17
- background: $gray-200;
15
+ // Make the document title shorter in top-toolbar mode, as it has to be covered.
16
+ .has-fixed-toolbar & {
17
+ width: min(100%, 380px);
18
+ }
19
+
20
+ .components-button {
21
+ border-radius: $grid-unit-05;
22
+
23
+ &:hover {
24
+ color: var(--wp-block-synced-color);
25
+ background: $gray-200;
26
+ }
18
27
  }
19
28
 
20
29
  @include break-medium() {
@@ -24,27 +33,40 @@
24
33
  @include break-large() {
25
34
  width: min(100%, 450px);
26
35
  }
36
+
37
+ &.is-synced-entity {
38
+ .edit-site-document-actions__title {
39
+ color: var(--wp-block-synced-color);
40
+ h1 {
41
+ color: var(--wp-block-synced-color);
42
+ }
43
+ }
44
+ }
27
45
  }
28
46
 
29
47
  .edit-site-document-actions__command {
30
- grid-column: 1 / -1;
31
- display: grid;
32
- grid-template-columns: 1fr 2fr 1fr;
33
- grid-row: 1;
48
+ flex-grow: 1;
49
+ color: var(--wp-block-synced-color);
50
+ overflow: hidden;
34
51
  }
35
52
 
36
-
37
53
  .edit-site-document-actions__title {
38
54
  flex-grow: 1;
39
- color: var(--wp-block-synced-color);
40
55
  overflow: hidden;
41
- grid-column: 2 / 3;
56
+
57
+ &:hover {
58
+ color: var(--wp-block-synced-color);
59
+ }
60
+
61
+ .block-editor-block-icon {
62
+ min-width: $grid-unit-30;
63
+ flex-shrink: 0;
64
+ }
42
65
 
43
66
  h1 {
44
67
  white-space: nowrap;
45
68
  overflow: hidden;
46
69
  text-overflow: ellipsis;
47
- color: var(--wp-block-synced-color);
48
70
  }
49
71
 
50
72
  .edit-site-document-actions.is-page & {
@@ -66,26 +88,21 @@
66
88
  }
67
89
  }
68
90
 
69
- .edit-site-document-actions__shortcut,
70
- .edit-site-document-actions__back {
71
- color: $gray-800;
72
-
73
- .edit-site-document-actions:hover & {
74
- color: $gray-900;
75
- }
76
- }
77
-
78
91
  .edit-site-document-actions__shortcut {
79
- text-align: right;
92
+ color: $gray-800;
80
93
  }
81
94
 
82
- .edit-site-document-actions__back {
95
+ .edit-site-document-actions__back.components-button.has-icon.has-text {
83
96
  min-width: $button-size;
84
97
  flex-shrink: 0;
85
- grid-column: 1 / 2;
86
- grid-row: 1;
98
+ color: $gray-700;
99
+ gap: 0;
87
100
  z-index: 1;
88
101
 
102
+ &:hover {
103
+ color: currentColor;
104
+ }
105
+
89
106
  .edit-site-document-actions.is-animated & {
90
107
  animation: edit-site-document-actions__slide-in-left 0.3s;
91
108
  @include reduce-motion("animation");