fomantic-ui-react
Version:
Fomantic-UI React -- A React Component Library.
89 lines (74 loc) • 3.52 kB
JavaScript
/**
* fomantic-ui-react v0.0.1-alpha.10
* (c) 2022 FireLoong <fireloong@foxmail.com>
* @license MIT
*/
;
Object.defineProperty(exports, '__esModule', { value: true });
var defineProperty = require('../_chunks/dep-6ab59a61.js');
var slicedToArray = require('../_chunks/dep-640599ea.js');
var objectWithoutProperties = require('../_chunks/dep-03754121.js');
var classNames = require('classnames');
var React = require('react');
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
var classNames__default = /*#__PURE__*/_interopDefaultLegacy(classNames);
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
var _excluded = ["as", "name", "label", "radio", "checked", "slider", "toggle", "readOnly", "disabled", "fitted", "right", "className"];
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { defineProperty._defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
var Checkbox = function Checkbox(_ref) {
var _ref$as = _ref.as,
as = _ref$as === void 0 ? "div" : _ref$as,
name = _ref.name,
label = _ref.label,
radio = _ref.radio,
checked = _ref.checked,
slider = _ref.slider,
toggle = _ref.toggle,
readOnly = _ref.readOnly,
disabled = _ref.disabled,
fitted = _ref.fitted,
right = _ref.right,
className = _ref.className,
props = objectWithoutProperties._objectWithoutProperties(_ref, _excluded);
var _useState = React.useState(checked),
_useState2 = slicedToArray._slicedToArray(_useState, 2),
isChecked = _useState2[0],
setIsChecked = _useState2[1];
if (!as) {
as = "div";
}
var children = /* @__PURE__ */React__default["default"].createElement(React__default["default"].Fragment, null, /* @__PURE__ */React__default["default"].createElement("input", {
type: radio ? "radio" : "checkbox",
className: "hidden",
name: name,
tabIndex: 0,
checked: isChecked,
disabled: disabled
}), /* @__PURE__ */React__default["default"].createElement("label", null, label));
return /*#__PURE__*/React.createElement(as, _objectSpread({
className: classNames__default["default"]("ui", {
radio: radio,
slider: slider,
toggle: toggle,
"read-only": readOnly,
disabled: disabled,
fitted: fitted,
"right aligned": right
}, "checkbox", {
checked: isChecked
}, className),
onClick: function onClick(e) {
if (!readOnly && !disabled) {
if (radio) {
setIsChecked(true);
} else {
setIsChecked(!isChecked);
}
}
}
}, props), children);
};
Checkbox.displayName = "Checkbox";
exports["default"] = Checkbox;
//# sourceMappingURL=Checkbox.js.map