[d565449] | 1 | import * as React from "react";
|
---|
| 2 | import type { AgnosticIndexRouteObject, AgnosticNonIndexRouteObject, AgnosticRouteMatch, History, LazyRouteFunction, Location, Action as NavigationType, RelativeRoutingType, Router, StaticHandlerContext, To, TrackedPromise } from "@remix-run/router";
|
---|
| 3 | export interface IndexRouteObject {
|
---|
| 4 | caseSensitive?: AgnosticIndexRouteObject["caseSensitive"];
|
---|
| 5 | path?: AgnosticIndexRouteObject["path"];
|
---|
| 6 | id?: AgnosticIndexRouteObject["id"];
|
---|
| 7 | loader?: AgnosticIndexRouteObject["loader"];
|
---|
| 8 | action?: AgnosticIndexRouteObject["action"];
|
---|
| 9 | hasErrorBoundary?: AgnosticIndexRouteObject["hasErrorBoundary"];
|
---|
| 10 | shouldRevalidate?: AgnosticIndexRouteObject["shouldRevalidate"];
|
---|
| 11 | handle?: AgnosticIndexRouteObject["handle"];
|
---|
| 12 | index: true;
|
---|
| 13 | children?: undefined;
|
---|
| 14 | element?: React.ReactNode | null;
|
---|
| 15 | hydrateFallbackElement?: React.ReactNode | null;
|
---|
| 16 | errorElement?: React.ReactNode | null;
|
---|
| 17 | Component?: React.ComponentType | null;
|
---|
| 18 | HydrateFallback?: React.ComponentType | null;
|
---|
| 19 | ErrorBoundary?: React.ComponentType | null;
|
---|
| 20 | lazy?: LazyRouteFunction<RouteObject>;
|
---|
| 21 | }
|
---|
| 22 | export interface NonIndexRouteObject {
|
---|
| 23 | caseSensitive?: AgnosticNonIndexRouteObject["caseSensitive"];
|
---|
| 24 | path?: AgnosticNonIndexRouteObject["path"];
|
---|
| 25 | id?: AgnosticNonIndexRouteObject["id"];
|
---|
| 26 | loader?: AgnosticNonIndexRouteObject["loader"];
|
---|
| 27 | action?: AgnosticNonIndexRouteObject["action"];
|
---|
| 28 | hasErrorBoundary?: AgnosticNonIndexRouteObject["hasErrorBoundary"];
|
---|
| 29 | shouldRevalidate?: AgnosticNonIndexRouteObject["shouldRevalidate"];
|
---|
| 30 | handle?: AgnosticNonIndexRouteObject["handle"];
|
---|
| 31 | index?: false;
|
---|
| 32 | children?: RouteObject[];
|
---|
| 33 | element?: React.ReactNode | null;
|
---|
| 34 | hydrateFallbackElement?: React.ReactNode | null;
|
---|
| 35 | errorElement?: React.ReactNode | null;
|
---|
| 36 | Component?: React.ComponentType | null;
|
---|
| 37 | HydrateFallback?: React.ComponentType | null;
|
---|
| 38 | ErrorBoundary?: React.ComponentType | null;
|
---|
| 39 | lazy?: LazyRouteFunction<RouteObject>;
|
---|
| 40 | }
|
---|
| 41 | export type RouteObject = IndexRouteObject | NonIndexRouteObject;
|
---|
| 42 | export type DataRouteObject = RouteObject & {
|
---|
| 43 | children?: DataRouteObject[];
|
---|
| 44 | id: string;
|
---|
| 45 | };
|
---|
| 46 | export interface RouteMatch<ParamKey extends string = string, RouteObjectType extends RouteObject = RouteObject> extends AgnosticRouteMatch<ParamKey, RouteObjectType> {
|
---|
| 47 | }
|
---|
| 48 | export interface DataRouteMatch extends RouteMatch<string, DataRouteObject> {
|
---|
| 49 | }
|
---|
| 50 | export interface DataRouterContextObject extends Omit<NavigationContextObject, "future"> {
|
---|
| 51 | router: Router;
|
---|
| 52 | staticContext?: StaticHandlerContext;
|
---|
| 53 | }
|
---|
| 54 | export declare const DataRouterContext: React.Context<DataRouterContextObject | null>;
|
---|
| 55 | export declare const DataRouterStateContext: React.Context<import("@remix-run/router").RouterState | null>;
|
---|
| 56 | export declare const AwaitContext: React.Context<TrackedPromise | null>;
|
---|
| 57 | export interface NavigateOptions {
|
---|
| 58 | replace?: boolean;
|
---|
| 59 | state?: any;
|
---|
| 60 | preventScrollReset?: boolean;
|
---|
| 61 | relative?: RelativeRoutingType;
|
---|
[0c6b92a] | 62 | flushSync?: boolean;
|
---|
| 63 | viewTransition?: boolean;
|
---|
[d565449] | 64 | }
|
---|
| 65 | /**
|
---|
| 66 | * A Navigator is a "location changer"; it's how you get to different locations.
|
---|
| 67 | *
|
---|
| 68 | * Every history instance conforms to the Navigator interface, but the
|
---|
| 69 | * distinction is useful primarily when it comes to the low-level `<Router>` API
|
---|
| 70 | * where both the location and a navigator must be provided separately in order
|
---|
| 71 | * to avoid "tearing" that may occur in a suspense-enabled app if the action
|
---|
| 72 | * and/or location were to be read directly from the history instance.
|
---|
| 73 | */
|
---|
| 74 | export interface Navigator {
|
---|
| 75 | createHref: History["createHref"];
|
---|
| 76 | encodeLocation?: History["encodeLocation"];
|
---|
| 77 | go: History["go"];
|
---|
| 78 | push(to: To, state?: any, opts?: NavigateOptions): void;
|
---|
| 79 | replace(to: To, state?: any, opts?: NavigateOptions): void;
|
---|
| 80 | }
|
---|
| 81 | interface NavigationContextObject {
|
---|
| 82 | basename: string;
|
---|
| 83 | navigator: Navigator;
|
---|
| 84 | static: boolean;
|
---|
| 85 | future: {
|
---|
| 86 | v7_relativeSplatPath: boolean;
|
---|
| 87 | };
|
---|
| 88 | }
|
---|
| 89 | export declare const NavigationContext: React.Context<NavigationContextObject>;
|
---|
| 90 | interface LocationContextObject {
|
---|
| 91 | location: Location;
|
---|
| 92 | navigationType: NavigationType;
|
---|
| 93 | }
|
---|
| 94 | export declare const LocationContext: React.Context<LocationContextObject>;
|
---|
| 95 | export interface RouteContextObject {
|
---|
| 96 | outlet: React.ReactElement | null;
|
---|
| 97 | matches: RouteMatch[];
|
---|
| 98 | isDataRoute: boolean;
|
---|
| 99 | }
|
---|
| 100 | export declare const RouteContext: React.Context<RouteContextObject>;
|
---|
| 101 | export declare const RouteErrorContext: React.Context<any>;
|
---|
| 102 | export {};
|
---|