-
Notifications
You must be signed in to change notification settings - Fork 4.3k
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
Make elements font options referenceable #64443
Comments
I am not sure it makes sense to automatically generate variables for all the font styles. It reminds me of #38998, specifically the part about design tokens. Could this be solved by referencing the style? For example: {
"styles": {
"blocks": {
"core/quote": {
"typography": {
"ref": "styles.element.typography.heading"
}
}
}
},
} This would apply all the typography settings of the heading, to the block. The same idea could be applied for referencing the values in custom CSS, by generating a custom variable that references an existing {
"custom": {
"typography": {
"headings": {
"fontFamily": {
"ref": "styles.element.typography.heading.fontFamily"
}
}
}
}
} Which would result in: --wp--custom--typography--headings--font-family: Abel, sans-serif; |
Thanks @jffng for your input! It looks like the alternative you propose makes sense. This {
"$schema": "https://schemas.wp.org/trunk/theme.json",
"styles": {
"elements": {
"heading":{
"typography": {
"fontFamily": "var(--wp--preset--font-family--system-ui)"
}
}
}
},
"settings": {
"typography": {
"fontFamilies": [
{
"fontFamily": "-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu, Cantarell, 'Helvetica Neue', sans-serif",
"name": "System Font",
"slug": "system-ui"
}
]
},
"useRootPaddingAwareAlignments": true,
"custom": {
"typography": {
"headings": {
"fontFamily": {
"ref": "styles.elements.heading.typography.fontFamily"
}
}
}
}
},
"version": 2
} Is producing this CSS: --wp--custom--typography--headings--font-family--ref: styles.elements.heading.typography.fontFamily; |
Update: there's a known limitation. {
"settings":{
"custom": {
"typography": {
"headings": {
"fontFamily": {
"ref": "styles.elements.heading.typography.fontFamily"
}
}
}
}
}
} There's an issue requesting to fix/implement that: #57286 Allow use of ref in theme.json settings, as is possible with styles |
There's some nuance in this outline that I'm likely missing, so let me know where I'm wrong. I'd also appreciate additional insights from @WordPress/gutenberg-design. It sounds like you want to be able to reference the values of one element in another. The use case I keep coming back to here is one of using color. My site has background and text colors, and I want to use those two for designing my buttons:
1 can already be accomplished, simply don't set a color (the equivalent of If the motivation for the elements mentioned here, and specifically typography, is the same as that for the color example, then I'd agree it's something we want. However we want this for every property, not just fonts, and we want a user interface for it. Related: #49279 and #48581. |
What problem does this address?
Should WordPress make element font options referenceable?
Currently, there's no way to reference, for example, the font family selection for the website's headings because the values of this option are printed in selector-value CSS.
Example of the current
theme.json
config:This config is printed like this in CSS:
This works to set the font family of headings but cannot be referenced in any other part of the styles. Let's say you have a theme and you want to reference the font selection of the heading. That's currently impossible. The only current workaround is using fonts with a 'positional' slug (for example, 'heading-font') and style variations. This way, when the variation is applied, the 'heading font' will change. But style variations are a pre-defined part of a theme, and they cannot be created using the editor (without plugins such as Create Block Theme).
We could solve this limitation by using the elements font selection as 'positional' variables for fonts. This will allow users to change an entire theme by installing a font using the font library and selecting it in the elements font panel.
What is your proposed solution?
WordPress should make element font options referenceable. Should it print the CSS variables with the element's font family styles? I imagine that WordPress could print CSS variables for the font options in
theme.json.
This way, the element's font options can be referenced and reused across the site and theme. Font switching will be possible without pre-defined theme style variations that cannot be created in the editor.Example of how the printed CSS variable could look:
The resulting CSS for headings could look like this:
Custom CSS of the theme could reuse these variables:
Other parts of theme JSON could reference this setting, too:
The text was updated successfully, but these errors were encountered: