From d1e435370cbef3ae9285b3256ce1080e9aaf1f0c Mon Sep 17 00:00:00 2001 From: Carolina Nymark Date: Fri, 23 Feb 2024 13:56:25 +0100 Subject: [PATCH] Font Library: add option to revoke access to Google Fonts (#59205) * Font Library: add option to revoke access to Google Fonts --------- Co-authored-by: carolinan Co-authored-by: matiasbenedetto --- .../font-library-modal/font-collection.js | 37 ++++++++++++++++--- .../font-library-modal/tab-panel-layout.js | 9 ++++- 2 files changed, 39 insertions(+), 7 deletions(-) diff --git a/packages/edit-site/src/components/global-styles/font-library-modal/font-collection.js b/packages/edit-site/src/components/global-styles/font-library-modal/font-collection.js index b792a5c8246c0c..74daf15640ffaf 100644 --- a/packages/edit-site/src/components/global-styles/font-library-modal/font-collection.js +++ b/packages/edit-site/src/components/global-styles/font-library-modal/font-collection.js @@ -19,10 +19,11 @@ import { FlexItem, Flex, Button, + DropdownMenu, } from '@wordpress/components'; import { debounce } from '@wordpress/compose'; import { sprintf, __, _x } from '@wordpress/i18n'; -import { search, closeSmall } from '@wordpress/icons'; +import { search, closeSmall, moreVertical } from '@wordpress/icons'; /** * Internal dependencies @@ -42,17 +43,14 @@ const DEFAULT_CATEGORY = { name: _x( 'All', 'font categories' ), }; +const LOCAL_STORAGE_ITEM = 'wp-font-library-google-fonts-permission'; const MIN_WINDOW_HEIGHT = 500; function FontCollection( { slug } ) { const requiresPermission = slug === 'google-fonts'; const getGoogleFontsPermissionFromStorage = () => { - return ( - window.localStorage.getItem( - 'wp-font-library-google-fonts-permission' - ) === 'true' - ); + return window.localStorage.getItem( LOCAL_STORAGE_ITEM ) === 'true'; }; const [ selectedFont, setSelectedFont ] = useState( null ); @@ -79,6 +77,11 @@ function FontCollection( { slug } ) { return () => window.removeEventListener( 'storage', handleStorage ); }, [ slug, requiresPermission ] ); + const revokeAccess = () => { + window.localStorage.setItem( LOCAL_STORAGE_ITEM, 'false' ); + window.dispatchEvent( new Event( 'storage' ) ); + }; + useEffect( () => { const fetchFontCollection = async () => { try { @@ -227,11 +230,33 @@ function FontCollection( { slug } ) { ); } + const ActionsComponent = () => { + if ( slug !== 'google-fonts' || renderConfirmDialog || selectedFont ) { + return null; + } + return ( + + ); + }; + return ( } description={ ! selectedFont ? selectedCollection.description diff --git a/packages/edit-site/src/components/global-styles/font-library-modal/tab-panel-layout.js b/packages/edit-site/src/components/global-styles/font-library-modal/tab-panel-layout.js index c959a5373190ec..87a569b5500ee0 100644 --- a/packages/edit-site/src/components/global-styles/font-library-modal/tab-panel-layout.js +++ b/packages/edit-site/src/components/global-styles/font-library-modal/tab-panel-layout.js @@ -11,6 +11,7 @@ import { Button, Notice, FlexBlock, + FlexItem, } from '@wordpress/components'; import { chevronLeft } from '@wordpress/icons'; import { __ } from '@wordpress/i18n'; @@ -27,6 +28,7 @@ function TabPanelLayout( { handleBack, children, footer, + actions, } ) { const { setNotice } = useContext( FontLibraryContext ); @@ -35,7 +37,11 @@ function TabPanelLayout( { - + { !! handleBack && (