Skip to content

Commit

Permalink
Upgrade types, use string index fallback for CSSProperties to allow n…
Browse files Browse the repository at this point in the history
…ested pseudos (#11007)
  • Loading branch information
pelotom authored Apr 14, 2018
1 parent 2c6c15e commit 5ee6676
Show file tree
Hide file tree
Showing 4 changed files with 33 additions and 8 deletions.
6 changes: 3 additions & 3 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@
},
"dependencies": {
"@types/jss": "^9.3.0",
"@types/react-transition-group": "^2.0.6",
"@types/react-transition-group": "^2.0.8",
"babel-runtime": "^6.26.0",
"brcast": "^3.0.1",
"classnames": "^2.2.5",
Expand Down Expand Up @@ -98,7 +98,7 @@
},
"devDependencies": {
"@types/enzyme": "^3.1.4",
"@types/react": "16.3.4",
"@types/react": "16.3.9",
"argos-cli": "^0.0.9",
"autoprefixer": "^8.0.0",
"autosuggest-highlight": "^3.1.1",
Expand Down Expand Up @@ -196,7 +196,7 @@
"workbox-build": "^3.0.1"
},
"resolutions": {
"@types/react": "16.3.4"
"@types/react": "16.3.9"
},
"sideEffects": false,
"nyc": {
Expand Down
8 changes: 7 additions & 1 deletion src/styles/withStyles.d.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,11 @@
import * as React from 'react';
import { Theme } from './createMuiTheme';
import * as CSS from 'csstype';

export interface CSSProperties extends CSS.Properties<number | string> {
// Allow pseudo selectors and media queries
[k: string]: CSS.Properties<number | string>[keyof CSS.Properties] | CSSProperties;
}

/**
* This is basically the API of JSS. It defines a Map<string, CSS>,
Expand All @@ -8,7 +14,7 @@ import { Theme } from './createMuiTheme';
* - the `keys` are the class (names) that will be created
* - the `values` are objects that represent CSS rules (`React.CSSProperties`).
*/
export type StyleRules<ClassKey extends string = string> = Record<ClassKey, React.CSSProperties>;
export type StyleRules<ClassKey extends string = string> = Record<ClassKey, CSSProperties>;

export type StyleRulesCallback<ClassKey extends string = string> = (
theme: Theme,
Expand Down
9 changes: 9 additions & 0 deletions test/typescript/styles.spec.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -166,3 +166,12 @@ const DecoratedComponent = withStyles(styles)(

// no 'classes' property required at element creation time (#8267)
<DecoratedComponent text="foo" />;

// Allow nested pseudo selectors
withStyles<'listItem'>(theme => ({
listItem: {
'&:hover $listItemIcon': {
visibility: 'inherit',
},
},
}))
18 changes: 14 additions & 4 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -128,11 +128,17 @@
dependencies:
"@types/react" "*"

"@types/react@*", "@types/[email protected]":
version "16.3.4"
resolved "https://registry.yarnpkg.com/@types/react/-/react-16.3.4.tgz#9bbb301cd38270ae200bed329a342bd2f140c3ea"
"@types/react-transition-group@^2.0.8":
version "2.0.8"
resolved "https://registry.yarnpkg.com/@types/react-transition-group/-/react-transition-group-2.0.8.tgz#1ea86f6d8288e4bba8d743317ba9cc61cdacc1ad"
dependencies:
csstype "^2.0.0"
"@types/react" "*"

"@types/react@*", "@types/[email protected]":
version "16.3.9"
resolved "https://registry.yarnpkg.com/@types/react/-/react-16.3.9.tgz#15be16b53c89aac558cf6445774502b2792555ff"
dependencies:
csstype "^2.2.0"

"@zeit/[email protected]":
version "1.1.1"
Expand Down Expand Up @@ -2946,6 +2952,10 @@ csstype@^2.0.0:
version "2.1.1"
resolved "https://registry.yarnpkg.com/csstype/-/csstype-2.1.1.tgz#37b01a7a9958ef0b88167ff6678deccd732e0ae2"

csstype@^2.2.0:
version "2.2.0"
resolved "https://registry.yarnpkg.com/csstype/-/csstype-2.2.0.tgz#1656ef97553ac53b77090844a2531c6660ebd902"

currently-unhandled@^0.4.1:
version "0.4.1"
resolved "https://registry.yarnpkg.com/currently-unhandled/-/currently-unhandled-0.4.1.tgz#988df33feab191ef799a61369dd76c17adf957ea"
Expand Down

0 comments on commit 5ee6676

Please sign in to comment.