Package Exports
- radium
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (radium) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
Radium
npm install radiumRadium is a set of tools to manage inline styles on React elements. It gives you powerful styling capabilities without CSS.
Inspired by React: CSS in JS by Christopher Chedeau.
Overview
Eliminating CSS in favor of inline styles that are computed on the fly is a powerful approach, providing a number of benefits over traditional CSS:
- Scoped styles without selectors
- Avoids specificity conflicts
- Source order independence
- Dead code elimination
- Highly expressive
Despite that, there are some common CSS features and techniques that inline styles don't easily accommodate: media queries, browser states (:hover, :focus, :active) and modifiers (no more .btn-primary!). Radium offers a standard interface and abstractions for dealing with these problems.
When we say expressive, we mean it: math, concatenation, regex, conditionals, functions–JavaScript is at your disposal. Modern web applications demand that the display changes when data changes, and Radium is here to help.
Features
- Modifier styles based on component props
- Media queries
- Browser state styles to support
:hover,:focus, and:active - Dynamic computed styles
Docs
Usage
Start by writing a style object with a combination of default styles, browser states, media queries, and modifiers. Pass the object to this.buildStyles() and Radium will determine the correct group of style rules to apply to your component.
<Button kind='primary'>Radium Button</Button>var React = require('react');
var { StyleResolverMixin, BrowserStateMixin } = require('radium');
var color = require('color');
var Button = React.createClass({
mixins: [ StyleResolverMixin, BrowserStateMixin ],
render: function () {
var styles = {
padding: '1.5em 2em',
border: 0,
borderRadius: 4,
color: '#fff',
cursor: 'pointer',
fontSize: 16,
fontWeight: 700,
states: [
{ hover: {
background: color('#0074d9').lighten(0.2).hexString()
}},
{ focus: {
boxShadow: '0 0 0 3px #eee, 0 0 0 6px #0074D9',
outline: 'none'
}}
],
modifiers: [
{ kind: {
primary: { background: '#0074D9' },
warning: { background: '#FF4136' }
}}
]
};
return (
<button
{...this.getBrowserStateEvents()}
style={this.buildStyles(styles)}
>
{this.props.children}
</button>
);
}
});Examples
To see local examples in action, do this:
npm install
npm run examplesContributing
Please see CONTRIBUTING