@automattic/newspack-blocks 1.37.0 → 1.48.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 (292) hide show
  1. package/.cache/babel/00255e6096be9e31ec354db849dfefaa.json.gz +0 -0
  2. package/.cache/babel/0265bee20d709ac92f56456637727f4b.json.gz +0 -0
  3. package/.cache/babel/02986ba19dc461a152ea1c45f3f36a27.json.gz +0 -0
  4. package/.cache/babel/06a1700c1a4a989fc7886c86bf6223f7.json.gz +0 -0
  5. package/.cache/babel/07169c73863508b392f15022920bd0b6.json.gz +0 -0
  6. package/.cache/babel/0a5083e561829e3884cb5c71388adc3f.json.gz +0 -0
  7. package/.cache/babel/0a713997b6e4f45849ed6a4bff79cca5.json.gz +0 -0
  8. package/.cache/babel/0a9506bf649ffbe854e75459cf6b8972.json.gz +0 -0
  9. package/.cache/babel/0c12c4398bbbf2d771b13dd1d0e64097.json.gz +0 -0
  10. package/.cache/babel/0f8c18da204f4cc2777ca3191f10c309.json.gz +0 -0
  11. package/.cache/babel/0fced15ed787cc4239bb53c1d12892e6.json.gz +0 -0
  12. package/.cache/babel/10faf7c74a89e9aa4d8b9528a654913e.json.gz +0 -0
  13. package/.cache/babel/1353b411b65a123b5dc35012db11aa1d.json.gz +0 -0
  14. package/.cache/babel/1729336f326db1cf54b9c1671dc5e36c.json.gz +0 -0
  15. package/.cache/babel/17a433ab631a32d0712f3f75cf85ea99.json.gz +0 -0
  16. package/.cache/babel/1948e72d907f681ff771881ad6800ee1.json.gz +0 -0
  17. package/.cache/babel/1ab4bf44aa14d2eb7e6911900a3b2c12.json.gz +0 -0
  18. package/.cache/babel/1decfd137cac87a75bd83ffbd39c9106.json.gz +0 -0
  19. package/.cache/babel/2143ceff6d186bc13bc902e0f1f33dbf.json.gz +0 -0
  20. package/.cache/babel/23c63332718e167968a7c2a8a5f730eb.json.gz +0 -0
  21. package/.cache/babel/24bf53676e12293cbf88d01e649fd167.json.gz +0 -0
  22. package/.cache/babel/26ba0bb46844575022e54a8819fbf405.json.gz +0 -0
  23. package/.cache/babel/281ca171ce8947f87f574df11059e00b.json.gz +0 -0
  24. package/.cache/babel/28700b83434e4dbfb9a20d7ec0a7e7a4.json.gz +0 -0
  25. package/.cache/babel/29cf8eeea8630ade027e34459f2e49ee.json.gz +0 -0
  26. package/.cache/babel/2b0dd254a46223a93e6259d2b797a7e7.json.gz +0 -0
  27. package/.cache/babel/2da6786ede3ddda4c86eeac524a6a796.json.gz +0 -0
  28. package/.cache/babel/2e7ce10fdee94274b48d528f94c32b34.json.gz +0 -0
  29. package/.cache/babel/2f93fed1706a40d82122281cc3677074.json.gz +0 -0
  30. package/.cache/babel/3a59b710e9745ef93148d6d74ee7d16f.json.gz +0 -0
  31. package/.cache/babel/3b2c440027c793c8f7978d7622cbfca0.json.gz +0 -0
  32. package/.cache/babel/3ca939ace4af88e266942d93837ab37a.json.gz +0 -0
  33. package/.cache/babel/3e671670c4d395cd1804ef4be31955e4.json.gz +0 -0
  34. package/.cache/babel/3e69fe002d9973c0030152a51da9477a.json.gz +0 -0
  35. package/.cache/babel/3f5f8ea603fd57850c6683c750fe53d8.json.gz +0 -0
  36. package/.cache/babel/41abaaadb68b0657a95fa0c356873def.json.gz +0 -0
  37. package/.cache/babel/421ac952d6b472ba18e1cb95ef65f42a.json.gz +0 -0
  38. package/.cache/babel/424185dd50e91d8dee5fdae43086010e.json.gz +0 -0
  39. package/.cache/babel/427a6423ebde76bcb488747127e47351.json.gz +0 -0
  40. package/.cache/babel/43e800659f23430a181fb4fc328eb6ef.json.gz +0 -0
  41. package/.cache/babel/469651017a2b6f3b9f63fda034974b3a.json.gz +0 -0
  42. package/.cache/babel/480d26447b7ee019a37e4e18422403e9.json.gz +0 -0
  43. package/.cache/babel/4b58fad313d90a4c1577a2766e6c924c.json.gz +0 -0
  44. package/.cache/babel/4d2d42fea63650192d1a3a5648b621c5.json.gz +0 -0
  45. package/.cache/babel/4d8c26a76e77fa64d01f30a5f2d62f85.json.gz +0 -0
  46. package/.cache/babel/4f606ce6656565507a74aaac8dc21eea.json.gz +0 -0
  47. package/.cache/babel/505f37592f4c601ccdc1581ca89d9009.json.gz +0 -0
  48. package/.cache/babel/50aaf34aa54b2cd3058518e42850bb62.json.gz +0 -0
  49. package/.cache/babel/51fbf389462feb111228ba7ec64c631d.json.gz +0 -0
  50. package/.cache/babel/51fc90ae5fe129a095172032f304dc2c.json.gz +0 -0
  51. package/.cache/babel/53dbf5484c5601528c2fd8d7fe728b78.json.gz +0 -0
  52. package/.cache/babel/58e4535574062eb2d8fa56d002e7190d.json.gz +0 -0
  53. package/.cache/babel/5aa5e8d1492938c62999de022c4b220e.json.gz +0 -0
  54. package/.cache/babel/5d64e475284e52c104df17e26066b17b.json.gz +0 -0
  55. package/.cache/babel/6333c664d69f13036f42bcf575c8e65d.json.gz +0 -0
  56. package/.cache/babel/635c439786b8522888342779b28ee9ee.json.gz +0 -0
  57. package/.cache/babel/648cffdd5ec4a2446f8935a17b98080b.json.gz +0 -0
  58. package/.cache/babel/64b0dd478e6f2dd51de5ee20e311aee7.json.gz +0 -0
  59. package/.cache/babel/6531721abbc0b3906b28b268ed7914af.json.gz +0 -0
  60. package/.cache/babel/66bf5585c7901a76c7d4014fa9ffed40.json.gz +0 -0
  61. package/.cache/babel/6ef313cb6d3a59f73a6b78e1a729fb13.json.gz +0 -0
  62. package/.cache/babel/6f14eed506421f15710d3dfafe3dcd93.json.gz +0 -0
  63. package/.cache/babel/70f6c01d8c6bc3efc41c97eaf49f7617.json.gz +0 -0
  64. package/.cache/babel/72321dde68f0bb9c334d90d6f4584be8.json.gz +0 -0
  65. package/.cache/babel/76c815fab58595f57e01af6591791d57.json.gz +0 -0
  66. package/.cache/babel/7c10f4d554daa8efe1e0a4457fb6d27b.json.gz +0 -0
  67. package/.cache/babel/7dffccddd9780ab37fb79f809947c2cd.json.gz +0 -0
  68. package/.cache/babel/7e5162e3319cd5d6fca6c0db0516aaeb.json.gz +0 -0
  69. package/.cache/babel/803192c922f7d419648bab7e1201b22e.json.gz +0 -0
  70. package/.cache/babel/81f3f0f896d29cdf88f8543dedb77787.json.gz +0 -0
  71. package/.cache/babel/84c019d3d643195fb37d08110f15f8c9.json.gz +0 -0
  72. package/.cache/babel/853c31db7c4351f2f36d1021c667224d.json.gz +0 -0
  73. package/.cache/babel/88ec99735ea4f314937736f04360ff8c.json.gz +0 -0
  74. package/.cache/babel/8959ab8fcfa783cb56e9418b99c0951c.json.gz +0 -0
  75. package/.cache/babel/8b9624d721f8706682e33fe1853c8287.json.gz +0 -0
  76. package/.cache/babel/8de5c373bbc4b6fbeec373d582935887.json.gz +0 -0
  77. package/.cache/babel/8f24517cff634d2e91c19e51be8816cc.json.gz +0 -0
  78. package/.cache/babel/901e1bb823eca196b594baa35a35a81c.json.gz +0 -0
  79. package/.cache/babel/90dbc666ff9fa3b88f305fe90a9917bf.json.gz +0 -0
  80. package/.cache/babel/91b62dfd9475df7a39dc08fbd43847f9.json.gz +0 -0
  81. package/.cache/babel/956daf27323e3b87bf8bf9bbf58881ed.json.gz +0 -0
  82. package/.cache/babel/959e9b81103c539a9d85ac60955451b9.json.gz +0 -0
  83. package/.cache/babel/963b1e44be998c4dcc6845745c377369.json.gz +0 -0
  84. package/.cache/babel/966b41ac1317b3e03ca1e59f7eb57e8c.json.gz +0 -0
  85. package/.cache/babel/969d5992cc682e3b43761ef02c10b851.json.gz +0 -0
  86. package/.cache/babel/99df128bb528d0f95a56b311801d14c1.json.gz +0 -0
  87. package/.cache/babel/9b33e7d21f3fc4955a536a033cced71b.json.gz +0 -0
  88. package/.cache/babel/9c5ec84f77314a621c01ad77da7ccb58.json.gz +0 -0
  89. package/.cache/babel/9d325af12a88623602a5f8c2fce04847.json.gz +0 -0
  90. package/.cache/babel/a413e4d325543836d0800684bb26ed04.json.gz +0 -0
  91. package/.cache/babel/a5405f86b8d1485e62a125275507e60f.json.gz +0 -0
  92. package/.cache/babel/a7f7461321ca6fd4360df04bb894c106.json.gz +0 -0
  93. package/.cache/babel/a8a6812e1c7b65cc6d0bdebe2a35c8ca.json.gz +0 -0
  94. package/.cache/babel/aa89cfc4c88fcc465b8d74af824e7f6b.json.gz +0 -0
  95. package/.cache/babel/adbaeb5ddf5612b3dcd233a3f6f17bf2.json.gz +0 -0
  96. package/.cache/babel/ae18cd6ec42a3366c73435b62a9f5f70.json.gz +0 -0
  97. package/.cache/babel/aea149ee1ec6fa3ca7839c63f5edd78d.json.gz +0 -0
  98. package/.cache/babel/af1b34067a69854e109c0b0e45d90e43.json.gz +0 -0
  99. package/.cache/babel/b3a335ab950f502914013810b43b0ad5.json.gz +0 -0
  100. package/.cache/babel/b6cfba15cda3404d4b1041df448ed2b2.json.gz +0 -0
  101. package/.cache/babel/ba711530bd319618a0510d8361bebb45.json.gz +0 -0
  102. package/.cache/babel/ba77e682225df6126b636458055601d9.json.gz +0 -0
  103. package/.cache/babel/bab8189a74eee8d72702d1510b52b3b3.json.gz +0 -0
  104. package/.cache/babel/bd8741020db56bb5d999252812d1d717.json.gz +0 -0
  105. package/.cache/babel/beaa874c5e01203d9dbe23cb89405276.json.gz +0 -0
  106. package/.cache/babel/c196c9b8c21953c474acdaa9029b3cbf.json.gz +0 -0
  107. package/.cache/babel/c1e31e6c217023eb3d3fd5d3de486ac3.json.gz +0 -0
  108. package/.cache/babel/c3aa996443e7f377aa423bcc03ffc617.json.gz +0 -0
  109. package/.cache/babel/c481eae84d69b65405a44af442dbfea7.json.gz +0 -0
  110. package/.cache/babel/c4a817d6c4bf6eb3687ffccc5c2df801.json.gz +0 -0
  111. package/.cache/babel/c8b10cf6f706fb669d6dd7564385768d.json.gz +0 -0
  112. package/.cache/babel/caa2f98ba4af6eba0605543f690693c6.json.gz +0 -0
  113. package/.cache/babel/cada4b2cecb2c1fcc48b7a7ecda54907.json.gz +0 -0
  114. package/.cache/babel/d1bed5404789c427c32965ac6ecad0d9.json.gz +0 -0
  115. package/.cache/babel/d395e8c0a9c63680f2dcf90ca0e91d4a.json.gz +0 -0
  116. package/.cache/babel/d4672090e0dd9a73bfb00bd770b23643.json.gz +0 -0
  117. package/.cache/babel/d4c81f65fe6d78cdbdcf1ef901b7ba1b.json.gz +0 -0
  118. package/.cache/babel/d515ddc0797ea256ff7271507737e9ce.json.gz +0 -0
  119. package/.cache/babel/d742848d263503f79168f1a6b8a52097.json.gz +0 -0
  120. package/.cache/babel/d834b41d7028519ecd0cbc8c65d33dde.json.gz +0 -0
  121. package/.cache/babel/d9060b9162e7caf974db0b90b6134727.json.gz +0 -0
  122. package/.cache/babel/d946975b9beac51a39f600461e84b1b6.json.gz +0 -0
  123. package/.cache/babel/daf0af780cff2270b1ae0e4b97a5a4ab.json.gz +0 -0
  124. package/.cache/babel/db5215643b0737dc5245972a5c25f736.json.gz +0 -0
  125. package/.cache/babel/dd57b8d31664b147b9f1e3f5cd18cc2a.json.gz +0 -0
  126. package/.cache/babel/e0c78bdaae19f15e2dd4a773e842422b.json.gz +0 -0
  127. package/.cache/babel/e1a2c7e4fc3afe9cc6e03d60f4e4a23d.json.gz +0 -0
  128. package/.cache/babel/e210ff9aa99df972b8d81c4bda70f642.json.gz +0 -0
  129. package/.cache/babel/e259a73f84d5b92b94e6d094719264c3.json.gz +0 -0
  130. package/.cache/babel/e6ce03a9908c9c4dc2c723531f1073f6.json.gz +0 -0
  131. package/.cache/babel/e8a1501dd8e4b3389ecdc8f722622359.json.gz +0 -0
  132. package/.cache/babel/eb3bb371036da362c42db50248d0b180.json.gz +0 -0
  133. package/.cache/babel/eb854e03c810bdb969497b2a36119bfa.json.gz +0 -0
  134. package/.cache/babel/ec25bb53826070b7f301e64f02355b8c.json.gz +0 -0
  135. package/.cache/babel/edbaca20e4a65f850c3d8321c1945718.json.gz +0 -0
  136. package/.cache/babel/f059f1ca9e49d5c3e655d20339860dce.json.gz +0 -0
  137. package/.cache/babel/f24c559fb42ef906405966598baf5f80.json.gz +0 -0
  138. package/.cache/babel/f2f333c3c546ad711d722d782decd450.json.gz +0 -0
  139. package/.cache/babel/f42c854ce8f1dc1a6e6fe7c510b033a5.json.gz +0 -0
  140. package/.cache/babel/f5211608f22c2e12594eafdbc4e66aa5.json.gz +0 -0
  141. package/.cache/babel/f645b8c88a49718cd778e3595212d4eb.json.gz +0 -0
  142. package/.cache/babel/f66dda5c4e4e9d04eb6b7411fcb12a65.json.gz +0 -0
  143. package/.cache/babel/f9d5b6f3f5438342dba75c2ce6143eef.json.gz +0 -0
  144. package/.cache/babel/fc9c60ee1d2e8783ba4c08db5cf97d40.json.gz +0 -0
  145. package/.cache/babel/fd558798cea72d04fb826468a89d72aa.json.gz +0 -0
  146. package/.cache/babel/fe735cbd0f6e131e28d8b6eb1f39141b.json.gz +0 -0
  147. package/.eslintrc.js +3 -26
  148. package/.nvmrc +1 -0
  149. package/CHANGELOG.md +422 -0
  150. package/babel.config.js +6 -0
  151. package/block-list.json +1 -1
  152. package/composer.json +2 -2
  153. package/composer.lock +446 -161
  154. package/dist/author-list/view.asset.php +1 -0
  155. package/dist/author-list/view.css +1 -0
  156. package/dist/author-list/view.js +1 -0
  157. package/dist/author-list/view.rtl.css +1 -0
  158. package/dist/author-profile/view.asset.php +1 -0
  159. package/dist/author-profile/view.css +1 -0
  160. package/dist/author-profile/view.js +1 -0
  161. package/dist/author-profile/view.rtl.css +1 -0
  162. package/dist/block_styles.asset.php +1 -0
  163. package/dist/block_styles.css +1 -0
  164. package/dist/block_styles.js +1 -0
  165. package/dist/block_styles.rtl.css +1 -0
  166. package/dist/carousel/view.asset.php +1 -0
  167. package/dist/carousel/view.css +1 -0
  168. package/dist/carousel/view.js +1 -0
  169. package/dist/carousel/view.rtl.css +1 -0
  170. package/dist/donate/view.asset.php +1 -0
  171. package/dist/donate/view.css +1 -0
  172. package/dist/donate/view.js +1 -0
  173. package/dist/donate/view.rtl.css +1 -0
  174. package/dist/donateStreamlined.asset.php +1 -0
  175. package/dist/donateStreamlined.css +1 -0
  176. package/dist/donateStreamlined.js +1 -0
  177. package/dist/donateStreamlined.rtl.css +1 -0
  178. package/dist/editor.asset.php +1 -0
  179. package/dist/editor.css +1 -0
  180. package/dist/editor.js +41 -0
  181. package/dist/editor.rtl.css +1 -0
  182. package/dist/homepage-articles/view.asset.php +1 -0
  183. package/dist/homepage-articles/view.css +1 -0
  184. package/dist/homepage-articles/view.js +1 -0
  185. package/dist/homepage-articles/view.rtl.css +1 -0
  186. package/dist/iframe/view.asset.php +1 -0
  187. package/dist/iframe/view.css +1 -0
  188. package/dist/iframe/view.js +1 -0
  189. package/dist/iframe/view.rtl.css +1 -0
  190. package/includes/class-newspack-blocks-api.php +14 -69
  191. package/includes/class-newspack-blocks-patterns.php +4 -1
  192. package/includes/class-newspack-blocks.php +421 -95
  193. package/newspack-blocks.php +26 -2
  194. package/package.json +31 -129
  195. package/postcss.config.js +11 -0
  196. package/src/block-patterns/subscribe-2.php +1 -1
  197. package/src/block-patterns/subscribe-3.php +1 -1
  198. package/src/block-patterns/subscribe-7.php +12 -0
  199. package/src/block-patterns/subscribe-8.php +12 -0
  200. package/src/block-patterns/subscribe-9.php +12 -0
  201. package/src/block-styles/core/columns/editor.scss +5 -8
  202. package/src/block-styles/core/columns/view.scss +83 -42
  203. package/src/blocks/author-list/block.json +82 -0
  204. package/src/blocks/author-list/class-wp-rest-newspack-author-list-controller.php +387 -0
  205. package/src/blocks/author-list/edit.js +527 -0
  206. package/src/blocks/author-list/editor.js +7 -0
  207. package/src/blocks/author-list/editor.scss +1 -0
  208. package/src/blocks/author-list/index.js +45 -0
  209. package/src/blocks/author-list/view.js +5 -0
  210. package/src/blocks/author-list/view.php +175 -0
  211. package/src/blocks/author-list/view.scss +46 -0
  212. package/src/blocks/author-profile/block.json +8 -0
  213. package/src/blocks/author-profile/class-wp-rest-newspack-authors-controller.php +69 -14
  214. package/src/blocks/author-profile/edit.js +212 -189
  215. package/src/blocks/author-profile/editor.scss +1 -1
  216. package/src/blocks/author-profile/single-author.js +100 -0
  217. package/src/blocks/author-profile/view.php +38 -92
  218. package/src/blocks/author-profile/view.scss +120 -1
  219. package/src/blocks/carousel/create-swiper.js +14 -5
  220. package/src/blocks/carousel/edit.js +4 -2
  221. package/src/blocks/carousel/editor.scss +3 -12
  222. package/src/blocks/carousel/view.js +1 -1
  223. package/src/blocks/carousel/view.php +9 -5
  224. package/src/blocks/carousel/view.scss +29 -3
  225. package/src/blocks/donate/class-wp-rest-newspack-donate-controller.php +22 -24
  226. package/src/blocks/donate/edit.js +49 -42
  227. package/src/blocks/donate/editor.scss +27 -3
  228. package/src/blocks/donate/index.js +31 -4
  229. package/src/blocks/donate/streamlined/index.js +248 -0
  230. package/src/blocks/donate/streamlined/index.test.js +125 -0
  231. package/src/blocks/donate/streamlined/style.scss +324 -0
  232. package/src/blocks/donate/streamlined/utils.js +174 -0
  233. package/src/blocks/donate/streamlined/utils.test.js +18 -0
  234. package/src/blocks/donate/view.php +77 -36
  235. package/src/blocks/donate/view.scss +291 -0
  236. package/src/blocks/homepage-articles/block.json +8 -0
  237. package/src/blocks/homepage-articles/class-wp-rest-newspack-articles-controller.php +24 -78
  238. package/src/blocks/homepage-articles/edit.js +26 -0
  239. package/src/blocks/homepage-articles/store.js +11 -1
  240. package/src/blocks/homepage-articles/templates/article.php +31 -3
  241. package/src/blocks/homepage-articles/templates/articles-loop.php +6 -5
  242. package/src/blocks/homepage-articles/utils.js +11 -10
  243. package/src/blocks/homepage-articles/view.php +4 -1
  244. package/src/blocks/homepage-articles/view.scss +69 -24
  245. package/src/blocks/iframe/block.json +34 -0
  246. package/src/blocks/iframe/class-wp-rest-newspack-iframe-controller.php +345 -0
  247. package/src/blocks/iframe/edit.js +252 -0
  248. package/src/blocks/iframe/editor.js +7 -0
  249. package/src/blocks/iframe/editor.scss +84 -0
  250. package/src/blocks/iframe/icons.js +10 -0
  251. package/src/blocks/iframe/iframe-placeholder.js +180 -0
  252. package/src/blocks/iframe/index.js +48 -0
  253. package/src/blocks/iframe/view.js +5 -0
  254. package/src/blocks/iframe/view.php +130 -0
  255. package/src/blocks/iframe/view.scss +9 -0
  256. package/src/blocks/video-playlist/view.php +4 -3
  257. package/src/components/query-controls.js +5 -4
  258. package/src/setup/editor.js +0 -1
  259. package/src/shared/js/utils.js +1 -1
  260. package/src/templates/author-profile-card.php +99 -0
  261. package/vendor/autoload.php +7 -0
  262. package/vendor/composer/ClassLoader.php +572 -0
  263. package/vendor/composer/InstalledVersions.php +350 -0
  264. package/vendor/composer/LICENSE +21 -0
  265. package/vendor/composer/autoload_classmap.php +10 -0
  266. package/vendor/composer/autoload_namespaces.php +9 -0
  267. package/vendor/composer/autoload_psr4.php +9 -0
  268. package/vendor/composer/autoload_real.php +55 -0
  269. package/vendor/composer/autoload_static.php +20 -0
  270. package/vendor/composer/installed.json +5 -0
  271. package/vendor/composer/installed.php +23 -0
  272. package/webpack.config.js +2 -3
  273. package/.circleci/config.yml +0 -96
  274. package/.distignore +0 -36
  275. package/.editorconfig +0 -22
  276. package/.github/ISSUE_TEMPLATE/Bug_report.md +0 -21
  277. package/.github/ISSUE_TEMPLATE/Enhancement.md +0 -17
  278. package/.github/ISSUE_TEMPLATE/Feature_request.md +0 -17
  279. package/.github/PULL_REQUEST_TEMPLATE.md +0 -29
  280. package/.github/workflows/main.yml +0 -15
  281. package/.phpcs.xml.dist +0 -55
  282. package/.prettierrc +0 -10
  283. package/.stylelintrc +0 -21
  284. package/.travis.yml +0 -67
  285. package/phpunit.xml.dist +0 -16
  286. package/src/blocks/author-profile/shared.scss +0 -95
  287. package/src/blocks/donate/streamlined.js +0 -180
  288. package/src/blocks/donate/streamlined.scss +0 -124
  289. package/src/setup/public-path.js +0 -13
  290. package/src/setup/view.js +0 -4
  291. package/tests/bootstrap.php +0 -31
  292. package/tests/test-sample.php +0 -20
@@ -0,0 +1,527 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import apiFetch from '@wordpress/api-fetch';
5
+ import { BlockControls, InspectorControls } from '@wordpress/block-editor';
6
+ import {
7
+ BaseControl,
8
+ Button,
9
+ ButtonGroup,
10
+ CheckboxControl,
11
+ Notice,
12
+ PanelBody,
13
+ PanelRow,
14
+ Placeholder,
15
+ RadioControl,
16
+ RangeControl,
17
+ Spinner,
18
+ ToggleControl,
19
+ Toolbar,
20
+ // eslint-disable-next-line @wordpress/no-unsafe-wp-apis
21
+ __experimentalUnitControl as UnitControl,
22
+ } from '@wordpress/components';
23
+ import { Fragment, useEffect, useState } from '@wordpress/element';
24
+ import { decodeEntities } from '@wordpress/html-entities';
25
+ import {
26
+ Icon,
27
+ columns as columnsIcon,
28
+ edit,
29
+ listView,
30
+ pullLeft,
31
+ pullRight,
32
+ } from '@wordpress/icons';
33
+ import { __, sprintf } from '@wordpress/i18n';
34
+ import { addQueryArgs } from '@wordpress/url';
35
+ import { avatarSizeOptions, textSizeOptions, units } from '../author-profile/edit';
36
+
37
+ /**
38
+ * Internal dependencies
39
+ */
40
+ import { SingleAuthor } from '../author-profile/single-author';
41
+
42
+ /**
43
+ * External dependencies
44
+ */
45
+ import { AutocompleteWithSuggestions } from 'newspack-components';
46
+ import classnames from 'classnames';
47
+
48
+ const AuthorList = ( { attributes, clientId, setAttributes } ) => {
49
+ const [ authors, setAuthors ] = useState( null );
50
+ const [ error, setError ] = useState( null );
51
+ const [ isLoading, setIsLoading ] = useState( false );
52
+ const [ maxItemsToSuggest, setMaxItemsToSuggest ] = useState( 0 );
53
+ const canUseCAP = Boolean( window.newspack_blocks_data?.can_use_cap );
54
+ const editableRoles = window.newspack_blocks_data?.editable_roles;
55
+ const separators = [];
56
+ const {
57
+ authorRoles,
58
+ authorType,
59
+ columns,
60
+ exclude,
61
+ excludeEmpty,
62
+ layout,
63
+ showBio,
64
+ showSocial,
65
+ showEmail,
66
+ showArchiveLink,
67
+ showAvatar,
68
+ showSeparators,
69
+ separatorSections,
70
+ textSize,
71
+ avatarAlignment,
72
+ avatarBorderRadius,
73
+ avatarSize,
74
+ avatarHideDefault,
75
+ } = attributes;
76
+ const isColumns = 'columns' === layout;
77
+
78
+ useEffect( () => {
79
+ getAuthors();
80
+ }, [ authorRoles, authorType, avatarHideDefault, exclude, excludeEmpty ] );
81
+
82
+ const getAuthors = async () => {
83
+ setError( null );
84
+ setIsLoading( true );
85
+ try {
86
+ const params = {
87
+ authorType,
88
+ authorRoles,
89
+ exclude: exclude.map( exclusion => parseInt( exclusion.value ) ),
90
+ };
91
+
92
+ if ( excludeEmpty ) {
93
+ params.excludeEmpty = 1;
94
+ }
95
+
96
+ if ( avatarHideDefault ) {
97
+ params.avatarHideDefault = 1;
98
+ }
99
+
100
+ const response = await apiFetch( {
101
+ path: addQueryArgs( '/newspack-blocks/v1/author-list', params ),
102
+ } );
103
+
104
+ if ( ! response ) {
105
+ throw __( 'Error fetching authors.', 'newspack-blocks' );
106
+ }
107
+ setAuthors( response );
108
+ } catch ( e ) {
109
+ setError( e.message || e || __( 'Error fetching authors.', 'newspack-blocks' ) );
110
+ }
111
+ setIsLoading( false );
112
+ };
113
+
114
+ // Authors grouped by alphabet.
115
+ const chunkedAuthors = {};
116
+ if ( Array.isArray( authors ) && separatorSections ) {
117
+ authors.forEach( author => {
118
+ const { last_name: lastName } = author;
119
+ const firstLetter = lastName.charAt( 0 ).toUpperCase();
120
+ if ( ! chunkedAuthors.hasOwnProperty( firstLetter ) ) {
121
+ chunkedAuthors[ firstLetter ] = [];
122
+ }
123
+ chunkedAuthors[ firstLetter ].push( author );
124
+ } );
125
+ }
126
+
127
+ return (
128
+ <>
129
+ <InspectorControls>
130
+ <PanelBody title={ __( 'Author List Settings', 'newspack-blocks' ) }>
131
+ { canUseCAP && (
132
+ <PanelRow>
133
+ <RadioControl
134
+ label={ __( 'Author Type', 'newspack' ) }
135
+ help={ sprintf(
136
+ // translators: help text for author type selection.
137
+ __( '%s will be displayed.', 'newspack-blocks' ),
138
+ 'all' === authorType
139
+ ? __( 'Both guest authors and WP users', 'newspack-blocks' )
140
+ : sprintf(
141
+ // translators: currently selected author type option.
142
+ __( '%s only', 'newspack-blocks' ),
143
+ 'guest-authors' === authorType
144
+ ? __( 'Guest authors', 'newspack-blocks' )
145
+ : __( 'WP users', 'newspack-blocks' )
146
+ )
147
+ ) }
148
+ selected={ authorType || 'all' }
149
+ options={ [
150
+ { label: __( 'All authors', 'newspack-blocks' ), value: 'all' },
151
+ { label: __( 'Guest authors', 'newspack-blocks' ), value: 'guest-authors' },
152
+ { label: __( 'WP users', 'newspack-blocks' ), value: 'users' },
153
+ ] }
154
+ onChange={ value => setAttributes( { authorType: value } ) }
155
+ />
156
+ </PanelRow>
157
+ ) }
158
+ { isColumns && (
159
+ <PanelRow>
160
+ <RangeControl
161
+ label={ __( 'Columns', 'newspack-blocks' ) }
162
+ value={ columns }
163
+ onChange={ _columns => setAttributes( { columns: _columns } ) }
164
+ min={ 2 }
165
+ max={ 6 }
166
+ required
167
+ />
168
+ </PanelRow>
169
+ ) }
170
+ { 'guest-authors' !== authorType && (
171
+ <PanelRow>
172
+ <BaseControl
173
+ id="newspack-blocks__author-list-roles"
174
+ label={ __( 'WP User Roles', 'newspack-blocks' ) }
175
+ >
176
+ { editableRoles.map( ( role, index ) => (
177
+ <CheckboxControl
178
+ checked={ -1 < authorRoles.indexOf( role ) }
179
+ key={ index }
180
+ label={ role }
181
+ value={ role }
182
+ onChange={ check => {
183
+ const selectedRoles = check
184
+ ? [ ...authorRoles, role ]
185
+ : authorRoles.filter( _role => _role !== role );
186
+
187
+ setAttributes( { authorRoles: selectedRoles } );
188
+ } }
189
+ />
190
+ ) ) }
191
+ </BaseControl>
192
+ </PanelRow>
193
+ ) }
194
+ <PanelRow>
195
+ <ToggleControl
196
+ label={ __( 'Display alphabetical separators', 'newspack-blocks' ) }
197
+ help={ __( 'Chunk authors alphabetically.', 'newspack-blocks' ) }
198
+ checked={ showSeparators }
199
+ onChange={ () => setAttributes( { showSeparators: ! showSeparators } ) }
200
+ />
201
+ </PanelRow>
202
+ { isColumns && showSeparators && (
203
+ <PanelRow>
204
+ <ToggleControl
205
+ label={ __( 'Group authors by alphabet', 'newspack-blocks' ) }
206
+ help={ __(
207
+ 'Display each alphabetical chunk as a discrete section.',
208
+ 'newspack-blocks'
209
+ ) }
210
+ checked={ separatorSections }
211
+ onChange={ () => setAttributes( { separatorSections: ! separatorSections } ) }
212
+ />
213
+ </PanelRow>
214
+ ) }
215
+ </PanelBody>
216
+ <PanelBody title={ __( 'Author List Exclusions', 'newspack-block' ) }>
217
+ <PanelRow>
218
+ <ToggleControl
219
+ label={ __( 'Exclude authors with 0 posts', 'newspack-blocks' ) }
220
+ help={ sprintf(
221
+ // Translators: Help message for "include empty authors" toggle.
222
+ __( 'Authors with no published posts will be %s.', 'newspack-blocks' ),
223
+ excludeEmpty
224
+ ? __( 'hidden', 'newspack-blocks' )
225
+ : __( 'displayed', 'newspack-blocks' )
226
+ ) }
227
+ checked={ excludeEmpty }
228
+ onChange={ () => setAttributes( { excludeEmpty: ! excludeEmpty } ) }
229
+ />
230
+ </PanelRow>
231
+ <PanelRow>
232
+ <AutocompleteWithSuggestions
233
+ label={ __( 'Search by author name', 'newspack-blocks' ) }
234
+ help={ __( 'Authors selected here will not be displayed.', 'newspack-blocks' ) }
235
+ fetchSuggestions={ async ( search = null, offset = 0 ) => {
236
+ const response = await apiFetch( {
237
+ parse: false,
238
+ path: addQueryArgs( '/newspack-blocks/v1/authors', {
239
+ search,
240
+ offset,
241
+ fields: 'id,name',
242
+ } ),
243
+ } );
244
+
245
+ const total = parseInt( response.headers.get( 'x-wp-total' ) || 0 );
246
+ const suggestions = await response.json();
247
+
248
+ // Set max items for "load more" functionality in suggestions list.
249
+ if ( ! maxItemsToSuggest && ! search ) {
250
+ setMaxItemsToSuggest( total );
251
+ }
252
+
253
+ return suggestions.map( _author => ( {
254
+ value: _author.id,
255
+ label: decodeEntities( _author.name ) || __( '(no name)', 'newspack' ),
256
+ } ) );
257
+ } }
258
+ maxItemsToSuggest={ maxItemsToSuggest }
259
+ multiSelect={ true }
260
+ onChange={ items => setAttributes( { exclude: items } ) }
261
+ postTypeLabel={ __( 'author', 'newspack-blocks' ) }
262
+ postTypeLabelPlural={ __( 'authors', 'newspack-blocks' ) }
263
+ selectedItems={ exclude }
264
+ />
265
+ </PanelRow>
266
+ </PanelBody>
267
+ <PanelBody title={ __( 'Author Profile Settings', 'newspack-blocks' ) }>
268
+ <BaseControl
269
+ label={ __( 'Text Size', 'newspack-blocks' ) }
270
+ id="newspack-blocks__text-size-control"
271
+ >
272
+ <PanelRow>
273
+ <ButtonGroup
274
+ id="newspack-blocks__text-size-control-buttons"
275
+ aria-label={ __( 'Text Size', 'newspack-blocks' ) }
276
+ >
277
+ { textSizeOptions.map( option => {
278
+ const isCurrent = textSize === option.value;
279
+ return (
280
+ <Button
281
+ isLarge
282
+ isPrimary={ isCurrent }
283
+ aria-pressed={ isCurrent }
284
+ aria-label={ option.label }
285
+ key={ option.value }
286
+ onClick={ () => setAttributes( { textSize: option.value } ) }
287
+ >
288
+ { option.shortName }
289
+ </Button>
290
+ );
291
+ } ) }
292
+ </ButtonGroup>
293
+ </PanelRow>
294
+ </BaseControl>
295
+ <PanelRow>
296
+ <ToggleControl
297
+ label={ __( 'Display biographical info', 'newspack-blocks' ) }
298
+ checked={ showBio }
299
+ onChange={ () => setAttributes( { showBio: ! showBio } ) }
300
+ />
301
+ </PanelRow>
302
+ <PanelRow>
303
+ <ToggleControl
304
+ label={ __( 'Display social links', 'newspack-blocks' ) }
305
+ checked={ showSocial }
306
+ onChange={ () => setAttributes( { showSocial: ! showSocial } ) }
307
+ />
308
+ </PanelRow>
309
+ <PanelRow>
310
+ <ToggleControl
311
+ label={ __( 'Display email address', 'newspack-blocks' ) }
312
+ checked={ showEmail }
313
+ onChange={ () => setAttributes( { showEmail: ! showEmail } ) }
314
+ />
315
+ </PanelRow>
316
+ <PanelRow>
317
+ <ToggleControl
318
+ label={ __( 'Link to author archive', 'newspack-blocks' ) }
319
+ checked={ showArchiveLink }
320
+ onChange={ () => setAttributes( { showArchiveLink: ! showArchiveLink } ) }
321
+ />
322
+ </PanelRow>
323
+ </PanelBody>
324
+ <PanelBody title={ __( 'Avatar Settings', 'newspack-blocks' ) }>
325
+ <PanelRow>
326
+ <ToggleControl
327
+ label={ __( 'Display avatar', 'newspack-blocks' ) }
328
+ checked={ showAvatar }
329
+ onChange={ () => setAttributes( { showAvatar: ! showAvatar } ) }
330
+ />
331
+ </PanelRow>
332
+ { showAvatar && (
333
+ <PanelRow>
334
+ <ToggleControl
335
+ label={ __( 'Hide default avatar', 'newspack-blocks' ) }
336
+ checked={ avatarHideDefault }
337
+ onChange={ () => setAttributes( { avatarHideDefault: ! avatarHideDefault } ) }
338
+ />
339
+ </PanelRow>
340
+ ) }
341
+ { showAvatar && (
342
+ <BaseControl
343
+ label={ __( 'Avatar Size', 'newspack-blocks' ) }
344
+ id="newspack-blocks__avatar-size-control"
345
+ >
346
+ <PanelRow>
347
+ <ButtonGroup
348
+ id="newspack-blocks__avatar-size-control-buttons"
349
+ aria-label={ __( 'Avatar Size', 'newspack-blocks' ) }
350
+ >
351
+ { avatarSizeOptions.map( option => {
352
+ const isCurrent = avatarSize === option.value;
353
+ return (
354
+ <Button
355
+ isLarge
356
+ isPrimary={ isCurrent }
357
+ aria-pressed={ isCurrent }
358
+ aria-label={ option.label }
359
+ key={ option.value }
360
+ onClick={ () => setAttributes( { avatarSize: option.value } ) }
361
+ >
362
+ { option.shortName }
363
+ </Button>
364
+ );
365
+ } ) }
366
+ </ButtonGroup>
367
+ </PanelRow>
368
+ </BaseControl>
369
+ ) }
370
+ { showAvatar && (
371
+ <PanelRow>
372
+ <UnitControl
373
+ label={ __( 'Avatar border radius', 'newspack-blocks' ) }
374
+ labelPosition="edge"
375
+ __unstableInputWidth="80px"
376
+ units={ units }
377
+ value={ avatarBorderRadius }
378
+ onChange={ value =>
379
+ setAttributes( { avatarBorderRadius: 0 > parseFloat( value ) ? '0' : value } )
380
+ }
381
+ />
382
+ </PanelRow>
383
+ ) }
384
+ </PanelBody>
385
+ </InspectorControls>
386
+ { authors && ! isLoading && (
387
+ <BlockControls>
388
+ <Toolbar
389
+ controls={ [
390
+ {
391
+ icon: <Icon icon={ listView } />,
392
+ title: __( 'List', 'newspack-blocks' ),
393
+ isActive: 'list' === layout,
394
+ onClick: () => {
395
+ setAttributes( { layout: 'list' } );
396
+ },
397
+ },
398
+ {
399
+ icon: <Icon icon={ columnsIcon } />,
400
+ title: __( 'Columns', 'newspack-blocks' ),
401
+ isActive: isColumns,
402
+ onClick: () => {
403
+ setAttributes( { layout: 'columns' } );
404
+ },
405
+ },
406
+ ] }
407
+ />
408
+ { showAvatar && 'is-style-center' !== attributes.className && (
409
+ <Toolbar
410
+ controls={ [
411
+ {
412
+ icon: <Icon icon={ pullLeft } />,
413
+ title: __( 'Show avatar on left', 'newspack-blocks' ),
414
+ isActive: avatarAlignment === 'left',
415
+ onClick: () => setAttributes( { avatarAlignment: 'left' } ),
416
+ },
417
+ {
418
+ icon: <Icon icon={ pullRight } />,
419
+ title: __( 'Show avatar on right', 'newspack-blocks' ),
420
+ isActive: avatarAlignment === 'right',
421
+ onClick: () => setAttributes( { avatarAlignment: 'right' } ),
422
+ },
423
+ ] }
424
+ />
425
+ ) }
426
+ <Toolbar
427
+ controls={ [
428
+ {
429
+ icon: <Icon icon={ edit } />,
430
+ title: __( 'Edit selection', 'newspack-blocks' ),
431
+ onClick: () => {
432
+ setAttributes( { authorId: 0 } );
433
+ },
434
+ },
435
+ ] }
436
+ />
437
+ </BlockControls>
438
+ ) }
439
+ <div className={ classnames( attributes.className, 'wp-block-newspack-blocks-author-list' ) }>
440
+ { ! isLoading && ! error && authors && Array.isArray( authors ) && (
441
+ <>
442
+ { isColumns && showSeparators && separatorSections ? (
443
+ Object.keys( chunkedAuthors ).map( ( firstLetter, index ) => (
444
+ <Fragment key={ index }>
445
+ <h2
446
+ className="newspack-blocks__author-list-separator"
447
+ id={ `newspack-blocks__author-list-separator__${ clientId }__${ firstLetter }` }
448
+ >
449
+ { firstLetter }
450
+ </h2>
451
+ <ul
452
+ className={ classnames( 'newspack-blocks__author-list-container', {
453
+ 'is-columns': isColumns,
454
+ [ `columns-${ columns }` ]: isColumns,
455
+ } ) }
456
+ >
457
+ { chunkedAuthors[ firstLetter ].map( ( author, i ) => (
458
+ <li key={ i } className="newspack-blocks__author-list-item">
459
+ <SingleAuthor author={ author } attributes={ attributes } />
460
+ </li>
461
+ ) ) }
462
+ </ul>
463
+ </Fragment>
464
+ ) )
465
+ ) : (
466
+ <ul
467
+ className={ classnames( 'newspack-blocks__author-list-container', {
468
+ 'is-columns': isColumns,
469
+ [ `columns-${ columns }` ]: isColumns,
470
+ } ) }
471
+ >
472
+ { authors.map( ( author, index ) => {
473
+ const { last_name: lastName } = author;
474
+ const firstLetter = lastName.charAt( 0 ).toUpperCase();
475
+ const showSeparator = 0 > separators.indexOf( firstLetter );
476
+
477
+ if ( showSeparator ) {
478
+ separators.push( firstLetter );
479
+ }
480
+
481
+ return (
482
+ <Fragment key={ index }>
483
+ { showSeparators && showSeparator && (
484
+ <li className="newspack-blocks__author-list-item">
485
+ <h2
486
+ className="newspack-blocks__author-list-separator"
487
+ id={ `newspack-blocks__author-list-separator__${ clientId }__${ firstLetter }` }
488
+ >
489
+ { firstLetter }
490
+ </h2>
491
+ </li>
492
+ ) }
493
+
494
+ <li className="newspack-blocks__author-list-item">
495
+ <SingleAuthor author={ author } attributes={ attributes } />
496
+ </li>
497
+ </Fragment>
498
+ );
499
+ } ) }
500
+ </ul>
501
+ ) }
502
+ </>
503
+ ) }
504
+ { ( ! authors || isLoading ) && (
505
+ <Placeholder
506
+ icon={ <Icon icon={ listView } /> }
507
+ label={ __( 'Author List', 'newspack-blocks' ) }
508
+ >
509
+ { error && (
510
+ <Notice status="error" isDismissible={ false }>
511
+ { error }
512
+ </Notice>
513
+ ) }
514
+ { isLoading && (
515
+ <div className="is-loading">
516
+ { __( 'Fetching authors…', 'newspack-blocks' ) }
517
+ <Spinner />
518
+ </div>
519
+ ) }
520
+ </Placeholder>
521
+ ) }
522
+ </div>
523
+ </>
524
+ );
525
+ };
526
+
527
+ export default AuthorList;
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Internal dependencies
3
+ */
4
+ import { registerBlockType } from '@wordpress/blocks';
5
+ import { name, settings } from '.';
6
+
7
+ registerBlockType( `newspack-blocks/${ name }`, settings );
@@ -0,0 +1 @@
1
+ @import './view.scss';
@@ -0,0 +1,45 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { __, _x } from '@wordpress/i18n';
5
+ import { Icon, listView } from '@wordpress/icons';
6
+
7
+ /**
8
+ * Internal dependencies
9
+ */
10
+ import edit from './edit';
11
+
12
+ /**
13
+ * Style dependencies - will load in editor
14
+ */
15
+ import './editor.scss';
16
+ import './view.scss';
17
+ import metadata from './block.json';
18
+ const { name, attributes, category } = metadata;
19
+
20
+ // Name must be exported separately.
21
+ export { name };
22
+
23
+ export const title = __( 'Author List', 'newspack-blocks' );
24
+
25
+ export const settings = {
26
+ title,
27
+ icon: {
28
+ src: <Icon icon={ listView } />,
29
+ foreground: '#36f',
30
+ },
31
+ keywords: [ __( 'author', 'newspack-blocks' ), __( 'profile', 'newspack-blocks' ) ],
32
+ description: __( 'Display a list of author profile cards.', 'newspack-blocks' ),
33
+ styles: [
34
+ { name: 'default', label: _x( 'Default', 'block style', 'newspack-blocks' ), isDefault: true },
35
+ { name: 'center', label: _x( 'Centered', 'block style', 'newspack-blocks' ) },
36
+ ],
37
+ attributes,
38
+ category,
39
+ supports: {
40
+ html: false,
41
+ default: '',
42
+ },
43
+ edit,
44
+ save: () => null, // to use view.php
45
+ };
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Style dependencies
3
+ */
4
+
5
+ import './view.scss';