UNPKG

antd

Version:

An enterprise-class UI design language and React components implementation

122 lines (103 loc) 4.34 kB
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } // TODO: remove this lint // SFC has specified a displayName, but not worked. /* eslint-disable react/display-name */ import * as React from 'react'; import { FormProvider as RcFormProvider } from 'rc-field-form'; import LocaleProvider, { ANT_MARK } from '../locale-provider'; import LocaleReceiver from '../locale-provider/LocaleReceiver'; import { ConfigConsumer, ConfigContext } from './context'; import { SizeContextProvider } from './SizeContext'; import message from '../message'; import notification from '../notification'; export { ConfigContext, ConfigConsumer }; export var configConsumerProps = ['getTargetContainer', 'getPopupContainer', 'rootPrefixCls', 'getPrefixCls', 'renderEmpty', 'csp', 'autoInsertSpaceInButton', 'locale', 'pageHeader']; var ConfigProvider = function ConfigProvider(props) { React.useEffect(function () { if (props.direction) { message.config({ rtl: props.direction === 'rtl' }); notification.config({ rtl: props.direction === 'rtl' }); } }, [props.direction]); var getPrefixClsWrapper = function getPrefixClsWrapper(context) { return function (suffixCls, customizePrefixCls) { var prefixCls = props.prefixCls; if (customizePrefixCls) return customizePrefixCls; var mergedPrefixCls = prefixCls || context.getPrefixCls(''); return suffixCls ? "".concat(mergedPrefixCls, "-").concat(suffixCls) : mergedPrefixCls; }; }; var renderProvider = function renderProvider(context, legacyLocale) { var children = props.children, getTargetContainer = props.getTargetContainer, getPopupContainer = props.getPopupContainer, renderEmpty = props.renderEmpty, csp = props.csp, autoInsertSpaceInButton = props.autoInsertSpaceInButton, form = props.form, input = props.input, locale = props.locale, pageHeader = props.pageHeader, componentSize = props.componentSize, direction = props.direction, space = props.space, virtual = props.virtual, dropdownMatchSelectWidth = props.dropdownMatchSelectWidth; var config = _extends(_extends({}, context), { getPrefixCls: getPrefixClsWrapper(context), csp: csp, autoInsertSpaceInButton: autoInsertSpaceInButton, locale: locale || legacyLocale, direction: direction, space: space, virtual: virtual, dropdownMatchSelectWidth: dropdownMatchSelectWidth }); if (getTargetContainer) { config.getTargetContainer = getTargetContainer; } if (getPopupContainer) { config.getPopupContainer = getPopupContainer; } if (renderEmpty) { config.renderEmpty = renderEmpty; } if (pageHeader) { config.pageHeader = pageHeader; } if (input) { config.input = input; } var childNode = children; // Additional Form provider var validateMessages = {}; if (locale && locale.Form && locale.Form.defaultValidateMessages) { validateMessages = locale.Form.defaultValidateMessages; } if (form && form.validateMessages) { validateMessages = _extends(_extends({}, validateMessages), form.validateMessages); } if (Object.keys(validateMessages).length > 0) { childNode = /*#__PURE__*/React.createElement(RcFormProvider, { validateMessages: validateMessages }, children); } return /*#__PURE__*/React.createElement(SizeContextProvider, { size: componentSize }, /*#__PURE__*/React.createElement(ConfigContext.Provider, { value: config }, /*#__PURE__*/React.createElement(LocaleProvider, { locale: locale || legacyLocale, _ANT_MARK__: ANT_MARK }, childNode))); }; return /*#__PURE__*/React.createElement(LocaleReceiver, null, function (_, __, legacyLocale) { return /*#__PURE__*/React.createElement(ConfigConsumer, null, function (context) { return renderProvider(context, legacyLocale); }); }); }; export default ConfigProvider;