button-group.js 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. "use strict";
  2. "use client";
  3. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
  4. var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
  5. Object.defineProperty(exports, "__esModule", {
  6. value: true
  7. });
  8. exports.default = exports.GroupSizeContext = void 0;
  9. var React = _interopRequireWildcard(require("react"));
  10. var _classnames = _interopRequireDefault(require("classnames"));
  11. var _warning = require("../_util/warning");
  12. var _configProvider = require("../config-provider");
  13. var _internal = require("../theme/internal");
  14. var __rest = void 0 && (void 0).__rest || function (s, e) {
  15. var t = {};
  16. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  17. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  18. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  19. }
  20. return t;
  21. };
  22. const GroupSizeContext = exports.GroupSizeContext = /*#__PURE__*/React.createContext(undefined);
  23. const ButtonGroup = props => {
  24. const {
  25. getPrefixCls,
  26. direction
  27. } = React.useContext(_configProvider.ConfigContext);
  28. const {
  29. prefixCls: customizePrefixCls,
  30. size,
  31. className
  32. } = props,
  33. others = __rest(props, ["prefixCls", "size", "className"]);
  34. const prefixCls = getPrefixCls('btn-group', customizePrefixCls);
  35. const [,, hashId] = (0, _internal.useToken)();
  36. const sizeCls = React.useMemo(() => {
  37. switch (size) {
  38. case 'large':
  39. return 'lg';
  40. case 'small':
  41. return 'sm';
  42. default:
  43. return '';
  44. }
  45. }, [size]);
  46. if (process.env.NODE_ENV !== 'production') {
  47. const warning = (0, _warning.devUseWarning)('Button.Group');
  48. warning.deprecated(false, 'Button.Group', 'Space.Compact');
  49. process.env.NODE_ENV !== "production" ? warning(!size || ['large', 'small', 'middle'].includes(size), 'usage', 'Invalid prop `size`.') : void 0;
  50. }
  51. const classes = (0, _classnames.default)(prefixCls, {
  52. [`${prefixCls}-${sizeCls}`]: sizeCls,
  53. [`${prefixCls}-rtl`]: direction === 'rtl'
  54. }, className, hashId);
  55. return /*#__PURE__*/React.createElement(GroupSizeContext.Provider, {
  56. value: size
  57. }, /*#__PURE__*/React.createElement("div", Object.assign({}, others, {
  58. className: classes
  59. })));
  60. };
  61. var _default = exports.default = ButtonGroup;