@wordpress/edit-site 6.3.0 → 6.5.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 (334) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/build/components/add-new-pattern/index.js +14 -3
  3. package/build/components/add-new-pattern/index.js.map +1 -1
  4. package/build/components/add-new-post/index.js +2 -1
  5. package/build/components/add-new-post/index.js.map +1 -1
  6. package/build/components/add-new-template/index.js +3 -1
  7. package/build/components/add-new-template/index.js.map +1 -1
  8. package/build/components/add-new-template/utils.js +2 -2
  9. package/build/components/add-new-template/utils.js.map +1 -1
  10. package/build/components/block-editor/use-site-editor-settings.js +1 -82
  11. package/build/components/block-editor/use-site-editor-settings.js.map +1 -1
  12. package/build/components/editor/index.js +71 -20
  13. package/build/components/editor/index.js.map +1 -1
  14. package/build/components/global-styles/block-preview-panel.js +14 -5
  15. package/build/components/global-styles/block-preview-panel.js.map +1 -1
  16. package/build/components/global-styles/font-families.js +40 -22
  17. package/build/components/global-styles/font-families.js.map +1 -1
  18. package/build/components/global-styles/font-library-modal/context.js +0 -5
  19. package/build/components/global-styles/font-library-modal/context.js.map +1 -1
  20. package/build/components/global-styles/font-library-modal/font-collection.js +25 -5
  21. package/build/components/global-styles/font-library-modal/font-collection.js.map +1 -1
  22. package/build/components/global-styles/font-library-modal/index.js +5 -12
  23. package/build/components/global-styles/font-library-modal/index.js.map +1 -1
  24. package/build/components/global-styles/font-library-modal/installed-fonts.js +78 -15
  25. package/build/components/global-styles/font-library-modal/installed-fonts.js.map +1 -1
  26. package/build/components/global-styles/font-library-modal/upload-fonts.js +2 -3
  27. package/build/components/global-styles/font-library-modal/upload-fonts.js.map +1 -1
  28. package/build/components/global-styles/font-sizes/confirm-delete-font-size-dialog.js +39 -0
  29. package/build/components/global-styles/font-sizes/confirm-delete-font-size-dialog.js.map +1 -0
  30. package/build/components/global-styles/font-sizes/confirm-reset-font-sizes-dialog.js +39 -0
  31. package/build/components/global-styles/font-sizes/confirm-reset-font-sizes-dialog.js.map +1 -0
  32. package/build/components/global-styles/font-sizes/font-size-preview.js +44 -0
  33. package/build/components/global-styles/font-sizes/font-size-preview.js.map +1 -0
  34. package/build/components/global-styles/font-sizes/font-size.js +213 -0
  35. package/build/components/global-styles/font-sizes/font-size.js.map +1 -0
  36. package/build/components/global-styles/font-sizes/font-sizes-count.js +50 -0
  37. package/build/components/global-styles/font-sizes/font-sizes-count.js.map +1 -0
  38. package/build/components/global-styles/font-sizes/font-sizes.js +163 -0
  39. package/build/components/global-styles/font-sizes/font-sizes.js.map +1 -0
  40. package/build/components/global-styles/font-sizes/rename-font-size-dialog.js +67 -0
  41. package/build/components/global-styles/font-sizes/rename-font-size-dialog.js.map +1 -0
  42. package/build/components/global-styles/screen-block.js +10 -8
  43. package/build/components/global-styles/screen-block.js.map +1 -1
  44. package/build/components/global-styles/screen-style-variations.js +2 -2
  45. package/build/components/global-styles/screen-style-variations.js.map +1 -1
  46. package/build/components/global-styles/screen-typeset.js +40 -0
  47. package/build/components/global-styles/screen-typeset.js.map +1 -0
  48. package/build/components/global-styles/screen-typography-element.js +14 -0
  49. package/build/components/global-styles/screen-typography-element.js.map +1 -1
  50. package/build/components/global-styles/screen-typography.js +5 -6
  51. package/build/components/global-styles/screen-typography.js.map +1 -1
  52. package/build/components/global-styles/shadows-edit-panel.js +50 -59
  53. package/build/components/global-styles/shadows-edit-panel.js.map +1 -1
  54. package/build/components/global-styles/size-control/index.js +85 -0
  55. package/build/components/global-styles/size-control/index.js.map +1 -0
  56. package/build/components/global-styles/style-variations-container.js +3 -0
  57. package/build/components/global-styles/style-variations-container.js.map +1 -1
  58. package/build/components/global-styles/typeset-button.js +97 -0
  59. package/build/components/global-styles/typeset-button.js.map +1 -0
  60. package/build/components/global-styles/typeset.js +80 -0
  61. package/build/components/global-styles/typeset.js.map +1 -0
  62. package/build/components/global-styles/ui.js +12 -0
  63. package/build/components/global-styles/ui.js.map +1 -1
  64. package/build/components/global-styles/utils.js +10 -1
  65. package/build/components/global-styles/utils.js.map +1 -1
  66. package/build/components/global-styles/variations/variations-color.js.map +1 -1
  67. package/build/components/global-styles/variations/variations-typography.js +1 -1
  68. package/build/components/global-styles/variations/variations-typography.js.map +1 -1
  69. package/build/components/layout/index.js +6 -0
  70. package/build/components/layout/index.js.map +1 -1
  71. package/build/components/layout/router.js +14 -6
  72. package/build/components/layout/router.js.map +1 -1
  73. package/build/components/page-patterns/fields.js +230 -0
  74. package/build/components/page-patterns/fields.js.map +1 -0
  75. package/build/components/page-patterns/header.js +1 -1
  76. package/build/components/page-patterns/header.js.map +1 -1
  77. package/build/components/page-patterns/index.js +21 -227
  78. package/build/components/page-patterns/index.js.map +1 -1
  79. package/build/components/page-patterns/use-patterns.js +26 -1
  80. package/build/components/page-patterns/use-patterns.js.map +1 -1
  81. package/build/components/page-templates/fields.js +169 -0
  82. package/build/components/page-templates/fields.js.map +1 -0
  83. package/build/components/page-templates/index.js +38 -198
  84. package/build/components/page-templates/index.js.map +1 -1
  85. package/build/components/post-edit/index.js +117 -0
  86. package/build/components/post-edit/index.js.map +1 -0
  87. package/build/components/post-fields/index.js +318 -0
  88. package/build/components/post-fields/index.js.map +1 -0
  89. package/build/components/post-list/index.js +339 -0
  90. package/build/components/post-list/index.js.map +1 -0
  91. package/build/components/posts-app/router.js +3 -3
  92. package/build/components/posts-app/router.js.map +1 -1
  93. package/build/components/sidebar-dataviews/add-new-view.js +2 -2
  94. package/build/components/sidebar-dataviews/add-new-view.js.map +1 -1
  95. package/build/components/sidebar-dataviews/dataview-item.js +2 -3
  96. package/build/components/sidebar-dataviews/dataview-item.js.map +1 -1
  97. package/build/components/sidebar-dataviews/default-views.js +103 -91
  98. package/build/components/sidebar-dataviews/default-views.js.map +1 -1
  99. package/build/components/sidebar-dataviews/index.js +2 -2
  100. package/build/components/sidebar-dataviews/index.js.map +1 -1
  101. package/build/components/sidebar-navigation-screen-global-styles/content.js +64 -0
  102. package/build/components/sidebar-navigation-screen-global-styles/content.js.map +1 -0
  103. package/build/components/sidebar-navigation-screen-global-styles/index.js +2 -47
  104. package/build/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  105. package/build/components/site-hub/index.js +6 -3
  106. package/build/components/site-hub/index.js.map +1 -1
  107. package/build/components/style-book/index.js +22 -25
  108. package/build/components/style-book/index.js.map +1 -1
  109. package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js +5 -0
  110. package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
  111. package/build/hooks/push-changes-to-global-styles/index.js +3 -4
  112. package/build/hooks/push-changes-to-global-styles/index.js.map +1 -1
  113. package/build/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js +2 -4
  114. package/build/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js.map +1 -1
  115. package/build/index.js +4 -2
  116. package/build/index.js.map +1 -1
  117. package/build/store/selectors.js +34 -6
  118. package/build/store/selectors.js.map +1 -1
  119. package/build/utils/get-filtered-template-parts.js +64 -0
  120. package/build/utils/get-filtered-template-parts.js.map +1 -0
  121. package/build-module/components/add-new-pattern/index.js +14 -3
  122. package/build-module/components/add-new-pattern/index.js.map +1 -1
  123. package/build-module/components/add-new-post/index.js +2 -1
  124. package/build-module/components/add-new-post/index.js.map +1 -1
  125. package/build-module/components/add-new-template/index.js +3 -1
  126. package/build-module/components/add-new-template/index.js.map +1 -1
  127. package/build-module/components/add-new-template/utils.js +2 -2
  128. package/build-module/components/add-new-template/utils.js.map +1 -1
  129. package/build-module/components/block-editor/use-site-editor-settings.js +1 -82
  130. package/build-module/components/block-editor/use-site-editor-settings.js.map +1 -1
  131. package/build-module/components/editor/index.js +73 -22
  132. package/build-module/components/editor/index.js.map +1 -1
  133. package/build-module/components/global-styles/block-preview-panel.js +14 -5
  134. package/build-module/components/global-styles/block-preview-panel.js.map +1 -1
  135. package/build-module/components/global-styles/font-families.js +42 -24
  136. package/build-module/components/global-styles/font-families.js.map +1 -1
  137. package/build-module/components/global-styles/font-library-modal/context.js +0 -5
  138. package/build-module/components/global-styles/font-library-modal/context.js.map +1 -1
  139. package/build-module/components/global-styles/font-library-modal/font-collection.js +26 -6
  140. package/build-module/components/global-styles/font-library-modal/font-collection.js.map +1 -1
  141. package/build-module/components/global-styles/font-library-modal/index.js +5 -12
  142. package/build-module/components/global-styles/font-library-modal/index.js.map +1 -1
  143. package/build-module/components/global-styles/font-library-modal/installed-fonts.js +81 -18
  144. package/build-module/components/global-styles/font-library-modal/installed-fonts.js.map +1 -1
  145. package/build-module/components/global-styles/font-library-modal/upload-fonts.js +2 -3
  146. package/build-module/components/global-styles/font-library-modal/upload-fonts.js.map +1 -1
  147. package/build-module/components/global-styles/font-sizes/confirm-delete-font-size-dialog.js +32 -0
  148. package/build-module/components/global-styles/font-sizes/confirm-delete-font-size-dialog.js.map +1 -0
  149. package/build-module/components/global-styles/font-sizes/confirm-reset-font-sizes-dialog.js +32 -0
  150. package/build-module/components/global-styles/font-sizes/confirm-reset-font-sizes-dialog.js.map +1 -0
  151. package/build-module/components/global-styles/font-sizes/font-size-preview.js +37 -0
  152. package/build-module/components/global-styles/font-sizes/font-size-preview.js.map +1 -0
  153. package/build-module/components/global-styles/font-sizes/font-size.js +207 -0
  154. package/build-module/components/global-styles/font-sizes/font-size.js.map +1 -0
  155. package/build-module/components/global-styles/font-sizes/font-sizes-count.js +43 -0
  156. package/build-module/components/global-styles/font-sizes/font-sizes-count.js.map +1 -0
  157. package/build-module/components/global-styles/font-sizes/font-sizes.js +157 -0
  158. package/build-module/components/global-styles/font-sizes/font-sizes.js.map +1 -0
  159. package/build-module/components/global-styles/font-sizes/rename-font-size-dialog.js +61 -0
  160. package/build-module/components/global-styles/font-sizes/rename-font-size-dialog.js.map +1 -0
  161. package/build-module/components/global-styles/screen-block.js +10 -8
  162. package/build-module/components/global-styles/screen-block.js.map +1 -1
  163. package/build-module/components/global-styles/screen-style-variations.js +2 -2
  164. package/build-module/components/global-styles/screen-style-variations.js.map +1 -1
  165. package/build-module/components/global-styles/screen-typeset.js +34 -0
  166. package/build-module/components/global-styles/screen-typeset.js.map +1 -0
  167. package/build-module/components/global-styles/screen-typography-element.js +14 -0
  168. package/build-module/components/global-styles/screen-typography-element.js.map +1 -1
  169. package/build-module/components/global-styles/screen-typography.js +5 -6
  170. package/build-module/components/global-styles/screen-typography.js.map +1 -1
  171. package/build-module/components/global-styles/shadows-edit-panel.js +51 -60
  172. package/build-module/components/global-styles/shadows-edit-panel.js.map +1 -1
  173. package/build-module/components/global-styles/size-control/index.js +79 -0
  174. package/build-module/components/global-styles/size-control/index.js.map +1 -0
  175. package/build-module/components/global-styles/style-variations-container.js +3 -0
  176. package/build-module/components/global-styles/style-variations-container.js.map +1 -1
  177. package/build-module/components/global-styles/typeset-button.js +89 -0
  178. package/build-module/components/global-styles/typeset-button.js.map +1 -0
  179. package/build-module/components/global-styles/typeset.js +71 -0
  180. package/build-module/components/global-styles/typeset.js.map +1 -0
  181. package/build-module/components/global-styles/ui.js +12 -0
  182. package/build-module/components/global-styles/ui.js.map +1 -1
  183. package/build-module/components/global-styles/utils.js +10 -1
  184. package/build-module/components/global-styles/utils.js.map +1 -1
  185. package/build-module/components/global-styles/variations/variations-color.js +1 -1
  186. package/build-module/components/global-styles/variations/variations-color.js.map +1 -1
  187. package/build-module/components/global-styles/variations/variations-typography.js +1 -2
  188. package/build-module/components/global-styles/variations/variations-typography.js.map +1 -1
  189. package/build-module/components/layout/index.js +6 -0
  190. package/build-module/components/layout/index.js.map +1 -1
  191. package/build-module/components/layout/router.js +14 -6
  192. package/build-module/components/layout/router.js.map +1 -1
  193. package/build-module/components/page-patterns/fields.js +223 -0
  194. package/build-module/components/page-patterns/fields.js.map +1 -0
  195. package/build-module/components/page-patterns/header.js +1 -1
  196. package/build-module/components/page-patterns/header.js.map +1 -1
  197. package/build-module/components/page-patterns/index.js +24 -230
  198. package/build-module/components/page-patterns/index.js.map +1 -1
  199. package/build-module/components/page-patterns/use-patterns.js +26 -1
  200. package/build-module/components/page-patterns/use-patterns.js.map +1 -1
  201. package/build-module/components/page-templates/fields.js +160 -0
  202. package/build-module/components/page-templates/fields.js.map +1 -0
  203. package/build-module/components/page-templates/index.js +39 -199
  204. package/build-module/components/page-templates/index.js.map +1 -1
  205. package/build-module/components/post-edit/index.js +110 -0
  206. package/build-module/components/post-edit/index.js.map +1 -0
  207. package/build-module/components/post-fields/index.js +310 -0
  208. package/build-module/components/post-fields/index.js.map +1 -0
  209. package/build-module/components/post-list/index.js +333 -0
  210. package/build-module/components/post-list/index.js.map +1 -0
  211. package/build-module/components/posts-app/router.js +3 -3
  212. package/build-module/components/posts-app/router.js.map +1 -1
  213. package/build-module/components/sidebar-dataviews/add-new-view.js +2 -2
  214. package/build-module/components/sidebar-dataviews/add-new-view.js.map +1 -1
  215. package/build-module/components/sidebar-dataviews/dataview-item.js +2 -3
  216. package/build-module/components/sidebar-dataviews/dataview-item.js.map +1 -1
  217. package/build-module/components/sidebar-dataviews/default-views.js +102 -90
  218. package/build-module/components/sidebar-dataviews/default-views.js.map +1 -1
  219. package/build-module/components/sidebar-dataviews/index.js +5 -5
  220. package/build-module/components/sidebar-dataviews/index.js.map +1 -1
  221. package/build-module/components/sidebar-navigation-screen-global-styles/content.js +57 -0
  222. package/build-module/components/sidebar-navigation-screen-global-styles/content.js.map +1 -0
  223. package/build-module/components/sidebar-navigation-screen-global-styles/index.js +2 -47
  224. package/build-module/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  225. package/build-module/components/site-hub/index.js +7 -4
  226. package/build-module/components/site-hub/index.js.map +1 -1
  227. package/build-module/components/style-book/index.js +23 -26
  228. package/build-module/components/style-book/index.js.map +1 -1
  229. package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js +5 -0
  230. package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
  231. package/build-module/hooks/push-changes-to-global-styles/index.js +3 -4
  232. package/build-module/hooks/push-changes-to-global-styles/index.js.map +1 -1
  233. package/build-module/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js +2 -3
  234. package/build-module/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js.map +1 -1
  235. package/build-module/index.js +4 -2
  236. package/build-module/index.js.map +1 -1
  237. package/build-module/store/selectors.js +35 -7
  238. package/build-module/store/selectors.js.map +1 -1
  239. package/build-module/utils/get-filtered-template-parts.js +57 -0
  240. package/build-module/utils/get-filtered-template-parts.js.map +1 -0
  241. package/build-style/posts-rtl.css +749 -492
  242. package/build-style/posts.css +749 -492
  243. package/build-style/style-rtl.css +956 -613
  244. package/build-style/style.css +956 -613
  245. package/package.json +41 -41
  246. package/src/components/add-new-pattern/index.js +16 -5
  247. package/src/components/add-new-post/index.js +2 -1
  248. package/src/components/add-new-template/index.js +4 -1
  249. package/src/components/add-new-template/style.scss +4 -6
  250. package/src/components/add-new-template/utils.js +10 -6
  251. package/src/components/block-editor/use-site-editor-settings.js +15 -111
  252. package/src/components/editor/index.js +80 -22
  253. package/src/components/editor/style.scss +59 -1
  254. package/src/components/global-styles/block-preview-panel.js +22 -9
  255. package/src/components/global-styles/font-families.js +65 -32
  256. package/src/components/global-styles/font-library-modal/context.js +0 -5
  257. package/src/components/global-styles/font-library-modal/font-collection.js +34 -10
  258. package/src/components/global-styles/font-library-modal/index.js +6 -9
  259. package/src/components/global-styles/font-library-modal/installed-fonts.js +115 -16
  260. package/src/components/global-styles/font-library-modal/style.scss +9 -0
  261. package/src/components/global-styles/font-library-modal/upload-fonts.js +2 -2
  262. package/src/components/global-styles/font-sizes/confirm-delete-font-size-dialog.js +43 -0
  263. package/src/components/global-styles/font-sizes/confirm-reset-font-sizes-dialog.js +37 -0
  264. package/src/components/global-styles/font-sizes/font-size-preview.js +43 -0
  265. package/src/components/global-styles/font-sizes/font-size.js +250 -0
  266. package/src/components/global-styles/font-sizes/font-sizes-count.js +40 -0
  267. package/src/components/global-styles/font-sizes/font-sizes.js +263 -0
  268. package/src/components/global-styles/font-sizes/rename-font-size-dialog.js +70 -0
  269. package/src/components/global-styles/screen-block.js +12 -14
  270. package/src/components/global-styles/screen-style-variations.js +2 -2
  271. package/src/components/global-styles/screen-typeset.js +42 -0
  272. package/src/components/global-styles/screen-typography-element.js +14 -0
  273. package/src/components/global-styles/screen-typography.js +7 -6
  274. package/src/components/global-styles/shadows-edit-panel.js +66 -73
  275. package/src/components/global-styles/size-control/index.js +86 -0
  276. package/src/components/global-styles/style-variations-container.js +4 -0
  277. package/src/components/global-styles/style.scss +17 -10
  278. package/src/components/global-styles/typeset-button.js +93 -0
  279. package/src/components/global-styles/typeset.js +73 -0
  280. package/src/components/global-styles/ui.js +15 -0
  281. package/src/components/global-styles/utils.js +13 -1
  282. package/src/components/global-styles/variations/variations-color.js +1 -1
  283. package/src/components/global-styles/variations/variations-typography.js +1 -2
  284. package/src/components/layout/index.js +11 -0
  285. package/src/components/layout/router.js +13 -5
  286. package/src/components/layout/style.scss +34 -8
  287. package/src/components/page-patterns/fields.js +251 -0
  288. package/src/components/page-patterns/header.js +1 -1
  289. package/src/components/page-patterns/index.js +24 -246
  290. package/src/components/page-patterns/style.scss +82 -85
  291. package/src/components/page-patterns/use-patterns.js +31 -1
  292. package/src/components/page-templates/fields.js +157 -0
  293. package/src/components/page-templates/index.js +46 -192
  294. package/src/components/page-templates/style.scss +19 -8
  295. package/src/components/post-edit/index.js +115 -0
  296. package/src/components/post-edit/style.scss +9 -0
  297. package/src/components/post-fields/index.js +357 -0
  298. package/src/components/post-list/index.js +386 -0
  299. package/src/components/{posts-app → post-list}/style.scss +12 -9
  300. package/src/components/posts-app/router.js +3 -3
  301. package/src/components/sidebar-dataviews/add-new-view.js +2 -4
  302. package/src/components/sidebar-dataviews/dataview-item.js +2 -2
  303. package/src/components/sidebar-dataviews/default-views.js +116 -104
  304. package/src/components/sidebar-dataviews/index.js +4 -3
  305. package/src/components/sidebar-navigation-screen-global-styles/content.js +55 -0
  306. package/src/components/sidebar-navigation-screen-global-styles/index.js +1 -55
  307. package/src/components/site-hub/index.js +11 -2
  308. package/src/components/site-icon/style.scss +4 -1
  309. package/src/components/style-book/index.js +27 -32
  310. package/src/components/sync-state-with-url/use-init-edited-entity-from-url.js +5 -0
  311. package/src/hooks/push-changes-to-global-styles/index.js +3 -4
  312. package/src/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js +2 -3
  313. package/src/index.js +6 -2
  314. package/src/posts.scss +1 -1
  315. package/src/store/selectors.js +53 -14
  316. package/src/store/test/selectors.js +1 -26
  317. package/src/style.scss +2 -1
  318. package/src/utils/get-filtered-template-parts.js +61 -0
  319. package/src/utils/test/get-filtered-template-parts.js +127 -0
  320. package/build/components/global-styles/screen-background.js +0 -36
  321. package/build/components/global-styles/screen-background.js.map +0 -1
  322. package/build/components/posts-app/posts-list.js +0 -568
  323. package/build/components/posts-app/posts-list.js.map +0 -1
  324. package/build/utils/clone-deep.js +0 -15
  325. package/build/utils/clone-deep.js.map +0 -1
  326. package/build-module/components/global-styles/screen-background.js +0 -30
  327. package/build-module/components/global-styles/screen-background.js.map +0 -1
  328. package/build-module/components/posts-app/posts-list.js +0 -560
  329. package/build-module/components/posts-app/posts-list.js.map +0 -1
  330. package/build-module/utils/clone-deep.js +0 -9
  331. package/build-module/utils/clone-deep.js.map +0 -1
  332. package/src/components/global-styles/screen-background.js +0 -29
  333. package/src/components/posts-app/posts-list.js +0 -651
  334. package/src/utils/clone-deep.js +0 -8
@@ -0,0 +1,357 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import clsx from 'clsx';
5
+
6
+ /**
7
+ * WordPress dependencies
8
+ */
9
+ import { __, sprintf } from '@wordpress/i18n';
10
+ import { decodeEntities } from '@wordpress/html-entities';
11
+ import {
12
+ createInterpolateElement,
13
+ useMemo,
14
+ useState,
15
+ } from '@wordpress/element';
16
+ import { dateI18n, getDate, getSettings } from '@wordpress/date';
17
+ import {
18
+ trash,
19
+ drafts,
20
+ published,
21
+ scheduled,
22
+ pending,
23
+ notAllowed,
24
+ commentAuthorAvatar as authorIcon,
25
+ } from '@wordpress/icons';
26
+ import { __experimentalHStack as HStack, Icon } from '@wordpress/components';
27
+ import { useSelect } from '@wordpress/data';
28
+ import { useEntityRecords, store as coreStore } from '@wordpress/core-data';
29
+
30
+ /**
31
+ * Internal dependencies
32
+ */
33
+ import {
34
+ LAYOUT_GRID,
35
+ LAYOUT_TABLE,
36
+ LAYOUT_LIST,
37
+ OPERATOR_IS_ANY,
38
+ } from '../../utils/constants';
39
+ import { default as Link, useLink } from '../routes/link';
40
+ import Media from '../media';
41
+
42
+ // See https://github.com/WordPress/gutenberg/issues/55886
43
+ // We do not support custom statutes at the moment.
44
+ const STATUSES = [
45
+ { value: 'draft', label: __( 'Draft' ), icon: drafts },
46
+ { value: 'future', label: __( 'Scheduled' ), icon: scheduled },
47
+ { value: 'pending', label: __( 'Pending Review' ), icon: pending },
48
+ { value: 'private', label: __( 'Private' ), icon: notAllowed },
49
+ { value: 'publish', label: __( 'Published' ), icon: published },
50
+ { value: 'trash', label: __( 'Trash' ), icon: trash },
51
+ ];
52
+
53
+ const getFormattedDate = ( dateToDisplay ) =>
54
+ dateI18n(
55
+ getSettings().formats.datetimeAbbreviated,
56
+ getDate( dateToDisplay )
57
+ );
58
+
59
+ function FeaturedImage( { item, viewType } ) {
60
+ const isDisabled = item.status === 'trash';
61
+ const { onClick } = useLink( {
62
+ postId: item.id,
63
+ postType: item.type,
64
+ canvas: 'edit',
65
+ } );
66
+ const hasMedia = !! item.featured_media;
67
+ const size =
68
+ viewType === LAYOUT_GRID
69
+ ? [ 'large', 'full', 'medium', 'thumbnail' ]
70
+ : [ 'thumbnail', 'medium', 'large', 'full' ];
71
+ const media = hasMedia ? (
72
+ <Media
73
+ className="edit-site-post-list__featured-image"
74
+ id={ item.featured_media }
75
+ size={ size }
76
+ />
77
+ ) : null;
78
+ const renderButton = viewType !== LAYOUT_LIST && ! isDisabled;
79
+ return (
80
+ <div
81
+ className={ `edit-site-post-list__featured-image-wrapper is-layout-${ viewType }` }
82
+ >
83
+ { renderButton ? (
84
+ <button
85
+ className="edit-site-post-list__featured-image-button"
86
+ type="button"
87
+ onClick={ onClick }
88
+ aria-label={ item.title?.rendered || __( '(no title)' ) }
89
+ >
90
+ { media }
91
+ </button>
92
+ ) : (
93
+ media
94
+ ) }
95
+ </div>
96
+ );
97
+ }
98
+
99
+ function PostStatusField( { item } ) {
100
+ const status = STATUSES.find( ( { value } ) => value === item.status );
101
+ const label = status?.label || item.status;
102
+ const icon = status?.icon;
103
+ return (
104
+ <HStack alignment="left" spacing={ 0 }>
105
+ { icon && (
106
+ <div className="edit-site-post-list__status-icon">
107
+ <Icon icon={ icon } />
108
+ </div>
109
+ ) }
110
+ <span>{ label }</span>
111
+ </HStack>
112
+ );
113
+ }
114
+
115
+ function PostAuthorField( { item } ) {
116
+ const { text, imageUrl } = useSelect(
117
+ ( select ) => {
118
+ const { getUser } = select( coreStore );
119
+ const user = getUser( item.author );
120
+ return {
121
+ imageUrl: user?.avatar_urls?.[ 48 ],
122
+ text: user?.name,
123
+ };
124
+ },
125
+ [ item ]
126
+ );
127
+ const [ isImageLoaded, setIsImageLoaded ] = useState( false );
128
+ return (
129
+ <HStack alignment="left" spacing={ 0 }>
130
+ { !! imageUrl && (
131
+ <div
132
+ className={ clsx( 'page-templates-author-field__avatar', {
133
+ 'is-loaded': isImageLoaded,
134
+ } ) }
135
+ >
136
+ <img
137
+ onLoad={ () => setIsImageLoaded( true ) }
138
+ alt={ __( 'Author avatar' ) }
139
+ src={ imageUrl }
140
+ />
141
+ </div>
142
+ ) }
143
+ { ! imageUrl && (
144
+ <div className="page-templates-author-field__icon">
145
+ <Icon icon={ authorIcon } />
146
+ </div>
147
+ ) }
148
+ <span className="page-templates-author-field__name">{ text }</span>
149
+ </HStack>
150
+ );
151
+ }
152
+
153
+ function usePostFields( viewType ) {
154
+ const { records: authors, isResolving: isLoadingAuthors } =
155
+ useEntityRecords( 'root', 'user', { per_page: -1 } );
156
+
157
+ const { frontPageId, postsPageId } = useSelect( ( select ) => {
158
+ const { getEntityRecord } = select( coreStore );
159
+ const siteSettings = getEntityRecord( 'root', 'site' );
160
+ return {
161
+ frontPageId: siteSettings?.page_on_front,
162
+ postsPageId: siteSettings?.page_for_posts,
163
+ };
164
+ }, [] );
165
+
166
+ const fields = useMemo(
167
+ () => [
168
+ {
169
+ id: 'featured-image',
170
+ label: __( 'Featured Image' ),
171
+ getValue: ( { item } ) => item.featured_media,
172
+ render: ( { item } ) => (
173
+ <FeaturedImage item={ item } viewType={ viewType } />
174
+ ),
175
+ enableSorting: false,
176
+ },
177
+ {
178
+ label: __( 'Title' ),
179
+ id: 'title',
180
+ type: 'text',
181
+ getValue: ( { item } ) =>
182
+ typeof item.title === 'string'
183
+ ? item.title
184
+ : item.title?.raw,
185
+ render: ( { item } ) => {
186
+ const addLink =
187
+ [ LAYOUT_TABLE, LAYOUT_GRID ].includes( viewType ) &&
188
+ item.status !== 'trash';
189
+ const renderedTitle =
190
+ typeof item.title === 'string'
191
+ ? item.title
192
+ : item.title?.rendered;
193
+ const title = addLink ? (
194
+ <Link
195
+ params={ {
196
+ postId: item.id,
197
+ postType: item.type,
198
+ canvas: 'edit',
199
+ } }
200
+ >
201
+ { decodeEntities( renderedTitle ) ||
202
+ __( '(no title)' ) }
203
+ </Link>
204
+ ) : (
205
+ <span>
206
+ { decodeEntities( renderedTitle ) ||
207
+ __( '(no title)' ) }
208
+ </span>
209
+ );
210
+
211
+ let suffix = '';
212
+ if ( item.id === frontPageId ) {
213
+ suffix = (
214
+ <span className="edit-site-post-list__title-badge">
215
+ { __( 'Homepage' ) }
216
+ </span>
217
+ );
218
+ } else if ( item.id === postsPageId ) {
219
+ suffix = (
220
+ <span className="edit-site-post-list__title-badge">
221
+ { __( 'Posts Page' ) }
222
+ </span>
223
+ );
224
+ }
225
+
226
+ return (
227
+ <HStack
228
+ className="edit-site-post-list__title"
229
+ alignment="center"
230
+ justify="flex-start"
231
+ >
232
+ { title }
233
+ { suffix }
234
+ </HStack>
235
+ );
236
+ },
237
+ enableHiding: false,
238
+ },
239
+ {
240
+ label: __( 'Author' ),
241
+ id: 'author',
242
+ type: 'integer',
243
+ elements:
244
+ authors?.map( ( { id, name } ) => ( {
245
+ value: id,
246
+ label: name,
247
+ } ) ) || [],
248
+ render: PostAuthorField,
249
+ sort: ( a, b, direction ) => {
250
+ const nameA = a._embedded?.author?.[ 0 ]?.name || '';
251
+ const nameB = b._embedded?.author?.[ 0 ]?.name || '';
252
+
253
+ return direction === 'asc'
254
+ ? nameA.localeCompare( nameB )
255
+ : nameB.localeCompare( nameA );
256
+ },
257
+ },
258
+ {
259
+ label: __( 'Status' ),
260
+ id: 'status',
261
+ getValue: ( { item } ) =>
262
+ STATUSES.find( ( { value } ) => value === item.status )
263
+ ?.label ?? item.status,
264
+ elements: STATUSES,
265
+ render: PostStatusField,
266
+ enableSorting: false,
267
+ filterBy: {
268
+ operators: [ OPERATOR_IS_ANY ],
269
+ },
270
+ },
271
+ {
272
+ label: __( 'Date' ),
273
+ id: 'date',
274
+ render: ( { item } ) => {
275
+ const isDraftOrPrivate = [ 'draft', 'private' ].includes(
276
+ item.status
277
+ );
278
+ if ( isDraftOrPrivate ) {
279
+ return createInterpolateElement(
280
+ sprintf(
281
+ /* translators: %s: page creation date */
282
+ __( '<span>Modified: <time>%s</time></span>' ),
283
+ getFormattedDate( item.date )
284
+ ),
285
+ {
286
+ span: <span />,
287
+ time: <time />,
288
+ }
289
+ );
290
+ }
291
+
292
+ const isScheduled = item.status === 'future';
293
+ if ( isScheduled ) {
294
+ return createInterpolateElement(
295
+ sprintf(
296
+ /* translators: %s: page creation date */
297
+ __( '<span>Scheduled: <time>%s</time></span>' ),
298
+ getFormattedDate( item.date )
299
+ ),
300
+ {
301
+ span: <span />,
302
+ time: <time />,
303
+ }
304
+ );
305
+ }
306
+
307
+ const isPublished = item.status === 'publish';
308
+ if ( isPublished ) {
309
+ return createInterpolateElement(
310
+ sprintf(
311
+ /* translators: %s: page creation time */
312
+ __( '<span>Published: <time>%s</time></span>' ),
313
+ getFormattedDate( item.date )
314
+ ),
315
+ {
316
+ span: <span />,
317
+ time: <time />,
318
+ }
319
+ );
320
+ }
321
+
322
+ // Pending posts show the modified date if it's newer.
323
+ const dateToDisplay =
324
+ getDate( item.modified ) > getDate( item.date )
325
+ ? item.modified
326
+ : item.date;
327
+
328
+ const isPending = item.status === 'pending';
329
+ if ( isPending ) {
330
+ return createInterpolateElement(
331
+ sprintf(
332
+ /* translators: %s: the newest of created or modified date for the page */
333
+ __( '<span>Modified: <time>%s</time></span>' ),
334
+ getFormattedDate( dateToDisplay )
335
+ ),
336
+ {
337
+ span: <span />,
338
+ time: <time />,
339
+ }
340
+ );
341
+ }
342
+
343
+ // Unknow status.
344
+ return <time>{ getFormattedDate( item.date ) }</time>;
345
+ },
346
+ },
347
+ ],
348
+ [ authors, viewType, frontPageId, postsPageId ]
349
+ );
350
+
351
+ return {
352
+ isLoading: isLoadingAuthors,
353
+ fields,
354
+ };
355
+ }
356
+
357
+ export default usePostFields;