@mskcc/carbon-react
Version:
Carbon react components for the MSKCC DSM
134 lines (125 loc) • 5.21 kB
JavaScript
/**
* MSKCC 2021, 2024
*/
;
Object.defineProperty(exports, '__esModule', { value: true });
var _rollupPluginBabelHelpers = require('../../_virtual/_rollupPluginBabelHelpers.js');
var PropTypes = require('prop-types');
var React = require('react');
var cx = require('classnames');
var usePrefix = require('../../internal/usePrefix.js');
var setupGetInstanceId = require('../../tools/setupGetInstanceId.js');
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
var cx__default = /*#__PURE__*/_interopDefaultLegacy(cx);
const getInstanceId = setupGetInstanceId["default"]();
function CheckboxGroup(_ref) {
let {
children,
className,
helperText,
invalid,
invalidText,
legendId,
legendText,
orientation,
readOnly,
size = 'default',
warn,
warnText,
disableFocus,
...rest
} = _ref;
const prefix = usePrefix.usePrefix();
const showWarning = !readOnly && !invalid && warn;
const showHelper = !invalid && !warn;
const checkboxGroupInstanceId = getInstanceId();
const helperId = !helperText ? undefined : `checkbox-group-helper-text-${checkboxGroupInstanceId}`;
const helper = helperText ? /*#__PURE__*/React__default["default"].createElement("div", {
id: helperId,
className: `${prefix}--form__helper-text`
}, helperText) : null;
const fieldsetClasses = cx__default["default"](`${prefix}--fieldset ${prefix}--checkbox-group`, className, {
[`${prefix}--checkbox-group--readonly`]: readOnly,
[`${prefix}--checkbox-group--invalid`]: !readOnly && invalid,
[`${prefix}--checkbox-group--warning`]: showWarning,
[`msk-checkbox-group-horizontal`]: orientation === 'horizontal',
[`msk-checkbox-group-md`]: size === 'md',
[`msk-checkbox-group-lg`]: size === 'lg',
'msk-checkbox-group--disable-focus': disableFocus
});
return /*#__PURE__*/React__default["default"].createElement("fieldset", _rollupPluginBabelHelpers["extends"]({
className: fieldsetClasses,
"data-invalid": invalid ? true : undefined,
"aria-labelledby": rest['aria-labelledby'] || legendId,
"aria-readonly": readOnly,
"aria-describedby": !invalid && !warn && helper ? helperId : undefined
}, rest), /*#__PURE__*/React__default["default"].createElement("legend", {
className: `${prefix}--label`,
id: legendId || rest['aria-labelledby']
}, legendText), children, /*#__PURE__*/React__default["default"].createElement("div", {
className: `${prefix}--checkbox-group__validation-msg`
}, !readOnly && invalid && /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, /*#__PURE__*/React__default["default"].createElement("span", {
className: `${prefix}--checkbox__invalid-icon msk-icon`
}, "error"), /*#__PURE__*/React__default["default"].createElement("div", {
className: `${prefix}--form-requirement`
}, invalidText)), showWarning && /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, /*#__PURE__*/React__default["default"].createElement("span", {
className: `${prefix}--checkbox__invalid-icon ${prefix}--checkbox__invalid-icon--warning msk-icon`
}, "warning"), /*#__PURE__*/React__default["default"].createElement("div", {
className: `${prefix}--form-requirement`
}, warnText))), showHelper && helper);
}
CheckboxGroup.propTypes = {
/**
* Provide the children form elements to be rendered inside of the `<fieldset>`
*/
children: PropTypes__default["default"].node,
/**
* Provide a custom className to be applied to the containing `<fieldset>` node
*/
className: PropTypes__default["default"].string,
/**
* Specify whether the form group is currently in warning state
*/
// warn: PropTypes.bool,
/**
* Provide the text that is displayed when the form group is in warning state
*/
// warnText: PropTypes.node,
disableFocus: PropTypes__default["default"].bool,
/**
* Provide text for the form group for additional help
*/
helperText: PropTypes__default["default"].node,
/**
* Specify whether the form group is currently invalid
*/
invalid: PropTypes__default["default"].bool,
/**
* Provide the text that is displayed when the form group is in an invalid state
*/
invalidText: PropTypes__default["default"].node,
/**
* Provide id for the fieldset <legend> which corresponds to the fieldset
* `aria-labelledby`
*/
legendId: PropTypes__default["default"].node,
/**
* Provide the text to be rendered inside of the fieldset `<legend>`
*/
legendText: PropTypes__default["default"].node.isRequired,
/**
* Specify the orientation of them items
*/
orientation: PropTypes__default["default"].oneOf(['horizontal', 'vertical']),
/**
* Whether the CheckboxGroup should be read-only
*/
readOnly: PropTypes__default["default"].bool,
/**
* Set the size of the checkbox
*/
size: PropTypes__default["default"].oneOf(['default', 'md', 'lg'])
};
exports["default"] = CheckboxGroup;