bootstrap-4-react
Version:
Bootstrap 4 React components
27 lines (23 loc) • 709 B
JavaScript
import React, { Component } from 'react';
import { JS } from 'fsts';
import { mergeClassName } from './className.js';
export function withFont() {
return function(Comp) {
return class extends Component {
render() {
const { font, fontWeight } = this.props;
const cn = mergeClassName(
this.props,
[
font? 'font-' + font : '',
fontWeight? 'font-weight-' + fontWeight : ''
]
);
const p = JS.lessProps(this.props, ['className', 'font', 'fontWeight']);
return cn
? <Comp {...p} className={cn}>{this.props.children}</Comp>
: <Comp {...p}>{this.props.children}</Comp>
}
}
}
}