UNPKG

@material-ui/core

Version:

React components that implement Google's Material Design.

109 lines (83 loc) 4.63 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _deepmerge = _interopRequireDefault(require("deepmerge")); var _isPlainObject = _interopRequireDefault(require("is-plain-object")); var _warning = _interopRequireDefault(require("warning")); 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")); // < 1kb payload overhead when lodash/merge is > 3kb. function createMuiTheme() { 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, shadowsInput = options.shadows, spacingInput = options.spacing, _options$typography = options.typography, typographyInput = _options$typography === void 0 ? {} : _options$typography, other = (0, _objectWithoutProperties2.default)(options, ["breakpoints", "mixins", "palette", "shadows", "spacing", "typography"]); var palette = (0, _createPalette.default)(paletteInput); var breakpoints = (0, _createBreakpoints.default)(breakpointsInput); var spacing = (0, _createSpacing.default)(spacingInput); var muiTheme = (0, _extends2.default)({ breakpoints: breakpoints, direction: 'ltr', mixins: (0, _createMixins.default)(breakpoints, spacing, mixinsInput), overrides: {}, // Inject custom styles palette: palette, props: {}, // Inject custom props shadows: shadowsInput || _shadows.default, typography: (0, _createTypography.default)(palette, typographyInput), spacing: spacing }, (0, _deepmerge.default)({ shape: _shape.default, transitions: _transitions.default, zIndex: _zIndex.default }, other, { isMergeableObject: _isPlainObject.default })); 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) { process.env.NODE_ENV !== "production" ? (0, _warning.default)(false, ["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://material-ui.com/r/pseudo-classes-guide'].join('\n')) : void 0; // Remove the style to prevent global conflicts. node[key] = {}; } } }; traverse(muiTheme.overrides); } process.env.NODE_ENV !== "production" ? (0, _warning.default)(muiTheme.shadows.length === 25, 'Material-UI: the shadows array provided to createMuiTheme should support 25 elevations.') : void 0; return muiTheme; } var _default = createMuiTheme; exports.default = _default;