forked from cssinjs/jss
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdynamicStyles.js
94 lines (82 loc) · 2.47 KB
/
dynamicStyles.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
/* eslint-disable react/prop-types */
import expect from 'expect.js'
import TestRenderer from 'react-test-renderer'
import * as React from 'react'
import {stripIndent} from 'common-tags'
import {JssProvider, SheetsRegistry, createUseStyles, withStyles} from '../src'
import createCommonDynamicStylesTests from '../test-utils/createCommonDynamicStylesTests'
const createGenerateId = () => {
let counter = 0
return rule => `${rule.key}-${counter++}`
}
describe('React-JSS: dynamic styles', () => {
describe('using createUseStyles', () => {
const createStyledComponent = (styles, options = {}) => {
const useStyles = createUseStyles(styles, options)
const Comp = props => {
const classes = useStyles(props)
if (props.getClasses) props.getClasses(classes)
return null
}
Comp.displayName = options.name
return Comp
}
createCommonDynamicStylesTests({createStyledComponent})
})
describe('using withStyles', () => {
const createStyledComponent = (styles, options = {}) => {
const Comp = ({getClasses, classes}) => {
if (getClasses) getClasses(classes)
return null
}
Comp.displayName = options.name
return withStyles(styles, options)(Comp)
}
createCommonDynamicStylesTests({createStyledComponent})
})
it('issue', () => {
const registry = new SheetsRegistry()
const useStyles = createUseStyles({
button: () => ({
'&': {}
})
})
const MyComponent = () => {
const [x, setDummy] = React.useState(0)
useStyles({x})
return (
<button type="button" onClick={() => setDummy(prev => prev + 1)}>
{x}
</button>
)
}
const renderer = TestRenderer.create(
<JssProvider registry={registry} generateId={createGenerateId()}>
<MyComponent />
</JssProvider>
)
expect(registry.toString()).to.be(stripIndent`
.button-0 {}
.button-d0-1 {}
.button-d0-1 {}
`)
TestRenderer.act(() => {
renderer.root.findByType('button').props.onClick()
})
TestRenderer.act(() => {
renderer.root.findByType('button').props.onClick()
})
expect(registry.toString()).not.to.be(stripIndent`
.button-0 {}
.button-d0-1 {}
.button-d0-1 {}
.button-d0-1 {}
.button-d0-1 {}
`)
expect(registry.toString()).to.be(stripIndent`
.button-0 {}
.button-d0-1 {}
.button-d0-1 {}
`)
})
})