286b51008c
• Added: - aria-label to Heading component
80 lines
1.7 KiB
JavaScript
80 lines
1.7 KiB
JavaScript
import classNames from 'classnames/bind'
|
|
|
|
// Bind CSS Modules global variable `_s` to classNames module
|
|
const cx = classNames.bind(_s)
|
|
|
|
// Define sizes for enumeration for Heading component `size` prop
|
|
const SIZES = {
|
|
h1: 'h1',
|
|
h2: 'h2',
|
|
h3: 'h3',
|
|
h4: 'h4',
|
|
h5: 'h5',
|
|
h6: 'h6',
|
|
}
|
|
|
|
const ARIA_LEVELS = {
|
|
h1: '1',
|
|
h2: '2',
|
|
h3: '3',
|
|
h4: '4',
|
|
h5: '5',
|
|
h6: '6',
|
|
}
|
|
|
|
/**
|
|
* Renders an H-tag
|
|
* @param {bool} [props.isCentered] - if text is centered within the element
|
|
* @param {string} [props.size='h1'] - the size of the heading
|
|
*/
|
|
export default class Heading extends PureComponent {
|
|
|
|
static propTypes = {
|
|
children: PropTypes.any,
|
|
isCentered: PropTypes.bool,
|
|
size: PropTypes.oneOf(Object.keys(SIZES)),
|
|
}
|
|
|
|
static defaultProps = {
|
|
size: SIZES.h1,
|
|
}
|
|
|
|
render() {
|
|
const { children, size, isCentered } = this.props
|
|
|
|
// Each size has it's own custom style
|
|
const classes = cx({
|
|
default: 1,
|
|
text: 1,
|
|
textAlignCenter: isCentered,
|
|
|
|
colorPrimary: [SIZES.h1, SIZES.h2].indexOf(size) > -1,
|
|
colorSecondary: [SIZES.h3, SIZES.h4, SIZES.h5].indexOf(size) > -1,
|
|
|
|
fs24PX: size === SIZES.h1,
|
|
fs19PX: size === SIZES.h2,
|
|
fs16PX: size === SIZES.h3,
|
|
fs13PX: size === SIZES.h4,
|
|
fs12PX: size === SIZES.h5,
|
|
|
|
mt5: [SIZES.h4].indexOf(size) > -1,
|
|
|
|
lineHeight2: size === SIZES.h5,
|
|
py2: size === SIZES.h5,
|
|
|
|
fontWeightMedium: [SIZES.h1, SIZES.h3, SIZES.h5].indexOf(size) > -1,
|
|
fontWeightBold: [SIZES.h2, SIZES.h4].indexOf(size) > -1,
|
|
})
|
|
|
|
return React.createElement(
|
|
size,
|
|
{
|
|
className: classes,
|
|
role: 'heading',
|
|
'aria-level': ARIA_LEVELS[size],
|
|
},
|
|
children,
|
|
)
|
|
}
|
|
|
|
} |