react-bootstrap
Version:
Bootstrap 4 components built with React
57 lines (42 loc) • 2.06 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 = /*#__PURE__*/_react.default.forwardRef(function (_ref, ref) {
var id = _ref.id,
bsPrefix = _ref.bsPrefix,
bsCustomPrefix = _ref.bsCustomPrefix,
className = _ref.className,
isValid = _ref.isValid,
isInvalid = _ref.isInvalid,
lang = _ref.lang,
_ref$as = _ref.as,
Component = _ref$as === void 0 ? 'input' : _ref$as,
props = (0, _objectWithoutPropertiesLoose2.default)(_ref, ["id", "bsPrefix", "bsCustomPrefix", "className", "isValid", "isInvalid", "lang", "as"]);
var _useContext = (0, _react.useContext)(_FormContext.default),
controlId = _useContext.controlId,
custom = _useContext.custom;
var type = 'file';
var _ref2 = custom ? [bsCustomPrefix, 'custom-file-input'] : [bsPrefix, 'form-control-file'],
prefix = _ref2[0],
defaultPrefix = _ref2[1];
bsPrefix = (0, _ThemeProvider.useBootstrapPrefix)(prefix, defaultPrefix);
return /*#__PURE__*/_react.default.createElement(Component, (0, _extends2.default)({}, props, {
ref: ref,
id: id || controlId,
type: type,
lang: lang,
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"];
;