JSS plugin for classes composition
This plugin allows you to use CSS frameworks and legacy code together with JSS as well as reuse Rules more granularly.
Make sure you read how to use
plugins
in general.
Compose with global classes.
To combine JSS with CSS framework like Material Design Lite or Bootstrap and others.
const styles = {
button: {
composes: 'btn btn-primary',
color: 'red'
}
buttonActive: {
composes: ['btn', 'btn-primary'],
color: 'blue'
}
}
Compiles to:
.button-123456 {
color: red;
}
.buttonActive-123456 {
color: blue;
}
When you use it:
<button className={classes.button}>Button</button>
<button className={classes.buttonActive}>Active Button</button>
It renders to:
<button class="button-123456 btn">Button</button>
<button class="button-123456 btn btn-primary">Active Button</button>
Compose with local classes.
Manage element states without rules duplication.
To reference a local rule, prefix the rule name with $
symbol.
const styles = {
button: {
color: 'black'
},
buttonActive: {
composes: '$button',
color: 'red'
},
buttonActiveDisabled: {
composes: '$buttonActive',
opacity: 0.5
},
disabled: {
opacity: 0.5
},
active: {
color: 'red'
},
buttonDisabled: {
composes: ['$button', '$active', '$disabled']
}
}
Compiles to:
.button-123456 {
color: black;
}
.buttonActive-123456 {
color: red;
}
.buttonActiveDisabled-123456 {
opacity: 0.5;
}
.disabled-123456 {
opacity: 0.5;
}
.active-123456 {
color: red;
}
When you use it:
<button className={classes.buttonActiveDisabled}>Active Disabled Button</button>
<button className={classes.buttonDisabled}>Disabled Button with active state</button>
It renders to:
<button class="button-123456 buttonActive-123456">Active Disabled Button</button>
<button class="buttonDisabled-123456 button-123456 active-123456 disabled-123456">Disabled Button with active state</button>
Mix global and local classes.
You can compose both local and global classes at the same time.
const styles = {
active: {
color: 'red'
},
button: {
composes: ['$active', 'btn', 'btn-primary'],
color: 'blue'
}
}
Compiles to:
.active-123456 {
color: red;
}
.button-123456 {
color: blue;
}
When you use it:
<button className={classes.button}>Button</button>
It renders to:
<button class="button-123456 active-123456 btn btn-primary">Button</button>
Caveats
- Doesn't work within global Style Sheets.
- Does not work inside of nested rules.
- When composing local rules, they need to be defined first. Otherwise you get wrong css selector order and specificity.
Issues
File a bug against cssinjs/jss prefixed with [jss-compose].
Run tests
npm i
npm test
License
MIT