ant-design/components/config-provider/index.tsx
zombieJ 1a0a06fca9
ConfigProvider support prefixCls (#13389)
Basic support prefixCls.
2018-12-05 19:12:18 +08:00

61 lines
1.6 KiB
TypeScript

import * as React from 'react';
import createReactContext, { Context } from 'create-react-context';
export interface ConfigConsumerProps {
getPopupContainer?: (triggerNode?: HTMLElement) => HTMLElement;
rootPrefixCls?: string;
getPrefixCls: (suffixCls: string, customizePrefixCls?: string) => string;
}
interface ConfigProviderProps {
getPopupContainer?: (triggerNode?: HTMLElement) => HTMLElement;
prefixCls?: string;
children?: React.ReactNode;
}
const ConfigContext: Context<ConfigConsumerProps | null> = createReactContext({
getPrefixCls: (suffixCls: string, customizePrefixCls?: string) => {
if (customizePrefixCls) return customizePrefixCls;
return `ant-${suffixCls}`;
},
});
export const ConfigConsumer = ConfigContext.Consumer;
class ConfigProvider extends React.Component<ConfigProviderProps> {
getPrefixCls = (suffixCls: string, customizePrefixCls?: string) => {
const { prefixCls = 'ant' } = this.props;
if (customizePrefixCls) return customizePrefixCls;
return suffixCls ? `${prefixCls}-${suffixCls}` : prefixCls;
};
renderProvider = (context: ConfigConsumerProps) => {
const { getPopupContainer, children } = this.props;
const config: ConfigConsumerProps = {
...context,
getPopupContainer,
getPrefixCls: this.getPrefixCls,
};
return (
<ConfigContext.Provider value={config}>
{children}
</ConfigContext.Provider>
);
}
render() {
return (
<ConfigConsumer>
{this.renderProvider}
</ConfigConsumer>
);
}
}
export default ConfigProvider;