@wordpress/edit-site 5.10.0 → 5.11.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 (252) hide show
  1. package/CHANGELOG.md +2 -0
  2. package/build/components/add-new-template/{add-custom-generic-template-modal.js → add-custom-generic-template-modal-content.js} +7 -22
  3. package/build/components/add-new-template/add-custom-generic-template-modal-content.js.map +1 -0
  4. package/build/components/add-new-template/{add-custom-template-modal.js → add-custom-template-modal-content.js} +11 -21
  5. package/build/components/add-new-template/add-custom-template-modal-content.js.map +1 -0
  6. package/build/components/add-new-template/new-template.js +98 -65
  7. package/build/components/add-new-template/new-template.js.map +1 -1
  8. package/build/components/block-editor/index.js +1 -3
  9. package/build/components/block-editor/index.js.map +1 -1
  10. package/build/components/create-template-part-modal/index.js +6 -7
  11. package/build/components/create-template-part-modal/index.js.map +1 -1
  12. package/build/components/editor/index.js +15 -40
  13. package/build/components/editor/index.js.map +1 -1
  14. package/build/components/editor-canvas-container/index.js +10 -3
  15. package/build/components/editor-canvas-container/index.js.map +1 -1
  16. package/build/components/global-styles/screen-block.js +80 -3
  17. package/build/components/global-styles/screen-block.js.map +1 -1
  18. package/build/components/global-styles/screen-revisions/index.js +3 -10
  19. package/build/components/global-styles/screen-revisions/index.js.map +1 -1
  20. package/build/components/global-styles/screen-revisions/revisions-buttons.js +16 -18
  21. package/build/components/global-styles/screen-revisions/revisions-buttons.js.map +1 -1
  22. package/build/components/global-styles/screen-revisions/use-global-styles-revisions.js +15 -24
  23. package/build/components/global-styles/screen-revisions/use-global-styles-revisions.js.map +1 -1
  24. package/build/components/global-styles/screen-root.js +4 -4
  25. package/build/components/global-styles/screen-root.js.map +1 -1
  26. package/build/components/global-styles/style-variations-container.js +6 -10
  27. package/build/components/global-styles/style-variations-container.js.map +1 -1
  28. package/build/components/global-styles/ui.js +9 -9
  29. package/build/components/global-styles/ui.js.map +1 -1
  30. package/build/components/header-edit-mode/document-actions/index.js +28 -103
  31. package/build/components/header-edit-mode/document-actions/index.js.map +1 -1
  32. package/build/components/header-edit-mode/index.js +14 -1
  33. package/build/components/header-edit-mode/index.js.map +1 -1
  34. package/build/components/layout/hooks.js +54 -0
  35. package/build/components/layout/hooks.js.map +1 -0
  36. package/build/components/layout/index.js +45 -98
  37. package/build/components/layout/index.js.map +1 -1
  38. package/build/components/list/actions/index.js +5 -2
  39. package/build/components/list/actions/index.js.map +1 -1
  40. package/build/components/resizable-frame/index.js +242 -0
  41. package/build/components/resizable-frame/index.js.map +1 -0
  42. package/build/components/revisions/index.js +2 -1
  43. package/build/components/revisions/index.js.map +1 -1
  44. package/build/components/secondary-sidebar/list-view-sidebar.js +4 -3
  45. package/build/components/secondary-sidebar/list-view-sidebar.js.map +1 -1
  46. package/build/components/sidebar/index.js +4 -4
  47. package/build/components/sidebar/index.js.map +1 -1
  48. package/build/components/sidebar-edit-mode/template-revisions/index.js +1 -1
  49. package/build/components/sidebar-edit-mode/template-revisions/index.js.map +1 -1
  50. package/build/components/sidebar-navigation-screen-global-styles/index.js +75 -11
  51. package/build/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  52. package/build/components/sidebar-navigation-screen-main/index.js +24 -33
  53. package/build/components/sidebar-navigation-screen-main/index.js.map +1 -1
  54. package/build/components/sidebar-navigation-screen-navigation-menu/index.js +162 -0
  55. package/build/components/sidebar-navigation-screen-navigation-menu/index.js.map +1 -0
  56. package/build/components/sidebar-navigation-screen-navigation-menus/constants.js +17 -0
  57. package/build/components/sidebar-navigation-screen-navigation-menus/constants.js.map +1 -0
  58. package/build/components/sidebar-navigation-screen-navigation-menus/index.js +53 -103
  59. package/build/components/sidebar-navigation-screen-navigation-menus/index.js.map +1 -1
  60. package/build/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js +87 -0
  61. package/build/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js.map +1 -0
  62. package/build/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js +14 -71
  63. package/build/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js.map +1 -1
  64. package/build/components/sidebar-navigation-screen-navigation-menus/navigator-button.js +53 -0
  65. package/build/components/sidebar-navigation-screen-navigation-menus/navigator-button.js.map +1 -0
  66. package/build/components/sidebar-navigation-screen-templates/index.js +36 -11
  67. package/build/components/sidebar-navigation-screen-templates/index.js.map +1 -1
  68. package/build/components/site-hub/index.js +1 -3
  69. package/build/components/site-hub/index.js.map +1 -1
  70. package/build/components/style-book/index.js +93 -19
  71. package/build/components/style-book/index.js.map +1 -1
  72. package/build/components/use-edited-entity-record/index.js +8 -4
  73. package/build/components/use-edited-entity-record/index.js.map +1 -1
  74. package/build/hooks/commands/use-edit-mode-commands.js +105 -0
  75. package/build/hooks/commands/use-edit-mode-commands.js.map +1 -0
  76. package/build/store/actions.js +5 -3
  77. package/build/store/actions.js.map +1 -1
  78. package/build-module/components/add-new-template/{add-custom-generic-template-modal.js → add-custom-generic-template-modal-content.js} +8 -20
  79. package/build-module/components/add-new-template/add-custom-generic-template-modal-content.js.map +1 -0
  80. package/build-module/components/add-new-template/{add-custom-template-modal.js → add-custom-template-modal-content.js} +13 -22
  81. package/build-module/components/add-new-template/add-custom-template-modal-content.js.map +1 -0
  82. package/build-module/components/add-new-template/new-template.js +98 -67
  83. package/build-module/components/add-new-template/new-template.js.map +1 -1
  84. package/build-module/components/block-editor/index.js +1 -3
  85. package/build-module/components/block-editor/index.js.map +1 -1
  86. package/build-module/components/create-template-part-modal/index.js +7 -8
  87. package/build-module/components/create-template-part-modal/index.js.map +1 -1
  88. package/build-module/components/editor/index.js +16 -43
  89. package/build-module/components/editor/index.js.map +1 -1
  90. package/build-module/components/editor-canvas-container/index.js +7 -3
  91. package/build-module/components/editor-canvas-container/index.js.map +1 -1
  92. package/build-module/components/global-styles/screen-block.js +82 -4
  93. package/build-module/components/global-styles/screen-block.js.map +1 -1
  94. package/build-module/components/global-styles/screen-revisions/index.js +3 -10
  95. package/build-module/components/global-styles/screen-revisions/index.js.map +1 -1
  96. package/build-module/components/global-styles/screen-revisions/revisions-buttons.js +16 -19
  97. package/build-module/components/global-styles/screen-revisions/revisions-buttons.js.map +1 -1
  98. package/build-module/components/global-styles/screen-revisions/use-global-styles-revisions.js +15 -24
  99. package/build-module/components/global-styles/screen-revisions/use-global-styles-revisions.js.map +1 -1
  100. package/build-module/components/global-styles/screen-root.js +4 -4
  101. package/build-module/components/global-styles/screen-root.js.map +1 -1
  102. package/build-module/components/global-styles/style-variations-container.js +7 -11
  103. package/build-module/components/global-styles/style-variations-container.js.map +1 -1
  104. package/build-module/components/global-styles/ui.js +10 -10
  105. package/build-module/components/global-styles/ui.js.map +1 -1
  106. package/build-module/components/header-edit-mode/document-actions/index.js +31 -107
  107. package/build-module/components/header-edit-mode/document-actions/index.js.map +1 -1
  108. package/build-module/components/header-edit-mode/index.js +14 -2
  109. package/build-module/components/header-edit-mode/index.js.map +1 -1
  110. package/build-module/components/layout/hooks.js +41 -0
  111. package/build-module/components/layout/hooks.js.map +1 -0
  112. package/build-module/components/layout/index.js +46 -101
  113. package/build-module/components/layout/index.js.map +1 -1
  114. package/build-module/components/list/actions/index.js +6 -3
  115. package/build-module/components/list/actions/index.js.map +1 -1
  116. package/build-module/components/resizable-frame/index.js +228 -0
  117. package/build-module/components/resizable-frame/index.js.map +1 -0
  118. package/build-module/components/revisions/index.js +2 -1
  119. package/build-module/components/revisions/index.js.map +1 -1
  120. package/build-module/components/secondary-sidebar/list-view-sidebar.js +3 -3
  121. package/build-module/components/secondary-sidebar/list-view-sidebar.js.map +1 -1
  122. package/build-module/components/sidebar/index.js +3 -3
  123. package/build-module/components/sidebar/index.js.map +1 -1
  124. package/build-module/components/sidebar-edit-mode/template-revisions/index.js +1 -1
  125. package/build-module/components/sidebar-edit-mode/template-revisions/index.js.map +1 -1
  126. package/build-module/components/sidebar-navigation-screen-global-styles/index.js +70 -14
  127. package/build-module/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  128. package/build-module/components/sidebar-navigation-screen-main/index.js +21 -32
  129. package/build-module/components/sidebar-navigation-screen-main/index.js.map +1 -1
  130. package/build-module/components/sidebar-navigation-screen-navigation-menu/index.js +141 -0
  131. package/build-module/components/sidebar-navigation-screen-navigation-menu/index.js.map +1 -0
  132. package/build-module/components/sidebar-navigation-screen-navigation-menus/constants.js +10 -0
  133. package/build-module/components/sidebar-navigation-screen-navigation-menus/constants.js.map +1 -0
  134. package/build-module/components/sidebar-navigation-screen-navigation-menus/index.js +52 -103
  135. package/build-module/components/sidebar-navigation-screen-navigation-menus/index.js.map +1 -1
  136. package/build-module/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js +71 -0
  137. package/build-module/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js.map +1 -0
  138. package/build-module/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js +12 -71
  139. package/build-module/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js.map +1 -1
  140. package/build-module/components/sidebar-navigation-screen-navigation-menus/navigator-button.js +40 -0
  141. package/build-module/components/sidebar-navigation-screen-navigation-menus/navigator-button.js.map +1 -0
  142. package/build-module/components/sidebar-navigation-screen-templates/index.js +35 -11
  143. package/build-module/components/sidebar-navigation-screen-templates/index.js.map +1 -1
  144. package/build-module/components/site-hub/index.js +1 -3
  145. package/build-module/components/site-hub/index.js.map +1 -1
  146. package/build-module/components/style-book/index.js +93 -20
  147. package/build-module/components/style-book/index.js.map +1 -1
  148. package/build-module/components/use-edited-entity-record/index.js +8 -4
  149. package/build-module/components/use-edited-entity-record/index.js.map +1 -1
  150. package/build-module/hooks/commands/use-edit-mode-commands.js +86 -0
  151. package/build-module/hooks/commands/use-edit-mode-commands.js.map +1 -0
  152. package/build-module/store/actions.js +5 -3
  153. package/build-module/store/actions.js.map +1 -1
  154. package/build-style/style-rtl.css +233 -210
  155. package/build-style/style.css +234 -210
  156. package/package.json +37 -37
  157. package/src/components/add-new-template/add-custom-generic-template-modal-content.js +82 -0
  158. package/src/components/add-new-template/{add-custom-template-modal.js → add-custom-template-modal-content.js} +13 -26
  159. package/src/components/add-new-template/new-template.js +139 -153
  160. package/src/components/add-new-template/style.scss +79 -66
  161. package/src/components/block-editor/index.js +2 -3
  162. package/src/components/create-template-part-modal/index.js +19 -25
  163. package/src/components/editor/index.js +16 -45
  164. package/src/components/editor/style.scss +21 -6
  165. package/src/components/editor-canvas-container/index.js +28 -19
  166. package/src/components/global-styles/screen-block.js +74 -3
  167. package/src/components/global-styles/screen-revisions/index.js +3 -11
  168. package/src/components/global-styles/screen-revisions/revisions-buttons.js +33 -25
  169. package/src/components/global-styles/screen-revisions/style.scss +3 -2
  170. package/src/components/global-styles/screen-revisions/test/use-global-styles-revisions.js +16 -3
  171. package/src/components/global-styles/screen-revisions/use-global-styles-revisions.js +15 -19
  172. package/src/components/global-styles/screen-root.js +5 -3
  173. package/src/components/global-styles/style-variations-container.js +13 -18
  174. package/src/components/global-styles/style.scss +3 -0
  175. package/src/components/global-styles/ui.js +11 -9
  176. package/src/components/header-edit-mode/document-actions/index.js +26 -129
  177. package/src/components/header-edit-mode/document-actions/style.scss +28 -59
  178. package/src/components/header-edit-mode/index.js +18 -0
  179. package/src/components/header-edit-mode/style.scss +1 -0
  180. package/src/components/layout/hooks.js +46 -0
  181. package/src/components/layout/index.js +56 -125
  182. package/src/components/layout/style.scss +8 -2
  183. package/src/components/list/actions/index.js +12 -5
  184. package/src/components/list/style.scss +1 -0
  185. package/src/components/resizable-frame/index.js +253 -0
  186. package/src/components/resizable-frame/style.scss +69 -0
  187. package/src/components/revisions/index.js +1 -0
  188. package/src/components/secondary-sidebar/list-view-sidebar.js +2 -1
  189. package/src/components/sidebar/index.js +4 -4
  190. package/src/components/sidebar-edit-mode/template-revisions/index.js +1 -2
  191. package/src/components/sidebar-navigation-item/style.scss +9 -0
  192. package/src/components/sidebar-navigation-screen/style.scss +1 -2
  193. package/src/components/sidebar-navigation-screen-global-styles/index.js +106 -21
  194. package/src/components/sidebar-navigation-screen-main/index.js +35 -52
  195. package/src/components/sidebar-navigation-screen-navigation-menu/index.js +157 -0
  196. package/src/components/sidebar-navigation-screen-navigation-menus/constants.js +9 -0
  197. package/src/components/sidebar-navigation-screen-navigation-menus/index.js +63 -117
  198. package/src/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js +83 -0
  199. package/src/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js +6 -72
  200. package/src/components/sidebar-navigation-screen-navigation-menus/navigator-button.js +47 -0
  201. package/src/components/sidebar-navigation-screen-navigation-menus/style.scss +6 -20
  202. package/src/components/sidebar-navigation-screen-templates/index.js +53 -14
  203. package/src/components/site-hub/index.js +8 -9
  204. package/src/components/start-template-options/style.scss +20 -21
  205. package/src/components/style-book/index.js +132 -43
  206. package/src/components/style-book/style.scss +19 -0
  207. package/src/components/use-edited-entity-record/index.js +12 -3
  208. package/src/hooks/commands/use-edit-mode-commands.js +79 -0
  209. package/src/store/actions.js +4 -5
  210. package/src/store/test/utils.js +15 -5
  211. package/src/style.scss +1 -1
  212. package/build/components/add-new-template/add-custom-generic-template-modal.js.map +0 -1
  213. package/build/components/add-new-template/add-custom-template-modal.js.map +0 -1
  214. package/build/components/global-styles/border-panel.js +0 -135
  215. package/build/components/global-styles/border-panel.js.map +0 -1
  216. package/build/components/navigate-to-link/index.js +0 -51
  217. package/build/components/navigate-to-link/index.js.map +0 -1
  218. package/build/components/sidebar-navigation-screen-navigation-menus/loader.js +0 -19
  219. package/build/components/sidebar-navigation-screen-navigation-menus/loader.js.map +0 -1
  220. package/build/components/template-details/edit-template-title.js +0 -42
  221. package/build/components/template-details/edit-template-title.js.map +0 -1
  222. package/build/components/template-details/index.js +0 -103
  223. package/build/components/template-details/index.js.map +0 -1
  224. package/build/components/template-details/template-areas.js +0 -166
  225. package/build/components/template-details/template-areas.js.map +0 -1
  226. package/build/components/template-details/template-part-area-selector.js +0 -48
  227. package/build/components/template-details/template-part-area-selector.js.map +0 -1
  228. package/build-module/components/add-new-template/add-custom-generic-template-modal.js.map +0 -1
  229. package/build-module/components/add-new-template/add-custom-template-modal.js.map +0 -1
  230. package/build-module/components/global-styles/border-panel.js +0 -125
  231. package/build-module/components/global-styles/border-panel.js.map +0 -1
  232. package/build-module/components/navigate-to-link/index.js +0 -39
  233. package/build-module/components/navigate-to-link/index.js.map +0 -1
  234. package/build-module/components/sidebar-navigation-screen-navigation-menus/loader.js +0 -11
  235. package/build-module/components/sidebar-navigation-screen-navigation-menus/loader.js.map +0 -1
  236. package/build-module/components/template-details/edit-template-title.js +0 -33
  237. package/build-module/components/template-details/edit-template-title.js.map +0 -1
  238. package/build-module/components/template-details/index.js +0 -83
  239. package/build-module/components/template-details/index.js.map +0 -1
  240. package/build-module/components/template-details/template-areas.js +0 -145
  241. package/build-module/components/template-details/template-areas.js.map +0 -1
  242. package/build-module/components/template-details/template-part-area-selector.js +0 -36
  243. package/build-module/components/template-details/template-part-area-selector.js.map +0 -1
  244. package/src/components/add-new-template/add-custom-generic-template-modal.js +0 -101
  245. package/src/components/global-styles/border-panel.js +0 -114
  246. package/src/components/navigate-to-link/index.js +0 -46
  247. package/src/components/sidebar-navigation-screen-navigation-menus/loader.js +0 -9
  248. package/src/components/template-details/edit-template-title.js +0 -41
  249. package/src/components/template-details/index.js +0 -113
  250. package/src/components/template-details/style.scss +0 -72
  251. package/src/components/template-details/template-areas.js +0 -167
  252. package/src/components/template-details/template-part-area-selector.js +0 -39
@@ -1,36 +0,0 @@
1
- import { createElement } from "@wordpress/element";
2
-
3
- /**
4
- * WordPress dependencies
5
- */
6
- import { __ } from '@wordpress/i18n';
7
- import { SelectControl } from '@wordpress/components';
8
- import { useEntityProp } from '@wordpress/core-data';
9
- import { useSelect } from '@wordpress/data';
10
- import { store as editorStore } from '@wordpress/editor';
11
- export default function TemplatePartAreaSelector(_ref) {
12
- let {
13
- id
14
- } = _ref;
15
- const [area, setArea] = useEntityProp('postType', 'wp_template_part', 'area', id);
16
- const definedAreas = useSelect(select => select(editorStore).__experimentalGetDefaultTemplatePartAreas(), []);
17
- const areaOptions = definedAreas.map(_ref2 => {
18
- let {
19
- label,
20
- area: _area
21
- } = _ref2;
22
- return {
23
- label,
24
- value: _area
25
- };
26
- });
27
- return createElement(SelectControl, {
28
- __nextHasNoMarginBottom: true,
29
- label: __('Area'),
30
- labelPosition: "top",
31
- options: areaOptions,
32
- value: area,
33
- onChange: setArea
34
- });
35
- }
36
- //# sourceMappingURL=template-part-area-selector.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["@wordpress/edit-site/src/components/template-details/template-part-area-selector.js"],"names":["__","SelectControl","useEntityProp","useSelect","store","editorStore","TemplatePartAreaSelector","id","area","setArea","definedAreas","select","__experimentalGetDefaultTemplatePartAreas","areaOptions","map","label","_area","value"],"mappings":";;AAAA;AACA;AACA;AACA,SAASA,EAAT,QAAmB,iBAAnB;AACA,SAASC,aAAT,QAA8B,uBAA9B;AACA,SAASC,aAAT,QAA8B,sBAA9B;AACA,SAASC,SAAT,QAA0B,iBAA1B;AACA,SAASC,KAAK,IAAIC,WAAlB,QAAqC,mBAArC;AAEA,eAAe,SAASC,wBAAT,OAA4C;AAAA,MAAT;AAAEC,IAAAA;AAAF,GAAS;AAC1D,QAAM,CAAEC,IAAF,EAAQC,OAAR,IAAoBP,aAAa,CACtC,UADsC,EAEtC,kBAFsC,EAGtC,MAHsC,EAItCK,EAJsC,CAAvC;AAOA,QAAMG,YAAY,GAAGP,SAAS,CAC3BQ,MAAF,IACCA,MAAM,CAAEN,WAAF,CAAN,CAAsBO,yCAAtB,EAF4B,EAG7B,EAH6B,CAA9B;AAMA,QAAMC,WAAW,GAAGH,YAAY,CAACI,GAAb,CAAkB;AAAA,QAAE;AAAEC,MAAAA,KAAF;AAASP,MAAAA,IAAI,EAAEQ;AAAf,KAAF;AAAA,WAAgC;AACrED,MAAAA,KADqE;AAErEE,MAAAA,KAAK,EAAED;AAF8D,KAAhC;AAAA,GAAlB,CAApB;AAKA,SACC,cAAC,aAAD;AACC,IAAA,uBAAuB,MADxB;AAEC,IAAA,KAAK,EAAGhB,EAAE,CAAE,MAAF,CAFX;AAGC,IAAA,aAAa,EAAC,KAHf;AAIC,IAAA,OAAO,EAAGa,WAJX;AAKC,IAAA,KAAK,EAAGL,IALT;AAMC,IAAA,QAAQ,EAAGC;AANZ,IADD;AAUA","sourcesContent":["/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\nimport { SelectControl } from '@wordpress/components';\nimport { useEntityProp } from '@wordpress/core-data';\nimport { useSelect } from '@wordpress/data';\nimport { store as editorStore } from '@wordpress/editor';\n\nexport default function TemplatePartAreaSelector( { id } ) {\n\tconst [ area, setArea ] = useEntityProp(\n\t\t'postType',\n\t\t'wp_template_part',\n\t\t'area',\n\t\tid\n\t);\n\n\tconst definedAreas = useSelect(\n\t\t( select ) =>\n\t\t\tselect( editorStore ).__experimentalGetDefaultTemplatePartAreas(),\n\t\t[]\n\t);\n\n\tconst areaOptions = definedAreas.map( ( { label, area: _area } ) => ( {\n\t\tlabel,\n\t\tvalue: _area,\n\t} ) );\n\n\treturn (\n\t\t<SelectControl\n\t\t\t__nextHasNoMarginBottom\n\t\t\tlabel={ __( 'Area' ) }\n\t\t\tlabelPosition=\"top\"\n\t\t\toptions={ areaOptions }\n\t\t\tvalue={ area }\n\t\t\tonChange={ setArea }\n\t\t/>\n\t);\n}\n"]}
@@ -1,101 +0,0 @@
1
- /**
2
- * External dependencies
3
- */
4
- import { kebabCase } from 'lodash';
5
-
6
- /**
7
- * WordPress dependencies
8
- */
9
- import { useState } from '@wordpress/element';
10
- import { __ } from '@wordpress/i18n';
11
- import {
12
- Button,
13
- Modal,
14
- TextControl,
15
- __experimentalHStack as HStack,
16
- __experimentalVStack as VStack,
17
- } from '@wordpress/components';
18
-
19
- /**
20
- * Internal dependencies
21
- */
22
- import TemplateActionsLoadingScreen from './template-actions-loading-screen';
23
-
24
- function AddCustomGenericTemplateModal( {
25
- onClose,
26
- createTemplate,
27
- isCreatingTemplate,
28
- } ) {
29
- const [ title, setTitle ] = useState( '' );
30
- const defaultTitle = __( 'Custom Template' );
31
- const [ isBusy, setIsBusy ] = useState( false );
32
- async function onCreateTemplate( event ) {
33
- event.preventDefault();
34
- if ( isBusy ) {
35
- return;
36
- }
37
- setIsBusy( true );
38
- try {
39
- await createTemplate(
40
- {
41
- slug:
42
- 'wp-custom-template-' +
43
- kebabCase( title || defaultTitle ),
44
- title: title || defaultTitle,
45
- },
46
- false
47
- );
48
- } finally {
49
- setIsBusy( false );
50
- }
51
- }
52
- return (
53
- <Modal
54
- title={ __( 'Create custom template' ) }
55
- onRequestClose={ () => {
56
- onClose();
57
- } }
58
- overlayClassName="edit-site-custom-generic-template__modal"
59
- >
60
- { isCreatingTemplate && <TemplateActionsLoadingScreen /> }
61
- <form onSubmit={ onCreateTemplate }>
62
- <VStack spacing={ 6 }>
63
- <TextControl
64
- __nextHasNoMarginBottom
65
- label={ __( 'Name' ) }
66
- value={ title }
67
- onChange={ setTitle }
68
- placeholder={ defaultTitle }
69
- disabled={ isBusy }
70
- help={ __(
71
- 'Describe the template, e.g. "Post with sidebar".'
72
- ) }
73
- />
74
- <HStack
75
- className="edit-site-custom-generic-template__modal-actions"
76
- justify="right"
77
- >
78
- <Button
79
- variant="tertiary"
80
- onClick={ () => {
81
- onClose();
82
- } }
83
- >
84
- { __( 'Cancel' ) }
85
- </Button>
86
- <Button
87
- variant="primary"
88
- type="submit"
89
- isBusy={ isBusy }
90
- aria-disabled={ isBusy }
91
- >
92
- { __( 'Create' ) }
93
- </Button>
94
- </HStack>
95
- </VStack>
96
- </form>
97
- </Modal>
98
- );
99
- }
100
-
101
- export default AddCustomGenericTemplateModal;
@@ -1,114 +0,0 @@
1
- /**
2
- * WordPress dependencies
3
- */
4
- import { privateApis as blockEditorPrivateApis } from '@wordpress/block-editor';
5
- import { __experimentalHasSplitBorders as hasSplitBorders } from '@wordpress/components';
6
-
7
- /**
8
- * Internal dependencies
9
- */
10
- import { unlock } from '../../private-apis';
11
-
12
- const {
13
- useGlobalStyle,
14
- useGlobalSetting,
15
- useSettingsForBlockElement,
16
- BorderPanel: StylesBorderPanel,
17
- } = unlock( blockEditorPrivateApis );
18
-
19
- function applyFallbackStyle( border ) {
20
- if ( ! border ) {
21
- return border;
22
- }
23
-
24
- const hasColorOrWidth = border.color || border.width;
25
-
26
- if ( ! border.style && hasColorOrWidth ) {
27
- return { ...border, style: 'solid' };
28
- }
29
-
30
- if ( border.style && ! hasColorOrWidth ) {
31
- return undefined;
32
- }
33
-
34
- return border;
35
- }
36
-
37
- function applyAllFallbackStyles( border ) {
38
- if ( ! border ) {
39
- return border;
40
- }
41
-
42
- if ( hasSplitBorders( border ) ) {
43
- return {
44
- top: applyFallbackStyle( border.top ),
45
- right: applyFallbackStyle( border.right ),
46
- bottom: applyFallbackStyle( border.bottom ),
47
- left: applyFallbackStyle( border.left ),
48
- };
49
- }
50
-
51
- return applyFallbackStyle( border );
52
- }
53
-
54
- export default function BorderPanel( { name, variation = '' } ) {
55
- let prefixParts = [];
56
- if ( variation ) {
57
- prefixParts = [ 'variations', variation ].concat( prefixParts );
58
- }
59
- const prefix = prefixParts.join( '.' );
60
-
61
- const [ style ] = useGlobalStyle( prefix, name, 'user', {
62
- shouldDecodeEncode: false,
63
- } );
64
- const [ inheritedStyle, setStyle ] = useGlobalStyle( prefix, name, 'all', {
65
- shouldDecodeEncode: false,
66
- } );
67
- const [ rawSettings ] = useGlobalSetting( '', name );
68
- const settings = useSettingsForBlockElement( rawSettings, name );
69
-
70
- const onChange = ( newStyle ) => {
71
- if ( ! newStyle?.border ) {
72
- setStyle( newStyle );
73
- return;
74
- }
75
-
76
- // As Global Styles can't conditionally generate styles based on if
77
- // other style properties have been set, we need to force split
78
- // border definitions for user set global border styles. Border
79
- // radius is derived from the same property i.e. `border.radius` if
80
- // it is a string that is used. The longhand border radii styles are
81
- // only generated if that property is an object.
82
- //
83
- // For borders (color, style, and width) those are all properties on
84
- // the `border` style property. This means if the theme.json defined
85
- // split borders and the user condenses them into a flat border or
86
- // vice-versa we'd get both sets of styles which would conflict.
87
- const { radius, ...newBorder } = newStyle.border;
88
- const border = applyAllFallbackStyles( newBorder );
89
- const updatedBorder = ! hasSplitBorders( border )
90
- ? {
91
- top: border,
92
- right: border,
93
- bottom: border,
94
- left: border,
95
- }
96
- : {
97
- color: null,
98
- style: null,
99
- width: null,
100
- ...border,
101
- };
102
-
103
- setStyle( { ...newStyle, border: { ...updatedBorder, radius } } );
104
- };
105
-
106
- return (
107
- <StylesBorderPanel
108
- inheritedValue={ inheritedStyle }
109
- value={ style }
110
- onChange={ onChange }
111
- settings={ settings }
112
- />
113
- );
114
- }
@@ -1,46 +0,0 @@
1
- /**
2
- * WordPress dependencies
3
- */
4
- import { getPathAndQueryString } from '@wordpress/url';
5
- import { useMemo } from '@wordpress/element';
6
- import { useSelect } from '@wordpress/data';
7
- import { Button } from '@wordpress/components';
8
- import { edit } from '@wordpress/icons';
9
- import { __ } from '@wordpress/i18n';
10
- import { store as coreStore } from '@wordpress/core-data';
11
-
12
- export default function NavigateToLink( { type, id, onActivePageChange } ) {
13
- const post = useSelect(
14
- ( select ) =>
15
- type &&
16
- id &&
17
- type !== 'URL' &&
18
- select( coreStore ).getEntityRecord( 'postType', type, id ),
19
- [ type, id ]
20
- );
21
-
22
- const onClick = useMemo( () => {
23
- if ( ! post?.link ) return null;
24
- const path = getPathAndQueryString( post.link );
25
- return () =>
26
- onActivePageChange( {
27
- type,
28
- slug: post.slug,
29
- path,
30
- context: {
31
- postType: post.type,
32
- postId: post.id,
33
- },
34
- } );
35
- }, [ post, onActivePageChange ] );
36
-
37
- return (
38
- onClick && (
39
- <Button
40
- icon={ edit }
41
- label={ __( 'Edit Page Template' ) }
42
- onClick={ onClick }
43
- />
44
- )
45
- );
46
- }
@@ -1,9 +0,0 @@
1
- export function NavigationMenuLoader() {
2
- return (
3
- <>
4
- <div className="edit-site-sidebar-navigation-screen-navigation-menus__placeholder" />
5
- <div className="edit-site-sidebar-navigation-screen-navigation-menus__placeholder" />
6
- <div className="edit-site-sidebar-navigation-screen-navigation-menus__placeholder" />
7
- </>
8
- );
9
- }
@@ -1,41 +0,0 @@
1
- /**
2
- * WordPress dependencies
3
- */
4
- import { __ } from '@wordpress/i18n';
5
- import { TextControl } from '@wordpress/components';
6
- import { useEntityProp } from '@wordpress/core-data';
7
- import { useState } from '@wordpress/element';
8
-
9
- export default function EditTemplateTitle( { template } ) {
10
- const [ forceEmpty, setForceEmpty ] = useState( false );
11
- const [ title, setTitle ] = useEntityProp(
12
- 'postType',
13
- template.type,
14
- 'title',
15
- template.id
16
- );
17
-
18
- return (
19
- <TextControl
20
- __nextHasNoMarginBottom
21
- label={ __( 'Title' ) }
22
- value={ forceEmpty ? '' : title }
23
- help={
24
- template.type !== 'wp_template_part'
25
- ? __(
26
- 'Give the template a title that indicates its purpose, e.g. "Full Width".'
27
- )
28
- : null
29
- }
30
- onChange={ ( newTitle ) => {
31
- if ( ! newTitle && ! forceEmpty ) {
32
- setForceEmpty( true );
33
- return;
34
- }
35
- setForceEmpty( false );
36
- setTitle( newTitle );
37
- } }
38
- onBlur={ () => setForceEmpty( false ) }
39
- />
40
- );
41
- }
@@ -1,113 +0,0 @@
1
- /**
2
- * WordPress dependencies
3
- */
4
- import { __ } from '@wordpress/i18n';
5
- import {
6
- Button,
7
- MenuGroup,
8
- MenuItem,
9
- __experimentalVStack as VStack,
10
- __experimentalText as Text,
11
- } from '@wordpress/components';
12
- import { useDispatch, useSelect } from '@wordpress/data';
13
- import { store as editorStore } from '@wordpress/editor';
14
- import { decodeEntities } from '@wordpress/html-entities';
15
-
16
- /**
17
- * Internal dependencies
18
- */
19
- import isTemplateRevertable from '../../utils/is-template-revertable';
20
- import { store as editSiteStore } from '../../store';
21
- import EditTemplateTitle from './edit-template-title';
22
- import { useLink } from '../routes/link';
23
- import TemplatePartAreaSelector from './template-part-area-selector';
24
-
25
- export default function TemplateDetails( { template, onClose } ) {
26
- const { title, description } = useSelect(
27
- ( select ) =>
28
- select( editorStore ).__experimentalGetTemplateInfo( template ),
29
- []
30
- );
31
- const { revertTemplate } = useDispatch( editSiteStore );
32
-
33
- // TODO: We should update this to filter by template part's areas as well.
34
- const browseAllLinkProps = useLink( {
35
- path: '/' + template.type + '/all',
36
- } );
37
-
38
- const isTemplatePart = template.type === 'wp_template_part';
39
-
40
- // Only user-created and non-default templates can change the name.
41
- // But any user-created template part can be renamed.
42
- const canEditTitle = isTemplatePart
43
- ? ! template.has_theme_file
44
- : template.is_custom && ! template.has_theme_file;
45
-
46
- if ( ! template ) {
47
- return null;
48
- }
49
-
50
- const revert = () => {
51
- revertTemplate( template );
52
- onClose();
53
- };
54
-
55
- return (
56
- <div className="edit-site-template-details">
57
- <VStack className="edit-site-template-details__group" spacing={ 3 }>
58
- { canEditTitle ? (
59
- <EditTemplateTitle template={ template } />
60
- ) : (
61
- <Text
62
- size={ 16 }
63
- weight={ 600 }
64
- className="edit-site-template-details__title"
65
- as="p"
66
- >
67
- { decodeEntities( title ) }
68
- </Text>
69
- ) }
70
-
71
- { description && (
72
- <Text
73
- size="body"
74
- className="edit-site-template-details__description"
75
- as="p"
76
- >
77
- { decodeEntities( description ) }
78
- </Text>
79
- ) }
80
- </VStack>
81
-
82
- { isTemplatePart && (
83
- <div className="edit-site-template-details__group">
84
- <TemplatePartAreaSelector id={ template.id } />
85
- </div>
86
- ) }
87
-
88
- { isTemplateRevertable( template ) && (
89
- <MenuGroup className="edit-site-template-details__group edit-site-template-details__revert">
90
- <MenuItem
91
- className="edit-site-template-details__revert-button"
92
- info={ __(
93
- 'Use the template as supplied by the theme.'
94
- ) }
95
- onClick={ revert }
96
- >
97
- { __( 'Clear customizations' ) }
98
- </MenuItem>
99
- </MenuGroup>
100
- ) }
101
-
102
- <Button
103
- className="edit-site-template-details__show-all-button"
104
- { ...browseAllLinkProps }
105
- onClick={ () => onClose() }
106
- >
107
- { template?.type === 'wp_template'
108
- ? __( 'Manage all templates' )
109
- : __( 'Manage all template parts' ) }
110
- </Button>
111
- </div>
112
- );
113
- }
@@ -1,72 +0,0 @@
1
- .edit-site-template-details {
2
- .edit-site-template-details__group {
3
- margin: 0;
4
- padding: $grid-unit-20;
5
- }
6
-
7
- .edit-site-template-details__group + .edit-site-template-details__group {
8
- border-top: $border-width solid $gray-400;
9
- }
10
-
11
- .edit-site-template-details__description {
12
- color: $gray-700;
13
- }
14
-
15
- // The group already has a 8px padding inside, so overriding the parent padding.
16
- .edit-site-template-details__group.edit-site-template-details__template-areas {
17
- padding: $grid-unit-10;
18
- }
19
-
20
- .edit-site-template-details__template-areas-item {
21
- position: relative;
22
-
23
- .components-menu-items__item-icon {
24
- color: var(--wp-block-synced-color);
25
- }
26
-
27
- .edit-site-template-details__template-areas-item-more {
28
- position: absolute;
29
- right: 0;
30
- top: 0;
31
- bottom: 0;
32
- margin: auto 0;
33
- }
34
- }
35
-
36
- .edit-site-template-details__revert {
37
- // Make some spaces for the revert button to have some paddings.
38
- padding: $grid-unit-15 $grid-unit;
39
- }
40
-
41
- .edit-site-template-details__revert-button {
42
- height: auto;
43
- padding: $grid-unit-05 $grid-unit;
44
- text-align: left;
45
-
46
- &:focus:not(:disabled) {
47
- box-shadow: inset 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color), inset 0 0 0 3px $white;
48
- }
49
- }
50
-
51
- .edit-site-template-details__show-all-button.components-button {
52
- display: flex;
53
- justify-content: center;
54
- background: $gray-900;
55
- color: $white;
56
- width: 100%;
57
- height: ($button-size + $grid-unit-10);
58
- border-radius: 0;
59
-
60
- &:hover {
61
- color: $white;
62
- }
63
-
64
- &:active {
65
- color: $gray-400;
66
- }
67
-
68
- &:focus:not(:disabled) {
69
- box-shadow: inset 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color), inset 0 0 0 3px $white;
70
- }
71
- }
72
- }