@prometheusresearch/react-stylesheet
v0.3.2
Published
React components with predefined styles
Downloads
32
Readme
React Stylesheet
React Stylesheet is a way to style React components with... React components!
Installation
% npm install @prometheusresearch/react-stylesheet
Basic usage
The idea is that component should define a stylesheet to render its UI with.
A stylesheet is just a collection of React components. You ask what React Stylesheet does for you then? It allows to define styled DOM components with an easy API:
import React from 'react'
import {createStylesheet} from '@prometheusresearch/react-stylesheet'
let stylesheet = createStylesheet({
Root: { // generates <button /> with CSS class applied
Component: 'button',
fontSize: '12pt'
},
Caption: { // generates <button /> with CSS class applied
Component: 'div',
fontWeight: 'bold',
hover: { // yes, pseudo classes are supported
color: 'red'
}
}
})
Now we can define our component in terms of the stylesheet:
class Button extends React.Component {
render() {
let {caption} = this.props
let {Root, Icon} = stylesheet
return (
<Root>
<Caption>{caption}</Caption>
</Root>
)
}
}
Stylable composite components
Sometimes you want to define a reusable component which you would want to style later using different stylesheets.
You can define an initial stylesheet which does nothing but renders base DOM components and then override that:
import React from 'react'
import {attachStylesheet} from '@prometheusresearch/react-stylesheet'
import Icon from 'react-fa'
let stylesheet = {
Root: 'button',
Icon: Icon,
};
@attachStylesheet(stylesheet)
class Button extends React.Component {
render() {
let {caption, icon} = this.props
let {Root, Icon} = this.props.stylesheet
return (
<Root>
<Icon name={icon} />
{caption}
</Root>
)
}
}
What we did here is:
We use
attachStylesheet
higher order component to attach an initial stylesheet to a composite component.We use
stylesheet
prop passed to component to render component's UI.
Now the only part left is to produce a version of <Button />
with different
styling. We use styleComponent(Component, stylesheet)
function for that:
import {styleComponent} from '@prometheusresearch/react-stylesheet'
let SuccessButton = styleComponent(Button, {
Root: {
color: 'white',
backgroundColor: 'green',
hover: {
color: 'red'
}
},
Icon() {
return <Icon name="ok" />
}
})
We pass styleComponent()
a stylesheet which is merged into the original one:
If you pass a component (
Icon
in the example above) it is used instead of the original one.If you pass an object:
If it overrides DOM component in the original stylesheet, then the object is treated as a set of CSS styles. It's compiled to CSS class and a new styled DOM component wrapper is generated with the CSS class attached.
If it overrides composite component in the original stylesheet, then it's being used to style this component with recursive
styleComponent
function call.
The last point allows to style component hierarchies with easy:
let StyledForm = styleComponent(Form, {
Root: {
...
},
// this is the same as calling styleComponent(SubmitButton, { ... })
SubmitButton: {
Root: {
...
},
Icon: {
...
}
}
})
Styled DOM components
You can also produce styled DOM components with styleComponent
function:
import {styleComponent} from '@prometheusresearch/react-stylesheet'
let StyledDiv = styleComponent('div', {
color: 'red'
})
React.render(<StyledDiv />, ...)
That results in:
<style>
.autogenerated_class_name {
color: red;
}
</style>
...
<div class="autogenerated_class_name" />
The <style>
element is attached only at least one of the corresponding styled
DOM components are mounted into the DOM.
States for styled DOM components
Styled DOM components are allowed to have states:
import {styleComponent} from '@prometheusresearch/react-stylesheet'
let StyledDiv = styleComponent('div', {
color: 'red',
hover: {
color: 'black'
},
customState: {
backgroundColor: 'red'
}
})
States like hover
, active
, ... are compiled into pseudoclasses and into
regular classes as well.
You can toggle states by passing state names as keys to state
prop of styled
DOM components:
<StyledDiv state={{hover: false, active: true}} />
Helpers for DOM stylesheets
React Stylesheet provides helpers to define DOM stylesheets:
import {styleComponent} from '@prometheusresearch/react-stylesheet'
import {rgba, padding, none} from '@prometheusresearch/react-stylesheet/css'
let Warning = styleComponent('div', {
color: rgba(245, 123, 12),
padding: padding(10, 20),
textDecoration: none,
})
Credits
React Stylesheet is free software created by Prometheus Research and is released under the MIT license.