1 |
|
2 |
|
3 |
|
4 | import * as React from "react"
|
5 |
|
6 | export type IReactComponent<P = any> =
|
7 | | React.StatelessComponent<P>
|
8 | | React.ComponentClass<P>
|
9 | | React.ClassicComponentClass<P>
|
10 |
|
11 |
|
12 |
|
13 |
|
14 |
|
15 |
|
16 | export function observer(stores: string[]): <T extends IReactComponent>(clazz: T) => void
|
17 | // Deprecated: observer with with stores
|
18 | export function observer<T extends IReactComponent>(stores: string[], clazz: T): T
|
19 | export function observer<T extends IReactComponent>(target: T): T
|
20 |
|
21 | /**
|
22 | * Inject
|
23 | */
|
24 | export type IValueMap = { [key: string]: any }
|
25 | export type IStoresToProps<
|
26 | S extends IValueMap = {},
|
27 | P extends IValueMap = {},
|
28 | I extends IValueMap = {},
|
29 | C extends IValueMap = {}
|
30 | > = (stores: S, nextProps: P, context: C) => I
|
31 |
|
32 | export type IWrappedComponent<P> = {
|
33 | wrappedComponent: IReactComponent<P>
|
34 | wrappedInstance: React.ReactInstance | undefined
|
35 | }
|
36 |
|
37 |
|
38 |
|
39 |
|
40 | export function inject(
|
41 | ...stores: string[]
|
42 | ): <T extends IReactComponent<any>>(
|
43 | target: T
|
44 | ) => T & (T extends IReactComponent<infer P> ? IWrappedComponent<P> : never)
|
45 | export function inject<S, P, I, C>(
|
46 | fn: IStoresToProps<S, P, I, C>
|
47 | ): <T extends IReactComponent>(target: T) => T & IWrappedComponent<P>
|
48 |
|
49 | // Ideal implementation:
|
50 | // export function inject
|
51 | // (
|
52 |
|
53 |
|
54 |
|
55 |
|
56 |
|
57 |
|
58 |
|
59 |
|
60 |
|
61 |
|
62 |
|
63 |
|
64 |
|
65 |
|
66 | type Disposer = () => void
|
67 | export function disposeOnUnmount(target: React.Component<any, any>, propertyKey: string): void
|
68 | export function disposeOnUnmount<TF extends Disposer | Disposer[]>(
|
69 | target: React.Component<any, any>,
|
70 | fn: TF
|
71 | ): TF
|
72 |
|
73 |
|
74 |
|
75 |
|
76 | export function onError(cb: (error: Error) => void): () => void
|
77 |
|
78 | export class Provider extends React.Component<any, {}> {}
|
79 |
|
80 | export class Observer extends React.Component<
|
81 | {
|
82 | children?: () => React.ReactNode
|
83 | render?: () => React.ReactNode
|
84 | },
|
85 | {}
|
86 | > {}
|
87 |
|
88 | export function useStaticRendering(value: boolean): void
|
89 |
|
90 |
|
91 |
|
92 |
|
93 | export function trackComponents(): void
|
94 |
|
95 | export const renderReporter: RenderReporter
|
96 |
|
97 | export interface RenderReporter {
|
98 | on(handler: (data: IRenderEvent) => void): void
|
99 | }
|
100 |
|
101 | export interface IRenderEvent {
|
102 | event: "render" | "destroy"
|
103 | renderTime?: number
|
104 | totalTime?: number
|
105 | component: React.ReactElement<any>
|
106 | node: any
|
107 | }
|
108 |
|
109 |
|
110 |
|
111 |
|
112 |
|
113 | export const componentByNodeRegistery: any
|
114 |
|
115 |
|
116 |
|
117 | export const componentByNodeRegistry: any
|
118 |
|
119 |
|
120 |
|
121 |
|
122 | export const propTypes: {
|
123 | observableArray: React.Requireable<any>
|
124 | observableArrayOf: (type: React.Validator<any>) => React.Requireable<any>
|
125 | observableMap: React.Requireable<any>
|
126 | observableObject: React.Requireable<any>
|
127 | arrayOrObservableArray: React.Requireable<any>
|
128 | arrayOrObservableArrayOf: (type: React.Validator<any>) => React.Requireable<any>
|
129 | objectOrObservableObject: React.Requireable<any>
|
130 | }
|
131 |
|
132 | export const PropTypes: {
|
133 | observableArray: React.Requireable<any>
|
134 | observableArrayOf: (type: React.Validator<any>) => React.Requireable<any>
|
135 | observableMap: React.Requireable<any>
|
136 | observableObject: React.Requireable<any>
|
137 | arrayOrObservableArray: React.Requireable<any>
|
138 | arrayOrObservableArrayOf: (type: React.Validator<any>) => React.Requireable<any>
|
139 | objectOrObservableObject: React.Requireable<any>
|
140 | }
|
141 |
|
\ | No newline at end of file |