From 7a92d8516570bdc1d2b549c8b121fe6c42b1e06f Mon Sep 17 00:00:00 2001 From: Amy Sorto <8575252+amysorto@users.noreply.github.com> Date: Tue, 16 Jan 2024 19:36:32 +0000 Subject: [PATCH] fix(material/stepper): Update token values for M3 and add color variant support --- src/dev-app/theme-m3.scss | 3 ++ .../theming/_custom-tokens.scss | 44 ++++++++++++++++--- src/material/core/tokens/m2/mat/_stepper.scss | 7 ++- src/material/stepper/_stepper-theme.scss | 35 ++++++++++++--- src/material/stepper/step-header.scss | 2 + 5 files changed, 77 insertions(+), 14 deletions(-) diff --git a/src/dev-app/theme-m3.scss b/src/dev-app/theme-m3.scss index 060739a8f05d..35a3eabae67d 100644 --- a/src/dev-app/theme-m3.scss +++ b/src/dev-app/theme-m3.scss @@ -7,6 +7,7 @@ @mixin color-variants-back-compat($theme) { .mat-primary { @include mat.option-color($theme, $color-variant: primary); + @include mat.stepper-color($theme, $color-variant: primary); &.mat-icon { @include mat.icon-color($theme, $color-variant: primary); @@ -24,6 +25,7 @@ .mat-accent { @include mat.option-color($theme, $color-variant: secondary); + @include mat.stepper-color($theme, $color-variant: secondary); &.mat-icon { @include mat.icon-color($theme, $color-variant: secondary); @@ -41,6 +43,7 @@ .mat-warn { @include mat.option-color($theme, $color-variant: error); + @include mat.stepper-color($theme, $color-variant: error); &.mat-icon { @include mat.icon-color($theme, $color-variant: error); diff --git a/src/material-experimental/theming/_custom-tokens.scss b/src/material-experimental/theming/_custom-tokens.scss index 086e0f35569a..2420574c050f 100644 --- a/src/material-experimental/theming/_custom-tokens.scss +++ b/src/material-experimental/theming/_custom-tokens.scss @@ -718,7 +718,7 @@ /// @param {Boolean} $exclude-hardcoded Whether to exclude hardcoded token values /// @return {Map} A set of custom tokens for the mat-stepper @function stepper($systems, $exclude-hardcoded) { - @return mat.private-merge-all( + @return ( ( container-color: map.get($systems, md-sys-color, surface), line-color: map.get($systems, md-sys-color, outline-variant), @@ -732,9 +732,11 @@ ), header-label-text-color: map.get($systems, md-sys-color, on-surface-variant), header-optional-label-text-color: map.get($systems, md-sys-color, on-surface-variant), - header-selected-state-label-text-color: map.get($systems, md-sys-color, on-surface), - header-icon-background-color: map.get($systems, md-sys-color, inverse-surface), - header-icon-foreground-color: map.get($systems, md-sys-color, inverse-on-surface), + header-selected-state-label-text-color: map.get($systems, md-sys-color, on-surface-variant), + header-icon-background-color: map.get($systems, md-sys-color, on-surface-variant), + header-icon-foreground-color: map.get($systems, md-sys-color, surface), + header-edit-state-icon-background-color: map.get($systems, md-sys-color, primary), + header-edit-state-icon-foreground-color: map.get($systems, md-sys-color, on-primary), header-error-state-label-text-color: map.get($systems, md-sys-color, error), header-error-state-icon-foreground-color: map.get($systems, md-sys-color, error), header-error-state-icon-background-color: _hardcode(transparent, $exclude-hardcoded), @@ -743,10 +745,40 @@ header-label-text-size: map.get($systems, md-sys-typescale, title-small-size), header-label-text-weight: map.get($systems, md-sys-typescale, title-small-weight), header-error-state-label-text-size: map.get($systems, md-sys-typescale, title-small-size), - header-selected-state-label-text-size: map.get($systems, md-sys-typescale, title-small-szie), + header-focus-state-shape: map.get($systems, md-sys-shape, corner-medium), + header-hover-state-shape: map.get($systems, md-sys-shape, corner-medium), + header-selected-state-label-text-size: map.get($systems, md-sys-typescale, title-small-size), header-selected-state-label-text-weight: map.get( $systems, md-sys-typescale, title-small-weight), - ), + header-selected-state-icon-background-color: map.get($systems, md-sys-color, primary), + header-selected-state-icon-foreground-color: map.get($systems, md-sys-color, on-primary), + ), ( + // Color variants + primary: ( + header-edit-state-icon-background-color: map.get($systems, md-sys-color, primary), + header-edit-state-icon-foreground-color: map.get($systems, md-sys-color, on-primary), + header-selected-state-icon-background-color: map.get($systems, md-sys-color, primary), + header-selected-state-icon-foreground-color: map.get($systems, md-sys-color, on-primary), + ), + secondary: ( + header-edit-state-icon-background-color: map.get($systems, md-sys-color, secondary), + header-edit-state-icon-foreground-color: map.get($systems, md-sys-color, on-secondary), + header-selected-state-icon-background-color: map.get($systems, md-sys-color, secondary), + header-selected-state-icon-foreground-color: map.get($systems, md-sys-color, on-secondary), + ), + tertiary: ( + header-edit-state-icon-background-color: map.get($systems, md-sys-color, tertiary), + header-edit-state-icon-foreground-color: map.get($systems, md-sys-color, on-tertiary), + header-selected-state-icon-background-color: map.get($systems, md-sys-color, tertiary), + header-selected-state-icon-foreground-color: map.get($systems, md-sys-color, on-tertiary), + ), + error: ( + header-edit-state-icon-background-color: map.get($systems, md-sys-color, error), + header-edit-state-icon-foreground-color: map.get($systems, md-sys-color, on-error), + header-selected-state-icon-background-color: map.get($systems, md-sys-color, error), + header-selected-state-icon-foreground-color: map.get($systems, md-sys-color, on-error), + ) + ) ); } diff --git a/src/material/core/tokens/m2/mat/_stepper.scss b/src/material/core/tokens/m2/mat/_stepper.scss index 8a2fe0f5fbbb..4e1b645da88a 100644 --- a/src/material/core/tokens/m2/mat/_stepper.scss +++ b/src/material/core/tokens/m2/mat/_stepper.scss @@ -10,7 +10,12 @@ $prefix: (mat, stepper); // Tokens that can't be configured through Angular Material's current theming API, // but may be in a future version of the theming API. @function get-unthemable-tokens() { - @return (); + @return ( + // Border radius for step header on focus + header-focus-state-shape: 0, + // Border radius for step header on hover + header-hover-state-shape: 0, + ); } // Tokens that can be configured through Angular Material's color theming API. diff --git a/src/material/stepper/_stepper-theme.scss b/src/material/stepper/_stepper-theme.scss index 3a64b47c58b9..84ef0f14cfdf 100644 --- a/src/material/stepper/_stepper-theme.scss +++ b/src/material/stepper/_stepper-theme.scss @@ -1,4 +1,3 @@ -@use 'sass:map'; @use '../core/theming/theming'; @use '../core/theming/inspection'; @use '../core/typography/typography'; @@ -6,6 +5,9 @@ @use '../core/tokens/token-utils'; @use '../core/tokens/m2/mat/stepper' as tokens-mat-stepper; +/// Outputs base theme styles (styles not dependent on the color, typography, or density settings) +/// for mat-stepper. +/// @param {Map} $theme The theme to generate base styles for. @mixin base($theme) { @if inspection.get-theme-version($theme) == 1 { @include _theme-from-tokens(inspection.get-theme-tokens($theme, base)); @@ -13,9 +15,14 @@ @else {} } -@mixin color($theme) { +/// Outputs color theme styles for mat-stepper. +/// @param {Map} $theme The theme to generate color styles for. +/// @param {ArgList} Additional optional arguments (only supported for M3 themes): +/// $color-variant: The color variant to use for the stepper: primary, secondary, +/// tertiary, or error (If not specified, primary color values will be used). +@mixin color($theme, $options...) { @if inspection.get-theme-version($theme) == 1 { - @include _theme-from-tokens(inspection.get-theme-tokens($theme, color)); + @include _theme-from-tokens(inspection.get-theme-tokens($theme, color), $options...); } @else { @include sass-utils.current-selector-or-root() { @@ -35,6 +42,8 @@ } } +/// Outputs typography theme styles for mat-stepper. +/// @param {Map} $theme The theme to generate typography styles for. @mixin typography($theme) { @if inspection.get-theme-version($theme) == 1 { @include _theme-from-tokens(inspection.get-theme-tokens($theme, typography)); @@ -47,6 +56,8 @@ } } +/// Outputs density theme styles for mat-stepper. +/// @param {Map} $theme The theme to generate density styles for. @mixin density($theme) { @if inspection.get-theme-version($theme) == 1 { @include _theme-from-tokens(inspection.get-theme-tokens($theme, density)); @@ -59,10 +70,15 @@ } } -@mixin theme($theme) { +/// Outputs all (base, color, typography, and density) theme styles for mat-stepper. +/// @param {Map} $theme The theme to generate color styles for. +/// @param {ArgList} Additional optional arguments (only supported for M3 themes): +/// $color-variant: The color variant to use for the stepper: primary, secondary, +/// tertiary, or error (If not specified, primary color values will be used). +@mixin theme($theme, $options...) { @include theming.private-check-duplicate-theme-styles($theme, 'mat-stepper') { @if inspection.get-theme-version($theme) == 1 { - @include _theme-from-tokens(inspection.get-theme-tokens($theme)); + @include _theme-from-tokens(inspection.get-theme-tokens($theme), $options...); } @else { @include base($theme); @@ -79,9 +95,14 @@ } } -@mixin _theme-from-tokens($tokens) { +@mixin _theme-from-tokens($tokens, $options...) { @if ($tokens != ()) { + $mat-stepper-tokens: token-utils.get-tokens-for( + $tokens, + tokens-mat-stepper.$prefix, + $options... + ); @include token-utils.create-token-values( - tokens-mat-stepper.$prefix, map.get($tokens, tokens-mat-stepper.$prefix)); + tokens-mat-stepper.$prefix, $mat-stepper-tokens); } } diff --git a/src/material/stepper/step-header.scss b/src/material/stepper/step-header.scss index 746be3dbf50a..3c23e53df96f 100644 --- a/src/material/stepper/step-header.scss +++ b/src/material/stepper/step-header.scss @@ -28,11 +28,13 @@ &:hover:not([aria-disabled]), &:hover[aria-disabled='false'] { @include token-utils.create-token-slot(background-color, header-hover-state-layer-color); + @include token-utils.create-token-slot(border-radius, header-hover-state-shape); } &.cdk-keyboard-focused, &.cdk-program-focused { @include token-utils.create-token-slot(background-color, header-focus-state-layer-color); + @include token-utils.create-token-slot(border-radius, header-focus-state-shape); } }