Elizabeth Mitchell e8b5b29d1e feat(iconbutton): update tokens to v0.192
BREAKING CHANGE: Replace `container-size` tokens with `container-width` and `container-height`.

PiperOrigin-RevId: 566801178
2023-09-19 17:52:12 -07:00

132 lines
3.0 KiB
SCSS

//
// Copyright 2022 Google LLC
// SPDX-License-Identifier: Apache-2.0
//
// go/keep-sorted start
@use 'sass:list';
@use 'sass:map';
// go/keep-sorted end
// go/keep-sorted start
@use '../../focus/focus-ring';
@use '../../ripple/ripple';
@use '../../tokens';
// go/keep-sorted end
@mixin theme($tokens) {
$supported-tokens: tokens.$md-comp-icon-button-supported-tokens;
@each $token, $value in $tokens {
@if list.index($supported-tokens, $token) == null {
@error 'Token `#{$token}` is not a supported token.';
}
@if $value {
--md-icon-button-#{$token}: #{$value};
}
}
}
@mixin styles() {
$tokens: tokens.md-comp-icon-button-values();
:host {
@each $token, $value in $tokens {
--_#{$token}: var(--md-icon-button-#{$token}, #{$value});
}
// These custom properties are not used, so set defaults so token tests pass
// for <md-icon-button>.
--_container-shape-start-start: 0;
--_container-shape-start-end: 0;
--_container-shape-end-end: 0;
--_container-shape-end-start: 0;
--_container-height: 0;
--_container-width: 0;
height: var(--_state-layer-height);
width: var(--_state-layer-width);
}
:host([touch-target='wrapper']) {
margin: max(0px, (48px - var(--_state-layer-height))/2)
max(0px, (48px - var(--_state-layer-width))/2);
}
md-focus-ring {
@include focus-ring.theme(
(
'shape-start-start': var(--_state-layer-shape),
'shape-start-end': var(--_state-layer-shape),
'shape-end-end': var(--_state-layer-shape),
'shape-end-start': var(--_state-layer-shape),
)
);
}
.standard {
background-color: transparent;
color: var(--_icon-color);
@include ripple.theme(
(
hover-color: var(--_hover-state-layer-color),
hover-opacity: var(--_hover-state-layer-opacity),
pressed-color: var(--_pressed-state-layer-color),
pressed-opacity: var(--_pressed-state-layer-opacity),
)
);
&:hover {
color: var(--_hover-icon-color);
}
&:focus {
color: var(--_focus-icon-color);
}
&:active {
color: var(--_pressed-icon-color);
}
&:disabled {
color: var(--_disabled-icon-color);
}
}
md-ripple {
border-radius: var(--_state-layer-shape);
}
.standard:disabled .icon {
opacity: var(--_disabled-icon-opacity);
}
.selected {
&:not(:disabled) {
color: var(--_selected-icon-color);
&:hover {
color: var(--_selected-hover-icon-color);
}
&:focus {
color: var(--_selected-focus-icon-color);
}
&:active {
color: var(--_selected-pressed-icon-color);
}
}
@include ripple.theme(
(
hover-color: var(--_selected-hover-state-layer-color),
hover-opacity: var(--_selected-hover-state-layer-opacity),
pressed-color: var(--_selected-pressed-state-layer-color),
pressed-opacity: var(--_selected-pressed-state-layer-opacity),
)
);
}
}