@tanstack/solid-router
Version:
Modern and scalable routing for Solid applications
71 lines (70 loc) • 3.34 kB
TypeScript
import * as Solid from 'solid-js';
import type { HistoryAction } from '@tanstack/history';
import type { SolidNode } from './route';
import type { AnyRoute, AnyRouter, ParseRoute, RegisteredRouter } from '@tanstack/router-core';
interface ShouldBlockFnLocation<out TRouteId, out TFullPath, out TAllParams, out TFullSearchSchema> {
routeId: TRouteId;
fullPath: TFullPath;
pathname: string;
params: TAllParams;
search: TFullSearchSchema;
}
type MakeShouldBlockFnLocationUnion<TRouter extends AnyRouter = RegisteredRouter, TRoute extends AnyRoute = ParseRoute<TRouter['routeTree']>> = TRoute extends any ? ShouldBlockFnLocation<TRoute['id'], TRoute['fullPath'], TRoute['types']['allParams'], TRoute['types']['fullSearchSchema']> : never;
type BlockerResolver<TRouter extends AnyRouter = RegisteredRouter> = {
status: 'blocked';
current: MakeShouldBlockFnLocationUnion<TRouter>;
next: MakeShouldBlockFnLocationUnion<TRouter>;
action: HistoryAction;
proceed: () => void;
reset: () => void;
} | {
status: 'idle';
current: undefined;
next: undefined;
action: undefined;
proceed: undefined;
reset: undefined;
};
type ShouldBlockFnArgs<TRouter extends AnyRouter = RegisteredRouter> = {
current: MakeShouldBlockFnLocationUnion<TRouter>;
next: MakeShouldBlockFnLocationUnion<TRouter>;
action: HistoryAction;
};
export type ShouldBlockFn<TRouter extends AnyRouter = RegisteredRouter> = (args: ShouldBlockFnArgs<TRouter>) => boolean | Promise<boolean>;
export type UseBlockerOpts<TRouter extends AnyRouter = RegisteredRouter, TWithResolver extends boolean = boolean> = {
shouldBlockFn: ShouldBlockFn<TRouter>;
enableBeforeUnload?: boolean | (() => boolean);
disabled?: boolean;
withResolver?: TWithResolver;
};
type LegacyBlockerFn = () => Promise<any> | any;
type LegacyBlockerOpts = {
blockerFn?: LegacyBlockerFn;
condition?: boolean | any;
};
export declare function useBlocker<TRouter extends AnyRouter = RegisteredRouter, TWithResolver extends boolean = false>(opts: UseBlockerOpts<TRouter, TWithResolver>): TWithResolver extends true ? Solid.Accessor<BlockerResolver<TRouter>> : void;
/**
* @deprecated Use the shouldBlockFn property instead
*/
export declare function useBlocker(blockerFnOrOpts?: LegacyBlockerOpts): Solid.Accessor<BlockerResolver>;
/**
* @deprecated Use the UseBlockerOpts object syntax instead
*/
export declare function useBlocker(blockerFn?: LegacyBlockerFn, condition?: boolean | any): Solid.Accessor<BlockerResolver>;
interface BlockComponent {
<TRouter extends AnyRouter = RegisteredRouter, TWithResolver extends boolean = boolean>(opts: PromptProps<TRouter, TWithResolver>): SolidNode;
/**
* @deprecated Use the UseBlockerOpts property instead
*/
(opts: LegacyPromptProps): SolidNode;
}
export declare const Block: BlockComponent;
type LegacyPromptProps = {
blockerFn?: LegacyBlockerFn;
condition?: boolean | any;
children?: SolidNode | ((params: BlockerResolver) => SolidNode);
};
type PromptProps<TRouter extends AnyRouter = RegisteredRouter, TWithResolver extends boolean = boolean, TParams = TWithResolver extends true ? BlockerResolver<TRouter> : void> = UseBlockerOpts<TRouter, TWithResolver> & {
children?: SolidNode | ((params: TParams) => SolidNode);
};
export {};