@tanstack/solid-router 1.121.0-alpha.27 → 1.121.0-alpha.28
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/Asset.cjs +65 -21
- package/dist/cjs/Asset.cjs.map +1 -1
- package/dist/cjs/Asset.d.cts +2 -1
- package/dist/cjs/CatchBoundary.cjs +14 -15
- package/dist/cjs/CatchBoundary.cjs.map +1 -1
- package/dist/cjs/ClientOnly.cjs +12 -14
- package/dist/cjs/ClientOnly.cjs.map +1 -1
- package/dist/cjs/ClientOnly.d.cts +0 -20
- package/dist/cjs/HeadContent.cjs +28 -23
- package/dist/cjs/HeadContent.cjs.map +1 -1
- package/dist/cjs/Match.cjs +167 -141
- package/dist/cjs/Match.cjs.map +1 -1
- package/dist/cjs/Matches.cjs +26 -24
- package/dist/cjs/Matches.cjs.map +1 -1
- package/dist/cjs/Matches.d.cts +1 -0
- package/dist/cjs/RouterProvider.cjs +5 -5
- package/dist/cjs/RouterProvider.cjs.map +1 -1
- package/dist/cjs/SafeFragment.cjs +2 -2
- package/dist/cjs/SafeFragment.cjs.map +1 -1
- package/dist/cjs/ScriptOnce.cjs +4 -9
- package/dist/cjs/ScriptOnce.cjs.map +1 -1
- package/dist/cjs/ScriptOnce.d.cts +1 -1
- package/dist/cjs/Scripts.cjs +9 -13
- package/dist/cjs/Scripts.cjs.map +1 -1
- package/dist/cjs/ScrollRestoration.cjs +3 -4
- package/dist/cjs/ScrollRestoration.cjs.map +1 -1
- package/dist/cjs/Transitioner.cjs +9 -8
- package/dist/cjs/Transitioner.cjs.map +1 -1
- package/dist/cjs/awaited.cjs +2 -2
- package/dist/cjs/awaited.cjs.map +1 -1
- package/dist/cjs/fileRoute.cjs +5 -5
- package/dist/cjs/fileRoute.cjs.map +1 -1
- package/dist/cjs/index.cjs +0 -12
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/cjs/index.d.cts +3 -6
- package/dist/cjs/lazyRouteComponent.cjs +6 -26
- package/dist/cjs/lazyRouteComponent.cjs.map +1 -1
- package/dist/cjs/lazyRouteComponent.d.cts +1 -1
- package/dist/cjs/link.cjs +37 -31
- package/dist/cjs/link.cjs.map +1 -1
- package/dist/cjs/not-found.cjs +5 -7
- package/dist/cjs/not-found.cjs.map +1 -1
- package/dist/cjs/renderRouteNotFound.cjs +4 -4
- package/dist/cjs/renderRouteNotFound.cjs.map +1 -1
- package/dist/cjs/route.cjs +16 -16
- package/dist/cjs/route.cjs.map +1 -1
- package/dist/cjs/route.d.cts +14 -5
- package/dist/cjs/router.cjs.map +1 -1
- package/dist/cjs/routerContext.cjs.map +1 -1
- package/dist/cjs/scroll-restoration.cjs +12 -6
- package/dist/cjs/scroll-restoration.cjs.map +1 -1
- package/dist/cjs/ssr/RouterClient.cjs +45 -0
- package/dist/cjs/ssr/RouterClient.cjs.map +1 -0
- package/dist/cjs/ssr/RouterClient.d.cts +4 -0
- package/dist/cjs/ssr/RouterServer.cjs +56 -0
- package/dist/cjs/ssr/RouterServer.cjs.map +1 -0
- package/dist/cjs/ssr/RouterServer.d.cts +5 -0
- package/dist/cjs/ssr/client.cjs +5 -0
- package/dist/cjs/ssr/client.cjs.map +1 -0
- package/dist/cjs/ssr/client.d.cts +1 -0
- package/dist/cjs/ssr/defaultRenderHandler.cjs +18 -0
- package/dist/cjs/ssr/defaultRenderHandler.cjs.map +1 -0
- package/dist/cjs/ssr/defaultRenderHandler.d.cts +1 -0
- package/dist/cjs/ssr/defaultStreamHandler.cjs +20 -0
- package/dist/cjs/ssr/defaultStreamHandler.cjs.map +1 -0
- package/dist/cjs/ssr/defaultStreamHandler.d.cts +1 -0
- package/dist/cjs/ssr/renderRouterToStream.cjs +45 -0
- package/dist/cjs/ssr/renderRouterToStream.cjs.map +1 -0
- package/dist/cjs/ssr/renderRouterToStream.d.cts +8 -0
- package/dist/cjs/ssr/renderRouterToString.cjs +43 -0
- package/dist/cjs/ssr/renderRouterToString.cjs.map +1 -0
- package/dist/cjs/ssr/renderRouterToString.d.cts +7 -0
- package/dist/cjs/ssr/server.cjs +20 -0
- package/dist/cjs/ssr/server.cjs.map +1 -0
- package/dist/cjs/ssr/server.d.cts +6 -0
- package/dist/cjs/useBlocker.cjs +41 -35
- package/dist/cjs/useBlocker.cjs.map +1 -1
- package/dist/cjs/useCanGoBack.cjs.map +1 -1
- package/dist/cjs/useLoaderData.cjs.map +1 -1
- package/dist/cjs/useLoaderDeps.cjs.map +1 -1
- package/dist/cjs/useLocation.cjs +1 -1
- package/dist/cjs/useLocation.cjs.map +1 -1
- package/dist/cjs/useMatch.cjs.map +1 -1
- package/dist/cjs/useNavigate.cjs +9 -3
- package/dist/cjs/useNavigate.cjs.map +1 -1
- package/dist/cjs/useParams.cjs.map +1 -1
- package/dist/cjs/useRouter.cjs +1 -1
- package/dist/cjs/useRouter.cjs.map +1 -1
- package/dist/cjs/useRouterState.cjs +3 -3
- package/dist/cjs/useRouterState.cjs.map +1 -1
- package/dist/cjs/useSearch.cjs.map +1 -1
- package/dist/cjs/utils.cjs +1 -1
- package/dist/cjs/utils.cjs.map +1 -1
- package/dist/esm/Asset.d.ts +2 -1
- package/dist/esm/Asset.js +60 -16
- package/dist/esm/Asset.js.map +1 -1
- package/dist/esm/CatchBoundary.js +1 -2
- package/dist/esm/CatchBoundary.js.map +1 -1
- package/dist/esm/ClientOnly.d.ts +0 -20
- package/dist/esm/ClientOnly.js +11 -13
- package/dist/esm/ClientOnly.js.map +1 -1
- package/dist/esm/HeadContent.js +23 -18
- package/dist/esm/HeadContent.js.map +1 -1
- package/dist/esm/Match.js +148 -122
- package/dist/esm/Match.js.map +1 -1
- package/dist/esm/Matches.d.ts +1 -0
- package/dist/esm/Matches.js +18 -16
- package/dist/esm/Matches.js.map +1 -1
- package/dist/esm/RouterProvider.js.map +1 -1
- package/dist/esm/SafeFragment.js.map +1 -1
- package/dist/esm/ScriptOnce.d.ts +1 -1
- package/dist/esm/ScriptOnce.js +2 -7
- package/dist/esm/ScriptOnce.js.map +1 -1
- package/dist/esm/Scripts.js +7 -11
- package/dist/esm/Scripts.js.map +1 -1
- package/dist/esm/ScrollRestoration.js +3 -4
- package/dist/esm/ScrollRestoration.js.map +1 -1
- package/dist/esm/Transitioner.js +9 -8
- package/dist/esm/Transitioner.js.map +1 -1
- package/dist/esm/awaited.js.map +1 -1
- package/dist/esm/fileRoute.js +5 -5
- package/dist/esm/fileRoute.js.map +1 -1
- package/dist/esm/index.d.ts +3 -6
- package/dist/esm/index.js +2 -8
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/lazyRouteComponent.d.ts +1 -1
- package/dist/esm/lazyRouteComponent.js +2 -22
- package/dist/esm/lazyRouteComponent.js.map +1 -1
- package/dist/esm/link.js +34 -28
- package/dist/esm/link.js.map +1 -1
- package/dist/esm/not-found.js +2 -4
- package/dist/esm/not-found.js.map +1 -1
- package/dist/esm/renderRouteNotFound.js.map +1 -1
- package/dist/esm/route.d.ts +14 -5
- package/dist/esm/route.js +12 -12
- package/dist/esm/route.js.map +1 -1
- package/dist/esm/router.js.map +1 -1
- package/dist/esm/routerContext.js.map +1 -1
- package/dist/esm/scroll-restoration.js +10 -4
- package/dist/esm/scroll-restoration.js.map +1 -1
- package/dist/esm/ssr/RouterClient.d.ts +4 -0
- package/dist/esm/ssr/RouterClient.js +45 -0
- package/dist/esm/ssr/RouterClient.js.map +1 -0
- package/dist/esm/ssr/RouterServer.d.ts +5 -0
- package/dist/esm/ssr/RouterServer.js +56 -0
- package/dist/esm/ssr/RouterServer.js.map +1 -0
- package/dist/esm/ssr/client.d.ts +1 -0
- package/dist/esm/ssr/client.js +5 -0
- package/dist/esm/ssr/client.js.map +1 -0
- package/dist/esm/ssr/defaultRenderHandler.d.ts +1 -0
- package/dist/esm/ssr/defaultRenderHandler.js +18 -0
- package/dist/esm/ssr/defaultRenderHandler.js.map +1 -0
- package/dist/esm/ssr/defaultStreamHandler.d.ts +1 -0
- package/dist/esm/ssr/defaultStreamHandler.js +20 -0
- package/dist/esm/ssr/defaultStreamHandler.js.map +1 -0
- package/dist/esm/ssr/renderRouterToStream.d.ts +8 -0
- package/dist/esm/ssr/renderRouterToStream.js +28 -0
- package/dist/esm/ssr/renderRouterToStream.js.map +1 -0
- package/dist/esm/ssr/renderRouterToString.d.ts +7 -0
- package/dist/esm/ssr/renderRouterToString.js +26 -0
- package/dist/esm/ssr/renderRouterToString.js.map +1 -0
- package/dist/esm/ssr/server.d.ts +6 -0
- package/dist/esm/ssr/server.js +14 -0
- package/dist/esm/ssr/server.js.map +1 -0
- package/dist/esm/useBlocker.js +41 -35
- package/dist/esm/useBlocker.js.map +1 -1
- package/dist/esm/useCanGoBack.js.map +1 -1
- package/dist/esm/useLoaderData.js.map +1 -1
- package/dist/esm/useLoaderDeps.js.map +1 -1
- package/dist/esm/useLocation.js +1 -1
- package/dist/esm/useLocation.js.map +1 -1
- package/dist/esm/useMatch.js.map +1 -1
- package/dist/esm/useNavigate.js +9 -3
- package/dist/esm/useNavigate.js.map +1 -1
- package/dist/esm/useParams.js.map +1 -1
- package/dist/esm/useRouter.js +1 -1
- package/dist/esm/useRouter.js.map +1 -1
- package/dist/esm/useRouterState.js +3 -3
- package/dist/esm/useRouterState.js.map +1 -1
- package/dist/esm/useSearch.js.map +1 -1
- package/dist/esm/utils.js +1 -1
- package/dist/esm/utils.js.map +1 -1
- package/dist/source/Asset.d.ts +2 -1
- package/dist/source/Asset.jsx +45 -7
- package/dist/source/Asset.jsx.map +1 -1
- package/dist/source/ClientOnly.d.ts +0 -20
- package/dist/source/ClientOnly.jsx +3 -29
- package/dist/source/ClientOnly.jsx.map +1 -1
- package/dist/source/HeadContent.jsx +13 -0
- package/dist/source/HeadContent.jsx.map +1 -1
- package/dist/source/Match.jsx +74 -61
- package/dist/source/Match.jsx.map +1 -1
- package/dist/source/Matches.d.ts +1 -0
- package/dist/source/Matches.jsx +14 -11
- package/dist/source/Matches.jsx.map +1 -1
- package/dist/source/ScriptOnce.d.ts +1 -1
- package/dist/source/ScriptOnce.jsx +2 -12
- package/dist/source/ScriptOnce.jsx.map +1 -1
- package/dist/source/Transitioner.jsx +8 -8
- package/dist/source/Transitioner.jsx.map +1 -1
- package/dist/source/index.d.ts +3 -6
- package/dist/source/index.jsx +1 -4
- package/dist/source/index.jsx.map +1 -1
- package/dist/source/lazyRouteComponent.d.ts +1 -1
- package/dist/source/lazyRouteComponent.jsx +7 -21
- package/dist/source/lazyRouteComponent.jsx.map +1 -1
- package/dist/source/link.jsx +22 -17
- package/dist/source/link.jsx.map +1 -1
- package/dist/source/not-found.jsx.map +1 -1
- package/dist/source/route.d.ts +14 -5
- package/dist/source/route.jsx.map +1 -1
- package/dist/source/scroll-restoration.jsx +9 -2
- package/dist/source/scroll-restoration.jsx.map +1 -1
- package/dist/source/ssr/RouterClient.d.ts +4 -0
- package/dist/source/ssr/RouterClient.jsx +28 -0
- package/dist/source/ssr/RouterClient.jsx.map +1 -0
- package/dist/source/ssr/RouterServer.d.ts +5 -0
- package/dist/source/ssr/RouterServer.jsx +38 -0
- package/dist/source/ssr/RouterServer.jsx.map +1 -0
- package/dist/source/ssr/client.d.ts +1 -0
- package/dist/source/ssr/client.js +2 -0
- package/dist/source/ssr/client.js.map +1 -0
- package/dist/source/ssr/defaultRenderHandler.d.ts +1 -0
- package/dist/source/ssr/defaultRenderHandler.jsx +9 -0
- package/dist/source/ssr/defaultRenderHandler.jsx.map +1 -0
- package/dist/source/ssr/defaultStreamHandler.d.ts +1 -0
- package/dist/source/ssr/defaultStreamHandler.jsx +10 -0
- package/dist/source/ssr/defaultStreamHandler.jsx.map +1 -0
- package/dist/source/ssr/renderRouterToStream.d.ts +8 -0
- package/dist/source/ssr/renderRouterToStream.jsx +17 -0
- package/dist/source/ssr/renderRouterToStream.jsx.map +1 -0
- package/dist/source/ssr/renderRouterToString.d.ts +7 -0
- package/dist/source/ssr/renderRouterToString.jsx +20 -0
- package/dist/source/ssr/renderRouterToString.jsx.map +1 -0
- package/dist/source/ssr/server.d.ts +6 -0
- package/dist/source/ssr/server.js +7 -0
- package/dist/source/ssr/server.js.map +1 -0
- package/dist/source/useBlocker.jsx +44 -27
- package/dist/source/useBlocker.jsx.map +1 -1
- package/dist/source/useNavigate.jsx +12 -2
- package/dist/source/useNavigate.jsx.map +1 -1
- package/package.json +34 -7
- package/src/Asset.tsx +76 -7
- package/src/ClientOnly.tsx +5 -32
- package/src/HeadContent.tsx +17 -0
- package/src/Match.tsx +103 -81
- package/src/Matches.tsx +28 -19
- package/src/ScriptOnce.tsx +1 -13
- package/src/Transitioner.tsx +7 -7
- package/src/index.tsx +1 -18
- package/src/lazyRouteComponent.tsx +6 -26
- package/src/link.tsx +29 -21
- package/src/not-found.tsx +1 -1
- package/src/route.tsx +16 -5
- package/src/scroll-restoration.tsx +10 -3
- package/src/ssr/RouterClient.tsx +43 -0
- package/src/ssr/RouterServer.tsx +60 -0
- package/src/ssr/client.ts +1 -0
- package/src/ssr/defaultRenderHandler.tsx +12 -0
- package/src/ssr/defaultStreamHandler.tsx +13 -0
- package/src/ssr/renderRouterToStream.tsx +36 -0
- package/src/ssr/renderRouterToString.tsx +31 -0
- package/src/ssr/server.ts +6 -0
- package/src/useBlocker.tsx +48 -32
- package/src/useNavigate.tsx +14 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scroll-restoration.jsx","sourceRoot":"","sources":["../../src/scroll-restoration.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,8BAA8B,EAC9B,aAAa,EACb,UAAU,GACX,MAAM,uBAAuB,CAAA;AAC9B,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAA;AAEzC,MAAM,UAAU,iBAAiB;IAC/B,MAAM,MAAM,GAAG,SAAS,EAAE,CAAA;IAC1B,MAAM,MAAM,GACV,MAAM,CAAC,OAAO,CAAC,uBAAuB,IAAI,8BAA8B,CAAA;IAC1E,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,CAAA;IAC7C,MAAM,WAAW,GACf,OAAO,KAAK,8BAA8B,CAAC,MAAM,CAAC,cAAc,CAAC;QAC/D,CAAC,CAAC,OAAO;QACT,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"scroll-restoration.jsx","sourceRoot":"","sources":["../../src/scroll-restoration.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,8BAA8B,EAC9B,aAAa,EACb,UAAU,GACX,MAAM,uBAAuB,CAAA;AAC9B,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AACvC,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAA;AAEzC,MAAM,UAAU,iBAAiB;IAC/B,MAAM,MAAM,GAAG,SAAS,EAAE,CAAA;IAC1B,MAAM,MAAM,GACV,MAAM,CAAC,OAAO,CAAC,uBAAuB,IAAI,8BAA8B,CAAA;IAC1E,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,CAAA;IAC7C,MAAM,WAAW,GACf,OAAO,KAAK,8BAA8B,CAAC,MAAM,CAAC,cAAc,CAAC;QAC/D,CAAC,CAAC,OAAO;QACT,CAAC,CAAC,SAAS,CAAA;IAEf,IAAI,CAAC,MAAM,CAAC,iBAAiB,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;QAClD,OAAO,IAAI,CAAA;IACb,CAAC;IAED,MAAM,oBAAoB,GAAwC;QAChE,UAAU;QACV,uBAAuB,EAAE,IAAI;KAC9B,CAAA;IACD,IAAI,WAAW,EAAE,CAAC;QAChB,oBAAoB,CAAC,GAAG,GAAG,WAAW,CAAA;IACxC,CAAC;IAED,OAAO,CACL,CAAC,UAAU,CACT,QAAQ,CAAC,CAAC,IAAI,aAAa,CAAC,QAAQ,EAAE,KAAK,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC,GAAG,CAAC,EACnF,CACH,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { hydrate } from '@tanstack/router-core/ssr/client';
|
|
2
|
+
import { Await } from '../awaited';
|
|
3
|
+
import { HeadContent } from '../HeadContent';
|
|
4
|
+
import { RouterProvider } from '../RouterProvider';
|
|
5
|
+
let hydrationPromise;
|
|
6
|
+
const Dummy = (props) => <>{props.children}</>;
|
|
7
|
+
export function RouterClient(props) {
|
|
8
|
+
if (!hydrationPromise) {
|
|
9
|
+
if (!props.router.state.matches.length) {
|
|
10
|
+
hydrationPromise = hydrate(props.router);
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
hydrationPromise = Promise.resolve();
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
return (<Await promise={hydrationPromise} children={() => (<Dummy>
|
|
17
|
+
<Dummy>
|
|
18
|
+
<RouterProvider router={props.router} InnerWrap={(props) => (<Dummy>
|
|
19
|
+
<Dummy>
|
|
20
|
+
<HeadContent />
|
|
21
|
+
{props.children}
|
|
22
|
+
</Dummy>
|
|
23
|
+
<Dummy />
|
|
24
|
+
</Dummy>)}/>
|
|
25
|
+
</Dummy>
|
|
26
|
+
</Dummy>)}/>);
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=RouterClient.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RouterClient.jsx","sourceRoot":"","sources":["../../../src/ssr/RouterClient.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,kCAAkC,CAAA;AAC1D,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAClC,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAIlD,IAAI,gBAAgE,CAAA;AAEpE,MAAM,KAAK,GAAG,CAAC,KAAgC,EAAE,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAA;AAEzE,MAAM,UAAU,YAAY,CAAC,KAA4B;IACvD,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACtB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;YACvC,gBAAgB,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;QAC1C,CAAC;aAAM,CAAC;YACN,gBAAgB,GAAG,OAAO,CAAC,OAAO,EAAE,CAAA;QACtC,CAAC;IACH,CAAC;IACD,OAAO,CACL,CAAC,KAAK,CACJ,OAAO,CAAC,CAAC,gBAAgB,CAAC,CAC1B,QAAQ,CAAC,CAAC,GAAG,EAAE,CAAC,CACd,CAAC,KAAK,CACJ;UAAA,CAAC,KAAK,CACJ;YAAA,CAAC,cAAc,CACb,MAAM,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CACrB,SAAS,CAAC,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CACpB,CAAC,KAAK,CACJ;kBAAA,CAAC,KAAK,CACJ;oBAAA,CAAC,WAAW,CAAC,AAAD,EACZ;oBAAA,CAAC,KAAK,CAAC,QAAQ,CACjB;kBAAA,EAAE,KAAK,CACP;kBAAA,CAAC,KAAK,CAAC,AAAD,EACR;gBAAA,EAAE,KAAK,CAAC,CACT,CAAC,EAEN;UAAA,EAAE,KAAK,CACT;QAAA,EAAE,KAAK,CAAC,CACT,CAAC,EACF,CACH,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { Hydration, HydrationScript, NoHydration, ssr, useAssets, } from 'solid-js/web';
|
|
2
|
+
import { MetaProvider } from '@solidjs/meta';
|
|
3
|
+
import { Asset } from '../Asset';
|
|
4
|
+
import { useTags } from '../HeadContent';
|
|
5
|
+
import { RouterProvider } from '../RouterProvider';
|
|
6
|
+
import { Scripts } from '../Scripts';
|
|
7
|
+
export function ServerHeadContent() {
|
|
8
|
+
const tags = useTags();
|
|
9
|
+
useAssets(() => {
|
|
10
|
+
return (<MetaProvider>
|
|
11
|
+
{tags().map((tag) => (<Asset {...tag}/>))}
|
|
12
|
+
</MetaProvider>);
|
|
13
|
+
});
|
|
14
|
+
return null;
|
|
15
|
+
}
|
|
16
|
+
const docType = ssr('<!DOCTYPE html>');
|
|
17
|
+
export function RouterServer(props) {
|
|
18
|
+
return (<NoHydration>
|
|
19
|
+
{docType}
|
|
20
|
+
<html>
|
|
21
|
+
<head>
|
|
22
|
+
<HydrationScript />
|
|
23
|
+
</head>
|
|
24
|
+
<body>
|
|
25
|
+
<Hydration>
|
|
26
|
+
<RouterProvider router={props.router} InnerWrap={(props) => (<NoHydration>
|
|
27
|
+
<MetaProvider>
|
|
28
|
+
<ServerHeadContent />
|
|
29
|
+
<Hydration>{props.children}</Hydration>
|
|
30
|
+
<Scripts />
|
|
31
|
+
</MetaProvider>
|
|
32
|
+
</NoHydration>)}/>
|
|
33
|
+
</Hydration>
|
|
34
|
+
</body>
|
|
35
|
+
</html>
|
|
36
|
+
</NoHydration>);
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=RouterServer.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RouterServer.jsx","sourceRoot":"","sources":["../../../src/ssr/RouterServer.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,eAAe,EACf,WAAW,EACX,GAAG,EACH,SAAS,GACV,MAAM,cAAc,CAAA;AACrB,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAA;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAA;AAChC,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAA;AACxC,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAClD,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAA;AAGpC,MAAM,UAAU,iBAAiB;IAC/B,MAAM,IAAI,GAAG,OAAO,EAAE,CAAA;IACtB,SAAS,CAAC,GAAG,EAAE;QACb,OAAO,CACL,CAAC,YAAY,CACX;QAAA,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CACnB,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,EAAG,CACnB,CAAC,CACJ;MAAA,EAAE,YAAY,CAAC,CAChB,CAAA;IACH,CAAC,CAAC,CAAA;IACF,OAAO,IAAI,CAAA;AACb,CAAC;AAED,MAAM,OAAO,GAAG,GAAG,CAAC,iBAAiB,CAAC,CAAA;AAEtC,MAAM,UAAU,YAAY,CAA4B,KAEvD;IACC,OAAO,CACL,CAAC,WAAW,CACV;MAAA,CAAC,OAAc,CACf;MAAA,CAAC,IAAI,CACH;QAAA,CAAC,IAAI,CACH;UAAA,CAAC,eAAe,CAAC,AAAD,EAClB;QAAA,EAAE,IAAI,CACN;QAAA,CAAC,IAAI,CACH;UAAA,CAAC,SAAS,CACR;YAAA,CAAC,cAAc,CACb,MAAM,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CACrB,SAAS,CAAC,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CACpB,CAAC,WAAW,CACV;kBAAA,CAAC,YAAY,CACX;oBAAA,CAAC,iBAAiB,CAAC,AAAD,EAClB;oBAAA,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,SAAS,CACtC;oBAAA,CAAC,OAAO,CAAC,AAAD,EACV;kBAAA,EAAE,YAAY,CAChB;gBAAA,EAAE,WAAW,CAAC,CACf,CAAC,EAEN;UAAA,EAAE,SAAS,CACb;QAAA,EAAE,IAAI,CACR;MAAA,EAAE,IAAI,CACR;IAAA,EAAE,WAAW,CAAC,CACf,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { RouterClient } from './RouterClient';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../../src/ssr/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const defaultRenderHandler: import("@tanstack/router-core/ssr/server").HandlerCallback<import("@tanstack/router-core").AnyRouter>;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { defineHandlerCallback } from '@tanstack/router-core/ssr/server';
|
|
2
|
+
import { RouterServer } from './RouterServer';
|
|
3
|
+
import { renderRouterToString } from './renderRouterToString';
|
|
4
|
+
export const defaultRenderHandler = defineHandlerCallback(({ router, responseHeaders }) => renderRouterToString({
|
|
5
|
+
router,
|
|
6
|
+
responseHeaders,
|
|
7
|
+
children: () => <RouterServer router={router}/>,
|
|
8
|
+
}));
|
|
9
|
+
//# sourceMappingURL=defaultRenderHandler.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"defaultRenderHandler.jsx","sourceRoot":"","sources":["../../../src/ssr/defaultRenderHandler.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAA;AACxE,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAC7C,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAA;AAE7D,MAAM,CAAC,MAAM,oBAAoB,GAAG,qBAAqB,CACvD,CAAC,EAAE,MAAM,EAAE,eAAe,EAAE,EAAE,EAAE,CAC9B,oBAAoB,CAAC;IACnB,MAAM;IACN,eAAe;IACf,QAAQ,EAAE,GAAG,EAAE,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,EAAG;CACjD,CAAC,CACL,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const defaultStreamHandler: import("@tanstack/router-core/ssr/server").HandlerCallback<import("@tanstack/router-core").AnyRouter>;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { defineHandlerCallback } from '@tanstack/router-core/ssr/server';
|
|
2
|
+
import { RouterServer } from './RouterServer';
|
|
3
|
+
import { renderRouterToStream } from './renderRouterToStream';
|
|
4
|
+
export const defaultStreamHandler = defineHandlerCallback(({ request, router, responseHeaders }) => renderRouterToStream({
|
|
5
|
+
request,
|
|
6
|
+
router,
|
|
7
|
+
responseHeaders,
|
|
8
|
+
children: () => <RouterServer router={router}/>,
|
|
9
|
+
}));
|
|
10
|
+
//# sourceMappingURL=defaultStreamHandler.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"defaultStreamHandler.jsx","sourceRoot":"","sources":["../../../src/ssr/defaultStreamHandler.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAA;AACxE,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAC7C,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAA;AAE7D,MAAM,CAAC,MAAM,oBAAoB,GAAG,qBAAqB,CACvD,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,eAAe,EAAE,EAAE,EAAE,CACvC,oBAAoB,CAAC;IACnB,OAAO;IACP,MAAM;IACN,eAAe;IACf,QAAQ,EAAE,GAAG,EAAE,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,EAAG;CACjD,CAAC,CACL,CAAA"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { JSXElement } from 'solid-js';
|
|
2
|
+
import type { AnyRouter } from '@tanstack/router-core';
|
|
3
|
+
export declare const renderRouterToStream: ({ request, router, responseHeaders, children, }: {
|
|
4
|
+
request: Request;
|
|
5
|
+
router: AnyRouter;
|
|
6
|
+
responseHeaders: Headers;
|
|
7
|
+
children: () => JSXElement;
|
|
8
|
+
}) => Promise<Response>;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import * as Solid from 'solid-js/web';
|
|
2
|
+
import { isbot } from 'isbot';
|
|
3
|
+
import { transformReadableStreamWithRouter } from '@tanstack/router-core/ssr/server';
|
|
4
|
+
export const renderRouterToStream = async ({ request, router, responseHeaders, children, }) => {
|
|
5
|
+
const { writable, readable } = new TransformStream();
|
|
6
|
+
const stream = Solid.renderToStream(children);
|
|
7
|
+
if (isbot(request.headers.get('User-Agent'))) {
|
|
8
|
+
await stream;
|
|
9
|
+
}
|
|
10
|
+
stream.pipeTo(writable);
|
|
11
|
+
const responseStream = transformReadableStreamWithRouter(router, readable);
|
|
12
|
+
return new Response(responseStream, {
|
|
13
|
+
status: router.state.statusCode,
|
|
14
|
+
headers: responseHeaders,
|
|
15
|
+
});
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=renderRouterToStream.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"renderRouterToStream.jsx","sourceRoot":"","sources":["../../../src/ssr/renderRouterToStream.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,KAAK,EAAE,MAAM,OAAO,CAAA;AAC7B,OAAO,EAAE,iCAAiC,EAAE,MAAM,kCAAkC,CAAA;AAKpF,MAAM,CAAC,MAAM,oBAAoB,GAAG,KAAK,EAAE,EACzC,OAAO,EACP,MAAM,EACN,eAAe,EACf,QAAQ,GAMT,EAAE,EAAE;IACH,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,IAAI,eAAe,EAAE,CAAA;IAEpD,MAAM,MAAM,GAAG,KAAK,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAA;IAE7C,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC;QAC7C,MAAM,MAAM,CAAA;IACd,CAAC;IACD,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;IAEvB,MAAM,cAAc,GAAG,iCAAiC,CACtD,MAAM,EACN,QAAqC,CACtC,CAAA;IACD,OAAO,IAAI,QAAQ,CAAC,cAAqB,EAAE;QACzC,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,UAAU;QAC/B,OAAO,EAAE,eAAe;KACzB,CAAC,CAAA;AACJ,CAAC,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { JSXElement } from 'solid-js';
|
|
2
|
+
import type { AnyRouter } from '@tanstack/router-core';
|
|
3
|
+
export declare const renderRouterToString: ({ router, responseHeaders, children, }: {
|
|
4
|
+
router: AnyRouter;
|
|
5
|
+
responseHeaders: Headers;
|
|
6
|
+
children: () => JSXElement;
|
|
7
|
+
}) => Promise<Response>;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import * as Solid from 'solid-js/web';
|
|
2
|
+
export const renderRouterToString = async ({ router, responseHeaders, children, }) => {
|
|
3
|
+
try {
|
|
4
|
+
let html = Solid.renderToString(children);
|
|
5
|
+
const injectedHtml = await Promise.all(router.serverSsr.injectedHtml).then((htmls) => htmls.join(''));
|
|
6
|
+
html = html.replace(`</body>`, `${injectedHtml}</body>`);
|
|
7
|
+
return new Response(html, {
|
|
8
|
+
status: router.state.statusCode,
|
|
9
|
+
headers: responseHeaders,
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
catch (error) {
|
|
13
|
+
console.error('Render to string error:', error);
|
|
14
|
+
return new Response('Internal Server Error', {
|
|
15
|
+
status: 500,
|
|
16
|
+
headers: responseHeaders,
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=renderRouterToString.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"renderRouterToString.jsx","sourceRoot":"","sources":["../../../src/ssr/renderRouterToString.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAA;AAIrC,MAAM,CAAC,MAAM,oBAAoB,GAAG,KAAK,EAAE,EACzC,MAAM,EACN,eAAe,EACf,QAAQ,GAKT,EAAE,EAAE;IACH,IAAI,CAAC;QACH,IAAI,IAAI,GAAG,KAAK,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAA;QACzC,MAAM,YAAY,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,SAAU,CAAC,YAAY,CAAC,CAAC,IAAI,CACzE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAC1B,CAAA;QACD,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,GAAG,YAAY,SAAS,CAAC,CAAA;QACxD,OAAO,IAAI,QAAQ,CAAC,IAAI,EAAE;YACxB,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,UAAU;YAC/B,OAAO,EAAE,eAAe;SACzB,CAAC,CAAA;IACJ,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,yBAAyB,EAAE,KAAK,CAAC,CAAA;QAC/C,OAAO,IAAI,QAAQ,CAAC,uBAAuB,EAAE;YAC3C,MAAM,EAAE,GAAG;YACX,OAAO,EAAE,eAAe;SACzB,CAAC,CAAA;IACJ,CAAC;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export { RouterServer } from './RouterServer';
|
|
2
|
+
export { defaultRenderHandler } from './defaultRenderHandler';
|
|
3
|
+
export { defaultStreamHandler } from './defaultStreamHandler';
|
|
4
|
+
export { renderRouterToStream } from './renderRouterToStream';
|
|
5
|
+
export { renderRouterToString } from './renderRouterToString';
|
|
6
|
+
export * from '@tanstack/router-core/ssr/server';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { RouterServer } from './RouterServer';
|
|
2
|
+
export { defaultRenderHandler } from './defaultRenderHandler';
|
|
3
|
+
export { defaultStreamHandler } from './defaultStreamHandler';
|
|
4
|
+
export { renderRouterToStream } from './renderRouterToStream';
|
|
5
|
+
export { renderRouterToString } from './renderRouterToString';
|
|
6
|
+
export * from '@tanstack/router-core/ssr/server';
|
|
7
|
+
//# sourceMappingURL=server.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"server.js","sourceRoot":"","sources":["../../../src/ssr/server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAC7C,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAA;AAC7D,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAA;AAC7D,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAA;AAC7D,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAA;AAC7D,cAAc,kCAAkC,CAAA"}
|
|
@@ -23,24 +23,32 @@ function _resolveBlockerOpts(opts, condition) {
|
|
|
23
23
|
withResolver: false,
|
|
24
24
|
};
|
|
25
25
|
}
|
|
26
|
-
const shouldBlock = Boolean(opts.condition ?? true);
|
|
27
|
-
const fn = opts.blockerFn;
|
|
26
|
+
const shouldBlock = Solid.createMemo(() => Boolean(opts.condition ?? true));
|
|
28
27
|
const _customBlockerFn = async () => {
|
|
29
|
-
if (shouldBlock &&
|
|
30
|
-
return await
|
|
28
|
+
if (shouldBlock() && opts.blockerFn !== undefined) {
|
|
29
|
+
return await opts.blockerFn();
|
|
31
30
|
}
|
|
32
|
-
return shouldBlock;
|
|
31
|
+
return shouldBlock();
|
|
33
32
|
};
|
|
34
33
|
return {
|
|
35
|
-
shouldBlockFn
|
|
36
|
-
|
|
37
|
-
|
|
34
|
+
get shouldBlockFn() {
|
|
35
|
+
return _customBlockerFn;
|
|
36
|
+
},
|
|
37
|
+
get enableBeforeUnload() {
|
|
38
|
+
return shouldBlock();
|
|
39
|
+
},
|
|
40
|
+
get withResolver() {
|
|
41
|
+
return opts.blockerFn === undefined;
|
|
42
|
+
},
|
|
38
43
|
};
|
|
39
44
|
}
|
|
40
45
|
export function useBlocker(opts, condition) {
|
|
41
|
-
const
|
|
46
|
+
const props = Solid.mergeProps({
|
|
47
|
+
enableBeforeUnload: true,
|
|
48
|
+
disabled: false,
|
|
49
|
+
withResolver: false,
|
|
50
|
+
}, _resolveBlockerOpts(opts, condition));
|
|
42
51
|
const router = useRouter();
|
|
43
|
-
const { history } = router;
|
|
44
52
|
const [resolver, setResolver] = Solid.createSignal({
|
|
45
53
|
status: 'idle',
|
|
46
54
|
current: undefined,
|
|
@@ -67,12 +75,12 @@ export function useBlocker(opts, condition) {
|
|
|
67
75
|
}
|
|
68
76
|
const current = getLocation(blockerFnArgs.currentLocation);
|
|
69
77
|
const next = getLocation(blockerFnArgs.nextLocation);
|
|
70
|
-
const shouldBlock = await shouldBlockFn({
|
|
78
|
+
const shouldBlock = await props.shouldBlockFn({
|
|
71
79
|
action: blockerFnArgs.action,
|
|
72
80
|
current,
|
|
73
81
|
next,
|
|
74
82
|
});
|
|
75
|
-
if (!withResolver) {
|
|
83
|
+
if (!props.withResolver) {
|
|
76
84
|
return shouldBlock;
|
|
77
85
|
}
|
|
78
86
|
if (!shouldBlock) {
|
|
@@ -99,38 +107,47 @@ export function useBlocker(opts, condition) {
|
|
|
99
107
|
});
|
|
100
108
|
return canNavigateAsync;
|
|
101
109
|
};
|
|
102
|
-
|
|
110
|
+
const disposeBlock = props.disabled
|
|
103
111
|
? undefined
|
|
104
|
-
: history.block({
|
|
112
|
+
: router.history.block({
|
|
113
|
+
blockerFn: blockerFnComposed,
|
|
114
|
+
enableBeforeUnload: props.enableBeforeUnload,
|
|
115
|
+
});
|
|
116
|
+
Solid.onCleanup(() => disposeBlock?.());
|
|
105
117
|
});
|
|
106
118
|
return resolver;
|
|
107
119
|
}
|
|
108
120
|
const _resolvePromptBlockerArgs = (props) => {
|
|
109
121
|
if ('shouldBlockFn' in props) {
|
|
110
|
-
return
|
|
122
|
+
return props;
|
|
111
123
|
}
|
|
112
|
-
const shouldBlock = Boolean(props.condition ?? true);
|
|
113
|
-
const fn = props.blockerFn;
|
|
124
|
+
const shouldBlock = Solid.createMemo(() => Boolean(props.condition ?? true));
|
|
114
125
|
const _customBlockerFn = async () => {
|
|
115
|
-
if (shouldBlock &&
|
|
116
|
-
return await
|
|
126
|
+
if (shouldBlock() && props.blockerFn !== undefined) {
|
|
127
|
+
return await props.blockerFn();
|
|
117
128
|
}
|
|
118
129
|
return shouldBlock;
|
|
119
130
|
};
|
|
120
131
|
return {
|
|
121
132
|
shouldBlockFn: _customBlockerFn,
|
|
122
|
-
enableBeforeUnload
|
|
123
|
-
|
|
133
|
+
get enableBeforeUnload() {
|
|
134
|
+
return shouldBlock();
|
|
135
|
+
},
|
|
136
|
+
get withResolver() {
|
|
137
|
+
return props.blockerFn === undefined;
|
|
138
|
+
},
|
|
124
139
|
};
|
|
125
140
|
};
|
|
126
141
|
export function Block(opts) {
|
|
127
|
-
const
|
|
142
|
+
const [propsWithChildren, rest] = Solid.splitProps(opts, ['children']);
|
|
128
143
|
const args = _resolvePromptBlockerArgs(rest);
|
|
129
144
|
const resolver = useBlocker(args);
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
145
|
+
const children = Solid.createMemo(() => {
|
|
146
|
+
const child = propsWithChildren.children;
|
|
147
|
+
if (resolver && typeof child === 'function')
|
|
148
|
+
return child(resolver());
|
|
149
|
+
return child;
|
|
150
|
+
});
|
|
151
|
+
return <>{children()}</>;
|
|
135
152
|
}
|
|
136
153
|
//# sourceMappingURL=useBlocker.jsx.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useBlocker.jsx","sourceRoot":"","sources":["../../src/useBlocker.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,UAAU,CAAA;AACjC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AAmFvC,SAAS,mBAAmB,CAC1B,IAA2D,EAC3D,SAAyB;IAEzB,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;QACvB,OAAO;YACL,aAAa,EAAE,GAAG,EAAE,CAAC,IAAI;YACzB,YAAY,EAAE,KAAK;SACpB,CAAA;IACH,CAAC;IAED,IAAI,eAAe,IAAI,IAAI,EAAE,CAAC;QAC5B,OAAO,IAAI,CAAA;IACb,CAAC;IAED,IAAI,OAAO,IAAI,KAAK,UAAU,EAAE,CAAC;QAC/B,MAAM,WAAW,GAAG,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,CAAA;QAE9C,MAAM,gBAAgB,GAAG,KAAK,IAAI,EAAE;YAClC,IAAI,WAAW;gBAAE,OAAO,MAAM,IAAI,EAAE,CAAA;YACpC,OAAO,KAAK,CAAA;QACd,CAAC,CAAA;QAED,OAAO;YACL,aAAa,EAAE,gBAAgB;YAC/B,kBAAkB,EAAE,WAAW;YAC/B,YAAY,EAAE,KAAK;SACpB,CAAA;IACH,CAAC;IAED,MAAM,WAAW,GAAG,
|
|
1
|
+
{"version":3,"file":"useBlocker.jsx","sourceRoot":"","sources":["../../src/useBlocker.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,9 +1,19 @@
|
|
|
1
1
|
import * as Solid from 'solid-js';
|
|
2
2
|
import { useRouter } from './useRouter';
|
|
3
|
+
import { useMatch } from './useMatch';
|
|
3
4
|
export function useNavigate(_defaultOpts) {
|
|
4
|
-
const { navigate } = useRouter();
|
|
5
|
+
const { navigate, state } = useRouter();
|
|
6
|
+
const matchIndex = useMatch({
|
|
7
|
+
strict: false,
|
|
8
|
+
select: (match) => match.index,
|
|
9
|
+
});
|
|
5
10
|
return ((options) => {
|
|
6
|
-
return navigate({
|
|
11
|
+
return navigate({
|
|
12
|
+
...options,
|
|
13
|
+
from: options.from ??
|
|
14
|
+
_defaultOpts?.from ??
|
|
15
|
+
state.matches[matchIndex()].fullPath,
|
|
16
|
+
});
|
|
7
17
|
});
|
|
8
18
|
}
|
|
9
19
|
export function Navigate(props) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useNavigate.jsx","sourceRoot":"","sources":["../../src/useNavigate.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,UAAU,CAAA;AACjC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;
|
|
1
|
+
{"version":3,"file":"useNavigate.jsx","sourceRoot":"","sources":["../../src/useNavigate.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,UAAU,CAAA;AACjC,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AASrC,MAAM,UAAU,WAAW,CAGzB,YAED;IACC,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,SAAS,EAAE,CAAA;IAEvC,MAAM,UAAU,GAAG,QAAQ,CAAC;QAC1B,MAAM,EAAE,KAAK;QACb,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK;KAC/B,CAAC,CAAA;IAEF,OAAO,CAAC,CAAC,OAAwB,EAAE,EAAE;QACnC,OAAO,QAAQ,CAAC;YACd,GAAG,OAAO;YACV,IAAI,EACF,OAAO,CAAC,IAAI;gBACZ,YAAY,EAAE,IAAI;gBAClB,KAAK,CAAC,OAAO,CAAC,UAAU,EAAE,CAAE,CAAC,QAAQ;SACxC,CAAC,CAAA;IACJ,CAAC,CAAoC,CAAA;AACvC,CAAC;AAED,MAAM,UAAU,QAAQ,CAMtB,KAA+D;IAC/D,MAAM,EAAE,QAAQ,EAAE,GAAG,SAAS,EAAE,CAAA;IAEhC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACjB,QAAQ,CAAC;YACP,GAAG,KAAK;SACT,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,OAAO,IAAI,CAAA;AACb,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tanstack/solid-router",
|
|
3
|
-
"version": "1.121.0-alpha.
|
|
3
|
+
"version": "1.121.0-alpha.28",
|
|
4
4
|
"description": "Modern and scalable routing for Solid applications",
|
|
5
5
|
"author": "Tanner Linsley",
|
|
6
6
|
"license": "MIT",
|
|
@@ -42,6 +42,34 @@
|
|
|
42
42
|
"default": "./dist/cjs/index.cjs"
|
|
43
43
|
}
|
|
44
44
|
},
|
|
45
|
+
"./ssr/server": {
|
|
46
|
+
"solid": {
|
|
47
|
+
"types": "./dist/source/ssr/server.d.ts",
|
|
48
|
+
"default": "./dist/source/ssr/server.js"
|
|
49
|
+
},
|
|
50
|
+
"import": {
|
|
51
|
+
"types": "./dist/esm/ssr/server.d.ts",
|
|
52
|
+
"default": "./dist/esm/ssr/server.js"
|
|
53
|
+
},
|
|
54
|
+
"require": {
|
|
55
|
+
"types": "./dist/cjs/ssr/server.d.cts",
|
|
56
|
+
"default": "./dist/cjs/ssr/server.cjs"
|
|
57
|
+
}
|
|
58
|
+
},
|
|
59
|
+
"./ssr/client": {
|
|
60
|
+
"solid": {
|
|
61
|
+
"types": "./dist/source/ssr/client.d.ts",
|
|
62
|
+
"default": "./dist/source/ssr/client.js"
|
|
63
|
+
},
|
|
64
|
+
"import": {
|
|
65
|
+
"types": "./dist/esm/ssr/client.d.ts",
|
|
66
|
+
"default": "./dist/esm/ssr/client.js"
|
|
67
|
+
},
|
|
68
|
+
"require": {
|
|
69
|
+
"types": "./dist/cjs/ssr/client.d.cts",
|
|
70
|
+
"default": "./dist/cjs/ssr/client.cjs"
|
|
71
|
+
}
|
|
72
|
+
},
|
|
45
73
|
"./package.json": "./package.json"
|
|
46
74
|
},
|
|
47
75
|
"sideEffects": false,
|
|
@@ -56,21 +84,20 @@
|
|
|
56
84
|
"@solid-devtools/logger": "^0.9.4",
|
|
57
85
|
"@solid-primitives/refs": "^1.0.8",
|
|
58
86
|
"@solidjs/meta": "^0.29.4",
|
|
59
|
-
"@tanstack/solid-store": "
|
|
60
|
-
"
|
|
87
|
+
"@tanstack/solid-store": "0.7.0",
|
|
88
|
+
"isbot": "^5.1.22",
|
|
61
89
|
"tiny-invariant": "^1.3.3",
|
|
62
90
|
"tiny-warning": "^1.0.3",
|
|
63
|
-
"@tanstack/
|
|
64
|
-
"@tanstack/
|
|
91
|
+
"@tanstack/history": "1.121.0-alpha.28",
|
|
92
|
+
"@tanstack/router-core": "1.121.0-alpha.28"
|
|
65
93
|
},
|
|
66
94
|
"devDependencies": {
|
|
67
95
|
"@solidjs/testing-library": "^0.8.10",
|
|
68
96
|
"@testing-library/jest-dom": "^6.6.3",
|
|
69
|
-
"@types/jsesc": "^3.0.3",
|
|
70
97
|
"combinate": "^1.1.11",
|
|
71
98
|
"eslint-plugin-solid": "^0.14.5",
|
|
72
99
|
"solid-js": "^1.9.5",
|
|
73
|
-
"vite-plugin-solid": "^2.11.
|
|
100
|
+
"vite-plugin-solid": "^2.11.8",
|
|
74
101
|
"zod": "^3.23.8"
|
|
75
102
|
},
|
|
76
103
|
"peerDependencies": {
|
package/src/Asset.tsx
CHANGED
|
@@ -1,7 +1,13 @@
|
|
|
1
1
|
import { Meta, Style, Title } from '@solidjs/meta'
|
|
2
|
+
import { onCleanup, onMount } from 'solid-js'
|
|
2
3
|
import type { RouterManagedTag } from '@tanstack/router-core'
|
|
4
|
+
import type { JSX } from 'solid-js'
|
|
3
5
|
|
|
4
|
-
export function Asset({
|
|
6
|
+
export function Asset({
|
|
7
|
+
tag,
|
|
8
|
+
attrs,
|
|
9
|
+
children,
|
|
10
|
+
}: RouterManagedTag): JSX.Element | null {
|
|
5
11
|
switch (tag) {
|
|
6
12
|
case 'title':
|
|
7
13
|
return <Title {...attrs}>{children}</Title>
|
|
@@ -12,13 +18,76 @@ export function Asset({ tag, attrs, children }: RouterManagedTag): any {
|
|
|
12
18
|
case 'style':
|
|
13
19
|
return <Style {...attrs} innerHTML={children} />
|
|
14
20
|
case 'script':
|
|
15
|
-
|
|
16
|
-
return <script {...attrs} />
|
|
17
|
-
}
|
|
18
|
-
if (typeof children === 'string')
|
|
19
|
-
return <script {...attrs} innerHTML={children} />
|
|
20
|
-
return null
|
|
21
|
+
return <Script attrs={attrs}>{children}</Script>
|
|
21
22
|
default:
|
|
22
23
|
return null
|
|
23
24
|
}
|
|
24
25
|
}
|
|
26
|
+
|
|
27
|
+
interface ScriptAttrs {
|
|
28
|
+
[key: string]: string | boolean | undefined
|
|
29
|
+
src?: string
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
function Script({
|
|
33
|
+
attrs,
|
|
34
|
+
children,
|
|
35
|
+
}: {
|
|
36
|
+
attrs?: ScriptAttrs
|
|
37
|
+
children?: string
|
|
38
|
+
}): JSX.Element | null {
|
|
39
|
+
onMount(() => {
|
|
40
|
+
if (attrs?.src) {
|
|
41
|
+
const script = document.createElement('script')
|
|
42
|
+
|
|
43
|
+
for (const [key, value] of Object.entries(attrs)) {
|
|
44
|
+
if (value !== undefined && value !== false) {
|
|
45
|
+
script.setAttribute(
|
|
46
|
+
key,
|
|
47
|
+
typeof value === 'boolean' ? '' : String(value),
|
|
48
|
+
)
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
document.head.appendChild(script)
|
|
53
|
+
|
|
54
|
+
onCleanup(() => {
|
|
55
|
+
if (script.parentNode) {
|
|
56
|
+
script.parentNode.removeChild(script)
|
|
57
|
+
}
|
|
58
|
+
})
|
|
59
|
+
} else if (typeof children === 'string') {
|
|
60
|
+
const script = document.createElement('script')
|
|
61
|
+
script.textContent = children
|
|
62
|
+
|
|
63
|
+
if (attrs) {
|
|
64
|
+
for (const [key, value] of Object.entries(attrs)) {
|
|
65
|
+
if (value !== undefined && value !== false) {
|
|
66
|
+
script.setAttribute(
|
|
67
|
+
key,
|
|
68
|
+
typeof value === 'boolean' ? '' : String(value),
|
|
69
|
+
)
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
document.head.appendChild(script)
|
|
75
|
+
|
|
76
|
+
onCleanup(() => {
|
|
77
|
+
if (script.parentNode) {
|
|
78
|
+
script.parentNode.removeChild(script)
|
|
79
|
+
}
|
|
80
|
+
})
|
|
81
|
+
}
|
|
82
|
+
})
|
|
83
|
+
|
|
84
|
+
if (attrs?.src && typeof attrs.src === 'string') {
|
|
85
|
+
return <script {...attrs} />
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
if (typeof children === 'string') {
|
|
89
|
+
return <script {...attrs} innerHTML={children} />
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
return null
|
|
93
|
+
}
|
package/src/ClientOnly.tsx
CHANGED
|
@@ -30,36 +30,9 @@ export interface ClientOnlyProps {
|
|
|
30
30
|
* ```
|
|
31
31
|
*/
|
|
32
32
|
export function ClientOnly(props: ClientOnlyProps) {
|
|
33
|
-
return
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
* When doing Server-Side Rendering, the result will always be false.
|
|
39
|
-
* When doing Client-Side Rendering, the result will always be false on the
|
|
40
|
-
* first render and true from then on. Even if a new component renders it will
|
|
41
|
-
* always start with true.
|
|
42
|
-
*
|
|
43
|
-
* @example
|
|
44
|
-
* ```tsx
|
|
45
|
-
* // Disable a button that needs JS to work.
|
|
46
|
-
* let hydrated = useHydrated()
|
|
47
|
-
* return (
|
|
48
|
-
* <button type="button" disabled={!hydrated()} onClick={doSomethingCustom}>
|
|
49
|
-
* Click me
|
|
50
|
-
* </button>
|
|
51
|
-
* )
|
|
52
|
-
* ```
|
|
53
|
-
* @returns A signal accessor function that returns true if the JS has been hydrated already, false otherwise.
|
|
54
|
-
*/
|
|
55
|
-
export function useHydrated() {
|
|
56
|
-
const [hydrated, setHydrated] = Solid.createSignal(!isServer)
|
|
57
|
-
|
|
58
|
-
if (!isServer) {
|
|
59
|
-
Solid.createEffect(() => {
|
|
60
|
-
setHydrated(true)
|
|
61
|
-
})
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
return hydrated
|
|
33
|
+
return (
|
|
34
|
+
<Solid.Show when={!isServer} fallback={props.fallback}>
|
|
35
|
+
<>{props.children}</>
|
|
36
|
+
</Solid.Show>
|
|
37
|
+
)
|
|
65
38
|
}
|