From 3d38cb52e7b3a8f11988312da3c4dab2581a992a Mon Sep 17 00:00:00 2001 From: Olivier Tassinari Date: Mon, 24 Sep 2018 21:16:27 +0200 Subject: [PATCH] [styles] Remove react-jss dependency --- .size-limit.js | 2 +- package.json | 1 + packages/material-ui/package.json | 1 - packages/material-ui/src/styles/reactJssContext.js | 9 +++++++++ packages/material-ui/src/styles/withStyles.js | 7 ++++--- packages/material-ui/src/test-utils/getClasses.js | 2 +- 6 files changed, 16 insertions(+), 6 deletions(-) create mode 100644 packages/material-ui/src/styles/reactJssContext.js diff --git a/.size-limit.js b/.size-limit.js index 06c2e268def9b6..bfe8d5cedb1f20 100644 --- a/.size-limit.js +++ b/.size-limit.js @@ -16,7 +16,7 @@ module.exports = [ name: 'The initial cost people pay for using one component', webpack: true, path: 'packages/material-ui/build/Paper/index.js', - limit: '17.5 KB', + limit: '17.3 KB', }, { name: 'The size of all the modules of material-ui.', diff --git a/package.json b/package.json index 9d3edcedb1c433..b3344bce2abdca 100644 --- a/package.json +++ b/package.json @@ -130,6 +130,7 @@ "react-docgen": "^3.0.0-beta10", "react-dom": "^16.4.0", "react-inspector": "^2.2.2", + "react-jss": "^8.1.0", "react-markdown": "^3.4.1", "react-number-format": "^3.0.2", "react-redux": "^5.0.6", diff --git a/packages/material-ui/package.json b/packages/material-ui/package.json index c2c115f34f920b..96f1fa11d61f6c 100644 --- a/packages/material-ui/package.json +++ b/packages/material-ui/package.json @@ -57,7 +57,6 @@ "popper.js": "^1.14.1", "prop-types": "^15.6.0", "react-event-listener": "^0.6.2", - "react-jss": "^8.1.0", "react-transition-group": "^2.2.1", "recompose": "0.28.0 - 0.30.0", "warning": "^4.0.1" diff --git a/packages/material-ui/src/styles/reactJssContext.js b/packages/material-ui/src/styles/reactJssContext.js new file mode 100644 index 00000000000000..d4dcca6ec7227a --- /dev/null +++ b/packages/material-ui/src/styles/reactJssContext.js @@ -0,0 +1,9 @@ +// Share the same values than in +// https://github.com/cssinjs/jss/blob/master/packages/react-jss/src/ns.js +const ns = { + jss: '64a55d578f856d258dc345b094a2a2b3', + sheetsRegistry: 'd4bd0baacbc52bbd48bbb9eb24344ecd', + sheetOptions: '6fc570d6bd61383819d0f9e7407c452d', +}; + +export default ns; diff --git a/packages/material-ui/src/styles/withStyles.js b/packages/material-ui/src/styles/withStyles.js index e2239a2d61501e..893fafd3afd031 100644 --- a/packages/material-ui/src/styles/withStyles.js +++ b/packages/material-ui/src/styles/withStyles.js @@ -3,9 +3,8 @@ import PropTypes from 'prop-types'; import warning from 'warning'; import hoistNonReactStatics from 'hoist-non-react-statics'; import wrapDisplayName from 'recompose/wrapDisplayName'; -import contextTypes from 'react-jss/lib/contextTypes'; import { create } from 'jss'; -import * as ns from 'react-jss/lib/ns'; +import ns from './reactJssContext'; import jssPreset from './jssPreset'; import mergeClasses from './mergeClasses'; import createMuiTheme from './createMuiTheme'; @@ -303,7 +302,9 @@ const withStyles = (stylesOrCreator, options = {}) => Component => { WithStyles.contextTypes = { muiThemeProviderOptions: PropTypes.object, - ...contextTypes, + [ns.jss]: PropTypes.object, + [ns.sheetOptions]: PropTypes.object, + [ns.sheetsRegistry]: PropTypes.object, ...(listenToTheme ? themeListener.contextTypes : {}), }; diff --git a/packages/material-ui/src/test-utils/getClasses.js b/packages/material-ui/src/test-utils/getClasses.js index 6622fa85f2903c..3d18245703565b 100644 --- a/packages/material-ui/src/test-utils/getClasses.js +++ b/packages/material-ui/src/test-utils/getClasses.js @@ -1,4 +1,4 @@ -import * as ns from 'react-jss/lib/ns'; +import ns from '../styles/reactJssContext'; import { SheetsRegistry } from 'jss'; import createShallow from './createShallow'; import { sheetsManager } from '../styles/withStyles';