27 lines
627 B
TypeScript
27 lines
627 B
TypeScript
// @filename: file.tsx
|
|
// @jsx: react
|
|
// @noLib: true
|
|
// @libFiles: react.d.ts,lib.d.ts
|
|
|
|
import React = require('react');
|
|
|
|
interface ComponentProps {
|
|
AnyComponent: React.StatelessComponent<any> | React.ComponentClass<any>;
|
|
}
|
|
|
|
class MyComponent extends React.Component<ComponentProps, {}> {
|
|
render() {
|
|
const { AnyComponent } = this.props;
|
|
return (<AnyComponent />);
|
|
}
|
|
}
|
|
|
|
// Stateless Component As Props
|
|
<MyComponent AnyComponent={() => <button>test</button>}/>
|
|
|
|
// Component Class as Props
|
|
class MyButtonComponent extends React.Component<{},{}> {
|
|
}
|
|
|
|
<MyComponent AnyComponent={MyButtonComponent} />
|
|
|