UNPKG

2.25 kBJavaScriptView Raw
1"use strict";
2
3var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
5var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
7exports.__esModule = true;
8exports.useBootstrapPrefix = useBootstrapPrefix;
9exports.createBootstrapComponent = createBootstrapComponent;
10exports.default = exports.ThemeConsumer = void 0;
11
12var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
14var _forwardRef = _interopRequireDefault(require("@restart/context/forwardRef"));
15
16var _react = _interopRequireWildcard(require("react"));
17
18var ThemeContext = _react.default.createContext({});
19
20var Consumer = ThemeContext.Consumer,
21 Provider = ThemeContext.Provider;
22exports.ThemeConsumer = Consumer;
23
24function ThemeProvider(_ref) {
25 var prefixes = _ref.prefixes,
26 children = _ref.children;
27 var copiedPrefixes = (0, _react.useMemo)(function () {
28 return (0, _extends2.default)({}, prefixes);
29 }, [prefixes]);
30 return _react.default.createElement(Provider, {
31 value: copiedPrefixes
32 }, children);
33}
34
35function useBootstrapPrefix(prefix, defaultPrefix) {
36 var prefixes = (0, _react.useContext)(ThemeContext);
37 return prefix || prefixes[defaultPrefix] || defaultPrefix;
38}
39
40function createBootstrapComponent(Component, opts) {
41 if (typeof opts === 'string') opts = {
42 prefix: opts
43 };
44 var isClassy = Component.prototype && Component.prototype.isReactComponent; // If it's a functional component make sure we don't break it with a ref
45
46 var _opts = opts,
47 prefix = _opts.prefix,
48 _opts$forwardRefAs = _opts.forwardRefAs,
49 forwardRefAs = _opts$forwardRefAs === void 0 ? isClassy ? 'ref' : 'innerRef' : _opts$forwardRefAs;
50 return (0, _forwardRef.default)(function (_ref2, ref) {
51 var props = (0, _extends2.default)({}, _ref2);
52 props[forwardRefAs] = ref; // eslint-disable-next-line react/prop-types
53
54 var bsPrefix = useBootstrapPrefix(props.bsPrefix, prefix);
55 return _react.default.createElement(Component, (0, _extends2.default)({}, props, {
56 bsPrefix: bsPrefix
57 }));
58 }, {
59 displayName: "Bootstrap(" + (Component.displayName || Component.name) + ")"
60 });
61}
62
63var _default = ThemeProvider;
64exports.default = _default;
\No newline at end of file