react-bootstrap-v5
Version:
Bootstrap 4 components built with React
53 lines (47 loc) • 1.81 kB
JavaScript
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
import _extends from "@babel/runtime/helpers/esm/extends";
import classNames from 'classnames';
import React from 'react';
import createWithBsPrefix from './createWithBsPrefix';
import { useBootstrapPrefix } from './ThemeProvider';
import FormCheckInput from './FormCheckInput';
var InputGroupText = createWithBsPrefix('input-group-text', {
Component: 'span'
});
var InputGroupCheckbox = function InputGroupCheckbox(props) {
return /*#__PURE__*/React.createElement(InputGroupText, null, /*#__PURE__*/React.createElement(FormCheckInput, _extends({
type: "checkbox"
}, props)));
};
var InputGroupRadio = function InputGroupRadio(props) {
return /*#__PURE__*/React.createElement(InputGroupText, null, /*#__PURE__*/React.createElement(FormCheckInput, _extends({
type: "radio"
}, props)));
};
/**
*
* @property {InputGroupText} Text
* @property {InputGroupRadio} Radio
* @property {InputGroupCheckbox} Checkbox
*/
var InputGroup = React.forwardRef(function (_ref, ref) {
var bsPrefix = _ref.bsPrefix,
size = _ref.size,
className = _ref.className,
_ref$as = _ref.as,
Component = _ref$as === void 0 ? 'div' : _ref$as,
props = _objectWithoutPropertiesLoose(_ref, ["bsPrefix", "size", "className", "as"]);
bsPrefix = useBootstrapPrefix(bsPrefix, 'input-group');
return /*#__PURE__*/React.createElement(Component, _extends({
ref: ref
}, props, {
className: classNames(className, bsPrefix, size && bsPrefix + "-" + size)
}));
});
InputGroup.displayName = 'InputGroup';
var InputGroupWithExtras = _extends({}, InputGroup, {
Text: InputGroupText,
Radio: InputGroupRadio,
Checkbox: InputGroupCheckbox
});
export default InputGroupWithExtras;