import { defineComponent } from 'vue'; import { flattenChildren } from '../_util/props-util'; import PropTypes from '../_util/vue-types'; import useConfigInject from '../_util/hooks/useConfigInject'; import type { ExtractPropTypes, PropType } from 'vue'; import type { SizeType } from '../config-provider'; const buttonGroupProps = { prefixCls: PropTypes.string, size: { type: String as PropType, }, }; export { buttonGroupProps }; export type ButtonGroupProps = Partial>; export default defineComponent({ name: 'AButtonGroup', props: buttonGroupProps, setup(props, { slots }) { const { prefixCls, direction } = useConfigInject('btn-group', props); return () => { const { size } = props; // large => lg // small => sm let sizeCls = ''; switch (size) { case 'large': sizeCls = 'lg'; break; case 'small': sizeCls = 'sm'; break; default: break; } const classes = { [`${prefixCls.value}`]: true, [`${prefixCls.value}-${sizeCls}`]: sizeCls, [`${prefixCls.value}-rtl`]: direction.value === 'rtl', }; return
{flattenChildren(slots.default?.())}
; }; }, });