2016-11-08 20:07:17 +01:00
|
|
|
/// <reference path='fourslash.ts' />
|
|
|
|
|
|
|
|
//@Filename: file.tsx
|
|
|
|
// @jsx: preserve
|
|
|
|
// @noLib: true
|
|
|
|
|
|
|
|
//// declare module JSX {
|
|
|
|
//// interface Element { }
|
|
|
|
//// interface IntrinsicElements {
|
|
|
|
//// }
|
|
|
|
//// interface ElementAttributesProperty { props; }
|
|
|
|
//// }
|
|
|
|
//// interface ClickableProps {
|
|
|
|
//// children?: string;
|
|
|
|
//// className?: string;
|
|
|
|
//// }
|
|
|
|
//// interface ButtonProps extends ClickableProps {
|
|
|
|
//// onClick(event?: React.MouseEvent<HTMLButtonElement>): void;
|
|
|
|
//// }
|
|
|
|
//// interface LinkProps extends ClickableProps {
|
2019-06-13 21:25:02 +02:00
|
|
|
//// [|[|{| "isDefinition": true, "contextRangeIndex": 0 |}goTo|]: string;|]
|
2016-11-08 20:07:17 +01:00
|
|
|
//// }
|
|
|
|
//// declare function MainButton(buttonProps: ButtonProps): JSX.Element;
|
|
|
|
//// declare function MainButton(linkProps: LinkProps): JSX.Element;
|
|
|
|
//// declare function MainButton(props: ButtonProps | LinkProps): JSX.Element;
|
|
|
|
//// let opt = <MainButton />;
|
|
|
|
//// let opt = <MainButton children="chidlren" />;
|
|
|
|
//// let opt = <MainButton onClick={()=>{}} />;
|
|
|
|
//// let opt = <MainButton onClick={()=>{}} ignore-prop />;
|
2019-06-13 21:25:02 +02:00
|
|
|
//// let opt = <MainButton [|[|{| "isWriteAccess": true, "isDefinition": true, "contextRangeIndex": 2 |}goTo|]="goTo"|] />;
|
2018-05-07 19:08:38 +02:00
|
|
|
//// let opt = <MainButton [|{| "isWriteAccess": true, "isDefinition": true |}goTo|] />;
|
2016-11-08 20:07:17 +01:00
|
|
|
//// let opt = <MainButton wrong />;
|
|
|
|
|
2019-06-05 23:10:51 +02:00
|
|
|
verify.singleReferenceGroup("(property) LinkProps.goTo: string", "goTo");
|