UNPKG

@material-ui/core

Version:

React components that implement Google's Material Design.

122 lines (93 loc) 4.69 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.createMuiTheme = createMuiTheme; exports.default = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _utils = require("@material-ui/utils"); var _createBreakpoints = _interopRequireDefault(require("./createBreakpoints")); var _createMixins = _interopRequireDefault(require("./createMixins")); var _createPalette = _interopRequireDefault(require("./createPalette")); var _createTypography = _interopRequireDefault(require("./createTypography")); var _shadows = _interopRequireDefault(require("./shadows")); var _shape = _interopRequireDefault(require("./shape")); var _createSpacing = _interopRequireDefault(require("./createSpacing")); var _transitions = _interopRequireDefault(require("./transitions")); var _zIndex = _interopRequireDefault(require("./zIndex")); function createTheme() { var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var _options$breakpoints = options.breakpoints, breakpointsInput = _options$breakpoints === void 0 ? {} : _options$breakpoints, _options$mixins = options.mixins, mixinsInput = _options$mixins === void 0 ? {} : _options$mixins, _options$palette = options.palette, paletteInput = _options$palette === void 0 ? {} : _options$palette, spacingInput = options.spacing, _options$typography = options.typography, typographyInput = _options$typography === void 0 ? {} : _options$typography, other = (0, _objectWithoutProperties2.default)(options, ["breakpoints", "mixins", "palette", "spacing", "typography"]); var palette = (0, _createPalette.default)(paletteInput); var breakpoints = (0, _createBreakpoints.default)(breakpointsInput); var spacing = (0, _createSpacing.default)(spacingInput); var muiTheme = (0, _utils.deepmerge)({ breakpoints: breakpoints, direction: 'ltr', mixins: (0, _createMixins.default)(breakpoints, spacing, mixinsInput), overrides: {}, // Inject custom styles palette: palette, props: {}, // Provide default props shadows: _shadows.default, typography: (0, _createTypography.default)(palette, typographyInput), spacing: spacing, shape: _shape.default, transitions: _transitions.default, zIndex: _zIndex.default }, other); for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { args[_key - 1] = arguments[_key]; } muiTheme = args.reduce(function (acc, argument) { return (0, _utils.deepmerge)(acc, argument); }, muiTheme); if (process.env.NODE_ENV !== 'production') { var pseudoClasses = ['checked', 'disabled', 'error', 'focused', 'focusVisible', 'required', 'expanded', 'selected']; var traverse = function traverse(node, parentKey) { var depth = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1; var key; // eslint-disable-next-line guard-for-in, no-restricted-syntax for (key in node) { var child = node[key]; if (depth === 1) { if (key.indexOf('Mui') === 0 && child) { traverse(child, key, depth + 1); } } else if (pseudoClasses.indexOf(key) !== -1 && Object.keys(child).length > 0) { if (process.env.NODE_ENV !== 'production') { console.error(["Material-UI: The `".concat(parentKey, "` component increases ") + "the CSS specificity of the `".concat(key, "` internal state."), 'You can not override it like this: ', JSON.stringify(node, null, 2), '', 'Instead, you need to use the $ruleName syntax:', JSON.stringify({ root: (0, _defineProperty2.default)({}, "&$".concat(key), child) }, null, 2), '', 'https://mui.com/r/pseudo-classes-guide'].join('\n')); } // Remove the style to prevent global conflicts. node[key] = {}; } } }; traverse(muiTheme.overrides); } return muiTheme; } var warnedOnce = false; function createMuiTheme() { if (process.env.NODE_ENV !== 'production') { if (!warnedOnce) { warnedOnce = true; console.error(['Material-UI: the createMuiTheme function was renamed to createTheme.', '', "You should use `import { createTheme } from '@material-ui/core/styles'`"].join('\n')); } } return createTheme.apply(void 0, arguments); } var _default = createTheme; exports.default = _default;