Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[react-jss] Add proper support for observables in react-jss #1002

Open
wants to merge 1 commit into
base: move-get-dynamic-styles
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
30 changes: 15 additions & 15 deletions packages/react-jss/.size-snapshot.json
Original file line number Diff line number Diff line change
@@ -1,30 +1,30 @@
{
"dist/react-jss.js": {
"bundled": 132634,
"minified": 44917,
"gzipped": 13301
"bundled": 133197,
"minified": 45116,
"gzipped": 13343
},
"dist/react-jss.min.js": {
"bundled": 100902,
"minified": 35076,
"gzipped": 10549
"bundled": 101465,
"minified": 35274,
"gzipped": 10590
},
"dist/react-jss.cjs.js": {
"bundled": 14470,
"minified": 6688,
"gzipped": 2222
"bundled": 14639,
"minified": 6825,
"gzipped": 2251
},
"dist/react-jss.esm.js": {
"bundled": 13788,
"minified": 6102,
"gzipped": 2102,
"bundled": 13920,
"minified": 6203,
"gzipped": 2124,
"treeshaked": {
"rollup": {
"code": 1964,
"import_statements": 475
"code": 2005,
"import_statements": 516
},
"webpack": {
"code": 3358
"code": 3433
}
}
}
Expand Down
1 change: 1 addition & 0 deletions packages/react-jss/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@
"hoist-non-react-statics": "^3.2.0",
"jss": "10.0.0-alpha.9",
"jss-plugin-rule-value-function": "10.0.0-alpha.9",
"jss-plugin-rule-value-observable": "10.0.0-alpha.9",
"jss-preset-default": "10.0.0-alpha.9",
"prop-types": "^15.6.0",
"theming": "^3.0.3"
Expand Down
4 changes: 3 additions & 1 deletion packages/react-jss/src/withStyles.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import React, {Component, type ComponentType, type Node} from 'react'
import hoistNonReactStatics from 'hoist-non-react-statics'
import {SheetsManager, type StyleSheet} from 'jss'
import {getFunctionStyles} from 'jss-plugin-rule-value-function'
import {getObservableStyles} from 'jss-plugin-rule-value-observable'
import {ThemeContext} from 'theming'

import type {HOCProps, Options, Styles, InnerProps} from './types'
Expand Down Expand Up @@ -142,7 +143,8 @@ export default function withStyles<Theme: {}, S: Styles<Theme>>(
...contextSheetOptions,
index,
meta: `${displayName}, ${isThemingEnabled ? 'Themed' : 'Unthemed'}, Static`,
classNamePrefix: this.classNamePrefix
classNamePrefix: this.classNamePrefix,
link: getObservableStyles(themedStyles) !== null
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Now I think because of the separation in observable and function styles, we have double overhead for those 2 function calls.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We could have one function and do it in one go.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also we don't need getObservableStyles, we need hasObservables() from the logic above. It could be potentially one getDynamicStyles() : {styles, hasObservables, hasFunctions}

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this way it's a lot cleaner and the core doesn't need to know about observables or functions in that matter.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It is, but performance is the primary priority here. I think iterating over styles is quite a bit of overhead.

Copy link
Member Author

@HenriBeck HenriBeck Jan 27, 2019

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hmm, let's evaluate how important observables are in react. I think moving the getDynamicStyles out, still makes sense.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we can't evaluate that, because most people don't know this API exist. We need to promote it more, but in the end, we don't know how and were it is used.

Observables are part of the default preset, so it would be not logical if they didn't work with react-jss, which states using default preset.

Also even if we would remove observables from a default preset, it wouldn't be logical if react-jss doesn't work when user defined a new jss instance with an observable plugin.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we just need to figure out a good way to use observables with react-jss and get some use cases we can target for.

})
this.manager.add(theme, staticSheet)
// $FlowFixMe Cannot add random fields to instance of class StyleSheet
Expand Down