@wordpress/edit-site 3.0.8 → 3.0.12

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 (258) hide show
  1. package/build/components/add-new-template/index.js +49 -0
  2. package/build/components/add-new-template/index.js.map +1 -0
  3. package/build/components/add-new-template/new-template-part.js +95 -0
  4. package/build/components/add-new-template/new-template-part.js.map +1 -0
  5. package/build/components/add-new-template/new-template.js +133 -0
  6. package/build/components/add-new-template/new-template.js.map +1 -0
  7. package/build/components/block-editor/index.js +3 -1
  8. package/build/components/block-editor/index.js.map +1 -1
  9. package/build/components/create-template-part-modal/index.js +115 -0
  10. package/build/components/create-template-part-modal/index.js.map +1 -0
  11. package/build/components/editor/index.js +20 -16
  12. package/build/components/editor/index.js.map +1 -1
  13. package/build/components/global-styles/color-palette-panel.js +29 -6
  14. package/build/components/global-styles/color-palette-panel.js.map +1 -1
  15. package/build/components/global-styles/global-styles-provider.js +9 -47
  16. package/build/components/global-styles/global-styles-provider.js.map +1 -1
  17. package/build/components/global-styles/gradients-palette-panel.js +56 -0
  18. package/build/components/global-styles/gradients-palette-panel.js.map +1 -0
  19. package/build/components/global-styles/hooks.js +29 -27
  20. package/build/components/global-styles/hooks.js.map +1 -1
  21. package/build/components/global-styles/palette.js +11 -5
  22. package/build/components/global-styles/palette.js.map +1 -1
  23. package/build/components/global-styles/screen-background-color.js +2 -1
  24. package/build/components/global-styles/screen-background-color.js.map +1 -1
  25. package/build/components/global-styles/screen-block-list.js +9 -1
  26. package/build/components/global-styles/screen-block-list.js.map +1 -1
  27. package/build/components/global-styles/screen-color-palette.js +23 -3
  28. package/build/components/global-styles/screen-color-palette.js.map +1 -1
  29. package/build/components/global-styles/screen-link-color.js +2 -1
  30. package/build/components/global-styles/screen-link-color.js.map +1 -1
  31. package/build/components/global-styles/screen-text-color.js +2 -1
  32. package/build/components/global-styles/screen-text-color.js.map +1 -1
  33. package/build/components/global-styles/screen-typography-element.js +54 -0
  34. package/build/components/global-styles/screen-typography-element.js.map +1 -0
  35. package/build/components/global-styles/screen-typography.js +74 -6
  36. package/build/components/global-styles/screen-typography.js.map +1 -1
  37. package/build/components/global-styles/typography-panel.js +28 -8
  38. package/build/components/global-styles/typography-panel.js.map +1 -1
  39. package/build/components/global-styles/ui.js +12 -0
  40. package/build/components/global-styles/ui.js.map +1 -1
  41. package/build/components/global-styles/use-global-styles-output.js +2 -2
  42. package/build/components/global-styles/use-global-styles-output.js.map +1 -1
  43. package/build/components/global-styles/utils.js +1 -1
  44. package/build/components/global-styles/utils.js.map +1 -1
  45. package/build/components/header/index.js +1 -5
  46. package/build/components/header/index.js.map +1 -1
  47. package/build/components/keyboard-shortcuts/index.js +26 -0
  48. package/build/components/keyboard-shortcuts/index.js.map +1 -1
  49. package/build/components/list/actions/index.js +104 -0
  50. package/build/components/list/actions/index.js.map +1 -0
  51. package/build/components/list/actions/rename-menu-item.js +112 -0
  52. package/build/components/list/actions/rename-menu-item.js.map +1 -0
  53. package/build/components/list/added-by.js +180 -0
  54. package/build/components/list/added-by.js.map +1 -0
  55. package/build/components/list/header.js +50 -0
  56. package/build/components/list/header.js.map +1 -0
  57. package/build/components/list/index.js +102 -0
  58. package/build/components/list/index.js.map +1 -0
  59. package/build/components/list/table.js +114 -0
  60. package/build/components/list/table.js.map +1 -0
  61. package/build/components/list/use-register-shortcuts.js +52 -0
  62. package/build/components/list/use-register-shortcuts.js.map +1 -0
  63. package/build/components/navigation-sidebar/index.js +26 -10
  64. package/build/components/navigation-sidebar/index.js.map +1 -1
  65. package/build/components/navigation-sidebar/navigation-panel/index.js +42 -44
  66. package/build/components/navigation-sidebar/navigation-panel/index.js.map +1 -1
  67. package/build/components/navigation-sidebar/navigation-toggle/index.js +5 -17
  68. package/build/components/navigation-sidebar/navigation-toggle/index.js.map +1 -1
  69. package/build/components/template-details/index.js +3 -2
  70. package/build/components/template-details/index.js.map +1 -1
  71. package/build/components/template-part-converter/convert-to-template-part.js +20 -84
  72. package/build/components/template-part-converter/convert-to-template-part.js.map +1 -1
  73. package/build/components/welcome-guide/editor.js +58 -0
  74. package/build/components/welcome-guide/editor.js.map +1 -0
  75. package/build/components/welcome-guide/image.js +27 -0
  76. package/build/components/welcome-guide/image.js.map +1 -0
  77. package/build/components/welcome-guide/index.js +49 -0
  78. package/build/components/welcome-guide/index.js.map +1 -0
  79. package/build/components/welcome-guide/styles.js +83 -0
  80. package/build/components/welcome-guide/styles.js.map +1 -0
  81. package/build/index.js +36 -6
  82. package/build/index.js.map +1 -1
  83. package/build/plugins/index.js +4 -2
  84. package/build/plugins/index.js.map +1 -1
  85. package/build/plugins/welcome-guide-menu-item.js +39 -0
  86. package/build/plugins/welcome-guide-menu-item.js.map +1 -0
  87. package/build/store/actions.js +50 -24
  88. package/build/store/actions.js.map +1 -1
  89. package/build/store/defaults.js +4 -1
  90. package/build/store/defaults.js.map +1 -1
  91. package/build/store/selectors.js +25 -5
  92. package/build/store/selectors.js.map +1 -1
  93. package/build/utils/is-template-removable.js +21 -0
  94. package/build/utils/is-template-removable.js.map +1 -0
  95. package/build-module/components/add-new-template/index.js +36 -0
  96. package/build-module/components/add-new-template/index.js.map +1 -0
  97. package/build-module/components/add-new-template/new-template-part.js +79 -0
  98. package/build-module/components/add-new-template/new-template-part.js.map +1 -0
  99. package/build-module/components/add-new-template/new-template.js +114 -0
  100. package/build-module/components/add-new-template/new-template.js.map +1 -0
  101. package/build-module/components/block-editor/index.js +2 -1
  102. package/build-module/components/block-editor/index.js.map +1 -1
  103. package/build-module/components/create-template-part-modal/index.js +102 -0
  104. package/build-module/components/create-template-part-modal/index.js.map +1 -0
  105. package/build-module/components/editor/index.js +19 -17
  106. package/build-module/components/editor/index.js.map +1 -1
  107. package/build-module/components/global-styles/color-palette-panel.js +29 -7
  108. package/build-module/components/global-styles/color-palette-panel.js.map +1 -1
  109. package/build-module/components/global-styles/global-styles-provider.js +10 -43
  110. package/build-module/components/global-styles/global-styles-provider.js.map +1 -1
  111. package/build-module/components/global-styles/gradients-palette-panel.js +46 -0
  112. package/build-module/components/global-styles/gradients-palette-panel.js.map +1 -0
  113. package/build-module/components/global-styles/hooks.js +30 -28
  114. package/build-module/components/global-styles/hooks.js.map +1 -1
  115. package/build-module/components/global-styles/palette.js +12 -5
  116. package/build-module/components/global-styles/palette.js.map +1 -1
  117. package/build-module/components/global-styles/screen-background-color.js +2 -1
  118. package/build-module/components/global-styles/screen-background-color.js.map +1 -1
  119. package/build-module/components/global-styles/screen-block-list.js +7 -1
  120. package/build-module/components/global-styles/screen-block-list.js.map +1 -1
  121. package/build-module/components/global-styles/screen-color-palette.js +22 -3
  122. package/build-module/components/global-styles/screen-color-palette.js.map +1 -1
  123. package/build-module/components/global-styles/screen-link-color.js +2 -1
  124. package/build-module/components/global-styles/screen-link-color.js.map +1 -1
  125. package/build-module/components/global-styles/screen-text-color.js +2 -1
  126. package/build-module/components/global-styles/screen-text-color.js.map +1 -1
  127. package/build-module/components/global-styles/screen-typography-element.js +41 -0
  128. package/build-module/components/global-styles/screen-typography-element.js.map +1 -0
  129. package/build-module/components/global-styles/screen-typography.js +70 -6
  130. package/build-module/components/global-styles/screen-typography.js.map +1 -1
  131. package/build-module/components/global-styles/typography-panel.js +28 -8
  132. package/build-module/components/global-styles/typography-panel.js.map +1 -1
  133. package/build-module/components/global-styles/ui.js +11 -0
  134. package/build-module/components/global-styles/ui.js.map +1 -1
  135. package/build-module/components/global-styles/use-global-styles-output.js +2 -2
  136. package/build-module/components/global-styles/use-global-styles-output.js.map +1 -1
  137. package/build-module/components/global-styles/utils.js +1 -1
  138. package/build-module/components/global-styles/utils.js.map +1 -1
  139. package/build-module/components/header/index.js +1 -3
  140. package/build-module/components/header/index.js.map +1 -1
  141. package/build-module/components/keyboard-shortcuts/index.js +26 -0
  142. package/build-module/components/keyboard-shortcuts/index.js.map +1 -1
  143. package/build-module/components/list/actions/index.js +85 -0
  144. package/build-module/components/list/actions/index.js.map +1 -0
  145. package/build-module/components/list/actions/rename-menu-item.js +101 -0
  146. package/build-module/components/list/actions/rename-menu-item.js.map +1 -0
  147. package/build-module/components/list/added-by.js +166 -0
  148. package/build-module/components/list/added-by.js.map +1 -0
  149. package/build-module/components/list/header.js +37 -0
  150. package/build-module/components/list/header.js.map +1 -0
  151. package/build-module/components/list/index.js +81 -0
  152. package/build-module/components/list/index.js.map +1 -0
  153. package/build-module/components/list/table.js +98 -0
  154. package/build-module/components/list/table.js.map +1 -0
  155. package/build-module/components/list/use-register-shortcuts.js +41 -0
  156. package/build-module/components/list/use-register-shortcuts.js.map +1 -0
  157. package/build-module/components/navigation-sidebar/index.js +26 -10
  158. package/build-module/components/navigation-sidebar/index.js.map +1 -1
  159. package/build-module/components/navigation-sidebar/navigation-panel/index.js +41 -44
  160. package/build-module/components/navigation-sidebar/navigation-panel/index.js.map +1 -1
  161. package/build-module/components/navigation-sidebar/navigation-toggle/index.js +6 -18
  162. package/build-module/components/navigation-sidebar/navigation-toggle/index.js.map +1 -1
  163. package/build-module/components/template-details/index.js +3 -2
  164. package/build-module/components/template-details/index.js.map +1 -1
  165. package/build-module/components/template-part-converter/convert-to-template-part.js +20 -84
  166. package/build-module/components/template-part-converter/convert-to-template-part.js.map +1 -1
  167. package/build-module/components/welcome-guide/editor.js +45 -0
  168. package/build-module/components/welcome-guide/editor.js.map +1 -0
  169. package/build-module/components/welcome-guide/image.js +19 -0
  170. package/build-module/components/welcome-guide/image.js.map +1 -0
  171. package/build-module/components/welcome-guide/index.js +35 -0
  172. package/build-module/components/welcome-guide/index.js.map +1 -0
  173. package/build-module/components/welcome-guide/styles.js +69 -0
  174. package/build-module/components/welcome-guide/styles.js.map +1 -0
  175. package/build-module/index.js +28 -3
  176. package/build-module/index.js.map +1 -1
  177. package/build-module/plugins/index.js +3 -2
  178. package/build-module/plugins/index.js.map +1 -1
  179. package/build-module/plugins/welcome-guide-menu-item.js +27 -0
  180. package/build-module/plugins/welcome-guide-menu-item.js.map +1 -0
  181. package/build-module/store/actions.js +51 -25
  182. package/build-module/store/actions.js.map +1 -1
  183. package/build-module/store/defaults.js +4 -1
  184. package/build-module/store/defaults.js.map +1 -1
  185. package/build-module/store/selectors.js +21 -3
  186. package/build-module/store/selectors.js.map +1 -1
  187. package/build-module/utils/is-template-removable.js +14 -0
  188. package/build-module/utils/is-template-removable.js.map +1 -0
  189. package/build-style/style-rtl.css +468 -33
  190. package/build-style/style.css +468 -33
  191. package/package.json +10 -8
  192. package/src/components/add-new-template/index.js +30 -0
  193. package/src/components/add-new-template/new-template-part.js +81 -0
  194. package/src/components/add-new-template/new-template.js +136 -0
  195. package/src/components/add-new-template/style.scss +11 -0
  196. package/src/components/block-editor/index.js +2 -0
  197. package/src/components/create-template-part-modal/index.js +132 -0
  198. package/src/components/{template-part-converter → create-template-part-modal}/style.scss +9 -9
  199. package/src/components/editor/index.js +22 -15
  200. package/src/components/editor/style.scss +8 -0
  201. package/src/components/global-styles/color-palette-panel.js +64 -7
  202. package/src/components/global-styles/global-styles-provider.js +7 -36
  203. package/src/components/global-styles/gradients-palette-panel.js +79 -0
  204. package/src/components/global-styles/hooks.js +59 -27
  205. package/src/components/global-styles/palette.js +30 -10
  206. package/src/components/global-styles/screen-background-color.js +1 -0
  207. package/src/components/global-styles/screen-block-list.js +11 -1
  208. package/src/components/global-styles/screen-color-palette.js +30 -3
  209. package/src/components/global-styles/screen-link-color.js +1 -0
  210. package/src/components/global-styles/screen-text-color.js +1 -0
  211. package/src/components/global-styles/screen-typography-element.js +39 -0
  212. package/src/components/global-styles/screen-typography.js +84 -3
  213. package/src/components/global-styles/style.scss +33 -0
  214. package/src/components/global-styles/test/use-global-styles-output.js +3 -3
  215. package/src/components/global-styles/test/utils.js +1 -1
  216. package/src/components/global-styles/typography-panel.js +37 -7
  217. package/src/components/global-styles/ui.js +9 -0
  218. package/src/components/global-styles/use-global-styles-output.js +2 -2
  219. package/src/components/global-styles/utils.js +1 -1
  220. package/src/components/header/index.js +0 -6
  221. package/src/components/keyboard-shortcuts/index.js +32 -0
  222. package/src/components/list/actions/index.js +95 -0
  223. package/src/components/list/actions/rename-menu-item.js +134 -0
  224. package/src/components/list/added-by.js +179 -0
  225. package/src/components/list/header.js +34 -0
  226. package/src/components/list/index.js +96 -0
  227. package/src/components/list/style.scss +208 -0
  228. package/src/components/list/table.js +121 -0
  229. package/src/components/list/use-register-shortcuts.js +45 -0
  230. package/src/components/navigation-sidebar/index.js +24 -8
  231. package/src/components/navigation-sidebar/navigation-panel/index.js +57 -51
  232. package/src/components/navigation-sidebar/navigation-panel/style.scss +4 -2
  233. package/src/components/navigation-sidebar/navigation-toggle/index.js +24 -36
  234. package/src/components/navigation-sidebar/navigation-toggle/test/index.js +2 -0
  235. package/src/components/sidebar/style.scss +2 -1
  236. package/src/components/template-details/index.js +3 -2
  237. package/src/components/template-part-converter/convert-to-template-part.js +20 -140
  238. package/src/components/welcome-guide/editor.js +63 -0
  239. package/src/components/welcome-guide/image.js +11 -0
  240. package/src/components/welcome-guide/index.js +33 -0
  241. package/src/components/welcome-guide/style.scss +37 -0
  242. package/src/components/welcome-guide/styles.js +116 -0
  243. package/src/index.js +31 -3
  244. package/src/plugins/index.js +3 -1
  245. package/src/plugins/welcome-guide-menu-item.js +35 -0
  246. package/src/store/actions.js +85 -35
  247. package/src/store/defaults.js +4 -1
  248. package/src/store/selectors.js +22 -4
  249. package/src/store/test/actions.js +0 -30
  250. package/src/store/test/selectors.js +24 -0
  251. package/src/style.scss +9 -6
  252. package/src/utils/is-template-removable.js +13 -0
  253. package/build/components/header/navigation-link/index.js +0 -87
  254. package/build/components/header/navigation-link/index.js.map +0 -1
  255. package/build-module/components/header/navigation-link/index.js +0 -74
  256. package/build-module/components/header/navigation-link/index.js.map +0 -1
  257. package/src/components/header/navigation-link/index.js +0 -71
  258. package/src/components/header/navigation-link/style.scss +0 -69
@@ -0,0 +1,34 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { useSelect } from '@wordpress/data';
5
+ import { store as coreStore } from '@wordpress/core-data';
6
+ import { __experimentalHeading as Heading } from '@wordpress/components';
7
+
8
+ /**
9
+ * Internal dependencies
10
+ */
11
+ import AddNewTemplate from '../add-new-template';
12
+
13
+ export default function Header( { templateType } ) {
14
+ const postType = useSelect(
15
+ ( select ) => select( coreStore ).getPostType( templateType ),
16
+ [ templateType ]
17
+ );
18
+
19
+ if ( ! postType ) {
20
+ return null;
21
+ }
22
+
23
+ return (
24
+ <header className="edit-site-list-header">
25
+ <Heading level={ 1 } className="edit-site-list-header__title">
26
+ { postType.labels?.name }
27
+ </Heading>
28
+
29
+ <div className="edit-site-list-header__right">
30
+ <AddNewTemplate templateType={ templateType } />
31
+ </div>
32
+ </header>
33
+ );
34
+ }
@@ -0,0 +1,96 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import classnames from 'classnames';
5
+
6
+ /**
7
+ * WordPress dependencies
8
+ */
9
+ import { store as coreStore } from '@wordpress/core-data';
10
+ import { useSelect } from '@wordpress/data';
11
+ import { InterfaceSkeleton } from '@wordpress/interface';
12
+ import { __, sprintf } from '@wordpress/i18n';
13
+ import { store as keyboardShortcutsStore } from '@wordpress/keyboard-shortcuts';
14
+ import { EditorSnackbars } from '@wordpress/editor';
15
+
16
+ /**
17
+ * Internal dependencies
18
+ */
19
+ import useRegisterShortcuts from './use-register-shortcuts';
20
+ import Header from './header';
21
+ import NavigationSidebar from '../navigation-sidebar';
22
+ import Table from './table';
23
+ import { store as editSiteStore } from '../../store';
24
+
25
+ export default function List( { templateType } ) {
26
+ useRegisterShortcuts();
27
+
28
+ const { previousShortcut, nextShortcut, isNavigationOpen } = useSelect(
29
+ ( select ) => {
30
+ return {
31
+ previousShortcut: select(
32
+ keyboardShortcutsStore
33
+ ).getAllShortcutKeyCombinations(
34
+ 'core/edit-site/previous-region'
35
+ ),
36
+ nextShortcut: select(
37
+ keyboardShortcutsStore
38
+ ).getAllShortcutKeyCombinations( 'core/edit-site/next-region' ),
39
+ isNavigationOpen: select( editSiteStore ).isNavigationOpened(),
40
+ };
41
+ },
42
+ []
43
+ );
44
+
45
+ const postType = useSelect(
46
+ ( select ) => select( coreStore ).getPostType( templateType ),
47
+ [ templateType ]
48
+ );
49
+
50
+ // `postType` could load in asynchronously. Only provide the detailed region labels if
51
+ // the postType has loaded, otherwise `InterfaceSkeleton` will fallback to the defaults.
52
+ const itemsListLabel = postType?.labels?.items_list;
53
+ const detailedRegionLabels = postType
54
+ ? {
55
+ header: sprintf(
56
+ // translators: %s - the name of the page, 'Header' as in the header area of that page.
57
+ __( '%s - Header' ),
58
+ itemsListLabel
59
+ ),
60
+ body: sprintf(
61
+ // translators: %s - the name of the page, 'Content' as in the content area of that page.
62
+ __( '%s - Content' ),
63
+ itemsListLabel
64
+ ),
65
+ }
66
+ : undefined;
67
+
68
+ return (
69
+ <InterfaceSkeleton
70
+ className={ classnames( 'edit-site-list', {
71
+ 'is-navigation-open': isNavigationOpen,
72
+ } ) }
73
+ labels={ {
74
+ drawer: __( 'Navigation Sidebar' ),
75
+ ...detailedRegionLabels,
76
+ } }
77
+ header={ <Header templateType={ templateType } /> }
78
+ drawer={
79
+ <NavigationSidebar
80
+ activeTemplateType={ templateType }
81
+ isDefaultOpen
82
+ />
83
+ }
84
+ notices={ <EditorSnackbars /> }
85
+ content={
86
+ <main className="edit-site-list-main">
87
+ <Table templateType={ templateType } />
88
+ </main>
89
+ }
90
+ shortcuts={ {
91
+ previous: previousShortcut,
92
+ next: nextShortcut,
93
+ } }
94
+ />
95
+ );
96
+ }
@@ -0,0 +1,208 @@
1
+ .edit-site-list-header {
2
+ position: relative;
3
+ align-items: center;
4
+ background-color: $white;
5
+ display: flex;
6
+ height: $header-height;
7
+ box-sizing: border-box;
8
+ width: 100%;
9
+ justify-content: flex-end;
10
+ padding-right: $grid-unit-20;
11
+
12
+ body.is-fullscreen-mode & {
13
+ padding-left: 60px;
14
+ transition: padding-left 20ms linear;
15
+ transition-delay: 80ms;
16
+ @include reduce-motion("transition");
17
+ }
18
+
19
+ .edit-site-list-header__title {
20
+ position: absolute;
21
+ left: 0;
22
+ width: 100%;
23
+ text-align: center;
24
+ font-size: 20px;
25
+ padding: 0;
26
+ margin: 0;
27
+ }
28
+ }
29
+
30
+ .edit-site-list-header__right {
31
+ // Creating a stacking context so that it won't be covered by title.
32
+ position: relative;
33
+ }
34
+
35
+ .edit-site {
36
+ .edit-site-list {
37
+ .interface-interface-skeleton__editor {
38
+ min-width: 100%;
39
+
40
+ @include break-medium() {
41
+ min-width: 0;
42
+ }
43
+ }
44
+
45
+ .interface-interface-skeleton__content {
46
+ background: $white;
47
+ }
48
+ }
49
+ }
50
+
51
+ .edit-site-list-main {
52
+ display: flex;
53
+ align-items: center;
54
+ justify-content: center;
55
+ padding: $grid-unit-20;
56
+
57
+ @include break-medium() {
58
+ padding: $grid-unit * 9;
59
+ }
60
+ }
61
+
62
+ .edit-site-list-table {
63
+ width: 100%;
64
+ border: $border-width solid $gray-300;
65
+ border-radius: 2px;
66
+ margin: 0;
67
+ overflow: hidden;
68
+ border-spacing: 0;
69
+ max-width: 960px;
70
+
71
+ tr {
72
+ display: flex;
73
+ align-items: center;
74
+ padding: $grid-unit-20;
75
+ box-sizing: border-box;
76
+ border-top: $border-width solid $gray-100;
77
+ margin: 0;
78
+
79
+ &:first-child {
80
+ border-top: 0;
81
+ }
82
+
83
+ @include break-medium() {
84
+ padding: $grid-unit-30 $grid-unit-40;
85
+ }
86
+
87
+ // Template.
88
+ .edit-site-list-table-column:nth-child(1) {
89
+ width: calc(60% - 18px);
90
+ padding-right: $grid-unit-30;
91
+
92
+ a {
93
+ display: inline-block;
94
+ text-decoration: none;
95
+ font-weight: 500;
96
+ margin-bottom: $grid-unit-05;
97
+ }
98
+ }
99
+
100
+ // Added by.
101
+ .edit-site-list-table-column:nth-child(2) {
102
+ width: calc(40% - 18px);
103
+ }
104
+
105
+ // Actions.
106
+ .edit-site-list-table-column:nth-child(3) {
107
+ min-width: $button-size;
108
+ flex-shrink: 0;
109
+ }
110
+ }
111
+
112
+ tr.edit-site-list-table-head {
113
+ font-size: 16px;
114
+ font-weight: 600;
115
+ text-align: left;
116
+ color: $gray-900;
117
+ border-top: none;
118
+ border-bottom: $border-width solid $gray-300;
119
+
120
+ th {
121
+ font-weight: inherit;
122
+ }
123
+ }
124
+ }
125
+
126
+ .edit-site-list.is-navigation-open .components-snackbar-list {
127
+ @include break-medium() {
128
+ margin-left: $nav-sidebar-width;
129
+ }
130
+ }
131
+
132
+ .edit-site-list__rename-modal {
133
+ .components-base-control {
134
+ @include break-medium() {
135
+ width: $grid-unit * 40;
136
+ }
137
+ }
138
+
139
+ .components-modal__header {
140
+ border-bottom: none;
141
+ }
142
+
143
+ .components-modal__content::before {
144
+ margin-bottom: $grid-unit-05;
145
+ }
146
+ }
147
+
148
+ .edit-site-list__rename-modal-actions {
149
+ margin-top: $grid-unit-15;
150
+ }
151
+
152
+ .edit-site-template__actions {
153
+ button:not(:last-child) {
154
+ margin-right: $grid-unit-10;
155
+ }
156
+ }
157
+
158
+ .edit-site-list-added-by__icon {
159
+ display: flex;
160
+ flex-shrink: 0;
161
+ position: relative;
162
+ align-items: center;
163
+ justify-content: center;
164
+ width: $grid-unit-40;
165
+ height: $grid-unit-40;
166
+ background: $gray-800;
167
+ border-radius: 100%;
168
+
169
+ svg {
170
+ fill: $white;
171
+ }
172
+
173
+ &.is-customized::after {
174
+ position: absolute;
175
+ content: "";
176
+ background: var(--wp-admin-theme-color);
177
+ height: $grid-unit-10;
178
+ width: $grid-unit-10;
179
+ outline: 2px solid $white;
180
+ border-radius: 100%;
181
+ top: -1px;
182
+ right: -1px;
183
+ }
184
+ }
185
+
186
+ .edit-site-list-added-by__avatar {
187
+ flex-shrink: 0;
188
+ overflow: hidden;
189
+ border-radius: 100%;
190
+ background: $gray-800;
191
+ width: $grid-unit-40;
192
+ height: $grid-unit-40;
193
+
194
+ img {
195
+ width: $grid-unit-40;
196
+ height: $grid-unit-40;
197
+ object-fit: cover;
198
+ opacity: 0;
199
+ transition: opacity 0.1s linear;
200
+ @include reduce-motion("transition");
201
+ }
202
+
203
+ &.is-loaded {
204
+ img {
205
+ opacity: 1;
206
+ }
207
+ }
208
+ }
@@ -0,0 +1,121 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { useSelect } from '@wordpress/data';
5
+ import { store as coreStore } from '@wordpress/core-data';
6
+ import { __, sprintf } from '@wordpress/i18n';
7
+ import {
8
+ VisuallyHidden,
9
+ __experimentalHeading as Heading,
10
+ } from '@wordpress/components';
11
+ import { addQueryArgs } from '@wordpress/url';
12
+
13
+ /**
14
+ * Internal dependencies
15
+ */
16
+ import Actions from './actions';
17
+ import AddedBy from './added-by';
18
+
19
+ export default function Table( { templateType } ) {
20
+ const { templates, isLoading, postType } = useSelect(
21
+ ( select ) => {
22
+ const {
23
+ getEntityRecords,
24
+ hasFinishedResolution,
25
+ getPostType,
26
+ } = select( coreStore );
27
+
28
+ return {
29
+ templates: getEntityRecords( 'postType', templateType, {
30
+ per_page: -1,
31
+ } ),
32
+ isLoading: ! hasFinishedResolution( 'getEntityRecords', [
33
+ 'postType',
34
+ templateType,
35
+ { per_page: -1 },
36
+ ] ),
37
+ postType: getPostType( templateType ),
38
+ };
39
+ },
40
+ [ templateType ]
41
+ );
42
+
43
+ if ( ! templates || isLoading ) {
44
+ return null;
45
+ }
46
+
47
+ if ( ! templates.length ) {
48
+ return (
49
+ <div>
50
+ { sprintf(
51
+ // translators: The template type name, should be either "templates" or "template parts".
52
+ __( 'No %s found.' ),
53
+ postType?.labels?.name?.toLowerCase()
54
+ ) }
55
+ </div>
56
+ );
57
+ }
58
+
59
+ return (
60
+ // These explicit aria roles are needed for Safari.
61
+ // See https://developer.mozilla.org/en-US/docs/Web/CSS/display#tables
62
+ <table className="edit-site-list-table" role="table">
63
+ <thead>
64
+ <tr className="edit-site-list-table-head" role="row">
65
+ <th
66
+ className="edit-site-list-table-column"
67
+ role="columnheader"
68
+ >
69
+ { __( 'Template' ) }
70
+ </th>
71
+ <th
72
+ className="edit-site-list-table-column"
73
+ role="columnheader"
74
+ >
75
+ { __( 'Added by' ) }
76
+ </th>
77
+ <th
78
+ className="edit-site-list-table-column"
79
+ role="columnheader"
80
+ >
81
+ <VisuallyHidden>{ __( 'Actions' ) }</VisuallyHidden>
82
+ </th>
83
+ </tr>
84
+ </thead>
85
+
86
+ <tbody>
87
+ { templates.map( ( template ) => (
88
+ <tr
89
+ key={ template.id }
90
+ className="edit-site-list-table-row"
91
+ role="row"
92
+ >
93
+ <td className="edit-site-list-table-column" role="cell">
94
+ <Heading level={ 4 }>
95
+ <a
96
+ href={ addQueryArgs( window.location.href, {
97
+ postId: template.id,
98
+ postType: template.type,
99
+ } ) }
100
+ >
101
+ { template.title.rendered }
102
+ </a>
103
+ </Heading>
104
+ { template.description }
105
+ </td>
106
+
107
+ <td className="edit-site-list-table-column" role="cell">
108
+ <AddedBy
109
+ templateType={ templateType }
110
+ template={ template }
111
+ />
112
+ </td>
113
+ <td className="edit-site-list-table-column" role="cell">
114
+ <Actions template={ template } />
115
+ </td>
116
+ </tr>
117
+ ) ) }
118
+ </tbody>
119
+ </table>
120
+ );
121
+ }
@@ -0,0 +1,45 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+
5
+ import { useDispatch } from '@wordpress/data';
6
+ import { useEffect } from '@wordpress/element';
7
+ import { __ } from '@wordpress/i18n';
8
+ import { store as keyboardShortcutsStore } from '@wordpress/keyboard-shortcuts';
9
+
10
+ export default function useRegisterShortcuts() {
11
+ const { registerShortcut } = useDispatch( keyboardShortcutsStore );
12
+ useEffect( () => {
13
+ registerShortcut( {
14
+ name: 'core/edit-site/next-region',
15
+ category: 'global',
16
+ description: __( 'Navigate to the next part of the editor.' ),
17
+ keyCombination: {
18
+ modifier: 'ctrl',
19
+ character: '`',
20
+ },
21
+ aliases: [
22
+ {
23
+ modifier: 'access',
24
+ character: 'n',
25
+ },
26
+ ],
27
+ } );
28
+
29
+ registerShortcut( {
30
+ name: 'core/edit-site/previous-region',
31
+ category: 'global',
32
+ description: __( 'Navigate to the previous part of the editor.' ),
33
+ keyCombination: {
34
+ modifier: 'ctrlShift',
35
+ character: '`',
36
+ },
37
+ aliases: [
38
+ {
39
+ modifier: 'access',
40
+ character: 'p',
41
+ },
42
+ ],
43
+ } );
44
+ }, [] );
45
+ }
@@ -1,30 +1,46 @@
1
1
  /**
2
2
  * WordPress dependencies
3
3
  */
4
+ import { useEffect } from '@wordpress/element';
4
5
  import { createSlotFill } from '@wordpress/components';
5
- import { useSelect } from '@wordpress/data';
6
+ import { useViewportMatch } from '@wordpress/compose';
7
+ import { useDispatch } from '@wordpress/data';
6
8
 
7
9
  /**
8
10
  * Internal dependencies
9
11
  */
12
+ import { store as editSiteStore } from '../../store';
10
13
  import NavigationPanel from './navigation-panel';
11
14
  import NavigationToggle from './navigation-toggle';
12
- import { store as editSiteStore } from '../../store';
13
15
 
14
16
  export const {
15
17
  Fill: NavigationPanelPreviewFill,
16
18
  Slot: NavigationPanelPreviewSlot,
17
19
  } = createSlotFill( 'EditSiteNavigationPanelPreview' );
18
20
 
19
- export default function NavigationSidebar() {
20
- const isNavigationOpen = useSelect( ( select ) => {
21
- return select( editSiteStore ).isNavigationOpened();
22
- }, [] );
21
+ export default function NavigationSidebar( {
22
+ isDefaultOpen = false,
23
+ activeTemplateType,
24
+ } ) {
25
+ const isDesktopViewport = useViewportMatch( 'medium' );
26
+ const { setIsNavigationPanelOpened } = useDispatch( editSiteStore );
27
+
28
+ useEffect( () => {
29
+ // When transitioning to desktop open the navigation if `isDefaultOpen` is true.
30
+ if ( isDefaultOpen && isDesktopViewport ) {
31
+ setIsNavigationPanelOpened( true );
32
+ }
33
+
34
+ // When transitioning to mobile/tablet, close the navigation.
35
+ if ( ! isDesktopViewport ) {
36
+ setIsNavigationPanelOpened( false );
37
+ }
38
+ }, [ isDefaultOpen, isDesktopViewport, setIsNavigationPanelOpened ] );
23
39
 
24
40
  return (
25
41
  <>
26
- <NavigationToggle isOpen={ isNavigationOpen } />
27
- <NavigationPanel isOpen={ isNavigationOpen } />
42
+ <NavigationToggle />
43
+ <NavigationPanel activeItem={ activeTemplateType } />
28
44
  <NavigationPanelPreviewSlot />
29
45
  </>
30
46
  );