@real-router/validation-plugin 0.7.7 → 0.7.9
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/index.js +1 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/esm/index.mjs +1 -1
- package/dist/esm/index.mjs.map +1 -1
- package/package.json +5 -5
package/dist/cjs/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});let e=require("@real-router/core"),t=require("@real-router/core/validation"),n=require("@real-router/logger");const r=[`replace`,`reload`,`force`,`forceDeactivate`,`redirected`];function i(e){if(typeof e!=`object`||!e||Array.isArray(e))return!1;let t=e;for(let e of r){let n=t[e];if(n!==void 0&&typeof n!=`boolean`)return!1}let n=t.signal;return!(n!==void 0&&!(n instanceof AbortSignal))}const a=/\S/,o=/^[A-Z_a-z][\w-]*(?:\.[A-Z_a-z][\w-]*)*$/;function s(e,t){return TypeError(`[router.${e}] ${t}`)}function c(e){return typeof e==`string`?e===``?!0:e.length>1e4?!1:e.startsWith(`@@`)?!0:o.test(e):!1}function l(e,t=new WeakSet){if(e==null)return!0;let n=typeof e;if(n===`string`||n===`boolean`)return!0;if(n===`number`)return Number.isFinite(e);if(n===`function`||n===`symbol`)return!1;if(Array.isArray(e))return t.has(e)?!1:(t.add(e),e.every(e=>l(e,t)));if(n===`object`){if(t.has(e))return!1;t.add(e);let n=Object.getPrototypeOf(e);return n!==null&&n!==Object.prototype?!1:Object.values(e).every(e=>l(e,t))}return!1}function u(e){if(e==null)return!0;let t=typeof e;return t===`string`||t===`boolean`?!0:t===`number`?Number.isFinite(e):!1}function d(e){if(typeof e!=`object`||!e||Array.isArray(e))return!1;let t=Object.getPrototypeOf(e);if(t!==null&&t!==Object.prototype)return!1;let n=!1;for(let t in e){if(!Object.hasOwn(e,t))continue;let r=e[t];if(!u(r)){let e=typeof r;if(e===`function`||e===`symbol`)return!1;n=!0;break}}return n?l(e):!0}function ee(e){return c(e.name)&&typeof e.path==`string`&&d(e.params)}function f(e){return typeof e!=`object`||!e?!1:ee(e)}function p(e){return typeof e==`string`}function m(e){return typeof e==`boolean`}function te(e,t){return e in t}function h(e,t){if(typeof e!=`string`)throw s(t,`Route name must be a string, got ${typeof e}`);if(e!==``){if(!a.test(e))throw s(t,`Route name cannot contain only whitespace`);if(e.length>1e4)throw s(t,`Route name exceeds maximum length of 10000 characters. This is a technical safety limit.`);if(!e.startsWith(`@@`)&&!o.test(e))throw s(t,`Invalid route name "${e}". Each segment must start with a letter or underscore, followed by letters, numbers, underscores, or hyphens. Segments are separated by dots (e.g., "users.profile").`)}}function g(e){return e===null?`null`:Array.isArray(e)?`array[${e.length}]`:typeof e==`object`?`constructor`in e&&e.constructor.name!==`Object`?e.constructor.name:`object`:typeof e}function _(e){return{warn:Math.floor(e*.2),error:Math.floor(e*.5)}}function ne(e,t){if(typeof e!=`string`)throw TypeError(`[router.${t}] dependency name must be a string, got ${typeof e}`)}function re(e){if(typeof e!=`string`)throw TypeError(`[router.setDependency] dependency name must be a string, got ${typeof e}`)}function ie(e,t){if(!(e&&typeof e==`object`&&e.constructor===Object))throw TypeError(`[router.${t}] Invalid argument: expected plain object, received ${g(e)}`);for(let n in e)if(Object.getOwnPropertyDescriptor(e,n)?.get)throw TypeError(`[router.${t}] Getters not allowed: "${n}"`)}function ae(e,t){if(e===void 0)throw ReferenceError(`[router.getDependency] dependency "${t}" not found`)}function oe(e,t){let r=e,i=r.limits?.maxDependencies??100;if(i===0)return;let a=Object.keys(r.dependencies).length,{warn:o,error:s}=_(i);if(a>=i)throw RangeError(`[router.${t}] Dependency limit exceeded (${i}). Current: ${a}.`);a===s?n.logger.error(`router.${t}`,`${a} dependencies registered! This indicates architectural problems. Hard limit at ${i}.`):a===o&&n.logger.warn(`router.${t}`,`${a} dependencies registered. Consider if all are necessary.`)}function se(e){if(e!==void 0){if(!(e&&typeof e==`object`&&e.constructor===Object))throw TypeError(`[cloneRouter] Invalid dependencies: expected plain object or undefined, received ${typeof e}`);for(let t in e)if(Object.getOwnPropertyDescriptor(e,t)?.get)throw TypeError(`[cloneRouter] Getters not allowed in dependencies: "${t}"`)}}function ce(e,t){n.logger.warn(`router.${t}`,`Router dependency already exists and is being overwritten:`,e)}function le(e,t){n.logger.warn(`router.${t}`,`Overwritten:`,e.join(`, `))}function ue(e){n.logger.warn(`router.removeDependency`,`Attempted to remove non-existent dependency: "${typeof e==`string`?e:String(e)}"`)}const de=new Set([`$start`,`$stop`,`$$start`,`$$leaveApprove`,`$$cancel`,`$$success`,`$$error`]);function v(e){if(!de.has(e))throw TypeError(`[router.addEventListener] Invalid event name: ${String(e)}. Must be one of: $start, $stop, $$start, $$leaveApprove, $$cancel, $$success, $$error`)}function fe(e,t){if(v(e),typeof t!=`function`)throw TypeError(`[router.addEventListener] callback must be a function, got ${typeof t}`)}function pe(e,t){if(!m(e)&&typeof e!=`function`)throw TypeError(`[router.${t}] Handler must be a boolean or factory function, got ${g(e)}`)}function me(e,t,n){if(e)throw Error(`[router.${n}] Cannot modify route "${t}" during its own registration`)}function he(e,t,n=200){if(n!==0&&e>=n)throw RangeError(`[router.${t}] Lifecycle handler limit exceeded (${n}). This indicates too many routes with individual handlers. Consider using plugins for cross-cutting concerns.`)}function ge(e,t,r){if(r===0)return;let{warn:i,error:a}=_(r);e>=a?n.logger.error(`router.${t}`,`${e} lifecycle handlers registered! This is excessive. Hard limit at ${r}.`):e>=i&&n.logger.warn(`router.${t}`,`${e} lifecycle handlers registered. Consider consolidating logic.`)}function _e(e,t,r){n.logger.warn(`router.${r}`,`Overwriting existing ${t} handler for route "${e}"`)}function ve(e,t){n.logger.warn(`router.${t}`,`Guard for "${e}" returned a Promise. Sync check cannot resolve async guards — returning false.`)}function ye(e){if(typeof e!=`string`)throw TypeError(`[router.navigate] Invalid route name: expected string, got ${g(e)}`)}function be(e){if(e!==void 0&&(typeof e!=`object`||!e))throw TypeError(`[router.navigateToDefault] Invalid options: ${g(e)}. Expected NavigationOptions object.`)}function xe(e){if(typeof e!=`object`||!e)throw TypeError(`[router.navigateToState] Invalid state: ${g(e)}. Expected State object.`);let t=e;if(!p(t.name))throw TypeError(`[router.navigateToState] Invalid state.name: ${g(t.name)}. Expected string.`);if(!d(t.params))throw TypeError(`[router.navigateToState] Invalid state.params: ${g(t.params)}. Expected plain object.`);if(!p(t.path))throw TypeError(`[router.navigateToState] Invalid state.path: ${g(t.path)}. Expected string.`)}function Se(e,t){if(!i(e))throw TypeError(`[router.${t}] Invalid options: ${g(e)}. Expected NavigationOptions object.`)}function Ce(e,t){if(e!==void 0&&!d(e))throw TypeError(`[router.${t}] params must be a plain object, got ${g(e)}`)}function we(e){if(e!==void 0&&typeof e!=`string`)throw TypeError(`[router.start] path must be a string, got ${g(e)}.`);if(typeof e==`string`&&e!==``&&!e.startsWith(`/`))throw TypeError(`[router.start] path must start with "/", got "${e}".`)}const y={trailingSlash:[`strict`,`never`,`always`,`preserve`],queryParamsMode:[`default`,`strict`,`loose`],urlParamsEncoding:[`default`,`uri`,`uriComponent`,`none`]},b={arrayFormat:[`none`,`brackets`,`index`,`comma`],booleanFormat:[`none`,`auto`,`empty-true`],nullFormat:[`default`,`hidden`],numberFormat:[`none`,`auto`]},x=[`all`,`warn-error`,`error-only`,`none`],Te=new Set([`defaultRoute`,`defaultParams`,`trailingSlash`,`queryParamsMode`,`queryParams`,`urlParamsEncoding`,`allowNotFound`,`rewritePathOnMatch`,`logger`,`limits`]),S={maxDependencies:{min:0,max:1e4},maxPlugins:{min:0,max:1e3},maxListeners:{min:0,max:1e5},warnListeners:{min:0,max:1e5},maxEventDepth:{min:0,max:100},maxLifecycleHandlers:{min:0,max:1e4}};function C(e,t,n){if(typeof t!=`number`||!Number.isInteger(t))throw TypeError(`[router.${n}] limit "${e}" must be an integer, got ${String(t)}`);let r=S[e];if(t<r.min||t>r.max)throw RangeError(`[router.${n}] limit "${e}" must be between ${r.min} and ${r.max}, got ${t}`)}function w(e,t){if(!e||typeof e!=`object`||e.constructor!==Object)throw TypeError(`[router.${t}] invalid limits: expected plain object, got ${typeof e}`);for(let[n,r]of Object.entries(e)){if(!Object.hasOwn(S,n))throw TypeError(`[router.${t}] unknown limit: "${n}"`);r!==void 0&&C(n,r,t)}let{warnListeners:n,maxListeners:r}=e;if(typeof n==`number`&&typeof r==`number`&&r>0&&n>r)throw RangeError(`[router.${t}] "limits.warnListeners" (${n}) must not exceed "limits.maxListeners" (${r}) — the warning channel would be unreachable`)}function T(e,t,n,r){if(e!==void 0&&(typeof e!=`string`||!n.includes(e))){let i=n.map(e=>`"${e}"`).join(`, `);throw TypeError(`[router.${r}] Invalid "${t}": "${typeof e==`string`?e:`(${typeof e})`}". Must be one of: ${i}`)}}function Ee(e,t){if(e!==void 0&&typeof e!=`string`&&typeof e!=`function`)throw TypeError(`[router.${t}] Invalid "defaultRoute": expected string or function, got ${typeof e}`)}function E(e,t){if(e!==void 0&&typeof e!=`function`&&(!e||typeof e!=`object`||Array.isArray(e)||e.constructor!==Object))throw TypeError(`[router.${t}] Invalid "defaultParams": expected plain object or function, got ${typeof e}`)}function D(e,t){if(e===void 0)return;if(!e||typeof e!=`object`||Array.isArray(e))throw TypeError(`[router.${t}] Invalid "queryParams": expected plain object`);let n=e;for(let[e,r]of Object.entries(n)){if(!te(e,b))throw TypeError(`[router.${t}] Invalid "queryParams.${e}": unknown option`);T(r,`queryParams.${e}`,b[e],t)}}function De(e,t){if(e===void 0)return;if(!e||typeof e!=`object`||Array.isArray(e))throw TypeError(`[router.${t}] Invalid "logger": expected plain object`);let r=e;if(r.level!==void 0&&!x.includes(r.level)){let e=x.map(e=>`"${e}"`).join(`, `),n=typeof r.level==`string`?r.level:`(${typeof r.level})`;throw TypeError(`[router.${t}] Invalid "logger.level": "${n}". Must be one of: ${e}`)}if(r.callback!==void 0&&typeof r.callback!=`function`)throw TypeError(`[router.${t}] Invalid "logger.callback": expected function`);if(r.callbackIgnoresLevel!==void 0&&typeof r.callbackIgnoresLevel!=`boolean`)throw TypeError(`[router.${t}] Invalid "logger.callbackIgnoresLevel": expected boolean`);r.callbackIgnoresLevel===!0&&r.callback===void 0&&n.logger.error(`router.${t}`,`"logger.callbackIgnoresLevel: true" has no effect without "logger.callback" — the option is ignored`)}function Oe(e,t){if(!e||typeof e!=`object`||Array.isArray(e))throw TypeError(`[router.${t}] Invalid options: expected plain object`);let n=e;for(let e of Object.keys(n))if(!Te.has(e))throw TypeError(`[router.${t}] Unknown option: "${e}"`);if(Ee(n.defaultRoute,t),E(n.defaultParams,t),T(n.trailingSlash,`trailingSlash`,y.trailingSlash,t),T(n.queryParamsMode,`queryParamsMode`,y.queryParamsMode,t),T(n.urlParamsEncoding,`urlParamsEncoding`,y.urlParamsEncoding,t),n.allowNotFound!==void 0&&typeof n.allowNotFound!=`boolean`)throw TypeError(`[router.${t}] Invalid "allowNotFound": expected boolean, got ${typeof n.allowNotFound}`);if(n.rewritePathOnMatch!==void 0&&typeof n.rewritePathOnMatch!=`boolean`)throw TypeError(`[router.${t}] Invalid "rewritePathOnMatch": expected boolean, got ${typeof n.rewritePathOnMatch}`);D(n.queryParams,t),De(n.logger,t),n.limits!==void 0&&w(n.limits,t)}const O=`router.usePlugin`,ke={onStart:!0,onStop:!0,onTransitionStart:!0,onTransitionLeaveApprove:!0,onTransitionSuccess:!0,onTransitionError:!0,onTransitionCancel:!0};function Ae(e,t,n=50){if(n!==0&&e+t>n)throw RangeError(`[router.usePlugin] Plugin limit exceeded (${n}). Current: ${e}, Attempting to add: ${t}. This indicates an architectural problem. Consider consolidating plugins.`)}function je(e,t){if(t===0)return;let{warn:r,error:i}=_(t);e>=i?n.logger.error(O,`${e} plugins registered! This is excessive. Hard limit at ${t}.`):e>=r&&n.logger.warn(O,`${e} plugins registered. Consider if all are necessary.`)}function Me(e){for(let t in e)if(!(t===`teardown`||Object.hasOwn(ke,t)))throw TypeError(`[router.usePlugin] Unknown property '${t}'. Plugin must only contain event handlers and optional teardown.`)}function Ne(){n.logger.warn(O,`Duplicate factory in batch, will be registered once`)}function Pe(e){n.logger.warn(O,`Property '${e}' is not a function, skipping`)}function Fe(e){e===`onStart`&&n.logger.warn(O,`Router already started, onStart will not be called`)}function Ie(e,t){let n=[`start`,`buildPath`,`forwardState`];if(typeof e!=`string`||!n.includes(e))throw TypeError(`[router.addInterceptor] Invalid method: "${String(e)}". Must be one of: ${n.join(`, `)}`);if(typeof t!=`function`)throw TypeError(`[router.addInterceptor] interceptor must be a function, got ${typeof t}`)}function k(e,t){if(!e||typeof e!=`object`)throw TypeError(`[validation-plugin] ${t}: store must be an object`);let n=e;if(!Array.isArray(n.definitions))throw TypeError(`[validation-plugin] ${t}: store.definitions must be an array`);if(!n.config||typeof n.config!=`object`)throw TypeError(`[validation-plugin] ${t}: store.config must be an object`);if(!n.tree||typeof n.tree!=`object`)throw TypeError(`[validation-plugin] ${t}: store.tree must be an object`);return n}function A(e,t,n=``){for(let r of e){let e=n?`${n}.${r.name}`:r.name;t(r,e),r.children&&A(r.children,t,e)}}function j(e,t){let n=t.split(`.`),r=e;for(let e of n)if(r=r.children.get(e),!r)return!1;return!0}function Le(t,n){try{return(0,e.resolveForwardChain)(t,n)}catch(e){throw Error(`[validation-plugin] ${e.message}`,{cause:e})}}function M(e){let t=new Set;for(let n of e){for(let e of n.paramMeta.urlParams)t.add(e);for(let e of n.paramMeta.spatParams)t.add(e)}return t}function N(e,t,n){let r=e;if(r.constructor.name===`AsyncFunction`||r.toString().includes(`__awaiter`))throw TypeError(`[validation-plugin] Route "${n}" ${t} cannot be async`)}function P(e){let t=k(e,`validateExistingRoutes`),n=new Set;A(t.definitions,(e,t)=>{if(typeof e.name!=`string`||!e.name)throw TypeError(`[validation-plugin] validateExistingRoutes: route has invalid name: ${e.name}`);if(typeof e.path!=`string`)throw TypeError(`[validation-plugin] validateExistingRoutes: route "${t}" has non-string path (${typeof e.path})`);if(n.has(t))throw Error(`[validation-plugin] validateExistingRoutes: duplicate route name detected: "${t}"`);n.add(t)})}function F(e){let{config:t,tree:n,matcher:r}=k(e,`validateForwardToConsistency`);for(let[e,i]of Object.entries(t.forwardMap)){if(!j(n,i))throw Error(`[validation-plugin] validateForwardToConsistency: forwardTo target "${i}" does not exist in tree (source route: "${e}")`);let t=r.getSegmentsByName(e),a=r.getSegmentsByName(i);if(t&&a){let n=M(t),r=[...M(a)].filter(e=>!n.has(e));if(r.length>0)throw Error(`[validation-plugin] validateForwardToConsistency: forwardTo target "${i}" requires params [${r.join(`, `)}] not available in source route "${e}"`)}}for(let e of Object.keys(t.forwardMap))Le(e,t.forwardMap)}function Re(e){let{config:t}=k(e,`validateRoutePropertiesStore`);for(let[e,n]of Object.entries(t.decoders)){if(typeof n!=`function`)throw TypeError(`[validation-plugin] validateRoutePropertiesStore: route "${e}" decoder must be a function, got ${typeof n}`);N(n,`decoder`,e)}for(let[e,n]of Object.entries(t.encoders)){if(typeof n!=`function`)throw TypeError(`[validation-plugin] validateRoutePropertiesStore: route "${e}" encoder must be a function, got ${typeof n}`);N(n,`encoder`,e)}for(let[e,n]of Object.entries(t.defaultParams))if(typeof n!=`object`||!n||Array.isArray(n))throw TypeError(`[validation-plugin] validateRoutePropertiesStore: route "${e}" defaultParams must be a plain object, got ${Array.isArray(n)?`array`:typeof n}`);for(let[e,n]of Object.entries(t.forwardFnMap)){if(typeof n!=`function`)throw TypeError(`[validation-plugin] validateRoutePropertiesStore: route "${e}" forwardTo callback must be a function, got ${typeof n}`);N(n,`forwardTo callback`,e)}}function ze(e){let{config:t,tree:n}=k(e,`validateForwardToTargetsStore`);for(let[e,r]of Object.entries(t.forwardMap))if(!j(n,r))throw Error(`[validation-plugin] validateForwardToTargetsStore: forwardTo target "${r}" does not exist for route "${e}"`)}function I(e){if(!e||typeof e!=`object`)throw TypeError(`[validation-plugin] validateDependenciesStructure: deps must be an object`);let t=e;if(!t.dependencies||typeof t.dependencies!=`object`)throw TypeError(`[validation-plugin] validateDependenciesStructure: deps.dependencies must be an object`);let n=t.dependencies;for(let e of Object.keys(n))if(Object.getOwnPropertyDescriptor(n,e)?.get)throw TypeError(`[validation-plugin] validateDependenciesStructure: dependency "${e}" must not use a getter`);if(!t.limits||typeof t.limits!=`object`)throw TypeError(`[validation-plugin] validateDependenciesStructure: deps.limits must be an object`);let r=t.limits;for(let e of[`maxDependencies`,`maxPlugins`,`maxListeners`,`warnListeners`,`maxEventDepth`,`maxLifecycleHandlers`])if(typeof r[e]!=`number`)throw TypeError(`[validation-plugin] validateDependenciesStructure: deps.limits.${e} must be a number, got ${typeof r[e]}`)}function Be(e){let t=e&&typeof e==`object`?e:{};return t.limits&&typeof t.limits==`object`?t.limits:{}}function Ve(e,t){if(!e||typeof e!=`object`)return;let n=e;if(!Array.isArray(n.definitions))return;let r=n.definitions.length,i=t.maxRoutes;if(typeof i==`number`&&i>0&&r>i)throw RangeError(`[validation-plugin] validateLimitsConsistency: route count (${r}) exceeds configured limit (${i})`)}function He(e,t){if(!e||typeof e!=`object`)return;let n=e,r=n.dependencies,i=n.limits;if(!r||typeof r!=`object`||!i||typeof i!=`object`)return;let a=Object.keys(r).length,o=i,s=t.maxDependencies,c=o.maxDependencies,l=typeof s==`number`?s:c;if(typeof l==`number`&&l>0&&a>=l)throw RangeError(`[validation-plugin] validateLimitsConsistency: dependency count (${a}) reaches or exceeds maxDependencies limit (${l})`)}function Ue(e,t,n){let r=Be(e);Ve(t,r),He(n,r)}function L(e,t){if(!(typeof e!=`string`||!e)&&!j(k(t,`validateResolvedDefaultRoute`).tree,e))throw Error(`[validation-plugin] defaultRoute resolved to non-existent route: "${e}"`)}Object.freeze(new Map),Object.freeze([]);function We(e,t){let n=[],r=t.includes(`.`)?t.split(`.`):[t];e.path!==``&&n.push(e);let i=e;for(let e of r){let t=i.children.get(e);if(!t)return null;n.push(t),i=t}return n}function R(e,t){return TypeError(`[router.${e}] ${t}`)}function Ge(e){let t=!1;for(let n of e)if(n===`<`)t=!0;else if(n===`>`){if(!t)return!1;t=!1}return!t}function Ke(e,t,n,r){if(typeof e!=`string`){let t;throw t=e===null?`null`:Array.isArray(e)?`array`:typeof e,R(n,`Route path must be a string, got ${t}`)}if(e===``)return;if(/\s/.test(e))throw R(n,`Invalid path for route "${t}": whitespace not allowed in "${e}"`);if(!/^([/?~]|[^/]+$)/.test(e))throw R(n,`Route "${t}" has invalid path format: "${e}". Path should start with '/', '~', '?' or be a relative segment.`);if(e.includes(`//`))throw R(n,`Invalid path for route "${t}": double slashes not allowed in "${e}"`);if(!Ge(e))throw R(n,`Invalid path for route "${t}": unbalanced constraint delimiter ('<' or '>') in "${e}"`);let i=r&&r.paramMeta.urlParams.length>0;if(e.startsWith(`~`)&&i)throw R(n,`Absolute path "${e}" cannot be used under parent route with URL parameters`)}const qe=/^[A-Z_a-z][\w-]*$/,z=/\S/,B=1e4;function V(e){return e===null?`null`:typeof e==`object`?`constructor`in e&&e.constructor.name!==`Object`?e.constructor.name:`object`:typeof e}function Je(e){for(let t of Object.keys(e)){let n=Object.getOwnPropertyDescriptor(e,t);if(n&&(n.get||n.set))return!0}return!1}function Ye(e,t){if(!e||typeof e!=`object`)throw TypeError(`[router.${t}] Route must be an object, got ${V(e)}`);let n=Object.getPrototypeOf(e);if(n!==Object.prototype&&n!==null)throw TypeError(`[router.${t}] Route must be a plain object, got ${V(e)}`);if(Je(e))throw TypeError(`[router.${t}] Route must not have getters or setters`)}function Xe(e,t){if(e.encodeParams!==void 0&&typeof e.encodeParams!=`function`)throw TypeError(`[router.${t}] Route "${String(e.name)}" encodeParams must be a function`)}function Ze(e,t){if(e.decodeParams!==void 0&&typeof e.decodeParams!=`function`)throw TypeError(`[router.${t}] Route "${String(e.name)}" decodeParams must be a function`)}function Qe(e,t){if(typeof e.name!=`string`)throw TypeError(`[router.${t}] Route name must be a string, got ${V(e.name)}`);let n=e.name;if(n===``)throw TypeError(`[router.${t}] Route name cannot be empty`);if(!z.test(n))throw TypeError(`[router.${t}] Route name cannot contain only whitespace`);if(n.length>B)throw TypeError(`[router.${t}] Route name exceeds maximum length of ${B} characters`);if(!n.startsWith(`@@`)){if(n.includes(`.`))throw TypeError(`[router.${t}] Route name "${n}" cannot contain dots. Use children array or { parent } option in addRoute() instead.`);if(!qe.test(n))throw TypeError(`[router.${t}] Invalid route name "${n}". Name must start with a letter or underscore, followed by letters, numbers, underscores, or hyphens.`)}}function H(e,t){if(!t.includes(`.`))return e.children.get(t);let n=e;for(let e of t.split(`.`))if(n=n.children.get(e),!n)return;return n}function $e(e,t,n){if(H(e,t))throw Error(`[router.${n}] Route "${t}" already exists`)}function et(e,t,n){if(e.has(t))throw Error(`[router.${n}] Duplicate route "${t}" in batch`);e.add(t)}function tt(e,t,n,r){let i=t===``?e:H(e,t);if(i){for(let e of i.children.values())if(e.path===n)throw Error(`[router.${r}] Path "${n}" is already defined`)}}function nt(e,t,n,r){let i=e.get(t);if(i?.has(n))throw Error(`[router.${r}] Path "${n}" is already defined`);i?i.add(n):e.set(t,new Set([n]))}function U(e,t,n,r=``,i,a){Ye(e,t);let o=e;Qe(o,t),Ke(o.path,o.name,t,n),Xe(o,t),Ze(o,t);let s=o.name,c=r?`${r}.${s}`:s;n&&c&&$e(n,c,t),i&&et(i,c,t);let l=o.path,u=r;if(n&&tt(n,u,l,t),a&&nt(a,u,l,t),o.children!==void 0){if(!Array.isArray(o.children))throw TypeError(`[router.${t}] Route "${s}" children must be an array, got ${V(o.children)}`);for(let e of o.children)U(e,t,n,c,i,a)}}function rt(e,t){if(e!==void 0&&typeof e==`function`){let n=e.constructor.name===`AsyncFunction`,r=e.toString().includes(`__awaiter`);if(n||r)throw TypeError(`[router.addRoute] forwardTo callback cannot be async for route "${t}". Async functions break matchPath/buildPath.`)}}function W(e,t){if(e.canActivate!==void 0&&typeof e.canActivate!=`function`)throw TypeError(`[router.addRoute] canActivate must be a function for route "${t}", got ${g(e.canActivate)}`);if(e.canDeactivate!==void 0&&typeof e.canDeactivate!=`function`)throw TypeError(`[router.addRoute] canDeactivate must be a function for route "${t}", got ${g(e.canDeactivate)}`);if(e.defaultParams!==void 0){let n=e.defaultParams;if(typeof n!=`object`||!n||Array.isArray(n))throw TypeError(`[router.addRoute] defaultParams must be an object for route "${t}", got ${g(e.defaultParams)}`)}if(e.decodeParams?.constructor.name===`AsyncFunction`)throw TypeError(`[router.addRoute] decodeParams cannot be async for route "${t}". Async functions break matchPath/buildPath.`);if(e.encodeParams?.constructor.name===`AsyncFunction`)throw TypeError(`[router.addRoute] encodeParams cannot be async for route "${t}". Async functions break matchPath/buildPath.`);if(rt(e.forwardTo,t),e.children)for(let n of e.children)W(n,`${t}.${n.name}`)}function it(e){let t=new Set,n=/[*:]([A-Z_a-z]\w*)/g,r;for(;(r=n.exec(e))!==null;)t.add(r[1]);return t}function G(e){let t=new Set;for(let n of e)for(let e of it(n))t.add(e);return t}function K(e,t,n=``,r=[]){for(let i of e){let e=n?`${n}.${i.name}`:i.name,a=[...r,i.path];if(e===t)return a;if(i.children&&t.startsWith(`${e}.`))return K(i.children,t,e,a)}throw Error(`[internal] collectPathsToRoute: route "${t}" not found`)}function q(e,t=``){let n=new Set;for(let r of e){let e=t?`${t}.${r.name}`:r.name;if(n.add(e),r.children)for(let t of q(r.children,e))n.add(t)}return n}function J(e,t=``){let n=new Map;for(let r of e){let e=t?`${t}.${r.name}`:r.name;if(r.forwardTo&&typeof r.forwardTo==`string`&&n.set(e,r.forwardTo),r.children)for(let[t,i]of J(r.children,e))n.set(t,i)}return n}function at(e){let t=new Set;for(let n of e){for(let e of n.paramMeta.urlParams)t.add(e);for(let e of n.paramMeta.spatParams)t.add(e)}return t}function ot(e,t){let n=t.split(`.`),r=e;for(let e of n)if(r=r.children.get(e),!r)return!1;return!0}function st(e,t,n,r){return t?at(We(n,e)??[]):G(K(r,e))}function ct(e,t,n,r,i){let a=ot(i,t),o=r.has(t);if(!a&&!o)throw ReferenceError(`[router.addRoute] forwardTo target "${t}" does not exist for route "${e}"`);let s=G(K(n,e)),c=[...st(t,a,i,n)].filter(e=>!s.has(e));if(c.length>0)throw Error(`[router.addRoute] forwardTo target "${t}" requires params [${c.join(`, `)}] that are not available in source route "${e}"`)}function lt(t,n,r){let i=q(t),a=J(t),o={...n};for(let[e,t]of a)o[e]=t;for(let[e,n]of a)ct(e,n,t,i,r);for(let t of Object.keys(o))(0,e.resolveForwardChain)(t,o)}function Y(e,t){if(e.startsWith(`@@`))throw Error(`[router.${t}] Route name "${e}" uses the reserved "@@" prefix. Routes with this prefix are internal and cannot be modified through the public API.`)}function X(e,t){for(let n of e)n&&typeof n==`object`&&typeof n.name==`string`&&(Y(n.name,t),n.children&&X(n.children,t))}function ut(e){h(e,`removeRoute`)}function dt(e){if(typeof e!=`string`)throw TypeError(`[router.setRootPath] rootPath must be a string, got ${g(e)}`)}function Z(e){return e.constructor.name===`AsyncFunction`||String(e).includes(`__awaiter`)}function ft(e){let t=e;if(t.canActivate!==void 0&&typeof t.canActivate!=`function`)throw TypeError(`[router.addRoute] canActivate must be a function, got ${g(t.canActivate)}`);if(t.canDeactivate!==void 0&&typeof t.canDeactivate!=`function`)throw TypeError(`[router.addRoute] canDeactivate must be a function, got ${g(t.canDeactivate)}`)}function pt(e){let t=e,n=t.name;if(t.decodeParams!==void 0&&Z(t.decodeParams))throw TypeError(`[router.addRoute] decodeParams cannot be async for route "${String(n)}"`);if(t.encodeParams!==void 0&&Z(t.encodeParams))throw TypeError(`[router.addRoute] encodeParams cannot be async for route "${String(n)}"`);if(typeof t.forwardTo==`function`&&Z(t.forwardTo))throw TypeError(`[router.addRoute] forwardTo callback cannot be async for route "${String(n)}"`)}function mt(e){for(let t of e){if(typeof t!=`object`||!t||Array.isArray(t))throw TypeError(`[router.addRoute] Route must be an object, got ${g(t)}`);W(t,t.name)}}function ht(e){if(typeof e!=`string`||e===``)throw TypeError(`[router.addRoute] parent option must be a non-empty string, got ${g(e)}`);h(e,`addRoute`)}function gt(e,t,n,r){if(!p(e))throw TypeError(`[router.isActiveRoute] name must be a string, got ${typeof e}`);if(t!==void 0&&!d(t))throw TypeError(`[router.isActiveRoute] params must be a plain object, got ${g(t)}`);if(n!==void 0&&typeof n!=`boolean`)throw TypeError(`[router.isActiveRoute] strictEquality must be a boolean, got ${typeof n}`);if(r!==void 0&&typeof r!=`boolean`)throw TypeError(`[router.isActiveRoute] ignoreQueryParams must be a boolean, got ${typeof r}`)}function _t(e,t,n){if(!p(e))throw TypeError(`[router.${n}] Invalid routeName: ${g(e)}. Expected string.`);if(!d(t))throw TypeError(`[router.${n}] Invalid routeParams: ${g(t)}. Expected plain object.`)}function vt(e,t){if(h(e,`updateRoute`),e===``)throw ReferenceError(`[router.updateRoute] Invalid name: empty string. Cannot update root node.`);if(t===null)throw TypeError(`[router.updateRoute] updates must be an object, got null`);if(typeof t!=`object`||Array.isArray(t))throw TypeError(`[router.updateRoute] updates must be an object, got ${g(t)}`)}function Q(e,t){if(e.constructor.name===`AsyncFunction`||e.toString().includes(`__awaiter`))throw TypeError(`[router.updateRoute] ${t} cannot be an async function`)}function $(e,t){if(e!=null){if(typeof e!=`function`)throw TypeError(`[router.updateRoute] ${t} must be a function or null, got ${typeof e}`);Q(e,t)}}function yt(e,t,n,r){if(e!=null){if(typeof e!=`string`&&typeof e!=`function`)throw TypeError(`[router.updateRoute] forwardTo must be a string, function, or null, got ${g(e)}`);typeof e==`function`&&Q(e,`forwardTo callback`)}if(t!=null&&(typeof t!=`object`||Array.isArray(t)))throw TypeError(`[router.updateRoute] defaultParams must be an object or null, got ${g(t)}`);$(n,`decodeParams`),$(r,`encodeParams`)}function bt(e){if(!p(e)||e===``)throw TypeError(`[router.buildPath] route must be a non-empty string, got ${typeof e==`string`?`""`:typeof e}`)}function xt(e){if(!p(e))throw TypeError(`[router.matchPath] path must be a string, got ${typeof e}`)}function St(e){if(!p(e))throw TypeError(`[router.shouldUpdateNode] nodeName must be a string, got ${typeof e}`)}function Ct(e,t,n,r){if(r&&t){let e=t;for(let t of r.split(`.`))if(e=e.children.get(t),!e)throw ReferenceError(`[router.addRoute] Parent route "${r}" does not exist`)}let i=new Set,a=new Map;for(let n of e)U(n,`addRoute`,t,r??``,i,a);t&&n&<(e,n,t)}function wt(e){let t=new Set;for(let n of e)for(let e of n.paramMeta.urlParams)t.add(e);return t}function Tt(e,t,n){let r=n.getSegmentsByName(e),i=n.getSegmentsByName(t),a=wt(r),o=[];for(let e of i)for(let t of e.paramMeta.urlParams)o.push(t);let s=o.filter(e=>!a.has(e));if(s.length>0)throw Error(`[router.addRoute] forwardTo target "${t}" requires params [${s.join(`, `)}] that are not available in source route "${e}"`)}function Et(t,n,r){(0,e.resolveForwardChain)(t,{...r.forwardMap,[t]:n})}function Dt(e,t,n,r,i){if(!n(e))throw ReferenceError(`[router.updateRoute] route "${e}" does not exist`);if(t!=null&&typeof t==`string`){if(!n(t))throw Error(`[router.updateRoute] forwardTo target "${t}" does not exist`);Tt(e,t,r),Et(e,t,i)}}function Ot(e,t,n){if(!p(e))throw TypeError(`[router.makeState] Invalid name: ${g(e)}. Expected string.`);if(t!==void 0&&!d(t))throw TypeError(`[router.makeState] Invalid params: ${g(t)}. Expected plain object.`);if(n!==void 0&&!p(n))throw TypeError(`[router.makeState] Invalid path: ${g(n)}. Expected string.`)}function kt(e){return{routes:{validateBuildPathArgs:bt,validateMatchPathArgs:xt,validateIsActiveRouteArgs:gt,validateShouldUpdateNodeArgs:St,validateStateBuilderArgs:_t,validateAddRouteArgs(e){mt(e)},validateRoutes(e,t){let n=t;Ct(e,n.tree,n.config?.forwardMap)},validateRemoveRouteArgs:ut,validateUpdateRouteBasicArgs:vt,validateUpdateRoutePropertyTypes(e,t){let n=t;yt(n.forwardTo,n.defaultParams,n.decodeParams,n.encodeParams)},validateUpdateRoute(e,t,n){let r=n,i=t.forwardTo;Dt(e,i,e=>r.matcher.hasRoute(e),r.matcher,r.config)},validateParentOption(e,t){ht(e);let n=t;for(let t of e.split(`.`)){let r=n.children.get(t);if(!r)throw ReferenceError(`[router.addRoute] Parent route "${e}" does not exist`);n=r}},validateRouteName(e,t){h(e,t)},throwIfInternalRoute(e,t){Y(e,t)},throwIfInternalRouteInArray(e,t){X(e,t)},validateExistingRoutes:P,validateForwardToConsistency:F,validateSetRootPathArgs:dt,guardRouteCallbacks:ft,guardNoAsyncCallbacks:pt},options:{validateLimitValue(e,t){C(e,t,`validate`)},validateLimits(e){w(e,`validate`)},validateOptions:Oe,validateResolvedDefaultRoute:L},dependencies:{validateDependencyName:ne,validateSetDependencyArgs(e,t,n){re(e)},validateDependenciesObject:ie,validateDependencyExists(e,t){let n=t.dependencies?.[e];ae(n,e)},validateDependencyLimit(e,t){},validateDependenciesStructure:I,validateDependencyCount:oe,validateCloneArgs:se,warnOverwrite:ce,warnBatchOverwrite:le,warnRemoveNonExistent:ue},plugins:{validatePluginLimit(e,t){Ae(e,1,t?.maxPlugins)},validateNoDuplicatePlugins(e,t){},validatePluginKeys:Me,validateCountThresholds(t){je(t,e.getOptions().limits?.maxPlugins??50)},warnBatchDuplicates:Ne,warnPluginMethodType:Pe,warnPluginAfterStart:Fe,validateAddInterceptorArgs:Ie},lifecycle:{validateHandler:pe,validateNotRegistering(e,t,n){me(!1,e,n)},validateHandlerLimit(e,t,n){he(e,n,t?.maxLifecycleHandlers)},validateCountThresholds(t,n){ge(t,n,e.getOptions().limits?.maxLifecycleHandlers??200)},warnOverwrite:_e,warnAsyncGuardSync:ve},navigation:{validateNavigateArgs:ye,validateNavigateToDefaultArgs:be,validateNavigateToStateArgs:xe,validateNavigationOptions:Se,validateParams:Ce,validateStartArgs:we},state:{validateMakeStateArgs:Ot,validateAreStatesEqualArgs(e,t,n){if(!f(e))throw TypeError(`[router.areStatesEqual] Invalid state1: ${g(e)}. Expected State object.`);if(!f(t))throw TypeError(`[router.areStatesEqual] Invalid state2: ${g(t)}. Expected State object.`);if(n!==void 0&&!m(n))throw TypeError(`[router.areStatesEqual] Invalid ignoreQueryParams: ${g(n)}. Expected boolean.`)}},eventBus:{validateEventName:v,validateListenerArgs(e,t){fe(e,t)}}}}function At(){return n=>{let r=(0,t.getInternals)(n);if(n.isActive())throw new e.RouterError(`VALIDATION_PLUGIN_AFTER_START`,{message:`validation-plugin must be registered before router.start()`});r.validator=kt(r);try{let e=r.routeGetStore(),t=r.dependenciesGetStore(),n=r.getOptions();P(e),F(e),Re(e),ze(e),I(t),Ue(n,e,t),r.validator.options.validateOptions(n,`constructor (retrospective)`),typeof n.defaultRoute==`string`&&L(n.defaultRoute,e)}catch(e){throw r.validator=null,e}return{teardown(){r.validator=null}}}}exports.validationPlugin=At;
|
|
1
|
+
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});let e=require("@real-router/core"),t=require("@real-router/core/validation"),n=require("@real-router/logger");const r=[`replace`,`reload`,`force`,`forceDeactivate`,`redirected`];function i(e){if(typeof e!=`object`||!e||Array.isArray(e))return!1;let t=e;for(let e of r){let n=t[e];if(n!==void 0&&typeof n!=`boolean`)return!1}let n=t.signal;return!(n!==void 0&&!(n instanceof AbortSignal))}const a=/\S/,o=/^[A-Z_a-z][\w-]*(?:\.[A-Z_a-z][\w-]*)*$/;function s(e,t){return TypeError(`[router.${e}] ${t}`)}function c(e){return typeof e==`string`?e===``?!0:e.length>1e4?!1:e.startsWith(`@@`)?!0:o.test(e):!1}function l(e,t=new WeakSet){if(e==null)return!0;let n=typeof e;if(n===`string`||n===`boolean`)return!0;if(n===`number`)return Number.isFinite(e);if(n===`function`||n===`symbol`)return!1;if(Array.isArray(e))return t.has(e)?!1:(t.add(e),e.every(e=>l(e,t)));if(n===`object`){if(t.has(e))return!1;t.add(e);let n=Object.getPrototypeOf(e);return n!==null&&n!==Object.prototype?!1:Object.values(e).every(e=>l(e,t))}return!1}function u(e){if(e==null)return!0;let t=typeof e;return t===`string`||t===`boolean`?!0:t===`number`?Number.isFinite(e):!1}function d(e){if(typeof e!=`object`||!e||Array.isArray(e))return!1;let t=Object.getPrototypeOf(e);if(t!==null&&t!==Object.prototype)return!1;let n=!1;for(let t in e){if(!Object.hasOwn(e,t))continue;let r=e[t];if(!u(r)){let e=typeof r;if(e===`function`||e===`symbol`)return!1;n=!0;break}}return n?l(e):!0}function ee(e){return c(e.name)&&typeof e.path==`string`&&d(e.params)}function f(e){return typeof e!=`object`||!e?!1:ee(e)}function p(e){return typeof e==`string`}function m(e){return typeof e==`boolean`}function te(e,t){return e in t}function h(e,t){if(typeof e!=`string`)throw s(t,`Route name must be a string, got ${typeof e}`);if(e!==``){if(!a.test(e))throw s(t,`Route name cannot contain only whitespace`);if(e.length>1e4)throw s(t,`Route name exceeds maximum length of 10000 characters. This is a technical safety limit.`);if(!e.startsWith(`@@`)&&!o.test(e))throw s(t,`Invalid route name "${e}". Each segment must start with a letter or underscore, followed by letters, numbers, underscores, or hyphens. Segments are separated by dots (e.g., "users.profile").`)}}function g(e){return e===null?`null`:Array.isArray(e)?`array[${e.length}]`:typeof e==`object`?`constructor`in e&&e.constructor.name!==`Object`?e.constructor.name:`object`:typeof e}function _(e){return{warn:Math.floor(e*.2),error:Math.floor(e*.5)}}function ne(e,t){if(typeof e!=`string`)throw TypeError(`[router.${t}] dependency name must be a string, got ${typeof e}`)}function re(e){if(typeof e!=`string`)throw TypeError(`[router.setDependency] dependency name must be a string, got ${typeof e}`)}function ie(e,t){if(!(e&&typeof e==`object`&&e.constructor===Object))throw TypeError(`[router.${t}] Invalid argument: expected plain object, received ${g(e)}`);for(let n in e)if(Object.getOwnPropertyDescriptor(e,n)?.get)throw TypeError(`[router.${t}] Getters not allowed: "${n}"`)}function ae(e,t){if(e===void 0)throw ReferenceError(`[router.getDependency] dependency "${t}" not found`)}function oe(e,t){let r=e,i=r.limits?.maxDependencies??100;if(i===0)return;let a=Object.keys(r.dependencies).length,{warn:o,error:s}=_(i);if(a>=i)throw RangeError(`[router.${t}] Dependency limit exceeded (${i}). Current: ${a}.`);a===s?n.logger.error(`router.${t}`,`${a} dependencies registered! This indicates architectural problems. Hard limit at ${i}.`):a===o&&n.logger.warn(`router.${t}`,`${a} dependencies registered. Consider if all are necessary.`)}function se(e){if(e!==void 0){if(!(e&&typeof e==`object`&&e.constructor===Object))throw TypeError(`[cloneRouter] Invalid dependencies: expected plain object or undefined, received ${typeof e}`);for(let t in e)if(Object.getOwnPropertyDescriptor(e,t)?.get)throw TypeError(`[cloneRouter] Getters not allowed in dependencies: "${t}"`)}}function ce(e,t){n.logger.warn(`router.${t}`,`Router dependency already exists and is being overwritten:`,e)}function le(e,t){n.logger.warn(`router.${t}`,`Overwritten:`,e.join(`, `))}function ue(e){n.logger.warn(`router.removeDependency`,`Attempted to remove non-existent dependency: "${typeof e==`string`?e:String(e)}"`)}const de=new Set([`$start`,`$stop`,`$$start`,`$$leaveApprove`,`$$cancel`,`$$success`,`$$error`]);function v(e){if(!de.has(e))throw TypeError(`[router.addEventListener] Invalid event name: ${String(e)}. Must be one of: $start, $stop, $$start, $$leaveApprove, $$cancel, $$success, $$error`)}function fe(e,t){if(v(e),typeof t!=`function`)throw TypeError(`[router.addEventListener] callback must be a function, got ${typeof t}`)}function pe(e,t){if(!m(e)&&typeof e!=`function`)throw TypeError(`[router.${t}] Handler must be a boolean or factory function, got ${g(e)}`)}function me(e,t,n){if(e)throw Error(`[router.${n}] Cannot modify route "${t}" during its own registration`)}function he(e,t,n=200){if(n!==0&&e>=n)throw RangeError(`[router.${t}] Lifecycle handler limit exceeded (${n}). This indicates too many routes with individual handlers. Consider using plugins for cross-cutting concerns.`)}function ge(e,t,r){if(r===0)return;let{warn:i,error:a}=_(r);e>=a?n.logger.error(`router.${t}`,`${e} lifecycle handlers registered! This is excessive. Hard limit at ${r}.`):e>=i&&n.logger.warn(`router.${t}`,`${e} lifecycle handlers registered. Consider consolidating logic.`)}function _e(e,t,r){n.logger.warn(`router.${r}`,`Overwriting existing ${t} handler for route "${e}"`)}function ve(e,t){n.logger.warn(`router.${t}`,`Guard for "${e}" returned a Promise. Sync check cannot resolve async guards — returning false.`)}function ye(e){if(typeof e!=`string`)throw TypeError(`[router.navigate] Invalid route name: expected string, got ${g(e)}`)}function be(e){if(e!==void 0&&(typeof e!=`object`||!e))throw TypeError(`[router.navigateToDefault] Invalid options: ${g(e)}. Expected NavigationOptions object.`)}function xe(e){if(typeof e!=`object`||!e)throw TypeError(`[router.navigateToState] Invalid state: ${g(e)}. Expected State object.`);let t=e;if(!p(t.name))throw TypeError(`[router.navigateToState] Invalid state.name: ${g(t.name)}. Expected string.`);if(!d(t.params))throw TypeError(`[router.navigateToState] Invalid state.params: ${g(t.params)}. Expected plain object.`);if(!p(t.path))throw TypeError(`[router.navigateToState] Invalid state.path: ${g(t.path)}. Expected string.`)}function Se(e,t){if(!i(e))throw TypeError(`[router.${t}] Invalid options: ${g(e)}. Expected NavigationOptions object.`)}function Ce(e,t){if(e!==void 0&&!d(e))throw TypeError(`[router.${t}] params must be a plain object, got ${g(e)}`)}function we(e){if(e!==void 0&&typeof e!=`string`)throw TypeError(`[router.start] path must be a string, got ${g(e)}.`);if(typeof e==`string`&&e!==``&&!e.startsWith(`/`))throw TypeError(`[router.start] path must start with "/", got "${e}".`)}const y={trailingSlash:[`strict`,`never`,`always`,`preserve`],queryParamsMode:[`default`,`strict`,`loose`],urlParamsEncoding:[`default`,`uri`,`uriComponent`,`none`]},b={arrayFormat:[`none`,`brackets`,`index`,`comma`],booleanFormat:[`none`,`auto`,`empty-true`],nullFormat:[`default`,`hidden`],numberFormat:[`none`,`auto`]},x=[`all`,`warn-error`,`error-only`,`none`],Te=new Set([`defaultRoute`,`defaultParams`,`trailingSlash`,`queryParamsMode`,`queryParams`,`urlParamsEncoding`,`allowNotFound`,`rewritePathOnMatch`,`logger`,`limits`]),S={maxDependencies:{min:0,max:1e4},maxPlugins:{min:0,max:1e3},maxListeners:{min:0,max:1e5},warnListeners:{min:0,max:1e5},maxEventDepth:{min:0,max:100},maxLifecycleHandlers:{min:0,max:1e4}};function C(e,t,n){if(typeof t!=`number`||!Number.isInteger(t))throw TypeError(`[router.${n}] limit "${e}" must be an integer, got ${String(t)}`);let r=S[e];if(t<r.min||t>r.max)throw RangeError(`[router.${n}] limit "${e}" must be between ${r.min} and ${r.max}, got ${t}`)}function w(e,t){if(!e||typeof e!=`object`||e.constructor!==Object)throw TypeError(`[router.${t}] invalid limits: expected plain object, got ${typeof e}`);for(let[n,r]of Object.entries(e)){if(!Object.hasOwn(S,n))throw TypeError(`[router.${t}] unknown limit: "${n}"`);r!==void 0&&C(n,r,t)}let{warnListeners:n,maxListeners:r}=e;if(typeof n==`number`&&typeof r==`number`&&r>0&&n>r)throw RangeError(`[router.${t}] "limits.warnListeners" (${n}) must not exceed "limits.maxListeners" (${r}) — the warning channel would be unreachable`)}function T(e,t,n,r){if(e!==void 0&&(typeof e!=`string`||!n.includes(e))){let i=n.map(e=>`"${e}"`).join(`, `);throw TypeError(`[router.${r}] Invalid "${t}": "${typeof e==`string`?e:`(${typeof e})`}". Must be one of: ${i}`)}}function Ee(e,t){if(e!==void 0&&typeof e!=`string`&&typeof e!=`function`)throw TypeError(`[router.${t}] Invalid "defaultRoute": expected string or function, got ${typeof e}`)}function De(e,t){if(e!==void 0&&typeof e!=`function`&&(!e||typeof e!=`object`||Array.isArray(e)||e.constructor!==Object))throw TypeError(`[router.${t}] Invalid "defaultParams": expected plain object or function, got ${typeof e}`)}function E(e,t){if(e===void 0)return;if(!e||typeof e!=`object`||Array.isArray(e))throw TypeError(`[router.${t}] Invalid "queryParams": expected plain object`);let n=e;for(let[e,r]of Object.entries(n)){if(!te(e,b))throw TypeError(`[router.${t}] Invalid "queryParams.${e}": unknown option`);T(r,`queryParams.${e}`,b[e],t)}}function Oe(e,t){if(e===void 0)return;if(!e||typeof e!=`object`||Array.isArray(e))throw TypeError(`[router.${t}] Invalid "logger": expected plain object`);let r=e;if(r.level!==void 0&&!x.includes(r.level)){let e=x.map(e=>`"${e}"`).join(`, `),n=typeof r.level==`string`?r.level:`(${typeof r.level})`;throw TypeError(`[router.${t}] Invalid "logger.level": "${n}". Must be one of: ${e}`)}if(r.callback!==void 0&&typeof r.callback!=`function`)throw TypeError(`[router.${t}] Invalid "logger.callback": expected function`);if(r.callbackIgnoresLevel!==void 0&&typeof r.callbackIgnoresLevel!=`boolean`)throw TypeError(`[router.${t}] Invalid "logger.callbackIgnoresLevel": expected boolean`);r.callbackIgnoresLevel===!0&&r.callback===void 0&&n.logger.error(`router.${t}`,`"logger.callbackIgnoresLevel: true" has no effect without "logger.callback" — the option is ignored`)}function ke(e,t){if(!e||typeof e!=`object`||Array.isArray(e))throw TypeError(`[router.${t}] Invalid options: expected plain object`);let n=e;for(let e of Object.keys(n))if(!Te.has(e))throw TypeError(`[router.${t}] Unknown option: "${e}"`);if(Ee(n.defaultRoute,t),De(n.defaultParams,t),T(n.trailingSlash,`trailingSlash`,y.trailingSlash,t),T(n.queryParamsMode,`queryParamsMode`,y.queryParamsMode,t),T(n.urlParamsEncoding,`urlParamsEncoding`,y.urlParamsEncoding,t),n.allowNotFound!==void 0&&typeof n.allowNotFound!=`boolean`)throw TypeError(`[router.${t}] Invalid "allowNotFound": expected boolean, got ${typeof n.allowNotFound}`);if(n.rewritePathOnMatch!==void 0&&typeof n.rewritePathOnMatch!=`boolean`)throw TypeError(`[router.${t}] Invalid "rewritePathOnMatch": expected boolean, got ${typeof n.rewritePathOnMatch}`);E(n.queryParams,t),Oe(n.logger,t),n.limits!==void 0&&w(n.limits,t)}const D=`router.usePlugin`,Ae={onStart:!0,onStop:!0,onTransitionStart:!0,onTransitionLeaveApprove:!0,onTransitionSuccess:!0,onTransitionError:!0,onTransitionCancel:!0};function je(e,t,n=50){if(n!==0&&e+t>n)throw RangeError(`[router.usePlugin] Plugin limit exceeded (${n}). Current: ${e}, Attempting to add: ${t}. This indicates an architectural problem. Consider consolidating plugins.`)}function Me(e,t){if(t===0)return;let{warn:r,error:i}=_(t);e>=i?n.logger.error(D,`${e} plugins registered! This is excessive. Hard limit at ${t}.`):e>=r&&n.logger.warn(D,`${e} plugins registered. Consider if all are necessary.`)}function Ne(e){for(let t in e)if(!(t===`teardown`||Object.hasOwn(Ae,t)))throw TypeError(`[router.usePlugin] Unknown property '${t}'. Plugin must only contain event handlers and optional teardown.`)}function Pe(){n.logger.warn(D,`Duplicate factory in batch, will be registered once`)}function Fe(e){n.logger.warn(D,`Property '${e}' is not a function, skipping`)}function Ie(e){e===`onStart`&&n.logger.warn(D,`Router already started, onStart will not be called`)}function Le(e,t){let n=[`start`,`buildPath`,`forwardState`];if(typeof e!=`string`||!n.includes(e))throw TypeError(`[router.addInterceptor] Invalid method: "${String(e)}". Must be one of: ${n.join(`, `)}`);if(typeof t!=`function`)throw TypeError(`[router.addInterceptor] interceptor must be a function, got ${typeof t}`)}function O(e,t){if(!e||typeof e!=`object`)throw TypeError(`[validation-plugin] ${t}: store must be an object`);let n=e;if(!Array.isArray(n.definitions))throw TypeError(`[validation-plugin] ${t}: store.definitions must be an array`);if(!n.config||typeof n.config!=`object`)throw TypeError(`[validation-plugin] ${t}: store.config must be an object`);if(!n.tree||typeof n.tree!=`object`)throw TypeError(`[validation-plugin] ${t}: store.tree must be an object`);return n}function k(e,t,n=``){for(let r of e){let e=n?`${n}.${r.name}`:r.name;t(r,e),r.children&&k(r.children,t,e)}}function A(e,t){let n=t.split(`.`),r=e;for(let e of n)if(r=r.children.get(e),!r)return!1;return!0}function Re(t,n){try{return(0,e.resolveForwardChain)(t,n)}catch(e){throw Error(`[validation-plugin] ${e.message}`,{cause:e})}}function j(e){let t=new Set;for(let n of e){for(let e of n.paramMeta.urlParams)t.add(e);for(let e of n.paramMeta.spatParams)t.add(e)}return t}function M(e,t,n){let r=e;if(r.constructor.name===`AsyncFunction`||r.toString().includes(`__awaiter`))throw TypeError(`[validation-plugin] Route "${n}" ${t} cannot be async`)}function N(e){let t=O(e,`validateExistingRoutes`),n=new Set;k(t.definitions,(e,t)=>{if(typeof e.name!=`string`||!e.name)throw TypeError(`[validation-plugin] validateExistingRoutes: route has invalid name: ${e.name}`);if(typeof e.path!=`string`)throw TypeError(`[validation-plugin] validateExistingRoutes: route "${t}" has non-string path (${typeof e.path})`);if(n.has(t))throw Error(`[validation-plugin] validateExistingRoutes: duplicate route name detected: "${t}"`);n.add(t)})}function P(e){let{config:t,tree:n,matcher:r}=O(e,`validateForwardToConsistency`);for(let[e,i]of Object.entries(t.forwardMap)){if(!A(n,i))throw Error(`[validation-plugin] validateForwardToConsistency: forwardTo target "${i}" does not exist in tree (source route: "${e}")`);let t=r.getSegmentsByName(e),a=r.getSegmentsByName(i);if(t&&a){let n=j(t),r=[...j(a)].filter(e=>!n.has(e));if(r.length>0)throw Error(`[validation-plugin] validateForwardToConsistency: forwardTo target "${i}" requires params [${r.join(`, `)}] not available in source route "${e}"`)}}for(let e of Object.keys(t.forwardMap))Re(e,t.forwardMap)}function ze(e){let{config:t}=O(e,`validateRoutePropertiesStore`);for(let[e,n]of Object.entries(t.decoders)){if(typeof n!=`function`)throw TypeError(`[validation-plugin] validateRoutePropertiesStore: route "${e}" decoder must be a function, got ${typeof n}`);M(n,`decoder`,e)}for(let[e,n]of Object.entries(t.encoders)){if(typeof n!=`function`)throw TypeError(`[validation-plugin] validateRoutePropertiesStore: route "${e}" encoder must be a function, got ${typeof n}`);M(n,`encoder`,e)}for(let[e,n]of Object.entries(t.defaultParams))if(typeof n!=`object`||!n||Array.isArray(n))throw TypeError(`[validation-plugin] validateRoutePropertiesStore: route "${e}" defaultParams must be a plain object, got ${Array.isArray(n)?`array`:typeof n}`);for(let[e,n]of Object.entries(t.forwardFnMap)){if(typeof n!=`function`)throw TypeError(`[validation-plugin] validateRoutePropertiesStore: route "${e}" forwardTo callback must be a function, got ${typeof n}`);M(n,`forwardTo callback`,e)}}function Be(e){let{config:t,tree:n}=O(e,`validateForwardToTargetsStore`);for(let[e,r]of Object.entries(t.forwardMap))if(!A(n,r))throw Error(`[validation-plugin] validateForwardToTargetsStore: forwardTo target "${r}" does not exist for route "${e}"`)}function F(e){if(!e||typeof e!=`object`)throw TypeError(`[validation-plugin] validateDependenciesStructure: deps must be an object`);let t=e;if(!t.dependencies||typeof t.dependencies!=`object`)throw TypeError(`[validation-plugin] validateDependenciesStructure: deps.dependencies must be an object`);let n=t.dependencies;for(let e of Object.keys(n))if(Object.getOwnPropertyDescriptor(n,e)?.get)throw TypeError(`[validation-plugin] validateDependenciesStructure: dependency "${e}" must not use a getter`);if(!t.limits||typeof t.limits!=`object`)throw TypeError(`[validation-plugin] validateDependenciesStructure: deps.limits must be an object`);let r=t.limits;for(let e of[`maxDependencies`,`maxPlugins`,`maxListeners`,`warnListeners`,`maxEventDepth`,`maxLifecycleHandlers`])if(typeof r[e]!=`number`)throw TypeError(`[validation-plugin] validateDependenciesStructure: deps.limits.${e} must be a number, got ${typeof r[e]}`)}function Ve(e){let t=e&&typeof e==`object`?e:{};return t.limits&&typeof t.limits==`object`?t.limits:{}}function He(e,t){if(!e||typeof e!=`object`)return;let n=e;if(!Array.isArray(n.definitions))return;let r=n.definitions.length,i=t.maxRoutes;if(typeof i==`number`&&i>0&&r>i)throw RangeError(`[validation-plugin] validateLimitsConsistency: route count (${r}) exceeds configured limit (${i})`)}function Ue(e,t){if(!e||typeof e!=`object`)return;let n=e,r=n.dependencies,i=n.limits;if(!r||typeof r!=`object`||!i||typeof i!=`object`)return;let a=Object.keys(r).length,o=i,s=t.maxDependencies,c=o.maxDependencies,l=typeof s==`number`?s:c;if(typeof l==`number`&&l>0&&a>=l)throw RangeError(`[validation-plugin] validateLimitsConsistency: dependency count (${a}) reaches or exceeds maxDependencies limit (${l})`)}function We(e,t,n){let r=Ve(e);He(t,r),Ue(n,r)}function I(e,t){if(!(typeof e!=`string`||!e)&&!A(O(t,`validateResolvedDefaultRoute`).tree,e))throw Error(`[validation-plugin] defaultRoute resolved to non-existent route: "${e}"`)}function Ge(e){return`(${e.replaceAll(/(^<|>$)/g,``)})`}const L=`[^/?<]+`,Ke=new RegExp(String.raw`([:*])(${L})(<[^>]+>)?(\?)?`,`g`),qe=new RegExp(String.raw`([:*]${L}(?:<[^>]+>)?)\?(?=[/?]|$)`,`g`),Je=/<[^>]*>/g,Ye=/\?(.+)$/;function Xe(e){return e.replaceAll(Je,e=>`<${`x`.repeat(e.length-2)}>`).replaceAll(qe,`$1\0`)}function Ze(e){let t=[],n=[],r=[],i={},a=new Map,o=Ye.exec(Xe(e));if(o!==null){let t=e.slice(o.index+1).split(`&`);for(let e of t){let t=e.trim();t.length>0&&(n.push(t),i[t]=`query`)}e=e.slice(0,o.index)}let s;for(;(s=Ke.exec(e))!==null;){let e=s[1],n=s[2],o=s[3];if(e===`*`)r.push(n),t.push(n),i[n]=`url`;else if(t.push(n),i[n]=`url`,o){let e=`^${Ge(o)}$`;a.set(n,{pattern:new RegExp(e),constraint:o})}}return{urlParams:t,queryParams:n,spatParams:r,paramTypeMap:i,constraintPatterns:a,pathPattern:e}}RegExp(`^[:*](${L})`),Object.freeze(new Map),Object.freeze([]);function Qe(e,t){let n=[],r=t.includes(`.`)?t.split(`.`):[t];e.path!==``&&n.push(e);let i=e;for(let e of r){let t=i.children.get(e);if(!t)return null;n.push(t),i=t}return n}function R(e,t){return TypeError(`[router.${e}] ${t}`)}const z=RegExp(`[:*](?!${L})`);function $e(e){let t=!1;for(let n of e)if(n===`<`)t=!0;else if(n===`>`){if(!t)return!1;t=!1}return!t}function et(e,t,n,r){if(typeof e!=`string`){let t;throw t=e===null?`null`:Array.isArray(e)?`array`:typeof e,R(n,`Route path must be a string, got ${t}`)}if(e===``)return;if(/\s/.test(e))throw R(n,`Invalid path for route "${t}": whitespace not allowed in "${e}"`);if(!/^([/?~]|[^/]+$)/.test(e))throw R(n,`Route "${t}" has invalid path format: "${e}". Path should start with '/', '~', '?' or be a relative segment.`);if(e.includes(`//`))throw R(n,`Invalid path for route "${t}": double slashes not allowed in "${e}"`);if(!$e(e))throw R(n,`Invalid path for route "${t}": unbalanced constraint delimiter ('<' or '>') in "${e}"`);if(z.test(Ze(e).pathPattern))throw R(n,`Invalid path for route "${t}": parameter marker (':' or '*') without a name in "${e}"`);let i=r&&r.paramMeta.urlParams.length>0;if(e.startsWith(`~`)&&i)throw R(n,`Absolute path "${e}" cannot be used under parent route with URL parameters`)}const tt=/^[A-Z_a-z][\w-]*$/,nt=/\S/,B=1e4;function V(e){return e===null?`null`:typeof e==`object`?`constructor`in e&&e.constructor.name!==`Object`?e.constructor.name:`object`:typeof e}function rt(e){for(let t of Object.keys(e)){let n=Object.getOwnPropertyDescriptor(e,t);if(n&&(n.get||n.set))return!0}return!1}function it(e,t){if(!e||typeof e!=`object`)throw TypeError(`[router.${t}] Route must be an object, got ${V(e)}`);let n=Object.getPrototypeOf(e);if(n!==Object.prototype&&n!==null)throw TypeError(`[router.${t}] Route must be a plain object, got ${V(e)}`);if(rt(e))throw TypeError(`[router.${t}] Route must not have getters or setters`)}function at(e,t){if(e.encodeParams!==void 0&&typeof e.encodeParams!=`function`)throw TypeError(`[router.${t}] Route "${String(e.name)}" encodeParams must be a function`)}function ot(e,t){if(e.decodeParams!==void 0&&typeof e.decodeParams!=`function`)throw TypeError(`[router.${t}] Route "${String(e.name)}" decodeParams must be a function`)}function st(e,t){if(typeof e.name!=`string`)throw TypeError(`[router.${t}] Route name must be a string, got ${V(e.name)}`);let n=e.name;if(n===``)throw TypeError(`[router.${t}] Route name cannot be empty`);if(!nt.test(n))throw TypeError(`[router.${t}] Route name cannot contain only whitespace`);if(n.length>B)throw TypeError(`[router.${t}] Route name exceeds maximum length of ${B} characters`);if(!n.startsWith(`@@`)){if(n.includes(`.`))throw TypeError(`[router.${t}] Route name "${n}" cannot contain dots. Use children array or { parent } option in addRoute() instead.`);if(!tt.test(n))throw TypeError(`[router.${t}] Invalid route name "${n}". Name must start with a letter or underscore, followed by letters, numbers, underscores, or hyphens.`)}}function H(e,t){if(!t.includes(`.`))return e.children.get(t);let n=e;for(let e of t.split(`.`))if(n=n.children.get(e),!n)return;return n}function ct(e,t,n){if(H(e,t))throw Error(`[router.${n}] Route "${t}" already exists`)}function lt(e,t,n){if(e.has(t))throw Error(`[router.${n}] Duplicate route "${t}" in batch`);e.add(t)}function ut(e,t,n,r){let i=t===``?e:H(e,t);if(i){for(let e of i.children.values())if(e.path===n)throw Error(`[router.${r}] Path "${n}" is already defined`)}}function dt(e,t,n,r){let i=e.get(t);if(i?.has(n))throw Error(`[router.${r}] Path "${n}" is already defined`);i?i.add(n):e.set(t,new Set([n]))}function U(e,t,n,r=``,i,a){it(e,t);let o=e;st(o,t),et(o.path,o.name,t,n),at(o,t),ot(o,t);let s=o.name,c=r?`${r}.${s}`:s;n&&c&&ct(n,c,t),i&<(i,c,t);let l=o.path,u=r;if(n&&ut(n,u,l,t),a&&dt(a,u,l,t),o.children!==void 0){if(!Array.isArray(o.children))throw TypeError(`[router.${t}] Route "${s}" children must be an array, got ${V(o.children)}`);for(let e of o.children)U(e,t,n,c,i,a)}}function ft(e,t){if(e!==void 0&&typeof e==`function`){let n=e.constructor.name===`AsyncFunction`,r=e.toString().includes(`__awaiter`);if(n||r)throw TypeError(`[router.addRoute] forwardTo callback cannot be async for route "${t}". Async functions break matchPath/buildPath.`)}}function W(e,t){if(e.canActivate!==void 0&&typeof e.canActivate!=`function`)throw TypeError(`[router.addRoute] canActivate must be a function for route "${t}", got ${g(e.canActivate)}`);if(e.canDeactivate!==void 0&&typeof e.canDeactivate!=`function`)throw TypeError(`[router.addRoute] canDeactivate must be a function for route "${t}", got ${g(e.canDeactivate)}`);if(e.defaultParams!==void 0){let n=e.defaultParams;if(typeof n!=`object`||!n||Array.isArray(n))throw TypeError(`[router.addRoute] defaultParams must be an object for route "${t}", got ${g(e.defaultParams)}`)}if(e.decodeParams?.constructor.name===`AsyncFunction`)throw TypeError(`[router.addRoute] decodeParams cannot be async for route "${t}". Async functions break matchPath/buildPath.`);if(e.encodeParams?.constructor.name===`AsyncFunction`)throw TypeError(`[router.addRoute] encodeParams cannot be async for route "${t}". Async functions break matchPath/buildPath.`);if(ft(e.forwardTo,t),e.children)for(let n of e.children)W(n,`${t}.${n.name}`)}function pt(e){let t=new Set,n=/[*:]([A-Z_a-z]\w*)/g,r;for(;(r=n.exec(e))!==null;)t.add(r[1]);return t}function G(e){let t=new Set;for(let n of e)for(let e of pt(n))t.add(e);return t}function K(e,t,n=``,r=[]){for(let i of e){let e=n?`${n}.${i.name}`:i.name,a=[...r,i.path];if(e===t)return a;if(i.children&&t.startsWith(`${e}.`))return K(i.children,t,e,a)}throw Error(`[internal] collectPathsToRoute: route "${t}" not found`)}function q(e,t=``){let n=new Set;for(let r of e){let e=t?`${t}.${r.name}`:r.name;if(n.add(e),r.children)for(let t of q(r.children,e))n.add(t)}return n}function J(e,t=``){let n=new Map;for(let r of e){let e=t?`${t}.${r.name}`:r.name;if(r.forwardTo&&typeof r.forwardTo==`string`&&n.set(e,r.forwardTo),r.children)for(let[t,i]of J(r.children,e))n.set(t,i)}return n}function mt(e){let t=new Set;for(let n of e){for(let e of n.paramMeta.urlParams)t.add(e);for(let e of n.paramMeta.spatParams)t.add(e)}return t}function ht(e,t){let n=t.split(`.`),r=e;for(let e of n)if(r=r.children.get(e),!r)return!1;return!0}function gt(e,t,n,r){return t?mt(Qe(n,e)??[]):G(K(r,e))}function _t(e,t,n,r,i){let a=ht(i,t),o=r.has(t);if(!a&&!o)throw ReferenceError(`[router.addRoute] forwardTo target "${t}" does not exist for route "${e}"`);let s=G(K(n,e)),c=[...gt(t,a,i,n)].filter(e=>!s.has(e));if(c.length>0)throw Error(`[router.addRoute] forwardTo target "${t}" requires params [${c.join(`, `)}] that are not available in source route "${e}"`)}function vt(t,n,r){let i=q(t),a=J(t),o={...n};for(let[e,t]of a)o[e]=t;for(let[e,n]of a)_t(e,n,t,i,r);for(let t of Object.keys(o))(0,e.resolveForwardChain)(t,o)}function Y(e,t){if(e.startsWith(`@@`))throw Error(`[router.${t}] Route name "${e}" uses the reserved "@@" prefix. Routes with this prefix are internal and cannot be modified through the public API.`)}function X(e,t){for(let n of e)n&&typeof n==`object`&&typeof n.name==`string`&&(Y(n.name,t),n.children&&X(n.children,t))}function yt(e){h(e,`removeRoute`)}function bt(e){if(typeof e!=`string`)throw TypeError(`[router.setRootPath] rootPath must be a string, got ${g(e)}`)}function Z(e){return e.constructor.name===`AsyncFunction`||String(e).includes(`__awaiter`)}function xt(e){let t=e;if(t.canActivate!==void 0&&typeof t.canActivate!=`function`)throw TypeError(`[router.addRoute] canActivate must be a function, got ${g(t.canActivate)}`);if(t.canDeactivate!==void 0&&typeof t.canDeactivate!=`function`)throw TypeError(`[router.addRoute] canDeactivate must be a function, got ${g(t.canDeactivate)}`)}function St(e){let t=e,n=t.name;if(t.decodeParams!==void 0&&Z(t.decodeParams))throw TypeError(`[router.addRoute] decodeParams cannot be async for route "${String(n)}"`);if(t.encodeParams!==void 0&&Z(t.encodeParams))throw TypeError(`[router.addRoute] encodeParams cannot be async for route "${String(n)}"`);if(typeof t.forwardTo==`function`&&Z(t.forwardTo))throw TypeError(`[router.addRoute] forwardTo callback cannot be async for route "${String(n)}"`)}function Ct(e){for(let t of e){if(typeof t!=`object`||!t||Array.isArray(t))throw TypeError(`[router.addRoute] Route must be an object, got ${g(t)}`);W(t,t.name)}}function wt(e){if(typeof e!=`string`||e===``)throw TypeError(`[router.addRoute] parent option must be a non-empty string, got ${g(e)}`);h(e,`addRoute`)}function Tt(e,t,n,r){if(!p(e))throw TypeError(`[router.isActiveRoute] name must be a string, got ${typeof e}`);if(t!==void 0&&!d(t))throw TypeError(`[router.isActiveRoute] params must be a plain object, got ${g(t)}`);if(n!==void 0&&typeof n!=`boolean`)throw TypeError(`[router.isActiveRoute] strictEquality must be a boolean, got ${typeof n}`);if(r!==void 0&&typeof r!=`boolean`)throw TypeError(`[router.isActiveRoute] ignoreQueryParams must be a boolean, got ${typeof r}`)}function Et(e,t,n){if(!p(e))throw TypeError(`[router.${n}] Invalid routeName: ${g(e)}. Expected string.`);if(!d(t))throw TypeError(`[router.${n}] Invalid routeParams: ${g(t)}. Expected plain object.`)}function Dt(e,t){if(h(e,`updateRoute`),e===``)throw ReferenceError(`[router.updateRoute] Invalid name: empty string. Cannot update root node.`);if(t===null)throw TypeError(`[router.updateRoute] updates must be an object, got null`);if(typeof t!=`object`||Array.isArray(t))throw TypeError(`[router.updateRoute] updates must be an object, got ${g(t)}`)}function Q(e,t){if(e.constructor.name===`AsyncFunction`||e.toString().includes(`__awaiter`))throw TypeError(`[router.updateRoute] ${t} cannot be an async function`)}function $(e,t){if(e!=null){if(typeof e!=`function`)throw TypeError(`[router.updateRoute] ${t} must be a function or null, got ${typeof e}`);Q(e,t)}}function Ot(e,t,n,r){if(e!=null){if(typeof e!=`string`&&typeof e!=`function`)throw TypeError(`[router.updateRoute] forwardTo must be a string, function, or null, got ${g(e)}`);typeof e==`function`&&Q(e,`forwardTo callback`)}if(t!=null&&(typeof t!=`object`||Array.isArray(t)))throw TypeError(`[router.updateRoute] defaultParams must be an object or null, got ${g(t)}`);$(n,`decodeParams`),$(r,`encodeParams`)}function kt(e){if(!p(e)||e===``)throw TypeError(`[router.buildPath] route must be a non-empty string, got ${typeof e==`string`?`""`:typeof e}`)}function At(e){if(!p(e))throw TypeError(`[router.matchPath] path must be a string, got ${typeof e}`)}function jt(e){if(!p(e))throw TypeError(`[router.shouldUpdateNode] nodeName must be a string, got ${typeof e}`)}function Mt(e,t,n,r){if(r&&t){let e=t;for(let t of r.split(`.`))if(e=e.children.get(t),!e)throw ReferenceError(`[router.addRoute] Parent route "${r}" does not exist`)}let i=new Set,a=new Map;for(let n of e)U(n,`addRoute`,t,r??``,i,a);t&&n&&vt(e,n,t)}function Nt(e){let t=new Set;for(let n of e)for(let e of n.paramMeta.urlParams)t.add(e);return t}function Pt(e,t,n){let r=n.getSegmentsByName(e),i=n.getSegmentsByName(t),a=Nt(r),o=[];for(let e of i)for(let t of e.paramMeta.urlParams)o.push(t);let s=o.filter(e=>!a.has(e));if(s.length>0)throw Error(`[router.addRoute] forwardTo target "${t}" requires params [${s.join(`, `)}] that are not available in source route "${e}"`)}function Ft(t,n,r){(0,e.resolveForwardChain)(t,{...r.forwardMap,[t]:n})}function It(e,t,n,r,i){if(!n(e))throw ReferenceError(`[router.updateRoute] route "${e}" does not exist`);if(t!=null&&typeof t==`string`){if(!n(t))throw Error(`[router.updateRoute] forwardTo target "${t}" does not exist`);Pt(e,t,r),Ft(e,t,i)}}function Lt(e,t,n){if(!p(e))throw TypeError(`[router.makeState] Invalid name: ${g(e)}. Expected string.`);if(t!==void 0&&!d(t))throw TypeError(`[router.makeState] Invalid params: ${g(t)}. Expected plain object.`);if(n!==void 0&&!p(n))throw TypeError(`[router.makeState] Invalid path: ${g(n)}. Expected string.`)}function Rt(e){return{routes:{validateBuildPathArgs:kt,validateMatchPathArgs:At,validateIsActiveRouteArgs:Tt,validateShouldUpdateNodeArgs:jt,validateStateBuilderArgs:Et,validateAddRouteArgs(e){Ct(e)},validateRoutes(e,t){let n=t;Mt(e,n.tree,n.config?.forwardMap)},validateRemoveRouteArgs:yt,validateUpdateRouteBasicArgs:Dt,validateUpdateRoutePropertyTypes(e,t){let n=t;Ot(n.forwardTo,n.defaultParams,n.decodeParams,n.encodeParams)},validateUpdateRoute(e,t,n){let r=n,i=t.forwardTo;It(e,i,e=>r.matcher.hasRoute(e),r.matcher,r.config)},validateParentOption(e,t){wt(e);let n=t;for(let t of e.split(`.`)){let r=n.children.get(t);if(!r)throw ReferenceError(`[router.addRoute] Parent route "${e}" does not exist`);n=r}},validateRouteName(e,t){h(e,t)},throwIfInternalRoute(e,t){Y(e,t)},throwIfInternalRouteInArray(e,t){X(e,t)},validateExistingRoutes:N,validateForwardToConsistency:P,validateSetRootPathArgs:bt,guardRouteCallbacks:xt,guardNoAsyncCallbacks:St},options:{validateLimitValue(e,t){C(e,t,`validate`)},validateLimits(e){w(e,`validate`)},validateOptions:ke,validateResolvedDefaultRoute:I},dependencies:{validateDependencyName:ne,validateSetDependencyArgs(e,t,n){re(e)},validateDependenciesObject:ie,validateDependencyExists(e,t){let n=t.dependencies?.[e];ae(n,e)},validateDependencyLimit(e,t){},validateDependenciesStructure:F,validateDependencyCount:oe,validateCloneArgs:se,warnOverwrite:ce,warnBatchOverwrite:le,warnRemoveNonExistent:ue},plugins:{validatePluginLimit(e,t){je(e,1,t?.maxPlugins)},validateNoDuplicatePlugins(e,t){},validatePluginKeys:Ne,validateCountThresholds(t){Me(t,e.getOptions().limits?.maxPlugins??50)},warnBatchDuplicates:Pe,warnPluginMethodType:Fe,warnPluginAfterStart:Ie,validateAddInterceptorArgs:Le},lifecycle:{validateHandler:pe,validateNotRegistering(e,t,n){me(!1,e,n)},validateHandlerLimit(e,t,n){he(e,n,t?.maxLifecycleHandlers)},validateCountThresholds(t,n){ge(t,n,e.getOptions().limits?.maxLifecycleHandlers??200)},warnOverwrite:_e,warnAsyncGuardSync:ve},navigation:{validateNavigateArgs:ye,validateNavigateToDefaultArgs:be,validateNavigateToStateArgs:xe,validateNavigationOptions:Se,validateParams:Ce,validateStartArgs:we},state:{validateMakeStateArgs:Lt,validateAreStatesEqualArgs(e,t,n){if(!f(e))throw TypeError(`[router.areStatesEqual] Invalid state1: ${g(e)}. Expected State object.`);if(!f(t))throw TypeError(`[router.areStatesEqual] Invalid state2: ${g(t)}. Expected State object.`);if(n!==void 0&&!m(n))throw TypeError(`[router.areStatesEqual] Invalid ignoreQueryParams: ${g(n)}. Expected boolean.`)}},eventBus:{validateEventName:v,validateListenerArgs(e,t){fe(e,t)}}}}function zt(){return n=>{let r=(0,t.getInternals)(n);if(n.isActive())throw new e.RouterError(`VALIDATION_PLUGIN_AFTER_START`,{message:`validation-plugin must be registered before router.start()`});r.validator=Rt(r);try{let e=r.routeGetStore(),t=r.dependenciesGetStore(),n=r.getOptions();N(e),P(e),ze(e),Be(e),F(t),We(n,e,t),r.validator.options.validateOptions(n,`constructor (retrospective)`),typeof n.defaultRoute==`string`&&I(n.defaultRoute,e)}catch(e){throw r.validator=null,e}return{teardown(){r.validator=null}}}}exports.validationPlugin=zt;
|
|
2
2
|
//# sourceMappingURL=index.js.map
|