From bc6393af70320e0feb1ea97de207b06457d48ac5 Mon Sep 17 00:00:00 2001 From: Ben Dwyer Date: Wed, 19 Jun 2024 16:35:06 +0100 Subject: [PATCH] use variation titles for typeset button --- .../global-styles/typeset-button.js | 37 +++++++++++-------- 1 file changed, 21 insertions(+), 16 deletions(-) diff --git a/packages/edit-site/src/components/global-styles/typeset-button.js b/packages/edit-site/src/components/global-styles/typeset-button.js index eabb6e3a5651d4..257a32c962a572 100644 --- a/packages/edit-site/src/components/global-styles/typeset-button.js +++ b/packages/edit-site/src/components/global-styles/typeset-button.js @@ -23,10 +23,9 @@ import { getFontFamilies } from './utils'; import { NavigationButtonAsItem } from './navigation-button'; import Subtitle from './subtitle'; import { unlock } from '../../lock-unlock'; +import { filterObjectByProperty } from '../../hooks/use-theme-style-variations/use-theme-style-variations-by-property'; -const { GlobalStylesContext, areGlobalStyleConfigsEqual } = unlock( - blockEditorPrivateApis -); +const { GlobalStylesContext } = unlock( blockEditorPrivateApis ); const { mergeBaseAndUserConfigs } = unlock( editorPrivateApis ); function TypesetButton() { @@ -41,21 +40,27 @@ function TypesetButton() { coreStore ).__experimentalGetCurrentThemeGlobalStylesVariations(); }, [] ); - - const activeVariation = useMemo( - () => - variations.find( ( variation ) => - areGlobalStyleConfigsEqual( userConfig, variation ) - ), - [ userConfig, variations ] + const userTypographyConfig = filterObjectByProperty( + userConfig, + 'typography' ); - let title; - if ( activeVariation ) { - title = activeVariation.title; - } else { - title = allFontFamilies.map( ( font ) => font?.name ).join( ', ' ); - } + const title = useMemo( () => { + if ( Object.keys( userTypographyConfig ).length === 0 ) { + return __( 'Default' ); + } + const activeVariation = variations.find( ( variation ) => { + return ( + JSON.stringify( + filterObjectByProperty( variation, 'typography' ) + ) === JSON.stringify( userTypographyConfig ) + ); + } ); + if ( activeVariation ) { + return activeVariation.title; + } + return allFontFamilies.map( ( font ) => font?.name ).join( ', ' ); + }, [ userTypographyConfig, variations ] ); return ( hasFonts && (