-
Notifications
You must be signed in to change notification settings - Fork 19
/
react-router.d.ts
763 lines (678 loc) · 23.4 KB
/
react-router.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
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
/// <reference path="typings/main.d.ts" />
import * as React from "react";
import {LocationDescriptor, Query, Location, History, HistoryOptions, CreateHistory, BasenameOptions, QueryOptions} from "history";
declare module ReactRouter {
type RouteConfig = Route | PlainRoute;
type ReactComponent<IProps> = React.Component<IProps, any> | React.StatelessComponent<IProps> | React.ClassicComponent<IProps, any>;
type Params = { [paramName: string]: any };
//Components
export interface IRouterProps {
/**
* children (required)
* One or many <Route>s or PlainRoutes. When the history changes, <Router> will match a branch of its routes, and render their configured components, with child route components nested inside the parents.
*
* @type {(RouteConfig | RouteConfig[])
*/
children?: RouteConfig | RouteConfig[];
/**
* Alias for children.
*
* @type {(RouteConfig | RouteConfig[])}
* @alias children
*/
routes?: RouteConfig | RouteConfig[];
/**
* The history the router should listen to. Typically browserHistory or hashHistory.
*
* @example
* import { browserHistory } from 'react-router'
* ReactDOM.render(<Router history={browserHistory} />, el)
* @type {History}
*/
history?: History;
/**
* When the router is ready to render a branch of route components, it will use this function to create the elements. You may want to take control of creating the elements when you're using some sort of data abstraction, like setting up subscriptions to stores, or passing in some sort of * * application module to each component via props.
*
* @example
* <Router createElement={createElement} />
*
* // default behavior
* function createElement(Component, props) {
* // make sure you pass all the props in!
* return <Component {...props} />
* }
*
* // maybe you're using something like Relay
* function createElement(Component, props) {
* // make sure you pass all the props in!
* return <RelayContainer Component={Component} routerProps={props} />
* }
* @template IProps
* @param {Components<IProps, any>} component
* @param {IProps} props
*/
createElement?<IProps>(component: ReactComponent<IProps>, props: IProps): JSX.Element;
/**
* A function used to convert an object from <Link>s or calls to transitionTo to a URL query string.
*
* @param {Object} queryObject
*/
stringifyQuery?(queryObject: Object): string;
/**
* A function used to convert a query string into an object that gets passed to route component props.
*
* @param {string} queryString
*/
parseQueryString?(queryString: string): Object;
/**
* While the router is matching, errors may bubble up, here is your opportunity to catch and deal with them. Typically these will come from async features like route.getComponents, route.getIndexRoute, and route.getChildRoutes.
*
* @param {Error} error
*/
onError?(error: Error): void;
/**
* Called whenever the router updates its state in response to URL changes.
*/
onUpdate?(): void;
/**
* This is primarily for integrating with other libraries that need to participate in rendering before the route components are rendered. It defaults to render={(props) => <RouterContext {...props} />}.
* Ensure that you render a <RouterContext> at the end of the line, passing all the props passed to render.
*/
render?<IProps>(props: IProps): JSX.Element;
}
/**
* Primary component of React Router. It keeps your UI and the URL in sync.
*
* @export
* @class Router
* @extends {React.Component<IRouterProps, {}>}
*/
export class Router extends React.Component<IRouterProps, {}>{ }
export interface ILinkProps extends React.HTMLAttributes {
/**
* The path to link to, e.g. /users/123.
*
* @type {LocationDescriptor}
*/
to?: LocationDescriptor;
/**
* Should this link only active on index?
*
* @type {boolean}
*/
onlyActiveOnIndex?: boolean;
/**
* An object of key:value pairs to be stringified.
*
* @type {{ [key: string]: any }}
*/
query?: { [key: string]: any };
/**
* A hash to put in the URL, e.g. #a-hash.
*
* Note: React Router currently does not manage scroll position, and will not scroll to the element corresponding to the hash. Scroll position management utilities are available in the scroll-behavior library.
*
* @type {string}
*/
hash?: string;
/**
* State to persist to the location.
*
* @type {string}
*/
state?: string; //TOOD : Have a look back at this one
/**
* The styles to apply to the link element when its route is active.
*
* @type {string}
*/
activeClassName?: string;
/**
* The styles to apply to the link element when its route is active.
*
* @type {React.CSSProperties}
*/
activeStyle?: React.CSSProperties;
/**
* The styles to apply to the link element when its route is active.
*
* @param {React.MouseEvent} event **NOTE** I'm assuming this will be a click event.
*/
onClick?(event: React.MouseEvent): any;
}
/**
* The primary way to allow users to navigate around your application. <Link> will render a fully accessible anchor tag with the proper href.
* A <Link> can know when the route it links to is active and automatically apply an activeClassName and/or activeStyle when given either prop.
* The <Link> will be active if the current route is either the linked route or any descendant of the linked route.
* To have the link be active only on the exact linked route, use <IndexLink> instead.
*
* @example
* <Link to={`/users/${user.id}`} activeClassName="active">{user.name}</Link>
* // becomes one of these depending on your History and if the route is
* // active
* <a href="/users/123" class="active">Michael</a>
* <a href="#/users/123">Michael</a>
*
* // change the activeClassName
* <Link to={`/users/${user.id}`} activeClassName="current">{user.name}</Link>
*
* // change style when link is active
* <Link to="/users" style={{color: 'white'}} activeStyle={{color: 'red'}}>Users</Link>
* @export
* @class Link
* @extends {React.Component<ILinkProps, {}>}
*/
export class Link extends React.Component<ILinkProps, {}>{ }
/**
* An <IndexLink> is like a <Link>, except it is only active when the current route is exactly the linked route.
*
* @export
* @class IndexLink
* @extends {Link}
*/
export class IndexLink extends Link { }
export interface IRouterContext {
router?: IRouter;
}
/**
* Contains data and methods relevant to routing. Most useful for imperatively transitioning around the application.
*
* @export
* @interface IRouter
*/
export interface IRouter {
/**
* Transitions to a new URL, adding a new entry in the browser history.
*
* @example
* router.push('/users/12')
*
* // or with a location descriptor object
* router.push({
* pathname: '/users/12',
* query: { modal: true },
* state: { fromDashboard: true }
* })
*
* @param {LocationDescriptor} pathOrLoc
*/
push(pathOrLoc: LocationDescriptor): void;
/**
* Identical to push except replaces the current history entry with a new one.
*
* @param {LocationDescriptor} pathOrLoc
*/
push(pathOrLoc: LocationDescriptor): void;
/**
* Go forward or backward in the history by n or -n.
*
* @param {number} n
*/
go(n: number): void;
/**
* Go back one entry in the history.
*/
goBack(): void;
/**
* Go forward one entry in the history.
*/
goForward(): void;
/**
* Stringifies the query into the pathname, using the router's config.
*
* @param {LocationDescriptor} pathOrLoc
* @param {Query} query
*/
createPath(pathOrLoc: LocationDescriptor, query: Query): void;
/**
* Creates a URL, using the router's config. For example, it will add #/ in front of the pathname for hash history.
*
* @param {LocationDescriptor} pathOrLoc
* @param {Query} query
*/
createHref(pathOrLoc: LocationDescriptor, query: Query): void;
/**
* Returns true or false depending on if the pathOrLoc is active. Will be true for every route in the route branch matched (child route is active, therefore parent is too), unless indexOnly is specified, in which case it will only match the exact path.
*
* @param {LocationDescriptor} pathOrLoc
* @param {boolean} indexOnly
*/
isActive(pathOrLoc: LocationDescriptor, indexOnly: boolean): boolean;
}
/**
* A <RouterContext> renders the component tree for a given router state. Its used by <Router> but also useful for server rendering and integrating in brownfield development.
*
* It also provides a router object on context.
*
* @export
* @class RouterContext
* @extends {React.Component<{}, {}>}
*/
export class RouterContext extends React.Component<{}, {}>{
context: IRouterContext;
}
//Configuration
export interface IRouteProps extends IIndexRouteProps {
/**
* The path used in the URL.
*
* It will concat with the parent route's path unless it starts with /, making it an absolute path.
*
* Note: Absolute paths may not be used in route config that is dynamically loaded.
*
* If left undefined, the router will try to match the child routes.
*
* @type {string}
*/
path?: string;
}
export class Route extends React.Component<IRouteProps, {}> { }
export interface PlainRoute extends IRouteProps {
/**
* An array of child routes, same as children in JSX route configs.
*
* @type {PlainRoute[]}
*/
childRoutes?: PlainRoute[];
/**
* Same as childRoutes but asynchronous and receives the location. Useful for code-splitting and dynamic route matching (given some state or session data to return a different set of child routes).
*
* @example
*
* let myRoute = {
* path: 'course/:courseId',
* childRoutes: [
* announcementsRoute,
* gradesRoute,
* assignmentsRoute
* ]
* }
*
* // async child routes
* let myRoute = {
* path: 'course/:courseId',
* getChildRoutes(location, cb) {
* // do asynchronous stuff to find the child routes
* cb(null, [ announcementsRoute, gradesRoute, assignmentsRoute ])
* }
* }
*
* // navigation dependent child routes
* // can link with some state
* <Link to="/picture/123" state={{ fromDashboard: true }} />
*
* let myRoute = {
* path: 'picture/:id',
* getChildRoutes(location, cb) {
* let { state } = location
*
* if (state && state.fromDashboard) {
* cb(null, [dashboardPictureRoute])
* } else {
* cb(null, [pictureRoute])
* }
* }
* }
* @param {Location} location
* @param {(err: Error, routes: PlainRoute[]) => void} callback
*/
getChildRoutes?(location: Location, callback: (err: Error, routes: PlainRoute[]) => void): void;
/**
* The index route. This is the same as specifying an <IndexRoute> child when using JSX route configs.
*
* @type {PlainRoute}
*/
indexRoute?: PlainRoute;
/**
* Same as indexRoute, but asynchronous and receives the location. As with getChildRoutes, this can be useful for code-splitting and dynamic route matching.
*
* // For example:
* let myIndexRoute = {
* component: MyIndex
* }
*
* let myRoute = {
* path: 'courses',
* indexRoute: myIndexRoute
* }
*
* // async index route
* let myRoute = {
* path: 'courses',
* getIndexRoute(location, cb) {
* // do something async here
* cb(null, myIndexRoute)
* }
* }
* @param {Location} location
* @param {(err: Error, route: PlainRoute) => void} callback
*/
getIndexRoute?(location: Location, callback: (err: Error, route: PlainRoute) => void): void;
}
export interface IRedirectProps extends IIndexRedirectProps {
/**
* The path you want to redirect from, including dynamic segments.
*
* @type {string}
*/
from?: string;
}
/**
* A <Redirect> sets up a redirect to another route in your application to maintain old URLs.
*
* @export
* @class Redirect
* @extends {React.Component<IRedirectProps, {}>}
*/
export class Redirect extends React.Component<IRedirectProps, {}>{ }
export interface IIndexRouteProps {
/**
* A single component to be rendered when the route matches the URL. It can be rendered by the parent route component with this.props.children.
*
* @example
* const routes = (
* <Route component={App}>
* <Route path="groups" component={Groups} />
* <Route path="users" component={Users} />
* </Route>
* )
*
* class App extends React.Component {
* render () {
* return (
* <div>
* {// this will be either <Users> or <Groups> }
* {this.props.children}
* </div>
* )
* }
* }
*
* @type {Component<any>}
*/
component?: React.ComponentClass<any> | React.StatelessComponent<any>;
/**
* Routes can define one or more named components as an object of [name]: component pairs to be rendered when the path matches the URL. They can be rendered by the parent route component with this.props[name].
*
* @example
* // Think of it outside the context of the router - if you had pluggable
* // portions of your `render`, you might do it like this:
* // <App main={<Users />} sidebar={<UsersSidebar />} />
*
* const routes = (
* <Route component={App}>
* <Route path="groups" components={{main: Groups, sidebar: GroupsSidebar}} />
* <Route path="users" components={{main: Users, sidebar: UsersSidebar}}>
* <Route path="users/:userId" component={Profile} />
* </Route>
* </Route>
* )
*
* class App extends React.Component {
* render () {
* const { main, sidebar } = this.props
* return (
* <div>
* <div className="Main">
* {main}
* </div>
* <div className="Sidebar">
* {sidebar}
* </div>
* </div>
* )
* }
* }
*
* class Users extends React.Component {
* render () {
* return (
* <div>
* { // if at "/users/123" `children` will be <Profile>}
* { // UsersSidebar will also get <Profile> as this.props.children,
* so its a little weird, but you can decide which one wants
* to continue with the nesting //}
* {this.props.children}
* </div>
* )
* }
* }
* @type {{ [name: string]: Component<any> }}
*/
components?: { [name: string]: React.ComponentClass<any> | React.StatelessComponent<any>; }
/**
* Same as component but asynchronous, useful for code-splitting.
*
* @example
* <Route path="courses/:courseId" getComponent={(location, cb) => {
* // do asynchronous stuff to find the components
* cb(null, Course)
* }} />
*
* @param {Location} location
* @param {(error: Error, component: Component<any>) => void} callback
*/
getComponent?(location: Location, callback: (error: Error, component: ReactComponent<any>) => void): void;
/**
* Same as components but asynchronous, useful for code-splitting.
*
* @example
* <Route path="courses/:courseId" getComponents={(location, cb) => {
* // do asynchronous stuff to find the components
* cb(null, {sidebar: CourseSidebar, content: Course})
* }} />
* @param {Location} location
* @param {(error: Error, components: { [name: string]: Component<any> }) => void} callback
*/
getComponent?(location: Location, callback: (error: Error, components: { [name: string]: ReactComponent<any> }) => void): void;
/**
* Routes can be nested, this.props.children will contain the element created from the child route component. Please refer to the Route Configuration since this is a very critical part of the router's design.
*
* @type {Route[]}
*/
children?: Route[];
/**
* Called when a route is about to be entered. It provides the next router state and a function to redirect to another path. this will be the route instance that triggered the hook.
*
* If callback is listed as a 3rd argument, this hook will run asynchronously, and the transition will block until callback is called.
*
* @param {*} nextState
* @param {(location: LocationDescriptor) => void} replace
* @param {() => void} [callback]
*/
onEnter?(nextState: any, replace: (location: LocationDescriptor) => void, callback?: () => void): void;
/**
* Called when a route is about to be exited.
*/
onLeave?(): void;
}
/**
* An <IndexRoute> allows you to provide a default "child" to a parent route when visitor is at the URL of the parent.
*
* @export
* @class IndexRoute
* @extends {React.Component<IIndexRouteProps, {}>}
*/
export class IndexRoute extends React.Component<IIndexRouteProps, {}>{ }
export interface IIndexRedirectProps {
/**
* The path you want to redirect to.
*
* @type {string}
*/
to?: string;
/**
* By default, the query parameters will just pass through but you can specify them if you need to.
*
* @example
* // Say we want to change from `/profile/123` to `/about/123`
* // and redirect `/get-in-touch` to `/contact`
* <Route component={App}>
* <Route path="about/:userId" component={UserProfile} />
* {// /profile/123 -> /about/123 }
* <Redirect from="profile/:userId" to="about/:userId" />
* </Route>
* @description Note that the <Redirect> can be placed anywhere in the route hierarchy, though normal precedence rules apply. If you'd prefer the redirects to be next to their respective routes, the from path will match the same as a regular route path.
* @example
* <Route path="course/:courseId">
* <Route path="dashboard" />
* {// /course/123/home -> /course/123/dashboard }
* <Redirect from="home" to="dashboard" />
* </Route>
* @type {Query}
*/
query?: Query;
}
export class IndexRedirect extends React.Component<IIndexRedirectProps, {}>{ }
//Route Components
//TODO : This feels a little out of place
export interface IRoute {
/**
* Child routes for the current route.
*
* @type {IRoute[]}
*/
childRoutes?: IRoute[];
/**
* Component this route will render
*
* @type {typeof React.Component}
*/
component?: typeof React.Component;
/**
* Path for this route
*
* @type {string}
*/
path?: string;
}
/**
* Extension of all injected props
*
* @export
* @interface IInjectedProps
*/
export interface IInjectedProps {
/**
* The current location.
*
* @type {Location}
*/
location?: Location;
/**
* The dynamic segments of the URL.
*
* @type {Params}
*/
params?: Params
/**
* The route that rendered this component.
*
* @type {IRoute}
*/
route?: IRoute;
/**
* The routes that belonog to this component
*
* @type {IRoute[]}
*/
routes?: IRoute[];
/**
* A subset of this.props.params that were directly specified in this component's route.
* For example, if the route's path is users/:userId and the URL is /users/123/portfolios/345 then this.props.routeParams will be {userId: '123'}, and this.props.params will be {userId: '123', portfolioId: 345}.
*
* @type {Params}
*/
routeParams?: Params
/**
* The matched child route element to be rendered. If the route has named components then this will be undefined, and the components will instead be available as direct properties on this.props.
*
* @example
* render((
* <Router>
* <Route path="/" component={App}>
* <Route path="groups" component={Groups} />
* <Route path="users" component={Users} />
* </Route>
* </Router>
* ), node)
*
* class App extends React.Component {
* render() {
* return (
* <div>
* {// this will be either <Users> or <Groups> }
* {this.props.children}
* </div>
* )
* }
* }
* @type {typeof React.Component}
*/
children?: typeof React.Component;
}
//Histories
/**
* browserHistory uses the HTML5 History API when available, and falls back to full refreshes otherwise. browserHistory requires additional configuration on the server side to serve up URLs, but is the generally preferred solution for modern web pages.
* @export
*/
export const browserHistory: History;
/**
* hashHistory uses URL hashes, along with a query key to keep track of state. hashHistory requires no additional server configuration, but is generally less preferred than browserHistory.
* @export
*/
export const hashHistory: History;
/**
* createMemoryHistory creates an in-memory history object that does not interact with the browser URL. This is useful when you need to customize the history used for server-side rendering, as well as for automated testing.
*
* @export
* @param {HistoryOptions} [options]
*/
export function createMemoryHistory(options?: HistoryOptions): History;
/**
* useRouterHistory is a history enhancer that configures a given createHistory factory to work with React Router. This allows using custom histories in addition to the bundled singleton histories.
*
* @example
* const history = useRouterHistory(createHashHistory)({ queryKey: false })
* @export
* @template TArguments
* @template TResult
* @param {CreateHistory<TArguments, TResult>} createHistory
*/
export function useRouterHistory<TArguments, TResult extends History>(createHistory: CreateHistory<TArguments, TResult>): CreateHistory<TArguments, TResult>;
//Utilities
export interface IMatchArgs extends BasenameOptions, QueryOptions {
routes: RouteConfig;
location: Location;
history?: History;
}
/**
* This function is to be used for server-side rendering. It matches a set of routes to a location, without rendering, and calls a callback(error, redirectLocation, renderProps) when it's done.
*
* The function will create a history for you, passing the additional options along to create it.
* These options can include basename to control the base name for URLs, as well as the pair of parseQueryString and stringifyQuery to control query string parsing and serializing. You can also pass in an
* already instantiated history object, which can be constructed however you like.
*
* The three arguments to the callback function you pass to match are:
*
* error: A Javascript Error object if an error occurred, undefined otherwise.
* redirectLocation: A Location object if the route is a redirect, undefined otherwise.
* renderProps: The props you should pass to the routing context if the route matched, undefined otherwise.
* If all three parameters are undefined, this means that there was no route found matching the given location.
*
* Note: You probably don't want to use this in a browser unless you're doing server-side rendering of async routes.
*
* @export
* @param {routes: RouteConfig}
* @param {(error:Error, redirectLocation:Location, renderProps : Object) => void} callback
*/
export function match(args: IMatchArgs, callback: (error: Error, redirectLocation: Location, renderProps: Object) => void): void;
/**
* Creates and returns an array of routes from the given object which may be a JSX route, a plain object route, or an array of either.
*
* @export
* @param {((Route | PlainRoute)[])} routes
*/
export function createRoutes(routes: (Route | PlainRoute)[]): Route[];
}
export = ReactRouter;