import type { VNodeTypes, PropType, ComputedRef, Ref } from 'vue'; import { unref, inject, defineComponent, computed } from 'vue'; import defaultLocaleData from './en_US'; import type { Locale } from '.'; export type LocaleComponentName = Exclude; export interface LocaleReceiverProps { componentName?: string; defaultLocale?: Locale | Function; children: (locale: Locale, localeCode?: string, fullLocale?: Locale) => VNodeTypes; } interface LocaleInterface { [key: string]: any; } export interface LocaleReceiverContext { antLocale?: LocaleInterface; } export default defineComponent({ compatConfig: { MODE: 3 }, name: 'LocaleReceiver', props: { componentName: String as PropType, defaultLocale: { type: [Object, Function], }, children: { type: Function as PropType< (locale: any, localeCode?: string, fullLocale?: object) => VNodeTypes >, }, }, setup(props, { slots }) { const localeData = inject('localeData', {}); const locale = computed(() => { const { componentName = 'global', defaultLocale } = props; const locale = defaultLocale || (defaultLocaleData as LocaleInterface)[componentName || 'global']; const { antLocale } = localeData; const localeFromContext = componentName && antLocale ? antLocale[componentName] : {}; return { ...(typeof locale === 'function' ? locale() : locale), ...(localeFromContext || {}), }; }); const localeCode = computed(() => { const { antLocale } = localeData; const localeCode = antLocale && antLocale.locale; // Had use LocaleProvide but didn't set locale if (antLocale && antLocale.exist && !localeCode) { return defaultLocaleData.locale; } return localeCode; }); return () => { const children = props.children || slots.default; const { antLocale } = localeData; return children?.(locale.value, localeCode.value, antLocale); }; }, }); export function useLocaleReceiver( componentName: T, defaultLocale?: Locale[T] | Function | ComputedRef, propsLocale?: Ref, ): [ComputedRef] { const localeData = inject('localeData', {} as LocaleReceiverContext); const componentLocale = computed(() => { const { antLocale } = localeData; const locale = unref(defaultLocale) || (defaultLocaleData as LocaleInterface)[componentName || 'global']; const localeFromContext = componentName && antLocale ? antLocale[componentName] : {}; return { ...(typeof locale === 'function' ? (locale as Function)() : locale), ...(localeFromContext || {}), ...(unref(propsLocale) || {}), }; }); return [componentLocale]; }