react-toolbox/components/utils/is-component-of-type.js

40 lines
1.3 KiB
JavaScript

import React from 'react';
let customChecker;
/**
* Sets customChecker which will be used for all components.
*
* @param providedChecker {Function} - Checker function
*/
export function overrideComponentTypeChecker(providedChecker) {
customChecker = providedChecker;
}
/**
* Returns true if the provided element is a component of the provided type.
*
* @param classType {ReactElement class} - the class of a React Element
* @param reactElement {ReactElement} - any React Element (not a real DOM node)
*/
export function defaultChecker(classType, reactElement) {
if (process.env.NODE_ENV !== 'production') {
// https://github.com/gaearon/react-hot-loader/blob/v3.0.0-beta.7/docs/Known%20Limitations.md#checking-element-types
classType = React.createElement(classType).type;// eslint-disable-line no-param-reassign
}
return reactElement && reactElement.type === classType;
}
/**
* Executes customChecker if it's set or defaultChecker.
*
* @param classType {ReactElement class} - the class of a React Element
* @param reactElement {ReactElement} - any React Element (not a real DOM node)
*/
export default function isComponentOfType(classType, reactElement) {
return customChecker
? customChecker(classType, reactElement)
: defaultChecker(classType, reactElement);
}