@tanstack/react-router 0.0.1-beta.20 → 0.0.1-beta.200

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,200 @@
1
+ import * as React from 'react';
2
+ import { NoInfer } from '@tanstack/react-store';
3
+ import { MatchRouteOptions, RegisteredRouter, RouterOptions, Router, RouteMatch, RouteByPath, AnyRoute, AnyRouteProps, LinkOptions, ToOptions, ResolveRelativePath, NavigateOptions, ResolveFullPath, ResolveId, AnySearchSchema, ParsePathParams, RouteContext, AnyContext, UseLoaderResult, ResolveFullSearchSchema, RouteConstraints, RoutePaths, RoutesById, RouteIds, RouteById, ParseRoute, AllParams, AnyPathParams, Expand, ResolveAllParams, DeepMergeAll, IsAny } from '@tanstack/router-core';
4
+ declare module '@tanstack/router-core' {
5
+ interface RouterOptions<TRouteTree extends AnyRoute, TDehydrated extends Record<string, any>> {
6
+ Wrap?: React.ComponentType<{
7
+ children: React.ReactNode;
8
+ dehydratedState?: TDehydrated;
9
+ }>;
10
+ }
11
+ interface RegisterRouteComponent<TLoader = unknown, TFullSearchSchema extends Record<string, any> = AnySearchSchema, TAllParams extends AnyPathParams = AnyPathParams, TAllContext extends Record<string, any> = AnyContext> {
12
+ RouteComponent: RouteComponent<RouteProps<TLoader, TFullSearchSchema, TAllParams, TAllContext>>;
13
+ }
14
+ interface RegisterErrorRouteComponent<TFullSearchSchema extends Record<string, any> = AnySearchSchema, TAllParams extends AnyPathParams = AnyPathParams, TAllContext extends Record<string, any> = AnyContext> {
15
+ ErrorRouteComponent: RouteComponent<ErrorRouteProps<TFullSearchSchema, TAllParams, TAllContext>>;
16
+ }
17
+ interface RegisterPendingRouteComponent<TFullSearchSchema extends Record<string, any> = AnySearchSchema, TAllParams extends AnyPathParams = AnyPathParams, TAllContext extends Record<string, any> = AnyContext> {
18
+ PendingRouteComponent: RouteComponent<PendingRouteProps<TFullSearchSchema, TAllParams, TAllContext>>;
19
+ }
20
+ interface Route<TParentRoute extends RouteConstraints['TParentRoute'] = AnyRoute, TPath extends RouteConstraints['TPath'] = '/', TFullPath extends RouteConstraints['TFullPath'] = ResolveFullPath<TParentRoute, TPath>, TCustomId extends RouteConstraints['TCustomId'] = string, TId extends RouteConstraints['TId'] = ResolveId<TParentRoute, TCustomId, TPath>, TLoaderContext extends RouteConstraints['TLoaderContext'] = AnyContext, TLoader = unknown, TSearchSchema extends RouteConstraints['TSearchSchema'] = {}, TFullSearchSchema extends RouteConstraints['TFullSearchSchema'] = ResolveFullSearchSchema<TParentRoute, TSearchSchema>, TParams extends RouteConstraints['TParams'] = Expand<Record<ParsePathParams<TPath>, string>>, TAllParams extends RouteConstraints['TAllParams'] = ResolveAllParams<TParentRoute, TParams>, TRouteContext extends RouteConstraints['TRouteContext'] = RouteContext, TAllContext extends RouteConstraints['TAllContext'] = Expand<DeepMergeAll<[
21
+ IsAny<TParentRoute['types']['context'], {}>,
22
+ TLoaderContext,
23
+ TRouteContext
24
+ ]>>, TRouterContext extends RouteConstraints['TRouterContext'] = AnyContext, TChildren extends RouteConstraints['TChildren'] = unknown, TRouteTree extends RouteConstraints['TRouteTree'] = AnyRoute> {
25
+ useMatch: <TSelected = TAllContext>(opts?: {
26
+ select?: (search: TAllContext) => TSelected;
27
+ }) => TSelected;
28
+ useLoader: <TSelected = TLoader>(opts?: {
29
+ select?: (search: TLoader) => TSelected;
30
+ }) => UseLoaderResult<TSelected>;
31
+ useRouteContext: <TSelected = TAllContext>(opts?: {
32
+ select?: (search: TAllContext) => TSelected;
33
+ }) => TSelected;
34
+ useSearch: <TSelected = TFullSearchSchema>(opts?: {
35
+ select?: (search: TFullSearchSchema) => TSelected;
36
+ }) => TSelected;
37
+ useParams: <TSelected = TAllParams>(opts?: {
38
+ select?: (search: TAllParams) => TSelected;
39
+ }) => TSelected;
40
+ }
41
+ interface RegisterRouteProps<TLoader = unknown, TFullSearchSchema extends Record<string, any> = AnySearchSchema, TAllParams extends AnyPathParams = AnyPathParams, TAllContext extends Record<string, any> = AnyContext> {
42
+ RouteProps: RouteProps<TLoader, TFullSearchSchema, TAllParams, TAllContext>;
43
+ }
44
+ interface RegisterPendingRouteProps<TFullSearchSchema extends Record<string, any> = AnySearchSchema, TAllParams extends AnyPathParams = AnyPathParams, TAllContext extends Record<string, any> = AnyContext> {
45
+ PendingRouteProps: PendingRouteProps<TFullSearchSchema, TAllParams, TAllContext>;
46
+ }
47
+ interface RegisterErrorRouteProps<TFullSearchSchema extends Record<string, any> = AnySearchSchema, TAllParams extends AnyPathParams = AnyPathParams, TAllContext extends Record<string, any> = AnyContext> {
48
+ ErrorRouteProps: ErrorRouteProps;
49
+ }
50
+ }
51
+ export type RouteProps<TLoader = unknown, TFullSearchSchema extends Record<string, any> = AnySearchSchema, TAllParams extends AnyPathParams = AnyPathParams, TAllContext extends Record<string, any> = AnyContext> = {
52
+ useLoader: <TSelected = TLoader>(opts?: {
53
+ select?: (search: TLoader) => TSelected;
54
+ }) => UseLoaderResult<TSelected>;
55
+ useMatch: <TSelected = TAllContext>(opts?: {
56
+ select?: (search: TAllContext) => TSelected;
57
+ }) => TSelected;
58
+ useRouteContext: <TSelected = TAllContext>(opts?: {
59
+ select?: (search: TAllContext) => TSelected;
60
+ }) => TSelected;
61
+ useSearch: <TSelected = TFullSearchSchema>(opts?: {
62
+ select?: (search: TFullSearchSchema) => TSelected;
63
+ }) => TSelected;
64
+ useParams: <TSelected = TAllParams>(opts?: {
65
+ select?: (search: TAllParams) => TSelected;
66
+ }) => TSelected;
67
+ };
68
+ export type ErrorRouteProps<TFullSearchSchema extends Record<string, any> = AnySearchSchema, TAllParams extends AnyPathParams = AnyPathParams, TAllContext extends Record<string, any> = AnyContext> = {
69
+ error: unknown;
70
+ info: {
71
+ componentStack: string;
72
+ };
73
+ } & Omit<RouteProps<unknown, TFullSearchSchema, TAllParams, TAllContext>, 'useLoader'>;
74
+ export type PendingRouteProps<TFullSearchSchema extends Record<string, any> = AnySearchSchema, TAllParams extends AnyPathParams = AnyPathParams, TAllContext extends Record<string, any> = AnyContext> = Omit<RouteProps<unknown, TFullSearchSchema, TAllParams, TAllContext>, 'useLoader'>;
75
+ type ReactNode = any;
76
+ export type SyncRouteComponent<TProps> = ((props: TProps) => ReactNode) | React.LazyExoticComponent<(props: TProps) => ReactNode>;
77
+ export type AsyncRouteComponent<TProps> = SyncRouteComponent<TProps> & {
78
+ preload?: () => Promise<void>;
79
+ };
80
+ export type ErrorRouteComponent = AsyncRouteComponent<ErrorRouteComponentProps>;
81
+ export type ErrorRouteComponentProps = {
82
+ error: Error;
83
+ info: {
84
+ componentStack: string;
85
+ };
86
+ };
87
+ export type AnyRouteComponent = RouteComponent<AnyRouteProps>;
88
+ export type RouteComponent<TProps> = AsyncRouteComponent<TProps>;
89
+ export declare function lazyRouteComponent<T extends Record<string, any>, TKey extends keyof T = 'default'>(importer: () => Promise<T>, exportName?: TKey): T[TKey] extends (props: infer TProps) => any ? AsyncRouteComponent<TProps> : never;
90
+ export type LinkPropsOptions<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RoutePaths<TRouteTree> = '/', TTo extends string = '', TMaskFrom extends RoutePaths<TRouteTree> = '/', TMaskTo extends string = ''> = LinkOptions<TRouteTree, TFrom, TTo, TMaskFrom, TMaskTo> & {
91
+ activeProps?: React.AnchorHTMLAttributes<HTMLAnchorElement> | (() => React.AnchorHTMLAttributes<HTMLAnchorElement>);
92
+ inactiveProps?: React.AnchorHTMLAttributes<HTMLAnchorElement> | (() => React.AnchorHTMLAttributes<HTMLAnchorElement>);
93
+ startTransition?: boolean;
94
+ };
95
+ export type MakeUseMatchRouteOptions<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RoutePaths<TRouteTree> = '/', TTo extends string = '', TMaskFrom extends RoutePaths<TRouteTree> = '/', TMaskTo extends string = ''> = ToOptions<AnyRoute, TFrom, TTo, TMaskFrom, TMaskTo> & MatchRouteOptions;
96
+ export type MakeMatchRouteOptions<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RoutePaths<TRouteTree> = '/', TTo extends string = '', TMaskFrom extends RoutePaths<TRouteTree> = '/', TMaskTo extends string = ''> = ToOptions<TRouteTree, TFrom, TTo, TMaskFrom, TMaskTo> & MatchRouteOptions & {
97
+ children?: ((params?: RouteByPath<TRouteTree, ResolveRelativePath<TFrom, NoInfer<TTo>>>['types']['allParams']) => ReactNode) | React.ReactNode;
98
+ };
99
+ export type MakeLinkPropsOptions<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RoutePaths<TRouteTree> = '/', TTo extends string = '', TMaskFrom extends RoutePaths<TRouteTree> = '/', TMaskTo extends string = ''> = LinkPropsOptions<TRouteTree, TFrom, TTo, TMaskFrom, TMaskTo> & React.AnchorHTMLAttributes<HTMLAnchorElement>;
100
+ export type MakeLinkOptions<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RoutePaths<TRouteTree> = '/', TTo extends string = '', TMaskFrom extends RoutePaths<TRouteTree> = '/', TMaskTo extends string = ''> = LinkPropsOptions<TRouteTree, TFrom, TTo, TMaskFrom, TMaskTo> & Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, 'children'> & {
101
+ children?: React.ReactNode | ((state: {
102
+ isActive: boolean;
103
+ }) => React.ReactNode);
104
+ };
105
+ export type PromptProps = {
106
+ message: string;
107
+ condition?: boolean | any;
108
+ children?: ReactNode;
109
+ };
110
+ export declare function useLinkProps<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RoutePaths<TRouteTree> = '/', TTo extends string = '', TMaskFrom extends RoutePaths<TRouteTree> = '/', TMaskTo extends string = ''>(options: MakeLinkPropsOptions<TRouteTree, TFrom, TTo, TMaskFrom, TMaskTo>): React.AnchorHTMLAttributes<HTMLAnchorElement>;
111
+ export interface LinkComponent<TProps extends Record<string, any> = {}> {
112
+ <TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RoutePaths<TRouteTree> = '/', TTo extends string = '', TMaskFrom extends RoutePaths<TRouteTree> = '/', TMaskTo extends string = ''>(props: MakeLinkOptions<TRouteTree, TFrom, TTo, TMaskFrom, TMaskTo> & TProps & React.RefAttributes<HTMLAnchorElement>): ReactNode;
113
+ }
114
+ export declare const Link: LinkComponent;
115
+ export declare function Navigate<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RoutePaths<TRouteTree> = '/', TTo extends string = '', TMaskFrom extends RoutePaths<TRouteTree> = '/', TMaskTo extends string = ''>(props: NavigateOptions<TRouteTree, TFrom, TTo, TMaskFrom, TMaskTo>): null;
116
+ export declare const matchIdsContext: React.Context<string[]>;
117
+ export declare const routerContext: React.Context<import("@tanstack/router-core").AnyRouter>;
118
+ export type RouterProps<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TDehydrated extends Record<string, any> = Record<string, any>> = Omit<RouterOptions<TRouteTree, TDehydrated>, 'context'> & {
119
+ router: Router<TRouteTree>;
120
+ context?: Partial<RouterOptions<TRouteTree, TDehydrated>['context']>;
121
+ };
122
+ export declare function useRouterState<TSelected = RegisteredRouter['state']>(opts?: {
123
+ select: (state: RegisteredRouter['state']) => TSelected;
124
+ }): TSelected;
125
+ export declare function RouterProvider<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TDehydrated extends Record<string, any> = Record<string, any>>({ router, ...rest }: RouterProps<TRouteTree, TDehydrated>): JSX.Element;
126
+ export declare function useRouter(): RegisteredRouter;
127
+ export declare function useMatches<T = RouteMatch[]>(opts?: {
128
+ select?: (matches: RouteMatch[]) => T;
129
+ }): T;
130
+ type StrictOrFrom<TFrom> = {
131
+ from: TFrom;
132
+ strict?: true;
133
+ } | {
134
+ from?: never;
135
+ strict: false;
136
+ };
137
+ export declare function useMatch<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RouteIds<TRouteTree> = RouteIds<TRouteTree>, TStrict extends boolean = true, TRouteMatchState = RouteMatch<TRouteTree, TFrom>, TSelected = TRouteMatchState>(opts: StrictOrFrom<TFrom> & {
138
+ select?: (match: TRouteMatchState) => TSelected;
139
+ }): TStrict extends true ? TRouteMatchState : TRouteMatchState | undefined;
140
+ export type RouteFromIdOrRoute<T, TRouteTree extends AnyRoute = RegisteredRouter['routeTree']> = T extends ParseRoute<TRouteTree> ? T : T extends RouteIds<TRouteTree> ? RoutesById<TRouteTree>[T] : T extends string ? RouteIds<TRouteTree> : never;
141
+ export declare function useLoader<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RouteIds<TRouteTree> = RouteIds<TRouteTree>, TStrict extends boolean = true, TLoader = RouteById<TRouteTree, TFrom>['types']['loader'], TSelected = TLoader>(opts: StrictOrFrom<TFrom> & {
142
+ select?: (search: TLoader) => TSelected;
143
+ }): TStrict extends true ? TSelected : TSelected | undefined;
144
+ export declare function useRouterContext<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RouteIds<TRouteTree> = RouteIds<TRouteTree>, TStrict extends boolean = true, TContext = RouteById<TRouteTree, TFrom>['types']['context'], TSelected = TContext>(opts: StrictOrFrom<TFrom> & {
145
+ select?: (search: TContext) => TSelected;
146
+ }): TStrict extends true ? TSelected : TSelected | undefined;
147
+ export declare function useRouteContext<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RouteIds<TRouteTree> = RouteIds<TRouteTree>, TStrict extends boolean = true, TRouteContext = RouteById<TRouteTree, TFrom>['types']['context'], TSelected = TRouteContext>(opts: StrictOrFrom<TFrom> & {
148
+ select?: (search: TRouteContext) => TSelected;
149
+ }): TStrict extends true ? TSelected : TSelected | undefined;
150
+ export declare function useSearch<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RouteIds<TRouteTree> = RouteIds<TRouteTree>, TStrict extends boolean = true, TSearch = RouteById<TRouteTree, TFrom>['types']['fullSearchSchema'], TSelected = TSearch>(opts: StrictOrFrom<TFrom> & {
151
+ select?: (search: TSearch) => TSelected;
152
+ }): TStrict extends true ? TSelected : TSelected | undefined;
153
+ export declare function useParams<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RouteIds<TRouteTree> = RouteIds<TRouteTree>, TDefaultSelected = AllParams<TRouteTree> & RouteById<TRouteTree, TFrom>['types']['allParams'], TSelected = TDefaultSelected>(opts: StrictOrFrom<TFrom> & {
154
+ select?: (search: TDefaultSelected) => TSelected;
155
+ }): TSelected;
156
+ export declare function useNavigate<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TDefaultFrom extends RoutePaths<TRouteTree> = '/'>(defaultOpts?: {
157
+ from?: TDefaultFrom;
158
+ }): <TFrom extends RoutePaths<TRouteTree> = TDefaultFrom, TTo extends string = "", TMaskFrom extends RoutePaths<TRouteTree> = "/", TMaskTo extends string = "">(opts?: NavigateOptions<TRouteTree, TFrom, TTo, TMaskFrom, TMaskTo> | undefined) => Promise<void>;
159
+ export declare function useMatchRoute<TRouteTree extends AnyRoute = RegisteredRouter['routeTree']>(): <TFrom extends RoutePaths<TRouteTree> = "/", TTo extends string = "", TMaskFrom extends RoutePaths<TRouteTree> = "/", TMaskTo extends string = "", TResolved extends string = ResolveRelativePath<TFrom, NoInfer<TTo>>>(opts: MakeUseMatchRouteOptions<TRouteTree, TFrom, TTo, TMaskFrom, TMaskTo>) => false | RouteById<TRouteTree, TResolved>["types"]["allParams"];
160
+ export declare function MatchRoute<TRouteTree extends AnyRoute = RegisteredRouter['routeTree'], TFrom extends RoutePaths<TRouteTree> = '/', TTo extends string = '', TMaskFrom extends RoutePaths<TRouteTree> = '/', TMaskTo extends string = ''>(props: MakeMatchRouteOptions<TRouteTree, TFrom, TTo, TMaskFrom, TMaskTo>): any;
161
+ export declare function Outlet(): JSX.Element | null;
162
+ export declare function useInjectHtml(): (html: string | (() => Promise<string> | string)) => void;
163
+ export declare function useDehydrate(): <T>(key: any, data: T | (() => T | Promise<T>)) => () => T | undefined;
164
+ export declare function useHydrate(): <T = unknown>(key: any) => T;
165
+ export declare function CatchBoundary(props: {
166
+ resetKey: string;
167
+ children: any;
168
+ errorComponent?: any;
169
+ onCatch: (error: any) => void;
170
+ }): JSX.Element;
171
+ export declare class CatchBoundaryImpl extends React.Component<{
172
+ resetKey: string;
173
+ children: (props: {
174
+ error: any;
175
+ reset: () => void;
176
+ }) => any;
177
+ onCatch?: (error: any) => void;
178
+ }> {
179
+ state: any;
180
+ static getDerivedStateFromError(error: any): {
181
+ error: any;
182
+ };
183
+ componentDidUpdate(prevProps: Readonly<{
184
+ resetKey: string;
185
+ children: (props: {
186
+ error: any;
187
+ reset: () => void;
188
+ }) => any;
189
+ onCatch?: ((error: any, info: any) => void) | undefined;
190
+ }>, prevState: any): void;
191
+ componentDidCatch(error: any): void;
192
+ render(): any;
193
+ }
194
+ export declare function ErrorComponent({ error }: {
195
+ error: any;
196
+ }): JSX.Element;
197
+ export declare function useBlocker(message: string, condition?: boolean | any): void;
198
+ export declare function Block({ message, condition, children }: PromptProps): any;
199
+ export declare function shallow<T>(objA: T, objB: T): boolean;
200
+ export {};
@@ -0,0 +1,3 @@
1
+ import { ScrollRestorationOptions } from '@tanstack/router-core';
2
+ export declare function useScrollRestoration(options?: ScrollRestorationOptions): void;
3
+ export declare function ScrollRestoration(props: ScrollRestorationOptions): null;