react-bootstrap-v5
Version:
Bootstrap 4 components built with React
47 lines (34 loc) • 1.74 kB
JavaScript
;
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
exports.__esModule = true;
exports.default = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
var _classnames = _interopRequireDefault(require("classnames"));
var _react = _interopRequireWildcard(require("react"));
var _FormContext = _interopRequireDefault(require("./FormContext"));
var _ThemeProvider = require("./ThemeProvider");
var FormFileInput = _react.default.forwardRef(function (_ref, ref) {
var id = _ref.id,
bsPrefix = _ref.bsPrefix,
className = _ref.className,
isValid = _ref.isValid,
isInvalid = _ref.isInvalid,
_ref$as = _ref.as,
Component = _ref$as === void 0 ? 'input' : _ref$as,
props = (0, _objectWithoutPropertiesLoose2.default)(_ref, ["id", "bsPrefix", "className", "isValid", "isInvalid", "as"]);
var _useContext = (0, _react.useContext)(_FormContext.default),
controlId = _useContext.controlId;
bsPrefix = (0, _ThemeProvider.useBootstrapPrefix)(bsPrefix, 'form-file-input');
return /*#__PURE__*/_react.default.createElement(Component, (0, _extends2.default)({}, props, {
ref: ref,
id: id || controlId,
type: "file",
className: (0, _classnames.default)(className, bsPrefix, isValid && 'is-valid', isInvalid && 'is-invalid')
}));
});
FormFileInput.displayName = 'FormFileInput';
var _default = FormFileInput;
exports.default = _default;
module.exports = exports["default"];