@tanstack/react-router
Version:
Modern and scalable routing for React applications
57 lines (56 loc) • 1.83 kB
JavaScript
import { jsx, Fragment } from "react/jsx-runtime";
import { createElement } from "react";
import { Asset } from "./Asset.js";
import { useRouterState } from "./useRouterState.js";
import { useRouter } from "./useRouter.js";
const Scripts = () => {
const router = useRouter();
const nonce = router.options.ssr?.nonce;
const assetScripts = useRouterState({
select: (state) => {
const assetScripts2 = [];
const manifest = router.ssr?.manifest;
if (!manifest) {
return [];
}
state.matches.map((match) => router.looseRoutesById[match.routeId]).forEach(
(route) => manifest.routes[route.id]?.assets?.filter((d) => d.tag === "script").forEach((asset) => {
assetScripts2.push({
tag: "script",
attrs: { ...asset.attrs, nonce },
children: asset.children
});
})
);
return assetScripts2;
},
structuralSharing: true
});
const { scripts } = useRouterState({
select: (state) => ({
scripts: state.matches.map((match) => match.scripts).flat(1).filter(Boolean).map(({ children, ...script }) => ({
tag: "script",
attrs: {
...script,
suppressHydrationWarning: true,
nonce
},
children
}))
}),
structuralSharing: true
});
let serverBufferedScript = void 0;
if (router.serverSsr) {
serverBufferedScript = router.serverSsr.takeBufferedScripts();
}
const allScripts = [...scripts, ...assetScripts];
if (serverBufferedScript) {
allScripts.unshift(serverBufferedScript);
}
return /* @__PURE__ */ jsx(Fragment, { children: allScripts.map((asset, i) => /* @__PURE__ */ createElement(Asset, { ...asset, key: `tsr-scripts-${asset.tag}-${i}` })) });
};
export {
Scripts
};
//# sourceMappingURL=Scripts.js.map