sass-references/angular-material/material/core/style/_sass-utils.scss

116 lines
4.0 KiB
SCSS
Raw Permalink Normal View History

2024-12-06 10:42:08 +08:00
@use 'sass:color';
@use 'sass:string';
@use 'sass:list';
@use 'sass:map';
@use 'sass:meta';
/// Whether our theming API is using --sys- variables for color tokens.
$use-system-color-variables: false;
/// Whether our theming API is using --sys- variables for typography tokens.
$use-system-typography-variables: false;
/// Include content under the current selector (&) or the document root if there is no current
/// selector.
/// @param {String} $root [html] The default root selector to use when there is no current selector.
/// @output The given content under the current selector, or root selector if there is no current
/// selector.
/// @content Content to output under the current selector, or root selector if there is no current
/// selector.
@mixin current-selector-or-root($root: html) {
@if & {
@content;
}
@else {
#{$root} {
@content;
}
}
}
/// A version of the standard `map.merge` function that takes a variable number of arguments.
/// Each argument is merged into the final result from left to right.
/// @param {List} $maps The maps to combine with map.merge
/// @return {Map} The combined result of successively calling map.merge with each parameter.
@function merge-all($maps...) {
$result: ();
@each $map in $maps {
$result: map.merge($result, $map);
}
@return $result;
}
/// A version of the standard `map.deep-merge` function that takes a variable number of arguments.
/// Each argument is deep-merged into the final result from left to right.
/// @param {List} $maps The maps to combine with map.deep-merge
/// @return {Map} The combined result of successively calling map.deep-merge with each parameter.
@function deep-merge-all($maps...) {
$result: ();
@each $map in $maps {
$result: map.deep-merge($result, $map);
}
@return $result;
}
/// Coerces the given value to a list, by converting any non-list value into a single-item list.
/// This should be used when dealing with user-passed lists of args to avoid confusing errors,
/// since Sass treats `($x)` as equivalent to `$x`.
/// @param {Any} $value The value to coerce to a list.
/// @return {List} The original $value if it was a list, otherwise a single-item list containing
/// $value.
@function coerce-to-list($value) {
@return if(meta.type-of($value) != 'list', ($value,), $value);
}
/// A version of the Sass `color.change` function that is safe ot use with CSS variables.
@function safe-color-change($color, $args...) {
$args: meta.keywords($args);
$use-color-mix: $use-system-color-variables or
(is-css-var-name($color) and string.index($color, '--mat') == 1);
@if (meta.type-of($color) == 'color') {
@return color.change($color, $args...);
}
@else if ($color != null and
map.get($args, alpha) != null and $use-color-mix) {
$opacity: map.get($args, alpha);
@if meta.type-of($opacity) == number {
$opacity: ($opacity * 100) + '%';
}
@if (is-css-var-name($opacity)) {
$opacity: calc(var($opacity) * 100%);
}
@if (is-css-var-name($color)) {
$color: var($color);
}
@return #{color-mix(in srgb, #{$color} #{$opacity}, transparent)};
}
@return $color;
}
/// Gets the given arguments as a map of keywords and validates that only supported arguments were
/// passed.
/// @param {ArgList} $args The arguments to convert to a keywords map.
/// @param {List} $supported-args The supported argument names.
/// @return {Map} The $args as a map of argument name to argument value.
@function validate-keyword-args($args, $supported-args) {
@if list.length($args) > 0 {
@error #{'Expected keyword args, but got positional args: '}#{$args};
}
$kwargs: meta.keywords($args);
@each $arg, $v in $kwargs {
@if list.index($supported-args, $arg) == null {
@error #{'Unsupported argument '}#{$arg}#{'. Valid arguments are: '}#{$supported-args};
}
}
@return $kwargs;
}
// Returns whether the $value is a CSS variable name based on whether it's a string prefixed
// by "--".
@function is-css-var-name($value) {
@return meta.type-of($value) == string and string.index($value, '--') == 1;
}