ant-design-vue/components/config-provider/hooks/useConfigInject.ts

64 lines
2.4 KiB
TypeScript
Raw Normal View History

2023-02-20 03:04:25 +00:00
import { computed, h, inject } from 'vue';
2023-02-21 15:11:05 +00:00
import type { SizeType } from '../context';
2023-01-27 08:00:17 +00:00
import { defaultConfigProvider, configProviderKey } from '../context';
2023-02-21 15:11:05 +00:00
import { useInjectDisabled } from '../DisabledContext';
2023-02-20 03:04:25 +00:00
import { DefaultRenderEmpty } from '../renderEmpty';
2023-02-21 15:11:05 +00:00
import { useInjectSize } from '../SizeContext';
2023-01-27 08:00:17 +00:00
export default (name: string, props: Record<any, any>) => {
2023-02-21 15:11:05 +00:00
const sizeContext = useInjectSize();
const disabledContext = useInjectDisabled();
2023-01-27 08:00:17 +00:00
const configProvider = inject(configProviderKey, {
...defaultConfigProvider,
2023-02-20 03:04:25 +00:00
renderEmpty: (name?: string) => h(DefaultRenderEmpty, { componentName: name }),
2023-01-27 08:00:17 +00:00
});
const prefixCls = computed(() => configProvider.getPrefixCls(name, props.prefixCls));
const direction = computed(() => props.direction ?? configProvider.direction?.value);
2023-01-27 08:00:17 +00:00
const iconPrefixCls = computed(() => props.iconPrefixCls ?? configProvider.iconPrefixCls.value);
const rootPrefixCls = computed(() => configProvider.getPrefixCls());
const autoInsertSpaceInButton = computed(() => configProvider.autoInsertSpaceInButton?.value);
2023-01-27 08:00:17 +00:00
const renderEmpty = configProvider.renderEmpty;
const space = configProvider.space;
const pageHeader = configProvider.pageHeader;
const form = configProvider.form;
const getTargetContainer = configProvider.getTargetContainer;
const getPopupContainer = configProvider.getPopupContainer;
const dropdownMatchSelectWidth = computed<boolean | number>(
() => props.dropdownMatchSelectWidth ?? configProvider.dropdownMatchSelectWidth?.value,
2023-01-27 08:00:17 +00:00
);
const virtual = computed(
() =>
(props.virtual === undefined
? configProvider.virtual?.value !== false
2023-01-27 08:00:17 +00:00
: props.virtual !== false) && dropdownMatchSelectWidth.value !== false,
);
2023-02-21 15:11:05 +00:00
const size = computed(() => (props.size as SizeType) || sizeContext.value);
2023-01-27 08:00:17 +00:00
const autocomplete = computed(
() => props.autocomplete ?? configProvider.input?.value?.autocomplete,
2023-01-27 08:00:17 +00:00
);
2023-02-21 15:11:05 +00:00
const disabled = computed<boolean>(() => props.disabled ?? disabledContext.value);
2023-01-27 08:00:17 +00:00
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,
2023-02-20 02:28:16 +00:00
select: configProvider.select,
2023-01-27 08:00:17 +00:00
};
};