@sinoui/material-color-utilities
v0.2.5
Published
Algorithms and utilities that power the Material Design 3 (M3) color system, including choosing theme colors from images and creating tones of colors; all in a new color space.
Downloads
20
Readme
material-color-utilities
拷贝自 https://github.com/material-foundation/material-color-utilities 。主要用来解决无法在非 esm 环境中直接使用 @material/material-color-utilities 的问题。以后 @material/material-color-utilities 解决了 cjs 中直接使用的问题,再切换回来。
Algorithms and utilities that power the Material Design 3 (M3) color system, including choosing theme colors from images and creating tones of colors; all in a new color space.
See the main README for more information.
Getting started
npm i @material/material-color-utilities
or yarn add @material/material-color-utilities
import { HCT } from "@material/material-color-utilities";
// Simple demonstration of HCT.
const color = HCT.fromInt(0xff4285f4);
console.log(`Hue: ${color.hue}`);
console.log(`Chrome: ${color.chroma}`);
console.log(`Tone: ${color.tone}`);
Theming
import { argbFromHex, themeFromSourceColor, applyTheme } from "@material/material-color-utilities";
// Get the theme from a hex color
const theme = themeFromSourceColor(argbFromHex('#f82506'), [
{
name: "custom-1",
value: argbFromHex("#ff0000"),
blend: true,
},
]);
// Print out the theme as JSON
console.log(JSON.stringify(theme, null, 2));
// Check if the user has dark mode turned on
const systemDark = window.matchMedia("(prefers-color-scheme: dark)").matches;
// Apply the theme to the body by updating custom properties for material tokens
applyTheme(theme, {target: document.body, dark: systemDark});
Troubleshooting
If using node make sure to use the following flag:
node --experimental-specifier-resolution=node
Contributing
This repo is not accepting external contributions, but feature requests and bug reports are welcome on GitHub.