forked from aksonov/react-native-router-flux
-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.d.ts
361 lines (310 loc) · 9.75 KB
/
index.d.ts
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
// typings for [email protected]
// created by bang88 (https://github.com/bang88)
import * as React from 'react';
import * as ReactNative from 'react-native';
declare namespace RNRF {
export interface SceneProps {
// Scene
/**
* Will be used to call screen transition, for example, Actions.name(params). Must be unique.
*/
key: string,
/**
* The Component to be displayed. Not required when defining a nested Scene, see example. If it is defined for 'container' scene, it will be used as custom container renderer
*/
component?: React.ReactNode,
/**
* Set to true if this is the initial scene
*/
initial?: boolean,
/**
* Defines how the new screen is added to the navigator stack. One of push, jump, replace, reset. If parent container is tabbar (tabs=true), jump will be automatically set.
*/
type?: 'push' | 'jump' | string,
/**
* Scenes marked with clone will be treated as templates and cloned into the current scene's parent when pushed. See example.
*/
clone?: boolean,
/**
* Pass all own props (except style, key, name, component, tabs) to children. Note that passProps is also passed to children.
*/
passProps?: boolean,
// Animation
/**
* optional. acts as a shortcut to writing an applyAnimation function with Animated.timing for a given duration (in ms).
*/
duration?: number,
/**
* direction of animation horizontal/vertical
*/
direction?: 'vertical' | 'horizontal',
/**
* optional if provided overrides the default spring animation
*/
applyAnimation?: Function,
// Scene styles
/**
* optional style override for the Scene's component
*/
sceneStyle?: ReactNative.ViewStyle,
/**
* Optionally override the styles for NavigationCard's Animated.View rendering the scene. Receives first argument of NavigationSceneRendererProps and second argument of {hideNavBar,hideTabBar,isActive} (see Example app).
*/
getSceneStyle?: Function,
// Tabs
/**
* Defines 'TabBar' scene container, so child scenes will be displayed as 'tabs'. If no component is defined, built-in TabBar is used as renderer. All child scenes are wrapped into own navbar.
*/
tabs?: boolean,
/**
* optional style override for the Tabs component
*/
tabBarStyle?: ReactNative.ViewStyle,
/**
* hides tab bar for this scene and any following scenes until explicitly reversed (if built-in TabBar component is used as parent renderer)
*/
hideTabBar?: boolean,
// Navigation Bar
/**
* hides the navigation bar for this scene and any following scenes until explicitly reversed
*/
hideNavBar?: boolean,
/**
* optional style override for the navigation bar
*/
navigationBarStyle?: ReactNative.ViewStyle,
/**
* optional custom NavBar for the scene. Check built-in NavBar of the component for reference
*/
navBar?: React.ReactNode,
/**
* Simple way to override the drawerImage in the navBar
*/
drawerImage?: ReactNative.Image,
// Navigation Bar: Title
/**
* The title to be displayed in the navigation bar
*/
title?: string,
/**
* Optionally closure to return a value of the title based on state
*/
getTitle?: Function,
/**
* Optionally closure to render the title
*/
renderTitle?: Function,
/**
* optional style override for the title element
*/
titleStyle?: ReactNative.TextStyle,
// Navigation Bar: Back button
/**
* optional string to display with back button
*/
backTitle?: string
/**
* optional closure to render back text or button if this route happens to be the previous route
*/
renderBackButton?: Function
/**
* './back_chevron.png' Simple way to override the back button in the navBar
*/
backButtonImage?: ReactNative.Image,
/**
* optional style override for the back title element
*/
backButtonTextStyle?: ReactNative.TextStyle,
// Navigation Bar: Left button
/**
* optional string to display on the left if the previous route does not provide renderBackButton prop. renderBackButton > leftTitle >
*/
leftTitle?: string,
/**
* optional closure to render the left title / buttons element
*/
renderLeftButton?: Function,
/**
* function will be called when left navBar button is pressed
*/
onLeft?: Function,
/**
* Image for left button
*/
leftButtonImage?: ReactNative.Image,
/**
* Image style for left button
*/
leftButtonIconStyle?: ReactNative.ViewStyle,
/**
* optional style override for the container of left title / buttons
*/
leftButtonStyle?: ReactNative.ViewStyle,
/**
* optional style override for the left title element
*/
leftButtonTextStyle?: ReactNative.TextStyle,
// Navigation Bar: Right button
/**
* optional string to display on the right. onRight must be provided for this to appear.
*/
rightTitle?: string,
/**
* optional closure to render the right title / buttons element
*/
renderRightButton?: Function,
/**
* function will be called when right navBar button is pressed
*/
onRight?: Function,
/**
* Image for right button
*/
rightButtonImage?: ReactNative.Image,
/**
* Image style for right button
*/
rightButtonIconStyle?: ReactNative.ViewStyle,
/**
* optional style override for the container of right title / buttons
*/
rightButtonStyle?: ReactNative.ViewStyle,
/**
* optional style override for the right title element
*/
rightButtonTextStyle?: ReactNative.TextStyle,
/**
* optional wrappert
*/
wrapBy?: ()=>any,
panHandlers?: null | (()=>any)
}
/**
* Scene
*/
export class Scene extends React.Component<SceneProps, {}> {
}
// Router
interface RouterProps extends React.Props<Router> {
reducer?: Function,
createReducer?: Function,
scenes?: any,
/**
* optional Scene's props that can be used in Router
*/
type?: 'push' | 'jump' | string,
clone?: boolean,
passProps?: boolean,
duration?: number,
direction?: 'vertical' | 'horizontal',
applyAnimation?: Function,
sceneStyle?: ReactNative.ViewStyle,
getSceneStyle?: Function,
tabs?: boolean,
tabBarStyle?: ReactNative.ViewStyle,
hideTabBar?: boolean,
hideNavBar?: boolean,
navigationBarStyle?: ReactNative.ViewStyle,
navBar?: React.ReactNode,
drawerImage?: ReactNative.Image,
title?: string,
getTitle?: Function,
renderTitle?: Function,
titleStyle?: ReactNative.TextStyle,
backTitle?: string,
renderBackButton?: Function,
backButtonImage?: ReactNative.Image,
backButtonTextStyle?: ReactNative.TextStyle,
leftTitle?: string,
renderLeftButton?: Function,
onLeft?: Function,
leftButtonImage?: ReactNative.Image,
leftButtonIconStyle?: ReactNative.ViewStyle,
leftButtonStyle?: ReactNative.ViewStyle,
leftButtonTextStyle?: ReactNative.TextStyle,
rightTitle?: string,
renderRightButton?: Function,
onRight?: Function,
rightButtonImage?: ReactNative.Image,
rightButtonIconStyle?: ReactNative.ViewStyle,
rightButtonStyle?: ReactNative.ViewStyle,
rightButtonTextStyle?: ReactNative.TextStyle
}
export class Router extends React.Component<RouterProps, {}>{ }
// Actions
type props = Object;
interface RNRFActions {
pop(props?: props): void,
jump(props: props): void,
refresh(props: props): void,
focus(props: props): void,
create(scene: React.ReactNode, wrapBy?: () => any): Object,
[sceneKey: string]: (props?: props) => void
}
export var Actions: RNRFActions;
// ActionsConst
interface RNRFActionConst {
JUMP: string,
PUSH: string,
PUSH_OR_POP: string,
REPLACE: string,
BACK: string,
BACK_ACTION: string,
POP_AND_REPLACE: string,
POP_TO: string,
REFRESH: string,
RESET: string,
FOCUS: string,
}
export var ActionConst: RNRFActionConst;
// DefaultRenderer
interface DefaultRendererProps extends React.Props<DefaultRenderer> {
navigationState: Object,
onNavigate: Function
}
export class DefaultRenderer extends React.Component<DefaultRendererProps, {}>{ }
// Modal
interface ModalProps extends React.Props<Modal> {
navigationState: Object,
onNavigate: Function
}
export class Modal extends React.Component<ModalProps, {}>{ }
// navbar
interface NavBarProps extends React.Props<NavBar> {
navigationState?: Object,
backButtonImage?: number,
backButtonTextStyle?: ReactNative.TextStyle,
leftButtonStyle?: ReactNative.ViewStyle
leftButtonIconStyle?: ReactNative.ImageStyle,
getTitle?: Function,
titleStyle?: ReactNative.TextStyle,
position?: Object,
navigationBarStyle?: ReactNative.ViewStyle,
renderTitle?: any,
}
export class NavBar extends React.Component<NavBarProps, {}>{ }
// Reducer
export var Reducer: (state: {}, scence: {}) => any;
// Switch
interface SwitchProps extends React.Props<Switch> {
navigationState?: Object,
onNavigate?: Function,
selector?: Function,
}
export class Switch extends React.Component<SwitchProps, {}>{ }
// TabBar
interface TabBarProps extends React.Props<TabBar> {
navigationState?: Object,
tabIcon?: any,
onNavigate?: Function,
}
export class TabBar extends React.Component<TabBarProps, {}>{ }
// getInitialState
export var getInitialState: (scenes: any) => Object
// Util
export interface Util {
deepestExplicitValueForKey(navigationState: Object, key: string): any,
assert(expr: boolean, failDescription: any): void
}
}
export = RNRF;