@kitbag/router 0.1.0 → 0.2.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.
@@ -1 +1 @@
1
- (function(g,f){typeof exports=="object"&&typeof module<"u"?f(exports,require("vue")):typeof define=="function"&&define.amd?define(["exports","vue"],f):(g=typeof globalThis<"u"?globalThis:g||self,f(g["@kitbag/router"]={},g.Vue))})(this,function(g,f){"use strict";var fn=Object.defineProperty;var ln=(g,f,$)=>f in g?fn(g,f,{enumerable:!0,configurable:!0,writable:!0,value:$}):g[f]=$;var N=(g,f,$)=>(ln(g,typeof f!="symbol"?f+"":f,$),$);class $ extends Error{constructor(t){super(`Invalid Param "${t}": Router does not support multiple params by the same name. All param names must be unique.`)}}class Y extends Error{constructor(){super("Router not installed")}}class Pe extends Error{constructor(t,n){super(`useRoute called with incorrect route. Given ${t}, expected ${n}`)}}const ie=Symbol();function Se(){const e=f.inject(ie);if(!e)throw new Y;return e}const ue=Symbol();function X(){const e=f.inject(ue);if(!e)throw new Y;return e}function Ae(e,t){return[e,t].filter(n=>!!n).join(".")}function at(e){const t=X();function n(){if(!e)return;const r=t.route.matches.map(c=>c.name);if(!ct(r).includes(e))throw new Pe(e,t.route.key)}return f.watch(t.route,n,{immediate:!0,deep:!0}),t.route}function ct(e){return e.reduce((t,n)=>{const r=t.pop(),o=n?[Ae(r,n)]:[];return r?[...t,r,...o]:o},[])}const xe=Symbol();function fe(){return f.inject(xe,0)}class Z{constructor(){N(this,"onBeforeRouteEnter",new Set);N(this,"onBeforeRouteUpdate",new Set);N(this,"onBeforeRouteLeave",new Set);N(this,"onAfterRouteEnter",new Set);N(this,"onAfterRouteUpdate",new Set);N(this,"onAfterRouteLeave",new Set)}}class Be extends Error{}class Q extends Error{constructor(n){super("Error occurred during a router push operation.");N(this,"to");this.to=n}}class le extends Error{constructor(n){super(`Routing action rejected: ${n}`);N(this,"type");this.type=n}}function I(e){return Array.isArray(e)?e:[e]}function st(e,t){const n=new Z;return e.matches.forEach((r,o)=>{r.onBeforeRouteEnter&&he(e,t,o)&&I(r.onBeforeRouteEnter).forEach(a=>n.onBeforeRouteEnter.add(a)),r.onBeforeRouteUpdate&&de(e,t,o)&&I(r.onBeforeRouteUpdate).forEach(a=>n.onBeforeRouteUpdate.add(a))}),t.matches.forEach((r,o)=>{r.onBeforeRouteLeave&&pe(e,t,o)&&I(r.onBeforeRouteLeave).forEach(a=>n.onBeforeRouteLeave.add(a))}),n}function it(e,t){const n=new Z;return e.matches.forEach((r,o)=>{r.onAfterRouteEnter&&he(e,t,o)&&I(r.onAfterRouteEnter).forEach(a=>n.onAfterRouteEnter.add(a)),r.onAfterRouteUpdate&&de(e,t,o)&&I(r.onAfterRouteUpdate).forEach(a=>n.onAfterRouteUpdate.add(a))}),t.matches.forEach((r,o)=>{r.onAfterRouteLeave&&pe(e,t,o)&&I(r.onAfterRouteLeave).forEach(a=>n.onAfterRouteLeave.add(a))}),n}function J(e){return typeof e!="string"?!1:/^(https?:\/\/|\/).*/g.test(e)}function ut(){const e=c=>{throw new le(c)},t=(...c)=>{throw new Q(c)},n=(c,s,u)=>{if(J(c)){const w=s??{};throw new Q([c,{...w,replace:!0}])}const m=s,R=u??{};throw new Q([c,m,{...R,replace:!0}])},r=()=>{throw new Be};async function o({to:c,from:s,hooks:u}){const{global:m,component:R}=u,w=st(c,s),L=[...m.onBeforeRouteEnter,...w.onBeforeRouteEnter,...m.onBeforeRouteUpdate,...w.onBeforeRouteUpdate,...R.onBeforeRouteUpdate,...m.onBeforeRouteLeave,...w.onBeforeRouteLeave,...R.onBeforeRouteLeave];try{const p=L.map(A=>A(c,{from:s,reject:e,push:t,replace:n,abort:r}));await Promise.all(p)}catch(p){if(p instanceof Q)return{status:"PUSH",to:p.to};if(p instanceof le)return{status:"REJECT",type:p.type};if(p instanceof Be)return{status:"ABORT"};throw p}return{status:"SUCCESS"}}async function a({to:c,from:s,hooks:u}){const{global:m,component:R}=u,w=it(c,s),L=[...R.onAfterRouteLeave,...w.onAfterRouteLeave,...m.onAfterRouteLeave,...R.onAfterRouteUpdate,...w.onAfterRouteUpdate,...m.onAfterRouteUpdate,...R.onAfterRouteEnter,...w.onAfterRouteEnter,...m.onAfterRouteEnter];try{const p=L.map(A=>A(c,{from:s,reject:e,push:t,replace:n}));await Promise.all(p)}catch(p){if(p instanceof Q)return{status:"PUSH",to:p.to};if(p instanceof le)return{status:"REJECT",type:p.type};throw p}return{status:"SUCCESS"}}return{runBeforeRouteHooks:o,runAfterRouteHooks:a}}const he=(e,t,n)=>{const r=e.matches,o=(t==null?void 0:t.matches)??[];return r.length<n||r[n]!==o[n]},pe=(e,t,n)=>{const r=e.matches,o=(t==null?void 0:t.matches)??[];return r.length<n||r[n]!==o[n]},de=(e,t,n)=>e.matches[n]===(t==null?void 0:t.matches[n]);function Le(e){switch(e){case"onBeforeRouteEnter":case"onAfterRouteEnter":return he;case"onBeforeRouteUpdate":case"onAfterRouteUpdate":return de;case"onBeforeRouteLeave":case"onAfterRouteLeave":return pe;default:throw new Error(`Switch is not exhaustive for lifecycle: ${e}`)}}class ft{constructor(){N(this,"global",new Z);N(this,"component",new Z)}addBeforeRouteHook({lifecycle:t,timing:n,depth:r,hook:o}){const a=Le(t),c=this[n][t],s=(u,m)=>{if(a(u,m.from,r))return o(u,m)};return c.add(s),()=>c.delete(s)}addAfterRouteHook({lifecycle:t,timing:n,depth:r,hook:o}){const a=Le(t),c=this[n][t],s=(u,m)=>{if(a(u,m.from,r))return o(u,m)};return c.add(s),()=>c.delete(s)}}const Ue=Symbol();function lt(){const e=new ft;return{onBeforeRouteEnter:s=>e.addBeforeRouteHook({lifecycle:"onBeforeRouteEnter",hook:s,timing:"global",depth:0}),onBeforeRouteUpdate:s=>e.addBeforeRouteHook({lifecycle:"onBeforeRouteUpdate",hook:s,timing:"global",depth:0}),onBeforeRouteLeave:s=>e.addBeforeRouteHook({lifecycle:"onBeforeRouteLeave",hook:s,timing:"global",depth:0}),onAfterRouteEnter:s=>e.addAfterRouteHook({lifecycle:"onAfterRouteEnter",hook:s,timing:"global",depth:0}),onAfterRouteUpdate:s=>e.addAfterRouteHook({lifecycle:"onAfterRouteUpdate",hook:s,timing:"global",depth:0}),onAfterRouteLeave:s=>e.addAfterRouteHook({lifecycle:"onAfterRouteLeave",hook:s,timing:"global",depth:0}),hooks:e}}function je(){const e=f.inject(Ue);if(!e)throw new Y;return e}function He(e){return t=>{const n=fe(),o=je().addBeforeRouteHook({lifecycle:e,hook:t,depth:n,timing:"component"});return f.onUnmounted(o),o}}function me(e){return t=>{const n=fe(),o=je().addAfterRouteHook({lifecycle:e,hook:t,depth:n,timing:"component"});return f.onUnmounted(o),o}}const ht=He("onBeforeRouteUpdate"),pt=He("onBeforeRouteLeave"),dt=me("onAfterRouteEnter"),mt=me("onAfterRouteUpdate"),Rt=me("onAfterRouteLeave"),yt=["href"],$e=f.defineComponent({__name:"routerLink",props:{to:{type:[String,Function]},query:{},replace:{type:Boolean}},setup(e){const t=e,n=X(),r=f.computed(()=>J(t.to)?t.to:t.to(n.resolve)),o=f.computed(()=>{const{to:w,...L}=t;return L}),a=f.computed(()=>{var w;return(w=n.find(r.value,o.value))==null?void 0:w.matched}),c=f.computed(()=>!!a.value&&n.route.matches.includes(f.readonly(a.value))),s=f.computed(()=>!!a.value&&n.route.matched===a.value),u=f.computed(()=>({"router-link--match":c.value,"router-link--exact-match":s.value})),m=f.computed(()=>{const{host:w}=new URL(r.value,window.location.origin);return w!==window.location.host});function R(w){w.preventDefault(),n.push(r.value,o.value)}return(w,L)=>(f.openBlock(),f.createElementBlock("a",{href:r.value,class:f.normalizeClass(["router-link",u.value]),onClick:R},[f.renderSlot(w.$slots,"default",f.normalizeProps(f.guardReactiveProps({resolved:r.value,match:c.value,exactMatch:s.value,isExternal:m.value})))],10,yt))}}),Re=f.defineComponent({__name:"routerView",setup(e){const t=X(),n=Se(),r=fe();f.provide(xe,r+1);const o=f.computed(()=>{var c;const a=(c=t.route.matches[r])==null?void 0:c.component;return a?typeof a=="function"?f.defineAsyncComponent(a):a:null});return(a,c)=>f.unref(n)?(f.openBlock(),f.createBlock(f.resolveDynamicComponent(f.unref(n).component),{key:0})):f.renderSlot(a.$slots,"default",{key:1,route:f.unref(t).route,component:o.value},()=>[(f.openBlock(),f.createBlock(f.resolveDynamicComponent(o.value)))])}});function q(){return q=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},q.apply(this,arguments)}var U;(function(e){e.Pop="POP",e.Push="PUSH",e.Replace="REPLACE"})(U||(U={}));var W=process.env.NODE_ENV!=="production"?function(e){return Object.freeze(e)}:function(e){return e};function D(e,t){if(!e){typeof console<"u"&&console.warn(t);try{throw new Error(t)}catch{}}}var ee="beforeunload",gt="hashchange",Ne="popstate";function Ce(e){e===void 0&&(e={});var t=e,n=t.window,r=n===void 0?document.defaultView:n,o=r.history;function a(){var h=r.location,i=h.pathname,l=h.search,E=h.hash,b=o.state||{};return[b.idx,W({pathname:i,search:l,hash:E,state:b.usr||null,key:b.key||"default"})]}var c=null;function s(){if(c)p.call(c),c=null;else{var h=U.Pop,i=a(),l=i[0],E=i[1];if(p.length)if(l!=null){var b=R-l;b&&(c={action:h,location:E,retry:function(){k(b*-1)}},k(b))}else process.env.NODE_ENV!=="production"&&D(!1,"You are trying to block a POP navigation to a location that was not created by the history library. The block will fail silently in production, but in general you should do all navigation with the history library (instead of using window.history.pushState directly) to avoid this situation.");else j(h)}}r.addEventListener(Ne,s);var u=U.Pop,m=a(),R=m[0],w=m[1],L=F(),p=F();R==null&&(R=0,o.replaceState(q({},o.state,{idx:R}),""));function A(h){return typeof h=="string"?h:M(h)}function C(h,i){return i===void 0&&(i=null),W(q({pathname:w.pathname,hash:"",search:""},typeof h=="string"?G(h):h,{state:i,key:ne()}))}function V(h,i){return[{usr:h.state,key:h.key,idx:i},A(h)]}function H(h,i,l){return!p.length||(p.call({action:h,location:i,retry:l}),!1)}function j(h){u=h;var i=a();R=i[0],w=i[1],L.call({action:u,location:w})}function d(h,i){var l=U.Push,E=C(h,i);function b(){d(h,i)}if(H(l,E,b)){var x=V(E,R+1),y=x[0],S=x[1];try{o.pushState(y,"",S)}catch{r.location.assign(S)}j(l)}}function v(h,i){var l=U.Replace,E=C(h,i);function b(){v(h,i)}if(H(l,E,b)){var x=V(E,R),y=x[0],S=x[1];o.replaceState(y,"",S),j(l)}}function k(h){o.go(h)}var P={get action(){return u},get location(){return w},createHref:A,push:d,replace:v,go:k,back:function(){k(-1)},forward:function(){k(1)},listen:function(i){return L.push(i)},block:function(i){var l=p.push(i);return p.length===1&&r.addEventListener(ee,te),function(){l(),p.length||r.removeEventListener(ee,te)}}};return P}function wt(e){e===void 0&&(e={});var t=e,n=t.window,r=n===void 0?document.defaultView:n,o=r.history;function a(){var i=G(r.location.hash.substr(1)),l=i.pathname,E=l===void 0?"/":l,b=i.search,x=b===void 0?"":b,y=i.hash,S=y===void 0?"":y,B=o.state||{};return[B.idx,W({pathname:E,search:x,hash:S,state:B.usr||null,key:B.key||"default"})]}var c=null;function s(){if(c)p.call(c),c=null;else{var i=U.Pop,l=a(),E=l[0],b=l[1];if(p.length)if(E!=null){var x=R-E;x&&(c={action:i,location:b,retry:function(){P(x*-1)}},P(x))}else process.env.NODE_ENV!=="production"&&D(!1,"You are trying to block a POP navigation to a location that was not created by the history library. The block will fail silently in production, but in general you should do all navigation with the history library (instead of using window.history.pushState directly) to avoid this situation.");else d(i)}}r.addEventListener(Ne,s),r.addEventListener(gt,function(){var i=a(),l=i[1];M(l)!==M(w)&&s()});var u=U.Pop,m=a(),R=m[0],w=m[1],L=F(),p=F();R==null&&(R=0,o.replaceState(q({},o.state,{idx:R}),""));function A(){var i=document.querySelector("base"),l="";if(i&&i.getAttribute("href")){var E=r.location.href,b=E.indexOf("#");l=b===-1?E:E.slice(0,b)}return l}function C(i){return A()+"#"+(typeof i=="string"?i:M(i))}function V(i,l){return l===void 0&&(l=null),W(q({pathname:w.pathname,hash:"",search:""},typeof i=="string"?G(i):i,{state:l,key:ne()}))}function H(i,l){return[{usr:i.state,key:i.key,idx:l},C(i)]}function j(i,l,E){return!p.length||(p.call({action:i,location:l,retry:E}),!1)}function d(i){u=i;var l=a();R=l[0],w=l[1],L.call({action:u,location:w})}function v(i,l){var E=U.Push,b=V(i,l);function x(){v(i,l)}if(process.env.NODE_ENV!=="production"&&D(b.pathname.charAt(0)==="/","Relative pathnames are not supported in hash history.push("+JSON.stringify(i)+")"),j(E,b,x)){var y=H(b,R+1),S=y[0],B=y[1];try{o.pushState(S,"",B)}catch{r.location.assign(B)}d(E)}}function k(i,l){var E=U.Replace,b=V(i,l);function x(){k(i,l)}if(process.env.NODE_ENV!=="production"&&D(b.pathname.charAt(0)==="/","Relative pathnames are not supported in hash history.replace("+JSON.stringify(i)+")"),j(E,b,x)){var y=H(b,R),S=y[0],B=y[1];o.replaceState(S,"",B),d(E)}}function P(i){o.go(i)}var h={get action(){return u},get location(){return w},createHref:C,push:v,replace:k,go:P,back:function(){P(-1)},forward:function(){P(1)},listen:function(l){return L.push(l)},block:function(l){var E=p.push(l);return p.length===1&&r.addEventListener(ee,te),function(){E(),p.length||r.removeEventListener(ee,te)}}};return h}function Ve(e){e===void 0&&(e={});var t=e,n=t.initialEntries,r=n===void 0?["/"]:n,o=t.initialIndex,a=r.map(function(d){var v=W(q({pathname:"/",search:"",hash:"",state:null,key:ne()},typeof d=="string"?G(d):d));return process.env.NODE_ENV!=="production"&&D(v.pathname.charAt(0)==="/","Relative pathnames are not supported in createMemoryHistory({ initialEntries }) (invalid entry: "+JSON.stringify(d)+")"),v}),c=_e(o??a.length-1,0,a.length-1),s=U.Pop,u=a[c],m=F(),R=F();function w(d){return typeof d=="string"?d:M(d)}function L(d,v){return v===void 0&&(v=null),W(q({pathname:u.pathname,search:"",hash:""},typeof d=="string"?G(d):d,{state:v,key:ne()}))}function p(d,v,k){return!R.length||(R.call({action:d,location:v,retry:k}),!1)}function A(d,v){s=d,u=v,m.call({action:s,location:u})}function C(d,v){var k=U.Push,P=L(d,v);function h(){C(d,v)}process.env.NODE_ENV!=="production"&&D(u.pathname.charAt(0)==="/","Relative pathnames are not supported in memory history.push("+JSON.stringify(d)+")"),p(k,P,h)&&(c+=1,a.splice(c,a.length,P),A(k,P))}function V(d,v){var k=U.Replace,P=L(d,v);function h(){V(d,v)}process.env.NODE_ENV!=="production"&&D(u.pathname.charAt(0)==="/","Relative pathnames are not supported in memory history.replace("+JSON.stringify(d)+")"),p(k,P,h)&&(a[c]=P,A(k,P))}function H(d){var v=_e(c+d,0,a.length-1),k=U.Pop,P=a[v];function h(){H(d)}p(k,P,h)&&(c=v,A(k,P))}var j={get index(){return c},get action(){return s},get location(){return u},createHref:w,push:C,replace:V,go:H,back:function(){H(-1)},forward:function(){H(1)},listen:function(v){return m.push(v)},block:function(v){return R.push(v)}};return j}function _e(e,t,n){return Math.min(Math.max(e,t),n)}function te(e){e.preventDefault(),e.returnValue=""}function F(){var e=[];return{get length(){return e.length},push:function(n){return e.push(n),function(){e=e.filter(function(r){return r!==n})}},call:function(n){e.forEach(function(r){return r&&r(n)})}}}function ne(){return Math.random().toString(36).substr(2,8)}function M(e){var t=e.pathname,n=t===void 0?"/":t,r=e.search,o=r===void 0?"":r,a=e.hash,c=a===void 0?"":a;return o&&o!=="?"&&(n+=o.charAt(0)==="?"?o:"?"+o),c&&c!=="#"&&(n+=c.charAt(0)==="#"?c:"#"+c),n}function G(e){var t={};if(e){var n=e.indexOf("#");n>=0&&(t.hash=e.substr(n),e=e.substr(0,n));var r=e.indexOf("?");r>=0&&(t.search=e.substr(r),e=e.substr(0,r)),e&&(t.pathname=e)}return t}function vt(e,t){function n(r,o,a){if(typeof r=="object"){const s={...e.params,...r};return t(e.key,s,o)}const c={...e.params,[r]:o};return t(e.key,c,a)}return new Proxy(e,{get:(r,o,a)=>o==="update"?n:o==="params"?new Proxy(e.params,{set(c,s,u){return n(s,u),!0}}):Reflect.get(r,o,a)})}function Et(e,t){const n=f.reactive({...e}),r=c=>{Object.assign(n,{...c})},o=f.readonly(n),a=vt(o,t);return{currentRoute:o,routerRoute:a,updateRoute:r}}class re extends Error{}function bt(e){return e!==String&&e!==Boolean&&e!==Number}function qe(e){return typeof e=="function"&&bt(e)}function ye(e){return typeof e=="object"&&"get"in e&&typeof e.get=="function"&&"set"in e&&typeof e.set=="function"}function oe(e){return typeof e=="string"&&e.length>0}function kt(e,t){return e[t]??String}const Oe=Symbol();function Te(e){return Oe in e}function Pt(e){return{[Oe]:!0,get:t=>{if(oe(t))return ge(t,e)},set:t=>oe(t)?we(t,e):""}}const _={invalid:e=>{throw new re(e)}},St={get:e=>e,set:(e,{invalid:t})=>{if(typeof e!="string")throw t();return e}},De={get:(e,{invalid:t})=>{if(e==="true")return!0;if(e==="false")return!1;throw t()},set:(e,{invalid:t})=>{if(typeof e!="boolean")throw t();return e.toString()}},Me={get:(e,{invalid:t})=>{const n=Number(e);if(isNaN(n))throw t();return n},set:(e,{invalid:t})=>{if(typeof e!="number")throw t();return e.toString()}};function ge(e,t){if(e===void 0){if(Te(t))return t.get(e,_);throw new re}if(t===String)return St.get(e,_);if(t===Boolean)return De.get(e,_);if(t===Number)return Me.get(e,_);if(qe(t))return t(e,_);if(ye(t))return t.get(e,_);if(t instanceof RegExp){if(t.test(e))return e;throw new re}return e}function we(e,t){if(t===Boolean)return De.set(e,_);if(t===Number)return Me.set(e,_);if(ye(t))return t.set(e,_);try{return e.toString()}catch{throw new re}}function At(e){const t=ve(e.path.toString());return new RegExp(`^${t}$`,"i")}function xt(e){const t=new URLSearchParams(e.query.toString());return Array.from(t.entries()).filter(([,n])=>!Ie(n)).map(([n,r])=>new RegExp(`${n}=${ve(r)}(&|$)`,"i"))}function ve(e){return[Bt,Lt].reduce((t,n)=>n(t),e)}const Ee=":\\?([\\w]+)(?=\\W|$)",Ke=":([\\w]+)(?=\\W|$)";function Bt(e){return e.replace(new RegExp(Ee,"g"),"[^\\/]*")}function Ie(e){return new RegExp(Ee,"g").test(e)}function Lt(e){return e.replace(new RegExp(Ke,"g"),"[^\\/]+")}function Ut(e){const[t]=ae(e,new RegExp(Ee,"g")),[n]=ae(e,new RegExp(Ke,"g"));return t??n}function ae(e,t){return Array.from(e.matchAll(t)).flatMap(([,...r])=>r.map(o=>oe(o)?o:""))}function We(e,t,n){const r=Fe(t,n),[o]=ae(e,r);return o}function jt(e,t){if(!t)return e;const{name:n,param:r,value:o}=t,a=Fe(e,n);return ae(e,a).reduce((s,u)=>u===void 0?s:s.replace(u,()=>we(o,r)),e)}function Fe(e,t){const n=[Ht,$t,ve].reduce((r,o)=>o(r,t),e);return new RegExp(n,"g")}function Ht(e,t){const n=new RegExp(`(:\\?${t})(?=\\W|$)`,"g");return e.replace(n,"([^\\/]*)")}function $t(e,t){const n=new RegExp(`(:${t})(?=\\W|$)`,"g");return e.replace(n,"([^\\/]+)")}function Qe(e,...t){return t.reduce((n,r)=>{if(!r)return n;const o=new URLSearchParams(r).toString();return Object.keys(o).length===0?n:n.includes("?")?`${n}&${o}`:`${n}?${o}`},e)}function Nt(e,t={}){const{params:n={},query:r}=t,o={...e.path.params,...e.query.params},a=e.path.toString(),c=e.query.toString(),s=Ct(a,o,n),u=Vt(c,o,n);return Qe(s,u,r)}function Ct(e,t,n){return e.length?Object.entries(t).reduce((r,[o,a])=>jt(r,{name:o,param:a,value:n[o]}),e):e}function Vt(e,t,n){if(!e.length)return{};const r=new URLSearchParams(e);return Array.from(r.entries()).reduce((o,[a,c])=>{const s=Ut(c);if(!s)return{...o,[a]:c};const u=we(n[s],t[s]);return Ie(c)&&n[s]===void 0&&u===""?o:{...o,[a]:u}},{})}function Je(e){return(t,n,r)=>{if(J(t))return Qe(t,(n??{}).query);const o=n??{},a=r??{},c=e.find(u=>u.key===t);if(!c)throw`Route not found: "${String(t)}"`;if(c.matched.disabled)throw`Route disabled: "${String(t)}"`;return Nt(c,{params:o,query:a.query})}}function z(e){return!e.startsWith("http")?qt(e):_t(e)}function _t(e){const{protocol:t,host:n,pathname:r,search:o,searchParams:a,hash:c}=new URL(e,e);return{protocol:t,host:n,pathname:r,search:o,searchParams:a,hash:c}}function qt(e){const{pathname:t,search:n,searchParams:r,hash:o}=new URL(e,"https://localhost");return{pathname:t,search:n,searchParams:r,hash:o}}function Ge(e){const t=new URLSearchParams(e);return{get:n=>t.get(n),getAll:n=>t.getAll(n)}}const Ot=(e,t)=>{try{ze(e,t)}catch{return!1}return!0},ze=(e,t)=>{const{pathname:n,search:r}=z(t);return{...Tt(e.path,n),...Dt(e.query,r)}};function Tt(e,t){const n={},r=decodeURIComponent(t);for(const[o,a]of Object.entries(e.params)){const c=We(r,e.toString(),o),s=ge(c,a);n[o]=s}return n}function Dt(e,t){const n={},r=new URLSearchParams(t);for(const[o,a]of Object.entries(e.params)){const c=r.get(o)??void 0,s=ge(c,a);n[o]=s}return n}const Mt=(e,t)=>{const{pathname:n}=z(t);return At(e).test(n)},Kt=(e,t)=>{const{search:n}=z(t);return xt(e).every(o=>o.test(n))};function It(e){const{searchParams:t,pathname:n}=z(e),r=-1,o=1;return(a,c)=>{const s=Xe(a,t),u=Ye(a,n),m=Xe(c,t),R=Ye(c,n);return s+u>m+R?r:s+u<m+R?o:a.depth>c.depth?r:a.depth<c.depth?o:0}}function Ye(e,t){const n=Object.entries(e.path.params).filter(([,o])=>Te(o)).map(([o])=>o),r=n.filter(o=>We(t,e.path.toString(),o)===void 0);return n.length-r.length}function Xe(e,t){const n=new URLSearchParams(e.query.toString()),r=Array.from(n.keys()),o=r.filter(a=>!t.has(a));return r.length-o.length}function Ze(e,t){const n=[Wt,Mt,Kt,Ot],r=It(t),o=e.filter(m=>n.every(R=>R(m,t))).sort(r);if(o.length===0)return;const[a]=o,{search:c}=z(t),s=Ge(c),u=ze(a,t);return f.readonly({matched:a.matched,matches:a.matches,key:a.key,query:s,params:u})}const Wt=e=>"name"in e.matched&&!!e.matched.name;function Ft(e){return(t,n={})=>{const o=Je(e)(t,n);return Ze(e,o)}}function et(){return typeof window<"u"&&typeof window.document<"u"}function Qt({mode:e,listener:t}){const n=Jt(e),r=(u,m)=>{if(m!=null&&m.replace)return n.replace(u);n.push(u)},o=()=>{const u=M(n.location);return n.replace(u)};let a;return{...n,update:r,refresh:o,startListening:()=>{a==null||a(),a=n.listen(t)},stopListening:()=>{a==null||a()}}}function Jt(e="auto"){switch(e){case"auto":return et()?Ce():Ve();case"browser":return Ce();case"memory":return Ve();case"hash":return wt();default:const t=e;throw new Error(`Switch is not exhaustive for mode: ${t}`)}}function Gt(e){return f.defineComponent(()=>()=>f.h("h1",e),{name:e,props:[]})}const tt=Symbol();function zt({rejections:e}){const t=c=>{const s={...e};return f.markRaw(s[c]??Gt(c))},n=c=>{const s=f.markRaw(t(c)),u={name:c,path:"",component:s,meta:{}};return f.readonly({matched:u,matches:[u],key:c,query:Ge(""),params:{},[tt]:!0})},r=c=>c[tt]===!0,o=c=>{if(!c){a.value=null;return}const s=t(c);a.value={type:c,component:s}},a=f.ref(null);return{setRejection:o,rejection:a,getRejectionRoute:n,isRejectionRoute:r}}class Yt extends Error{constructor(){super("initialUrl must be set if window.location is unavailable")}}function Xt(e){if(e)return e;if(et())return window.location.toString();throw new Yt}function Zt(e,t={}){const n=Je(e),r=Qt({mode:t.historyMode,listener:()=>{const y=M(location);p(y)}}),{runBeforeRouteHooks:o,runAfterRouteHooks:a}=ut(),{hooks:c,onBeforeRouteEnter:s,onAfterRouteUpdate:u,onBeforeRouteLeave:m,onAfterRouteEnter:R,onBeforeRouteUpdate:w,onAfterRouteLeave:L}=lt();async function p(y,{replace:S}={}){r.stopListening();const B=Ze(e,y)??v("NotFound"),O={...P},K=await o({to:B,from:O,hooks:c});switch(K.status){case"ABORT":return;case"PUSH":r.update(y,{replace:S}),await A(...K.to);return;case"REJECT":r.update(y,{replace:S}),j(K.type),i(B);break;case"SUCCESS":r.update(y,{replace:S}),j(null),i(B);break;default:throw new Error(`Switch is not exhaustive for before hook response status: ${JSON.stringify(K)}`)}const T=await a({to:B,from:O,hooks:c});switch(T.status){case"PUSH":await A(...T.to);break;case"REJECT":j(T.type);break;case"SUCCESS":break;default:const se=T;throw new Error(`Switch is not exhaustive for after hook response status: ${JSON.stringify(se)}`)}r.startListening()}const A=(y,S,B)=>{if(J(y)){const se={...S},un=n(y,se);return p(un,{replace:se.replace})}const O={...B},T=n(y,S??{},O);return p(T,{replace:O.replace})},C=(y,S,B)=>{if(J(y)){const T={...S,replace:!0};return A(y,T)}const O=S??{},K={...B,replace:!0};return A(y,O,K)},V=y=>j(y),H=Ft(e),{setRejection:j,rejection:d,getRejectionRoute:v}=zt(t),k=v("NotFound"),{currentRoute:P,routerRoute:h,updateRoute:i}=Et(k,A);r.startListening();const l=Xt(t.initialUrl),E=p(l,{replace:!0});function b(y){y.component("RouterView",Re),y.component("RouterLink",$e),y.provide(ue,x),y.provide(ie,d),y.provide(Ue,c)}const x={route:h,resolve:n,push:A,replace:C,reject:V,find:H,refresh:r.refresh,forward:r.forward,back:r.back,go:r.go,install:b,initialized:E,onBeforeRouteEnter:s,onAfterRouteUpdate:u,onBeforeRouteLeave:m,onAfterRouteEnter:R,onBeforeRouteUpdate:w,onAfterRouteLeave:L};return x}function nt(e,t){const n=/:\??([\w]+)(?=\W|$)/g;return Array.from(e.matchAll(n)).reduce((o,[a,c])=>{const s=a.startsWith(":?"),u=kt(t,c);if(c in o)throw new $(c);return o[c]=s?Pt(u):u,o},{})}function be(e,t){return{path:e,params:nt(e,t),toString:()=>e}}function ke(e,t){const n=Object.keys(e),r=Object.keys(t),o=n.find(a=>r.includes(a));return o?{key:o,hasDuplicates:!0}:{key:void 0,hasDuplicates:!1}}function en(e,t){const{hasDuplicates:n,key:r}=ke(e.params,t.params);if(n)throw new $(r);return be(`${e.path}${t.path}`,{...e.params,...t.params})}function ce(e,t){return{query:e,params:nt(e,t),toString:()=>e}}function tn(e,t){const{hasDuplicates:n,key:r}=ke(e.params,t.params);if(n)throw new $(r);const o=[e.query,t.query].filter(oe).join("&");return ce(o,{...e.params,...t.params})}function rt(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}function nn(e){return rt(e)&&typeof e.path=="string"}function rn(e){return nn(e)?e:be(e,{})}function on(e){return rt(e)&&typeof e.query=="string"}function an(e){return e===void 0?ce("",{}):on(e)?e:ce(e,{})}function ot(e){return"children"in e}function cn(e){const t=e.reduce((n,r)=>{const o=sn({...r,component:r.component??Re});return ot(r)&&n.push(...r.children.map(a=>({...a,key:Ae(o.key,a.key),path:en(o.path,a.path),query:tn(o.query,a.query),matches:[o.matched,...a.matches],depth:a.depth+1}))),n.push(o),n},[]);return t.forEach(({path:n,query:r})=>{const{hasDuplicates:o,key:a}=ke(n.params,r.params);if(o)throw new $(a)}),t}function sn(e){const t=rn(e.path),n=an(e.query),r=f.markRaw({meta:{},...e});return{matched:r,matches:[r],key:e.name,path:t,query:n,depth:1,disabled:e.disabled??!1}}g.DuplicateParamsError=$,g.RouterLink=$e,g.RouterNotInstalledError=Y,g.RouterView=Re,g.UseRouteInvalidError=Pe,g.createRouter=Zt,g.createRoutes=cn,g.isParamGetSet=ye,g.isParamGetter=qe,g.isParentRoute=ot,g.onAfterRouteEnter=dt,g.onAfterRouteLeave=mt,g.onAfterRouteUpdate=Rt,g.onBeforeRouteLeave=ht,g.onBeforeRouteUpdate=pt,g.path=be,g.query=ce,g.routerInjectionKey=ue,g.routerRejectionKey=ie,g.useRejection=Se,g.useRoute=at,g.useRouter=X,Object.defineProperty(g,Symbol.toStringTag,{value:"Module"})});
1
+ (function(y,u){typeof exports=="object"&&typeof module<"u"?u(exports,require("vue")):typeof define=="function"&&define.amd?define(["exports","vue"],u):(y=typeof globalThis<"u"?globalThis:y||self,u(y["@kitbag/router"]={},y.Vue))})(this,function(y,u){"use strict";var mn=Object.defineProperty;var yn=(y,u,N)=>u in y?mn(y,u,{enumerable:!0,configurable:!0,writable:!0,value:N}):y[u]=N;var O=(y,u,N)=>(yn(y,typeof u!="symbol"?u+"":u,N),N);class N extends Error{constructor(t){super(`Invalid Param "${t}": Router does not support multiple params by the same name. All param names must be unique.`)}}class Z extends Error{constructor(){super("Router not installed")}}class Ae extends Error{constructor(t,n){super(`useRoute called with incorrect route. Given ${t}, expected ${n}`)}}const fe=Symbol();function xe(){const e=u.inject(fe);if(!e)throw new Z;return e}const le=Symbol();function ee(){const e=u.inject(le);if(!e)throw new Z;return e}function Be(e,t){return[e,t].filter(n=>!!n).join(".")}function ut(e){const t=ee();function n(){if(!e)return;const r=t.route.matches.map(c=>c.name);if(!ft(r).includes(e))throw new Ae(e,t.route.key)}return u.watch(t.route,n,{immediate:!0,deep:!0}),t.route}function ft(e){return e.reduce((t,n)=>{const r=t.pop(),o=n?[Be(r,n)]:[];return r?[...t,r,...o]:o},[])}const Le=Symbol();function he(){return u.inject(Le,0)}class te{constructor(){O(this,"onBeforeRouteEnter",new Set);O(this,"onBeforeRouteUpdate",new Set);O(this,"onBeforeRouteLeave",new Set);O(this,"onAfterRouteEnter",new Set);O(this,"onAfterRouteUpdate",new Set);O(this,"onAfterRouteLeave",new Set)}}class Ue extends Error{}class G extends Error{constructor(n){super("Error occurred during a router push operation.");O(this,"to");this.to=n}}class pe extends Error{constructor(n){super(`Routing action rejected: ${n}`);O(this,"type");this.type=n}}function J(e){return Array.isArray(e)?e:[e]}function lt(e,t){const n=new te;return e.matches.forEach((r,o)=>{r.onBeforeRouteEnter&&de(e,t,o)&&J(r.onBeforeRouteEnter).forEach(a=>n.onBeforeRouteEnter.add(a)),r.onBeforeRouteUpdate&&ye(e,t,o)&&J(r.onBeforeRouteUpdate).forEach(a=>n.onBeforeRouteUpdate.add(a))}),t.matches.forEach((r,o)=>{r.onBeforeRouteLeave&&me(e,t,o)&&J(r.onBeforeRouteLeave).forEach(a=>n.onBeforeRouteLeave.add(a))}),n}function ht(e,t){const n=new te;return e.matches.forEach((r,o)=>{r.onAfterRouteEnter&&de(e,t,o)&&J(r.onAfterRouteEnter).forEach(a=>n.onAfterRouteEnter.add(a)),r.onAfterRouteUpdate&&ye(e,t,o)&&J(r.onAfterRouteUpdate).forEach(a=>n.onAfterRouteUpdate.add(a))}),t.matches.forEach((r,o)=>{r.onAfterRouteLeave&&me(e,t,o)&&J(r.onAfterRouteLeave).forEach(a=>n.onAfterRouteLeave.add(a))}),n}function z(e){return typeof e!="string"?!1:/^(https?:\/\/|\/).*/g.test(e)}function pt(){const e=c=>{throw new pe(c)},t=(...c)=>{throw new G(c)},n=(c,s,f)=>{if(z(c)){const w=s??{};throw new G([c,{...w,replace:!0}])}const m=s,R=f??{};throw new G([c,m,{...R,replace:!0}])},r=()=>{throw new Ue};async function o({to:c,from:s,hooks:f}){const{global:m,component:R}=f,w=lt(c,s),L=[...m.onBeforeRouteEnter,...w.onBeforeRouteEnter,...m.onBeforeRouteUpdate,...w.onBeforeRouteUpdate,...R.onBeforeRouteUpdate,...m.onBeforeRouteLeave,...w.onBeforeRouteLeave,...R.onBeforeRouteLeave];try{const p=L.map(A=>A(c,{from:s,reject:e,push:t,replace:n,abort:r}));await Promise.all(p)}catch(p){if(p instanceof G)return{status:"PUSH",to:p.to};if(p instanceof pe)return{status:"REJECT",type:p.type};if(p instanceof Ue)return{status:"ABORT"};throw p}return{status:"SUCCESS"}}async function a({to:c,from:s,hooks:f}){const{global:m,component:R}=f,w=ht(c,s),L=[...R.onAfterRouteLeave,...w.onAfterRouteLeave,...m.onAfterRouteLeave,...R.onAfterRouteUpdate,...w.onAfterRouteUpdate,...m.onAfterRouteUpdate,...R.onAfterRouteEnter,...w.onAfterRouteEnter,...m.onAfterRouteEnter];try{const p=L.map(A=>A(c,{from:s,reject:e,push:t,replace:n}));await Promise.all(p)}catch(p){if(p instanceof G)return{status:"PUSH",to:p.to};if(p instanceof pe)return{status:"REJECT",type:p.type};throw p}return{status:"SUCCESS"}}return{runBeforeRouteHooks:o,runAfterRouteHooks:a}}const de=(e,t,n)=>{const r=e.matches,o=(t==null?void 0:t.matches)??[];return r.length<n||r[n]!==o[n]},me=(e,t,n)=>{const r=e.matches,o=(t==null?void 0:t.matches)??[];return r.length<n||r[n]!==o[n]},ye=(e,t,n)=>e.matches[n]===(t==null?void 0:t.matches[n]);function je(e){switch(e){case"onBeforeRouteEnter":case"onAfterRouteEnter":return de;case"onBeforeRouteUpdate":case"onAfterRouteUpdate":return ye;case"onBeforeRouteLeave":case"onAfterRouteLeave":return me;default:throw new Error(`Switch is not exhaustive for lifecycle: ${e}`)}}class dt{constructor(){O(this,"global",new te);O(this,"component",new te)}addBeforeRouteHook({lifecycle:t,timing:n,depth:r,hook:o}){const a=je(t),c=this[n][t],s=(f,m)=>{if(a(f,m.from,r))return o(f,m)};return c.add(s),()=>c.delete(s)}addAfterRouteHook({lifecycle:t,timing:n,depth:r,hook:o}){const a=je(t),c=this[n][t],s=(f,m)=>{if(a(f,m.from,r))return o(f,m)};return c.add(s),()=>c.delete(s)}}const He=Symbol();function mt(){const e=new dt;return{onBeforeRouteEnter:s=>e.addBeforeRouteHook({lifecycle:"onBeforeRouteEnter",hook:s,timing:"global",depth:0}),onBeforeRouteUpdate:s=>e.addBeforeRouteHook({lifecycle:"onBeforeRouteUpdate",hook:s,timing:"global",depth:0}),onBeforeRouteLeave:s=>e.addBeforeRouteHook({lifecycle:"onBeforeRouteLeave",hook:s,timing:"global",depth:0}),onAfterRouteEnter:s=>e.addAfterRouteHook({lifecycle:"onAfterRouteEnter",hook:s,timing:"global",depth:0}),onAfterRouteUpdate:s=>e.addAfterRouteHook({lifecycle:"onAfterRouteUpdate",hook:s,timing:"global",depth:0}),onAfterRouteLeave:s=>e.addAfterRouteHook({lifecycle:"onAfterRouteLeave",hook:s,timing:"global",depth:0}),hooks:e}}function $e(){const e=u.inject(He);if(!e)throw new Z;return e}function Ne(e){return t=>{const n=he(),o=$e().addBeforeRouteHook({lifecycle:e,hook:t,depth:n,timing:"component"});return u.onUnmounted(o),o}}function Re(e){return t=>{const n=he(),o=$e().addAfterRouteHook({lifecycle:e,hook:t,depth:n,timing:"component"});return u.onUnmounted(o),o}}const yt=Ne("onBeforeRouteUpdate"),Rt=Ne("onBeforeRouteLeave"),gt=Re("onAfterRouteEnter"),wt=Re("onAfterRouteUpdate"),vt=Re("onAfterRouteLeave"),Et=["href"],Oe=u.defineComponent({__name:"routerLink",props:{to:{type:[String,Function]},query:{},replace:{type:Boolean}},setup(e){const t=e,n=ee(),r=u.computed(()=>z(t.to)?t.to:t.to(n.resolve)),o=u.computed(()=>{const{to:w,...L}=t;return L}),a=u.computed(()=>{var w;return(w=n.find(r.value,o.value))==null?void 0:w.matched}),c=u.computed(()=>!!a.value&&n.route.matches.includes(u.readonly(a.value))),s=u.computed(()=>!!a.value&&n.route.matched===a.value),f=u.computed(()=>({"router-link--match":c.value,"router-link--exact-match":s.value})),m=u.computed(()=>{const{host:w}=new URL(r.value,window.location.origin);return w!==window.location.host});function R(w){w.preventDefault(),n.push(r.value,o.value)}return(w,L)=>(u.openBlock(),u.createElementBlock("a",{href:r.value,class:u.normalizeClass(["router-link",f.value]),onClick:R},[u.renderSlot(w.$slots,"default",u.normalizeProps(u.guardReactiveProps({resolved:r.value,match:c.value,exactMatch:s.value,isExternal:m.value})))],10,Et))}}),ge=u.defineComponent({__name:"routerView",setup(e){const t=ee(),n=xe(),r=he();u.provide(Le,r+1);const o=u.computed(()=>{var c;const a=(c=t.route.matches[r])==null?void 0:c.component;return a?typeof a=="function"?u.defineAsyncComponent(a):a:null});return(a,c)=>u.unref(n)?(u.openBlock(),u.createBlock(u.resolveDynamicComponent(u.unref(n).component),{key:0})):u.renderSlot(a.$slots,"default",{key:1,route:u.unref(t).route,component:o.value},()=>[(u.openBlock(),u.createBlock(u.resolveDynamicComponent(o.value)))])}});function bt(e,t){return u.defineComponent({name:"PropsWrapper",expose:[],async setup(){const n=await t();return()=>u.h(e,n)}})}function _(){return _=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},_.apply(this,arguments)}var U;(function(e){e.Pop="POP",e.Push="PUSH",e.Replace="REPLACE"})(U||(U={}));var F=process.env.NODE_ENV!=="production"?function(e){return Object.freeze(e)}:function(e){return e};function T(e,t){if(!e){typeof console<"u"&&console.warn(t);try{throw new Error(t)}catch{}}}var ne="beforeunload",Pt="hashchange",Ce="popstate";function Ve(e){e===void 0&&(e={});var t=e,n=t.window,r=n===void 0?document.defaultView:n,o=r.history;function a(){var h=r.location,i=h.pathname,l=h.search,E=h.hash,b=o.state||{};return[b.idx,F({pathname:i,search:l,hash:E,state:b.usr||null,key:b.key||"default"})]}var c=null;function s(){if(c)p.call(c),c=null;else{var h=U.Pop,i=a(),l=i[0],E=i[1];if(p.length)if(l!=null){var b=R-l;b&&(c={action:h,location:E,retry:function(){P(b*-1)}},P(b))}else process.env.NODE_ENV!=="production"&&T(!1,"You are trying to block a POP navigation to a location that was not created by the history library. The block will fail silently in production, but in general you should do all navigation with the history library (instead of using window.history.pushState directly) to avoid this situation.");else H(h)}}r.addEventListener(Ce,s);var f=U.Pop,m=a(),R=m[0],w=m[1],L=Q(),p=Q();R==null&&(R=0,o.replaceState(_({},o.state,{idx:R}),""));function A(h){return typeof h=="string"?h:M(h)}function C(h,i){return i===void 0&&(i=null),F(_({pathname:w.pathname,hash:"",search:""},typeof h=="string"?Y(h):h,{state:i,key:oe()}))}function V(h,i){return[{usr:h.state,key:h.key,idx:i},A(h)]}function $(h,i,l){return!p.length||(p.call({action:h,location:i,retry:l}),!1)}function H(h){f=h;var i=a();R=i[0],w=i[1],L.call({action:f,location:w})}function d(h,i){var l=U.Push,E=C(h,i);function b(){d(h,i)}if($(l,E,b)){var x=V(E,R+1),g=x[0],S=x[1];try{o.pushState(g,"",S)}catch{r.location.assign(S)}H(l)}}function v(h,i){var l=U.Replace,E=C(h,i);function b(){v(h,i)}if($(l,E,b)){var x=V(E,R),g=x[0],S=x[1];o.replaceState(g,"",S),H(l)}}function P(h){o.go(h)}var k={get action(){return f},get location(){return w},createHref:A,push:d,replace:v,go:P,back:function(){P(-1)},forward:function(){P(1)},listen:function(i){return L.push(i)},block:function(i){var l=p.push(i);return p.length===1&&r.addEventListener(ne,re),function(){l(),p.length||r.removeEventListener(ne,re)}}};return k}function kt(e){e===void 0&&(e={});var t=e,n=t.window,r=n===void 0?document.defaultView:n,o=r.history;function a(){var i=Y(r.location.hash.substr(1)),l=i.pathname,E=l===void 0?"/":l,b=i.search,x=b===void 0?"":b,g=i.hash,S=g===void 0?"":g,B=o.state||{};return[B.idx,F({pathname:E,search:x,hash:S,state:B.usr||null,key:B.key||"default"})]}var c=null;function s(){if(c)p.call(c),c=null;else{var i=U.Pop,l=a(),E=l[0],b=l[1];if(p.length)if(E!=null){var x=R-E;x&&(c={action:i,location:b,retry:function(){k(x*-1)}},k(x))}else process.env.NODE_ENV!=="production"&&T(!1,"You are trying to block a POP navigation to a location that was not created by the history library. The block will fail silently in production, but in general you should do all navigation with the history library (instead of using window.history.pushState directly) to avoid this situation.");else d(i)}}r.addEventListener(Ce,s),r.addEventListener(Pt,function(){var i=a(),l=i[1];M(l)!==M(w)&&s()});var f=U.Pop,m=a(),R=m[0],w=m[1],L=Q(),p=Q();R==null&&(R=0,o.replaceState(_({},o.state,{idx:R}),""));function A(){var i=document.querySelector("base"),l="";if(i&&i.getAttribute("href")){var E=r.location.href,b=E.indexOf("#");l=b===-1?E:E.slice(0,b)}return l}function C(i){return A()+"#"+(typeof i=="string"?i:M(i))}function V(i,l){return l===void 0&&(l=null),F(_({pathname:w.pathname,hash:"",search:""},typeof i=="string"?Y(i):i,{state:l,key:oe()}))}function $(i,l){return[{usr:i.state,key:i.key,idx:l},C(i)]}function H(i,l,E){return!p.length||(p.call({action:i,location:l,retry:E}),!1)}function d(i){f=i;var l=a();R=l[0],w=l[1],L.call({action:f,location:w})}function v(i,l){var E=U.Push,b=V(i,l);function x(){v(i,l)}if(process.env.NODE_ENV!=="production"&&T(b.pathname.charAt(0)==="/","Relative pathnames are not supported in hash history.push("+JSON.stringify(i)+")"),H(E,b,x)){var g=$(b,R+1),S=g[0],B=g[1];try{o.pushState(S,"",B)}catch{r.location.assign(B)}d(E)}}function P(i,l){var E=U.Replace,b=V(i,l);function x(){P(i,l)}if(process.env.NODE_ENV!=="production"&&T(b.pathname.charAt(0)==="/","Relative pathnames are not supported in hash history.replace("+JSON.stringify(i)+")"),H(E,b,x)){var g=$(b,R),S=g[0],B=g[1];o.replaceState(S,"",B),d(E)}}function k(i){o.go(i)}var h={get action(){return f},get location(){return w},createHref:C,push:v,replace:P,go:k,back:function(){k(-1)},forward:function(){k(1)},listen:function(l){return L.push(l)},block:function(l){var E=p.push(l);return p.length===1&&r.addEventListener(ne,re),function(){E(),p.length||r.removeEventListener(ne,re)}}};return h}function _e(e){e===void 0&&(e={});var t=e,n=t.initialEntries,r=n===void 0?["/"]:n,o=t.initialIndex,a=r.map(function(d){var v=F(_({pathname:"/",search:"",hash:"",state:null,key:oe()},typeof d=="string"?Y(d):d));return process.env.NODE_ENV!=="production"&&T(v.pathname.charAt(0)==="/","Relative pathnames are not supported in createMemoryHistory({ initialEntries }) (invalid entry: "+JSON.stringify(d)+")"),v}),c=qe(o??a.length-1,0,a.length-1),s=U.Pop,f=a[c],m=Q(),R=Q();function w(d){return typeof d=="string"?d:M(d)}function L(d,v){return v===void 0&&(v=null),F(_({pathname:f.pathname,search:"",hash:""},typeof d=="string"?Y(d):d,{state:v,key:oe()}))}function p(d,v,P){return!R.length||(R.call({action:d,location:v,retry:P}),!1)}function A(d,v){s=d,f=v,m.call({action:s,location:f})}function C(d,v){var P=U.Push,k=L(d,v);function h(){C(d,v)}process.env.NODE_ENV!=="production"&&T(f.pathname.charAt(0)==="/","Relative pathnames are not supported in memory history.push("+JSON.stringify(d)+")"),p(P,k,h)&&(c+=1,a.splice(c,a.length,k),A(P,k))}function V(d,v){var P=U.Replace,k=L(d,v);function h(){V(d,v)}process.env.NODE_ENV!=="production"&&T(f.pathname.charAt(0)==="/","Relative pathnames are not supported in memory history.replace("+JSON.stringify(d)+")"),p(P,k,h)&&(a[c]=k,A(P,k))}function $(d){var v=qe(c+d,0,a.length-1),P=U.Pop,k=a[v];function h(){$(d)}p(P,k,h)&&(c=v,A(P,k))}var H={get index(){return c},get action(){return s},get location(){return f},createHref:w,push:C,replace:V,go:$,back:function(){$(-1)},forward:function(){$(1)},listen:function(v){return m.push(v)},block:function(v){return R.push(v)}};return H}function qe(e,t,n){return Math.min(Math.max(e,t),n)}function re(e){e.preventDefault(),e.returnValue=""}function Q(){var e=[];return{get length(){return e.length},push:function(n){return e.push(n),function(){e=e.filter(function(r){return r!==n})}},call:function(n){e.forEach(function(r){return r&&r(n)})}}}function oe(){return Math.random().toString(36).substr(2,8)}function M(e){var t=e.pathname,n=t===void 0?"/":t,r=e.search,o=r===void 0?"":r,a=e.hash,c=a===void 0?"":a;return o&&o!=="?"&&(n+=o.charAt(0)==="?"?o:"?"+o),c&&c!=="#"&&(n+=c.charAt(0)==="#"?c:"#"+c),n}function Y(e){var t={};if(e){var n=e.indexOf("#");n>=0&&(t.hash=e.substr(n),e=e.substr(0,n));var r=e.indexOf("?");r>=0&&(t.search=e.substr(r),e=e.substr(0,r)),e&&(t.pathname=e)}return t}function St(e,t){function n(r,o,a){if(typeof r=="object"){const s={...e.params,...r};return t(e.key,s,o)}const c={...e.params,[r]:o};return t(e.key,c,a)}return new Proxy(e,{get:(r,o,a)=>o==="update"?n:o==="params"?new Proxy(e.params,{set(c,s,f){return n(s,f),!0}}):Reflect.get(r,o,a)})}function At(e,t){const n=u.reactive({...e}),r=c=>{Object.assign(n,{...c})},o=u.readonly(n),a=St(o,t);return{currentRoute:o,routerRoute:a,updateRoute:r}}class ae extends Error{}const K="[",W="]";function xt(e){return e!==String&&e!==Boolean&&e!==Number&&e!==Date}function De(e){return typeof e=="function"&&xt(e)}function we(e){return typeof e=="object"&&"get"in e&&typeof e.get=="function"&&"set"in e&&typeof e.set=="function"}function ce(e){return typeof e=="string"&&e.length>0}function Bt(e,t){return e[t]??String}const Te=Symbol();function Me(e){return Te in e}function Lt(e){return{[Te]:!0,get:t=>{if(ce(t))return ve(t,e)},set:t=>ce(t)?Ee(t,e):""}}const j={invalid:e=>{throw new ae(e)}},Ut={get:e=>e,set:(e,{invalid:t})=>{if(typeof e!="string")throw t();return e}},Ke={get:(e,{invalid:t})=>{if(e==="true")return!0;if(e==="false")return!1;throw t()},set:(e,{invalid:t})=>{if(typeof e!="boolean")throw t();return e.toString()}},Ie={get:(e,{invalid:t})=>{const n=Number(e);if(isNaN(n))throw t();return n},set:(e,{invalid:t})=>{if(typeof e!="number")throw t();return e.toString()}},Je={get:(e,{invalid:t})=>{console.log("inside date getter");const n=new Date(e);if(isNaN(n.getTime()))throw t();return n},set:(e,{invalid:t})=>{if(typeof e!="object"||!(e instanceof Date))throw t();return e.toISOString()}},Fe={get:(e,{invalid:t})=>{try{return JSON.parse(e)}catch{throw t()}},set:(e,{invalid:t})=>{try{return JSON.stringify(e)}catch{throw t()}}};function ve(e,t){if(e===void 0){if(Me(t))return t.get(e,j);throw new ae}if(t===String)return Ut.get(e,j);if(t===Boolean)return Ke.get(e,j);if(t===Number)return Ie.get(e,j);if(t===Date)return Je.get(e,j);if(t===JSON)return Fe.get(e,j);if(De(t))return t(e,j);if(we(t))return t.get(e,j);if(t instanceof RegExp){if(t.test(e))return e;throw new ae}return e}function Ee(e,t){if(t===Boolean)return Ke.set(e,j);if(t===Number)return Ie.set(e,j);if(t===Date)return Je.set(e,j);if(t===JSON)return Fe.set(e,j);if(we(t))return t.set(e,j);try{return e.toString()}catch{throw new ae}}function jt(e){const t=be(e.path.toString());return new RegExp(`^${t}$`,"i")}function Ht(e){const t=new URLSearchParams(e.query.toString());return Array.from(t.entries()).filter(([,n])=>!We(n)).map(([n,r])=>new RegExp(`${n}=${be(r)}(&|$)`,"i"))}function be(e){return[$t,Nt].reduce((t,n)=>n(t),e)}const Pe=`\\${K}\\?([\\w]+)\\${W}`,Qe=`\\${K}([\\w]+)\\${W}`;function $t(e){return e.replace(new RegExp(Pe,"g"),".*")}function We(e){return new RegExp(Pe,"g").test(e)}function Nt(e){return e.replace(new RegExp(Qe,"g"),".+")}function Ot(e){const[t]=se(e,new RegExp(Pe,"g")),[n]=se(e,new RegExp(Qe,"g"));return t??n}function se(e,t){return Array.from(e.matchAll(t)).flatMap(([,...r])=>r.map(o=>ce(o)?o:""))}function Ge(e,t,n){const r=ze(t,n),[o]=se(e,r);return o}function Ct(e,t){if(!t)return e;const{name:n,param:r,value:o}=t,a=ze(e,n);return se(e,a).reduce((s,f)=>f===void 0?s:s.replace(f,()=>Ee(o,r)),e)}function ze(e,t){const n=[Vt,_t,be].reduce((r,o)=>o(r,t),e);return new RegExp(n,"g")}function Vt(e,t){const n=new RegExp(`(\\${K}\\?${t})\\${W}`,"g");return e.replace(n,"(.*)")}function _t(e,t){const n=new RegExp(`(\\${K}${t})\\${W}`,"g");return e.replace(n,"(.+)")}function Ye(e,...t){return t.reduce((n,r)=>{if(!r)return n;const o=new URLSearchParams(r).toString();return Object.keys(o).length===0?n:n.includes("?")?`${n}&${o}`:`${n}?${o}`},e)}function qt(e,t={}){const{params:n={},query:r}=t,o={...e.path.params,...e.query.params},a=e.path.toString(),c=e.query.toString(),s=Dt(a,o,n),f=Tt(c,o,n);return Ye(s,f,r)}function Dt(e,t,n){return e.length?Object.entries(t).reduce((r,[o,a])=>Ct(r,{name:o,param:a,value:n[o]}),e):e}function Tt(e,t,n){if(!e.length)return{};const r=new URLSearchParams(e);return Array.from(r.entries()).reduce((o,[a,c])=>{const s=Ot(c);if(!s)return{...o,[a]:c};const f=Ee(n[s],t[s]);return We(c)&&n[s]===void 0&&f===""?o:{...o,[a]:f}},{})}function Xe(e){return(t,n,r)=>{if(z(t))return Ye(t,(n??{}).query);const o=n??{},a=r??{},c=e.find(f=>f.key===t);if(!c)throw`Route not found: "${String(t)}"`;if(c.matched.disabled)throw`Route disabled: "${String(t)}"`;return qt(c,{params:o,query:a.query})}}function X(e){return!e.startsWith("http")?Kt(e):Mt(e)}function Mt(e){const{protocol:t,host:n,pathname:r,search:o,searchParams:a,hash:c}=new URL(e,e);return{protocol:t,host:n,pathname:r,search:o,searchParams:a,hash:c}}function Kt(e){const{pathname:t,search:n,searchParams:r,hash:o}=new URL(e,"https://localhost");return{pathname:t,search:n,searchParams:r,hash:o}}function Ze(e){const t=new URLSearchParams(e);return{get:n=>t.get(n),getAll:n=>t.getAll(n)}}const It=(e,t)=>{try{et(e,t)}catch{return!1}return!0},et=(e,t)=>{const{pathname:n,search:r}=X(t);return{...Jt(e.path,n),...Ft(e.query,r)}};function Jt(e,t){const n={},r=decodeURIComponent(t);for(const[o,a]of Object.entries(e.params)){const c=Ge(r,e.toString(),o),s=ve(c,a);n[o]=s}return n}function Ft(e,t){const n={},r=new URLSearchParams(t);for(const[o,a]of Object.entries(e.params)){const c=r.get(o)??void 0,s=ve(c,a);n[o]=s}return n}const Qt=(e,t)=>{const{pathname:n}=X(t);return jt(e).test(n)},Wt=(e,t)=>{const{search:n}=X(t);return Ht(e).every(o=>o.test(n))};function Gt(e){const{searchParams:t,pathname:n}=X(e),r=-1,o=1;return(a,c)=>{const s=nt(a,t),f=tt(a,n),m=nt(c,t),R=tt(c,n);return s+f>m+R?r:s+f<m+R?o:a.depth>c.depth?r:a.depth<c.depth?o:0}}function tt(e,t){const n=Object.entries(e.path.params).filter(([,o])=>Me(o)).map(([o])=>o),r=n.filter(o=>Ge(t,e.path.toString(),o)===void 0);return n.length-r.length}function nt(e,t){const n=new URLSearchParams(e.query.toString()),r=Array.from(n.keys()),o=r.filter(a=>!t.has(a));return r.length-o.length}function rt(e,t){const n=[zt,Qt,Wt,It],r=Gt(t),o=e.filter(m=>n.every(R=>R(m,t))).sort(r);if(o.length===0)return;const[a]=o,{search:c}=X(t),s=Ze(c),f=et(a,t);return u.readonly({matched:a.matched,matches:a.matches,key:a.key,query:s,params:f})}const zt=e=>"name"in e.matched&&!!e.matched.name;function Yt(e){return(t,n={})=>{const o=Xe(e)(t,n);return rt(e,o)}}function ot(){return typeof window<"u"&&typeof window.document<"u"}function Xt({mode:e,listener:t}){const n=Zt(e),r=(f,m)=>{if(m!=null&&m.replace)return n.replace(f);n.push(f)},o=()=>{const f=M(n.location);return n.replace(f)};let a;return{...n,update:r,refresh:o,startListening:()=>{a==null||a(),a=n.listen(t)},stopListening:()=>{a==null||a()}}}function Zt(e="auto"){switch(e){case"auto":return ot()?Ve():_e();case"browser":return Ve();case"memory":return _e();case"hash":return kt();default:const t=e;throw new Error(`Switch is not exhaustive for mode: ${t}`)}}function en(e){return u.defineComponent(()=>()=>u.h("h1",e),{name:e,props:[]})}const at=Symbol();function tn({rejections:e}){const t=c=>{const s={...e};return u.markRaw(s[c]??en(c))},n=c=>{const s=u.markRaw(t(c)),f={name:c,path:"",component:s,meta:{}};return u.readonly({matched:f,matches:[f],key:c,query:Ze(""),params:{},[at]:!0})},r=c=>c[at]===!0,o=c=>{if(!c){a.value=null;return}const s=t(c);a.value={type:c,component:s}},a=u.ref(null);return{setRejection:o,rejection:a,getRejectionRoute:n,isRejectionRoute:r}}class nn extends Error{constructor(){super("initialUrl must be set if window.location is unavailable")}}function rn(e){if(e)return e;if(ot())return window.location.toString();throw new nn}function on(e,t={}){const n=Xe(e),r=Xt({mode:t.historyMode,listener:()=>{const g=M(location);p(g)}}),{runBeforeRouteHooks:o,runAfterRouteHooks:a}=pt(),{hooks:c,onBeforeRouteEnter:s,onAfterRouteUpdate:f,onBeforeRouteLeave:m,onAfterRouteEnter:R,onBeforeRouteUpdate:w,onAfterRouteLeave:L}=mt();async function p(g,{replace:S}={}){r.stopListening();const B=rt(e,g)??v("NotFound"),q={...k},I=await o({to:B,from:q,hooks:c});switch(I.status){case"ABORT":return;case"PUSH":r.update(g,{replace:S}),await A(...I.to);return;case"REJECT":r.update(g,{replace:S}),H(I.type),i(B);break;case"SUCCESS":r.update(g,{replace:S}),H(null),i(B);break;default:throw new Error(`Switch is not exhaustive for before hook response status: ${JSON.stringify(I)}`)}const D=await a({to:B,from:q,hooks:c});switch(D.status){case"PUSH":await A(...D.to);break;case"REJECT":H(D.type);break;case"SUCCESS":break;default:const ue=D;throw new Error(`Switch is not exhaustive for after hook response status: ${JSON.stringify(ue)}`)}r.startListening()}const A=(g,S,B)=>{if(z(g)){const ue={...S},dn=n(g,ue);return p(dn,{replace:ue.replace})}const q={...B},D=n(g,S??{},q);return p(D,{replace:q.replace})},C=(g,S,B)=>{if(z(g)){const D={...S,replace:!0};return A(g,D)}const q=S??{},I={...B,replace:!0};return A(g,q,I)},V=g=>H(g),$=Yt(e),{setRejection:H,rejection:d,getRejectionRoute:v}=tn(t),P=v("NotFound"),{currentRoute:k,routerRoute:h,updateRoute:i}=At(P,A);r.startListening();const l=rn(t.initialUrl),E=p(l,{replace:!0});function b(g){g.component("RouterView",ge),g.component("RouterLink",Oe),g.provide(le,x),g.provide(fe,d),g.provide(He,c)}const x={route:h,resolve:n,push:A,replace:C,reject:V,find:$,refresh:r.refresh,forward:r.forward,back:r.back,go:r.go,install:b,initialized:E,onBeforeRouteEnter:s,onAfterRouteUpdate:f,onBeforeRouteLeave:m,onAfterRouteEnter:R,onBeforeRouteUpdate:w,onAfterRouteLeave:L};return x}function ct(e,t){const n=new RegExp(`\\${K}\\??([\\w]+)\\${W}`,"g");return Array.from(e.matchAll(n)).reduce((o,[a,c])=>{const s=a.startsWith(`${K}?`),f=Bt(t,c);if(c in o)throw new N(c);return o[c]=s?Lt(f):f,o},{})}function ke(e,t){return{path:e,params:ct(e,t),toString:()=>e}}function Se(e,t){const n=Object.keys(e),r=Object.keys(t),o=n.find(a=>r.includes(a));return o?{key:o,hasDuplicates:!0}:{key:void 0,hasDuplicates:!1}}function an(e,t){const{hasDuplicates:n,key:r}=Se(e.params,t.params);if(n)throw new N(r);return ke(`${e.path}${t.path}`,{...e.params,...t.params})}function ie(e,t){return{query:e,params:ct(e,t),toString:()=>e}}function cn(e,t){const{hasDuplicates:n,key:r}=Se(e.params,t.params);if(n)throw new N(r);const o=[e.query,t.query].filter(ce).join("&");return ie(o,{...e.params,...t.params})}function st(e){return typeof e=="object"&&e!==null&&!Array.isArray(e)}function sn(e){return st(e)&&typeof e.path=="string"}function un(e){return sn(e)?e:ke(e,{})}function fn(e){return st(e)&&typeof e.query=="string"}function ln(e){return e===void 0?ie("",{}):fn(e)?e:ie(e,{})}function it(e){return"children"in e}function hn(e){const t=e.reduce((n,r)=>{const o=pn({...r,component:r.component??ge});return it(r)&&n.push(...r.children.map(a=>({...a,key:Be(o.key,a.key),path:an(o.path,a.path),query:cn(o.query,a.query),matches:[o.matched,...a.matches],depth:a.depth+1}))),n.push(o),n},[]);return t.forEach(({path:n,query:r})=>{const{hasDuplicates:o,key:a}=Se(n.params,r.params);if(o)throw new N(a)}),t}function pn(e){const t=un(e.path),n=ln(e.query),r=u.markRaw({meta:{},...e});return{matched:r,matches:[r],key:e.name,path:t,query:n,depth:1,disabled:e.disabled??!1}}y.DuplicateParamsError=N,y.RouterLink=Oe,y.RouterNotInstalledError=Z,y.RouterView=ge,y.UseRouteInvalidError=Ae,y.component=bt,y.createRouter=on,y.createRoutes=hn,y.isParamGetSet=we,y.isParamGetter=De,y.isParentRoute=it,y.onAfterRouteEnter=gt,y.onAfterRouteLeave=wt,y.onAfterRouteUpdate=vt,y.onBeforeRouteLeave=yt,y.onBeforeRouteUpdate=Rt,y.paramEnd=W,y.paramStart=K,y.path=ke,y.query=ie,y.routerInjectionKey=le,y.routerRejectionKey=fe,y.useRejection=xe,y.useRoute=ut,y.useRouter=ee,Object.defineProperty(y,Symbol.toStringTag,{value:"Module"})});
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@kitbag/router",
3
3
  "private": false,
4
- "version": "0.1.0",
4
+ "version": "0.2.0",
5
5
  "bugs": {
6
6
  "url": "https://github.com/kitbagjs/router/issues"
7
7
  },