button-group.js 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.default = exports.buttonGroupProps = exports.GroupSizeContext = void 0;
  7. var _vue = require("vue");
  8. var _propsUtil = require("../_util/props-util");
  9. var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
  10. var _internal = require("../theme/internal");
  11. var _devWarning = _interopRequireDefault(require("../vc-util/devWarning"));
  12. var _createContext = _interopRequireDefault(require("../_util/createContext"));
  13. const buttonGroupProps = () => ({
  14. prefixCls: String,
  15. size: {
  16. type: String
  17. }
  18. });
  19. exports.buttonGroupProps = buttonGroupProps;
  20. const GroupSizeContext = exports.GroupSizeContext = (0, _createContext.default)();
  21. var _default = exports.default = (0, _vue.defineComponent)({
  22. compatConfig: {
  23. MODE: 3
  24. },
  25. name: 'AButtonGroup',
  26. props: buttonGroupProps(),
  27. setup(props, _ref) {
  28. let {
  29. slots
  30. } = _ref;
  31. const {
  32. prefixCls,
  33. direction
  34. } = (0, _useConfigInject.default)('btn-group', props);
  35. const [,, hashId] = (0, _internal.useToken)();
  36. GroupSizeContext.useProvide((0, _vue.reactive)({
  37. size: (0, _vue.computed)(() => props.size)
  38. }));
  39. const classes = (0, _vue.computed)(() => {
  40. const {
  41. size
  42. } = props;
  43. let sizeCls = '';
  44. switch (size) {
  45. case 'large':
  46. sizeCls = 'lg';
  47. break;
  48. case 'small':
  49. sizeCls = 'sm';
  50. break;
  51. case 'middle':
  52. case undefined:
  53. break;
  54. default:
  55. // eslint-disable-next-line no-console
  56. (0, _devWarning.default)(!size, 'Button.Group', 'Invalid prop `size`.');
  57. }
  58. return {
  59. [`${prefixCls.value}`]: true,
  60. [`${prefixCls.value}-${sizeCls}`]: sizeCls,
  61. [`${prefixCls.value}-rtl`]: direction.value === 'rtl',
  62. [hashId.value]: true
  63. };
  64. });
  65. return () => {
  66. var _a;
  67. return (0, _vue.createVNode)("div", {
  68. "class": classes.value
  69. }, [(0, _propsUtil.flattenChildren)((_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots))]);
  70. };
  71. }
  72. });