Utility to build BEM class names for React components.
import React from 'react';
import {cx, ClassNames} from 'bluecore-classnames';
@ClassNames
class MyComponent extends React.Component {
constructor(props) {
super(props);
this.state = {hovered: true};
}
render() {
return (
<div className={cx('base')}>
<div className={cx('inner')}>
<div className={cx('first', ['active'])}>
<div className>={cx('second', {hovered: this.state.hovered})}</div>
</div>
</div>
);
}
}
export default MyComponent
Will be transformed into
div className: 'base',
div className: 'base_inner',
div className: 'base_inner_first base_inner_first--active'
div className: 'base_inner_second base_inner_second--hovered'
It can be very helpfull if you're using less or sass.
!!! To use es6 decorators you need to compile your code with babel compiler with stage-1 preset enabled.
Just apply ClassNames
decorator to your React class.
ClassNames
decorator accept className in format
className: ?<String>, additional className
element: <String>, name of your element
modifiers: ?<[String] || Object>, where object key is modifier name
cx
has the following declaration:
cx(element: <String>, modifiers: ?<Array, Object>)
Also you can set default values for compiler:
import {Compiler} from 'bluecore-classnames';
Compiler.setDefaults({
isStrict: false,
elementDelimeter: '-',
modifierDelimeter: '__'
});
If decorator found className
s with <string>
type it treats them as usual classNames.
import {Compiler} from 'bluecore-classnames';
Compiler.setDefaults({isStrict: false});
will make compiler to treat string classNames as element, so code below will work too:
<div className={'base'}>
<div className={'inner'}>
<div className={cx('first', ['active'])}>
<div className>={cx('second', {hovered: this.state.hovered})}</div>
</div>
</div>
or you can pass config directly to decorator:
@ClassNames({isStrict: false})
class MyComponent extends React.Component {
...
}