box-ui-elements-mlh
Version:
66 lines (59 loc) • 3.45 kB
JavaScript
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
import * as React from 'react';
import uniqueId from 'lodash/uniqueId';
import classNames from 'classnames';
import CheckboxTooltip from './CheckboxTooltip';
import './Checkbox.scss';
var Checkbox = function Checkbox(_ref) {
var _ref$className = _ref.className,
className = _ref$className === void 0 ? '' : _ref$className,
description = _ref.description,
fieldLabel = _ref.fieldLabel,
hideLabel = _ref.hideLabel,
id = _ref.id,
isChecked = _ref.isChecked,
isDisabled = _ref.isDisabled,
label = _ref.label,
name = _ref.name,
onChange = _ref.onChange,
subsection = _ref.subsection,
tooltip = _ref.tooltip,
rest = _objectWithoutProperties(_ref, ["className", "description", "fieldLabel", "hideLabel", "id", "isChecked", "isDisabled", "label", "name", "onChange", "subsection", "tooltip"]);
var generatedID = React.useRef(uniqueId('checkbox')).current; // use passed-in ID from props; otherwise generate one
var inputID = id || generatedID;
var checkboxAndLabel = /*#__PURE__*/React.createElement("span", {
className: "checkbox-label"
}, /*#__PURE__*/React.createElement("input", _extends({
checked: isChecked,
disabled: isDisabled,
id: inputID,
name: name,
onChange: onChange,
type: "checkbox"
}, rest)), /*#__PURE__*/React.createElement("span", {
className: "checkbox-pointer-target"
}), /*#__PURE__*/React.createElement("span", {
className: classNames('bdl-Checkbox-labelTooltipWrapper', {
'accessibility-hidden': hideLabel
})
}, /*#__PURE__*/React.createElement("label", {
htmlFor: inputID
}, label), tooltip && /*#__PURE__*/React.createElement(CheckboxTooltip, {
tooltip: tooltip
})));
return /*#__PURE__*/React.createElement("div", {
className: classNames('checkbox-container', className, {
'is-disabled bdl-is-disabled': isDisabled
})
}, fieldLabel && /*#__PURE__*/React.createElement("div", {
className: "label"
}, fieldLabel), checkboxAndLabel, description ? /*#__PURE__*/React.createElement("div", {
className: "checkbox-description"
}, description) : null, subsection ? /*#__PURE__*/React.createElement("div", {
className: "checkbox-subsection"
}, subsection) : null);
};
export default Checkbox;
//# sourceMappingURL=Checkbox.js.map