Skip to content

feat(theming): Add a typesafe like API to get theming tokens CSS var names #32800

@robmv

Description

@robmv

Feature Description

Currently there are Sass mixings that allow to, in a typesafe safe way, override theming tokens:

mat.snack-bar-overrides(....)

When saying typesafe, I mean that if a token is renamed or removed, the compiler will trigger an error. There are no equivalent to generating the CSS custom properties associated with these tokens.

Use Case

Why this could help?

I have a component to show temporary messages, much like an snack-bar, but it isn't a snack bar, but it uses the same snack bar theming, same colors, for example. So this uses currently --mat-snack-bar- prefixed CSS variables. The problem is that migrating from version 19 up to 21, many of these variables names were renamed from --mdc- to --mat- prefixes thankfully automatically but it missed that for snack bars, the prefixes changed from snackbar to snack-bar.

If instead of using the var named directly we had some kind of:

mat.token-var(snack-bar, container-color, white)

to generate var(--mat-snack-bar-container-color, white) in a typesafe way, triggering an error if a bad component or token name is used, this could have avoided the missed rename.

Metadata

Metadata

Assignees

No one assigned

    Labels

    featureThis issue represents a new feature or feature request rather than a bug or bug fixneeds triageThis issue needs to be triaged by the team

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions