@real-router/core 0.41.0 → 0.42.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.
Files changed (63) hide show
  1. package/dist/cjs/Router-B2tmtNiM.d.ts +353 -0
  2. package/dist/cjs/Router-CVNR-dug.js +6 -0
  3. package/dist/cjs/Router-CVNR-dug.js.map +1 -0
  4. package/dist/cjs/RouterError-BkgjTHQg.js +2 -0
  5. package/dist/cjs/RouterError-BkgjTHQg.js.map +1 -0
  6. package/dist/cjs/RouterValidator-TUi8eT8Q.d.ts +112 -0
  7. package/dist/cjs/api.d.ts +17 -12
  8. package/dist/cjs/api.js +2 -1
  9. package/dist/cjs/api.js.map +1 -1
  10. package/dist/cjs/getPluginApi-BXrM_Nwv.js +2 -0
  11. package/dist/cjs/getPluginApi-BXrM_Nwv.js.map +1 -0
  12. package/dist/cjs/index.d.ts +206 -196
  13. package/dist/cjs/index.js +2 -1
  14. package/dist/cjs/index.js.map +1 -1
  15. package/dist/cjs/internals-na15rxo_.js +2 -0
  16. package/dist/cjs/internals-na15rxo_.js.map +1 -0
  17. package/dist/cjs/utils.d.ts +6 -3
  18. package/dist/cjs/utils.js +2 -1
  19. package/dist/cjs/utils.js.map +1 -1
  20. package/dist/cjs/validation.d.ts +153 -152
  21. package/dist/cjs/validation.js +1 -1
  22. package/dist/esm/Router-4JRfQLMM.d.mts +353 -0
  23. package/dist/esm/Router-C_k70gHi.mjs +6 -0
  24. package/dist/esm/Router-C_k70gHi.mjs.map +1 -0
  25. package/dist/esm/RouterError-D0RlQE_5.mjs +2 -0
  26. package/dist/esm/RouterError-D0RlQE_5.mjs.map +1 -0
  27. package/dist/esm/RouterValidator-DphcVMEp.d.mts +112 -0
  28. package/dist/esm/api.d.mts +17 -12
  29. package/dist/esm/api.mjs +2 -1
  30. package/dist/esm/api.mjs.map +1 -1
  31. package/dist/esm/getPluginApi-D0bBPuLp.mjs +2 -0
  32. package/dist/esm/getPluginApi-D0bBPuLp.mjs.map +1 -0
  33. package/dist/esm/index.d.mts +206 -196
  34. package/dist/esm/index.mjs +2 -1
  35. package/dist/esm/index.mjs.map +1 -1
  36. package/dist/esm/internals-CCymabFj.mjs +2 -0
  37. package/dist/esm/internals-CCymabFj.mjs.map +1 -0
  38. package/dist/esm/utils.d.mts +6 -3
  39. package/dist/esm/utils.mjs +2 -1
  40. package/dist/esm/utils.mjs.map +1 -1
  41. package/dist/esm/validation.d.mts +153 -152
  42. package/dist/esm/validation.mjs +1 -1
  43. package/package.json +5 -7
  44. package/src/helpers.ts +9 -6
  45. package/src/namespaces/OptionsNamespace/constants.ts +1 -0
  46. package/dist/cjs/Router-DoJ3NWsT.d.ts +0 -46
  47. package/dist/cjs/RouterValidator-CaIeCVeB.d.ts +0 -136
  48. package/dist/cjs/index.d-y2b-8_3Y.d.ts +0 -236
  49. package/dist/cjs/metafile-cjs.json +0 -1
  50. package/dist/cjs/validation.js.map +0 -1
  51. package/dist/esm/Router-DoJ3NWsT.d.mts +0 -46
  52. package/dist/esm/RouterValidator-CaIeCVeB.d.mts +0 -136
  53. package/dist/esm/chunk-EPF2YSMX.mjs +0 -1
  54. package/dist/esm/chunk-EPF2YSMX.mjs.map +0 -1
  55. package/dist/esm/chunk-UPJLWPEL.mjs +0 -1
  56. package/dist/esm/chunk-UPJLWPEL.mjs.map +0 -1
  57. package/dist/esm/chunk-UUG7DSTN.mjs +0 -1
  58. package/dist/esm/chunk-UUG7DSTN.mjs.map +0 -1
  59. package/dist/esm/chunk-XQJDGUQE.mjs +0 -1
  60. package/dist/esm/chunk-XQJDGUQE.mjs.map +0 -1
  61. package/dist/esm/index.d-y2b-8_3Y.d.mts +0 -236
  62. package/dist/esm/metafile-esm.json +0 -1
  63. package/dist/esm/validation.mjs.map +0 -1
@@ -0,0 +1,353 @@
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 ../route-tree/dist/esm/index.d.mts
189
+ //#region src/builder/types.d.ts
190
+ /**
191
+ * Definition of a route for configuration.
192
+ */
193
+ interface RouteDefinition {
194
+ [key: string]: unknown;
195
+ name: string;
196
+ path: string;
197
+ children?: RouteDefinition[] | undefined;
198
+ }
199
+ /**
200
+ * Immutable route tree node.
201
+ *
202
+ * This is the core data structure of the new route-tree architecture.
203
+ * It contains only data (no methods) and is created by the builder.
204
+ *
205
+ * All caches are pre-computed at build time:
206
+ * - nonAbsoluteChildren: filtered children without absolute paths
207
+ * - absoluteDescendants: all descendants with absolute paths (recursive)
208
+ * - parentSegments: array from root to parent
209
+ * - fullName: pre-computed "users.profile" instead of runtime join
210
+ */
211
+ interface RouteTree {
212
+ /** Route segment name (e.g., "users" in "users.profile") */
213
+ readonly name: string;
214
+ /** Route path pattern (e.g., "/users/:id") */
215
+ readonly path: string;
216
+ /** Whether this route uses absolute path matching (path starts with "~") */
217
+ readonly absolute: boolean;
218
+ /** Child route nodes (Map for O(1) lookup by name) */
219
+ readonly children: ReadonlyMap<string, RouteTree>;
220
+ /** Parameter metadata extracted from path pattern (replaces parser dependency) */
221
+ readonly paramMeta: ParamMeta;
222
+ /** Parent node (null for root) */
223
+ readonly parent: RouteTree | null;
224
+ /** Children without absolute paths (for regular matching) */
225
+ readonly nonAbsoluteChildren: readonly RouteTree[];
226
+ /** Pre-computed full name (e.g., "users.profile") */
227
+ readonly fullName: string;
228
+ /**
229
+ * Pre-computed static path for routes without parameters.
230
+ * Used by buildPath fast path to avoid inject() overhead.
231
+ * Only set when route has no URL params, query params, or splat params.
232
+ */
233
+ readonly staticPath: string | null;
234
+ /**
235
+ * Pre-computed parameter type map for this segment.
236
+ * Cached to avoid recomputing on every navigation.
237
+ * Maps param name → "url" | "query".
238
+ */
239
+ readonly paramTypeMap: Readonly<Record<string, "url" | "query">>;
240
+ }
241
+ /**
242
+ * Options for building a route tree.
243
+ */
244
+ //#endregion
245
+ //#region src/createMatcher.d.ts
246
+ /**
247
+ * Query string formatting options.
248
+ *
249
+ * Controls how arrays, booleans, nulls, and numbers are serialized in query strings.
250
+ */
251
+ interface QueryParamsConfig {
252
+ readonly arrayFormat?: "none" | "brackets" | "index" | "comma";
253
+ readonly booleanFormat?: "none" | "string" | "empty-true";
254
+ readonly nullFormat?: "default" | "hidden";
255
+ readonly numberFormat?: "none" | "auto";
256
+ }
257
+ /**
258
+ * Options for creating a path matcher.
259
+ */
260
+ interface CreateMatcherOptions {
261
+ readonly caseSensitive?: boolean;
262
+ readonly strictTrailingSlash?: boolean;
263
+ readonly strictQueryParams?: boolean;
264
+ readonly urlParamsEncoding?: "default" | "uri" | "uriComponent" | "none";
265
+ readonly queryParams?: QueryParamsConfig;
266
+ }
267
+ /**
268
+ * Path matcher instance type.
269
+ *
270
+ * Opaque type — consumers use methods (match, buildPath, hasRoute, etc.)
271
+ * without knowing the underlying SegmentMatcher implementation.
272
+ */
273
+ type Matcher = SegmentMatcher;
274
+ /**
275
+ * Creates a path matcher with search-params DI baked in.
276
+ *
277
+ * @param options - Matcher configuration
278
+ * @returns Configured matcher instance
279
+ *
280
+ * @example
281
+ * ```typescript
282
+ * const matcher = createMatcher({
283
+ * strictTrailingSlash: true,
284
+ * queryParams: { booleanFormat: "string" },
285
+ * });
286
+ * matcher.registerTree(tree);
287
+ * const result = matcher.match("/users/123");
288
+ * ```
289
+ */
290
+ //#endregion
291
+ //#region src/types.d.ts
292
+ /**
293
+ * Immutable limits configuration type.
294
+ */
295
+ type Limits = Readonly<LimitsConfig>;
296
+ /**
297
+ * Extended build result that includes segments for path building.
298
+ * Used internally to avoid duplicate getSegmentsByName calls.
299
+ *
300
+ * @param segments - Route segments from getSegmentsByName (typed as unknown[] for cross-package compatibility)
301
+ * @internal
302
+ */
303
+ interface BuildStateResultWithSegments<P extends Params = Params> {
304
+ readonly state: RouteTreeState<P>;
305
+ readonly segments: readonly unknown[];
306
+ }
307
+ //#endregion
308
+ //#region src/Router.d.ts
309
+ /**
310
+ * Router class with integrated namespace architecture.
311
+ *
312
+ * All functionality is provided by namespace classes:
313
+ * - OptionsNamespace: getOptions (immutable)
314
+ * - DependenciesStore: get/set/remove dependencies
315
+ * - EventEmitter: subscribe
316
+ * - StateNamespace: state storage (getState, setState, getPreviousState)
317
+ * - RoutesNamespace: route tree operations
318
+ * - RouteLifecycleNamespace: canActivate/canDeactivate guards
319
+ * - PluginsNamespace: plugin lifecycle
320
+ * - NavigationNamespace: navigate
321
+ * - RouterLifecycleNamespace: start, stop, isStarted
322
+ *
323
+ * @internal This class implementation is internal. Use createRouter() instead.
324
+ */
325
+ declare class Router$1<Dependencies extends DefaultDependencies = DefaultDependencies> implements Router<Dependencies> {
326
+ #private;
327
+ [key: string]: unknown;
328
+ /**
329
+ * @param routes - Route definitions
330
+ * @param options - Router options
331
+ * @param dependencies - DI dependencies
332
+ */
333
+ constructor(routes?: Route<Dependencies>[], options?: Partial<Options>, dependencies?: Dependencies);
334
+ isActiveRoute(name: string, params?: Params, strictEquality?: boolean, ignoreQueryParams?: boolean): boolean;
335
+ buildPath(route: string, params?: Params): string;
336
+ getState<P extends Params = Params>(): State<P> | undefined;
337
+ getPreviousState(): State | undefined;
338
+ areStatesEqual(state1: State | undefined, state2: State | undefined, ignoreQueryParams?: boolean): boolean;
339
+ shouldUpdateNode(nodeName: string): (toState: State, fromState?: State) => boolean;
340
+ isActive(): boolean;
341
+ start(startPath: string): Promise<State>;
342
+ stop(): this;
343
+ dispose(): void;
344
+ canNavigateTo(name: string, params?: Params): boolean;
345
+ usePlugin(...plugins: (PluginFactory<Dependencies> | false | null | undefined)[]): Unsubscribe;
346
+ subscribe(listener: SubscribeFn): Unsubscribe;
347
+ navigate(routeName: string, routeParams?: Params, options?: NavigationOptions): Promise<State>;
348
+ navigateToDefault(options?: NavigationOptions): Promise<State>;
349
+ navigateToNotFound(path?: string): State;
350
+ }
351
+ //#endregion
352
+ 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 };
353
+ //# sourceMappingURL=Router-B2tmtNiM.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}}const m={defaultRoute:``,defaultParams:{},trailingSlash:`preserve`,queryParamsMode:`loose`,queryParams:{arrayFormat:`none`,booleanFormat:`none`,nullFormat:`default`,numberFormat:`none`},urlParamsEncoding:`default`,allowNotFound:!0,rewritePathOnMatch:!0};function h(e){Object.freeze(e);for(let t of Object.keys(e)){let n=e[t];n&&typeof n==`object`&&n.constructor===Object&&h(n)}return e}function g(e,t){return typeof e==`function`?e(t):e}function ee(e){if(!e||typeof e!=`object`||Array.isArray(e))throw TypeError(`[router.constructor] options must be a plain object`)}var te=class{#e;constructor(e={}){this.#e=h({...m,...e})}static validateOptionsIsObject(e){ee(e)}get(){return this.#e}};function _(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(!_(e[n],t[n]))return!1;return!0}return!1}const v=new WeakMap;function y(e){return v.get(e)}function ne(e,t){v.set(e,t)}var re=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&&ne(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(!_(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)||!_(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 b={[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},ie=Object.keys(b),x=`router.usePlugin`;function ae(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 oe=class t{#e=new Set;#t=new Set;#n;#r=e.i;#i=null;static validatePlugin(e){ae(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(x,`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(x,`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(x,`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 ie)e in n&&(typeof n[e]==`function`?(r.push(this.#n.addEventListener(b[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 se(e){let t=()=>e;return()=>t}var ce=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`?se(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 le(){return{decoders:Object.create(null),encoders:Object.create(null),defaultParams:Object.create(null),forwardMap:Object.create(null),forwardFnMap:Object.create(null)}}function ue(e,t){for(let n in e)if(e[n]!==t[n])return!1;return!0}function de(e,t,n){for(let r in e)if(!(r in n)&&e[r]!==t[r])return!1;return!0}function S(e){let t={name:e.name,path:e.path};return e.children&&(t.children=e.children.map(e=>S(e))),t}function fe(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}.`)&&fe(i.children,t,a))return!0}return!1}function pe(e,t){for(let n of Object.keys(e))t(n)&&delete e[n]}function me(e){return`(${e.replaceAll(/(^<|>$)/g,``)})`}const he=/([:*])([^/?<]+)(<[^>]+>)?(\?)?/g,ge=/([:*][^/?<]+(?:<[^>]+>)?)\?(?=\/|$)/g,_e=/\?(.+)$/;function ve(e){let t=[],n=[],r=[],i={},a=new Map,o=e.replaceAll(ge,`$1`),s=_e.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=he.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=`^${me(o)}$`;a.set(n,{pattern:new RegExp(e),constraint:o})}}return{urlParams:t,queryParams:n,spatParams:r,paramTypeMap:i,constraintPatterns:a,pathPattern:e}}const ye=/[^\w!$'()*+,.:;|~-]/gu,be=/[^\w!$'()*+,.:;|~-]/u,xe={default:e=>be.test(e)?e.replaceAll(ye,e=>encodeURIComponent(e)):e,uri:encodeURI,uriComponent:encodeURIComponent,none:e=>e},Se={default:decodeURIComponent,uri:decodeURI,uriComponent:decodeURIComponent,none:e=>e};function C(){return{staticChildren:Object.create(null),paramChild:void 0,splatChild:void 0,route:void 0,slashChildRoute:void 0}}function w(e){return e.length>1&&e.endsWith(`/`)?e.slice(0,-1):e}function Ce(e,t){return e===``?t:t===``?e:e+t}function we(e){let t={};if(e.length===0)return t;let n=e.split(`&`);for(let e of n){let n=e.indexOf(`=`);n===-1?t[e]=``:t[e.slice(0,n)]=e.slice(n+1)}return t}function Te(e){let t=[];for(let n of Object.keys(e)){let r=e[n],i=encodeURIComponent(n);t.push(r===``?i:`${i}=${encodeURIComponent(String(r))}`)}return t.join(`&`)}function T(e){return e>=48&&e<=57||e>=65&&e<=70||e>=97&&e<=102}function Ee(e){let t=0;for(;t<e.length;)if(e[t]===`%`){if(t+2>=e.length)return!1;let n=e.codePointAt(t+1)??0,r=e.codePointAt(t+2)??0;if(!T(n)||!T(r))return!1;t+=3}else t++;return!0}const E=/<[^>]*>/g;function D(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(E,``),u=o?l:Ce(n,l),d=i;a||(d=De(e,t,u,o?``:n,r,i));for(let n of t.children.values())D(e,n,u,r,d);a||r.pop()}function De(e,t,n,r,i,a){let o=je(n,r),s=Object.freeze([...i]),c=Oe(s),l=w(n),u=Re(e.rootQueryParams,i),d=ze(i),{buildStaticParts:f,buildParamSlots:p}=Le(o?w(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?ke(e,m,r):Ae(e,m,n,l,t),m}function Oe(e){let t={};for(let n of e)t[n.fullName]=n.paramTypeMap;return Object.freeze(t)}function ke(e,t,n){Ne(e,t,n);let r=w(n),i=e.options.caseSensitive?r:r.toLowerCase();e.staticCache.has(i)&&e.staticCache.set(i,t)}function Ae(e,t,n,r,i){if(Me(e,t,n),i.paramMeta.urlParams.length===0){let n=e.options.caseSensitive?r:r.toLowerCase();e.staticCache.set(n,t)}}function je(e,t){return w(e)===w(t)}function Me(e,t,n){let r=w(n);if(r===`/`){e.root.route=t;return}O(e,e.root,r,1,t)}function O(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(E,``).replace(/\?$/,``);t.paramChild??={node:C(),name:r},O(e,t.paramChild.node,n,s+1,i),s>=a?t.route??=i:O(e,t,n,s+1,i);return}t=Ie(e,t,c),r=s+1}t.route=i}function Ne(e,t,n){let r=Pe(e,n);r.slashChildRoute=t}function Pe(e,t){return Fe(e,e.root,t)}function Fe(e,t,n){let r=w(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=Ie(e,i,s),a=n+1}return i}function Ie(e,t,n){if(n.startsWith(`*`)){let e=n.slice(1);return t.splatChild??={node:C(),name:e},t.splatChild.node}if(n.startsWith(`:`)){let e=n.slice(1).replaceAll(E,``).replace(/\?$/,``);return t.paramChild??={node:C(),name:e},t.paramChild.node}let r=e.options.caseSensitive?n:n.toLowerCase();return r in t.staticChildren||(t.staticChildren[r]=C()),t.staticChildren[r]}function Le(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=xe[n],r=e.split(`/`),i=t(r[0]);for(let e=1;e<r.length;e++)i+=`/${t(r[e])}`;return i}:xe[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 Re(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 ze(e){let t=new Map;for(let n of e)for(let[e,r]of n.paramMeta.constraintPatterns)t.set(e,r);return t}const Be=/[\u0080-\uFFFF]/;var Ve=class{get options(){return this.#e}#e;#t=C();#n=new Map;#r=new Map;#i=new Map;#a=new Map;#o=``;#s=[];constructor(e){this.#e={caseSensitive:e?.caseSensitive??!0,strictTrailingSlash:e?.strictTrailingSlash??!1,strictQueryParams:e?.strictQueryParams??!1,urlParamsEncoding:e?.urlParamsEncoding??`default`,parseQueryString:e?.parseQueryString??we,buildQueryString:e?.buildQueryString??Te}}registerTree(e){this.#s=e.paramMeta.queryParams,D({root:this.#t,options:this.#e,routesByName:this.#n,segmentsByName:this.#r,metaByName:this.#i,staticCache:this.#a,rootQueryParams:this.#s},e,``,[],null)}match(e){let t=this.#f(e);if(!t)return;let[n,r,i]=t,a=this.#e.caseSensitive?r:r.toLowerCase(),o=this.#a.get(a);if(o)return this.#e.strictTrailingSlash&&!this.#m(n,o)?void 0:this.#p(o,{},i);let s={},c=this.#h(r,s);if(c&&!(this.#e.strictTrailingSlash&&!this.#m(n,c))&&!(c.hasConstraints&&!this.#v(s,c))&&this.#_(s))return this.#p(c,s,i)}buildPath(e,t,n){let r=this.#n.get(e);if(!r)throw Error(`[SegmentMatcher.buildPath] '${e}' is not defined`);r.hasConstraints&&t&&this.#c(r,e,t);let i=this.#l(r,t),a=this.#u(i,n?.trailingSlash),o=this.#d(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.#o=e}#c(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}'`)}}}#l(e,t){let n=e.buildStaticParts,r=e.buildParamSlots;if(r.length===0)return this.#o+n[0];let i=this.#o+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=typeof r==`object`?JSON.stringify(r):String(r),s=a.encoder(o);i+=s+n[e+1]}return i}#u(e,t){return t===`always`&&!e.endsWith(`/`)?`${e}/`:t===`never`&&e!==`/`&&e.endsWith(`/`)?e.slice(0,-1):e}#d(e,t,n){if(!t)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):``}#f(e){if(e===``&&(e=`/`),!e.startsWith(`/`))return;let t=e.indexOf(`#`);if(t!==-1&&(e=e.slice(0,t)),Be.test(e))return;if(this.#o.length>0){if(!e.startsWith(this.#o))return;e=e.slice(this.#o.length)||`/`}let n=e.indexOf(`?`),r=n===-1?e:e.slice(0,n),i=n===-1?void 0:e.slice(n+1);if(r.includes(`//`))return;let a=r;return[a,w(a),i]}#p(e,t,n){if(n!==void 0){let r=this.#e.parseQueryString(n);if(this.#e.strictQueryParams){let t=e.declaredQueryParamsSet;for(let e of Object.keys(r))if(!t.has(e))return}for(let e of Object.keys(r))t[e]=r[e]}return{segments:e.matchSegments,params:t,meta:e.meta}}#m(e,t){return(e.length>1&&e.endsWith(`/`))===t.hasTrailingSlash}#h(e,t){return e.length===1?this.#t.slashChildRoute??this.#t.route:this.#g(this.#t,e,1,t)}#g(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.#g(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}#_(e){let t=this.#e.urlParamsEncoding;if(t===`none`)return!0;let n=Se[t];for(let t in e){let r=e[t];if(r.includes(`%`)){if(!Ee(r))return!1;e[t]=n(r)}}return!0}#v(e,t){for(let[n,r]of t.constraintPatterns)if(!r.pattern.test(e[n]))return!1;return!0}};const k=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)},He=(e,t)=>{if(e===void 0)return t.boolean.decodeUndefined();let n=t.boolean.decodeRaw(e);if(n!==null)return n;let r=k(e),i=t.number.decode(r);return i===null?t.boolean.decodeValue(r):i},A=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)},Ue={none:{encodeArray:(e,t)=>{if(t.length===0)return``;let n=`${e}=${A(t[0])}`;for(let r=1;r<t.length;r++)n+=`&${e}=${A(t[r])}`;return n}},brackets:{encodeArray:(e,t)=>{if(t.length===0)return``;let n=`${e}[]=${A(t[0])}`;for(let r=1;r<t.length;r++)n+=`&${e}[]=${A(t[r])}`;return n}},index:{encodeArray:(e,t)=>{if(t.length===0)return``;let n=`${e}[0]=${A(t[0])}`;for(let r=1;r<t.length;r++)n+=`&${e}[${r}]=${A(t[r])}`;return n}},comma:{encodeArray:(e,t)=>{if(t.length===0)return`${e}=`;let n=`${e}=${A(t[0])}`;for(let e=1;e<t.length;e++)n+=`,${A(t[e])}`;return n}}},We={encode:(e,t)=>`${e}=${t}`,decodeUndefined:()=>null,decodeRaw:()=>null,decodeValue:e=>e},Ge={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},qe={none:We,string:Ge,"empty-true":Ke},Je={default:{encode:e=>e},hidden:{encode:()=>``}},Ye={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}},Xe=(e,t,n,r)=>({boolean:qe[t],null:Je[n],number:Ye[r],array:Ue[e]}),Ze={arrayFormat:`none`,booleanFormat:`none`,nullFormat:`default`,numberFormat:`none`,strategies:{boolean:qe.none,null:Je.default,number:Ye.none,array:Ue.none}},Qe=e=>{if(!e||e.arrayFormat===void 0&&e.booleanFormat===void 0&&e.nullFormat===void 0&&e.numberFormat===void 0)return Ze;let t=e.arrayFormat??`none`,n=e.booleanFormat??`none`,r=e.nullFormat??`default`,i=e.numberFormat??`none`;return{arrayFormat:t,booleanFormat:n,nullFormat:r,numberFormat:i,strategies:Xe(t,n,r,i)}},j=e=>encodeURIComponent(e),$e=(e,t,n)=>{let r=j(e);switch(typeof t){case`string`:case`number`:return`${r}=${j(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}=${j(t)}`;default:return`${r}=${j(t)}`}},et=e=>{let t=e.indexOf(`?`);return t===-1?e:e.slice(t+1)};function tt(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 nt(e,t,n,r,i){return i?He(r?e.slice(t+1,n):void 0,i):r?k(e.slice(t+1,n)):null}function rt(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}tt(r,k(e.slice(t,c)),nt(e,a,n,o,i),l)}const it=(e,t)=>{let n=et(e);if(n===``||n===`?`)return{};if(!t)return at(n);let r=Qe(t),i={},a=0,o=n.length;for(;a<o;){let e=n.indexOf(`&`,a);e===-1&&(e=o),rt(n,a,e,i,r.strategies),a=e+1}return i};function at(e){let t={};return ot(e,t),t}function ot(e,t){let n=0,r=e.length;for(;n<r;){let i=e.indexOf(`&`,n);i===-1&&(i=r),rt(e,n,i,t),n=i+1}}const st=(e,t)=>{let n=Object.keys(e);if(n.length===0)return``;let r=Qe(t),i=[];for(let t of n){let n=e[t];if(n===void 0)continue;let a=$e(t,n,r);a&&i.push(a)}return i.join(`&`)};function M(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=M(t,a);a.children.push(e)}return a}function ct(e,t,n){let r=M({name:e,path:t},null);for(let e of n){let t=M(e,r);r.children.push(t)}return r}function lt(e){return e.parent?.name?`${e.parent.fullName}.${e.name}`:e.name}function N(e,t){return e.endsWith(`/`)&&t.startsWith(`/`)?e+t.slice(1):e+t}function ut(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;let i=[],a=e.parent;for(;a?.path;)i.unshift(a),a=a.parent;let o=``;for(let e of i){let{urlParams:t,queryParams:n,spatParams:r}=e.paramMeta;if(t.length>0||n.length>0||r.length>0)return null;o=e.absolute?e.path:N(o,e.path)}return e.absolute?e.path:N(o,e.path)}function dt(e){let t=new Map;for(let n of e)t.set(n.name,n);return t}function ft(e){let t={};for(let n of e.urlParams)t[n]=`url`;for(let n of e.queryParams)t[n]=`query`;return t}function pt(e,t,n){let r=[],i=[];for(let a of e){let e=P(a,t,n);r.push(e),e.absolute||i.push(e)}return{childrenMap:dt(r),nonAbsoluteChildren:i}}function P(e,t,n){let r=ve(e.path),i=ft(r),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};a.fullName=lt(a);let{childrenMap:o,nonAbsoluteChildren:s}=pt(e.children,a,n);return a.children=o,a.nonAbsoluteChildren=s,a.staticPath=ut(a),n&&(Object.freeze(s),Object.freeze(i),Object.freeze(a.children),Object.freeze(a)),a}function mt(e,t=!0){return P(e,null,t)}function ht(e,t){let n=[];return{add(e){return n.push(e),this},addMany(e){return n.push(...e),this},build(r){return mt(ct(e,t,n),!r?.skipFreeze)}}}function gt(e,t,n,r){return ht(e,t).addMany(n).build(r)}function F(e){let t=e.absolute?`~${e.path}`:e.path,n={name:e.name,path:t};return e.children.size>0&&(n.children=[...e.children.values()].map(e=>F(e))),n}function _t(e){return[...e.children.values()].map(e=>F(e))}function vt(e){let t=e?.queryParams;return new Ve({...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=>it(e,t),buildQueryString:e=>st(e,t)})}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=gt(``,t,e),i=vt(n);return i.registerTree(r),{tree:r,matcher:i}}function yt(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,le()),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 bt(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 xt(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&&bt(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;xt(s,e,t,n,r,i,a),s.children&&H(s.children,t,n,r,i,a,e)}}function St(e,t){let n=[],r=le(),i=Object.create(null),a=new Map,o=new Map;for(let t of e)n.push(S(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:yt,resetStore:z,nodeToDefinition:F}}}const U=[];Object.freeze(U);function Ct(e){let t=e.length,n=[];for(let r=t-1;r>=0;r--)n.push(e[r]);return n}function wt(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 Tt(e){let t=typeof e;return t===`string`||t===`number`||t===`boolean`}function Et(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(Tt(t)&&Tt(i)&&String(t)!==String(i))return!1}return!0}function Dt(e,t,n,r,i,a){for(let o=0;o<a;o++){let a=r[o];if(a!==i[o]||!Et(a,e,t,n))return o}return a}const Ot=new Map;function W(e){let t=Ot.get(e);if(t)return t;let n=kt(e);return Object.freeze(n),Ot.set(e,n),n}function kt(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]:wt(e)}let G,K,q=null,At,jt,J=null;function Mt(e,t){if(!t)return{intersection:``,toActivate:W(e.name),toDeactivate:U};let n=y(e),r=y(t);if(!n&&!r)return{intersection:``,toActivate:W(e.name),toDeactivate:Ct(W(t.name))};let i=W(e.name),a=W(t.name),o=Math.min(a.length,i.length),s=Dt(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===At&&t===jt)return J;let n=Mt(e,t);return At=G,jt=K,J=q,G=e,K=t,q=n,n}function Nt(e){let t=[];for(let n of e)for(let e of n.paramMeta.urlParams)t.push(e);return t}function Pt(e){return e.at(-1)?.fullName??``}function Ft(e,t){return{name:t??Pt(e.segments),params:e.params,meta:e.meta}}var It=class{#e;#t;get#n(){return this.#e.depsStore}constructor(e=[],t){this.#e=St(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}=Ft(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 Ft({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 ue(t,s)?!o||de(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?Nt(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 Lt=new e.t(e.c.ROUTER_NOT_STARTED),Rt=new e.t(e.c.ROUTE_NOT_FOUND),zt=new e.t(e.c.SAME_STATES),Bt=Promise.reject(Lt),Vt=Promise.reject(Rt),Ht=Promise.reject(zt);Bt.catch(()=>{}),Vt.catch(()=>{}),Ht.catch(()=>{});function Ut(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 Wt({signal:e,...t}){return t}function Gt(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=Ut(i,a,o,s,c);let l=e.r(r);t.setState(l);let u=a.signal===void 0?a:Wt(a);return t.sendTransitionDone(l,i,u),l}function Kt(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 X(t,n,r){if(t instanceof DOMException&&t.name===`AbortError`)throw new e.t(e.c.TRANSITION_CANCELLED);qt(t,n,r)}function qt(t,n,r){throw t instanceof e.t?(t.setCode(n),t):new e.t(n,Yt(t,r))}const Jt=new Set([`code`,`segment`,`path`,`redirect`]);function Yt(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))Jt.has(n)||(t[n]=r);return{...n,...t}}return n}async function Xt(t,n,r){let i;try{i=await t}catch(e){X(e,n,r);return}if(!i)throw new e.t(n,{segment:r})}async function Zt(t,n,r,i,a,o,s,c,l,u){await Xt(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){X(e,r,c)}if(d instanceof Promise){await Xt(d,r,c);continue}if(!d)throw new e.t(r,{segment:c})}}async function Qt(t,n,r,i,a,o,s,c){if(await t,!c())throw new e.t(e.c.TRANSITION_CANCELLED);if(i){let t=Z(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 $t(t,n,r,i,a,o,s,c,l,u){if(a){let a=Z(t,r,e.c.CANNOT_DEACTIVATE,s,c,l,u);if(a!==void 0)return Qt(a,n,i,o,s,c,l,u)}if(!u())throw new e.t(e.c.TRANSITION_CANCELLED);if(o)return Z(n,i,e.c.CANNOT_ACTIVATE,s,c,l,u)}function Z(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){X(e,r,l)}if(d instanceof Promise)return Zt(t,n,r,i,a,o,s,c+1,d,l);if(!d)throw new e.t(r,{segment:l})}}const Q=[e.s.UNKNOWN_ROUTE];Object.freeze(Q);const en={replace:!0};Object.freeze(en);function tn(t,n){return n?.name===e.s.UNKNOWN_ROUTE&&!t.replace?{...t,replace:!0}:t}function nn(e,t,n){return!!e&&!t.reload&&!t.force&&e.path===n.path}var rn=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,Bt;let a,o,s=!1,c=null;try{if(a=i.buildNavigateState(t,n),!a)return i.emitTransitionError(void 0,i.getState(),Rt),this.lastSyncRejected=!0,Vt;if(o=i.getState(),r=tn(r,o),nn(o,r,a))return i.emitTransitionError(a,o,zt),this.lastSyncRejected=!0,Ht;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),g=o&&!r.forceDeactivate&&p.length>0,ee=!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=$t(u,d,p,m,!!g,ee,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(Gt(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:Q,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,en),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 Gt(a,n)}catch(e){throw Kt(a,e,n.toState,n.fromState),e}finally{this.#a(r)}}#i(e,t,n,r,i){t&&this.#a(t),n&&r&&Kt(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 an={replace:!0};Object.freeze(an);var on=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,an):n.navigateToNotFound(t)}stop(){this.#e.clearState()}},sn=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 cn=new e.t(e.c.ROUTER_ALREADY_STARTED),ln=new Set([`all`,`warn-error`,`error-only`]);function un(e){return typeof e==`string`&&ln.has(e)}function dn(e){return typeof e==`string`?`"${e}"`:typeof e==`object`?JSON.stringify(e):String(e)}function fn(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&&!un(t.level))throw TypeError(`Invalid logger level: ${dn(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 pn=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:g(e.defaultRoute,e=>this.dependenciesStore.dependencies[e]),params:g(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 mn(e){e.wireLimits(),e.wireRouteLifecycleDeps(),e.wireRoutesDeps(),e.wirePluginsDeps(),e.wireNavigationDeps(),e.wireLifecycleDeps(),e.wireStateDeps()}const hn=Object.freeze({});var gn=class r{#e;#t;#n;#r;#i;#a;#o;#s;#c;#l;constructor(r=[],i={},a={}){i.logger&&fn(i.logger)&&(n.logger.configure(i.logger),delete i.logger),te.validateOptionsIsObject(i),d(a),r.length>0&&f(r),this.#e=new te(i),this.#t=e.n(i.limits),this.#n=p(a),this.#r=new re,this.#i=new It(r,_n(this.#e.get())),this.#a=new ce,this.#o=new oe,this.#s=new rn,this.#c=new on,this.#l=new sn({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`)}})}),mn(new pn({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),It.shouldUpdateNode(e)}isActive(){return this.#l.isActive()}start(e){if(!this.#l.canStart())return Promise.reject(cn);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 sn.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??hn;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??hn;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 _n(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 fe}}),Object.defineProperty(exports,`i`,{enumerable:!0,get:function(){return H}}),Object.defineProperty(exports,`l`,{enumerable:!0,get:function(){return S}}),Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return B}}),Object.defineProperty(exports,`o`,{enumerable:!0,get:function(){return _t}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return V}}),Object.defineProperty(exports,`s`,{enumerable:!0,get:function(){return pe}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return gn}}),Object.defineProperty(exports,`u`,{enumerable:!0,get:function(){return f}});
6
+ //# sourceMappingURL=Router-CVNR-dug.js.map