UNPKG

4.87 kBJavaScriptView Raw
1"use strict";
2
3var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
4var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
5Object.defineProperty(exports, "__esModule", {
6 value: true
7});
8exports.createMuiTheme = createMuiTheme;
9exports.default = void 0;
10var _formatMuiErrorMessage2 = _interopRequireDefault(require("@mui/utils/formatMuiErrorMessage"));
11var _deepmerge = _interopRequireDefault(require("@mui/utils/deepmerge"));
12var _styleFunctionSx = _interopRequireWildcard(require("@mui/system/styleFunctionSx"));
13var _createTheme = _interopRequireDefault(require("@mui/system/createTheme"));
14var _generateUtilityClass = _interopRequireDefault(require("@mui/utils/generateUtilityClass"));
15var _createMixins = _interopRequireDefault(require("./createMixins"));
16var _createPalette = _interopRequireDefault(require("./createPalette"));
17var _createTypography = _interopRequireDefault(require("./createTypography"));
18var _shadows = _interopRequireDefault(require("./shadows"));
19var _createTransitions = _interopRequireDefault(require("./createTransitions"));
20var _zIndex = _interopRequireDefault(require("./zIndex"));
21var _stringifyTheme = require("./stringifyTheme");
22function createThemeNoVars(options = {}, ...args) {
23 const {
24 breakpoints: breakpointsInput,
25 mixins: mixinsInput = {},
26 spacing: spacingInput,
27 palette: paletteInput = {},
28 transitions: transitionsInput = {},
29 typography: typographyInput = {},
30 shape: shapeInput,
31 ...other
32 } = options;
33 if (options.vars) {
34 throw new Error(process.env.NODE_ENV !== "production" ? 'MUI: `vars` is a private field used for CSS variables support.\n' + 'Please use another name.' : (0, _formatMuiErrorMessage2.default)(20));
35 }
36 const palette = (0, _createPalette.default)(paletteInput);
37 const systemTheme = (0, _createTheme.default)(options);
38 let muiTheme = (0, _deepmerge.default)(systemTheme, {
39 mixins: (0, _createMixins.default)(systemTheme.breakpoints, mixinsInput),
40 palette,
41 // Don't use [...shadows] until you've verified its transpiled code is not invoking the iterator protocol.
42 shadows: _shadows.default.slice(),
43 typography: (0, _createTypography.default)(palette, typographyInput),
44 transitions: (0, _createTransitions.default)(transitionsInput),
45 zIndex: {
46 ..._zIndex.default
47 }
48 });
49 muiTheme = (0, _deepmerge.default)(muiTheme, other);
50 muiTheme = args.reduce((acc, argument) => (0, _deepmerge.default)(acc, argument), muiTheme);
51 if (process.env.NODE_ENV !== 'production') {
52 // TODO v6: Refactor to use globalStateClassesMapping from @mui/utils once `readOnly` state class is used in Rating component.
53 const stateClasses = ['active', 'checked', 'completed', 'disabled', 'error', 'expanded', 'focused', 'focusVisible', 'required', 'selected'];
54 const traverse = (node, component) => {
55 let key;
56
57 // eslint-disable-next-line guard-for-in
58 for (key in node) {
59 const child = node[key];
60 if (stateClasses.includes(key) && Object.keys(child).length > 0) {
61 if (process.env.NODE_ENV !== 'production') {
62 const stateClass = (0, _generateUtilityClass.default)('', key);
63 console.error([`MUI: The \`${component}\` component increases ` + `the CSS specificity of the \`${key}\` internal state.`, 'You can not override it like this: ', JSON.stringify(node, null, 2), '', `Instead, you need to use the '&.${stateClass}' syntax:`, JSON.stringify({
64 root: {
65 [`&.${stateClass}`]: child
66 }
67 }, null, 2), '', 'https://mui.com/r/state-classes-guide'].join('\n'));
68 }
69 // Remove the style to prevent global conflicts.
70 node[key] = {};
71 }
72 }
73 };
74 Object.keys(muiTheme.components).forEach(component => {
75 const styleOverrides = muiTheme.components[component].styleOverrides;
76 if (styleOverrides && component.startsWith('Mui')) {
77 traverse(styleOverrides, component);
78 }
79 });
80 }
81 muiTheme.unstable_sxConfig = {
82 ..._styleFunctionSx.unstable_defaultSxConfig,
83 ...other?.unstable_sxConfig
84 };
85 muiTheme.unstable_sx = function sx(props) {
86 return (0, _styleFunctionSx.default)({
87 sx: props,
88 theme: this
89 });
90 };
91 muiTheme.toRuntimeSource = _stringifyTheme.stringifyTheme; // for Pigment CSS integration
92
93 return muiTheme;
94}
95let warnedOnce = false;
96function createMuiTheme(...args) {
97 if (process.env.NODE_ENV !== 'production') {
98 if (!warnedOnce) {
99 warnedOnce = true;
100 console.error(['MUI: the createMuiTheme function was renamed to createTheme.', '', "You should use `import { createTheme } from '@mui/material/styles'`"].join('\n'));
101 }
102 }
103 return createThemeNoVars(...args);
104}
105var _default = exports.default = createThemeNoVars;
\No newline at end of file