import type { PropType } from 'vue'; import { computed, defineComponent } from 'vue'; import type { SizeType } from '../config-provider'; import { FormItemInputContext } from '../form/FormItemContext'; import type { FocusEventHandler, MouseEventHandler } from '../_util/EventInterface'; import useConfigInject from '../config-provider/hooks/useConfigInject'; export default defineComponent({ compatConfig: { MODE: 3 }, name: 'AInputGroup', props: { prefixCls: String, size: { type: String as PropType }, compact: { type: Boolean, default: undefined }, onMouseenter: { type: Function as PropType }, onMouseleave: { type: Function as PropType }, onFocus: { type: Function as PropType }, onBlur: { type: Function as PropType }, }, setup(props, { slots }) { const { prefixCls, direction } = useConfigInject('input-group', props); const formItemInputContext = FormItemInputContext.useInject(); FormItemInputContext.useProvide(formItemInputContext, { isFormItemInput: false, }); const cls = computed(() => { const pre = prefixCls.value; return { [`${pre}`]: true, [`${pre}-lg`]: props.size === 'large', [`${pre}-sm`]: props.size === 'small', [`${pre}-compact`]: props.compact, [`${pre}-rtl`]: direction.value === 'rtl', }; }); return () => { return ( {slots.default?.()} ); }; }, });