@native-router/react 1.0.1 → 1.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs +2 -0
- package/dist/index.cjs.map +1 -0
- package/dist/server-64ccd715.cjs +2 -0
- package/dist/server-64ccd715.cjs.map +1 -0
- package/dist/server.cjs +2 -0
- package/dist/server.cjs.map +1 -0
- package/package.json +8 -6
package/dist/index.cjs
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./server-64ccd715.cjs"),r=require("@native-router/core"),t=require("react"),o=require("react/jsx-runtime");require("history"),require("@native-router/core/util");const u=t.createContext({loading:!1});exports.HashRouter=e.HashRouter,exports.HistoryRouter=e.HistoryRouter,exports.MemoryRouter=e.MemoryRouter,exports.Router=e.Router,exports.View=e.View,exports.createRouter=e.createRouter,exports.defaultResolveView=e.resolveView,exports.resolveClientView=e.resolveClientView,exports.useData=e.useData,exports.useLoading=e.useLoading,exports.useMatched=e.useMatched,exports.useRouter=e.useRouter,exports.useView=e.useView,exports.Link=function(u){let{to:s,...n}=u;const i=e.useRouter(),c=t.useRef(!1);return o.jsx("a",{...n,href:r.createHref(i,s),onClick:function(e){e.preventDefault(),c.current||(c.current=!0,r.navigate(i,s).finally((()=>c.current=!1)))}})},exports.PrefetchLink=function(s){let{to:n,children:i,...c}=s;const a=e.useRouter(),l=t.useRef(),[f,x]=t.useState(!1),[p,v]=t.useState(),[R,d]=t.useState(),h=r.toLocation(a,n);function w(){x(!0),l.current=r.resolve(a,h).then((e=>(d(e),e))).catch((e=>{throw v(e),e})).finally((()=>x(!1)))}t.useEffect((()=>{l.current=void 0}),[n,a]);const y=t.useMemo((()=>({loading:f,error:p,view:R})),[f,p,R]);return o.jsx(u.Provider,{value:y,children:o.jsx("a",{...c,href:r.createHref(a,n),onMouseEnter:function(){l.current||w()},onClick:function(e){e.preventDefault(),l.current||w(),r.commit(a,l.current,h).finally((()=>l.current=void 0))},children:i})})},exports.usePrefetch=function(){return t.useContext(u)};
|
|
2
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.cjs","sources":["../src/components/PrefetchLink.tsx","../src/components/Link.tsx"],"sourcesContent":["import {commit, createHref, resolve, toLocation} from '@native-router/core';\nimport type {LinkProps} from '@@/types';\nimport {\n createContext,\n MouseEvent,\n ReactNode,\n useContext,\n useEffect,\n useMemo,\n useRef,\n useState\n} from 'react';\nimport {useRouter} from './Router';\n\ntype PrefetchLinkContext = {loading: boolean; error?: Error; view?: ReactNode};\n\nconst Context = createContext<PrefetchLinkContext>({loading: false});\n\n/**\n * Get the prefetch context. Use for render a preview view.\n * @group Hooks\n */\nexport function usePrefetch() {\n return useContext(Context);\n}\n\n/**\n * Link support hover prefetch.\n * @param props\n * @group Components\n */\nexport default function PrefetchLink({to, children, ...rest}: LinkProps) {\n const router = useRouter();\n const viewPromiseRef = useRef<undefined | Promise<ReactNode>>();\n const [loading, setLoading] = useState(false);\n const [error, setError] = useState<Error>();\n const [view, setView] = useState<ReactNode>();\n const location = toLocation(router, to);\n\n function prefetchIt() {\n setLoading(true);\n viewPromiseRef.current = resolve(router, location)\n .then((v) => {\n setView(v);\n return v;\n })\n .catch((e) => {\n setError(e);\n throw e;\n })\n .finally(() => setLoading(false));\n }\n\n function handlePrefetch() {\n if (viewPromiseRef.current) return;\n prefetchIt();\n }\n\n function handleClick(e: MouseEvent<HTMLAnchorElement>) {\n e.preventDefault();\n if (!viewPromiseRef.current) {\n prefetchIt();\n }\n commit(router, viewPromiseRef.current!, location).finally(\n () => (viewPromiseRef.current = undefined)\n );\n }\n\n useEffect(() => {\n viewPromiseRef.current = undefined;\n }, [to, router]);\n\n const linkContext = useMemo(\n () => ({loading, error, view}),\n [loading, error, view]\n );\n\n return (\n <Context.Provider value={linkContext}>\n <a\n {...rest}\n href={createHref(router, to)}\n onMouseEnter={handlePrefetch}\n onClick={handleClick}\n >\n {children}\n </a>\n </Context.Provider>\n );\n}\n","import {createHref, navigate} from '@native-router/core';\nimport type {LinkProps} from '@@/types';\nimport {useRef, type MouseEvent} from 'react';\nimport {useRouter} from './Router';\n\n/**\n * Link for navigate in app.\n * @param props\n * @group Components\n */\nexport default function Link({to, ...rest}: LinkProps) {\n const router = useRouter();\n const lock = useRef(false);\n\n function handleClick(e: MouseEvent<HTMLAnchorElement>) {\n e.preventDefault();\n\n if (lock.current) return;\n lock.current = true;\n navigate(router, to).finally(() => (lock.current = false));\n }\n return (\n // eslint-disable-next-line jsx-a11y/anchor-has-content\n <a {...rest} href={createHref(router, to)} onClick={handleClick} />\n );\n}\n"],"names":["Context","createContext","loading","_ref","to","rest","router","useRouter","lock","useRef","href","createHref","onClick","e","preventDefault","current","navigate","finally","children","viewPromiseRef","setLoading","useState","error","setError","view","setView","location","toLocation","prefetchIt","resolve","then","v","catch","useEffect","undefined","linkContext","useMemo","_jsx","Provider","value","onMouseEnter","useContext"],"mappings":"mQAgBA,MAAMA,EAA6CC,EAAAA,cAAA,CAACC,SAAS,obCN7D,SAA4BC,GAAC,IAAAC,GAACA,KAAOC,GAAgBF,EACnD,MAAMG,EAASC,EAAAA,YACTC,EAAOC,UAAO,GASpB,aAEE,IAAA,IAAOJ,EAAMK,KAAMC,EAAAA,WAAWL,EAAQF,GAAKQ,QAT7C,SAAqBC,GACnBA,EAAEC,iBAEEN,EAAKO,UACTP,EAAKO,SAAU,EACfC,WAASV,EAAQF,GAAIa,SAAQ,IAAOT,EAAKO,SAAU,IACrD,GAKF,uBDMA,SAAoCZ,GAAC,IAAAC,GAACA,EAAAA,SAAIc,KAAab,GAAgBF,EACrE,MAAMG,EAASC,EAAAA,YACTY,EAAiBV,EAAAA,UAChBP,EAASkB,GAAcC,YAAS,IAChCC,EAAOC,GAAYF,EAAgBA,YACnCG,EAAMC,GAAWJ,EAAoBA,WACtCK,EAAWC,EAAAA,WAAWrB,EAAQF,GAEpC,SAASwB,IACPR,GAAW,GACXD,EAAeJ,QAAUc,UAAQvB,EAAQoB,GACtCI,MAAYC,IACXN,EAAQM,GACDA,KAERC,OAAanB,IAENA,MADNU,EAASV,GACHA,CAAAA,IAEPI,SAAQ,IAAMG,GAAW,IAC9B,CAiBAa,EAAAA,WAAU,KACRd,EAAeJ,aAAUmB,CAAAA,GACxB,CAAC9B,EAAIE,IAEF6B,MAAAA,EAAcC,EAAAA,SAClB,KAAO,CAAClC,UAASoB,QAAOE,UACxB,CAACtB,EAASoB,EAAOE,IAIjBa,OAAAA,EAAAA,IAACrC,EAAQsC,SAAQ,CAACC,MAAOJ,EAAYjB,eACnC,IAAA,IACMb,EACJK,KAAMC,EAAAA,WAAWL,EAAQF,GACzBoC,aA7BN,WACMrB,EAAeJ,SACRa,GACb,EA2BMhB,QAzBN,SAAqBC,GACnBA,EAAEC,iBACGK,EAAeJ,SACPa,IAENtB,EAAAA,OAAAA,EAAQa,EAAeJ,QAAUW,GAAUT,SAChD,IAAOE,EAAeJ,aAAUmB,GAEpC,EAiB2BhB,cAM7B,sBAnEO,WACL,OAAOuB,EAAAA,WAAWzC,EACpB"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";const e=require("history"),t=require("@native-router/core"),r=require("@native-router/core/util"),n=require("react"),o=require("react/jsx-runtime"),i=n.createContext(null);function s(e){return o.jsx(i.Provider,{...e})}function u(){return n.useContext(i)}function c(){return u()}const a=n.createContext([void 0,{}]);function l(){return n.useContext(a)}function d(e){let{children:t,name:r,data:i}=e;const s=l()[1],u=n.useMemo((()=>[i,r?{...s,[r]:i}:s]),[i,r,s]);return o.jsx(a.Provider,{value:u,children:t})}const x=n.createContext(void 0);const h=n.createContext(void 0);function f(e,t){return y(e,t,((e,t)=>e?.(t)))}const v=new WeakMap;function p(e,t){const r=new Array(e.length);return y(e,t,((e,t)=>Promise.resolve(e?.(t)).then((e=>r[t.index]=e)))).then((e=>(v.set(e,r),e)))}function y(e,t,r){let{router:n,location:i}=t;return Promise.all(e.map(((t,s)=>{let{params:u,route:a}=t;const l={matched:e,params:u,index:s,router:n,location:i};return Promise.all([r(a.data,l),function(){if(!a.component)return c;const e=a.component(l);return Promise.resolve(e).then((e=>"default"in e?e.default:e))}()]).then((e=>{let[t,r]=e;return o.jsx(d,{data:t,name:a.name,children:o.jsx(x.Provider,{value:l,children:o.jsx(r,{})})})}))}))).then((e=>e.reverse().reduce(((e,t)=>o.jsx(s,{value:e,children:t})))))}const m=n.createContext(null);function j(e){let{router:r,children:i}=e;const[u,c]=n.useState(t.getCurrentView(r));return n.useEffect((()=>t.listen(r,c)),[r]),o.jsx(m.Provider,{value:r,children:"undefined"===i?u:o.jsx(s,{value:u,children:i})})}function w(e,r){let{resolveView:n=f,...o}=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};return t.create(e,r,n,o)}function g(e,i){let{routes:s,children:u,...c}=e;const[a,l]=r.splitProps(c,["baseUrl","currentView"]),d=n.useMemo((()=>w(s,i(),a)),[s,i,...Object.keys(a),...Object.values(a)]),[x,f]=n.useState();t.setOptions(d,{...l,onLoadingChange(e){f(e&&{key:r.uniqId(),status:e})}});const v=n.useMemo((()=>o.jsx(j,{router:d,children:u})),[d,u]);return o.jsx(h.Provider,{value:x,children:v})}const C="_nativeRouterReactSSRData";function M(e,r,n){return t.resolve(e,r).then((t=>{const i=function(e){return v.get(e)}(t);return o.jsxs(o.Fragment,{children:[o.jsx(j,{router:e,children:t}),o.jsx("script",{...n?.scriptAttributes,suppressHydrationWarning:!0,dangerouslySetInnerHTML:{__html:`window.${n?.hydrateKey||C} = ${JSON.stringify({data:i,location:r})};`}})]})}))}exports.HashRouter=function(t){return g(t,e.createHashHistory)},exports.HistoryRouter=function(t){return g(t,e.createBrowserHistory)},exports.MemoryRouter=function(t){let{initialEntries:r,initialIndex:o,...i}=t;return g(i,n.useMemo((()=>()=>e.createMemoryHistory({initialEntries:r,initialIndex:o})),[r,o]))},exports.Router=j,exports.View=c,exports.createRouter=w,exports.resolveClientView=function(r,n){const{data:o,location:i}=window[n?.hydrateKey||C],s=t.create(r,e.createMemoryHistory({initialEntries:[i]}),function(e){return(t,r)=>y(t,r,((t,r)=>e[r.index]))}(o),n);return t.resolve(s,i)},exports.resolveServerView=function(n,o){let{scriptAttributes:i,hydrateKey:s,...u}=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};const c=t.create(n,e.createMemoryHistory({initialEntries:[o]}),p,u);return M(c,r.isString(o)?t.toLocation(c,o):o,{scriptAttributes:i,hydrateKey:s})},exports.resolveView=f,exports.useData=function(e){const[t,r]=l();return e?r[e]:t},exports.useLoading=function(){return n.useContext(h)},exports.useMatched=function(){return n.useContext(x)},exports.useRouter=function(){return n.useContext(m)},exports.useView=u;
|
|
2
|
+
//# sourceMappingURL=server-64ccd715.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"server-64ccd715.cjs","sources":["../src/context.tsx","../src/resolve-view.tsx","../src/components/Router.tsx","../src/ssr.tsx"],"sourcesContent":["import {createContext, ReactNode, useContext, useMemo} from 'react';\nimport type {Context, LoadStatus, Route} from './types';\n\nconst ViewContext = createContext<ReactNode>(null);\n\nexport function ViewProvider(props: {children: ReactNode; value: ReactNode}) {\n return <ViewContext.Provider {...props} />;\n}\n\n/**\n * @group Hooks\n * @see {@link View View Component}\n */\nexport function useView() {\n return useContext(ViewContext);\n}\n\n/**\n * Used for route component to render child route component.\n * It just render the return of {@link useView}\n * @group Components\n */\nexport function View() {\n return useView();\n}\n\nconst DataContext = createContext<[any, Record<string, any>]>([undefined, {}]);\n\nfunction useDataContext() {\n return useContext(DataContext);\n}\n\n/**\n * @group Hooks\n */\nexport function useNamedData() {\n return useDataContext()[1];\n}\n\nexport function DataProvider({\n children,\n name,\n data\n}: {\n children: ReactNode;\n data: any;\n name?: string;\n}) {\n const namedData = useNamedData();\n const value = useMemo(\n () => [data, name ? {...namedData, [name]: data} : namedData] as [any, any],\n [data, name, namedData]\n );\n return <DataContext.Provider value={value}>{children}</DataContext.Provider>;\n}\n\nexport const MatchedContext = createContext<Context<Route> | undefined>(\n undefined\n);\n\n/**\n * @group Hooks\n */\nexport function useMatched() {\n return useContext(MatchedContext)!;\n}\n\n/**\n * @group Hooks\n */\nexport function useData(name?: string) {\n const [data, namedData] = useDataContext();\n return name ? namedData[name] : data;\n}\n\nexport const LoadingContext = createContext<LoadStatus | undefined>(undefined);\n\n/**\n * @group Hooks\n */\nexport function useLoading() {\n return useContext(LoadingContext);\n}\n","import type {ComponentType, ReactElement} from 'react';\nimport type {Context, ResolveViewContext, Route} from '@@/types';\nimport type {Matched} from '@native-router/core';\nimport {DataProvider, MatchedContext, View, ViewProvider} from './context';\n\n/**\n * The default implementation of resolve view\n * @param matched the matched result\n * @param viewContext resolved view context\n * @returns the resolve view\n * @see {@link create router->create}\n */\nexport default function resolveView(\n matched: Matched<Route>[],\n ctx: ResolveViewContext<Route>\n) {\n return resolveViewBase(matched, ctx, (data, dataCtx) => data?.(dataCtx));\n}\n\nconst viewDataMap = new WeakMap<ReactElement, any[]>();\n\nexport function resolveViewServer(\n matched: Matched<Route>[],\n ctx: ResolveViewContext<Route>\n) {\n const dataResults = new Array(matched.length);\n return resolveViewBase(matched, ctx, (data, dataCtx) =>\n Promise.resolve(data?.(dataCtx)).then(\n (result) => (dataResults[dataCtx.index] = result)\n )\n ).then((view) => {\n viewDataMap.set(view, dataResults);\n return view;\n });\n}\n\nexport function createHydrateResolveView(data: any[]) {\n return (matched: Matched<Route>[], ctx: ResolveViewContext<Route>) =>\n resolveViewBase(matched, ctx, (_, dataCtx) => data[dataCtx.index]);\n}\n\nexport function getViewData(view: ReactElement) {\n return viewDataMap.get(view);\n}\n\nfunction resolveViewBase(\n matched: Matched<Route>[],\n {router, location}: ResolveViewContext<Route>,\n resolveData: (\n dataFetcher: ((ctx: Context<Route>) => any) | undefined,\n ctx: Context<Route>\n ) => any\n) {\n return Promise.all(\n matched.map(({params, route}, index) => {\n const ctx = {\n matched: matched!,\n params,\n index,\n router,\n location\n };\n function resolveComponent(): ComponentType | Promise<ComponentType> {\n if (!route.component) return View;\n const r = route.component(ctx);\n return Promise.resolve(r).then((m) => ('default' in m ? m.default : m));\n }\n\n return Promise.all([\n resolveData(route.data, ctx),\n resolveComponent()\n ]).then(([data, C]) => (\n <DataProvider data={data} name={route.name}>\n <MatchedContext.Provider value={ctx}>\n <C />\n </MatchedContext.Provider>\n </DataProvider>\n ));\n })\n ).then((views) =>\n views\n .reverse()\n .reduce((acc, view) => <ViewProvider value={acc}>{view}</ViewProvider>)\n );\n}\n","import {\n ReactNode,\n createContext,\n useContext,\n useEffect,\n useState,\n useMemo\n} from 'react';\nimport {\n History,\n createBrowserHistory,\n createHashHistory,\n createMemoryHistory,\n MemoryHistoryOptions\n} from 'history';\nimport type {LoadStatus, Route} from '@@/types';\nimport {LoadingContext, ViewProvider} from '@@/context';\nimport {create, getCurrentView, listen, setOptions} from '@native-router/core';\nimport type {Options, ResolveView, RouterInstance} from '@native-router/core';\nimport {splitProps, uniqId} from '@native-router/core/util';\nimport defaultResolve from '@@/resolve-view';\n\nconst RouterContext = createContext<RouterInstance<Route, ReactNode> | null>(\n null\n);\n\ntype Props = {\n children: ReactNode;\n routes: Route[] | Route;\n resolveView?: typeof defaultResolve;\n} & Omit<Options<ReactNode>, 'onLoadingChange'>;\n\n/**\n * Base Router Component.\n * @group Components\n */\nexport function Router({\n router,\n children\n}: {\n children: ReactNode;\n router: RouterInstance<Route, ReactNode>;\n}) {\n const [view, setView] = useState<ReactNode>(getCurrentView(router));\n\n useEffect(() => listen(router, setView), [router]);\n return (\n <RouterContext.Provider value={router}>\n {children === 'undefined' ? (\n view\n ) : (\n <ViewProvider value={view}>{children}</ViewProvider>\n )}\n </RouterContext.Provider>\n );\n}\n\nexport function createRouter(\n routes: Route | Route[],\n history: History,\n {\n resolveView = defaultResolve,\n ...options\n }: Options<ReactNode> & {resolveView?: ResolveView<Route, ReactNode>} = {}\n): RouterInstance<Route, ReactNode> {\n return create(routes, history, resolveView, options);\n}\n\nfunction useNewRouter(\n {routes, children, ...options}: Props,\n createHistory: () => History\n) {\n const [tracked, rest] = splitProps(options, ['baseUrl', 'currentView']);\n const router = useMemo(\n () => createRouter(routes, createHistory(), tracked),\n [routes, createHistory, ...Object.keys(tracked), ...Object.values(tracked)]\n );\n\n const [loading, setLoading] = useState<LoadStatus>();\n setOptions(router, {\n ...rest,\n onLoadingChange(status) {\n setLoading(status && {key: uniqId(), status});\n }\n });\n\n const r = useMemo(\n () => <Router router={router}>{children}</Router>,\n [router, children]\n );\n\n return <LoadingContext.Provider value={loading}>{r}</LoadingContext.Provider>;\n}\n\n/**\n * History mode Router Component.\n * @group Components\n */\nexport function HistoryRouter(props: Props) {\n return useNewRouter(props, createBrowserHistory);\n}\n\n/**\n * Hash mode Router Component.\n * @group Components\n */\nexport function HashRouter(props: Props) {\n return useNewRouter(props, createHashHistory);\n}\n\n/**\n * Memory mode Router Component.\n * @group Components\n */\nexport function MemoryRouter({\n initialEntries,\n initialIndex,\n ...props\n}: Props & MemoryHistoryOptions) {\n const createHistory = useMemo(\n () => () => createMemoryHistory({initialEntries, initialIndex}),\n [initialEntries, initialIndex]\n );\n return useNewRouter(props, createHistory);\n}\n\n/**\n * Get Router instance.\n * @group Hooks\n * @returns Router Instance\n */\nexport function useRouter() {\n return useContext(RouterContext)!;\n}\n","import {createMemoryHistory} from 'history';\nimport {ReactElement, ReactNode} from 'react';\nimport {create, resolve, toLocation} from '@native-router/core';\nimport type {Location, Options, RouterInstance} from '@native-router/core';\nimport {isString} from '@native-router/core/util';\nimport {Router} from './components/Router';\nimport {\n createHydrateResolveView,\n getViewData,\n resolveViewServer\n} from './resolve-view';\nimport type {Route} from './types';\n\nconst defaultHydrateKey = '_nativeRouterReactSSRData';\n\nexport function resolveServerViewBase(\n router: RouterInstance<Route, ReactNode>,\n location: Location,\n options?: {\n scriptAttributes?: Record<string, string>;\n hydrateKey?: string;\n }\n) {\n return resolve<Route, ReactNode>(router, location).then((view) => {\n const data = getViewData(view as ReactElement);\n return (\n <>\n <Router router={router}>{view}</Router>\n <script\n {...options?.scriptAttributes}\n suppressHydrationWarning\n // eslint-disable-next-line react/no-danger\n dangerouslySetInnerHTML={{\n __html: `window.${\n options?.hydrateKey || defaultHydrateKey\n } = ${JSON.stringify({data, location})};`\n }}\n />\n </>\n );\n });\n}\n\nexport function resolveServerView(\n routes: Route | Route[],\n location: Location | string,\n {\n scriptAttributes,\n hydrateKey,\n ...options\n }: Options<ReactElement> & {\n scriptAttributes?: Record<string, string>;\n hydrateKey?: string;\n } = {}\n) {\n const router = create(\n routes,\n createMemoryHistory({initialEntries: [location]}),\n resolveViewServer,\n options\n );\n\n return resolveServerViewBase(\n router,\n isString(location) ? toLocation(router, location) : location,\n {\n scriptAttributes,\n hydrateKey\n }\n );\n}\n\nexport function resolveClientView(\n routes: Route | Route[],\n options?: Options<ReactElement> & {\n hydrateKey?: string;\n }\n) {\n const {data, location} = (window as any)[\n options?.hydrateKey || defaultHydrateKey\n ] as {data: any[]; location: Location};\n const router = create(\n routes,\n createMemoryHistory({initialEntries: [location]}),\n createHydrateResolveView(data),\n options\n );\n return resolve(router, location);\n}\n"],"names":["ViewContext","ViewProvider","props","_jsx","Provider","useView","useContext","View","DataContext","createContext","undefined","useDataContext","DataProvider","_ref","children","name","data","namedData","value","useMemo","MatchedContext","LoadingContext","resolveView","matched","ctx","resolveViewBase","dataCtx","viewDataMap","WeakMap","resolveViewServer","dataResults","Array","length","Promise","resolve","then","result","index","view","set","resolveData","router","location","all","map","_ref2","params","route","component","r","m","default","resolveComponent","_ref3","C","views","reverse","reduce","acc","RouterContext","Router","setView","useState","getCurrentView","useEffect","listen","createRouter","routes","history","defaultResolve","options","arguments","create","useNewRouter","createHistory","tracked","rest","splitProps","Object","keys","values","loading","setLoading","setOptions","onLoadingChange","status","key","uniqId","defaultHydrateKey","resolveServerViewBase","get","getViewData","_Fragment","scriptAttributes","suppressHydrationWarning","dangerouslySetInnerHTML","__html","hydrateKey","JSON","stringify","createHashHistory","createBrowserHistory","initialEntries","initialIndex","createMemoryHistory","resolveClientView","window","_","createHydrateResolveView","resolveServerView","isString","toLocation"],"mappings":"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"}
|
package/dist/server.cjs
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./server-64ccd715.cjs");require("history"),require("@native-router/core"),require("@native-router/core/util"),require("react"),require("react/jsx-runtime"),exports.resolveServerView=e.resolveServerView;
|
|
2
|
+
//# sourceMappingURL=server.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"server.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
package/package.json
CHANGED
|
@@ -1,14 +1,16 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@native-router/react",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.2",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"exports": {
|
|
6
6
|
".": {
|
|
7
|
-
"import": "./dist/index.
|
|
7
|
+
"import": "./dist/index.js",
|
|
8
|
+
"require": "./dist/index.cjs",
|
|
8
9
|
"types": "./dist/types/index.d.ts"
|
|
9
10
|
},
|
|
10
11
|
"./server": {
|
|
11
|
-
"import": "./dist/server.
|
|
12
|
+
"import": "./dist/server.js",
|
|
13
|
+
"require": "./dist/server.cjs",
|
|
12
14
|
"types": "./dist/types/server.d.ts"
|
|
13
15
|
}
|
|
14
16
|
},
|
|
@@ -46,15 +48,15 @@
|
|
|
46
48
|
},
|
|
47
49
|
"repository": {
|
|
48
50
|
"type": "git",
|
|
49
|
-
"url": "https://github.com/
|
|
51
|
+
"url": "https://github.com/native-router/react"
|
|
50
52
|
},
|
|
51
53
|
"sideEffects": false,
|
|
52
54
|
"author": "wmzy",
|
|
53
55
|
"license": "MIT",
|
|
54
56
|
"bugs": {
|
|
55
|
-
"url": "https://github.com/
|
|
57
|
+
"url": "https://github.com/native-router/react/issues"
|
|
56
58
|
},
|
|
57
|
-
"homepage": "https://github.com/
|
|
59
|
+
"homepage": "https://github.com/native-router/react",
|
|
58
60
|
"engines": {
|
|
59
61
|
"node": ">=14"
|
|
60
62
|
},
|