forked from supasate/connected-react-router
-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.d.ts
102 lines (85 loc) · 3.65 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
declare module 'connected-react-router' {
import * as React from 'react';
import { Middleware, Reducer } from 'redux';
import { ReactReduxContextValue } from 'react-redux';
import { match } from 'react-router';
import {
Action,
Hash,
History,
Path,
Location,
LocationState,
LocationDescriptorObject,
Search
} from 'history';
interface ConnectedRouterProps<S = LocationState> {
history: History<S>;
context?: React.Context<ReactReduxContextValue>;
}
export type RouterActionType = Action;
export interface RouterState<S = LocationState> {
location: Location<S>
action: RouterActionType
}
export const LOCATION_CHANGE: '@@router/LOCATION_CHANGE';
export const CALL_HISTORY_METHOD: '@@router/CALL_HISTORY_METHOD';
export interface LocationChangeAction<S = LocationState> {
type: typeof LOCATION_CHANGE;
payload: LocationChangePayload<S>;
}
export interface LocationChangePayload<S = LocationState> extends RouterState<S> {
isFirstRendering: boolean;
}
export interface CallHistoryMethodAction<A = any[]> {
type: typeof CALL_HISTORY_METHOD;
payload: LocationActionPayload<A>;
}
export interface RouterRootState<S = LocationState> {
router: RouterState<S>;
}
export type matchSelectorFn<
S extends RouterRootState, Params extends { [K in keyof Params]?: string }
> = (state: S) => match<Params> | null;
export type RouterAction<S = LocationState> = LocationChangeAction<S> | CallHistoryMethodAction;
export function push<S = LocationState>(path: Path, state?: S): CallHistoryMethodAction<[ Path, S? ]>;
export function push<S = LocationState>(location: LocationDescriptorObject<S>): CallHistoryMethodAction<[ LocationDescriptorObject<S> ]>;
export function replace<S = LocationState>(path: Path, state?: S): CallHistoryMethodAction<[ Path, S? ]>;
export function replace<S = LocationState>(location: LocationDescriptorObject<S>): CallHistoryMethodAction<[ LocationDescriptorObject<S> ]>;
export function go(n: number): CallHistoryMethodAction<[ number ]>;
export function goBack(): CallHistoryMethodAction<[]>;
export function goForward(): CallHistoryMethodAction<[]>;
export function getRouter<S extends RouterRootState<LS>, LS = LocationState>(state: S): RouterState<LS>;
export function getAction<S extends RouterRootState>(state: S): RouterActionType;
export function getHash<S extends RouterRootState>(state: S): Hash;
export function getLocation<S extends RouterRootState<LS>, LS = LocationState>(state: S): Location<LS>;
export function getSearch<S extends RouterRootState>(state: S): Search;
export function createMatchSelector<
S extends RouterRootState, Params extends { [K in keyof Params]?: string }
>(path: string): matchSelectorFn<S, Params>;
export function onLocationChanged<S = LocationState>(location: Location<S>, action: RouterActionType, isFirstRendering?: boolean)
: LocationChangeAction<S>;
export type Push = typeof push;
export type Replace = typeof replace;
export type Go = typeof go;
export type GoBack = typeof goBack;
export type GoForward = typeof goForward;
export const routerActions: {
push: Push;
replace: Replace;
go: Go;
goBack: GoBack;
goForward: GoForward;
};
export interface LocationActionPayload<A = any[]> {
method: string;
args?: A;
}
export class ConnectedRouter<S = LocationState> extends React.Component<
ConnectedRouterProps<S>,
{}
> {}
export function connectRouter<S = LocationState>(history: History<S>)
: Reducer<RouterState<S>, LocationChangeAction<S>>
export function routerMiddleware<S = LocationState>(history: History<S>): Middleware;
}