amis-rpc-design/node_modules/antd/es/locale/useLocale.js
2023-10-07 19:42:30 +08:00

22 lines
1.1 KiB
JavaScript

import * as React from 'react';
import LocaleContext from './context';
import defaultLocaleData from './en_US';
const useLocale = (componentName, defaultLocale) => {
const fullLocale = React.useContext(LocaleContext);
const getLocale = React.useMemo(() => {
var _a;
const locale = defaultLocale || defaultLocaleData[componentName];
const localeFromContext = (_a = fullLocale === null || fullLocale === void 0 ? void 0 : fullLocale[componentName]) !== null && _a !== void 0 ? _a : {};
return Object.assign(Object.assign({}, typeof locale === 'function' ? locale() : locale), localeFromContext || {});
}, [componentName, defaultLocale, fullLocale]);
const getLocaleCode = React.useMemo(() => {
const localeCode = fullLocale === null || fullLocale === void 0 ? void 0 : fullLocale.locale;
// Had use LocaleProvide but didn't set locale
if ((fullLocale === null || fullLocale === void 0 ? void 0 : fullLocale.exist) && !localeCode) {
return defaultLocaleData.locale;
}
return localeCode;
}, [fullLocale]);
return [getLocale, getLocaleCode];
};
export default useLocale;