button-group.js 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  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 = void 0;
  7. var _vue = require("vue");
  8. var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
  9. var _propsUtil = require("../_util/props-util");
  10. var _useConfigInject2 = _interopRequireDefault(require("../_util/hooks/useConfigInject"));
  11. var _unreachableException = _interopRequireDefault(require("../_util/unreachableException"));
  12. var buttonGroupProps = function buttonGroupProps() {
  13. return {
  14. prefixCls: String,
  15. size: {
  16. type: String
  17. }
  18. };
  19. };
  20. exports.buttonGroupProps = buttonGroupProps;
  21. var _default = (0, _vue.defineComponent)({
  22. compatConfig: {
  23. MODE: 3
  24. },
  25. name: 'AButtonGroup',
  26. props: buttonGroupProps(),
  27. setup: function setup(props, _ref) {
  28. var slots = _ref.slots;
  29. var _useConfigInject = (0, _useConfigInject2.default)('btn-group', props),
  30. prefixCls = _useConfigInject.prefixCls,
  31. direction = _useConfigInject.direction;
  32. var classes = (0, _vue.computed)(function () {
  33. var _ref2;
  34. var size = props.size;
  35. // large => lg
  36. // small => sm
  37. var sizeCls = '';
  38. switch (size) {
  39. case 'large':
  40. sizeCls = 'lg';
  41. break;
  42. case 'small':
  43. sizeCls = 'sm';
  44. break;
  45. case 'middle':
  46. case undefined:
  47. break;
  48. default:
  49. // eslint-disable-next-line no-console
  50. console.warn(new _unreachableException.default(size).error);
  51. }
  52. return _ref2 = {}, (0, _defineProperty2.default)(_ref2, "".concat(prefixCls.value), true), (0, _defineProperty2.default)(_ref2, "".concat(prefixCls.value, "-").concat(sizeCls), sizeCls), (0, _defineProperty2.default)(_ref2, "".concat(prefixCls.value, "-rtl"), direction.value === 'rtl'), _ref2;
  53. });
  54. return function () {
  55. var _slots$default;
  56. return (0, _vue.createVNode)("div", {
  57. "class": classes.value
  58. }, [(0, _propsUtil.flattenChildren)((_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots))]);
  59. };
  60. }
  61. });
  62. exports.default = _default;