Dashboard sipadu mbip
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

createWithBsPrefix.js 1.5KB

12345678910111213141516171819202122232425262728293031323334353637
  1. import _extends from "@babel/runtime/helpers/esm/extends";
  2. import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
  3. import classNames from 'classnames';
  4. import React from 'react';
  5. import camelize from 'dom-helpers/util/camelize';
  6. import { useBootstrapPrefix } from '../ThemeProvider';
  7. var pascalCase = function pascalCase(str) {
  8. return str[0].toUpperCase() + camelize(str).slice(1);
  9. };
  10. export default function createWithBsPrefix(prefix, _temp) {
  11. var _ref = _temp === void 0 ? {} : _temp,
  12. _ref$displayName = _ref.displayName,
  13. displayName = _ref$displayName === void 0 ? pascalCase(prefix) : _ref$displayName,
  14. _ref$Component = _ref.Component,
  15. Component = _ref$Component === void 0 ? 'div' : _ref$Component,
  16. defaultProps = _ref.defaultProps;
  17. var BsComponent = React.forwardRef( // eslint-disable-next-line react/prop-types
  18. function (_ref2, ref) {
  19. var className = _ref2.className,
  20. bsPrefix = _ref2.bsPrefix,
  21. _ref2$as = _ref2.as,
  22. Tag = _ref2$as === void 0 ? Component : _ref2$as,
  23. props = _objectWithoutPropertiesLoose(_ref2, ["className", "bsPrefix", "as"]);
  24. var resolvedPrefix = useBootstrapPrefix(bsPrefix, prefix);
  25. return React.createElement(Tag, _extends({
  26. ref: ref,
  27. className: classNames(className, resolvedPrefix)
  28. }, props));
  29. });
  30. BsComponent.defaultProps = defaultProps;
  31. BsComponent.displayName = displayName;
  32. return BsComponent;
  33. }