@use '../../token-utils'; @use '../../../style/sass-utils'; // The prefix used to generate the fully qualified name for tokens in this file. $prefix: (mat, icon); // 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 (); } // Tokens that can be configured through Angular Material's color theming API. @function get-color-tokens($config) { // Default the icon to `inherit` so it matches the text around it. @return private-get-icon-color-tokens(inherit); } // Tokens that can be configured through Angular Material's typography theming API. @function get-typography-tokens($config) { @return (); } // Tokens that can be configured through Angular Material's density theming API. @function get-density-tokens($config) { @return (); } // Mixin used to set a specific color on an icon. @function private-get-icon-color-tokens($color) { @return ( color: $color, ); } // Combines the tokens generated by the above functions into a single map with placeholder values. // This is used to create token slots. @function get-token-slots() { @return sass-utils.deep-merge-all( get-unthemable-tokens(), get-color-tokens(token-utils.$placeholder-color-config), get-typography-tokens(token-utils.$placeholder-typography-config), get-density-tokens(token-utils.$placeholder-density-config) ); }