@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.
- package/.cache/babel/00255e6096be9e31ec354db849dfefaa.json.gz +0 -0
- package/.cache/babel/0265bee20d709ac92f56456637727f4b.json.gz +0 -0
- package/.cache/babel/02986ba19dc461a152ea1c45f3f36a27.json.gz +0 -0
- package/.cache/babel/06a1700c1a4a989fc7886c86bf6223f7.json.gz +0 -0
- package/.cache/babel/07169c73863508b392f15022920bd0b6.json.gz +0 -0
- package/.cache/babel/0a5083e561829e3884cb5c71388adc3f.json.gz +0 -0
- package/.cache/babel/0a713997b6e4f45849ed6a4bff79cca5.json.gz +0 -0
- package/.cache/babel/0a9506bf649ffbe854e75459cf6b8972.json.gz +0 -0
- package/.cache/babel/0c12c4398bbbf2d771b13dd1d0e64097.json.gz +0 -0
- package/.cache/babel/0f8c18da204f4cc2777ca3191f10c309.json.gz +0 -0
- package/.cache/babel/0fced15ed787cc4239bb53c1d12892e6.json.gz +0 -0
- package/.cache/babel/10faf7c74a89e9aa4d8b9528a654913e.json.gz +0 -0
- package/.cache/babel/1353b411b65a123b5dc35012db11aa1d.json.gz +0 -0
- package/.cache/babel/1729336f326db1cf54b9c1671dc5e36c.json.gz +0 -0
- package/.cache/babel/17a433ab631a32d0712f3f75cf85ea99.json.gz +0 -0
- package/.cache/babel/1948e72d907f681ff771881ad6800ee1.json.gz +0 -0
- package/.cache/babel/1ab4bf44aa14d2eb7e6911900a3b2c12.json.gz +0 -0
- package/.cache/babel/1decfd137cac87a75bd83ffbd39c9106.json.gz +0 -0
- package/.cache/babel/2143ceff6d186bc13bc902e0f1f33dbf.json.gz +0 -0
- package/.cache/babel/23c63332718e167968a7c2a8a5f730eb.json.gz +0 -0
- package/.cache/babel/24bf53676e12293cbf88d01e649fd167.json.gz +0 -0
- package/.cache/babel/26ba0bb46844575022e54a8819fbf405.json.gz +0 -0
- package/.cache/babel/281ca171ce8947f87f574df11059e00b.json.gz +0 -0
- package/.cache/babel/28700b83434e4dbfb9a20d7ec0a7e7a4.json.gz +0 -0
- package/.cache/babel/29cf8eeea8630ade027e34459f2e49ee.json.gz +0 -0
- package/.cache/babel/2b0dd254a46223a93e6259d2b797a7e7.json.gz +0 -0
- package/.cache/babel/2da6786ede3ddda4c86eeac524a6a796.json.gz +0 -0
- package/.cache/babel/2e7ce10fdee94274b48d528f94c32b34.json.gz +0 -0
- package/.cache/babel/2f93fed1706a40d82122281cc3677074.json.gz +0 -0
- package/.cache/babel/3a59b710e9745ef93148d6d74ee7d16f.json.gz +0 -0
- package/.cache/babel/3b2c440027c793c8f7978d7622cbfca0.json.gz +0 -0
- package/.cache/babel/3ca939ace4af88e266942d93837ab37a.json.gz +0 -0
- package/.cache/babel/3e671670c4d395cd1804ef4be31955e4.json.gz +0 -0
- package/.cache/babel/3e69fe002d9973c0030152a51da9477a.json.gz +0 -0
- package/.cache/babel/3f5f8ea603fd57850c6683c750fe53d8.json.gz +0 -0
- package/.cache/babel/41abaaadb68b0657a95fa0c356873def.json.gz +0 -0
- package/.cache/babel/421ac952d6b472ba18e1cb95ef65f42a.json.gz +0 -0
- package/.cache/babel/424185dd50e91d8dee5fdae43086010e.json.gz +0 -0
- package/.cache/babel/427a6423ebde76bcb488747127e47351.json.gz +0 -0
- package/.cache/babel/43e800659f23430a181fb4fc328eb6ef.json.gz +0 -0
- package/.cache/babel/469651017a2b6f3b9f63fda034974b3a.json.gz +0 -0
- package/.cache/babel/480d26447b7ee019a37e4e18422403e9.json.gz +0 -0
- package/.cache/babel/4b58fad313d90a4c1577a2766e6c924c.json.gz +0 -0
- package/.cache/babel/4d2d42fea63650192d1a3a5648b621c5.json.gz +0 -0
- package/.cache/babel/4d8c26a76e77fa64d01f30a5f2d62f85.json.gz +0 -0
- package/.cache/babel/4f606ce6656565507a74aaac8dc21eea.json.gz +0 -0
- package/.cache/babel/505f37592f4c601ccdc1581ca89d9009.json.gz +0 -0
- package/.cache/babel/50aaf34aa54b2cd3058518e42850bb62.json.gz +0 -0
- package/.cache/babel/51fbf389462feb111228ba7ec64c631d.json.gz +0 -0
- package/.cache/babel/51fc90ae5fe129a095172032f304dc2c.json.gz +0 -0
- package/.cache/babel/53dbf5484c5601528c2fd8d7fe728b78.json.gz +0 -0
- package/.cache/babel/58e4535574062eb2d8fa56d002e7190d.json.gz +0 -0
- package/.cache/babel/5aa5e8d1492938c62999de022c4b220e.json.gz +0 -0
- package/.cache/babel/5d64e475284e52c104df17e26066b17b.json.gz +0 -0
- package/.cache/babel/6333c664d69f13036f42bcf575c8e65d.json.gz +0 -0
- package/.cache/babel/635c439786b8522888342779b28ee9ee.json.gz +0 -0
- package/.cache/babel/648cffdd5ec4a2446f8935a17b98080b.json.gz +0 -0
- package/.cache/babel/64b0dd478e6f2dd51de5ee20e311aee7.json.gz +0 -0
- package/.cache/babel/6531721abbc0b3906b28b268ed7914af.json.gz +0 -0
- package/.cache/babel/66bf5585c7901a76c7d4014fa9ffed40.json.gz +0 -0
- package/.cache/babel/6ef313cb6d3a59f73a6b78e1a729fb13.json.gz +0 -0
- package/.cache/babel/6f14eed506421f15710d3dfafe3dcd93.json.gz +0 -0
- package/.cache/babel/70f6c01d8c6bc3efc41c97eaf49f7617.json.gz +0 -0
- package/.cache/babel/72321dde68f0bb9c334d90d6f4584be8.json.gz +0 -0
- package/.cache/babel/76c815fab58595f57e01af6591791d57.json.gz +0 -0
- package/.cache/babel/7c10f4d554daa8efe1e0a4457fb6d27b.json.gz +0 -0
- package/.cache/babel/7dffccddd9780ab37fb79f809947c2cd.json.gz +0 -0
- package/.cache/babel/7e5162e3319cd5d6fca6c0db0516aaeb.json.gz +0 -0
- package/.cache/babel/803192c922f7d419648bab7e1201b22e.json.gz +0 -0
- package/.cache/babel/81f3f0f896d29cdf88f8543dedb77787.json.gz +0 -0
- package/.cache/babel/84c019d3d643195fb37d08110f15f8c9.json.gz +0 -0
- package/.cache/babel/853c31db7c4351f2f36d1021c667224d.json.gz +0 -0
- package/.cache/babel/88ec99735ea4f314937736f04360ff8c.json.gz +0 -0
- package/.cache/babel/8959ab8fcfa783cb56e9418b99c0951c.json.gz +0 -0
- package/.cache/babel/8b9624d721f8706682e33fe1853c8287.json.gz +0 -0
- package/.cache/babel/8de5c373bbc4b6fbeec373d582935887.json.gz +0 -0
- package/.cache/babel/8f24517cff634d2e91c19e51be8816cc.json.gz +0 -0
- package/.cache/babel/901e1bb823eca196b594baa35a35a81c.json.gz +0 -0
- package/.cache/babel/90dbc666ff9fa3b88f305fe90a9917bf.json.gz +0 -0
- package/.cache/babel/91b62dfd9475df7a39dc08fbd43847f9.json.gz +0 -0
- package/.cache/babel/956daf27323e3b87bf8bf9bbf58881ed.json.gz +0 -0
- package/.cache/babel/959e9b81103c539a9d85ac60955451b9.json.gz +0 -0
- package/.cache/babel/963b1e44be998c4dcc6845745c377369.json.gz +0 -0
- package/.cache/babel/966b41ac1317b3e03ca1e59f7eb57e8c.json.gz +0 -0
- package/.cache/babel/969d5992cc682e3b43761ef02c10b851.json.gz +0 -0
- package/.cache/babel/99df128bb528d0f95a56b311801d14c1.json.gz +0 -0
- package/.cache/babel/9b33e7d21f3fc4955a536a033cced71b.json.gz +0 -0
- package/.cache/babel/9c5ec84f77314a621c01ad77da7ccb58.json.gz +0 -0
- package/.cache/babel/9d325af12a88623602a5f8c2fce04847.json.gz +0 -0
- package/.cache/babel/a413e4d325543836d0800684bb26ed04.json.gz +0 -0
- package/.cache/babel/a5405f86b8d1485e62a125275507e60f.json.gz +0 -0
- package/.cache/babel/a7f7461321ca6fd4360df04bb894c106.json.gz +0 -0
- package/.cache/babel/a8a6812e1c7b65cc6d0bdebe2a35c8ca.json.gz +0 -0
- package/.cache/babel/aa89cfc4c88fcc465b8d74af824e7f6b.json.gz +0 -0
- package/.cache/babel/adbaeb5ddf5612b3dcd233a3f6f17bf2.json.gz +0 -0
- package/.cache/babel/ae18cd6ec42a3366c73435b62a9f5f70.json.gz +0 -0
- package/.cache/babel/aea149ee1ec6fa3ca7839c63f5edd78d.json.gz +0 -0
- package/.cache/babel/af1b34067a69854e109c0b0e45d90e43.json.gz +0 -0
- package/.cache/babel/b3a335ab950f502914013810b43b0ad5.json.gz +0 -0
- package/.cache/babel/b6cfba15cda3404d4b1041df448ed2b2.json.gz +0 -0
- package/.cache/babel/ba711530bd319618a0510d8361bebb45.json.gz +0 -0
- package/.cache/babel/ba77e682225df6126b636458055601d9.json.gz +0 -0
- package/.cache/babel/bab8189a74eee8d72702d1510b52b3b3.json.gz +0 -0
- package/.cache/babel/bd8741020db56bb5d999252812d1d717.json.gz +0 -0
- package/.cache/babel/beaa874c5e01203d9dbe23cb89405276.json.gz +0 -0
- package/.cache/babel/c196c9b8c21953c474acdaa9029b3cbf.json.gz +0 -0
- package/.cache/babel/c1e31e6c217023eb3d3fd5d3de486ac3.json.gz +0 -0
- package/.cache/babel/c3aa996443e7f377aa423bcc03ffc617.json.gz +0 -0
- package/.cache/babel/c481eae84d69b65405a44af442dbfea7.json.gz +0 -0
- package/.cache/babel/c4a817d6c4bf6eb3687ffccc5c2df801.json.gz +0 -0
- package/.cache/babel/c8b10cf6f706fb669d6dd7564385768d.json.gz +0 -0
- package/.cache/babel/caa2f98ba4af6eba0605543f690693c6.json.gz +0 -0
- package/.cache/babel/cada4b2cecb2c1fcc48b7a7ecda54907.json.gz +0 -0
- package/.cache/babel/d1bed5404789c427c32965ac6ecad0d9.json.gz +0 -0
- package/.cache/babel/d395e8c0a9c63680f2dcf90ca0e91d4a.json.gz +0 -0
- package/.cache/babel/d4672090e0dd9a73bfb00bd770b23643.json.gz +0 -0
- package/.cache/babel/d4c81f65fe6d78cdbdcf1ef901b7ba1b.json.gz +0 -0
- package/.cache/babel/d515ddc0797ea256ff7271507737e9ce.json.gz +0 -0
- package/.cache/babel/d742848d263503f79168f1a6b8a52097.json.gz +0 -0
- package/.cache/babel/d834b41d7028519ecd0cbc8c65d33dde.json.gz +0 -0
- package/.cache/babel/d9060b9162e7caf974db0b90b6134727.json.gz +0 -0
- package/.cache/babel/d946975b9beac51a39f600461e84b1b6.json.gz +0 -0
- package/.cache/babel/daf0af780cff2270b1ae0e4b97a5a4ab.json.gz +0 -0
- package/.cache/babel/db5215643b0737dc5245972a5c25f736.json.gz +0 -0
- package/.cache/babel/dd57b8d31664b147b9f1e3f5cd18cc2a.json.gz +0 -0
- package/.cache/babel/e0c78bdaae19f15e2dd4a773e842422b.json.gz +0 -0
- package/.cache/babel/e1a2c7e4fc3afe9cc6e03d60f4e4a23d.json.gz +0 -0
- package/.cache/babel/e210ff9aa99df972b8d81c4bda70f642.json.gz +0 -0
- package/.cache/babel/e259a73f84d5b92b94e6d094719264c3.json.gz +0 -0
- package/.cache/babel/e6ce03a9908c9c4dc2c723531f1073f6.json.gz +0 -0
- package/.cache/babel/e8a1501dd8e4b3389ecdc8f722622359.json.gz +0 -0
- package/.cache/babel/eb3bb371036da362c42db50248d0b180.json.gz +0 -0
- package/.cache/babel/eb854e03c810bdb969497b2a36119bfa.json.gz +0 -0
- package/.cache/babel/ec25bb53826070b7f301e64f02355b8c.json.gz +0 -0
- package/.cache/babel/edbaca20e4a65f850c3d8321c1945718.json.gz +0 -0
- package/.cache/babel/f059f1ca9e49d5c3e655d20339860dce.json.gz +0 -0
- package/.cache/babel/f24c559fb42ef906405966598baf5f80.json.gz +0 -0
- package/.cache/babel/f2f333c3c546ad711d722d782decd450.json.gz +0 -0
- package/.cache/babel/f42c854ce8f1dc1a6e6fe7c510b033a5.json.gz +0 -0
- package/.cache/babel/f5211608f22c2e12594eafdbc4e66aa5.json.gz +0 -0
- package/.cache/babel/f645b8c88a49718cd778e3595212d4eb.json.gz +0 -0
- package/.cache/babel/f66dda5c4e4e9d04eb6b7411fcb12a65.json.gz +0 -0
- package/.cache/babel/f9d5b6f3f5438342dba75c2ce6143eef.json.gz +0 -0
- package/.cache/babel/fc9c60ee1d2e8783ba4c08db5cf97d40.json.gz +0 -0
- package/.cache/babel/fd558798cea72d04fb826468a89d72aa.json.gz +0 -0
- package/.cache/babel/fe735cbd0f6e131e28d8b6eb1f39141b.json.gz +0 -0
- package/.eslintrc.js +3 -26
- package/.nvmrc +1 -0
- package/CHANGELOG.md +422 -0
- package/babel.config.js +6 -0
- package/block-list.json +1 -1
- package/composer.json +2 -2
- package/composer.lock +446 -161
- package/dist/author-list/view.asset.php +1 -0
- package/dist/author-list/view.css +1 -0
- package/dist/author-list/view.js +1 -0
- package/dist/author-list/view.rtl.css +1 -0
- package/dist/author-profile/view.asset.php +1 -0
- package/dist/author-profile/view.css +1 -0
- package/dist/author-profile/view.js +1 -0
- package/dist/author-profile/view.rtl.css +1 -0
- package/dist/block_styles.asset.php +1 -0
- package/dist/block_styles.css +1 -0
- package/dist/block_styles.js +1 -0
- package/dist/block_styles.rtl.css +1 -0
- package/dist/carousel/view.asset.php +1 -0
- package/dist/carousel/view.css +1 -0
- package/dist/carousel/view.js +1 -0
- package/dist/carousel/view.rtl.css +1 -0
- package/dist/donate/view.asset.php +1 -0
- package/dist/donate/view.css +1 -0
- package/dist/donate/view.js +1 -0
- package/dist/donate/view.rtl.css +1 -0
- package/dist/donateStreamlined.asset.php +1 -0
- package/dist/donateStreamlined.css +1 -0
- package/dist/donateStreamlined.js +1 -0
- package/dist/donateStreamlined.rtl.css +1 -0
- package/dist/editor.asset.php +1 -0
- package/dist/editor.css +1 -0
- package/dist/editor.js +41 -0
- package/dist/editor.rtl.css +1 -0
- package/dist/homepage-articles/view.asset.php +1 -0
- package/dist/homepage-articles/view.css +1 -0
- package/dist/homepage-articles/view.js +1 -0
- package/dist/homepage-articles/view.rtl.css +1 -0
- package/dist/iframe/view.asset.php +1 -0
- package/dist/iframe/view.css +1 -0
- package/dist/iframe/view.js +1 -0
- package/dist/iframe/view.rtl.css +1 -0
- package/includes/class-newspack-blocks-api.php +14 -69
- package/includes/class-newspack-blocks-patterns.php +4 -1
- package/includes/class-newspack-blocks.php +421 -95
- package/newspack-blocks.php +26 -2
- package/package.json +31 -129
- package/postcss.config.js +11 -0
- package/src/block-patterns/subscribe-2.php +1 -1
- package/src/block-patterns/subscribe-3.php +1 -1
- package/src/block-patterns/subscribe-7.php +12 -0
- package/src/block-patterns/subscribe-8.php +12 -0
- package/src/block-patterns/subscribe-9.php +12 -0
- package/src/block-styles/core/columns/editor.scss +5 -8
- package/src/block-styles/core/columns/view.scss +83 -42
- package/src/blocks/author-list/block.json +82 -0
- package/src/blocks/author-list/class-wp-rest-newspack-author-list-controller.php +387 -0
- package/src/blocks/author-list/edit.js +527 -0
- package/src/blocks/author-list/editor.js +7 -0
- package/src/blocks/author-list/editor.scss +1 -0
- package/src/blocks/author-list/index.js +45 -0
- package/src/blocks/author-list/view.js +5 -0
- package/src/blocks/author-list/view.php +175 -0
- package/src/blocks/author-list/view.scss +46 -0
- package/src/blocks/author-profile/block.json +8 -0
- package/src/blocks/author-profile/class-wp-rest-newspack-authors-controller.php +69 -14
- package/src/blocks/author-profile/edit.js +212 -189
- package/src/blocks/author-profile/editor.scss +1 -1
- package/src/blocks/author-profile/single-author.js +100 -0
- package/src/blocks/author-profile/view.php +38 -92
- package/src/blocks/author-profile/view.scss +120 -1
- package/src/blocks/carousel/create-swiper.js +14 -5
- package/src/blocks/carousel/edit.js +4 -2
- package/src/blocks/carousel/editor.scss +3 -12
- package/src/blocks/carousel/view.js +1 -1
- package/src/blocks/carousel/view.php +9 -5
- package/src/blocks/carousel/view.scss +29 -3
- package/src/blocks/donate/class-wp-rest-newspack-donate-controller.php +22 -24
- package/src/blocks/donate/edit.js +49 -42
- package/src/blocks/donate/editor.scss +27 -3
- package/src/blocks/donate/index.js +31 -4
- package/src/blocks/donate/streamlined/index.js +248 -0
- package/src/blocks/donate/streamlined/index.test.js +125 -0
- package/src/blocks/donate/streamlined/style.scss +324 -0
- package/src/blocks/donate/streamlined/utils.js +174 -0
- package/src/blocks/donate/streamlined/utils.test.js +18 -0
- package/src/blocks/donate/view.php +77 -36
- package/src/blocks/donate/view.scss +291 -0
- package/src/blocks/homepage-articles/block.json +8 -0
- package/src/blocks/homepage-articles/class-wp-rest-newspack-articles-controller.php +24 -78
- package/src/blocks/homepage-articles/edit.js +26 -0
- package/src/blocks/homepage-articles/store.js +11 -1
- package/src/blocks/homepage-articles/templates/article.php +31 -3
- package/src/blocks/homepage-articles/templates/articles-loop.php +6 -5
- package/src/blocks/homepage-articles/utils.js +11 -10
- package/src/blocks/homepage-articles/view.php +4 -1
- package/src/blocks/homepage-articles/view.scss +69 -24
- package/src/blocks/iframe/block.json +34 -0
- package/src/blocks/iframe/class-wp-rest-newspack-iframe-controller.php +345 -0
- package/src/blocks/iframe/edit.js +252 -0
- package/src/blocks/iframe/editor.js +7 -0
- package/src/blocks/iframe/editor.scss +84 -0
- package/src/blocks/iframe/icons.js +10 -0
- package/src/blocks/iframe/iframe-placeholder.js +180 -0
- package/src/blocks/iframe/index.js +48 -0
- package/src/blocks/iframe/view.js +5 -0
- package/src/blocks/iframe/view.php +130 -0
- package/src/blocks/iframe/view.scss +9 -0
- package/src/blocks/video-playlist/view.php +4 -3
- package/src/components/query-controls.js +5 -4
- package/src/setup/editor.js +0 -1
- package/src/shared/js/utils.js +1 -1
- package/src/templates/author-profile-card.php +99 -0
- package/vendor/autoload.php +7 -0
- package/vendor/composer/ClassLoader.php +572 -0
- package/vendor/composer/InstalledVersions.php +350 -0
- package/vendor/composer/LICENSE +21 -0
- package/vendor/composer/autoload_classmap.php +10 -0
- package/vendor/composer/autoload_namespaces.php +9 -0
- package/vendor/composer/autoload_psr4.php +9 -0
- package/vendor/composer/autoload_real.php +55 -0
- package/vendor/composer/autoload_static.php +20 -0
- package/vendor/composer/installed.json +5 -0
- package/vendor/composer/installed.php +23 -0
- package/webpack.config.js +2 -3
- package/.circleci/config.yml +0 -96
- package/.distignore +0 -36
- package/.editorconfig +0 -22
- package/.github/ISSUE_TEMPLATE/Bug_report.md +0 -21
- package/.github/ISSUE_TEMPLATE/Enhancement.md +0 -17
- package/.github/ISSUE_TEMPLATE/Feature_request.md +0 -17
- package/.github/PULL_REQUEST_TEMPLATE.md +0 -29
- package/.github/workflows/main.yml +0 -15
- package/.phpcs.xml.dist +0 -55
- package/.prettierrc +0 -10
- package/.stylelintrc +0 -21
- package/.travis.yml +0 -67
- package/phpunit.xml.dist +0 -16
- package/src/blocks/author-profile/shared.scss +0 -95
- package/src/blocks/donate/streamlined.js +0 -180
- package/src/blocks/donate/streamlined.scss +0 -124
- package/src/setup/public-path.js +0 -13
- package/src/setup/view.js +0 -4
- package/tests/bootstrap.php +0 -31
- 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 @@
|
|
|
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
|
+
};
|