import { computed, h, inject } from 'vue'; import type { SizeType } from '../context'; import { defaultConfigProvider, configProviderKey } from '../context'; import { useInjectDisabled } from '../DisabledContext'; import { DefaultRenderEmpty } from '../renderEmpty'; import { useInjectSize } from '../SizeContext'; export default (name: string, props: Record) => { const sizeContext = useInjectSize(); const disabledContext = useInjectDisabled(); const configProvider = inject(configProviderKey, { ...defaultConfigProvider, renderEmpty: (name?: string) => h(DefaultRenderEmpty, { componentName: name }), }); const prefixCls = computed(() => configProvider.getPrefixCls(name, props.prefixCls)); const direction = computed(() => props.direction ?? configProvider.direction?.value); const iconPrefixCls = computed(() => props.iconPrefixCls ?? configProvider.iconPrefixCls.value); const rootPrefixCls = computed(() => configProvider.getPrefixCls()); const autoInsertSpaceInButton = computed(() => configProvider.autoInsertSpaceInButton?.value); const renderEmpty = configProvider.renderEmpty; const space = configProvider.space; const pageHeader = configProvider.pageHeader; const form = configProvider.form; const getTargetContainer = computed( () => props.getTargetContainer ?? configProvider.getTargetContainer?.value, ); const getPopupContainer = computed( () => props.getPopupContainer ?? configProvider.getPopupContainer?.value, ); const dropdownMatchSelectWidth = computed( () => props.dropdownMatchSelectWidth ?? configProvider.dropdownMatchSelectWidth?.value, ); const virtual = computed( () => (props.virtual === undefined ? configProvider.virtual?.value !== false : props.virtual !== false) && dropdownMatchSelectWidth.value !== false, ); const size = computed(() => (props.size as SizeType) || sizeContext.value); const autocomplete = computed( () => props.autocomplete ?? configProvider.input?.value?.autocomplete, ); const disabled = computed(() => props.disabled ?? disabledContext.value); const csp = computed(() => props.csp ?? configProvider.csp); return { configProvider, prefixCls, direction, size, getTargetContainer, getPopupContainer, space, pageHeader, form, autoInsertSpaceInButton, renderEmpty, virtual, dropdownMatchSelectWidth, rootPrefixCls, getPrefixCls: configProvider.getPrefixCls, autocomplete, csp, iconPrefixCls, disabled, select: configProvider.select, }; };