UNPKG

@gorazdo/material-you

Version:

Material You theme for @material-ui library

60 lines (59 loc) 2.62 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.useMaterialYouColors = exports.MaterialYouColor = void 0; const core_1 = require("@material-ui/core"); const react_1 = __importStar(require("react")); const MaterialYouColorContext = (0, react_1.createContext)(undefined); const generateColors = (color) => { const luminance = (0, core_1.getLuminance)(color); console.log({ color, luminance }); if (luminance > 0.3) { // todo change the lightness detection // change color and background-color generation return { color: (0, core_1.darken)(color, 0.6), backgroundColor: color, }; } return { color, backgroundColor: (0, core_1.emphasize)(color, 1.1), }; }; const MaterialYouColor = ({ children, color, }) => { const contextValue = (0, react_1.useMemo)(() => generateColors(color), [color]); return (react_1.default.createElement(MaterialYouColorContext.Provider, { value: contextValue }, children)); }; exports.MaterialYouColor = MaterialYouColor; const useMaterialYouColors = (cssProperties = {}) => { const colors = (0, react_1.useContext)(MaterialYouColorContext); const theme = (0, core_1.useTheme)(); if (!colors) { return Object.assign({ backgroundColor: theme.palette.background.default, color: theme.palette.text.secondary }, cssProperties); } return Object.assign(Object.assign({}, colors), cssProperties); }; exports.useMaterialYouColors = useMaterialYouColors;