From 9ec85dcad6b4c019f9fe1b35e26c5011f926697c Mon Sep 17 00:00:00 2001 From: ramonjd Date: Tue, 11 Oct 2022 15:29:22 +1100 Subject: [PATCH] Initial commit - ensure that we convert fluid font sizes to fluid values in the editor for search block block supports - we do this by passing the getTypographyClassesAndStyles hook a flag to tell it whether to convert Updated CHANGELOG.md Added tests --- packages/block-editor/CHANGELOG.md | 3 ++- packages/block-editor/README.md | 1 + .../src/hooks/test/use-typography-props.js | 22 +++++++++++++++++++ .../src/hooks/use-typography-props.js | 21 +++++++++++++++--- packages/block-library/src/search/edit.js | 7 +++++- 5 files changed, 49 insertions(+), 5 deletions(-) diff --git a/packages/block-editor/CHANGELOG.md b/packages/block-editor/CHANGELOG.md index e2230b0c3ff1ed..cc14eb7d867897 100644 --- a/packages/block-editor/CHANGELOG.md +++ b/packages/block-editor/CHANGELOG.md @@ -4,7 +4,8 @@ ### Bug Fix -- `FontSizePicker`: Update fluid utils so that only string, floats and integers are treated as valid font sizes for the purposes of fluid typography.([#44847](https://github.com/WordPress/gutenberg/pull/44847)) +- `FontSizePicker`: Update fluid utils so that only string, floats and integers are treated as valid font sizes for the purposes of fluid typography ([#44847](https://github.com/WordPress/gutenberg/pull/44847)) +- `getTypographyClassesAndStyles()`: Ensure that font sizes are transformed into fluid values if fluid typography is activated ([#44852](https://github.com/WordPress/gutenberg/pull/44852)) ## 10.2.0 (2022-10-05) diff --git a/packages/block-editor/README.md b/packages/block-editor/README.md index d30f5279970285..2ecacfd4b959e9 100644 --- a/packages/block-editor/README.md +++ b/packages/block-editor/README.md @@ -521,6 +521,7 @@ attributes. _Parameters_ - _attributes_ `Object`: Block attributes. +- _isFluidFontSizeActive_ `boolean`: Whether the function should try to convert font sizes to fluid values. _Returns_ diff --git a/packages/block-editor/src/hooks/test/use-typography-props.js b/packages/block-editor/src/hooks/test/use-typography-props.js index 93e4de29bc7348..52f7bf97328ee3 100644 --- a/packages/block-editor/src/hooks/test/use-typography-props.js +++ b/packages/block-editor/src/hooks/test/use-typography-props.js @@ -25,4 +25,26 @@ describe( 'getTypographyClassesAndStyles', () => { }, } ); } ); + + it( 'should return fluid font size styles', () => { + const attributes = { + fontFamily: 'tofu', + style: { + typography: { + letterSpacing: '22px', + fontSize: '2rem', + textTransform: 'uppercase', + }, + }, + }; + expect( getTypographyClassesAndStyles( attributes, true ) ).toEqual( { + className: 'has-tofu-font-family', + style: { + letterSpacing: '22px', + fontSize: + 'clamp(1.5rem, 1.5rem + ((1vw - 0.48rem) * 2.885), 3rem)', + textTransform: 'uppercase', + }, + } ); + } ); } ); diff --git a/packages/block-editor/src/hooks/use-typography-props.js b/packages/block-editor/src/hooks/use-typography-props.js index d08105d8d90c1e..d70ae08aafc593 100644 --- a/packages/block-editor/src/hooks/use-typography-props.js +++ b/packages/block-editor/src/hooks/use-typography-props.js @@ -9,6 +9,7 @@ import classnames from 'classnames'; */ import { getInlineStyles } from './style'; import { getFontSizeClass } from '../components/font-sizes'; +import { getComputedFluidTypographyValue } from '../components/font-sizes/fluid-utils'; // This utility is intended to assist where the serialization of the typography // block support is being skipped for a block but the typography related CSS @@ -18,12 +19,26 @@ import { getFontSizeClass } from '../components/font-sizes'; * Provides the CSS class names and inline styles for a block's typography support * attributes. * - * @param {Object} attributes Block attributes. + * @param {Object} attributes Block attributes. + * @param {boolean} isFluidFontSizeActive Whether the function should try to convert font sizes to fluid values. * * @return {Object} Typography block support derived CSS classes & styles. */ -export function getTypographyClassesAndStyles( attributes ) { - const typographyStyles = attributes?.style?.typography || {}; +export function getTypographyClassesAndStyles( + attributes, + isFluidFontSizeActive +) { + let typographyStyles = attributes?.style?.typography || {}; + + if ( isFluidFontSizeActive ) { + typographyStyles = { + ...typographyStyles, + fontSize: getComputedFluidTypographyValue( { + fontSize: attributes?.style?.typography?.fontSize, + } ), + }; + } + const style = getInlineStyles( { typography: typographyStyles } ); const fontFamilyClassName = !! attributes?.fontFamily ? `has-${ kebabCase( attributes.fontFamily ) }-font-family` diff --git a/packages/block-library/src/search/edit.js b/packages/block-library/src/search/edit.js index 807dda04e743e4..377788d281d3d0 100644 --- a/packages/block-library/src/search/edit.js +++ b/packages/block-library/src/search/edit.js @@ -16,6 +16,7 @@ import { getTypographyClassesAndStyles as useTypographyProps, store as blockEditorStore, __experimentalGetElementClassName, + useSetting, } from '@wordpress/block-editor'; import { useDispatch, useSelect } from '@wordpress/data'; import { useEffect } from '@wordpress/element'; @@ -113,7 +114,11 @@ export default function SearchEdit( { } const colorProps = useColorProps( attributes ); - const typographyProps = useTypographyProps( attributes ); + const fluidTypographyEnabled = useSetting( 'typography.fluid' ); + const typographyProps = useTypographyProps( + attributes, + fluidTypographyEnabled + ); const unitControlInstanceId = useInstanceId( UnitControl ); const unitControlInputId = `wp-block-search__width-${ unitControlInstanceId }`; const isButtonPositionInside = 'button-inside' === buttonPosition;