@modastar/z-router 0.0.8 → 0.0.10
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/.oxlintrc.json +24 -0
- package/.vscode/settings.json +3 -0
- package/dist/index.cjs +1 -1
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +34 -20
- package/dist/index.d.ts +34 -20
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/example/README.md +3 -0
- package/example/dist/assets/index-BnRxLDj4.js +23 -0
- package/example/dist/assets/index-C0uITd16.css +1 -0
- package/example/dist/assets/index-CejLCVJl.js +1 -0
- package/example/dist/index.html +14 -0
- package/example/package.json +10 -2
- package/example/pnpm-lock.yaml +3967 -564
- package/package.json +3 -2
package/dist/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{useContext as
|
|
1
|
+
import{useContext as Lt}from"react";import{createContext as Ct}from"react";var B=Ct(null);var w=()=>{let t=Lt(B);if(t===null)throw new Error("useRouter must be used within a Stack");return t};import{memo as bt}from"react";import{jsx as wt}from"react/jsx-runtime";var ro=bt(({to:t,replace:r,transition:e,duration:s,onFinish:o,...u})=>{let n=w();return wt("a",{...u,href:t,onClick:i=>{i.preventDefault(),n.navigate({to:t,replace:r,transition:e,duration:s,onFinish:o})}})});import{createContext as Ot}from"react";var G=Ot(null);import{memo as St,useCallback as z}from"react";import{jsx as Tt}from"react/jsx-runtime";var E=St(({location:t,...r})=>{let e=w(),s=z(n=>t.state[n],[t]),o=z((n,i)=>{e.setLocationState(t.index,{...t.state,[n]:i})},[e,t]),u=z(n=>{delete t.state[n],e.setLocationState(t.index,t.state)},[e,t]);return Tt(G.Provider,{value:{...t,canGoBack:t.index>0,canGoForward:t.index<e.history.length-1,getState:s,setState:o,deleteState:u},...r})},(t,r)=>t.location===r.location);import{createContext as kt}from"react";var U=kt(0);import{useContext as Mt}from"react";var ot=()=>Mt(U);import{createContext as At}from"react";var I=At(null);import{useContext as Nt}from"react";var X=()=>{let t=Nt(I);if(t===null)throw new Error("useRouteMatch must be used within a RouteMatchProvider");return t};import{jsx as Dt}from"react/jsx-runtime";var et=({depth:t,...r})=>Dt(U.Provider,{value:t,...r});import{useContext as Et}from"react";var H=()=>{let t=Et(G);if(t===null)throw new Error("useLocation must be used within a LocationProvider");return t};import{createContext as Ft}from"react";var F=Ft(null);import{useContext as $t}from"react";var nt=()=>{let t=$t(F);if(t===null)throw new Error("useRoute must be used within a RouteProvider");return t};import{useEffect as Wt,useState as jt}from"react";import{jsx as q}from"react/jsx-runtime";var Y=({depth:t=0})=>{let r=w(),e=H(),s=X(),o=nt(),u=`_Z.${o.id}.pending`,[n,i]=jt(!!o?.beforeLoad&&o?.getState(u)!==!1);if(Wt(()=>{!o||t>=s.matches.length||n&&o?.beforeLoad&&o.getState(u)!==!0&&(o.setState(u,!0),o.beforeLoad({location:e}).catch(({cause:h})=>{"to"in h&&r.navigate(h)}).finally(()=>{o.setState(u,!1),i(!1)}))},[o]),!o)return null;if(t>=s.matches.length){let h=o.notFoundComponent;return q(h,{})}if(n){let h=o.pendingComponent;return q(h,{})}let p=o.component;return p?q(p,{}):q(rt,{})};import{useContext as Gt}from"react";import{createContext as Bt}from"react";var _=Bt(null);var K=()=>{let t=Gt(_);if(t===null)throw new Error("useRootRoute must be used within a RootRouteProvider");return t};import{useCallback as it}from"react";import{jsx as st}from"react/jsx-runtime";var V=({route:t,...r})=>{if(!t)return st(F.Provider,{value:null,...r});let{state:e,getRouteState:s,setRouteState:o}=K(),u=it(i=>s(t.id,i),[s,t.id]),n=it((i,p)=>{o(t.id,i,p)},[o,t.id]);return st(F.Provider,{value:{...t,state:e[t.id],getState:u,setState:n},...r})};import{jsx as J}from"react/jsx-runtime";var rt=()=>{let t=X(),r=ot()+1;return J(et,{depth:r,children:J(V,{route:t.matches.at(r),children:J(Y,{depth:r})})})};import{useCallback as $,useEffect as lt,useState as W}from"react";var at={defaultTransitionDuration:300};var Oe=300,Se=t=>new Error("",{cause:t}),Ut=(t,r)=>{try{let e,s;if(r.startsWith("http://")||r.startsWith("https://")){let f=new URL(r);e=f.pathname,s=f.searchParams}else{let[f,d]=r.split("?");if(!f)return null;e=f,s=new URLSearchParams(d||"")}let o=e.replaceAll(/^\/|\/$/g,""),u=t.replaceAll(/^\/|\/$/g,""),n=o.split("/"),i=u.split("/");if(n.length!==i.length)return null;let p={};for(let f=0;f<i.length;f++){let d=i[f],P=n[f];if(d.startsWith(":")){let O=d.slice(1);p[O]=decodeURIComponent(P)}else if(d!==P)return null}let h=Object.fromEntries(s.entries());return{params:p,query:h}}catch{return null}},ut=(t,r)=>{let e=(s,{children:o})=>{if(o&&o.length>0){for(let n of o){let i=e([...s,n],n);if(i)return i}return null}let u=Ut(It(s),r);return u?{matches:s,...u}:null};return e([t],t)||{matches:[],params:{},query:{}}},It=t=>{let r=[];for(let e of t)e.pathname!==void 0&&r.push(e.pathname.replaceAll(/^\/|\/$/g,""));return"/"+r.join("/")},pt=({href:t,pathname:r,search:e})=>({index:0,href:t,state:{index:0},pathname:r,search:Object.fromEntries(new URLSearchParams(e))}),Te=t=>({...at,...t}),mt=t=>{let r=(e,s)=>{let o=e.name??(e.pathname?`${s}/${e.pathname.replaceAll(/^\/|\/$/g,"")}`:s);return{...e,id:o,children:e.children?.map(n=>r(n,o))}};return r(t,"")},ct=t=>t.length>0,dt=(t,r)=>{let e=t.split("/").filter(ct),s=r.split("/").filter(ct);for(let o of s)o!=="."&&(o===".."?e.pop():e.push(o));return"/"+e.join("/")};import{jsx as ft}from"react/jsx-runtime";var Fe=({options:t,...r})=>{let[e,s]=W([pt(window.location)]),[o,u]=W(0),n=e.at(o),[i,p]=W(!1),[h,f]=W(0),[d,P]=W();lt(()=>{window.history.replaceState(n.state,"",n.pathname)},[]),lt(()=>{let m=({state:l})=>{u(l?.index)};return addEventListener("popstate",m),()=>{removeEventListener("popstate",m)}},[o]);let O=$(({to:m,replace:l})=>{if(!m)return n;let g=l?o:o+1,x=m.startsWith("/")?m:dt(n.pathname,m),v={index:g};return{index:g,href:origin+x,search:{},state:v,pathname:x}},[o,n]),k=(m,l=t.defaultTransitionDuration,g)=>{p(!0),f(l),P(m),setTimeout(()=>{p(!1),P(void 0),g?.()},l)},L=$(({to:m,replace:l,transition:g,duration:x,onFinish:v})=>{if(i)return;let y=l?o:o+1,R=O({to:m,replace:l}),D=()=>{l?(s(S=>[...S.slice(0,y),R,...S.slice(y+1)]),window.history.replaceState(R.state,"",R.pathname)):(s(S=>[...S.slice(0,y),R]),u(y),window.history.pushState(R.state,"",R.pathname)),v?.()};g??t.defaultUseTransition?.(n,R)?k(R,x,D):D()},[o,e,i,t]),j=$(({transition:m,duration:l,onFinish:g,depth:x}={})=>{if(o===0||i)return;let v=x??1,y=e.at(o-v),R=()=>{window.history.go(-v),g?.()};y&&(m??t.defaultUseTransition?.(n,y))?k(y,l,R):R()},[o,e,i,t]),b=$(({transition:m,duration:l,depth:g,onFinish:x}={})=>{if(o+1>=e.length||i)return;let v=g??1,y=e.at(o+v),R=()=>{window.history.go(v),x?.()};y&&(m??t.defaultUseTransition?.(n,y))?k(y,l,R):R()},[o,e,i,t]),N=$((m,l)=>{s(g=>g.map(x=>x.index===m?{...x,state:l}:x)),m===o&&window.history.replaceState(l,"",n.pathname)},[o]);return ft(B.Provider,{value:{options:t,history:e,location:n,canGoBack:o>0,canGoForward:o<e.length-1,isTransitioning:i,transitionDuration:h,transitioningToLocation:d,buildLocation:O,navigate:L,back:j,forward:b,setLocationState:N},children:ft(E,{location:n,...r})})};import{useCallback as qt,useEffect as Yt,useRef as tt,useState as A}from"react";import{jsx as Q}from"react/jsx-runtime";var Z=()=>{let t=K(),r=H(),e=ut(t,r.pathname);return Q(I.Provider,{value:e,children:Q(V,{route:t,children:Q(Y,{})})})};import{useCallback as Rt,useState as Xt}from"react";import{jsx as Ht}from"react/jsx-runtime";var ht=({rootRoute:t,...r})=>{let e=mt(t),[s,o]=Xt({}),u=Rt((i,p)=>s[i]?.[p],[s]),n=Rt((i,p,h)=>{o(f=>({...f,[i]:{...f[i],[p]:h}}))},[]);return Ht(_.Provider,{value:{...e,state:s,getRouteState:u,setRouteState:n},...r})};import{jsx as C,jsxs as Kt}from"react/jsx-runtime";var _t=({style:t,...r})=>{let{history:e,location:s,canGoBack:o,canGoForward:u,isTransitioning:n,transitioningToLocation:i,transitionDuration:p,back:h,forward:f}=w(),d=s.index,P=tt(!1),O=tt(0),k=tt(0),[L,j]=A(!1),[b,N]=A(0),[m,l]=A(!1),[g,x]=A(!1),[v,y]=A(!1),[R,D]=A(!1);if(Yt(()=>{!n||!i||(D(!0),setTimeout(()=>{D(!1)},p))},[n,i,p]),d===void 0)return;let S=()=>{j(!1),N(0),l(!1),x(!1),y(!1)},gt=T=>{n||!u&&!o||(P.current=!0,O.current=T.touches[0].clientX,k.current=T.touches[0].clientY)},xt=T=>{if(!P.current)return;let{clientX:vt,clientY:Pt}=T.touches[0];if(!L&&Math.abs(Pt-k.current)>30){P.current=!1;return}let M=vt-O.current;if(!(Math.abs(M)<10)){if(L||j(!0),M>0&&d===0||M<0&&d+1===e.length){N(0);return}!m&&M<0&&l(!0),!g&&M>0&&x(!0),N(Math.max(Math.min(M,window.innerWidth),-window.innerWidth))}},yt=qt(()=>{if(P.current=!1,!L)return;let T={onFinish:S};b>innerWidth*.3&&o?h(T):b<-innerWidth*.3&&u?f(T):(y(!0),setTimeout(S,p))},[h,f,L,b,o,u,p]);return Kt("div",{style:{position:"relative",overflow:"hidden",...t},...r,children:[d>=1&&(L&&g||n&&i.index<d)&&C("div",{style:{position:"absolute",inset:0},children:C(E,{location:e.at(d-1),children:C(Z,{},d-1)})}),C("div",{style:{background:"white",position:"absolute",inset:0,transform:n&&i.index<d?"translateX(100%)":L&&b>0&&!v?`translateX(${b}px)`:"translateX(0px)",transition:v||n&&i.index<d?`transform ${p}ms ease-out`:""},onTouchStart:gt,onTouchMove:xt,onTouchEnd:yt,children:C(Z,{})},d),(L&&m||n&&d<=i.index)&&C("div",{style:{background:"white",position:"absolute",inset:0,transform:`translateX(${R?"0px":n||v?"100%":`${innerWidth+b}px`})`,transition:`transform ${n||v?p:0}ms ease-in`},children:C(E,{location:n?i:e.at(d+1),children:C(Z,{},i?.index)})})]})},sn=({rootRoute:t,...r})=>C(ht,{rootRoute:t,children:C(_t,{...r})});export{Oe as DefaultTransitionDuration,ro as Link,G as LocationContext,E as LocationProvider,rt as Outlet,_ as RootRouteContext,B as RouterContext,Fe as RouterProvider,sn as Stack,It as buildPathnameFromMatches,Te as createRouterOptions,Ut as matchPattern,ut as matchRoute,pt as parseLocation,mt as parseRoute,Se as redirect,dt as resolveRelativePathname,H as useLocation,K as useRootRoute,nt as useRoute,X as useRouteMatch,w as useRouter};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/hooks/useRouter.ts","../src/context/router-context.ts","../src/components/link.tsx","../src/context/location-context.ts","../src/components/location-provider.tsx","../src/context/outlet-context.ts","../src/hooks/useOutlet.ts","../src/context/route-match-context.ts","../src/hooks/useRouteMatch.ts","../src/components/outlet-provider.tsx","../src/hooks/useLocation.ts","../src/context/route-context.ts","../src/hooks/useRoute.ts","../src/components/route-component.tsx","../src/hooks/useRootRoute.ts","../src/context/root-route-context.ts","../src/components/route-provider.tsx","../src/components/outlet.tsx","../src/components/router-provider.tsx","../src/constants.ts","../src/utils.ts","../src/components/stack.tsx","../src/components/page-renderer.tsx","../src/components/root-route-provider.tsx"],"sourcesContent":["import { useContext } from \"react\";\n\nimport { RouterContext } from \"@/context/router-context.js\";\n\nexport const useRouter = () => {\n const router = useContext(RouterContext);\n if (router === null) {\n throw new Error(\"useRouter must be used within a Stack\");\n }\n return router;\n};\n","import { createContext } from \"react\";\n\nimport type {\n BackOptions,\n ForwardOptions,\n Location,\n NavigateOptions,\n RouterOptions,\n} from \"@/types.js\";\n\nexport interface RouterContextType {\n // Router Config\n options: RouterOptions;\n\n // Navigation State\n history: Location[];\n location?: Location;\n canGoBack: boolean;\n canGoForward: boolean;\n\n // Transition state\n isTransitioning: boolean;\n transitionDuration: number;\n transitioningToLocation?: Location;\n\n // Actions\n navigate: (options: NavigateOptions) => void;\n back: (options?: BackOptions) => void;\n forward: (options?: ForwardOptions) => void;\n\n // Low-level state action\n setLocationState: (index: number, state: Record<string, any>) => void;\n}\n\nexport const RouterContext = createContext<RouterContextType | null>(null);\n","import { useRouter } from \"@/hooks/useRouter.js\";\nimport type { NavigateOptions } from \"@/types.js\";\n\nexport type LinkProps = React.ComponentPropsWithoutRef<\"a\"> & NavigateOptions;\n\nexport const Link: React.FC<LinkProps> = ({\n to,\n replace,\n transition,\n duration,\n onFinish,\n ...props\n}) => {\n const router = useRouter();\n return (\n <a\n {...props}\n href={to}\n onClick={(e) => {\n e.preventDefault();\n router.navigate({ to, replace, transition, duration, onFinish });\n }}\n />\n );\n};\n","import { createContext } from \"react\";\n\nimport type { Location } from \"@/types.js\";\n\nexport interface LocationContextType extends Location {\n canGoBack: boolean;\n canGoForward: boolean;\n getState: (key: string) => any;\n setState: (key: string, value: any) => void;\n deleteState: (key: string) => void;\n}\n\nexport const LocationContext = createContext<LocationContextType | null>(null);\n","import { LocationContext } from \"@/context/location-context.js\";\nimport { useRouter } from \"@/hooks/useRouter.js\";\nimport type { Location } from \"@/types.js\";\nimport { useCallback } from \"react\";\n\nexport const LocationProvider = ({\n location,\n ...props\n}: {\n location: Location;\n children: React.ReactNode;\n}) => {\n const router = useRouter();\n const getState = useCallback(\n (key: string) => {\n return location.state[key];\n },\n [location]\n );\n const setState = useCallback(\n (key: string, value: any) => {\n router.setLocationState(location.index, {\n ...location.state,\n [key]: value,\n });\n },\n [router, location]\n );\n const deleteState = useCallback(\n (key: string) => {\n delete location.state[key];\n router.setLocationState(location.index, location.state);\n },\n [router, location]\n );\n return (\n <LocationContext.Provider\n value={{\n ...location,\n canGoBack: location.index > 0,\n canGoForward: location.index < router.history.length - 1,\n getState,\n setState,\n deleteState,\n }}\n {...props}\n />\n );\n};\n","import { createContext } from \"react\";\n\nexport const OutletContext = createContext<number>(0);\n","import { OutletContext } from \"@/context/outlet-context.js\";\nimport { useContext } from \"react\";\n\nexport const useOutlet = () => useContext(OutletContext);\n","import type { RouteMatch } from \"@/types.js\";\nimport { createContext } from \"react\";\n\nexport const RouteMatchContext = createContext<RouteMatch | null>(null);\n","import { RouteMatchContext } from \"@/context/route-match-context.js\";\nimport { useContext } from \"react\";\n\nexport const useRouteMatch = () => {\n const routeMatch = useContext(RouteMatchContext);\n if (routeMatch === null) {\n throw new Error(\"useRouteMatch must be used within a RouteMatchProvider\");\n }\n return routeMatch;\n};\n","import { OutletContext } from \"@/context/outlet-context.js\";\n\nexport const OutletProvider = ({\n depth,\n ...props\n}: {\n depth: number;\n children?: React.ReactNode;\n}) => <OutletContext.Provider value={depth} {...props} />;\n","import { useContext } from \"react\";\n\nimport { LocationContext } from \"@/context/location-context.js\";\n\nexport const useLocation = () => {\n const context = useContext(LocationContext);\n if (context === null) {\n throw new Error(\"useLocation must be used within a LocationProvider\");\n }\n return context;\n};\n","import type { ParsedRoute } from \"@/types.js\";\nimport { createContext } from \"react\";\n\nexport interface RouteContextType extends ParsedRoute {\n getState: (key: string) => any;\n setState: (key: string, value: any) => void;\n}\n\nexport const RouteContext = createContext<RouteContextType | null>(null);\n","import { RouteContext } from \"@/context/route-context.js\";\nimport { useContext } from \"react\";\n\nexport const useRoute = () => {\n const route = useContext(RouteContext);\n if (route === null) {\n throw new Error(\"useRoute must be used within a RouteProvider\");\n }\n return route;\n};\n","import { useLocation } from \"@/hooks/useLocation.js\";\nimport { useRoute } from \"@/hooks/useRoute.js\";\nimport { useRouteMatch } from \"@/hooks/useRouteMatch.js\";\nimport { useRouter } from \"@/hooks/useRouter.js\";\nimport { useEffect, useState } from \"react\";\nimport { Outlet } from \"./outlet.js\";\n\nexport const RouteComponent = ({ depth = 0 }: { depth?: number }) => {\n const router = useRouter();\n const location = useLocation();\n const routeMatch = useRouteMatch();\n const route = useRoute();\n\n const pendingStateKey = `_Z.${route.id}.pending`;\n\n const [pending, setPending] = useState(\n !!route?.beforeLoad && route?.getState(pendingStateKey) !== false\n );\n\n useEffect(() => {\n if (!route || depth >= routeMatch.matches.length) {\n return;\n }\n // TODO: push location still loading. Maybe store state in route () instead of location\n if (pending && route?.beforeLoad) {\n route.setState(pendingStateKey, true);\n route\n .beforeLoad({ location })\n .catch(({ cause }: Error) => {\n if (\"to\" in (cause as any)) {\n router.navigate(cause as any);\n }\n })\n .finally(() => {\n route.setState(pendingStateKey, false);\n setPending(false);\n });\n }\n }, []);\n\n if (!route) {\n return null;\n }\n\n if (depth >= routeMatch.matches.length) {\n const NotFoundComponent = route.notFoundComponent!;\n return <NotFoundComponent />;\n }\n\n if (pending) {\n const PendingComponent = route.pendingComponent!;\n return <PendingComponent />;\n }\n\n const Component = route.component;\n return Component ? <Component /> : <Outlet />;\n};\n","import { useContext } from \"react\";\n\nimport { RootRouteContext } from \"@/context/root-route-context.js\";\n\nexport const useRootRoute = () => {\n const route = useContext(RootRouteContext);\n if (route === null) {\n throw new Error(\"useRootRoute must be used within a RootRouteProvider\");\n }\n return route;\n};\n","import { createContext } from \"react\";\n\nimport type { ParsedRoute } from \"@/types.js\";\n\nexport interface RootRouteContextType extends ParsedRoute {\n getRouteState: (id: string, key: string) => any;\n setRouteState: (id: string, key: string, value: any) => void;\n}\n\nexport const RootRouteContext = createContext<RootRouteContextType | null>(\n null\n);\n","import { RouteContext } from \"@/context/route-context.js\";\nimport { useRootRoute } from \"@/hooks/useRootRoute.js\";\nimport type { ParsedRoute } from \"@/types.js\";\nimport { useCallback } from \"react\";\n\nexport const RouteProvider = ({\n route,\n ...props\n}: {\n route?: ParsedRoute;\n children?: React.ReactNode;\n}) => {\n if (!route) {\n return <RouteContext.Provider value={null} {...props} />;\n }\n\n const rootRoute = useRootRoute();\n\n const getState = useCallback(\n (key: string) => {\n return rootRoute.getRouteState(route.id, key);\n },\n [rootRoute.getRouteState]\n );\n\n const setState = useCallback(\n (key: string, value: any) => {\n rootRoute.setRouteState(route.id, key, value);\n },\n [rootRoute.setRouteState]\n );\n\n return (\n <RouteContext.Provider\n value={{ ...route, getState, setState }}\n {...props}\n />\n );\n};\n","import { useOutlet } from \"@/hooks/useOutlet.js\";\nimport { useRouteMatch } from \"@/hooks/useRouteMatch.js\";\nimport { OutletProvider } from \"./outlet-provider.js\";\nimport { RouteComponent } from \"./route-component.js\";\nimport { RouteProvider } from \"./route-provider.js\";\n\nexport const Outlet = () => {\n const routeMatch = useRouteMatch();\n const depth = useOutlet() + 1;\n return (\n <OutletProvider depth={depth}>\n <RouteProvider route={routeMatch.matches.at(depth)}>\n <RouteComponent depth={depth} />\n </RouteProvider>\n </OutletProvider>\n );\n};\n","import { useCallback, useEffect, useState } from \"react\";\n\nimport { RouterContext } from \"@/context/router-context.js\";\nimport type {\n BackOptions,\n ForwardOptions,\n Location,\n NavigateOptions,\n RouterOptions,\n} from \"@/types.js\";\nimport { parseLocation } from \"@/utils.js\";\nimport { LocationProvider } from \"./location-provider.js\";\n\nexport const RouterProvider = ({\n options,\n ...props\n}: {\n options: RouterOptions;\n children: React.ReactNode;\n}) => {\n const [history, setHistory] = useState<Location[]>([\n parseLocation(window.location),\n ]);\n const [currentLocationIndex, setCurrentLocationIndex] = useState<number>(0);\n const location = history.at(currentLocationIndex)!;\n const [isTransitioning, setIsTransitioning] = useState<boolean>(false);\n const [transitionDuration, setTransitionDuration] = useState<number>(0);\n const [transitioningToLocation, setTransitioningToLocation] =\n useState<Location>();\n\n useEffect(() => {\n window.history.replaceState(history[0].state, \"\", history[0].pathname);\n const handlePopState = ({ state }: PopStateEvent) => {\n setCurrentLocationIndex(state?.index ?? 0);\n };\n\n addEventListener(\"popstate\", handlePopState);\n return () => {\n removeEventListener(\"popstate\", handlePopState);\n };\n }, []);\n\n const transitionTo = (\n location: Location,\n duration: number = options.defaultTransitionDuration,\n callback?: () => void\n ) => {\n setIsTransitioning(true);\n setTransitionDuration(duration);\n setTransitioningToLocation(location);\n setTimeout(() => {\n setIsTransitioning(false);\n setTransitioningToLocation(undefined);\n // TODO: May can be deleted\n setCurrentLocationIndex(location.index);\n callback?.();\n }, duration);\n };\n\n // Update location state\n const setLocationState = useCallback(\n (index: number, state: Record<string, any>) => {\n setHistory((prevHistory) =>\n prevHistory.map((location) =>\n location.index === index ? { ...location, state } : location\n )\n );\n if (index === currentLocationIndex) {\n window.history.replaceState(state, \"\", location.pathname);\n }\n },\n [currentLocationIndex]\n );\n\n const navigate = useCallback(\n ({\n to,\n replace,\n transition,\n duration,\n onFinish,\n ...locationOptions\n }: NavigateOptions) => {\n if (isTransitioning) return;\n\n const index = replace ? currentLocationIndex : currentLocationIndex + 1;\n\n // Resolve to with absolute or relative paths like \"..\" or \".\"\n // TODO: Wrap into a utility function\n let pathname: string;\n if (to.startsWith(\"/\")) {\n pathname = to;\n } else {\n const currentPathSegments = location.pathname\n .split(\"/\")\n .filter((seg) => seg.length > 0);\n const toPathSegments = to.split(\"/\").filter((seg) => seg.length > 0);\n for (const segment of toPathSegments) {\n if (segment === \".\") {\n continue;\n } else if (segment === \"..\") {\n currentPathSegments.pop();\n } else {\n currentPathSegments.push(segment);\n }\n }\n pathname = \"/\" + currentPathSegments.join(\"/\");\n }\n const state = {\n index,\n };\n const newLocation = {\n index,\n search: {},\n state,\n pathname,\n ...locationOptions,\n };\n\n const updateHistory = () => {\n if (replace) {\n setHistory((prevHistory) => [\n ...prevHistory.slice(0, index),\n newLocation,\n ...prevHistory.slice(index + 1),\n ]);\n window.history.replaceState(state, \"\", pathname);\n } else {\n setHistory((prevHistory) => [\n ...prevHistory.slice(0, index),\n newLocation,\n ]);\n setCurrentLocationIndex(index);\n window.history.pushState(state, \"\", pathname);\n }\n onFinish?.();\n };\n\n if (transition ?? options.defaultUseTransition?.(location, newLocation)) {\n transitionTo(newLocation, duration, updateHistory);\n } else {\n updateHistory();\n }\n },\n [currentLocationIndex, history, isTransitioning, options]\n );\n\n const back = useCallback(\n ({ transition, duration, onFinish, depth }: BackOptions = {}) => {\n if (currentLocationIndex === 0 || isTransitioning) return;\n const backDepth = depth ?? 1;\n const newLocation = history.at(currentLocationIndex - backDepth);\n\n const updateHistory = () => {\n window.history.go(-backDepth);\n onFinish?.();\n };\n\n if (\n newLocation &&\n (transition ?? options.defaultUseTransition?.(location, newLocation))\n ) {\n transitionTo(newLocation, duration, updateHistory);\n } else {\n updateHistory();\n }\n },\n [currentLocationIndex, history, isTransitioning, options]\n );\n\n const forward = useCallback(\n ({ transition, duration, depth, onFinish }: ForwardOptions = {}) => {\n if (currentLocationIndex + 1 >= history.length || isTransitioning) return;\n const forwardDepth = depth ?? 1;\n const newLocation = history.at(currentLocationIndex + forwardDepth);\n\n const updateHistory = () => {\n window.history.go(forwardDepth);\n onFinish?.();\n };\n\n if (\n newLocation &&\n (transition ?? options.defaultUseTransition?.(location, newLocation))\n ) {\n transitionTo(newLocation, duration, updateHistory);\n } else {\n updateHistory();\n }\n },\n [currentLocationIndex, history, isTransitioning, options]\n );\n\n return (\n <RouterContext.Provider\n value={{\n options,\n\n history,\n location,\n canGoBack: currentLocationIndex > 0,\n canGoForward: currentLocationIndex < history.length - 1,\n\n isTransitioning,\n transitionDuration,\n transitioningToLocation,\n\n navigate,\n back,\n forward,\n\n setLocationState,\n }}\n >\n <LocationProvider location={location} {...props} />\n </RouterContext.Provider>\n );\n};\n","import type { RouterOptions } from \"./types.js\";\n\nexport const DefaultRouterOptions: RouterOptions = {\n defaultTransitionDuration: 300,\n};\n","import { DefaultRouterOptions } from \"./constants.js\";\nimport type {\n Location,\n ParsedRoute,\n Route,\n RouteMatch,\n RouterOptions,\n} from \"./types.js\";\n\nexport const DefaultTransitionDuration = 300;\n\nexport const redirect = (options: { to: string; replace?: boolean }) => {\n return new Error(\"\", { cause: options });\n};\n\n/**\n * @param pattern pathname pattern like `/users/:id`. Leading and trailing slashes are optional.\n * @param url URL to match against the pattern. Can be href or pathname with query string.\n * @returns extracted params and query if matched, otherwise null\n */\nexport const matchPattern = (\n pattern: string,\n url: string\n): { params: Record<string, string>; query: Record<string, string> } | null => {\n try {\n // 解析 URL\n let pathname, searchParams;\n\n if (url.startsWith(\"http://\") || url.startsWith(\"https://\")) {\n const urlObj = new URL(url);\n pathname = urlObj.pathname;\n searchParams = urlObj.searchParams;\n } else {\n // 處理相對路徑\n const [path, queryString] = url.split(\"?\");\n if (!path) {\n return null;\n }\n pathname = path;\n searchParams = new URLSearchParams(queryString || \"\");\n }\n\n // 移除路徑首尾的斜線以便比較\n const cleanPath = pathname.replaceAll(/^\\/|\\/$/g, \"\");\n const cleanPattern = pattern.replaceAll(/^\\/|\\/$/g, \"\");\n\n // 分割路徑段\n const pathSegments = cleanPath.split(\"/\");\n const patternSegments = cleanPattern.split(\"/\");\n\n // 路徑段數量不同則不匹配\n if (pathSegments.length !== patternSegments.length) {\n return null;\n }\n\n // 提取路徑參數\n const params: Record<string, string> = {};\n for (let i = 0; i < patternSegments.length; i++) {\n const patternSegment = patternSegments[i];\n const pathSegment = pathSegments[i];\n\n if (patternSegment.startsWith(\":\")) {\n // 動態參數\n const paramName = patternSegment.slice(1);\n params[paramName] = decodeURIComponent(pathSegment);\n } else if (patternSegment !== pathSegment) {\n // 靜態段不匹配\n return null;\n }\n }\n\n // 提取查詢參數\n const query = Object.fromEntries(searchParams.entries());\n\n return { params, query };\n } catch {\n return null;\n }\n};\n\nexport const matchRoute = (route: ParsedRoute, url: string): RouteMatch => {\n const _matchRoute = (\n matches: ParsedRoute[],\n { children }: ParsedRoute\n ): RouteMatch | null => {\n if (children && children.length > 0) {\n for (const childRoute of children) {\n const matchesResult = _matchRoute([...matches, childRoute], childRoute);\n if (matchesResult) {\n return matchesResult;\n }\n }\n return null;\n }\n\n const result = matchPattern(buildPathnameFromMatches(matches), url);\n return result ? { matches, ...result } : null;\n };\n\n return (\n _matchRoute([route], route) || {\n matches: [],\n params: {},\n query: {},\n }\n );\n};\n\nexport const buildPathnameFromMatches = (matches: Route[]): string => {\n let cleanedPathnames: string[] = []; // pathnames without leading/trailing slashes\n for (const match of matches) {\n if (match.pathname === undefined) continue;\n cleanedPathnames.push(match.pathname.replaceAll(/^\\/|\\/$/g, \"\"));\n }\n return \"/\" + cleanedPathnames.join(\"/\");\n};\n\nexport const parseLocation = (location: globalThis.Location): Location => ({\n index: 0,\n state: {\n index: 0,\n },\n pathname: location.pathname,\n search: Object.fromEntries(new URLSearchParams(location.search)),\n});\n\nexport const createRouterOptions = (\n options?: Partial<RouterOptions>\n): RouterOptions => ({\n ...DefaultRouterOptions,\n ...options,\n});\n\nexport const parseRoute = (route: Route): ParsedRoute => {\n const parseRouteRecursive = (route: Route, parentId: string): ParsedRoute => {\n const id =\n route.name ??\n (route.pathname\n ? `${parentId}/${route.pathname.replaceAll(/^\\/|\\/$/g, \"\")}`\n : parentId);\n\n const parsedRoute: ParsedRoute = {\n ...route,\n id,\n children: route.children?.map((child) => parseRouteRecursive(child, id)),\n };\n\n return parsedRoute;\n };\n return parseRouteRecursive(route, \"\");\n};\n","import { useEffect, useState } from \"react\";\n\nimport { useRouter } from \"@/hooks/useRouter.js\";\nimport type { Route } from \"@/types.js\";\n\nimport { LocationProvider } from \"./location-provider.js\";\nimport { PageRenderer } from \"./page-renderer.js\";\nimport { RootRouteProvider } from \"./root-route-provider.js\";\n\nconst StackComponent = () => {\n const {\n history,\n location,\n canGoBack,\n canGoForward,\n isTransitioning,\n transitioningToLocation,\n transitionDuration,\n back,\n forward,\n } = useRouter();\n const currentLocationIndex = location?.index;\n const transitioningToLocationIndex = transitioningToLocation?.index;\n\n const [isDragging, setIsDragging] = useState(false);\n const [startX, setStartX] = useState(0);\n const [dragOffset, setDragOffset] = useState(0);\n const [isCanceling, setIsCanceling] = useState(false);\n const [isTransitionStarted, setIsTransitionStarted] = useState(false);\n\n useEffect(() => {\n if (!isTransitioning || !transitioningToLocation) return;\n setIsTransitionStarted(true);\n setTimeout(() => {\n setIsTransitionStarted(false);\n }, transitionDuration);\n }, [isTransitioning, transitioningToLocation]);\n\n if (currentLocationIndex === undefined) return;\n\n const reset = () => {\n setIsDragging(false);\n setDragOffset(0);\n setIsCanceling(false);\n };\n\n const handleTouchStart = (e: React.TouchEvent) => {\n if (isTransitioning || (!canGoForward && !canGoBack)) return;\n setIsDragging(true);\n setStartX(e.touches[0].clientX);\n };\n\n const handleTouchMove = (e: React.TouchEvent) => {\n if (!isDragging) return;\n const offset = e.touches[0].clientX - startX;\n if (\n (offset > 0 && currentLocationIndex === 0) ||\n (offset < 0 && currentLocationIndex + 1 === history.length)\n ) {\n setDragOffset(0);\n return;\n }\n setDragOffset(Math.min(innerWidth, offset));\n };\n\n const handleTouchEnd = () => {\n if (!isDragging) return;\n\n if (dragOffset > innerWidth * 0.3 && canGoBack) {\n back({\n onFinish: reset,\n });\n } else if (dragOffset < -innerWidth * 0.3 && canGoForward) {\n forward({\n onFinish: reset,\n });\n } else {\n setIsCanceling(true);\n setTimeout(reset, transitionDuration);\n }\n };\n\n return (\n <div\n style={{\n position: \"relative\",\n inset: 0,\n height: \"100%\",\n width: \"100%\",\n overflow: \"hidden\",\n }}\n >\n {currentLocationIndex >= 1 &&\n ((isDragging && dragOffset > 0) ||\n (isTransitioning &&\n transitioningToLocation &&\n transitioningToLocation.index < currentLocationIndex)) && (\n <div\n style={{\n position: \"absolute\",\n inset: 0,\n zIndex: -10,\n }}\n >\n <LocationProvider location={history.at(currentLocationIndex - 1)!}>\n <PageRenderer key={currentLocationIndex - 1} />\n </LocationProvider>\n </div>\n )}\n <div\n key={currentLocationIndex}\n style={{\n background: \"white\",\n position: \"absolute\",\n inset: 0,\n overflow: \"hidden\",\n transform:\n isTransitioning &&\n transitioningToLocation &&\n transitioningToLocation.index < currentLocationIndex\n ? `translateX(100%)`\n : isDragging && dragOffset > 0 && !isCanceling\n ? `translateX(${dragOffset}px)`\n : \"translateX(0px)\",\n transition:\n isCanceling ||\n (isTransitioning &&\n transitioningToLocation &&\n transitioningToLocation.index < currentLocationIndex)\n ? `transform ${transitionDuration}ms ease-out`\n : \"\",\n boxShadow:\n isDragging && dragOffset > 0\n ? \"-4px 0 8px rgba(0,0,0,0.1)\"\n : \"none\",\n }}\n onTouchStart={handleTouchStart}\n onTouchMove={handleTouchMove}\n onTouchEnd={handleTouchEnd}\n >\n <PageRenderer />\n </div>\n {((isDragging && dragOffset < 0) ||\n (isTransitioning &&\n transitioningToLocation &&\n currentLocationIndex <= transitioningToLocation.index)) && (\n <div\n style={{\n background: \"white\",\n position: \"absolute\",\n inset: 0,\n zIndex: 10,\n overflow: \"hidden\",\n transition: \"transform ease-in\",\n transform: isTransitionStarted\n ? `translateX(0px)`\n : isTransitioning\n ? \"translateX(100%)\"\n : `translateX(${innerWidth + dragOffset}px)`,\n transitionDuration:\n isTransitioning || isCanceling\n ? `${transitionDuration}ms`\n : \"0ms\",\n }}\n >\n <LocationProvider\n location={\n isTransitioning\n ? transitioningToLocation!\n : history.at(currentLocationIndex + 1)!\n }\n >\n <PageRenderer key={transitioningToLocationIndex} />\n </LocationProvider>\n </div>\n )}\n </div>\n );\n};\n\nexport const Stack = ({ rootRoute }: { rootRoute: Route }) => (\n <RootRouteProvider rootRoute={rootRoute}>\n <StackComponent />\n </RootRouteProvider>\n);\n","import { RouteMatchContext } from \"@/context/route-match-context.js\";\nimport { useLocation } from \"@/hooks/useLocation.js\";\nimport { useRootRoute } from \"@/hooks/useRootRoute.js\";\nimport { matchRoute } from \"@/utils.js\";\nimport { RouteComponent } from \"./route-component.js\";\nimport { RouteProvider } from \"./route-provider.js\";\n\nexport const PageRenderer = () => {\n const rootRoute = useRootRoute();\n const location = useLocation();\n const routeMatch = matchRoute(rootRoute, location.pathname);\n return (\n <RouteMatchContext.Provider value={routeMatch}>\n <RouteProvider route={rootRoute}>\n <RouteComponent />\n </RouteProvider>\n </RouteMatchContext.Provider>\n );\n};\n","import { RootRouteContext } from \"@/context/root-route-context.js\";\nimport type { Route } from \"@/types.js\";\nimport { parseRoute } from \"@/utils.js\";\nimport { useCallback, useState } from \"react\";\n\nexport const RootRouteProvider = ({\n rootRoute,\n ...props\n}: {\n rootRoute: Route;\n children: React.ReactNode;\n}) => {\n const parsedRoute = parseRoute(rootRoute);\n const [state, setState] = useState<Record<string, Record<string, any>>>({});\n\n const getRouteState = useCallback(\n (id: string, key: string) => {\n return state[id]?.[key];\n },\n [state]\n );\n\n const setRouteState = useCallback((id: string, key: string, value: any) => {\n setState((prevState) => ({\n ...prevState,\n [id]: {\n ...prevState[id],\n [key]: value,\n },\n }));\n }, []);\n\n return (\n <RootRouteContext.Provider\n value={{ ...parsedRoute, getRouteState, setRouteState }}\n {...props}\n />\n );\n};\n"],"mappings":"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","names":["useContext","createContext","RouterContext","useRouter","router","useContext","RouterContext","jsx","Link","to","replace","transition","duration","onFinish","props","router","useRouter","e","createContext","LocationContext","useCallback","jsx","LocationProvider","location","props","router","useRouter","getState","key","setState","value","deleteState","LocationContext","createContext","OutletContext","useContext","useOutlet","OutletContext","createContext","RouteMatchContext","useContext","useRouteMatch","routeMatch","RouteMatchContext","jsx","OutletProvider","depth","props","OutletContext","useContext","useLocation","context","useContext","LocationContext","createContext","RouteContext","useContext","useRoute","route","RouteContext","useEffect","useState","jsx","RouteComponent","depth","router","useRouter","location","useLocation","routeMatch","useRouteMatch","route","useRoute","pendingStateKey","pending","setPending","useState","useEffect","cause","NotFoundComponent","PendingComponent","Component","Outlet","useContext","createContext","RootRouteContext","useRootRoute","route","useContext","RootRouteContext","useCallback","jsx","RouteProvider","route","props","RouteContext","rootRoute","useRootRoute","getState","key","setState","value","jsx","Outlet","routeMatch","useRouteMatch","depth","useOutlet","OutletProvider","RouteProvider","RouteComponent","useCallback","useEffect","useState","DefaultRouterOptions","DefaultTransitionDuration","redirect","options","matchPattern","pattern","url","pathname","searchParams","urlObj","path","queryString","cleanPath","cleanPattern","pathSegments","patternSegments","params","i","patternSegment","pathSegment","paramName","query","matchRoute","route","_matchRoute","matches","children","childRoute","matchesResult","result","buildPathnameFromMatches","cleanedPathnames","match","parseLocation","location","createRouterOptions","DefaultRouterOptions","parseRoute","parseRouteRecursive","parentId","id","child","jsx","RouterProvider","options","props","history","setHistory","useState","parseLocation","currentLocationIndex","setCurrentLocationIndex","location","isTransitioning","setIsTransitioning","transitionDuration","setTransitionDuration","transitioningToLocation","setTransitioningToLocation","useEffect","handlePopState","state","transitionTo","duration","callback","setLocationState","useCallback","index","prevHistory","navigate","to","replace","transition","onFinish","locationOptions","pathname","currentPathSegments","seg","toPathSegments","segment","newLocation","updateHistory","back","depth","backDepth","forward","forwardDepth","RouterContext","LocationProvider","useEffect","useState","jsx","PageRenderer","rootRoute","useRootRoute","location","useLocation","routeMatch","matchRoute","RouteMatchContext","RouteProvider","RouteComponent","useCallback","useState","jsx","RootRouteProvider","rootRoute","props","parsedRoute","parseRoute","state","setState","getRouteState","id","key","setRouteState","value","prevState","RootRouteContext","jsx","jsxs","StackComponent","history","location","canGoBack","canGoForward","isTransitioning","transitioningToLocation","transitionDuration","back","forward","useRouter","currentLocationIndex","transitioningToLocationIndex","isDragging","setIsDragging","useState","startX","setStartX","dragOffset","setDragOffset","isCanceling","setIsCanceling","isTransitionStarted","setIsTransitionStarted","useEffect","reset","handleTouchStart","e","handleTouchMove","offset","handleTouchEnd","LocationProvider","PageRenderer","Stack","rootRoute","RootRouteProvider"]}
|
|
1
|
+
{"version":3,"sources":["../src/hooks/useRouter.ts","../src/context/router-context.ts","../src/components/link.tsx","../src/context/location-context.ts","../src/components/location-provider.tsx","../src/context/outlet-context.ts","../src/hooks/useOutlet.ts","../src/context/route-match-context.ts","../src/hooks/useRouteMatch.ts","../src/components/outlet-provider.tsx","../src/hooks/useLocation.ts","../src/context/route-context.ts","../src/hooks/useRoute.ts","../src/components/route-component.tsx","../src/hooks/useRootRoute.ts","../src/context/root-route-context.ts","../src/components/route-provider.tsx","../src/components/outlet.tsx","../src/components/router-provider.tsx","../src/constants.ts","../src/utils.ts","../src/components/stack.tsx","../src/components/page-renderer.tsx","../src/components/root-route-provider.tsx"],"sourcesContent":["import { useContext } from \"react\";\n\nimport { RouterContext } from \"@/context/router-context.js\";\n\nexport const useRouter = () => {\n const router = useContext(RouterContext);\n if (router === null) {\n throw new Error(\"useRouter must be used within a Stack\");\n }\n return router;\n};\n","import { createContext } from \"react\";\n\nimport type {\n BackActionOptions,\n ForwardActionOptions,\n Location,\n NavigateActionOptions,\n NavigationOptions,\n RouterOptions,\n} from \"@/types.js\";\n\nexport interface RouterContextType {\n // Router Config\n options: RouterOptions;\n\n // Navigation State\n history: Location[];\n location: Location;\n canGoBack: boolean;\n canGoForward: boolean;\n\n // Transition state\n isTransitioning: boolean;\n transitionDuration: number;\n transitioningToLocation?: Location;\n\n // Utilities\n buildLocation: (to: NavigationOptions) => Location;\n\n // Navigation Actions\n navigate: (options: NavigateActionOptions) => void;\n back: (options?: BackActionOptions) => void;\n forward: (options?: ForwardActionOptions) => void;\n\n // Low-level state action\n setLocationState: (index: number, state: Record<string, any>) => void;\n}\n\nexport const RouterContext = createContext<RouterContextType | null>(null);\n","import { useRouter } from \"@/hooks/useRouter.js\";\nimport type { NavigateActionOptions } from \"@/types.js\";\nimport { memo } from \"react\";\n\nexport type LinkProps = React.ComponentPropsWithoutRef<\"a\"> &\n NavigateActionOptions;\n\nexport const Link: React.FC<LinkProps> = memo(\n ({ to, replace, transition, duration, onFinish, ...props }) => {\n const router = useRouter();\n return (\n <a\n {...props}\n href={to}\n onClick={(e) => {\n e.preventDefault();\n router.navigate({ to, replace, transition, duration, onFinish });\n }}\n />\n );\n }\n);\n","import { createContext } from \"react\";\n\nimport type { Location } from \"@/types.js\";\n\nexport interface LocationContextType extends Location {\n canGoBack: boolean;\n canGoForward: boolean;\n getState: (key: string) => any;\n setState: (key: string, value: any) => void;\n deleteState: (key: string) => void;\n}\n\nexport const LocationContext = createContext<LocationContextType | null>(null);\n","import { LocationContext } from \"@/context/location-context.js\";\nimport { useRouter } from \"@/hooks/useRouter.js\";\nimport type { Location } from \"@/types.js\";\nimport { memo, useCallback } from \"react\";\n\nexport const LocationProvider = memo(\n ({\n location,\n ...props\n }: {\n location: Location;\n children: React.ReactNode;\n }) => {\n const router = useRouter();\n const getState = useCallback(\n (key: string) => {\n return location.state[key];\n },\n [location]\n );\n const setState = useCallback(\n (key: string, value: any) => {\n router.setLocationState(location.index, {\n ...location.state,\n [key]: value,\n });\n },\n [router, location]\n );\n const deleteState = useCallback(\n (key: string) => {\n delete location.state[key];\n router.setLocationState(location.index, location.state);\n },\n [router, location]\n );\n return (\n <LocationContext.Provider\n value={{\n ...location,\n canGoBack: location.index > 0,\n canGoForward: location.index < router.history.length - 1,\n getState,\n setState,\n deleteState,\n }}\n {...props}\n />\n );\n },\n (a, b) => a.location === b.location\n);\n","import { createContext } from \"react\";\n\nexport const OutletContext = createContext<number>(0);\n","import { OutletContext } from \"@/context/outlet-context.js\";\nimport { useContext } from \"react\";\n\nexport const useOutlet = () => useContext(OutletContext);\n","import type { RouteMatch } from \"@/types.js\";\nimport { createContext } from \"react\";\n\nexport const RouteMatchContext = createContext<RouteMatch | null>(null);\n","import { RouteMatchContext } from \"@/context/route-match-context.js\";\nimport { useContext } from \"react\";\n\nexport const useRouteMatch = () => {\n const routeMatch = useContext(RouteMatchContext);\n if (routeMatch === null) {\n throw new Error(\"useRouteMatch must be used within a RouteMatchProvider\");\n }\n return routeMatch;\n};\n","import { OutletContext } from \"@/context/outlet-context.js\";\n\nexport const OutletProvider = ({\n depth,\n ...props\n}: {\n depth: number;\n children?: React.ReactNode;\n}) => <OutletContext.Provider value={depth} {...props} />;\n","import { useContext } from \"react\";\n\nimport { LocationContext } from \"@/context/location-context.js\";\n\nexport const useLocation = () => {\n const context = useContext(LocationContext);\n if (context === null) {\n throw new Error(\"useLocation must be used within a LocationProvider\");\n }\n return context;\n};\n","import type { ParsedRoute } from \"@/types.js\";\nimport { createContext } from \"react\";\n\nexport interface RouteContextType extends ParsedRoute {\n state: Record<string, any>;\n getState: (key: string) => any;\n setState: (key: string, value: any) => void;\n}\n\nexport const RouteContext = createContext<RouteContextType | null>(null);\n","import { RouteContext } from \"@/context/route-context.js\";\nimport { useContext } from \"react\";\n\nexport const useRoute = () => {\n const route = useContext(RouteContext);\n if (route === null) {\n throw new Error(\"useRoute must be used within a RouteProvider\");\n }\n return route;\n};\n","import { useLocation } from \"@/hooks/useLocation.js\";\nimport { useRoute } from \"@/hooks/useRoute.js\";\nimport { useRouteMatch } from \"@/hooks/useRouteMatch.js\";\nimport { useRouter } from \"@/hooks/useRouter.js\";\nimport { useEffect, useState } from \"react\";\nimport { Outlet } from \"./outlet.js\";\n\nexport const RouteComponent = ({ depth = 0 }: { depth?: number }) => {\n const router = useRouter();\n const location = useLocation();\n const routeMatch = useRouteMatch();\n const route = useRoute();\n\n const pendingStateKey = `_Z.${route.id}.pending`;\n\n const [pending, setPending] = useState(\n !!route?.beforeLoad && route?.getState(pendingStateKey) !== false\n );\n\n useEffect(() => {\n if (!route || depth >= routeMatch.matches.length) {\n return;\n }\n if (\n pending &&\n route?.beforeLoad &&\n route.getState(pendingStateKey) !== true\n ) {\n route.setState(pendingStateKey, true);\n route\n .beforeLoad({ location })\n .catch(({ cause }: Error) => {\n if (\"to\" in (cause as any)) {\n router.navigate(cause as any);\n }\n })\n .finally(() => {\n route.setState(pendingStateKey, false);\n setPending(false);\n });\n }\n }, [route]);\n\n if (!route) {\n return null;\n }\n\n if (depth >= routeMatch.matches.length) {\n const NotFoundComponent = route.notFoundComponent!;\n return <NotFoundComponent />;\n }\n\n if (pending) {\n const PendingComponent = route.pendingComponent!;\n return <PendingComponent />;\n }\n\n const Component = route.component;\n return Component ? <Component /> : <Outlet />;\n};\n","import { useContext } from \"react\";\n\nimport { RootRouteContext } from \"@/context/root-route-context.js\";\n\nexport const useRootRoute = () => {\n const route = useContext(RootRouteContext);\n if (route === null) {\n throw new Error(\"useRootRoute must be used within a RootRouteProvider\");\n }\n return route;\n};\n","import { createContext } from \"react\";\n\nimport type { ParsedRoute } from \"@/types.js\";\n\nexport interface RootRouteContextType extends ParsedRoute {\n state: Record<string, Record<string, any>>;\n getRouteState: (id: string, key: string) => any;\n setRouteState: (id: string, key: string, value: any) => void;\n}\n\nexport const RootRouteContext = createContext<RootRouteContextType | null>(\n null\n);\n","import { RouteContext } from \"@/context/route-context.js\";\nimport { useRootRoute } from \"@/hooks/useRootRoute.js\";\nimport type { ParsedRoute } from \"@/types.js\";\nimport { useCallback } from \"react\";\n\nexport const RouteProvider = ({\n route,\n ...props\n}: {\n route?: ParsedRoute;\n children?: React.ReactNode;\n}) => {\n if (!route) {\n return <RouteContext.Provider value={null} {...props} />;\n }\n\n const { state, getRouteState, setRouteState } = useRootRoute();\n\n const getState = useCallback(\n (key: string) => getRouteState(route.id, key),\n [getRouteState, route.id]\n );\n\n const setState = useCallback(\n (key: string, value: any) => {\n setRouteState(route.id, key, value);\n },\n [setRouteState, route.id]\n );\n\n return (\n <RouteContext.Provider\n value={{ ...route, state: state[route.id], getState, setState }}\n {...props}\n />\n );\n};\n","import { useOutlet } from \"@/hooks/useOutlet.js\";\nimport { useRouteMatch } from \"@/hooks/useRouteMatch.js\";\nimport { OutletProvider } from \"./outlet-provider.js\";\nimport { RouteComponent } from \"./route-component.js\";\nimport { RouteProvider } from \"./route-provider.js\";\n\nexport const Outlet = () => {\n const routeMatch = useRouteMatch();\n const depth = useOutlet() + 1;\n return (\n <OutletProvider depth={depth}>\n <RouteProvider route={routeMatch.matches.at(depth)}>\n <RouteComponent depth={depth} />\n </RouteProvider>\n </OutletProvider>\n );\n};\n","import { useCallback, useEffect, useState } from \"react\";\n\nimport { RouterContext } from \"@/context/router-context.js\";\nimport type {\n BackActionOptions,\n ForwardActionOptions,\n Location,\n NavigateActionOptions,\n NavigationOptions,\n RouterOptions,\n} from \"@/types.js\";\nimport { parseLocation, resolveRelativePathname } from \"@/utils.js\";\nimport { LocationProvider } from \"./location-provider.js\";\n\nexport const RouterProvider = ({\n options,\n ...props\n}: {\n options: RouterOptions;\n children: React.ReactNode;\n}) => {\n const [history, setHistory] = useState<Location[]>([\n parseLocation(window.location),\n ]);\n const [currentLocationIndex, setCurrentLocationIndex] = useState<number>(0);\n const location = history.at(currentLocationIndex)!;\n const [isTransitioning, setIsTransitioning] = useState<boolean>(false);\n const [transitionDuration, setTransitionDuration] = useState<number>(0);\n const [transitioningToLocation, setTransitioningToLocation] =\n useState<Location>();\n\n useEffect(() => {\n window.history.replaceState(location.state, \"\", location.pathname);\n }, []);\n\n useEffect(() => {\n const handlePopState = ({ state }: PopStateEvent) => {\n setCurrentLocationIndex(state?.index);\n };\n\n addEventListener(\"popstate\", handlePopState);\n return () => {\n removeEventListener(\"popstate\", handlePopState);\n };\n }, [currentLocationIndex]);\n\n // Utilities\n const buildLocation = useCallback(\n ({ to, replace }: NavigationOptions): Location => {\n if (!to) return location;\n const index = replace ? currentLocationIndex : currentLocationIndex + 1;\n\n // Resolve to with absolute or relative paths like \"..\" or \".\"\n const pathname = to.startsWith(\"/\")\n ? to\n : resolveRelativePathname(location.pathname, to);\n const state = {\n index,\n };\n return {\n index,\n href: origin + pathname,\n search: {},\n state,\n pathname,\n };\n },\n [currentLocationIndex, location]\n );\n\n // Transition helper\n const transitionTo = (\n location: Location,\n duration: number = options.defaultTransitionDuration,\n callback?: () => void\n ) => {\n setIsTransitioning(true);\n setTransitionDuration(duration);\n setTransitioningToLocation(location);\n setTimeout(() => {\n setIsTransitioning(false);\n setTransitioningToLocation(undefined);\n callback?.();\n }, duration);\n };\n\n // Navigation actions\n const navigate = useCallback(\n ({\n to,\n replace,\n transition,\n duration,\n onFinish,\n }: NavigateActionOptions) => {\n if (isTransitioning) return;\n\n const index = replace ? currentLocationIndex : currentLocationIndex + 1;\n const newLocation = buildLocation({ to, replace });\n\n const updateHistory = () => {\n if (replace) {\n setHistory((prevHistory) => [\n ...prevHistory.slice(0, index),\n newLocation,\n ...prevHistory.slice(index + 1),\n ]);\n window.history.replaceState(\n newLocation.state,\n \"\",\n newLocation.pathname\n );\n } else {\n setHistory((prevHistory) => [\n ...prevHistory.slice(0, index),\n newLocation,\n ]);\n setCurrentLocationIndex(index);\n window.history.pushState(newLocation.state, \"\", newLocation.pathname);\n }\n onFinish?.();\n };\n\n if (transition ?? options.defaultUseTransition?.(location, newLocation)) {\n transitionTo(newLocation, duration, updateHistory);\n } else {\n updateHistory();\n }\n },\n [currentLocationIndex, history, isTransitioning, options]\n );\n\n const back = useCallback(\n ({ transition, duration, onFinish, depth }: BackActionOptions = {}) => {\n if (currentLocationIndex === 0 || isTransitioning) return;\n const backDepth = depth ?? 1;\n const newLocation = history.at(currentLocationIndex - backDepth);\n\n const updateHistory = () => {\n window.history.go(-backDepth);\n onFinish?.();\n };\n\n if (\n newLocation &&\n (transition ?? options.defaultUseTransition?.(location, newLocation))\n ) {\n transitionTo(newLocation, duration, updateHistory);\n } else {\n updateHistory();\n }\n },\n [currentLocationIndex, history, isTransitioning, options]\n );\n\n const forward = useCallback(\n ({ transition, duration, depth, onFinish }: ForwardActionOptions = {}) => {\n if (currentLocationIndex + 1 >= history.length || isTransitioning) return;\n const forwardDepth = depth ?? 1;\n const newLocation = history.at(currentLocationIndex + forwardDepth);\n\n const updateHistory = () => {\n window.history.go(forwardDepth);\n onFinish?.();\n };\n\n if (\n newLocation &&\n (transition ?? options.defaultUseTransition?.(location, newLocation))\n ) {\n transitionTo(newLocation, duration, updateHistory);\n } else {\n updateHistory();\n }\n },\n [currentLocationIndex, history, isTransitioning, options]\n );\n\n // Low-level state action\n const setLocationState = useCallback(\n (index: number, state: Record<string, any>) => {\n setHistory((prevHistory) =>\n prevHistory.map((location) =>\n location.index === index ? { ...location, state } : location\n )\n );\n if (index === currentLocationIndex) {\n window.history.replaceState(state, \"\", location.pathname);\n }\n },\n [currentLocationIndex]\n );\n\n return (\n <RouterContext.Provider\n // oxlint-disable-next-line jsx-no-new-object-as-prop\n value={{\n options,\n\n history,\n location,\n canGoBack: currentLocationIndex > 0,\n canGoForward: currentLocationIndex < history.length - 1,\n\n isTransitioning,\n transitionDuration,\n transitioningToLocation,\n\n buildLocation,\n\n navigate,\n back,\n forward,\n\n setLocationState,\n }}\n >\n <LocationProvider location={location} {...props} />\n </RouterContext.Provider>\n );\n};\n","import type { RouterOptions } from \"./types.js\";\n\nexport const DefaultRouterOptions: RouterOptions = {\n defaultTransitionDuration: 300,\n};\n","import { DefaultRouterOptions } from \"./constants.js\";\nimport type {\n Location,\n ParsedRoute,\n Route,\n RouteMatch,\n RouterOptions,\n} from \"./types.js\";\n\nexport const DefaultTransitionDuration = 300;\n\nexport const redirect = (options: { to: string; replace?: boolean }) => {\n return new Error(\"\", { cause: options });\n};\n\n/**\n * @param pattern pathname pattern like `/users/:id`. Leading and trailing slashes are optional.\n * @param url URL to match against the pattern. Can be href or pathname with query string.\n * @returns extracted params and query if matched, otherwise null\n */\nexport const matchPattern = (\n pattern: string,\n url: string\n): { params: Record<string, string>; query: Record<string, string> } | null => {\n try {\n // 解析 URL\n let pathname, searchParams;\n\n if (url.startsWith(\"http://\") || url.startsWith(\"https://\")) {\n const urlObj = new URL(url);\n pathname = urlObj.pathname;\n searchParams = urlObj.searchParams;\n } else {\n // 處理相對路徑\n const [path, queryString] = url.split(\"?\");\n if (!path) {\n return null;\n }\n pathname = path;\n searchParams = new URLSearchParams(queryString || \"\");\n }\n\n // 移除路徑首尾的斜線以便比較\n const cleanPath = pathname.replaceAll(/^\\/|\\/$/g, \"\");\n const cleanPattern = pattern.replaceAll(/^\\/|\\/$/g, \"\");\n\n // 分割路徑段\n const pathSegments = cleanPath.split(\"/\");\n const patternSegments = cleanPattern.split(\"/\");\n\n // 路徑段數量不同則不匹配\n if (pathSegments.length !== patternSegments.length) {\n return null;\n }\n\n // 提取路徑參數\n const params: Record<string, string> = {};\n for (let i = 0; i < patternSegments.length; i++) {\n const patternSegment = patternSegments[i];\n const pathSegment = pathSegments[i];\n\n if (patternSegment.startsWith(\":\")) {\n // 動態參數\n const paramName = patternSegment.slice(1);\n params[paramName] = decodeURIComponent(pathSegment);\n } else if (patternSegment !== pathSegment) {\n // 靜態段不匹配\n return null;\n }\n }\n\n // 提取查詢參數\n const query = Object.fromEntries(searchParams.entries());\n\n return { params, query };\n } catch {\n return null;\n }\n};\n\nexport const matchRoute = (route: ParsedRoute, url: string): RouteMatch => {\n const _matchRoute = (\n matches: ParsedRoute[],\n { children }: ParsedRoute\n ): RouteMatch | null => {\n if (children && children.length > 0) {\n for (const childRoute of children) {\n const matchesResult = _matchRoute([...matches, childRoute], childRoute);\n if (matchesResult) {\n return matchesResult;\n }\n }\n return null;\n }\n\n const result = matchPattern(buildPathnameFromMatches(matches), url);\n return result ? { matches, ...result } : null;\n };\n\n return (\n _matchRoute([route], route) || {\n matches: [],\n params: {},\n query: {},\n }\n );\n};\n\nexport const buildPathnameFromMatches = (matches: Route[]): string => {\n let cleanedPathnames: string[] = []; // pathnames without leading/trailing slashes\n for (const match of matches) {\n if (match.pathname === undefined) continue;\n cleanedPathnames.push(match.pathname.replaceAll(/^\\/|\\/$/g, \"\"));\n }\n return \"/\" + cleanedPathnames.join(\"/\");\n};\n\nexport const parseLocation = ({\n href,\n pathname,\n search,\n}: globalThis.Location): Location => ({\n index: 0,\n href,\n state: {\n index: 0,\n },\n pathname,\n search: Object.fromEntries(new URLSearchParams(search)),\n});\n\nexport const createRouterOptions = (\n options?: Partial<RouterOptions>\n): RouterOptions => ({\n ...DefaultRouterOptions,\n ...options,\n});\n\nexport const parseRoute = (route: Route): ParsedRoute => {\n const parseRouteRecursive = (route: Route, parentId: string): ParsedRoute => {\n const id =\n route.name ??\n (route.pathname\n ? `${parentId}/${route.pathname.replaceAll(/^\\/|\\/$/g, \"\")}`\n : parentId);\n\n const parsedRoute: ParsedRoute = {\n ...route,\n id,\n children: route.children?.map((child) => parseRouteRecursive(child, id)),\n };\n\n return parsedRoute;\n };\n return parseRouteRecursive(route, \"\");\n};\n\nconst isPathSegmentValid = (segment: string): boolean => segment.length > 0;\n\n/**\n * Resolves a relative path against a base pathname.\n * @param pathname The base pathname.\n * @param to The relative path to resolve.\n * @returns The resolved absolute pathname.\n */\nexport const resolveRelativePathname = (\n pathname: string,\n to: string\n): string => {\n const currentPathSegments = pathname.split(\"/\").filter(isPathSegmentValid);\n const toPathSegments = to.split(\"/\").filter(isPathSegmentValid);\n for (const segment of toPathSegments) {\n if (segment === \".\") {\n continue;\n } else if (segment === \"..\") {\n currentPathSegments.pop();\n } else {\n currentPathSegments.push(segment);\n }\n }\n return \"/\" + currentPathSegments.join(\"/\");\n};\n","import { useCallback, useEffect, useRef, useState } from \"react\";\n\nimport { useRouter } from \"@/hooks/useRouter.js\";\nimport type { Route } from \"@/types.js\";\n\nimport { LocationProvider } from \"./location-provider.js\";\nimport { PageRenderer } from \"./page-renderer.js\";\nimport { RootRouteProvider } from \"./root-route-provider.js\";\n\ntype StackComponentProps = React.ComponentPropsWithoutRef<\"div\">;\n\nconst StackComponent: React.FC<StackComponentProps> = ({ style, ...props }) => {\n const {\n history,\n location,\n canGoBack,\n canGoForward,\n isTransitioning,\n transitioningToLocation,\n transitionDuration,\n back,\n forward,\n } = useRouter();\n const currentLocationIndex = location.index;\n\n const isTouching = useRef(false);\n const startX = useRef(0);\n const startY = useRef(0);\n const [isDragging, setIsDragging] = useState(false);\n const [dragOffset, setDragOffset] = useState(0);\n const [draggedLeft, setDraggedLeft] = useState(false);\n const [draggedRight, setDraggedRight] = useState(false);\n const [isCanceling, setIsCanceling] = useState(false);\n const [isTransitionStarted, setIsTransitionStarted] = useState(false);\n\n useEffect(() => {\n if (!isTransitioning || !transitioningToLocation) return;\n setIsTransitionStarted(true);\n setTimeout(() => {\n setIsTransitionStarted(false);\n }, transitionDuration);\n }, [isTransitioning, transitioningToLocation, transitionDuration]);\n\n if (currentLocationIndex === undefined) return;\n\n const reset = () => {\n setIsDragging(false);\n setDragOffset(0);\n setDraggedLeft(false);\n setDraggedRight(false);\n setIsCanceling(false);\n };\n\n const handleTouchStart = (e: React.TouchEvent) => {\n if (isTransitioning || (!canGoForward && !canGoBack)) return;\n isTouching.current = true;\n startX.current = e.touches[0].clientX;\n startY.current = e.touches[0].clientY;\n };\n\n const handleTouchMove = (e: React.TouchEvent) => {\n if (!isTouching.current) return;\n // Skip vertical drag\n const { clientX, clientY } = e.touches[0];\n if (!isDragging && Math.abs(clientY - startY.current) > 30) {\n isTouching.current = false;\n return;\n }\n const offset = clientX - startX.current;\n if (Math.abs(offset) < 10) return;\n if (!isDragging) {\n setIsDragging(true);\n }\n if (\n (offset > 0 && currentLocationIndex === 0) ||\n (offset < 0 && currentLocationIndex + 1 === history.length)\n ) {\n setDragOffset(0);\n return;\n }\n if (!draggedLeft && offset < 0) setDraggedLeft(true);\n if (!draggedRight && offset > 0) setDraggedRight(true);\n setDragOffset(\n Math.max(Math.min(offset, window.innerWidth), -window.innerWidth)\n );\n };\n\n const handleTouchEnd = useCallback(() => {\n isTouching.current = false;\n if (!isDragging) return;\n\n const options = {\n onFinish: reset,\n };\n if (dragOffset > innerWidth * 0.3 && canGoBack) {\n back(options);\n } else if (dragOffset < -innerWidth * 0.3 && canGoForward) {\n forward(options);\n } else {\n setIsCanceling(true);\n setTimeout(reset, transitionDuration);\n }\n }, [\n back,\n forward,\n isDragging,\n dragOffset,\n canGoBack,\n canGoForward,\n transitionDuration,\n ]);\n\n return (\n <div\n style={{\n position: \"relative\",\n overflow: \"hidden\",\n ...style,\n }}\n {...props}\n >\n {currentLocationIndex >= 1 &&\n ((isDragging && draggedRight) ||\n (isTransitioning &&\n transitioningToLocation!.index < currentLocationIndex)) && (\n <div\n style={{\n position: \"absolute\",\n inset: 0,\n }}\n >\n <LocationProvider location={history.at(currentLocationIndex - 1)!}>\n <PageRenderer key={currentLocationIndex - 1} />\n </LocationProvider>\n </div>\n )}\n <div\n key={currentLocationIndex}\n style={{\n background: \"white\",\n position: \"absolute\",\n inset: 0,\n transform:\n isTransitioning &&\n transitioningToLocation!.index < currentLocationIndex\n ? `translateX(100%)`\n : isDragging && dragOffset > 0 && !isCanceling\n ? `translateX(${dragOffset}px)`\n : \"translateX(0px)\",\n transition:\n isCanceling ||\n (isTransitioning &&\n transitioningToLocation!.index < currentLocationIndex)\n ? `transform ${transitionDuration}ms ease-out`\n : \"\",\n }}\n onTouchStart={handleTouchStart}\n onTouchMove={handleTouchMove}\n onTouchEnd={handleTouchEnd}\n >\n <PageRenderer />\n </div>\n\n {((isDragging && draggedLeft) ||\n (isTransitioning &&\n currentLocationIndex <= transitioningToLocation!.index)) && (\n <div\n style={{\n background: \"white\",\n position: \"absolute\",\n inset: 0,\n transform: `translateX(${\n isTransitionStarted\n ? \"0px\"\n : isTransitioning || isCanceling\n ? \"100%\"\n : `${innerWidth + dragOffset}px`\n })`,\n transition: `transform ${\n isTransitioning || isCanceling ? transitionDuration : 0\n }ms ease-in`,\n }}\n >\n <LocationProvider\n location={\n isTransitioning\n ? transitioningToLocation!\n : history.at(currentLocationIndex + 1)!\n }\n >\n <PageRenderer key={transitioningToLocation?.index} />\n </LocationProvider>\n </div>\n )}\n </div>\n );\n};\n\nexport interface StackProps extends StackComponentProps {\n rootRoute: Route;\n}\n\nexport const Stack: React.FC<StackProps> = ({ rootRoute, ...props }) => (\n <RootRouteProvider rootRoute={rootRoute}>\n <StackComponent {...props} />\n </RootRouteProvider>\n);\n","import { RouteMatchContext } from \"@/context/route-match-context.js\";\nimport { useLocation } from \"@/hooks/useLocation.js\";\nimport { useRootRoute } from \"@/hooks/useRootRoute.js\";\nimport { matchRoute } from \"@/utils.js\";\nimport { RouteComponent } from \"./route-component.js\";\nimport { RouteProvider } from \"./route-provider.js\";\n\nexport const PageRenderer = () => {\n const rootRoute = useRootRoute();\n const location = useLocation();\n const routeMatch = matchRoute(rootRoute, location.pathname);\n return (\n <RouteMatchContext.Provider value={routeMatch}>\n <RouteProvider route={rootRoute}>\n <RouteComponent />\n </RouteProvider>\n </RouteMatchContext.Provider>\n );\n};\n","import { RootRouteContext } from \"@/context/root-route-context.js\";\nimport type { Route } from \"@/types.js\";\nimport { parseRoute } from \"@/utils.js\";\nimport { useCallback, useState } from \"react\";\n\nexport const RootRouteProvider = ({\n rootRoute,\n ...props\n}: {\n rootRoute: Route;\n children: React.ReactNode;\n}) => {\n const parsedRoute = parseRoute(rootRoute);\n const [state, setState] = useState<Record<string, Record<string, any>>>({});\n\n const getRouteState = useCallback(\n (id: string, key: string) => {\n return state[id]?.[key];\n },\n [state]\n );\n\n const setRouteState = useCallback((id: string, key: string, value: any) => {\n setState((prevState) => ({\n ...prevState,\n [id]: {\n ...prevState[id],\n [key]: value,\n },\n }));\n }, []);\n\n return (\n <RootRouteContext.Provider\n value={{ ...parsedRoute, state, getRouteState, setRouteState }}\n {...props}\n />\n );\n};\n"],"mappings":"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","names":["useContext","createContext","RouterContext","useRouter","router","useContext","RouterContext","memo","jsx","Link","to","replace","transition","duration","onFinish","props","router","useRouter","e","createContext","LocationContext","memo","useCallback","jsx","LocationProvider","location","props","router","useRouter","getState","key","setState","value","deleteState","LocationContext","a","b","createContext","OutletContext","useContext","useOutlet","OutletContext","createContext","RouteMatchContext","useContext","useRouteMatch","routeMatch","RouteMatchContext","jsx","OutletProvider","depth","props","OutletContext","useContext","useLocation","context","useContext","LocationContext","createContext","RouteContext","useContext","useRoute","route","RouteContext","useEffect","useState","jsx","RouteComponent","depth","router","useRouter","location","useLocation","routeMatch","useRouteMatch","route","useRoute","pendingStateKey","pending","setPending","useState","useEffect","cause","NotFoundComponent","PendingComponent","Component","Outlet","useContext","createContext","RootRouteContext","useRootRoute","route","useContext","RootRouteContext","useCallback","jsx","RouteProvider","route","props","RouteContext","state","getRouteState","setRouteState","useRootRoute","getState","key","setState","value","jsx","Outlet","routeMatch","useRouteMatch","depth","useOutlet","OutletProvider","RouteProvider","RouteComponent","useCallback","useEffect","useState","DefaultRouterOptions","DefaultTransitionDuration","redirect","options","matchPattern","pattern","url","pathname","searchParams","urlObj","path","queryString","cleanPath","cleanPattern","pathSegments","patternSegments","params","i","patternSegment","pathSegment","paramName","query","matchRoute","route","_matchRoute","matches","children","childRoute","matchesResult","result","buildPathnameFromMatches","cleanedPathnames","match","parseLocation","href","search","createRouterOptions","DefaultRouterOptions","parseRoute","parseRouteRecursive","parentId","id","child","isPathSegmentValid","segment","resolveRelativePathname","to","currentPathSegments","toPathSegments","jsx","RouterProvider","options","props","history","setHistory","useState","parseLocation","currentLocationIndex","setCurrentLocationIndex","location","isTransitioning","setIsTransitioning","transitionDuration","setTransitionDuration","transitioningToLocation","setTransitioningToLocation","useEffect","handlePopState","state","buildLocation","useCallback","to","replace","index","pathname","resolveRelativePathname","transitionTo","duration","callback","navigate","transition","onFinish","newLocation","updateHistory","prevHistory","back","depth","backDepth","forward","forwardDepth","setLocationState","RouterContext","LocationProvider","useCallback","useEffect","useRef","useState","jsx","PageRenderer","rootRoute","useRootRoute","location","useLocation","routeMatch","matchRoute","RouteMatchContext","RouteProvider","RouteComponent","useCallback","useState","jsx","RootRouteProvider","rootRoute","props","parsedRoute","parseRoute","state","setState","getRouteState","id","key","setRouteState","value","prevState","RootRouteContext","jsx","jsxs","StackComponent","style","props","history","location","canGoBack","canGoForward","isTransitioning","transitioningToLocation","transitionDuration","back","forward","useRouter","currentLocationIndex","isTouching","useRef","startX","startY","isDragging","setIsDragging","useState","dragOffset","setDragOffset","draggedLeft","setDraggedLeft","draggedRight","setDraggedRight","isCanceling","setIsCanceling","isTransitionStarted","setIsTransitionStarted","useEffect","reset","handleTouchStart","e","handleTouchMove","clientX","clientY","offset","handleTouchEnd","useCallback","options","LocationProvider","PageRenderer","Stack","rootRoute","RootRouteProvider"]}
|