Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use available font weights and styles in FontAppearanceControl #61915

Merged
merged 46 commits into from
Jul 1, 2024
Merged
Show file tree
Hide file tree
Changes from 9 commits
Commits
Show all changes
46 commits
Select commit Hold shift + click to select a range
707ee73
Pass active font faces to appearance control component
mikachan May 23, 2024
c733432
Add formatFontWeight function
mikachan May 23, 2024
42811bd
Use only available font weights in FontAppearanceControl
mikachan May 23, 2024
a4ad7f9
Refactor weight and style array fallbacks
mikachan May 23, 2024
ead32c3
Rename normal to regular in styles list
mikachan May 23, 2024
861cd72
Make font weight labels translatable
mikachan May 23, 2024
af44839
Handle system fonts
mikachan May 25, 2024
af005a5
Add comment for font weight and style options
mikachan May 25, 2024
52802aa
Check against fontFamily rather than name
mikachan May 25, 2024
2811262
Handle font style names and values similar to font weights
mikachan May 25, 2024
a1bc596
Use some() rather than findIndex()
mikachan May 25, 2024
ca26c60
Merge branch 'trunk' into fix/font-weight-list
mikachan May 29, 2024
2d42dc4
Add getMergedFontFamiliesAndFontFamilyFaces function
mikachan May 30, 2024
b4fa5eb
Add tests for getMergedFontFamiliesAndFontFamilyFaces
mikachan May 30, 2024
672ae3a
Merge common case statements
mikachan May 30, 2024
dc60306
Remove toUpperCase() on font style names
mikachan May 30, 2024
3ba9ce8
Attempt to fix variable fonts options
mikachan May 30, 2024
15739d8
Fix formatFontStyle test
mikachan May 30, 2024
7677b53
Trim any surrounding whitespace from fontweight string
mikachan May 31, 2024
362d1c7
Add tests for normal and bold font weights
mikachan May 31, 2024
aba764d
Trim font weight before checking for spaces
mikachan May 31, 2024
e6d2e67
Create getFontStylesAndWeights function
mikachan May 31, 2024
7bd07ab
Move trim into if statement and improve comment
mikachan May 31, 2024
48eac26
Allow all uncombined weights and styles to be returned from getFontSt…
mikachan Jun 3, 2024
8ffd9b2
Make option key consistent with combined result
mikachan Jun 4, 2024
6b36ff0
Move combined option logic into getFontStylesAndWeights()
mikachan Jun 4, 2024
1ca996b
Swap ABeeZee test for Piazzolla example
mikachan Jun 4, 2024
ac2991f
Merge branch 'trunk' into fix/font-weight-list
mikachan Jun 16, 2024
29f6fcb
Fix isSystemFont logic
mikachan Jun 18, 2024
7a96507
Apply available font styles and weights when fontFamily changes
mikachan Jun 21, 2024
19a1e11
Merge branch 'trunk' into fix/font-weight-list
mikachan Jun 21, 2024
150e3a9
Swap isSystemFont logic around
mikachan Jun 21, 2024
f0b23cf
Merge branch 'trunk' into fix/font-weight-list
mikachan Jun 24, 2024
a55bf4f
Merge branch 'trunk' into fix/font-weight-list
mikachan Jun 24, 2024
97cbbad
Export isSystemFont and isVariableFont from getFontStylesAndWeights
mikachan Jun 24, 2024
ec2cf86
Use getFontStylesAndWeights to compare font face values
mikachan Jun 24, 2024
fa55510
Merge branch 'trunk' into fix/font-weight-list
mikachan Jun 25, 2024
ce08121
Improve comments for getFontStylesAndWeights
mikachan Jun 26, 2024
541010c
Improve test wording
mikachan Jun 26, 2024
da9f221
Add todo item
mikachan Jun 26, 2024
d359d9e
Include faux bold and italic as options
mikachan Jun 28, 2024
0ece8f5
Handle variable font weights
mikachan Jun 28, 2024
ad00060
Try to set the nearest available font weight
mikachan Jun 28, 2024
d7bba77
Only adds faux bold if a weight of 600 or above is not already available
creativecoder Jun 28, 2024
f6aef40
Updates tests with new faux bold logic
creativecoder Jun 28, 2024
f871c01
Merge branch 'trunk' into fix/font-weight-list
creativecoder Jun 30, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,11 @@ import { CustomSelectControl } from '@wordpress/components';
import { useMemo } from '@wordpress/element';
import { __, _x, sprintf } from '@wordpress/i18n';

/**
* Internal dependencies
*/
import { formatFontWeight } from '../../utils/format-font-weight';

const FONT_STYLES = [
{
name: _x( 'Regular', 'font style' ),
Expand Down Expand Up @@ -76,7 +81,7 @@ const getFontAppearanceLabel = ( hasFontStyles, hasFontWeights ) => {
};

/**
* Control to display unified font style and weight options.
* Control to display font style and weight options of the active font.
*
* @param {Object} props Component props.
*
Expand All @@ -87,6 +92,7 @@ export default function FontAppearanceControl( props ) {
onChange,
hasFontStyles = true,
hasFontWeights = true,
fontFamilyFaces,
value: { fontStyle, fontWeight },
...otherProps
} = props;
Expand All @@ -98,12 +104,48 @@ export default function FontAppearanceControl( props ) {
style: { fontStyle: undefined, fontWeight: undefined },
};

// Build font style and weight options based on the font family faces.
let fontWeights = [];
let fontStyles = [];

fontFamilyFaces?.forEach( ( face ) => {
if ( face.fontWeight ) {
if (
fontWeights.findIndex(
( weight ) => weight.value === face.fontWeight
) === -1
mikachan marked this conversation as resolved.
Show resolved Hide resolved
) {
fontWeights.push( formatFontWeight( face.fontWeight ) );
}
}
if ( face.fontStyle ) {
if (
fontStyles.findIndex(
( style ) => style.value === face.fontStyle
) === -1
) {
let styleName = face.fontStyle;
if ( face.fontStyle === 'normal' ) {
styleName = _x( 'Regular', 'font style' );
}

fontStyles.push( {
name: styleName,
value: face.fontStyle,
} );
}
}
} );

fontWeights = fontWeights.length === 0 ? FONT_WEIGHTS : fontWeights;
fontStyles = fontStyles.length === 0 ? FONT_STYLES : fontStyles;

// Combines both font style and weight options into a single dropdown.
const combineOptions = () => {
const combinedOptions = [ defaultOption ];

FONT_STYLES.forEach( ( { name: styleName, value: styleValue } ) => {
FONT_WEIGHTS.forEach(
fontStyles.forEach( ( { name: styleName, value: styleValue } ) => {
fontWeights.forEach(
( { name: weightName, value: weightValue } ) => {
const optionName =
styleValue === 'normal'
Expand Down Expand Up @@ -133,7 +175,7 @@ export default function FontAppearanceControl( props ) {
// Generates select options for font styles only.
const styleOptions = () => {
const combinedOptions = [ defaultOption ];
FONT_STYLES.forEach( ( { name, value } ) => {
fontStyles.forEach( ( { name, value } ) => {
combinedOptions.push( {
key: value,
name,
Expand All @@ -146,7 +188,7 @@ export default function FontAppearanceControl( props ) {
// Generates select options for font weights only.
const weightOptions = () => {
const combinedOptions = [ defaultOption ];
FONT_WEIGHTS.forEach( ( { name, value } ) => {
fontWeights.forEach( ( { name, value } ) => {
combinedOptions.push( {
key: value,
name,
Expand All @@ -163,7 +205,7 @@ export default function FontAppearanceControl( props ) {
}

return hasFontStyles ? styleOptions() : weightOptions();
}, [ props.options ] );
}, [ props.options, fontStyles, fontWeights ] );

// Find current selection by comparing font style & weight against options,
// and fall back to the Default option if there is no matching option.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -178,6 +178,9 @@ export default function TypographyPanel( {
);
}, [ fontFamilies ] );
const fontFamily = decodeValue( inheritedValue?.typography?.fontFamily );
const fontFamilyFaces = mergedFontFamilies.find(
( family ) => family.fontFamily === fontFamily
)?.fontFace;
const setFontFamily = ( newValue ) => {
const slug = mergedFontFamilies?.find(
( { fontFamily: f } ) => f === newValue
Expand Down Expand Up @@ -406,6 +409,7 @@ export default function TypographyPanel( {
onChange={ setFontAppearance }
hasFontStyles={ hasFontStyles }
hasFontWeights={ hasFontWeights }
fontFamilyFaces={ fontFamilyFaces }
size="__unstable-large"
__nextHasNoMarginBottom
/>
Expand Down
58 changes: 58 additions & 0 deletions packages/block-editor/src/utils/format-font-weight.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
/**
* WordPress dependencies
*/
import { _x } from '@wordpress/i18n';

/**
* Formats font weights to human readable names.
*
* @param {string} fontWeight font weight string
* @return {Object} new object with formatted font weight
*/
export function formatFontWeight( fontWeight ) {
if ( ! fontWeight ) {
return {};
}

if ( typeof fontWeight === 'object' ) {
return fontWeight;
}

let name;

switch ( fontWeight ) {
case '100':
name = _x( 'Thin', 'font weight' );
break;
case '200':
name = _x( 'Extra Light', 'font weight' );
break;
case '300':
name = _x( 'Light', 'font weight' );
break;
case '400':
name = _x( 'Regular', 'font weight' );
break;
case '500':
name = _x( 'Medium', 'font weight' );
break;
case '600':
name = _x( 'Semi Bold', 'font weight' );
break;
case '700':
name = _x( 'Bold', 'font weight' );
break;
case '800':
name = _x( 'Extra Bold', 'font weight' );
break;
case '900':
name = _x( 'Black', 'font weight' );
break;

default:
name = fontWeight;
break;
}

return { name, value: fontWeight };
}
54 changes: 54 additions & 0 deletions packages/block-editor/src/utils/test/format-font-weight.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
/**
* Internal dependencies
*/
import { formatFontWeight } from '../format-font-weight';

describe( 'formatFontWeight', () => {
it( 'should return empty object if weight is not available', () => {
expect( formatFontWeight() ).toEqual( {} );
} );

it( 'should return the same object if weight is already an object', () => {
const fontWeight = { name: 'Thin', value: '100' };
expect( formatFontWeight( fontWeight ) ).toEqual( fontWeight );
} );

it( 'should return the formatted font weight', () => {
expect( formatFontWeight( '100' ) ).toEqual( {
name: 'Thin',
value: '100',
} );
expect( formatFontWeight( '200' ) ).toEqual( {
name: 'Extra Light',
value: '200',
} );
expect( formatFontWeight( '300' ) ).toEqual( {
name: 'Light',
value: '300',
} );
expect( formatFontWeight( '400' ) ).toEqual( {
name: 'Regular',
value: '400',
} );
expect( formatFontWeight( '500' ) ).toEqual( {
name: 'Medium',
value: '500',
} );
expect( formatFontWeight( '600' ) ).toEqual( {
name: 'Semi Bold',
value: '600',
} );
expect( formatFontWeight( '700' ) ).toEqual( {
name: 'Bold',
value: '700',
} );
expect( formatFontWeight( '800' ) ).toEqual( {
name: 'Extra Bold',
value: '800',
} );
expect( formatFontWeight( '900' ) ).toEqual( {
name: 'Black',
value: '900',
} );
mikachan marked this conversation as resolved.
Show resolved Hide resolved
} );
} );
Loading