UNPKG

box-ui-elements-mlh

Version:
66 lines (59 loc) 3.45 kB
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