react-bootstrap-v5
Version:
Bootstrap 4 components built with React
51 lines (36 loc) • 2.17 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 _FormFileButton = _interopRequireDefault(require("./FormFileButton"));
var _FormFileText = _interopRequireDefault(require("./FormFileText"));
var _ThemeProvider = require("./ThemeProvider");
var FormFileLabel = _react.default.forwardRef(function (_ref, ref) {
var bsPrefix = _ref.bsPrefix,
className = _ref.className,
htmlFor = _ref.htmlFor,
_ref$label = _ref.label,
label = _ref$label === void 0 ? 'Choose file...' : _ref$label,
_ref$button = _ref.button,
button = _ref$button === void 0 ? 'Browse' : _ref$button,
children = _ref.children,
props = (0, _objectWithoutPropertiesLoose2.default)(_ref, ["bsPrefix", "className", "htmlFor", "label", "button", "children"]);
var _useContext = (0, _react.useContext)(_FormContext.default),
controlId = _useContext.controlId;
bsPrefix = (0, _ThemeProvider.useBootstrapPrefix)(bsPrefix, 'form-file-label');
return /*#__PURE__*/_react.default.createElement("label", (0, _extends2.default)({}, props, {
ref: ref,
htmlFor: htmlFor || controlId,
className: (0, _classnames.default)(className, bsPrefix)
}), children || /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_FormFileText.default, null, label), /*#__PURE__*/_react.default.createElement(_FormFileButton.default, null, button)));
});
FormFileLabel.displayName = 'FormFileLabel';
var _default = FormFileLabel;
exports.default = _default;
module.exports = exports["default"];