UNPKG

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