@real-router/core 0.41.0 → 0.43.0
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.
- package/dist/cjs/Router-73rMK2YI.d.ts +409 -0
- package/dist/cjs/Router-NL2_9FQk.js +6 -0
- package/dist/cjs/Router-NL2_9FQk.js.map +1 -0
- package/dist/cjs/RouterError-BkgjTHQg.js +2 -0
- package/dist/cjs/RouterError-BkgjTHQg.js.map +1 -0
- package/dist/cjs/RouterValidator-TUi8eT8Q.d.ts +112 -0
- package/dist/cjs/api.d.ts +17 -12
- package/dist/cjs/api.js +2 -1
- package/dist/cjs/api.js.map +1 -1
- package/dist/cjs/getPluginApi-BXrM_Nwv.js +2 -0
- package/dist/cjs/getPluginApi-BXrM_Nwv.js.map +1 -0
- package/dist/cjs/index.d.ts +206 -196
- package/dist/cjs/index.js +2 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/internals-na15rxo_.js +2 -0
- package/dist/cjs/internals-na15rxo_.js.map +1 -0
- package/dist/cjs/utils.d.ts +6 -3
- package/dist/cjs/utils.js +2 -1
- package/dist/cjs/utils.js.map +1 -1
- package/dist/cjs/validation.d.ts +153 -152
- package/dist/cjs/validation.js +1 -1
- package/dist/esm/Router-BhDMI4UX.d.mts +409 -0
- package/dist/esm/Router-CUi2TqAr.mjs +6 -0
- package/dist/esm/Router-CUi2TqAr.mjs.map +1 -0
- package/dist/esm/RouterError-D0RlQE_5.mjs +2 -0
- package/dist/esm/RouterError-D0RlQE_5.mjs.map +1 -0
- package/dist/esm/RouterValidator-DphcVMEp.d.mts +112 -0
- package/dist/esm/api.d.mts +17 -12
- package/dist/esm/api.mjs +2 -1
- package/dist/esm/api.mjs.map +1 -1
- package/dist/esm/getPluginApi-D0bBPuLp.mjs +2 -0
- package/dist/esm/getPluginApi-D0bBPuLp.mjs.map +1 -0
- package/dist/esm/index.d.mts +206 -196
- package/dist/esm/index.mjs +2 -1
- package/dist/esm/index.mjs.map +1 -1
- package/dist/esm/internals-CCymabFj.mjs +2 -0
- package/dist/esm/internals-CCymabFj.mjs.map +1 -0
- package/dist/esm/utils.d.mts +6 -3
- package/dist/esm/utils.mjs +2 -1
- package/dist/esm/utils.mjs.map +1 -1
- package/dist/esm/validation.d.mts +153 -152
- package/dist/esm/validation.mjs +1 -1
- package/package.json +5 -7
- package/src/helpers.ts +9 -6
- package/src/namespaces/OptionsNamespace/constants.ts +3 -5
- package/dist/cjs/Router-DoJ3NWsT.d.ts +0 -46
- package/dist/cjs/RouterValidator-CaIeCVeB.d.ts +0 -136
- package/dist/cjs/index.d-y2b-8_3Y.d.ts +0 -236
- package/dist/cjs/metafile-cjs.json +0 -1
- package/dist/cjs/validation.js.map +0 -1
- package/dist/esm/Router-DoJ3NWsT.d.mts +0 -46
- package/dist/esm/RouterValidator-CaIeCVeB.d.mts +0 -136
- package/dist/esm/chunk-EPF2YSMX.mjs +0 -1
- package/dist/esm/chunk-EPF2YSMX.mjs.map +0 -1
- package/dist/esm/chunk-UPJLWPEL.mjs +0 -1
- package/dist/esm/chunk-UPJLWPEL.mjs.map +0 -1
- package/dist/esm/chunk-UUG7DSTN.mjs +0 -1
- package/dist/esm/chunk-UUG7DSTN.mjs.map +0 -1
- package/dist/esm/chunk-XQJDGUQE.mjs +0 -1
- package/dist/esm/chunk-XQJDGUQE.mjs.map +0 -1
- package/dist/esm/index.d-y2b-8_3Y.d.mts +0 -236
- package/dist/esm/metafile-esm.json +0 -1
- package/dist/esm/validation.mjs.map +0 -1
|
@@ -0,0 +1,409 @@
|
|
|
1
|
+
import { DefaultDependencies, EventMethodMap, GuardFnFactory, LimitsConfig, NavigationOptions, Options, Params, PluginFactory, Route, RouteConfigUpdate, RouteTreeState, Router, State, SubscribeFn, Unsubscribe } from "@real-router/types";
|
|
2
|
+
|
|
3
|
+
//#region ../path-matcher/dist/esm/index.d.mts
|
|
4
|
+
//#region src/types.d.ts
|
|
5
|
+
/**
|
|
6
|
+
* Path Matcher Type Definitions.
|
|
7
|
+
*
|
|
8
|
+
* Core types for path matching and parameter extraction.
|
|
9
|
+
*
|
|
10
|
+
* @module path-matcher/types
|
|
11
|
+
*/
|
|
12
|
+
/**
|
|
13
|
+
* Constraint pattern for a URL parameter.
|
|
14
|
+
*/
|
|
15
|
+
interface ConstraintPattern {
|
|
16
|
+
/**
|
|
17
|
+
* Compiled RegExp for validating the parameter value.
|
|
18
|
+
*
|
|
19
|
+
* @example /^(\d+)$/ for constraint "<\\d+>"
|
|
20
|
+
*/
|
|
21
|
+
readonly pattern: RegExp;
|
|
22
|
+
/**
|
|
23
|
+
* Raw constraint string from the route pattern.
|
|
24
|
+
*
|
|
25
|
+
* @example "<\\d+>"
|
|
26
|
+
*/
|
|
27
|
+
readonly constraint: string;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Parameter metadata extracted from a route path pattern.
|
|
31
|
+
*/
|
|
32
|
+
interface ParamMeta {
|
|
33
|
+
/**
|
|
34
|
+
* URL parameter names extracted from the path pattern.
|
|
35
|
+
*
|
|
36
|
+
* @example [":id", ":postId"] from "/users/:id/posts/:postId"
|
|
37
|
+
*/
|
|
38
|
+
readonly urlParams: readonly string[];
|
|
39
|
+
/**
|
|
40
|
+
* Query parameter names extracted from the path pattern.
|
|
41
|
+
*
|
|
42
|
+
* @example ["q", "page"] from "/search?q&page"
|
|
43
|
+
*/
|
|
44
|
+
readonly queryParams: readonly string[];
|
|
45
|
+
/**
|
|
46
|
+
* Splat parameter names extracted from the path pattern.
|
|
47
|
+
*
|
|
48
|
+
* @example ["path"] from "/files/*path"
|
|
49
|
+
*/
|
|
50
|
+
readonly spatParams: readonly string[];
|
|
51
|
+
/**
|
|
52
|
+
* Map of parameter names to their type (url or query).
|
|
53
|
+
*
|
|
54
|
+
* @example { id: "url", q: "query" }
|
|
55
|
+
*/
|
|
56
|
+
readonly paramTypeMap: Readonly<Record<string, "url" | "query">>;
|
|
57
|
+
/**
|
|
58
|
+
* Map of parameter names to their constraint patterns.
|
|
59
|
+
*
|
|
60
|
+
* Only includes parameters with explicit constraints (e.g., `:id<\\d+>`).
|
|
61
|
+
* Parameters without constraints are not included in this map.
|
|
62
|
+
*
|
|
63
|
+
* @example
|
|
64
|
+
* ```typescript
|
|
65
|
+
* buildParamMeta("/users/:id<\\d+>").constraintPatterns.get("id")
|
|
66
|
+
* // → { pattern: /^(\d+)$/, constraint: "<\\d+>" }
|
|
67
|
+
*
|
|
68
|
+
* buildParamMeta("/users/:id").constraintPatterns.size
|
|
69
|
+
* // → 0 (no constraints)
|
|
70
|
+
* ```
|
|
71
|
+
*/
|
|
72
|
+
readonly constraintPatterns: ReadonlyMap<string, ConstraintPattern>;
|
|
73
|
+
/**
|
|
74
|
+
* Path pattern without query string, pre-computed for buildPath.
|
|
75
|
+
*
|
|
76
|
+
* @example "/users/:id" from "/users/:id?q&page"
|
|
77
|
+
*/
|
|
78
|
+
readonly pathPattern: string;
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* URL parameter encoding strategies.
|
|
82
|
+
*
|
|
83
|
+
* - `default` - encodeURIComponent preserving sub-delimiters (+, :, ', !, ,, ;, *)
|
|
84
|
+
* - `uri` - encodeURI/decodeURI
|
|
85
|
+
* - `uriComponent` - encodeURIComponent/decodeURIComponent
|
|
86
|
+
* - `none` - no encoding/decoding
|
|
87
|
+
*/
|
|
88
|
+
type URLParamsEncodingType = "default" | "uri" | "uriComponent" | "none";
|
|
89
|
+
interface MatcherInputNode {
|
|
90
|
+
readonly name: string;
|
|
91
|
+
readonly path: string;
|
|
92
|
+
readonly fullName: string;
|
|
93
|
+
readonly absolute: boolean;
|
|
94
|
+
readonly children: ReadonlyMap<string, MatcherInputNode>;
|
|
95
|
+
readonly nonAbsoluteChildren: readonly MatcherInputNode[];
|
|
96
|
+
readonly paramMeta: ParamMeta;
|
|
97
|
+
readonly paramTypeMap: Readonly<Record<string, "url" | "query">>;
|
|
98
|
+
readonly staticPath: string | null;
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Per-call options for buildPath.
|
|
102
|
+
*/
|
|
103
|
+
interface BuildPathOptions {
|
|
104
|
+
readonly queryParamsMode?: "default" | "strict" | "loose" | undefined;
|
|
105
|
+
readonly trailingSlash?: "default" | "always" | "never" | undefined;
|
|
106
|
+
}
|
|
107
|
+
interface MatchResult {
|
|
108
|
+
readonly segments: readonly MatcherInputNode[];
|
|
109
|
+
readonly params: Readonly<Record<string, unknown>>;
|
|
110
|
+
readonly meta: Readonly<Record<string, Record<string, "url" | "query">>>;
|
|
111
|
+
}
|
|
112
|
+
interface SegmentMatcherOptions {
|
|
113
|
+
caseSensitive?: boolean;
|
|
114
|
+
strictTrailingSlash?: boolean;
|
|
115
|
+
strictQueryParams?: boolean;
|
|
116
|
+
urlParamsEncoding?: URLParamsEncodingType;
|
|
117
|
+
parseQueryString?: (queryString: string) => Record<string, unknown>;
|
|
118
|
+
buildQueryString?: (params: Record<string, unknown>) => string;
|
|
119
|
+
}
|
|
120
|
+
interface ResolvedMatcherOptions {
|
|
121
|
+
readonly caseSensitive: boolean;
|
|
122
|
+
readonly strictTrailingSlash: boolean;
|
|
123
|
+
readonly strictQueryParams: boolean;
|
|
124
|
+
readonly urlParamsEncoding: URLParamsEncodingType;
|
|
125
|
+
readonly parseQueryString: (queryString: string) => Record<string, unknown>;
|
|
126
|
+
readonly buildQueryString: (params: Record<string, unknown>) => string;
|
|
127
|
+
} //#endregion
|
|
128
|
+
//#region src/buildParamMeta.d.ts
|
|
129
|
+
/**
|
|
130
|
+
* Builds parameter metadata from a route path pattern.
|
|
131
|
+
*
|
|
132
|
+
* Extracts URL parameters, query parameters, and splat parameters
|
|
133
|
+
* from the path pattern string.
|
|
134
|
+
*
|
|
135
|
+
* @param path - Route path pattern (e.g., "/users/:id/posts/:postId?q")
|
|
136
|
+
* @returns Parameter metadata object
|
|
137
|
+
*
|
|
138
|
+
* @example
|
|
139
|
+
* ```typescript
|
|
140
|
+
* buildParamMeta("/users/:id")
|
|
141
|
+
* // → {
|
|
142
|
+
* // urlParams: ["id"],
|
|
143
|
+
* // queryParams: [],
|
|
144
|
+
* // spatParams: [],
|
|
145
|
+
* // paramTypeMap: { id: "url" }
|
|
146
|
+
* // }
|
|
147
|
+
*
|
|
148
|
+
* buildParamMeta("/search?q&page")
|
|
149
|
+
* // → {
|
|
150
|
+
* // urlParams: [],
|
|
151
|
+
* // queryParams: ["q", "page"],
|
|
152
|
+
* // spatParams: [],
|
|
153
|
+
* // paramTypeMap: { q: "query", page: "query" }
|
|
154
|
+
* // }
|
|
155
|
+
*
|
|
156
|
+
* buildParamMeta("/files/*path")
|
|
157
|
+
* // → {
|
|
158
|
+
* // urlParams: ["path"],
|
|
159
|
+
* // queryParams: [],
|
|
160
|
+
* // spatParams: ["path"],
|
|
161
|
+
* // paramTypeMap: { path: "url" }
|
|
162
|
+
* // }
|
|
163
|
+
*
|
|
164
|
+
* buildParamMeta("/users/:id/posts/:postId?q&page")
|
|
165
|
+
* // → {
|
|
166
|
+
* // urlParams: ["id", "postId"],
|
|
167
|
+
* // queryParams: ["q", "page"],
|
|
168
|
+
* // spatParams: [],
|
|
169
|
+
* // paramTypeMap: { id: "url", postId: "url", q: "query", page: "query" }
|
|
170
|
+
* // }
|
|
171
|
+
* ```
|
|
172
|
+
*/
|
|
173
|
+
//#endregion
|
|
174
|
+
//#region src/SegmentMatcher.d.ts
|
|
175
|
+
declare class SegmentMatcher {
|
|
176
|
+
#private;
|
|
177
|
+
get options(): ResolvedMatcherOptions;
|
|
178
|
+
constructor(options?: SegmentMatcherOptions);
|
|
179
|
+
registerTree(node: MatcherInputNode): void;
|
|
180
|
+
match(path: string): MatchResult | undefined;
|
|
181
|
+
buildPath(name: string, params?: Record<string, unknown>, options?: BuildPathOptions): string;
|
|
182
|
+
getSegmentsByName(name: string): readonly MatcherInputNode[] | undefined;
|
|
183
|
+
getMetaByName(name: string): Readonly<Record<string, Record<string, "url" | "query">>> | undefined;
|
|
184
|
+
hasRoute(name: string): boolean;
|
|
185
|
+
setRootPath(rootPath: string): void;
|
|
186
|
+
} //#endregion
|
|
187
|
+
//#endregion
|
|
188
|
+
//#region ../search-params/dist/esm/index.d.mts
|
|
189
|
+
//#region src/types.d.ts
|
|
190
|
+
/**
|
|
191
|
+
* Search Params Type Definitions.
|
|
192
|
+
*
|
|
193
|
+
* Consolidated interfaces and type aliases for the search-params module.
|
|
194
|
+
*
|
|
195
|
+
* @module search-params/types
|
|
196
|
+
*/
|
|
197
|
+
/**
|
|
198
|
+
* Array parameter encoding format.
|
|
199
|
+
*
|
|
200
|
+
* @remarks
|
|
201
|
+
* - `none` - repeated keys: `a=1&a=2`
|
|
202
|
+
* - `brackets` - bracket notation: `a[]=1&a[]=2`
|
|
203
|
+
* - `index` - indexed notation: `a[0]=1&a[1]=2`
|
|
204
|
+
* - `comma` - comma-separated: `a=1,2`
|
|
205
|
+
*/
|
|
206
|
+
type ArrayFormat = "none" | "brackets" | "index" | "comma";
|
|
207
|
+
/**
|
|
208
|
+
* Boolean parameter encoding format.
|
|
209
|
+
*
|
|
210
|
+
* @remarks
|
|
211
|
+
* - `none` - no special handling
|
|
212
|
+
* - `auto` - auto-detect "true"/"false" strings as boolean values
|
|
213
|
+
* - `empty-true` - true values have no value: `?flag` instead of `?flag=true`
|
|
214
|
+
*/
|
|
215
|
+
type BooleanFormat = "none" | "auto" | "empty-true";
|
|
216
|
+
/**
|
|
217
|
+
* Null parameter encoding format.
|
|
218
|
+
*
|
|
219
|
+
* @remarks
|
|
220
|
+
* - `default` - key only: `?key`
|
|
221
|
+
* - `hidden` - omit from query string
|
|
222
|
+
*/
|
|
223
|
+
type NullFormat = "default" | "hidden";
|
|
224
|
+
/**
|
|
225
|
+
* Number parameter encoding format.
|
|
226
|
+
*
|
|
227
|
+
* @remarks
|
|
228
|
+
* - `none` - no special handling
|
|
229
|
+
* - `auto` - decode numeric strings (/^\d+(\.\d+)?$/) to Number()
|
|
230
|
+
*/
|
|
231
|
+
type NumberFormat = "none" | "auto";
|
|
232
|
+
/**
|
|
233
|
+
* Options for search-params parsing and building.
|
|
234
|
+
*/
|
|
235
|
+
interface Options$1 {
|
|
236
|
+
/** Array parameter encoding format. @default "none" */
|
|
237
|
+
arrayFormat?: ArrayFormat;
|
|
238
|
+
/** Boolean parameter encoding format. @default "auto" */
|
|
239
|
+
booleanFormat?: BooleanFormat;
|
|
240
|
+
/** Null parameter encoding format. @default "default" */
|
|
241
|
+
nullFormat?: NullFormat;
|
|
242
|
+
/** Number parameter encoding format. @default "auto" */
|
|
243
|
+
numberFormat?: NumberFormat;
|
|
244
|
+
}
|
|
245
|
+
/**
|
|
246
|
+
* Internal options with all required fields.
|
|
247
|
+
*/
|
|
248
|
+
//#endregion
|
|
249
|
+
//#region ../route-tree/dist/esm/index.d.mts
|
|
250
|
+
//#region src/builder/types.d.ts
|
|
251
|
+
/**
|
|
252
|
+
* Definition of a route for configuration.
|
|
253
|
+
*/
|
|
254
|
+
interface RouteDefinition {
|
|
255
|
+
[key: string]: unknown;
|
|
256
|
+
name: string;
|
|
257
|
+
path: string;
|
|
258
|
+
children?: RouteDefinition[] | undefined;
|
|
259
|
+
}
|
|
260
|
+
/**
|
|
261
|
+
* Immutable route tree node.
|
|
262
|
+
*
|
|
263
|
+
* This is the core data structure of the new route-tree architecture.
|
|
264
|
+
* It contains only data (no methods) and is created by the builder.
|
|
265
|
+
*
|
|
266
|
+
* All caches are pre-computed at build time:
|
|
267
|
+
* - nonAbsoluteChildren: filtered children without absolute paths
|
|
268
|
+
* - absoluteDescendants: all descendants with absolute paths (recursive)
|
|
269
|
+
* - parentSegments: array from root to parent
|
|
270
|
+
* - fullName: pre-computed "users.profile" instead of runtime join
|
|
271
|
+
*/
|
|
272
|
+
interface RouteTree {
|
|
273
|
+
/** Route segment name (e.g., "users" in "users.profile") */
|
|
274
|
+
readonly name: string;
|
|
275
|
+
/** Route path pattern (e.g., "/users/:id") */
|
|
276
|
+
readonly path: string;
|
|
277
|
+
/** Whether this route uses absolute path matching (path starts with "~") */
|
|
278
|
+
readonly absolute: boolean;
|
|
279
|
+
/** Child route nodes (Map for O(1) lookup by name) */
|
|
280
|
+
readonly children: ReadonlyMap<string, RouteTree>;
|
|
281
|
+
/** Parameter metadata extracted from path pattern (replaces parser dependency) */
|
|
282
|
+
readonly paramMeta: ParamMeta;
|
|
283
|
+
/** Parent node (null for root) */
|
|
284
|
+
readonly parent: RouteTree | null;
|
|
285
|
+
/** Children without absolute paths (for regular matching) */
|
|
286
|
+
readonly nonAbsoluteChildren: readonly RouteTree[];
|
|
287
|
+
/** Pre-computed full name (e.g., "users.profile") */
|
|
288
|
+
readonly fullName: string;
|
|
289
|
+
/**
|
|
290
|
+
* Pre-computed static path for routes without parameters.
|
|
291
|
+
* Used by buildPath fast path to avoid inject() overhead.
|
|
292
|
+
* Only set when route has no URL params, query params, or splat params.
|
|
293
|
+
*/
|
|
294
|
+
readonly staticPath: string | null;
|
|
295
|
+
/**
|
|
296
|
+
* Pre-computed parameter type map for this segment.
|
|
297
|
+
* Cached to avoid recomputing on every navigation.
|
|
298
|
+
* Maps param name → "url" | "query".
|
|
299
|
+
*/
|
|
300
|
+
readonly paramTypeMap: Readonly<Record<string, "url" | "query">>;
|
|
301
|
+
}
|
|
302
|
+
/**
|
|
303
|
+
* Options for building a route tree.
|
|
304
|
+
*/
|
|
305
|
+
//#endregion
|
|
306
|
+
//#region src/createMatcher.d.ts
|
|
307
|
+
/**
|
|
308
|
+
* Query string formatting options.
|
|
309
|
+
*
|
|
310
|
+
* Controls how arrays, booleans, nulls, and numbers are serialized in query strings.
|
|
311
|
+
*/
|
|
312
|
+
type QueryParamsConfig = Readonly<Options$1>;
|
|
313
|
+
/**
|
|
314
|
+
* Options for creating a path matcher.
|
|
315
|
+
*/
|
|
316
|
+
interface CreateMatcherOptions {
|
|
317
|
+
readonly caseSensitive?: boolean;
|
|
318
|
+
readonly strictTrailingSlash?: boolean;
|
|
319
|
+
readonly strictQueryParams?: boolean;
|
|
320
|
+
readonly urlParamsEncoding?: "default" | "uri" | "uriComponent" | "none";
|
|
321
|
+
readonly queryParams?: QueryParamsConfig;
|
|
322
|
+
}
|
|
323
|
+
/**
|
|
324
|
+
* Path matcher instance type.
|
|
325
|
+
*
|
|
326
|
+
* Opaque type — consumers use methods (match, buildPath, hasRoute, etc.)
|
|
327
|
+
* without knowing the underlying SegmentMatcher implementation.
|
|
328
|
+
*/
|
|
329
|
+
type Matcher = SegmentMatcher;
|
|
330
|
+
/**
|
|
331
|
+
* Creates a path matcher with search-params DI baked in.
|
|
332
|
+
*
|
|
333
|
+
* @param options - Matcher configuration
|
|
334
|
+
* @returns Configured matcher instance
|
|
335
|
+
*
|
|
336
|
+
* @example
|
|
337
|
+
* ```typescript
|
|
338
|
+
* const matcher = createMatcher({
|
|
339
|
+
* strictTrailingSlash: true,
|
|
340
|
+
* queryParams: { booleanFormat: "auto" },
|
|
341
|
+
* });
|
|
342
|
+
* matcher.registerTree(tree);
|
|
343
|
+
* const result = matcher.match("/users/123");
|
|
344
|
+
* ```
|
|
345
|
+
*/
|
|
346
|
+
//#endregion
|
|
347
|
+
//#region src/types.d.ts
|
|
348
|
+
/**
|
|
349
|
+
* Immutable limits configuration type.
|
|
350
|
+
*/
|
|
351
|
+
type Limits = Readonly<LimitsConfig>;
|
|
352
|
+
/**
|
|
353
|
+
* Extended build result that includes segments for path building.
|
|
354
|
+
* Used internally to avoid duplicate getSegmentsByName calls.
|
|
355
|
+
*
|
|
356
|
+
* @param segments - Route segments from getSegmentsByName (typed as unknown[] for cross-package compatibility)
|
|
357
|
+
* @internal
|
|
358
|
+
*/
|
|
359
|
+
interface BuildStateResultWithSegments<P extends Params = Params> {
|
|
360
|
+
readonly state: RouteTreeState<P>;
|
|
361
|
+
readonly segments: readonly unknown[];
|
|
362
|
+
}
|
|
363
|
+
//#endregion
|
|
364
|
+
//#region src/Router.d.ts
|
|
365
|
+
/**
|
|
366
|
+
* Router class with integrated namespace architecture.
|
|
367
|
+
*
|
|
368
|
+
* All functionality is provided by namespace classes:
|
|
369
|
+
* - OptionsNamespace: getOptions (immutable)
|
|
370
|
+
* - DependenciesStore: get/set/remove dependencies
|
|
371
|
+
* - EventEmitter: subscribe
|
|
372
|
+
* - StateNamespace: state storage (getState, setState, getPreviousState)
|
|
373
|
+
* - RoutesNamespace: route tree operations
|
|
374
|
+
* - RouteLifecycleNamespace: canActivate/canDeactivate guards
|
|
375
|
+
* - PluginsNamespace: plugin lifecycle
|
|
376
|
+
* - NavigationNamespace: navigate
|
|
377
|
+
* - RouterLifecycleNamespace: start, stop, isStarted
|
|
378
|
+
*
|
|
379
|
+
* @internal This class implementation is internal. Use createRouter() instead.
|
|
380
|
+
*/
|
|
381
|
+
declare class Router$1<Dependencies extends DefaultDependencies = DefaultDependencies> implements Router<Dependencies> {
|
|
382
|
+
#private;
|
|
383
|
+
[key: string]: unknown;
|
|
384
|
+
/**
|
|
385
|
+
* @param routes - Route definitions
|
|
386
|
+
* @param options - Router options
|
|
387
|
+
* @param dependencies - DI dependencies
|
|
388
|
+
*/
|
|
389
|
+
constructor(routes?: Route<Dependencies>[], options?: Partial<Options>, dependencies?: Dependencies);
|
|
390
|
+
isActiveRoute(name: string, params?: Params, strictEquality?: boolean, ignoreQueryParams?: boolean): boolean;
|
|
391
|
+
buildPath(route: string, params?: Params): string;
|
|
392
|
+
getState<P extends Params = Params>(): State<P> | undefined;
|
|
393
|
+
getPreviousState(): State | undefined;
|
|
394
|
+
areStatesEqual(state1: State | undefined, state2: State | undefined, ignoreQueryParams?: boolean): boolean;
|
|
395
|
+
shouldUpdateNode(nodeName: string): (toState: State, fromState?: State) => boolean;
|
|
396
|
+
isActive(): boolean;
|
|
397
|
+
start(startPath: string): Promise<State>;
|
|
398
|
+
stop(): this;
|
|
399
|
+
dispose(): void;
|
|
400
|
+
canNavigateTo(name: string, params?: Params): boolean;
|
|
401
|
+
usePlugin(...plugins: (PluginFactory<Dependencies> | false | null | undefined)[]): Unsubscribe;
|
|
402
|
+
subscribe(listener: SubscribeFn): Unsubscribe;
|
|
403
|
+
navigate(routeName: string, routeParams?: Params, options?: NavigationOptions): Promise<State>;
|
|
404
|
+
navigateToDefault(options?: NavigationOptions): Promise<State>;
|
|
405
|
+
navigateToNotFound(path?: string): State;
|
|
406
|
+
}
|
|
407
|
+
//#endregion
|
|
408
|
+
export { Limits as a, RouteConfigUpdate as c, RouteDefinition as d, RouteTree as f, GuardFnFactory as i, CreateMatcherOptions as l, BuildStateResultWithSegments as n, PluginFactory as o, EventMethodMap as r, Route as s, Router$1 as t, Matcher as u };
|
|
409
|
+
//# sourceMappingURL=Router-73rMK2YI.d.ts.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
const e=require(`./RouterError-BkgjTHQg.js`),t=require(`./internals-na15rxo_.js`);let n=require(`@real-router/logger`),r=require(`@real-router/fsm`);const i={maxListeners:0,warnListeners:0,maxEventDepth:0};var a=class extends Error{},o=class{#e=new Map;#t=null;#n=i;#r;#i;constructor(e){e?.limits&&(this.#n=e.limits),this.#r=e?.onListenerError??null,this.#i=e?.onListenerWarn??null}static validateCallback(e,t){if(typeof e!=`function`)throw TypeError(`Expected callback to be a function for event ${t}`)}setLimits(e){this.#n=e}on(e,t){let n=this.#c(e);if(n.has(t))throw Error(`Duplicate listener for "${e}"`);let{maxListeners:r,warnListeners:i}=this.#n;if(i!==0&&n.size===i&&this.#i?.(e,i),r!==0&&n.size>=r)throw Error(`Listener limit (${r}) reached for "${e}"`);return n.add(t),()=>{this.off(e,t)}}off(e,t){this.#e.get(e)?.delete(t)}emit(e,t,n,r,i){let a=this.#e.get(e);if(!a||a.size===0)return;let o=arguments.length-1;if(this.#n.maxEventDepth===0){this.#a(a,e,o,t,n,r,i);return}this.#s(a,e,o,t,n,r,i)}clearAll(){this.#e.clear(),this.#t=null}listenerCount(e){return this.#e.get(e)?.size??0}#a(e,t,n,r,i,a,o){if(e.size===1){let[s]=e;try{this.#o(s,n,r,i,a,o)}catch(e){this.#r?.(t,e)}return}let s=[...e];for(let e of s)try{this.#o(e,n,r,i,a,o)}catch(e){this.#r?.(t,e)}}#o(e,t,n,r,i,a){switch(t){case 0:e();break;case 1:e(n);break;case 2:e(n,r);break;case 3:e(n,r,i);break;default:e(n,r,i,a)}}#s(e,t,n,r,i,o,s){this.#t??=new Map;let c=this.#t,l=c.get(t)??0;if(l>=this.#n.maxEventDepth)throw new a(`Maximum recursion depth (${this.#n.maxEventDepth}) exceeded for event: ${t}`);try{c.set(t,l+1);let u=e.size===1?e:[...e];for(let e of u)try{this.#o(e,n,r,i,o,s)}catch(e){if(e instanceof a)throw e;this.#r?.(t,e)}}finally{c.set(t,c.get(t)-1)}}#c(e){let t=this.#e.get(e);if(t)return t;let n=new Set;return this.#e.set(e,n),n}};const s={IDLE:`IDLE`,STARTING:`STARTING`,READY:`READY`,TRANSITIONING:`TRANSITIONING`,DISPOSED:`DISPOSED`},c={START:`START`,STARTED:`STARTED`,NAVIGATE:`NAVIGATE`,COMPLETE:`COMPLETE`,FAIL:`FAIL`,CANCEL:`CANCEL`,STOP:`STOP`,DISPOSE:`DISPOSE`},l={initial:s.IDLE,context:null,transitions:{[s.IDLE]:{[c.START]:s.STARTING,[c.DISPOSE]:s.DISPOSED},[s.STARTING]:{[c.STARTED]:s.READY,[c.FAIL]:s.IDLE},[s.READY]:{[c.NAVIGATE]:s.TRANSITIONING,[c.FAIL]:s.READY,[c.STOP]:s.IDLE},[s.TRANSITIONING]:{[c.NAVIGATE]:s.TRANSITIONING,[c.COMPLETE]:s.READY,[c.CANCEL]:s.READY,[c.FAIL]:s.READY},[s.DISPOSED]:{}}};function u(){return new r.FSM(l)}function d(e){if(!e||typeof e!=`object`||e.constructor!==Object)throw TypeError(`dependencies must be a plain object`);for(let t in e)if(Object.getOwnPropertyDescriptor(e,t)?.get)throw TypeError(`dependencies cannot contain getters: "${t}"`)}function f(e,t){for(let n of e){let e=n;if(typeof e!=`object`||!e||Array.isArray(e))throw TypeError(`route must be a non-array object`);t?.routes.guardRouteCallbacks(n),t?.routes.guardNoAsyncCallbacks(n);let r=n.children;r&&f(r,t)}}function p(t={}){let n=Object.create(null);for(let e in t)t[e]!==void 0&&(n[e]=t[e]);return{dependencies:n,limits:e.i}}function m(e){return`(${e.replaceAll(/(^<|>$)/g,``)})`}const h=/([:*])([^/?<]+)(<[^>]+>)?(\?)?/g,ee=/([:*][^/?<]+(?:<[^>]+>)?)\?(?=\/|$)/g,te=/\?(.+)$/;function ne(e){let t=[],n=[],r=[],i={},a=new Map,o=e.replaceAll(ee,`$1`),s=te.exec(o);if(s!==null){let t=s[1].split(`&`);for(let e of t){let t=e.trim();t.length>0&&(n.push(t),i[t]=`query`)}e=e.slice(0,s.index)}let c;for(;(c=h.exec(e))!==null;){let e=c[1],n=c[2],o=c[3];if(e===`*`)r.push(n),t.push(n),i[n]=`url`;else if(t.push(n),i[n]=`url`,o){let e=`^${m(o)}$`;a.set(n,{pattern:new RegExp(e),constraint:o})}}return{urlParams:t,queryParams:n,spatParams:r,paramTypeMap:i,constraintPatterns:a,pathPattern:e}}const re=/[^\w!$'()*+,.:;|~-]/gu,ie=/[^\w!$'()*+,.:;|~-]/u,ae={default:e=>ie.test(e)?e.replaceAll(re,e=>encodeURIComponent(e)):e,uri:encodeURI,uriComponent:encodeURIComponent,none:e=>e},oe={default:decodeURIComponent,uri:decodeURI,uriComponent:decodeURIComponent,none:e=>e};function g(){return{staticChildren:Object.create(null),paramChild:void 0,splatChild:void 0,route:void 0,slashChildRoute:void 0}}function _(e){return e.length>1&&e.endsWith(`/`)?e.slice(0,-1):e}function se(e,t){return e===``?t:t===``?e:e+t}function ce(e){let t={};if(e.length===0)return t;let n=0,r=e.length;for(;n<=r;){let i=e.indexOf(`&`,n);i===-1&&(i=r);let a=e.indexOf(`=`,n);a===-1||a>i?t[e.slice(n,i)]=``:t[e.slice(n,a)]=e.slice(a+1,i),n=i+1}return t}function le(e){let t=``;for(let n in e){t.length>0&&(t+=`&`);let r=e[n],i=encodeURIComponent(n);t+=r===``?i:`${i}=${encodeURIComponent(String(r))}`}return t}function v(e){return e>=48&&e<=57||e>=65&&e<=70||e>=97&&e<=102}function ue(e){let t=0;for(;t<e.length;)if(e.codePointAt(t)===37){if(t+2>=e.length)return!1;let n=e.codePointAt(t+1)??0,r=e.codePointAt(t+2)??0;if(!v(n)||!v(r))return!1;t+=3}else t++;return!0}const y=/<[^>]*>/g;function de(e,t,n,r,i){let a=t.fullName===``;a||r.push(t);let o=t.absolute,s=t.paramMeta.pathPattern,c=o&&s.startsWith(`~`)?s.slice(1):s,l=(o?c:s).replaceAll(y,``),u=o?l:se(n,l),d=i;a||(d=fe(e,t,u,o?``:n,r,i));for(let n of t.children.values())de(e,n,u,r,d);a||r.pop()}function fe(e,t,n,r,i,a){let o=ge(n,r),s=Object.freeze([...i]),c=pe(s),l=_(n),u=Ce(e.rootQueryParams,i),d=we(i),{buildStaticParts:f,buildParamSlots:p}=Se(o?_(r):l,o?i.slice(0,-1):i,e.options.urlParamsEncoding),m={name:t.fullName,parent:a,depth:i.length-1,matchSegments:s,meta:c,declaredQueryParams:u,declaredQueryParamsSet:new Set(u),hasTrailingSlash:n.length>1&&n.endsWith(`/`),constraintPatterns:d,hasConstraints:d.size>0,buildStaticParts:f,buildParamSlots:p,buildParamNamesSet:new Set(p.map(e=>e.paramName))};return e.routesByName.set(t.fullName,m),e.segmentsByName.set(t.fullName,s),e.metaByName.set(t.fullName,c),o?me(e,m,r):he(e,m,n,l,t),m}function pe(e){let t={};for(let n of e)t[n.fullName]=n.paramTypeMap;return Object.freeze(t)}function me(e,t,n){ve(e,t,n);let r=_(n),i=e.options.caseSensitive?r:r.toLowerCase();e.staticCache.has(i)&&e.staticCache.set(i,t)}function he(e,t,n,r,i){if(_e(e,t,n),i.paramMeta.urlParams.length===0){let n=e.options.caseSensitive?r:r.toLowerCase();e.staticCache.set(n,t)}}function ge(e,t){return _(e)===_(t)}function _e(e,t,n){let r=_(n);if(r===`/`){e.root.route=t;return}b(e,e.root,r,1,t)}function b(e,t,n,r,i){let a=n.length;for(;r<=a;){let o=n.indexOf(`/`,r),s=o===-1?a:o,c=n.slice(r,s);if(c.endsWith(`?`)){let r=c.slice(1).replaceAll(y,``).replace(/\?$/,``);t.paramChild??={node:g(),name:r},b(e,t.paramChild.node,n,s+1,i),s>=a?t.route??=i:b(e,t,n,s+1,i);return}t=xe(e,t,c),r=s+1}t.route=i}function ve(e,t,n){let r=ye(e,n);r.slashChildRoute=t}function ye(e,t){return be(e,e.root,t)}function be(e,t,n){let r=_(n);if(r===`/`||r===``)return t;let i=t,a=1,o=r.length;for(;a<=o;){let t=r.indexOf(`/`,a),n=t===-1?o:t;if(n<=a)break;let s=r.slice(a,n);i=xe(e,i,s),a=n+1}return i}function xe(e,t,n){if(n.startsWith(`*`)){let e=n.slice(1);return t.splatChild??={node:g(),name:e},t.splatChild.node}if(n.startsWith(`:`)){let e=n.slice(1).replaceAll(y,``).replace(/\?$/,``);return t.paramChild??={node:g(),name:e},t.paramChild.node}let r=e.options.caseSensitive?n:n.toLowerCase();return r in t.staticChildren||(t.staticChildren[r]=g()),t.staticChildren[r]}function Se(e,t,n){let r=new Set,i=new Set;for(let e of t){for(let t of e.paramMeta.urlParams)r.add(t);for(let t of e.paramMeta.spatParams)i.add(t)}if(r.size===0)return{buildStaticParts:[e],buildParamSlots:[]};let a=[],o=[],s=/[:*]([\w]+)(?:<[^>]*>)?(\?)?/gu,c=0,l;for(;(l=s.exec(e))!==null;){let t=l[1],r=l[2]===`?`;a.push(e.slice(c,l.index));let s=i.has(t)?e=>{let t=ae[n],r=e.split(`/`),i=t(r[0]);for(let e=1;e<r.length;e++)i+=`/${t(r[e])}`;return i}:ae[n];o.push({paramName:t,isOptional:r,encoder:s}),c=l.index+l[0].length}return a.push(e.slice(c)),{buildStaticParts:a,buildParamSlots:o}}function Ce(e,t){let n=[];e.length>0&&n.push(...e);for(let e of t)e.paramMeta.queryParams.length>0&&n.push(...e.paramMeta.queryParams);return n}function we(e){let t=new Map;for(let n of e)for(let[e,r]of n.paramMeta.constraintPatterns)t.set(e,r);return t}var Te=class{get options(){return this.#e}#e;#t=g();#n=new Map;#r=new Map;#i=new Map;#a=new Map;#o={cleanPath:``,normalized:``,queryString:void 0};#s=``;#c=[];#l=``;constructor(e){this.#e={caseSensitive:e?.caseSensitive??!0,strictTrailingSlash:e?.strictTrailingSlash??!1,strictQueryParams:e?.strictQueryParams??!1,urlParamsEncoding:e?.urlParamsEncoding??`default`,parseQueryString:e?.parseQueryString??ce,buildQueryString:e?.buildQueryString??le}}registerTree(e){this.#c=e.paramMeta.queryParams,de({root:this.#t,options:this.#e,routesByName:this.#n,segmentsByName:this.#r,metaByName:this.#i,staticCache:this.#a,rootQueryParams:this.#c},e,``,[],null)}match(e){if(!this.#m(e))return;let{cleanPath:t,normalized:n,queryString:r}=this.#o,i=this.#e.caseSensitive?n:n.toLowerCase(),a=this.#a.get(i);if(a)return this.#e.strictTrailingSlash&&!this.#_(t,a)?void 0:this.#g(a,{},r);let o={},s=this.#v(n,o);if(s&&!(this.#e.strictTrailingSlash&&!this.#_(t,s))&&!(s.hasConstraints&&!this.#x(o,s))&&this.#b(o))return this.#g(s,o,r)}buildPath(e,t,n){let r=this.#n.get(e);if(!r)throw Error(`[SegmentMatcher.buildPath] '${e}' is not defined`);r.hasConstraints&&t&&this.#u(r,e,t);let i=this.#d(r,t),a=this.#f(i,n?.trailingSlash),o=this.#p(r,t,n?.queryParamsMode);return a+(o?`?${o}`:``)}getSegmentsByName(e){return this.#r.get(e)}getMetaByName(e){return this.#i.get(e)}hasRoute(e){return this.#n.has(e)}setRootPath(e){this.#s=e}#u(e,t,n){for(let[r,i]of e.constraintPatterns){let e=n[r];if(e!=null){let n=typeof e==`object`?JSON.stringify(e):String(e);if(!i.pattern.test(n))throw Error(`[SegmentMatcher.buildPath] '${t}' — param '${r}' value '${n}' does not match constraint '${i.constraint}'`)}}}#d(e,t){let n=e.buildStaticParts,r=e.buildParamSlots;if(r.length===0)return this.#s+n[0];let i=this.#s+n[0];for(let[e,a]of r.entries()){let r=t?.[a.paramName];if(r==null){if(!a.isOptional)throw Error(`[SegmentMatcher.buildPath] Missing required param '${a.paramName}'`);i.length>1&&i.endsWith(`/`)&&(i=i.slice(0,-1)),i+=n[e+1];continue}let o;o=typeof r==`string`?r:typeof r==`object`?JSON.stringify(r):String(r);let s=a.encoder(o);i+=s+n[e+1]}return i}#f(e,t){return t===`always`&&!e.endsWith(`/`)?`${e}/`:t===`never`&&e!==`/`&&e.endsWith(`/`)?e.slice(0,-1):e}#p(e,t,n){if(!t||e.declaredQueryParams.length===0&&n!==`loose`)return``;let r={},i=!1;for(let n of e.declaredQueryParams)n in t&&(r[n]=t[n],i=!0);if(n===`loose`)for(let n in t)Object.hasOwn(t,n)&&!e.declaredQueryParamsSet.has(n)&&!e.buildParamNamesSet.has(n)&&(r[n]=t[n],i=!0);return i?this.#e.buildQueryString(r):``}#m(e){if(e===``&&(e=`/`),e.codePointAt(0)!==47)return!1;let t=this.#s.length;if(t>0){if(e.length<t||!e.startsWith(this.#s))return!1;e=e.length===t?`/`:e.slice(t)}let n=this.#h(e);if(n===-2)return!1;n===-3&&(e=this.#l);let r=n>=0?e.slice(0,n):e,i=n>=0?e.slice(n+1):void 0,a=_(r);return this.#o.cleanPath=r,this.#o.normalized=a,this.#o.queryString=i,!0}#h(e){let t=!1;for(let n=0;n<e.length;n++){let r=e.codePointAt(n);if(r===35)return this.#l=e.slice(0,n),-3;if(r===63)return n;if(r>=128)return-2;if(r===47){if(t)return-2;t=!0}else t=!1}return-1}#g(e,t,n){if(n!==void 0){let r=this.#e.parseQueryString(n);if(this.#e.strictQueryParams){let n=e.declaredQueryParamsSet;for(let e in r){if(!n.has(e))return;t[e]=r[e]}}else for(let e in r)t[e]=r[e]}return{segments:e.matchSegments,params:t,meta:e.meta}}#_(e,t){return(e.length>1&&e.endsWith(`/`))===t.hasTrailingSlash}#v(e,t){return e.length===1?this.#t.slashChildRoute??this.#t.route:this.#y(this.#t,e,1,t)}#y(e,t,n,r){let i=e,a=t.length;for(;n<=a;){let e=t.indexOf(`/`,n),o=e===-1?a:e,s=t.slice(n,o),c=this.#e.caseSensitive?s:s.toLowerCase(),l;if(c in i.staticChildren)l=i.staticChildren[c];else if(i.paramChild)l=i.paramChild.node,r[i.paramChild.name]=s;else if(i.splatChild){let e={},a=this.#y(i.splatChild.node,t,n,e);return a?(Object.assign(r,e),a):(r[i.splatChild.name]=t.slice(n),i.splatChild.node.route)}else return;i=l,n=o+1}return i.slashChildRoute??i.route}#b(e){let t=this.#e.urlParamsEncoding;if(t===`none`)return!0;let n=oe[t];for(let t in e){let r=e[t];if(r.includes(`%`)){if(!ue(r))return!1;e[t]=n(r)}}return!0}#x(e,t){for(let[n,r]of t.constraintPatterns)if(!r.pattern.test(e[n]))return!1;return!0}};const x=e=>{let t=e.indexOf(`%`),n=e.indexOf(`+`);if(t===-1&&n===-1)return e;let r=n===-1?e:e.replaceAll(`+`,` `);return t===-1?r:decodeURIComponent(r)},Ee=(e,t)=>{if(e===void 0)return t.boolean.decodeUndefined();let n=t.boolean.decodeRaw(e);if(n!==null)return n;let r=x(e),i=t.number.decode(r);return i===null?t.boolean.decodeValue(r):i},S=e=>{let t=typeof e;if(t!==`string`&&t!==`number`&&t!==`boolean`)throw TypeError(`[search-params] Array element must be a string, number, or boolean — received ${t===`object`&&e===null?`null`:t}`);return encodeURIComponent(e)},C={none:{encodeArray:(e,t)=>{if(t.length===0)return``;let n=`${e}=${S(t[0])}`;for(let r=1;r<t.length;r++)n+=`&${e}=${S(t[r])}`;return n}},brackets:{encodeArray:(e,t)=>{if(t.length===0)return``;let n=`${e}[]=${S(t[0])}`;for(let r=1;r<t.length;r++)n+=`&${e}[]=${S(t[r])}`;return n}},index:{encodeArray:(e,t)=>{if(t.length===0)return``;let n=`${e}[0]=${S(t[0])}`;for(let r=1;r<t.length;r++)n+=`&${e}[${r}]=${S(t[r])}`;return n}},comma:{encodeArray:(e,t)=>{if(t.length===0)return`${e}=`;let n=`${e}=${S(t[0])}`;for(let e=1;e<t.length;e++)n+=`,${S(t[e])}`;return n}}},De={encode:(e,t)=>`${e}=${t}`,decodeUndefined:()=>null,decodeRaw:()=>null,decodeValue:e=>e},Oe={encode:(e,t)=>`${e}=${t}`,decodeUndefined:()=>null,decodeRaw:e=>e===`true`?!0:e===`false`?!1:null,decodeValue:e=>e},ke={encode:(e,t)=>t?e:`${e}=false`,decodeUndefined:()=>!0,decodeRaw:()=>null,decodeValue:e=>e},w={none:De,auto:Oe,"empty-true":ke},T={default:{encode:e=>e},hidden:{encode:()=>``}},Ae={auto:{decode:e=>{let t=e.length;if(t===0)return null;let n=!1;for(let r=0;r<t;r++){let i=e.codePointAt(r);if(!(i!==void 0&&i>=48&&i<=57)){if(i===46&&!n&&r!==0&&r!==t-1){n=!0;continue}return null}}return Number(e)}},none:{decode:()=>null}},je=(e,t,n,r)=>({boolean:w[t],null:T[n],number:Ae[r],array:C[e]}),Me={boolean:w.auto,null:T.default,number:Ae.auto,array:C.none},E={arrayFormat:`none`,booleanFormat:`auto`,nullFormat:`default`,numberFormat:`auto`},Ne={...E,strategies:Me},Pe=e=>{if(!e||e.arrayFormat===void 0&&e.booleanFormat===void 0&&e.nullFormat===void 0&&e.numberFormat===void 0)return Ne;let t=e.arrayFormat??E.arrayFormat,n=e.booleanFormat??E.booleanFormat,r=e.nullFormat??E.nullFormat,i=e.numberFormat??E.numberFormat;return{arrayFormat:t,booleanFormat:n,nullFormat:r,numberFormat:i,strategies:je(t,n,r,i)}},D=e=>encodeURIComponent(e),Fe=(e,t,n)=>{let r=D(e);switch(typeof t){case`string`:case`number`:return`${r}=${D(t)}`;case`boolean`:return n.strategies.boolean.encode(r,t);case`object`:return t===null?n.strategies.null.encode(r):Array.isArray(t)?n.strategies.array.encodeArray(r,t):`${r}=${D(t)}`;default:return`${r}=${D(t)}`}},Ie=e=>{let t=e.indexOf(`?`);return t===-1?e:e.slice(t+1)};function Le(e,t,n,r){let i=e[t];i===void 0?e[t]=r?[n]:n:Array.isArray(i)?i.push(n):e[t]=[i,n]}function Re(e,t,n,r,i){return i?Ee(r?e.slice(t+1,n):void 0,i):r?x(e.slice(t+1,n)):null}function ze(e,t,n,r,i){let a=e.indexOf(`=`,t),o=a!==-1&&a<n,s=o?a:n,c=s,l=!1;for(let n=t;n<s;n++)if(e.codePointAt(n)===91){c=n,l=!0;break}Le(r,x(e.slice(t,c)),Re(e,a,n,o,i),l)}const Be=(e,t)=>{let n=Ie(e);if(n===``||n===`?`)return{};if(!t)return Ve(n);let r=Pe(t),i={},a=0,o=n.length;for(;a<o;){let e=n.indexOf(`&`,a);e===-1&&(e=o),ze(n,a,e,i,r.strategies),a=e+1}return i};function Ve(e){let t={};return He(e,t),t}function He(e,t){let n=0,r=e.length;for(;n<r;){let i=e.indexOf(`&`,n);i===-1&&(i=r),ze(e,n,i,t),n=i+1}}const Ue=(e,t)=>{let n=Object.keys(e);if(n.length===0)return``;let r=Pe(t),i=[];for(let t of n){let n=e[t];if(n===void 0)continue;let a=Fe(t,n,r);a&&i.push(a)}return i.join(`&`)};function O(e,t){let n=e.path,r=n.startsWith(`~`),i=r?n.slice(1):n,a={name:e.name,path:i,absolute:r,children:[],parent:t,nonAbsoluteChildren:[],fullName:``};if(e.children)for(let t of e.children){let e=O(t,a);a.children.push(e)}return a}function We(e,t,n){let r=O({name:e,path:t},null);for(let e of n){let t=O(e,r);r.children.push(t)}return r}const Ge=Object.freeze(new Map),Ke=Object.freeze([]);function qe(e){return e.parent?.name?`${e.parent.fullName}.${e.name}`:e.name}function Je(e,t){return e.endsWith(`/`)&&t.startsWith(`/`)?e+t.slice(1):e+t}function Ye(e){if(!e.path)return null;let{urlParams:t,queryParams:n,spatParams:r}=e.paramMeta;if(t.length>0||n.length>0||r.length>0)return null;if(e.absolute)return e.path;let i=e.parent;return i?.path?i.staticPath===null?null:Je(i.staticPath,e.path):e.path}function Xe(e){let t=new Map;for(let n of e)t.set(n.name,n);return t}function Ze(e,t,n){let r=[],i=[];for(let a of e){let e=Qe(a,t,n);r.push(e),e.absolute||i.push(e)}return{childrenMap:Xe(r),nonAbsoluteChildren:i}}function Qe(e,t,n){let r=ne(e.path),i=r.paramTypeMap,a={name:e.name,path:e.path,absolute:e.absolute,parent:t,children:void 0,paramMeta:r,nonAbsoluteChildren:void 0,fullName:``,staticPath:null,paramTypeMap:i};if(a.fullName=qe(a),a.staticPath=Ye(a),e.children.length===0)a.children=Ge,a.nonAbsoluteChildren=Ke;else{let{childrenMap:t,nonAbsoluteChildren:r}=Ze(e.children,a,n);a.children=t,a.nonAbsoluteChildren=r}return n&&(e.children.length>0&&(Object.freeze(a.nonAbsoluteChildren),Object.freeze(a.children)),Object.freeze(i),Object.freeze(a)),a}function $e(e,t=!0){return Qe(e,null,t)}function et(e,t){let n=[];return{add(e){return n.push(e),this},addMany(e){return n.push(...e),this},build(r){return $e(We(e,t,n),!r?.skipFreeze)}}}function tt(e,t,n,r){return et(e,t).addMany(n).build(r)}function k(e){let t=e.absolute?`~${e.path}`:e.path,n={name:e.name,path:t};return e.children.size>0&&(n.children=Array.from(e.children.values(),k)),n}function nt(e){return Array.from(e.children.values(),k)}function rt(e){let t=e?.queryParams;return new Te({...e?.caseSensitive===void 0?void 0:{caseSensitive:e.caseSensitive},...e?.strictTrailingSlash===void 0?void 0:{strictTrailingSlash:e.strictTrailingSlash},...e?.strictQueryParams===void 0?void 0:{strictQueryParams:e.strictQueryParams},...e?.urlParamsEncoding===void 0?void 0:{urlParamsEncoding:e.urlParamsEncoding},parseQueryString:e=>Be(e,t),buildQueryString:e=>Ue(e,t)})}const it={defaultRoute:``,defaultParams:{},trailingSlash:`preserve`,queryParamsMode:`loose`,queryParams:E,urlParamsEncoding:`default`,allowNotFound:!0,rewritePathOnMatch:!0};function at(e){Object.freeze(e);for(let t of Object.keys(e)){let n=e[t];n&&typeof n==`object`&&n.constructor===Object&&at(n)}return e}function ot(e,t){return typeof e==`function`?e(t):e}function st(e){if(!e||typeof e!=`object`||Array.isArray(e))throw TypeError(`[router.constructor] options must be a plain object`)}var ct=class{#e;constructor(e={}){this.#e=at({...it,...e})}static validateOptionsIsObject(e){st(e)}get(){return this.#e}};function A(e,t){if(e===t)return!0;if(Array.isArray(e)&&Array.isArray(t)){if(e.length!==t.length)return!1;for(let n=0;n<e.length;n++)if(!A(e[n],t[n]))return!1;return!0}return!1}const lt=new WeakMap;function ut(e){return lt.get(e)}function dt(e,t){lt.set(e,t)}var ft=class{#e=void 0;#t=void 0;#n;#r=new Map;get(){return this.#e}set(t){this.#t=this.#e,this.#e=t?e.r(t):void 0}getPrevious(){return this.#t}reset(){this.#e=void 0,this.#t=void 0,this.#r.clear()}setDependencies(e){this.#n=e}makeState(t,n,r,i,a){let o=this.#n.getDefaultParams(),s=Object.hasOwn(o,t),c;c=s?{...o[t],...n}:!n||n===e.a?e.a:{...n};let l={name:t,params:c,path:r??this.#n.buildPath(t,n)};return i&&dt(l,i),a?l:e.r(l)}areStatesEqual(e,t,n=!0){if(!e||!t)return!!e==!!t;if(e.name!==t.name)return!1;if(n){let n=this.#i(e.name);for(let r of n)if(!A(e.params[r],t.params[r]))return!1;return!0}let r=Object.keys(e.params),i=Object.keys(t.params);if(r.length!==i.length)return!1;for(let n of r)if(!(n in t.params)||!A(e.params[n],t.params[n]))return!1;return!0}#i(e){let t=this.#r.get(e);if(t!==void 0)return t;let n=this.#n.getUrlParams(e);return this.#r.set(e,n),n}};const j={[e.u.ROUTER_START]:e.l.ROUTER_START,[e.u.ROUTER_STOP]:e.l.ROUTER_STOP,[e.u.TRANSITION_SUCCESS]:e.l.TRANSITION_SUCCESS,[e.u.TRANSITION_START]:e.l.TRANSITION_START,[e.u.TRANSITION_ERROR]:e.l.TRANSITION_ERROR,[e.u.TRANSITION_CANCEL]:e.l.TRANSITION_CANCEL},pt=Object.keys(j),M=`router.usePlugin`;function mt(e){if(!(e&&typeof e==`object`)||Array.isArray(e))throw TypeError(`[router.usePlugin] Plugin factory must return an object, got ${typeof e}`);if(typeof e.then==`function`)throw TypeError(`[router.usePlugin] Async plugin factories are not supported. Factory returned a Promise instead of a plugin object.`)}var ht=class t{#e=new Set;#t=new Set;#n;#r=e.i;#i=null;static validatePlugin(e){mt(e)}static validateNoDuplicatePlugins(e,t){for(let n of e)if(t(n))throw Error(`[router.usePlugin] Plugin factory already registered. To re-register, first unsubscribe the existing plugin.`)}setDependencies(e){this.#n=e}setLimits(e){
|
|
2
|
+
// eslint-disable-next-line sonarjs/void-use -- @preserve: limits passed to validator via RouterInternals; void suppresses TS6133 until plugin implements validateCountThresholds
|
|
3
|
+
this.#r=e,this.#r}setValidatorGetter(e){this.#i=e}count(){return this.#e.size}use(...e){if(this.#i?.()?.plugins.validateCountThresholds(this.#e.size+e.length),e.length===1){let t=e[0],r=this.#o(t);this.#e.add(t);let i=!1,a=()=>{if(!i){i=!0,this.#e.delete(t),this.#t.delete(a);try{r()}catch(e){n.logger.error(M,`Error during cleanup:`,e)}}};return this.#t.add(a),a}let t=this.#a(e),r=[];try{for(let e of t){let t=this.#o(e);r.push({factory:e,cleanup:t})}}catch(e){for(let{cleanup:e}of r)try{e()}catch(e){n.logger.error(M,`Cleanup error:`,e)}throw e}for(let{factory:e}of r)this.#e.add(e);let i=!1,a=()=>{if(!i){i=!0,this.#t.delete(a);for(let{factory:e}of r)this.#e.delete(e);for(let{cleanup:e}of r)try{e()}catch(e){n.logger.error(M,`Error during cleanup:`,e)}}};return this.#t.add(a),a}getAll(){return[...this.#e]}has(e){return this.#e.has(e)}disposeAll(){for(let e of this.#t)e();this.#e.clear(),this.#t.clear()}#a(e){let t=new Set;for(let n of e)t.has(n)?this.#i?.()?.plugins.warnBatchDuplicates(e):t.add(n);return t}#o(e){let n=this.#n.compileFactory(e);t.validatePlugin(n),this.#i?.()?.plugins.validatePluginKeys(n),Object.freeze(n);let r=[];for(let e of pt)e in n&&(typeof n[e]==`function`?(r.push(this.#n.addEventListener(j[e],n[e])),e===`onStart`&&this.#n.canNavigate()&&this.#i?.()?.plugins.warnPluginAfterStart(e)):this.#i?.()?.plugins.warnPluginMethodType(e));return()=>{for(let e of r)e();typeof n.teardown==`function`&&n.teardown()}}};function gt(e){let t=()=>e;return()=>t}var _t=class{#e=new Map;#t=new Map;#n=new Map;#r=new Map;#i=[this.#n,this.#r];#a=new Set;#o=new Set;#s=new Set;#c;#l=e.i;#u=null;setDependencies(e){this.#c=e}setLimits(e){
|
|
4
|
+
// eslint-disable-next-line sonarjs/void-use -- @preserve: Wave 3 validator reads limits via RouterInternals; void suppresses TS6133 until then
|
|
5
|
+
this.#l=e,this.#l}setValidatorGetter(e){this.#u=e}getHandlerCount(e){return e===`activate`?this.#t.size:this.#e.size}addCanActivate(e,t,n=!1){n?this.#o.add(e):this.#o.delete(e);let r=this.#t.has(e);this.#d(`activate`,e,t,this.#t,this.#r,`canActivate`,r)}addCanDeactivate(e,t,n=!1){n?this.#s.add(e):this.#s.delete(e);let r=this.#e.has(e);this.#d(`deactivate`,e,t,this.#e,this.#n,`canDeactivate`,r)}clearCanActivate(e){this.#t.delete(e),this.#r.delete(e),this.#o.delete(e)}clearCanDeactivate(e){this.#e.delete(e),this.#n.delete(e),this.#s.delete(e)}clearAll(){this.#t.clear(),this.#r.clear(),this.#e.clear(),this.#n.clear(),this.#o.clear(),this.#s.clear()}clearDefinitionGuards(){for(let e of this.#o)this.#t.delete(e),this.#r.delete(e);for(let e of this.#s)this.#e.delete(e),this.#n.delete(e);this.#o.clear(),this.#s.clear()}getFactories(){let e={},t={};for(let[t,n]of this.#e)e[t]=n;for(let[e,n]of this.#t)t[e]=n;return[e,t]}getFunctions(){return this.#i}canNavigateTo(e,t,n,r){for(let t of e)if(!this.#f(this.#n,t,n,r,`canNavigateTo`))return!1;for(let e of t)if(!this.#f(this.#r,e,n,r,`canNavigateTo`))return!1;return!0}#d(e,t,n,r,i,a,o){o?this.#u?.()?.lifecycle.warnOverwrite(t,e,a):this.#u?.()?.lifecycle.validateCountThresholds(r.size+1,a);let s=typeof n==`boolean`?gt(n):n;r.set(t,s),this.#a.add(t);try{let e=this.#c.compileFactory(s);if(typeof e!=`function`)throw TypeError(`[router.${a}] Factory must return a function, got ${typeof e}`);i.set(t,e)}catch(e){throw r.delete(t),e}finally{this.#a.delete(t)}}#f(e,t,n,r,i){let a=e.get(t);if(!a)return!0;try{let e=a(n,r);return typeof e==`boolean`?e:(this.#u?.()?.lifecycle.warnAsyncGuardSync(t,i),!1)}catch{return!1}}};function N(){return{decoders:Object.create(null),encoders:Object.create(null),defaultParams:Object.create(null),forwardMap:Object.create(null),forwardFnMap:Object.create(null)}}function vt(e,t){for(let n in e)if(e[n]!==t[n])return!1;return!0}function yt(e,t,n){for(let r in e)if(!(r in n)&&e[r]!==t[r])return!1;return!0}function P(e){let t={name:e.name,path:e.path};return e.children&&(t.children=e.children.map(e=>P(e))),t}function F(e,t,n=``){for(let r=0;r<e.length;r++){let i=e[r],a=n?`${n}.${i.name}`:i.name;if(a===t)return e.splice(r,1),!0;if(i.children&&t.startsWith(`${a}.`)&&F(i.children,t,a))return!0}return!1}function bt(e,t){for(let n of Object.keys(e))t(n)&&delete e[n]}function I(e,t,n=100){let r=new Set,i=[e],a=e;for(;t[a];){let e=t[a];if(r.has(e)){let t=i.indexOf(e),n=[...i.slice(t),e];throw Error(`Circular forwardTo: ${n.join(` → `)}`)}if(r.add(a),i.push(e),a=e,i.length>n)throw Error(`forwardTo chain exceeds maximum depth (${n}): ${i.join(` → `)}`)}return a}function L(e,t,n){let r=tt(``,t,e),i=rt(n);return i.registerTree(r),{tree:r,matcher:i}}function xt(e){let t=L(e.definitions,e.rootPath,e.matcherOptions);e.tree=t.tree,e.matcher=t.matcher,e.resolvedForwardMap=V(e.config)}function R(e){let t=L(e.definitions,e.rootPath,e.matcherOptions);e.tree=t.tree,e.matcher=t.matcher}function z(e){B(e),R(e)}function B(e){e.definitions.length=0,Object.assign(e.config,N()),e.resolvedForwardMap=Object.create(null),e.routeCustomFields=Object.create(null)}function V(e){let t=Object.create(null);for(let n of Object.keys(e.forwardMap))t[n]=I(n,e.forwardMap);return t}function St(e,t,r){if(e.canActivate){let r=typeof e.forwardTo==`string`?e.forwardTo:`[dynamic]`;n.logger.warn(`real-router`,`Route "${t}" has both forwardTo and canActivate. canActivate will be ignored because forwardTo creates a redirect (industry standard). Move canActivate to the target route "${r}".`)}if(e.canDeactivate){let r=typeof e.forwardTo==`string`?e.forwardTo:`[dynamic]`;n.logger.warn(`real-router`,`Route "${t}" has both forwardTo and canDeactivate. canDeactivate will be ignored because forwardTo creates a redirect (industry standard). Move canDeactivate to the target route "${r}".`)}if(typeof e.forwardTo==`function`){let n=e.forwardTo.constructor.name===`AsyncFunction`,r=e.forwardTo.toString().includes(`__awaiter`);if(n||r)throw TypeError(`forwardTo callback cannot be async for route "${t}". Async functions break matchPath/buildPath.`)}typeof e.forwardTo==`string`?r.forwardMap[t]=e.forwardTo:r.forwardFnMap[t]=e.forwardTo}function Ct(e,t,n,r,i,a,o){let s=new Set([`name`,`path`,`children`,`canActivate`,`canDeactivate`,`forwardTo`,`encodeParams`,`decodeParams`,`defaultParams`]),c=Object.fromEntries(Object.entries(e).filter(([e])=>!s.has(e)));Object.keys(c).length>0&&(r[t]=c),e.canActivate&&(o?o.addActivateGuard(t,e.canActivate):i.set(t,e.canActivate)),e.canDeactivate&&(o?o.addDeactivateGuard(t,e.canDeactivate):a.set(t,e.canDeactivate)),e.forwardTo&&St(e,t,n),e.decodeParams&&(n.decoders[t]=t=>e.decodeParams?.(t)??t),e.encodeParams&&(n.encoders[t]=t=>e.encodeParams?.(t)??t),e.defaultParams&&(n.defaultParams[t]=e.defaultParams)}function H(e,t,n,r,i,a,o=``){for(let s of e){let e=o?`${o}.${s.name}`:s.name;Ct(s,e,t,n,r,i,a),s.children&&H(s.children,t,n,r,i,a,e)}}function wt(e,t){let n=[],r=N(),i=Object.create(null),a=new Map,o=new Map;for(let t of e)n.push(P(t));let{tree:s,matcher:c}=L(n,``,t);return H(e,r,i,a,o,void 0,``),{definitions:n,config:r,tree:s,matcher:c,resolvedForwardMap:V(r),routeCustomFields:i,rootPath:``,matcherOptions:t,depsStore:void 0,lifecycleNamespace:void 0,pendingCanActivate:a,pendingCanDeactivate:o,treeOperations:{commitTreeChanges:xt,resetStore:z,nodeToDefinition:k}}}const U=[];Object.freeze(U);function Tt(e){let t=e.length,n=[];for(let r=t-1;r>=0;r--)n.push(e[r]);return n}function Et(e){let t=e.split(`.`),n=t.length,r=[t[0]],i=t[0].length;for(let a=1;a<n-1;a++)i+=1+t[a].length,r.push(e.slice(0,i));return r.push(e),r}function Dt(e){let t=typeof e;return t===`string`||t===`number`||t===`boolean`}function Ot(e,t,n,r){let i=t[e];if(!i||typeof i!=`object`)return!0;for(let e of Object.keys(i)){let t=n.params[e],i=r.params[e];if(Dt(t)&&Dt(i)&&String(t)!==String(i))return!1}return!0}function kt(e,t,n,r,i,a){for(let o=0;o<a;o++){let a=r[o];if(a!==i[o]||!Ot(a,e,t,n))return o}return a}const At=new Map;function W(e){let t=At.get(e);if(t)return t;let n=jt(e);return Object.freeze(n),At.set(e,n),n}function jt(e){if(!e)return[``];let t=e.indexOf(`.`);if(t===-1)return[e];let n=e.indexOf(`.`,t+1);if(n===-1)return[e.slice(0,t),e];let r=e.indexOf(`.`,n+1);return r===-1?[e.slice(0,t),e.slice(0,n),e]:e.indexOf(`.`,r+1)===-1?[e.slice(0,t),e.slice(0,n),e.slice(0,r),e]:Et(e)}let G,K,q=null,Mt,Nt,J=null;function Pt(e,t){if(!t)return{intersection:``,toActivate:W(e.name),toDeactivate:U};let n=ut(e),r=ut(t);if(!n&&!r)return{intersection:``,toActivate:W(e.name),toDeactivate:Tt(W(t.name))};let i=W(e.name),a=W(t.name),o=Math.min(a.length,i.length),s=kt(n??r,e,t,i,a,o),c;if(s>=a.length)c=U;else if(s===0&&a.length===1)c=a;else{c=[];for(let e=a.length-1;e>=s;e--)c.push(a[e])}let l=s===0?i:i.slice(s);return{intersection:s>0?a[s-1]:``,toDeactivate:c,toActivate:l}}function Y(e,t){if(q!==null&&e===G&&t===K)return q;if(J!==null&&e===Mt&&t===Nt)return J;let n=Pt(e,t);return Mt=G,Nt=K,J=q,G=e,K=t,q=n,n}function Ft(e){let t=[];for(let n of e)for(let e of n.paramMeta.urlParams)t.push(e);return t}function It(e){return e.at(-1)?.fullName??``}function Lt(e,t){return{name:t??It(e.segments),params:e.params,meta:e.meta}}var Rt=class{#e;#t;get#n(){return this.#e.depsStore}constructor(e=[],t){this.#e=wt(e,t)}static shouldUpdateNode(e){return(t,n)=>{if(!(t&&typeof t==`object`&&`name`in t))throw TypeError(`[router.shouldUpdateNode] toState must be valid State object`);if(t.transition?.reload||e===``&&!n)return!0;let{intersection:r,toActivate:i,toDeactivate:a}=Y(t,n);return e===r||i.includes(e)?!0:a.includes(e)}}setDependencies(e){this.#e.depsStore=e;for(let[t,n]of this.#e.pendingCanActivate)e.addActivateGuard(t,n);this.#e.pendingCanActivate.clear();for(let[t,n]of this.#e.pendingCanDeactivate)e.addDeactivateGuard(t,n);this.#e.pendingCanDeactivate.clear()}setLifecycleNamespace(e){this.#e.lifecycleNamespace=e}setRootPath(e){this.#e.rootPath=e,R(this.#e)}hasRoute(e){return this.#e.matcher.hasRoute(e)}clearRoutes(){z(this.#e)}buildPath(t,n,r){if(t===e.s.UNKNOWN_ROUTE)return typeof n?.path==`string`?n.path:``;let i=Object.hasOwn(this.#e.config.defaultParams,t)?{...this.#e.config.defaultParams[t],...n}:n??{},a=typeof this.#e.config.encoders[t]==`function`?this.#e.config.encoders[t]({...i}):i;return this.#e.matcher.buildPath(t,a,this.#i(r))}matchPath(e,t){let n=t,r=this.#e.matcher.match(e);if(!r)return;let{name:i,params:a,meta:o}=Lt(r),s=typeof this.#e.config.decoders[i]==`function`?this.#e.config.decoders[i](a):a,{name:c,params:l}=this.#n.forwardState(i,s),u=e;if(n.rewritePathOnMatch){let e=typeof this.#e.config.encoders[c]==`function`?this.#e.config.encoders[c]({...l}):l,t=n.trailingSlash;u=this.#e.matcher.buildPath(c,e,{trailingSlash:t===`never`||t===`always`?t:void 0,queryParamsMode:n.queryParamsMode})}return this.#n.makeState(c,l,u,o)}forwardState(e,t){if(Object.hasOwn(this.#e.config.forwardFnMap,e)){let n=this.#r(e,t),r=this.#e.config.forwardFnMap[e],i=this.#a(e,r,t);return{name:i,params:this.#r(i,n)}}let n=this.#e.resolvedForwardMap[e]??e;if(n!==e&&Object.hasOwn(this.#e.config.forwardFnMap,n)){let r=this.#r(e,t),i=this.#e.config.forwardFnMap[n],a=this.#a(n,i,t);return{name:a,params:this.#r(a,r)}}if(n!==e){let r=this.#r(e,t);return{name:n,params:this.#r(n,r)}}return{name:e,params:this.#r(e,t)}}buildStateResolved(e,t){let n=this.#e.matcher.getSegmentsByName(e);if(n)return Lt({segments:n,params:t,meta:this.#e.matcher.getMetaByName(e)},e)}isActiveRoute(e,t={},n=!1,r=!0){let i=this.#n.getState();if(!i)return!1;let a=i.name;if(a!==e&&!a.startsWith(`${e}.`)&&!e.startsWith(`${a}.`))return!1;let o=this.#e.config.defaultParams[e];if(n||a===e){let n={name:e,params:o?{...o,...t}:t,path:``};return this.#n.areStatesEqual(n,i,r)}let s=i.params;return vt(t,s)?!o||yt(o,s,t):!1}getMetaForState(e){return this.#e.matcher.hasRoute(e)?this.#e.matcher.getMetaByName(e):void 0}getUrlParams(e){let t=this.#e.matcher.getSegmentsByName(e);return t?Ft(t):[]}getStore(){return this.#e}#r(e,t){return Object.hasOwn(this.#e.config.defaultParams,e)?{...this.#e.config.defaultParams[e],...t}:t}#i(e){if(this.#t)return this.#t;let t=e?.trailingSlash;return this.#t=Object.freeze({trailingSlash:t===`never`||t===`always`?t:void 0,queryParamsMode:e?.queryParamsMode}),this.#t}#a(e,t,n){let r=new Set([e]),i=t(this.#n.getDependency,n),a=0;if(typeof i!=`string`)throw TypeError(`forwardTo callback must return a string, got ${typeof i}`);for(;a<100;){if(this.#e.matcher.getSegmentsByName(i)===void 0)throw Error(`Route "${i}" does not exist`);if(r.has(i)){let e=[...r,i].join(` → `);throw Error(`Circular forwardTo detected: ${e}`)}if(r.add(i),Object.hasOwn(this.#e.config.forwardFnMap,i)){let e=this.#e.config.forwardFnMap[i];i=e(this.#n.getDependency,n),a++;continue}let e=this.#e.config.forwardMap[i];if(e!==void 0){i=e,a++;continue}return i}throw Error(`forwardTo exceeds maximum depth of 100`)}};const zt=new e.t(e.c.ROUTER_NOT_STARTED),Bt=new e.t(e.c.ROUTE_NOT_FOUND),Vt=new e.t(e.c.SAME_STATES),Ht=Promise.reject(zt),Ut=Promise.reject(Bt),Wt=Promise.reject(Vt);Ht.catch(()=>{}),Ut.catch(()=>{}),Wt.catch(()=>{});function Gt(e,t,n,r,i){let a={phase:`activating`,reason:`success`,segments:{deactivated:n,activated:r,intersection:i}};return e?.name!==void 0&&(a.from=e.name),t.reload!==void 0&&(a.reload=t.reload),t.redirected!==void 0&&(a.redirected=t.redirected),a}function Kt({signal:e,...t}){return t}function X(t,n){let{toState:r,fromState:i,opts:a,toDeactivate:o,toActivate:s,intersection:c}=n;if(r.name!==e.s.UNKNOWN_ROUTE&&!t.hasRoute(r.name)){let n=new e.t(e.c.ROUTE_NOT_FOUND,{routeName:r.name});throw t.sendTransitionFail(r,i,n),n}if(i)for(let e of o)!s.includes(e)&&n.canDeactivateFunctions.has(e)&&t.clearCanDeactivate(e);r.transition=Gt(i,a,o,s,c);let l=e.r(r);t.setState(l);let u=a.signal===void 0?a:Kt(a);return t.sendTransitionDone(l,i,u),l}function qt(t,n,r,i){let a=n;a.code===e.c.TRANSITION_CANCELLED||a.code===e.c.ROUTE_NOT_FOUND||t.sendTransitionFail(r,i,a)}function Z(t,n,r){if(t instanceof DOMException&&t.name===`AbortError`)throw new e.t(e.c.TRANSITION_CANCELLED);Jt(t,n,r)}function Jt(t,n,r){throw t instanceof e.t?(t.setCode(n),t):new e.t(n,Xt(t,r))}const Yt=new Set([`code`,`segment`,`path`,`redirect`]);function Xt(e,t){let n={segment:t};if(e instanceof Error)return{...n,message:e.message,stack:e.stack,...`cause`in e&&e.cause!==void 0&&{cause:e.cause}};if(e&&typeof e==`object`){let t={};for(let[n,r]of Object.entries(e))Yt.has(n)||(t[n]=r);return{...n,...t}}return n}async function Zt(t,n,r){let i;try{i=await t}catch(e){Z(e,n,r);return}if(!i)throw new e.t(n,{segment:r})}async function Qt(t,n,r,i,a,o,s,c,l,u){await Zt(l,r,u);for(let l=c;l<n.length;l++){if(!s())throw new e.t(e.c.TRANSITION_CANCELLED);let c=n[l],u=t.get(c);if(!u)continue;let d=!1;try{d=u(i,a,o)}catch(e){Z(e,r,c)}if(d instanceof Promise){await Zt(d,r,c);continue}if(!d)throw new e.t(r,{segment:c})}}async function $t(t,n,r,i,a,o,s,c){if(await t,!c())throw new e.t(e.c.TRANSITION_CANCELLED);if(i){let t=Q(n,r,e.c.CANNOT_ACTIVATE,a,o,s,c);if(t!==void 0&&await t,!c())throw new e.t(e.c.TRANSITION_CANCELLED)}}function en(t,n,r,i,a,o,s,c,l,u){if(a){let a=Q(t,r,e.c.CANNOT_DEACTIVATE,s,c,l,u);if(a!==void 0)return $t(a,n,i,o,s,c,l,u)}if(!u())throw new e.t(e.c.TRANSITION_CANCELLED);if(o)return Q(n,i,e.c.CANNOT_ACTIVATE,s,c,l,u)}function Q(t,n,r,i,a,o,s){for(let[c,l]of n.entries()){if(!s())throw new e.t(e.c.TRANSITION_CANCELLED);let u=t.get(l);if(!u)continue;let d=!1;try{d=u(i,a,o)}catch(e){Z(e,r,l)}if(d instanceof Promise)return Qt(t,n,r,i,a,o,s,c+1,d,l);if(!d)throw new e.t(r,{segment:l})}}const tn=[e.s.UNKNOWN_ROUTE];Object.freeze(tn);const nn={replace:!0};Object.freeze(nn);function rn(t,n){return n?.name===e.s.UNKNOWN_ROUTE&&!t.replace?{...t,replace:!0}:t}function an(e,t,n){return!!e&&!t.reload&&!t.force&&e.path===n.path}var on=class{lastSyncResolved=!1;lastSyncRejected=!1;#e;#t=null;#n=0;setDependencies(e){this.#e=e}navigate(t,n,r){this.lastSyncResolved=!1;let i=this.#e;if(!i.canNavigate())return this.lastSyncRejected=!0,Ht;let a,o,s=!1,c=null;try{if(a=i.buildNavigateState(t,n),!a)return i.emitTransitionError(void 0,i.getState(),Bt),this.lastSyncRejected=!0,Ut;if(o=i.getState(),r=rn(r,o),an(o,r,a))return i.emitTransitionError(a,o,Vt),this.lastSyncRejected=!0,Wt;if(this.#o(),r.signal?.aborted)throw new e.t(e.c.TRANSITION_CANCELLED,{reason:r.signal.reason});let l=++this.#n;if(i.startTransition(a,o),s=!0,this.#n!==l)throw new e.t(e.c.TRANSITION_CANCELLED);let[u,d]=i.getLifecycleFunctions(),f=a.name===e.s.UNKNOWN_ROUTE,{toDeactivate:p,toActivate:m,intersection:h}=Y(a,o),ee=o&&!r.forceDeactivate&&p.length>0,te=!f&&m.length>0;if(u.size>0||d.size>0){c=new AbortController,this.#t=c;let t=c.signal,n=()=>this.#n===l&&i.isActive(),s=en(u,d,p,m,!!ee,te,a,o,t,n);if(s!==void 0)return this.#r(s,{toState:a,fromState:o,opts:r,toDeactivate:p,toActivate:m,intersection:h,canDeactivateFunctions:u},c,l);if(!n())throw new e.t(e.c.TRANSITION_CANCELLED);this.#a(c)}return this.lastSyncResolved=!0,Promise.resolve(X(i,{toState:a,fromState:o,opts:r,toDeactivate:p,toActivate:m,intersection:h,canDeactivateFunctions:u}))}catch(e){return this.#i(e,c,s,a,o),Promise.reject(e)}}navigateToDefault(t){let n=this.#e;if(!n.getOptions().defaultRoute)return Promise.reject(new e.t(e.c.ROUTE_NOT_FOUND,{routeName:`defaultRoute not configured`}));let{route:r,params:i}=n.resolveDefault();return r?this.navigate(r,i,t):Promise.reject(new e.t(e.c.ROUTE_NOT_FOUND,{routeName:`defaultRoute resolved to empty`}))}navigateToNotFound(t){this.#o();let n=this.#e.getState(),r=n?W(n.name).toReversed():[];Object.freeze(r);let i={deactivated:r,activated:tn,intersection:``};Object.freeze(i);let a={phase:`activating`,...n&&{from:n.name},reason:`success`,segments:i};Object.freeze(a);let o={name:e.s.UNKNOWN_ROUTE,params:{},path:t,transition:a};return Object.freeze(o),this.#e.setState(o),this.#e.emitTransitionSuccess(o,n,nn),o}abortCurrentNavigation(){this.#t?.abort(new e.t(e.c.TRANSITION_CANCELLED)),this.#t=null}async#r(t,n,r,i){let a=this.#e,o=()=>this.#n===i&&!r.signal.aborted&&a.isActive();try{if(n.opts.signal){if(n.opts.signal.aborted)throw new e.t(e.c.TRANSITION_CANCELLED,{reason:n.opts.signal.reason});n.opts.signal.addEventListener(`abort`,()=>{r.abort(n.opts.signal?.reason)},{once:!0,signal:r.signal})}if(await t,!o())throw new e.t(e.c.TRANSITION_CANCELLED);return X(a,n)}catch(e){throw qt(a,e,n.toState,n.fromState),e}finally{this.#a(r)}}#i(e,t,n,r,i){t&&this.#a(t),n&&r&&qt(this.#e,e,r,i)}#a(e){e.abort(),this.#t===e&&(this.#t=null)}#o(){this.#e.isTransitioning()&&(n.logger.warn(`router.navigate`,`Concurrent navigation detected on shared router instance. For SSR, use cloneRouter() to create isolated instance per request.`),this.#t?.abort(new e.t(e.c.TRANSITION_CANCELLED)),this.#e.cancelNavigation())}};const sn={replace:!0};Object.freeze(sn);var cn=class{#e;setDependencies(e){this.#e=e}async start(t){let n=this.#e,r=n.getOptions(),i=n.matchPath(t);if(!i&&!r.allowNotFound){let r=new e.t(e.c.ROUTE_NOT_FOUND,{path:t});throw n.emitTransitionError(void 0,void 0,r),r}return n.completeStart(),i?n.navigate(i.name,i.params,sn):n.navigateToNotFound(t)}stop(){this.#e.clearState()}},ln=class{#e;#t;#n;#r;#i;#a;constructor(e){this.#e=e.routerFSM,this.#t=e.emitter,this.#n=void 0,this.#s()}static validateSubscribeListener(e){if(typeof e!=`function`)throw TypeError(`[router.subscribe] Expected a function. For Observable pattern use @real-router/rx package`)}emitRouterStart(){this.#t.emit(e.l.ROUTER_START)}emitRouterStop(){this.#t.emit(e.l.ROUTER_STOP)}emitTransitionStart(t,n){this.#t.emit(e.l.TRANSITION_START,t,n)}emitTransitionSuccess(t,n,r){this.#t.emit(e.l.TRANSITION_SUCCESS,t,n,r)}emitTransitionError(t,n,r){this.#t.emit(e.l.TRANSITION_ERROR,t,n,r)}emitTransitionCancel(t,n){this.#t.emit(e.l.TRANSITION_CANCEL,t,n)}sendStart(){this.#e.send(c.START)}sendStop(){this.#e.send(c.STOP)}sendDispose(){this.#e.send(c.DISPOSE)}sendStarted(){this.#e.send(c.STARTED)}sendNavigate(e,t){this.#n=e,this.#e.forceState(s.TRANSITIONING),this.emitTransitionStart(e,t)}sendComplete(e,t,n={}){this.#e.forceState(s.READY),this.emitTransitionSuccess(e,t,n),this.#n===e&&(this.#n=void 0)}sendFail(e,t,n){let r=this.#n;this.#r=e,this.#i=t,this.#a=n,this.#e.send(c.FAIL),this.#n===r&&(this.#n=void 0)}sendFailSafe(e,t,n){this.isReady()?this.sendFail(e,t,n):this.emitTransitionError(e,t,n)}sendCancel(e,t){let n=this.#n;this.#r=e,this.#i=t,this.#e.send(c.CANCEL),this.#n===n&&(this.#n=void 0)}canBeginTransition(){return this.#e.canSend(c.NAVIGATE)}canStart(){return this.#e.canSend(c.START)}canCancel(){return this.#e.canSend(c.CANCEL)}isActive(){let e=this.#e.getState();return e!==s.IDLE&&e!==s.DISPOSED}isDisposed(){return this.#e.getState()===s.DISPOSED}isTransitioning(){return this.#e.getState()===s.TRANSITIONING}isReady(){return this.#e.getState()===s.READY}getCurrentToState(){return this.#n}addEventListener(e,t){return this.#t.on(e,t)}subscribe(t){return this.#t.on(e.l.TRANSITION_SUCCESS,(e,n)=>{t({route:e,previousRoute:n})})}clearAll(){this.#t.clearAll()}setLimits(e){this.#t.setLimits(e)}sendCancelIfTransitioning(e){this.canCancel()&&this.sendCancel(this.#n,e)}#o(){this.emitTransitionError(this.#r,this.#i,this.#a)}#s(){let e=this.#e;e.on(s.STARTING,c.STARTED,()=>{this.emitRouterStart()}),e.on(s.READY,c.STOP,()=>{this.emitRouterStop()}),e.on(s.TRANSITIONING,c.CANCEL,()=>{let e=this.#r;e!==void 0&&this.emitTransitionCancel(e,this.#i)}),e.on(s.STARTING,c.FAIL,()=>{this.#o()}),e.on(s.READY,c.FAIL,()=>{this.#o()}),e.on(s.TRANSITIONING,c.FAIL,()=>{this.#o()})}};const un=new e.t(e.c.ROUTER_ALREADY_STARTED),dn=new Set([`all`,`warn-error`,`error-only`]);function fn(e){return typeof e==`string`&&dn.has(e)}function pn(e){return typeof e==`string`?`"${e}"`:typeof e==`object`?JSON.stringify(e):String(e)}function mn(e){if(typeof e!=`object`||!e)throw TypeError(`Logger config must be an object`);let t=e;for(let e of Object.keys(t))if(e!==`level`&&e!==`callback`)throw TypeError(`Unknown logger config property: "${e}"`);if(`level`in t&&t.level!==void 0&&!fn(t.level))throw TypeError(`Invalid logger level: ${pn(t.level)}. Expected: "all" | "warn-error" | "error-only"`);if(`callback`in t&&t.callback!==void 0&&typeof t.callback!=`function`)throw TypeError(`Logger callback must be a function, got ${typeof t.callback}`);return!0}var hn=class{router;options;limits;dependenciesStore;state;routes;routeLifecycle;plugins;navigation;lifecycle;eventBus;constructor(e){this.router=e.router,this.options=e.options,this.limits=e.limits,this.dependenciesStore=e.dependenciesStore,this.state=e.state,this.routes=e.routes,this.routeLifecycle=e.routeLifecycle,this.plugins=e.plugins,this.navigation=e.navigation,this.lifecycle=e.lifecycle,this.eventBus=e.eventBus}wireLimits(){this.dependenciesStore.limits=this.limits,this.plugins.setLimits(this.limits),this.eventBus.setLimits({maxListeners:this.limits.maxListeners,warnListeners:this.limits.warnListeners,maxEventDepth:this.limits.maxEventDepth}),this.routeLifecycle.setLimits(this.limits)}wireRouteLifecycleDeps(){let e={compileFactory:this.createCompileFactory()};this.routeLifecycle.setDependencies(e),this.routeLifecycle.setValidatorGetter(()=>{try{return t.r(this.router).validator}catch{return null}})}wireRoutesDeps(){this.routes.setDependencies({addActivateGuard:(e,t)=>{this.routeLifecycle.addCanActivate(e,t,!0)},addDeactivateGuard:(e,t)=>{this.routeLifecycle.addCanDeactivate(e,t,!0)},makeState:(e,t,n,r)=>this.state.makeState(e,t,n,r),getState:()=>this.state.get(),areStatesEqual:(e,t,n)=>this.state.areStatesEqual(e,t,n),getDependency:e=>this.dependenciesStore.dependencies[e],forwardState:(e,n)=>{let r=t.r(this.router);return r.validator?.routes.validateStateBuilderArgs(e,n,`forwardState`),r.forwardState(e,n)}}),this.routes.setLifecycleNamespace(this.routeLifecycle)}wirePluginsDeps(){let e={addEventListener:(e,t)=>this.eventBus.addEventListener(e,t),canNavigate:()=>this.eventBus.canBeginTransition(),compileFactory:this.createCompileFactory()};this.plugins.setDependencies(e),this.plugins.setValidatorGetter(()=>{try{return t.r(this.router).validator}catch{return null}})}wireNavigationDeps(){this.navigation.setDependencies({getOptions:()=>this.options.get(),hasRoute:e=>this.routes.hasRoute(e),getState:()=>this.state.get(),setState:e=>{this.state.set(e)},buildNavigateState:(e,n)=>{let r=t.r(this.router);r.validator?.routes.validateStateBuilderArgs(e,n,`navigate`);let{name:i,params:a}=r.forwardState(e,n),o=this.routes.getMetaForState(i);if(o===void 0)return;let s=r.buildPath(i,a);return this.state.makeState(i,a,s,o,!0)},resolveDefault:()=>{let e=this.options.get();return{route:ot(e.defaultRoute,e=>this.dependenciesStore.dependencies[e]),params:ot(e.defaultParams,e=>this.dependenciesStore.dependencies[e])}},startTransition:(e,t)=>{this.eventBus.sendNavigate(e,t)},cancelNavigation:()=>{let e=this.eventBus.getCurrentToState();e!==void 0&&this.eventBus.sendCancel(e,this.state.get())},sendTransitionDone:(e,t,n)=>{this.eventBus.sendComplete(e,t,n)},sendTransitionFail:(e,t,n)=>{this.eventBus.sendFail(e,t,n)},emitTransitionError:(e,t,n)=>{this.eventBus.sendFailSafe(e,t,n)},emitTransitionSuccess:(e,t,n)=>{this.eventBus.emitTransitionSuccess(e,t,n)},canNavigate:()=>this.eventBus.canBeginTransition(),getLifecycleFunctions:()=>this.routeLifecycle.getFunctions(),isActive:()=>this.router.isActive(),isTransitioning:()=>this.eventBus.isTransitioning(),clearCanDeactivate:e=>{this.routeLifecycle.clearCanDeactivate(e)}})}wireLifecycleDeps(){this.lifecycle.setDependencies({getOptions:()=>this.options.get(),navigate:(e,t,n)=>this.navigation.navigate(e,t,n),navigateToNotFound:e=>this.navigation.navigateToNotFound(e),clearState:()=>{this.state.set(void 0)},matchPath:e=>this.routes.matchPath(e,this.options.get()),completeStart:()=>{this.eventBus.sendStarted()},emitTransitionError:(e,t,n)=>{this.eventBus.sendFail(e,t,n)}})}wireStateDeps(){this.state.setDependencies({getDefaultParams:()=>this.routes.getStore().config.defaultParams,buildPath:(e,n)=>t.r(this.router).buildPath(e,n),getUrlParams:e=>this.routes.getUrlParams(e)})}createCompileFactory(){let{router:e,dependenciesStore:t}=this;return n=>n(e,e=>t.dependencies[e])}};function gn(e){e.wireLimits(),e.wireRouteLifecycleDeps(),e.wireRoutesDeps(),e.wirePluginsDeps(),e.wireNavigationDeps(),e.wireLifecycleDeps(),e.wireStateDeps()}const _n=Object.freeze({});var vn=class r{#e;#t;#n;#r;#i;#a;#o;#s;#c;#l;constructor(r=[],i={},a={}){i.logger&&mn(i.logger)&&(n.logger.configure(i.logger),delete i.logger),ct.validateOptionsIsObject(i),d(a),r.length>0&&f(r),this.#e=new ct(i),this.#t=e.n(i.limits),this.#n=p(a),this.#r=new ft,this.#i=new Rt(r,yn(this.#e.get())),this.#a=new _t,this.#o=new ht,this.#s=new on,this.#c=new cn,this.#l=new ln({routerFSM:u(),emitter:new o({onListenerError:(e,t)=>{n.logger.error(`Router`,`Error in listener for ${e}:`,t)},onListenerWarn:(e,t)=>{n.logger.warn(`router.addEventListener`,`Event "${e}" has ${t} listeners — possible memory leak`)}})}),gn(new hn({router:this,options:this.#e,limits:this.#t,dependenciesStore:this.#n,state:this.#r,routes:this.#i,routeLifecycle:this.#a,plugins:this.#o,navigation:this.#s,lifecycle:this.#c,eventBus:this.#l}));let s=new Map;t.i(this,{makeState:(e,t,n,r)=>this.#r.makeState(e,t,n,r),forwardState:t.n(`forwardState`,(e,t)=>this.#i.forwardState(e,t),s),buildStateResolved:(e,t)=>this.#i.buildStateResolved(e,t),matchPath:(e,t)=>this.#i.matchPath(e,t),getOptions:()=>this.#e.get(),addEventListener:(e,t)=>this.#l.addEventListener(e,t),buildPath:t.n(`buildPath`,(t,n)=>this.#i.buildPath(t,n??e.a,this.#e.get()),s),start:t.t(`start`,e=>this.#c.start(e),s),interceptors:s,setRootPath:e=>{this.#i.setRootPath(e)},getRootPath:()=>this.#i.getStore().rootPath,getTree:()=>this.#i.getStore().tree,isDisposed:()=>this.#l.isDisposed(),validator:null,dependenciesGetStore:()=>this.#n,cloneOptions:()=>({...this.#e.get()}),cloneDependencies:()=>({...this.#n.dependencies}),getLifecycleFactories:()=>this.#a.getFactories(),getPluginFactories:()=>this.#o.getAll(),routeGetStore:()=>this.#i.getStore(),getStateName:()=>this.#r.get()?.name,isTransitioning:()=>this.#l.isTransitioning(),clearState:()=>{this.#r.set(void 0)},setState:e=>{this.#r.set(e)},routerExtensions:[]}),this.isActiveRoute=this.isActiveRoute.bind(this),this.buildPath=this.buildPath.bind(this),this.getState=this.getState.bind(this),this.getPreviousState=this.getPreviousState.bind(this),this.areStatesEqual=this.areStatesEqual.bind(this),this.shouldUpdateNode=this.shouldUpdateNode.bind(this),this.isActive=this.isActive.bind(this),this.start=this.start.bind(this),this.stop=this.stop.bind(this),this.dispose=this.dispose.bind(this),this.canNavigateTo=this.canNavigateTo.bind(this),this.usePlugin=this.usePlugin.bind(this),this.navigate=this.navigate.bind(this),this.navigateToDefault=this.navigateToDefault.bind(this),this.navigateToNotFound=this.navigateToNotFound.bind(this),this.subscribe=this.subscribe.bind(this)}isActiveRoute(e,r,i,a){return t.r(this).validator?.routes.validateIsActiveRouteArgs(e,r,i,a),t.r(this).validator?.routes.validateRouteName(e,`isActiveRoute`),e===``?(n.logger.warn(`real-router`,`isActiveRoute("") called with empty string. Root node is not considered a parent of any route.`),!1):this.#i.isActiveRoute(e,r,i,a)}buildPath(e,n){let r=t.r(this);return r.validator?.routes.validateBuildPathArgs(e),r.validator?.navigation.validateParams(n,`buildPath`),r.buildPath(e,n)}getState(){return this.#r.get()}getPreviousState(){return this.#r.getPrevious()}areStatesEqual(e,n,r=!0){return t.r(this).validator?.state.validateAreStatesEqualArgs(e,n,r),this.#r.areStatesEqual(e,n,r)}shouldUpdateNode(e){return t.r(this).validator?.routes.validateShouldUpdateNodeArgs(e),Rt.shouldUpdateNode(e)}isActive(){return this.#l.isActive()}start(e){if(!this.#l.canStart())return Promise.reject(un);t.r(this).validator?.navigation.validateStartArgs(e),this.#l.sendStart();let n=t.r(this).start(e).catch(e=>{throw this.#l.isReady()&&(this.#c.stop(),this.#l.sendStop()),e});return r.#d(n),n}stop(){return this.#s.abortCurrentNavigation(),this.#l.sendCancelIfTransitioning(this.#r.get()),!this.#l.isReady()&&!this.#l.isTransitioning()?this:(this.#c.stop(),this.#l.sendStop(),this)}dispose(){if(this.#l.isDisposed())return;this.#s.abortCurrentNavigation(),this.#l.sendCancelIfTransitioning(this.#r.get()),(this.#l.isReady()||this.#l.isTransitioning())&&(this.#c.stop(),this.#l.sendStop()),this.#l.sendDispose(),this.#l.clearAll(),this.#o.disposeAll();let e=t.r(this);for(let t of e.routerExtensions)for(let e of t.keys)delete this[e];e.routerExtensions.length=0,this.#i.clearRoutes(),this.#a.clearAll(),this.#r.reset(),this.#n.dependencies=Object.create(null),this.#f()}canNavigateTo(e,n){let r=t.r(this);if(r.validator?.routes.validateRouteName(e,`canNavigateTo`),r.validator?.navigation.validateParams(n,`canNavigateTo`),!this.#i.hasRoute(e))return!1;let{name:i,params:a}=r.forwardState(e,n??{}),o=this.#r.makeState(i,a),s=this.#r.get(),{toDeactivate:c,toActivate:l}=Y(o,s);return this.#a.canNavigateTo(c,l,o,s)}usePlugin(...e){let n=e.filter(Boolean);if(n.length===0)return()=>{};let r=t.r(this);r.validator?.plugins.validatePluginLimit(this.#o.count(),this.#t);for(let e of n)r.validator?.plugins.validateNoDuplicatePlugins(e,this.#o.getAll());return this.#o.use(...n)}subscribe(e){return ln.validateSubscribeListener(e),this.#l.subscribe(e)}navigate(n,i,a){let o=t.r(this);o.validator?.navigation.validateNavigateArgs(n),o.validator?.navigation.validateParams(i,`navigate`);let s=a??_n;o.validator?.navigation.validateNavigationOptions(s,`navigate`);let c=this.#s.navigate(n,i??e.a,s);return this.#s.lastSyncResolved?this.#s.lastSyncResolved=!1:this.#s.lastSyncRejected?this.#s.lastSyncRejected=!1:r.#d(c),c}navigateToDefault(e){let n=t.r(this);n.validator?.navigation.validateNavigateToDefaultArgs(e);let i=e??_n;n.validator?.navigation.validateNavigationOptions(i,`navigateToDefault`);let a=this.#s.navigateToDefault(i);return this.#s.lastSyncResolved?this.#s.lastSyncResolved=!1:this.#s.lastSyncRejected?this.#s.lastSyncRejected=!1:r.#d(a),a}navigateToNotFound(t){if(!this.#l.isActive())throw new e.t(e.c.ROUTER_NOT_STARTED);if(t!==void 0&&typeof t!=`string`)throw TypeError(`[router.navigateToNotFound] path must be a string, got ${typeof t}`);let n=t??this.#r.get().path;return this.#s.navigateToNotFound(n)}static#u=t=>{t instanceof e.t&&(t.code===e.c.SAME_STATES||t.code===e.c.TRANSITION_CANCELLED||t.code===e.c.ROUTER_NOT_STARTED||t.code===e.c.ROUTE_NOT_FOUND)||n.logger.error(`router.navigate`,`Unexpected navigation error`,t)};static#d(e){e.catch(r.#u)}#f(){this.navigate=$,this.navigateToDefault=$,this.navigateToNotFound=$,this.start=$,this.stop=$,this.usePlugin=$,this.subscribe=$,this.canNavigateTo=$}};function $(){throw new e.t(e.c.ROUTER_DISPOSED)}function yn(e){return{strictTrailingSlash:e.trailingSlash===`strict`,strictQueryParams:e.queryParamsMode===`strict`,urlParamsEncoding:e.urlParamsEncoding,queryParams:e.queryParams}}Object.defineProperty(exports,`a`,{enumerable:!0,get:function(){return I}}),Object.defineProperty(exports,`c`,{enumerable:!0,get:function(){return P}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return H}}),Object.defineProperty(exports,`l`,{enumerable:!0,get:function(){return nt}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return B}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return bt}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return V}}),Object.defineProperty(exports,`s`,{enumerable:!0,get:function(){return F}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return vn}}),Object.defineProperty(exports,`u`,{enumerable:!0,get:function(){return f}});
|
|
6
|
+
//# sourceMappingURL=Router-NL2_9FQk.js.map
|