2019-08-05 18:38:10 +08:00
|
|
|
// TODO: remove this lint
|
|
|
|
// SFC has specified a displayName, but not worked.
|
|
|
|
/* eslint-disable react/display-name */
|
2018-11-26 12:06:42 +08:00
|
|
|
import * as React from 'react';
|
2019-07-03 20:14:39 +08:00
|
|
|
import { FormProvider as RcFormProvider } from 'rc-field-form';
|
|
|
|
import { ValidateMessages } from 'rc-field-form/lib/interface';
|
2019-10-08 14:45:17 +08:00
|
|
|
import { RenderEmptyHandler } from './renderEmpty';
|
2019-07-24 10:34:55 +08:00
|
|
|
import LocaleProvider, { Locale, ANT_MARK } from '../locale-provider';
|
2019-08-06 00:27:47 +08:00
|
|
|
import LocaleReceiver from '../locale-provider/LocaleReceiver';
|
2020-11-03 16:22:18 +08:00
|
|
|
import {
|
|
|
|
ConfigConsumer,
|
|
|
|
ConfigContext,
|
|
|
|
CSPConfig,
|
|
|
|
DirectionType,
|
|
|
|
ConfigConsumerProps,
|
|
|
|
} from './context';
|
2020-01-03 13:38:16 +08:00
|
|
|
import { SizeType, SizeContextProvider } from './SizeContext';
|
2020-04-29 23:18:22 +08:00
|
|
|
import message from '../message';
|
|
|
|
import notification from '../notification';
|
2020-10-24 14:27:49 +08:00
|
|
|
import { RequiredMark } from '../form/Form';
|
2018-12-26 16:01:00 +08:00
|
|
|
|
2020-11-03 16:22:18 +08:00
|
|
|
export {
|
|
|
|
RenderEmptyHandler,
|
|
|
|
ConfigContext,
|
|
|
|
ConfigConsumer,
|
|
|
|
CSPConfig,
|
|
|
|
DirectionType,
|
|
|
|
ConfigConsumerProps,
|
|
|
|
};
|
2018-11-26 12:06:42 +08:00
|
|
|
|
2019-02-19 11:42:05 +08:00
|
|
|
export const configConsumerProps = [
|
2020-04-29 20:22:16 +08:00
|
|
|
'getTargetContainer',
|
2019-02-19 11:42:05 +08:00
|
|
|
'getPopupContainer',
|
|
|
|
'rootPrefixCls',
|
|
|
|
'getPrefixCls',
|
|
|
|
'renderEmpty',
|
|
|
|
'csp',
|
|
|
|
'autoInsertSpaceInButton',
|
2019-07-24 10:34:55 +08:00
|
|
|
'locale',
|
2019-10-15 11:46:12 +08:00
|
|
|
'pageHeader',
|
2019-02-19 11:42:05 +08:00
|
|
|
];
|
|
|
|
|
2019-03-16 09:48:21 +08:00
|
|
|
export interface ConfigProviderProps {
|
2020-04-29 20:22:16 +08:00
|
|
|
getTargetContainer?: () => HTMLElement;
|
2019-04-28 11:47:22 +08:00
|
|
|
getPopupContainer?: (triggerNode: HTMLElement) => HTMLElement;
|
2018-12-05 19:12:18 +08:00
|
|
|
prefixCls?: string;
|
|
|
|
children?: React.ReactNode;
|
2018-12-26 16:01:00 +08:00
|
|
|
renderEmpty?: RenderEmptyHandler;
|
2019-01-09 20:15:37 +08:00
|
|
|
csp?: CSPConfig;
|
2019-01-10 11:47:11 +08:00
|
|
|
autoInsertSpaceInButton?: boolean;
|
2019-07-03 20:14:39 +08:00
|
|
|
form?: {
|
|
|
|
validateMessages?: ValidateMessages;
|
2020-10-24 14:27:49 +08:00
|
|
|
requiredMark?: RequiredMark;
|
2019-07-03 20:14:39 +08:00
|
|
|
};
|
2020-04-22 10:38:43 +08:00
|
|
|
input?: {
|
|
|
|
autoComplete?: string;
|
|
|
|
};
|
2019-07-24 10:34:55 +08:00
|
|
|
locale?: Locale;
|
2019-10-15 11:46:12 +08:00
|
|
|
pageHeader?: {
|
|
|
|
ghost: boolean;
|
|
|
|
};
|
2020-01-03 13:38:16 +08:00
|
|
|
componentSize?: SizeType;
|
2020-11-03 16:22:18 +08:00
|
|
|
direction?: DirectionType;
|
2020-03-22 11:38:02 +08:00
|
|
|
space?: {
|
|
|
|
size?: SizeType | number;
|
|
|
|
};
|
2020-05-05 15:00:43 +08:00
|
|
|
virtual?: boolean;
|
|
|
|
dropdownMatchSelectWidth?: boolean;
|
2018-12-05 19:12:18 +08:00
|
|
|
}
|
|
|
|
|
2020-09-11 21:24:26 +08:00
|
|
|
const ConfigProvider: React.FC<ConfigProviderProps> & {
|
|
|
|
ConfigContext: typeof ConfigContext;
|
|
|
|
} = props => {
|
2020-04-29 23:18:22 +08:00
|
|
|
React.useEffect(() => {
|
|
|
|
if (props.direction) {
|
|
|
|
message.config({
|
|
|
|
rtl: props.direction === 'rtl',
|
|
|
|
});
|
|
|
|
notification.config({
|
|
|
|
rtl: props.direction === 'rtl',
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}, [props.direction]);
|
|
|
|
|
2020-12-09 17:12:32 +08:00
|
|
|
const getPrefixClsWrapper = (context: ConfigConsumerProps) => (
|
|
|
|
suffixCls: string,
|
|
|
|
customizePrefixCls?: string,
|
|
|
|
) => {
|
|
|
|
const { prefixCls } = props;
|
2018-12-05 19:12:18 +08:00
|
|
|
|
2020-12-09 17:12:32 +08:00
|
|
|
if (customizePrefixCls) return customizePrefixCls;
|
2018-12-05 19:12:18 +08:00
|
|
|
|
2020-12-09 17:12:32 +08:00
|
|
|
const mergedPrefixCls = prefixCls || context.getPrefixCls('');
|
2020-04-21 11:16:33 +08:00
|
|
|
|
2020-12-09 17:12:32 +08:00
|
|
|
return suffixCls ? `${mergedPrefixCls}-${suffixCls}` : mergedPrefixCls;
|
2018-11-26 12:06:42 +08:00
|
|
|
};
|
|
|
|
|
2020-04-29 23:18:22 +08:00
|
|
|
const renderProvider = (context: ConfigConsumerProps, legacyLocale: Locale) => {
|
2019-07-03 20:14:39 +08:00
|
|
|
const {
|
|
|
|
children,
|
2020-04-29 20:22:16 +08:00
|
|
|
getTargetContainer,
|
2019-07-03 20:14:39 +08:00
|
|
|
getPopupContainer,
|
|
|
|
renderEmpty,
|
|
|
|
csp,
|
|
|
|
autoInsertSpaceInButton,
|
|
|
|
form,
|
2020-04-22 10:38:43 +08:00
|
|
|
input,
|
2019-07-24 10:34:55 +08:00
|
|
|
locale,
|
2019-10-15 11:46:12 +08:00
|
|
|
pageHeader,
|
2020-01-03 13:38:16 +08:00
|
|
|
componentSize,
|
2020-01-02 19:10:16 +08:00
|
|
|
direction,
|
2020-03-22 11:38:02 +08:00
|
|
|
space,
|
2020-05-05 15:00:43 +08:00
|
|
|
virtual,
|
|
|
|
dropdownMatchSelectWidth,
|
2020-04-29 23:18:22 +08:00
|
|
|
} = props;
|
2018-12-05 19:12:18 +08:00
|
|
|
|
|
|
|
const config: ConfigConsumerProps = {
|
|
|
|
...context,
|
2020-04-29 23:18:22 +08:00
|
|
|
getPrefixCls: getPrefixClsWrapper(context),
|
2019-01-09 20:15:37 +08:00
|
|
|
csp,
|
2019-01-10 11:47:11 +08:00
|
|
|
autoInsertSpaceInButton,
|
2019-11-15 14:35:25 +08:00
|
|
|
locale: locale || legacyLocale,
|
2020-01-02 19:10:16 +08:00
|
|
|
direction,
|
2020-03-22 11:38:02 +08:00
|
|
|
space,
|
2020-05-05 15:00:43 +08:00
|
|
|
virtual,
|
|
|
|
dropdownMatchSelectWidth,
|
2018-12-05 19:12:18 +08:00
|
|
|
};
|
2018-11-26 12:06:42 +08:00
|
|
|
|
2020-04-29 20:22:16 +08:00
|
|
|
if (getTargetContainer) {
|
|
|
|
config.getTargetContainer = getTargetContainer;
|
|
|
|
}
|
|
|
|
|
2018-12-26 16:01:00 +08:00
|
|
|
if (getPopupContainer) {
|
|
|
|
config.getPopupContainer = getPopupContainer;
|
|
|
|
}
|
2019-10-15 11:46:12 +08:00
|
|
|
|
2018-12-26 16:01:00 +08:00
|
|
|
if (renderEmpty) {
|
|
|
|
config.renderEmpty = renderEmpty;
|
|
|
|
}
|
|
|
|
|
2019-10-15 11:46:12 +08:00
|
|
|
if (pageHeader) {
|
|
|
|
config.pageHeader = pageHeader;
|
|
|
|
}
|
|
|
|
|
2020-04-22 10:38:43 +08:00
|
|
|
if (input) {
|
|
|
|
config.input = input;
|
|
|
|
}
|
|
|
|
|
2020-10-24 14:27:49 +08:00
|
|
|
if (form) {
|
|
|
|
config.form = form;
|
|
|
|
}
|
2019-07-03 20:14:39 +08:00
|
|
|
|
2020-10-24 14:27:49 +08:00
|
|
|
let childNode = children;
|
2019-07-03 20:14:39 +08:00
|
|
|
// Additional Form provider
|
2020-04-18 13:18:51 +08:00
|
|
|
let validateMessages: ValidateMessages = {};
|
|
|
|
|
|
|
|
if (locale && locale.Form && locale.Form.defaultValidateMessages) {
|
|
|
|
validateMessages = locale.Form.defaultValidateMessages;
|
|
|
|
}
|
2019-07-03 20:14:39 +08:00
|
|
|
if (form && form.validateMessages) {
|
2020-04-18 13:18:51 +08:00
|
|
|
validateMessages = { ...validateMessages, ...form.validateMessages };
|
|
|
|
}
|
|
|
|
|
|
|
|
if (Object.keys(validateMessages).length > 0) {
|
|
|
|
childNode = <RcFormProvider validateMessages={validateMessages}>{children}</RcFormProvider>;
|
2019-07-03 20:14:39 +08:00
|
|
|
}
|
|
|
|
|
2020-11-16 20:21:39 +08:00
|
|
|
const childrenWithLocale =
|
|
|
|
locale === undefined ? (
|
|
|
|
childNode
|
|
|
|
) : (
|
|
|
|
<LocaleProvider locale={locale || legacyLocale} _ANT_MARK__={ANT_MARK}>
|
|
|
|
{childNode}
|
|
|
|
</LocaleProvider>
|
|
|
|
);
|
|
|
|
|
2019-07-24 10:34:55 +08:00
|
|
|
return (
|
2020-01-03 13:38:16 +08:00
|
|
|
<SizeContextProvider size={componentSize}>
|
2020-11-16 20:21:39 +08:00
|
|
|
<ConfigContext.Provider value={config}>{childrenWithLocale}</ConfigContext.Provider>
|
2020-01-03 13:38:16 +08:00
|
|
|
</SizeContextProvider>
|
2019-07-24 10:34:55 +08:00
|
|
|
);
|
2018-12-07 20:02:01 +08:00
|
|
|
};
|
2018-12-05 19:12:18 +08:00
|
|
|
|
2020-04-29 23:18:22 +08:00
|
|
|
return (
|
|
|
|
<LocaleReceiver>
|
|
|
|
{(_, __, legacyLocale) => (
|
|
|
|
<ConfigConsumer>
|
|
|
|
{context => renderProvider(context, legacyLocale as Locale)}
|
|
|
|
</ConfigConsumer>
|
|
|
|
)}
|
|
|
|
</LocaleReceiver>
|
|
|
|
);
|
|
|
|
};
|
2018-11-26 12:06:42 +08:00
|
|
|
|
2020-09-11 21:24:26 +08:00
|
|
|
/** @private internal usage. do not use in your production */
|
|
|
|
ConfigProvider.ConfigContext = ConfigContext;
|
2018-12-07 20:02:01 +08:00
|
|
|
export default ConfigProvider;
|