2017-01-23 20:52:31 +01:00
|
|
|
|
// @filename: file.tsx
|
|
|
|
|
// @jsx: preserve
|
|
|
|
|
// @module: amd
|
|
|
|
|
// @noLib: true
|
2017-10-04 23:43:35 +02:00
|
|
|
|
// @skipLibCheck: true
|
2017-01-23 20:52:31 +01:00
|
|
|
|
// @libFiles: react.d.ts,lib.d.ts
|
|
|
|
|
|
|
|
|
|
import React = require('react')
|
|
|
|
|
|
|
|
|
|
declare function Component<U>(l: U): JSX.Element;
|
|
|
|
|
function createComponent<T extends { prop: number }>(arg: T) {
|
|
|
|
|
let a1 = <Component {...arg} />;
|
|
|
|
|
let a2 = <Component {...arg} prop1 />;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
declare function ComponentSpecific<U>(l: { prop: U }): JSX.Element;
|
|
|
|
|
declare function ComponentSpecific1<U>(l: { prop: U, "ignore-prop": number }): JSX.Element;
|
|
|
|
|
|
|
|
|
|
function Bar<T extends { prop: number }>(arg: T) {
|
|
|
|
|
let a1 = <ComponentSpecific {...arg} ignore-prop="hi" />; // U is number
|
|
|
|
|
let a2 = <ComponentSpecific1 {...arg} ignore-prop={10} />; // U is number
|
|
|
|
|
let a3 = <ComponentSpecific {...arg} prop="hello" />; // U is "hello"
|
2017-05-08 22:35:09 +02:00
|
|
|
|
let a4 = <ComponentSpecific {...arg} prop1="hello" />; // U is "hello"
|
2017-01-23 20:52:31 +01:00
|
|
|
|
}
|