mirror of
https://github.com/material-components/material-web.git
synced 2024-09-17 16:48:02 +03:00
5e40a1bcec
Adds `@material/web/tokens/internal/shape` to take a shape token and create 4 logical tokens from its value. All components' logical shape tokens are now generated by the token files themselves, rather than added in each component's styles. PiperOrigin-RevId: 601783846
151 lines
3.3 KiB
SCSS
151 lines
3.3 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 '../../ripple/ripple';
|
|
@use '../../tokens';
|
|
// go/keep-sorted end
|
|
|
|
$_custom-property-prefix: 'filled-tonal-icon-button';
|
|
|
|
@mixin theme($tokens) {
|
|
$supported-tokens: tokens.$md-comp-filled-tonal-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-filled-tonal-icon-button-#{$token}: #{$value};
|
|
}
|
|
}
|
|
}
|
|
|
|
@mixin styles() {
|
|
$tokens: tokens.md-comp-filled-tonal-icon-button-values(
|
|
$exclude-custom-properties: false,
|
|
);
|
|
|
|
:host {
|
|
// Only use the logical properties.
|
|
$tokens: map.remove($tokens, 'container-shape');
|
|
@each $token, $value in $tokens {
|
|
--_#{$token}: #{$value};
|
|
}
|
|
}
|
|
|
|
.icon-button {
|
|
color: var(--_icon-color);
|
|
|
|
&:hover {
|
|
color: var(--_hover-icon-color);
|
|
}
|
|
|
|
&:focus {
|
|
color: var(--_focus-icon-color);
|
|
}
|
|
|
|
&:active {
|
|
color: var(--_pressed-icon-color);
|
|
}
|
|
|
|
&:disabled {
|
|
color: var(--_disabled-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),
|
|
)
|
|
);
|
|
}
|
|
|
|
.icon-button::before {
|
|
// Background color, separate node for opacity changes
|
|
background-color: var(--_container-color);
|
|
border-radius: inherit;
|
|
content: '';
|
|
inset: 0;
|
|
position: absolute;
|
|
z-index: -1; // place behind content
|
|
}
|
|
|
|
.icon-button:disabled::before {
|
|
background-color: var(--_disabled-container-color);
|
|
opacity: var(--_disabled-container-opacity);
|
|
}
|
|
|
|
.icon-button:disabled .icon {
|
|
opacity: var(--_disabled-icon-opacity);
|
|
}
|
|
|
|
.toggle-filled-tonal {
|
|
&:not(:disabled) {
|
|
color: var(--_toggle-icon-color);
|
|
|
|
&:hover {
|
|
color: var(--_toggle-hover-icon-color);
|
|
}
|
|
|
|
&:focus {
|
|
color: var(--_toggle-focus-icon-color);
|
|
}
|
|
|
|
&:active {
|
|
color: var(--_toggle-pressed-icon-color);
|
|
}
|
|
}
|
|
|
|
@include ripple.theme(
|
|
(
|
|
hover-color: var(--_toggle-hover-state-layer-color),
|
|
pressed-color: var(--_toggle-pressed-state-layer-color),
|
|
)
|
|
);
|
|
}
|
|
|
|
.toggle-filled-tonal:not(:disabled)::before {
|
|
// Note: filled tonal icon buttons have three container colors,
|
|
// "container-color" for regular, then selected/unselected for toggle.
|
|
background-color: var(--_unselected-container-color);
|
|
}
|
|
|
|
.selected {
|
|
&:not(:disabled) {
|
|
color: var(--_toggle-selected-icon-color);
|
|
|
|
&:hover {
|
|
color: var(--_toggle-selected-hover-icon-color);
|
|
}
|
|
|
|
&:focus {
|
|
color: var(--_toggle-selected-focus-icon-color);
|
|
}
|
|
|
|
&:active {
|
|
color: var(--_toggle-selected-pressed-icon-color);
|
|
}
|
|
}
|
|
|
|
@include ripple.theme(
|
|
(
|
|
hover-color: var(--_toggle-selected-hover-state-layer-color),
|
|
pressed-color: var(--_toggle-selected-pressed-state-layer-color),
|
|
)
|
|
);
|
|
}
|
|
|
|
.selected:not(:disabled)::before {
|
|
background-color: var(--_selected-container-color);
|
|
}
|
|
}
|