File: tsxCompletion13.ts

package info (click to toggle)
node-typescript 5.1.6%2Bds1-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 492,516 kB
  • sloc: javascript: 2,078,951; makefile: 6; sh: 1
file content (58 lines) | stat: -rw-r--r-- 2,062 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
/// <reference path='fourslash.ts' />

//@Filename: file.tsx
// @jsx: preserve
// @skipLibCheck: 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 {
////     goTo: string;
//// }
//// 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 /*1*/ />;
//// let opt = <MainButton children="chidlren" /*2*/ />;
//// let opt = <MainButton onClick={()=>{}} /*3*/ />;
//// let opt = <MainButton onClick={()=>{}} ignore-prop /*4*/ />;
//// let opt = <MainButton goTo="goTo" /*5*/ />;
//// let opt = <MainButton wrong /*6*/ />;

verify.completions(
    {
        marker: ["1", "6"],
        exact: [
          "goTo",
          "onClick",
          { name: "children", kind: "property", kindModifiers: "optional", sortText: completion.SortText.OptionalMember },
          { name: "className", kind: "property", kindModifiers: "optional", sortText: completion.SortText.OptionalMember },
        ]
    },
    {
      marker: "2",
      exact: [
        "goTo",
        "onClick",
        { name: "className", kind: "property", kindModifiers: "optional", sortText: completion.SortText.OptionalMember },
      ]
    },
    {
      marker: ["3", "4", "5"],
      exact: [
        { name: "children", kind: "property", kindModifiers: "optional", sortText: completion.SortText.OptionalMember },
        { name: "className", kind: "property", kindModifiers: "optional", sortText: completion.SortText.OptionalMember },
      ]
    },
);