import * as React from 'react'; import rcWarning, { resetWarned } from 'rc-util/lib/warning'; export { resetWarned }; export function noop() {} type Warning = (valid: boolean, component: string, message?: string) => void; // eslint-disable-next-line import/no-mutable-exports let warning: Warning = noop; if (process.env.NODE_ENV !== 'production') { warning = (valid, component, message) => { rcWarning(valid, `[antd: ${component}] ${message}`); // StrictMode will inject console which will not throw warning in React 17. if (process.env.NODE_ENV === 'test') { resetWarned(); } }; } type TypeWarning = ( valid: boolean, component: string, /** * - deprecated: Some API will be removed in future but still support now. * - usage: Some API usage is not correct. * - breaking: Breaking change like API is removed. */ type: 'deprecated' | 'usage' | 'breaking', message?: string, ) => void; export interface WarningContextProps { deprecated?: boolean; } export const WarningContext = React.createContext({}); /** * This is a hook but we not named as `useWarning` * since this is only used in development. * We should always wrap this in `if (process.env.NODE_ENV !== 'production')` condition */ export const devUseWarning: () => TypeWarning = process.env.NODE_ENV !== 'production' ? () => { const { deprecated } = React.useContext(WarningContext); const typeWarning: TypeWarning = (valid, component, type, message) => { if (deprecated !== false || type !== 'deprecated') { warning(valid, component, message); } }; return typeWarning; } : () => noop; export default warning;