wetrade-design
Version:
一款多语言支持Vue3的UI框架
65 lines • 2.1 kB
JavaScript
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
import { createVNode as _createVNode } from "vue";
import { computed, defineComponent } from 'vue';
import { flattenChildren } from '../_util/props-util';
import useConfigInject from '../_util/hooks/useConfigInject';
import UnreachableException from '../_util/unreachableException';
export var buttonGroupProps = function buttonGroupProps() {
return {
prefixCls: String,
size: {
type: String
}
};
};
export default defineComponent({
compatConfig: {
MODE: 3
},
name: 'AButtonGroup',
props: buttonGroupProps(),
setup: function setup(props, _ref) {
var slots = _ref.slots;
var _useConfigInject = useConfigInject('btn-group', props),
prefixCls = _useConfigInject.prefixCls,
direction = _useConfigInject.direction;
var classes = computed(function () {
var _ref2;
var size = props.size;
// large => lg
// small => sm
var sizeCls = '';
switch (size) {
case 'large':
// 40px
sizeCls = 'lg';
break;
case 'big':
// 36px
sizeCls = 'bg';
break;
case 'middle': // 32px
case undefined:
break;
case 'small':
// 28px
sizeCls = 'sm';
break;
case 'extra-small':
// 24px
sizeCls = 'xs';
break;
default:
// eslint-disable-next-line no-console
console.warn(new UnreachableException(size).error);
}
return _ref2 = {}, _defineProperty(_ref2, "".concat(prefixCls.value), true), _defineProperty(_ref2, "".concat(prefixCls.value, "-").concat(sizeCls), sizeCls), _defineProperty(_ref2, "".concat(prefixCls.value, "-rtl"), direction.value === 'rtl'), _ref2;
});
return function () {
var _slots$default;
return _createVNode("div", {
"class": classes.value
}, [flattenChildren((_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots))]);
};
}
});