recharts
Version:
React charts
85 lines (81 loc) • 2.61 kB
JavaScript
import get from 'es-toolkit/compat/get';
import { Children } from 'react';
import { isFragment } from 'react-is';
import { isNullish } from './DataUtils';
export var SCALE_TYPES = ['auto', 'linear', 'pow', 'sqrt', 'log', 'identity', 'time', 'band', 'point', 'ordinal', 'quantile', 'quantize', 'utc', 'sequential', 'threshold'];
/**
* @deprecated instead find another approach that does not depend on displayName.
* Get the display name of a component
* @param {Object} Comp Specified Component
* @return {String} Display name of Component
*/
export var getDisplayName = Comp => {
if (typeof Comp === 'string') {
return Comp;
}
if (!Comp) {
return '';
}
return Comp.displayName || Comp.name || 'Component';
};
// `toArray` gets called multiple times during the render
// so we can memoize last invocation (since reference to `children` is the same)
var lastChildren = null;
var lastResult = null;
/**
* @deprecated instead find another approach that does not require reading React Elements from DOM.
*
* @param children do not use
* @return deprecated do not use
*/
export var toArray = children => {
if (children === lastChildren && Array.isArray(lastResult)) {
return lastResult;
}
var result = [];
Children.forEach(children, child => {
if (isNullish(child)) return;
if (isFragment(child)) {
result = result.concat(toArray(child.props.children));
} else {
// @ts-expect-error this could still be Iterable<ReactNode> and TS does not like that
result.push(child);
}
});
lastResult = result;
lastChildren = children;
return result;
};
/**
* @deprecated instead find another approach that does not require reading React Elements from DOM.
*
* Find and return all matched children by type.
* `type` must be a React.ComponentType
*
* @param children do not use
* @param type do not use
* @return deprecated do not use
*/
export function findAllByType(children, type) {
var result = [];
var types = [];
if (Array.isArray(type)) {
types = type.map(t => getDisplayName(t));
} else {
types = [getDisplayName(type)];
}
toArray(children).forEach(child => {
var childType = get(child, 'type.displayName') || get(child, 'type.name');
// ts-expect-error toArray and lodash.get are not compatible. Let's get rid of the whole findAllByType function
if (types.indexOf(childType) !== -1) {
result.push(child);
}
});
return result;
}
export var isClipDot = dot => {
if (dot && typeof dot === 'object' && 'clipDot' in dot) {
return Boolean(dot.clipDot);
}
return true;
};