Files
react/packages/react-devtools-shell/app/DeeplyNestedComponents/index.js
T
2019-08-13 18:11:59 -07:00

39 lines
719 B
JavaScript

// @flow
import React, {Fragment} from 'react';
function wrapWithHoc(Component, index) {
function HOC() {
return <Component />;
}
// $FlowFixMe
const displayName = Component.displayName || Component.name;
HOC.displayName = `withHoc${index}(${displayName})`;
return HOC;
}
function wrapWithNested(Component, times) {
for (let i = 0; i < times; i++) {
Component = wrapWithHoc(Component, i);
}
return Component;
}
function Nested() {
return <div>Deeply nested div</div>;
}
const DeeplyNested = wrapWithNested(Nested, 100);
export default function DeeplyNestedComponents() {
return (
<Fragment>
<h1>Deeply nested component</h1>
<DeeplyNested />
</Fragment>
);
}