1 | "use strict";
|
2 |
|
3 | var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
4 | var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
5 | Object.defineProperty(exports, "__esModule", {
|
6 | value: true
|
7 | });
|
8 | exports.createMuiTheme = createMuiTheme;
|
9 | exports.default = void 0;
|
10 | var _formatMuiErrorMessage2 = _interopRequireDefault(require("@mui/utils/formatMuiErrorMessage"));
|
11 | var _deepmerge = _interopRequireDefault(require("@mui/utils/deepmerge"));
|
12 | var _styleFunctionSx = _interopRequireWildcard(require("@mui/system/styleFunctionSx"));
|
13 | var _createTheme = _interopRequireDefault(require("@mui/system/createTheme"));
|
14 | var _generateUtilityClass = _interopRequireDefault(require("@mui/utils/generateUtilityClass"));
|
15 | var _createMixins = _interopRequireDefault(require("./createMixins"));
|
16 | var _createPalette = _interopRequireDefault(require("./createPalette"));
|
17 | var _createTypography = _interopRequireDefault(require("./createTypography"));
|
18 | var _shadows = _interopRequireDefault(require("./shadows"));
|
19 | var _createTransitions = _interopRequireDefault(require("./createTransitions"));
|
20 | var _zIndex = _interopRequireDefault(require("./zIndex"));
|
21 | var _stringifyTheme = require("./stringifyTheme");
|
22 | function 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 |
|
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 |
|
53 | const stateClasses = ['active', 'checked', 'completed', 'disabled', 'error', 'expanded', 'focused', 'focusVisible', 'required', 'selected'];
|
54 | const traverse = (node, component) => {
|
55 | let key;
|
56 |
|
57 |
|
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 |
|
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;
|
92 |
|
93 | return muiTheme;
|
94 | }
|
95 | let warnedOnce = false;
|
96 | function 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 | }
|
105 | var _default = exports.default = createThemeNoVars; |
\ | No newline at end of file |