2022-11-03 18:09:54 +01:00
|
|
|
import React from 'react';
|
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
import classnames from 'classnames';
|
|
|
|
import {
|
2023-06-26 21:59:04 +02:00
|
|
|
FontWeight,
|
2023-02-02 21:15:26 +01:00
|
|
|
TextVariant,
|
2023-06-26 21:59:04 +02:00
|
|
|
Display,
|
2023-02-02 21:15:26 +01:00
|
|
|
AlignItems,
|
2022-11-03 18:09:54 +01:00
|
|
|
} from '../../../helpers/constants/design-system';
|
2023-06-26 21:59:04 +02:00
|
|
|
import { Text } from '../text';
|
2022-11-03 18:09:54 +01:00
|
|
|
|
2023-03-17 18:24:07 +01:00
|
|
|
export const Label = ({ htmlFor, className, children, ...props }) => (
|
2022-11-03 18:09:54 +01:00
|
|
|
<Text
|
|
|
|
className={classnames(
|
|
|
|
'mm-label',
|
2023-02-15 15:29:26 +01:00
|
|
|
{ 'mm-label--html-for': htmlFor },
|
2022-11-03 18:09:54 +01:00
|
|
|
className,
|
|
|
|
)}
|
2022-11-29 22:01:05 +01:00
|
|
|
as="label"
|
|
|
|
htmlFor={htmlFor}
|
2023-02-02 21:15:26 +01:00
|
|
|
variant={TextVariant.bodyMd}
|
2023-06-26 21:59:04 +02:00
|
|
|
fontWeight={FontWeight.Medium}
|
|
|
|
display={Display.InlineFlex}
|
2023-02-02 21:15:26 +01:00
|
|
|
alignItems={AlignItems.center}
|
2022-11-03 18:09:54 +01:00
|
|
|
{...props}
|
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</Text>
|
|
|
|
);
|
|
|
|
|
|
|
|
Label.propTypes = {
|
|
|
|
/**
|
|
|
|
* The content of the label
|
|
|
|
*/
|
|
|
|
children: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),
|
|
|
|
/**
|
|
|
|
* The id of the input associated with the label
|
|
|
|
*/
|
|
|
|
htmlFor: PropTypes.string,
|
|
|
|
/**
|
|
|
|
* Additional classNames to be added to the label component
|
|
|
|
*/
|
|
|
|
className: PropTypes.string,
|
|
|
|
};
|