From f8a28b08a6b78031dc80601fb388ee3278134ea1 Mon Sep 17 00:00:00 2001 From: Olivier Tassinari Date: Fri, 5 Jul 2019 20:53:06 +0300 Subject: [PATCH] [styles] Warn when using a missing style rule --- docs/src/modules/components/MarkdownDocs.js | 2 +- docs/src/modules/utils/generateMarkdown.js | 16 +++++++++++ .../src/makeStyles/makeStyles.js | 28 +++++++++++++++++++ .../material-ui/src/Typography/Typography.js | 3 +- .../material-ui/src/utils/oneOfWithString.js | 5 ++++ 5 files changed, 52 insertions(+), 2 deletions(-) create mode 100644 packages/material-ui/src/utils/oneOfWithString.js diff --git a/docs/src/modules/components/MarkdownDocs.js b/docs/src/modules/components/MarkdownDocs.js index c9b51fdca2bb47..b0d6ad7fa322a5 100644 --- a/docs/src/modules/components/MarkdownDocs.js +++ b/docs/src/modules/components/MarkdownDocs.js @@ -178,7 +178,7 @@ function MarkdownDocs(props) { )} - + {!disableEdit ? (
x.trim()) + .filter(x => x) + .map(x => ({ value: x, computed: false })), + }); + } const deprecatedInfo = getDeprecatedInfo(type); if (deprecatedInfo !== false) { diff --git a/packages/material-ui-styles/src/makeStyles/makeStyles.js b/packages/material-ui-styles/src/makeStyles/makeStyles.js index b23ffbe93e712c..e0755013a8ce16 100644 --- a/packages/material-ui-styles/src/makeStyles/makeStyles.js +++ b/packages/material-ui-styles/src/makeStyles/makeStyles.js @@ -1,6 +1,7 @@ import React from 'react'; import warning from 'warning'; import { getDynamicStyles } from 'jss'; +import { getDisplayName } from '@material-ui/utils'; import mergeClasses from '../mergeClasses'; import multiKeyStore from './multiKeyStore'; import useTheme from '../useTheme'; @@ -44,6 +45,33 @@ function getClasses({ state, stylesOptions }, classes, Component) { newClasses: classes, Component, }); + + if (process.env.NODE_ENV !== 'production' && typeof Proxy !== 'undefined') { + state.cacheClasses.value = new Proxy(state.cacheClasses.value, { + get(target, styleRule) { + if ( + !(styleRule in target) && + styleRule !== '@@toStringTag' && + typeof styleRule !== 'symbol' && + styleRule !== 'inspect' + ) { + const name = state.name || getDisplayName(Component); + warning( + false, + [ + `Material-UI: you access a style rule \`${styleRule}\` that does not exist.`, + styleRule && `The style was definied on the \`${name}\` component.`, + '', + 'Instead, the following classes keys are available:', + JSON.stringify(target, null, 2), + ].join('\n'), + ); + } + + return target[styleRule]; + }, + }); + } } return state.cacheClasses.value; diff --git a/packages/material-ui/src/Typography/Typography.js b/packages/material-ui/src/Typography/Typography.js index 1ad330e32cb201..132001221ca2f1 100644 --- a/packages/material-ui/src/Typography/Typography.js +++ b/packages/material-ui/src/Typography/Typography.js @@ -3,6 +3,7 @@ import PropTypes from 'prop-types'; import clsx from 'clsx'; import withStyles from '../styles/withStyles'; import { capitalize } from '../utils/helpers'; +import oneOfWithString from '../utils/oneOfWithString'; export const styles = theme => ({ /* Styles applied to the root element. */ @@ -221,7 +222,7 @@ Typography.propTypes = { /** * Applies the theme typography styles. */ - variant: PropTypes.oneOf([ + variant: oneOfWithString([ 'h1', 'h2', 'h3', diff --git a/packages/material-ui/src/utils/oneOfWithString.js b/packages/material-ui/src/utils/oneOfWithString.js new file mode 100644 index 00000000000000..fc53ea20638715 --- /dev/null +++ b/packages/material-ui/src/utils/oneOfWithString.js @@ -0,0 +1,5 @@ +import * as PropTypes from 'prop-types'; + +export default function oneOfWithString() { + return PropTypes.string; +}