From 87120c7ef03d4a1cf88b426f5ae608a7bee17264 Mon Sep 17 00:00:00 2001 From: Matias Benedetto Date: Tue, 26 Mar 2024 11:17:55 -0300 Subject: [PATCH] Activate the fonts coming from the backend and not the data from the frontend (#60093) * Activate the fonts coming from the backend and not the data from the frontend * add comment ----- Co-authored-by: matiasbenedetto Co-authored-by: mikachan Co-authored-by: getdave Co-authored-by: mcsf Co-authored-by: carolinan Co-authored-by: huzaifaalmesbah Co-authored-by: srueegger Co-authored-by: annezazu --- .../font-library-modal/context.js | 29 +++++++++++++++---- 1 file changed, 23 insertions(+), 6 deletions(-) diff --git a/packages/edit-site/src/components/global-styles/font-library-modal/context.js b/packages/edit-site/src/components/global-styles/font-library-modal/context.js index dc593c7dfbb295..ff8cfc1284b1ec 100644 --- a/packages/edit-site/src/components/global-styles/font-library-modal/context.js +++ b/packages/edit-site/src/components/global-styles/font-library-modal/context.js @@ -281,11 +281,13 @@ function FontLibraryProvider( { children } ) { sucessfullyInstalledFontFaces?.length > 0 || alreadyInstalledFontFaces?.length > 0 ) { - fontFamilyToInstall.fontFace = [ + // Use font data from REST API not from client to ensure + // correct font information is used. + installedFontFamily.fontFace = [ ...sucessfullyInstalledFontFaces, - ...alreadyInstalledFontFaces, ]; - fontFamiliesToActivate.push( fontFamilyToInstall ); + + fontFamiliesToActivate.push( installedFontFamily ); } // If it's a system font but was installed successfully, activate it. @@ -402,14 +404,29 @@ function FontLibraryProvider( { children } ) { }; const activateCustomFontFamilies = ( fontsToAdd ) => { - // Merge the existing custom fonts with the new fonts. + // Removes the id from the families and faces to avoid saving that to global styles post content. + const fontsToActivate = fontsToAdd.map( + ( { id: _familyDbId, fontFace, ...font } ) => ( { + ...font, + ...( fontFace && fontFace.length > 0 + ? { + fontFace: fontFace.map( + ( { id: _faceDbId, ...face } ) => face + ), + } + : {} ), + } ) + ); + // Activate the fonts by set the new custom fonts array. setFontFamilies( { ...fontFamilies, - custom: mergeFontFamilies( fontFamilies?.custom, fontsToAdd ), + // Merge the existing custom fonts with the new fonts. + custom: mergeFontFamilies( fontFamilies?.custom, fontsToActivate ), } ); + // Add custom fonts to the browser. - fontsToAdd.forEach( ( font ) => { + fontsToActivate.forEach( ( font ) => { if ( font.fontFace ) { font.fontFace.forEach( ( face ) => { // Load font faces just in the iframe because they already are in the document.