UNPKG

1.5 kBJavaScriptView Raw
1import _extends from "@babel/runtime/helpers/esm/extends";
2import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
3var _excluded = ["className", "bsPrefix", "as"];
4import classNames from 'classnames';
5import camelize from 'dom-helpers/camelize';
6import React from 'react';
7import { useBootstrapPrefix } from './ThemeProvider';
8
9var pascalCase = function pascalCase(str) {
10 return str[0].toUpperCase() + camelize(str).slice(1);
11};
12
13// TODO: emstricten & fix the typing here! `createWithBsPrefix<TElementType>...`
14export default function createWithBsPrefix(prefix, _temp) {
15 var _ref = _temp === void 0 ? {} : _temp,
16 _ref$displayName = _ref.displayName,
17 displayName = _ref$displayName === void 0 ? pascalCase(prefix) : _ref$displayName,
18 Component = _ref.Component,
19 defaultProps = _ref.defaultProps;
20
21 var BsComponent = /*#__PURE__*/React.forwardRef(function (_ref2, ref) {
22 var className = _ref2.className,
23 bsPrefix = _ref2.bsPrefix,
24 _ref2$as = _ref2.as,
25 Tag = _ref2$as === void 0 ? Component || 'div' : _ref2$as,
26 props = _objectWithoutPropertiesLoose(_ref2, _excluded);
27
28 var resolvedPrefix = useBootstrapPrefix(bsPrefix, prefix);
29 return /*#__PURE__*/React.createElement(Tag, _extends({
30 ref: ref,
31 className: classNames(className, resolvedPrefix)
32 }, props));
33 });
34 BsComponent.defaultProps = defaultProps;
35 BsComponent.displayName = displayName;
36 return BsComponent;
37}
\No newline at end of file