@tanstack/start-plugin-core 1.20.3-alpha.1
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/LICENSE +21 -0
- package/README.md +12 -0
- package/dist/cjs/compilers.cjs +402 -0
- package/dist/cjs/compilers.cjs.map +1 -0
- package/dist/cjs/compilers.d.cts +21 -0
- package/dist/cjs/extractHtmlScripts.cjs +35 -0
- package/dist/cjs/extractHtmlScripts.cjs.map +1 -0
- package/dist/cjs/extractHtmlScripts.d.cts +4 -0
- package/dist/cjs/index.cjs +15 -0
- package/dist/cjs/index.cjs.map +1 -0
- package/dist/cjs/index.d.cts +7 -0
- package/dist/cjs/nitro/build-nitro.cjs +18 -0
- package/dist/cjs/nitro/build-nitro.cjs.map +1 -0
- package/dist/cjs/nitro/build-nitro.d.cts +2 -0
- package/dist/cjs/nitro/build-sitemap.cjs +54 -0
- package/dist/cjs/nitro/build-sitemap.cjs.map +1 -0
- package/dist/cjs/nitro/build-sitemap.d.cts +9 -0
- package/dist/cjs/nitro/dev-server-plugin.cjs +128 -0
- package/dist/cjs/nitro/dev-server-plugin.cjs.map +1 -0
- package/dist/cjs/nitro/dev-server-plugin.d.cts +5 -0
- package/dist/cjs/nitro/nitro-plugin.cjs +128 -0
- package/dist/cjs/nitro/nitro-plugin.cjs.map +1 -0
- package/dist/cjs/nitro/nitro-plugin.d.cts +3 -0
- package/dist/cjs/plugin.cjs +117 -0
- package/dist/cjs/plugin.cjs.map +1 -0
- package/dist/cjs/plugin.d.cts +2713 -0
- package/dist/cjs/prerender.cjs +171 -0
- package/dist/cjs/prerender.cjs.map +1 -0
- package/dist/cjs/prerender.d.cts +8 -0
- package/dist/cjs/queue.cjs +131 -0
- package/dist/cjs/queue.cjs.map +1 -0
- package/dist/cjs/queue.d.cts +32 -0
- package/dist/cjs/routesManifestPlugin.cjs +165 -0
- package/dist/cjs/routesManifestPlugin.cjs.map +1 -0
- package/dist/cjs/routesManifestPlugin.d.cts +3 -0
- package/dist/cjs/schema.cjs +136 -0
- package/dist/cjs/schema.cjs.map +1 -0
- package/dist/cjs/schema.d.cts +8128 -0
- package/dist/cjs/start-compiler-plugin.cjs +72 -0
- package/dist/cjs/start-compiler-plugin.cjs.map +1 -0
- package/dist/cjs/start-compiler-plugin.d.cts +13 -0
- package/dist/cjs/start-server-routes-plugin/config.d.cts +49 -0
- package/dist/cjs/start-server-routes-plugin/plugin.cjs +608 -0
- package/dist/cjs/start-server-routes-plugin/plugin.cjs.map +1 -0
- package/dist/cjs/start-server-routes-plugin/plugin.d.cts +3 -0
- package/dist/cjs/start-server-routes-plugin/template.cjs +111 -0
- package/dist/cjs/start-server-routes-plugin/template.cjs.map +1 -0
- package/dist/cjs/start-server-routes-plugin/template.d.cts +34 -0
- package/dist/esm/compilers.d.ts +21 -0
- package/dist/esm/compilers.js +384 -0
- package/dist/esm/compilers.js.map +1 -0
- package/dist/esm/extractHtmlScripts.d.ts +4 -0
- package/dist/esm/extractHtmlScripts.js +18 -0
- package/dist/esm/extractHtmlScripts.js.map +1 -0
- package/dist/esm/index.d.ts +7 -0
- package/dist/esm/index.js +15 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/nitro/build-nitro.d.ts +2 -0
- package/dist/esm/nitro/build-nitro.js +18 -0
- package/dist/esm/nitro/build-nitro.js.map +1 -0
- package/dist/esm/nitro/build-sitemap.d.ts +9 -0
- package/dist/esm/nitro/build-sitemap.js +54 -0
- package/dist/esm/nitro/build-sitemap.js.map +1 -0
- package/dist/esm/nitro/dev-server-plugin.d.ts +5 -0
- package/dist/esm/nitro/dev-server-plugin.js +128 -0
- package/dist/esm/nitro/dev-server-plugin.js.map +1 -0
- package/dist/esm/nitro/nitro-plugin.d.ts +3 -0
- package/dist/esm/nitro/nitro-plugin.js +128 -0
- package/dist/esm/nitro/nitro-plugin.js.map +1 -0
- package/dist/esm/plugin.d.ts +2713 -0
- package/dist/esm/plugin.js +117 -0
- package/dist/esm/plugin.js.map +1 -0
- package/dist/esm/prerender.d.ts +8 -0
- package/dist/esm/prerender.js +171 -0
- package/dist/esm/prerender.js.map +1 -0
- package/dist/esm/queue.d.ts +32 -0
- package/dist/esm/queue.js +131 -0
- package/dist/esm/queue.js.map +1 -0
- package/dist/esm/routesManifestPlugin.d.ts +3 -0
- package/dist/esm/routesManifestPlugin.js +165 -0
- package/dist/esm/routesManifestPlugin.js.map +1 -0
- package/dist/esm/schema.d.ts +8128 -0
- package/dist/esm/schema.js +136 -0
- package/dist/esm/schema.js.map +1 -0
- package/dist/esm/start-compiler-plugin.d.ts +13 -0
- package/dist/esm/start-compiler-plugin.js +72 -0
- package/dist/esm/start-compiler-plugin.js.map +1 -0
- package/dist/esm/start-server-routes-plugin/config.d.ts +49 -0
- package/dist/esm/start-server-routes-plugin/plugin.d.ts +3 -0
- package/dist/esm/start-server-routes-plugin/plugin.js +608 -0
- package/dist/esm/start-server-routes-plugin/plugin.js.map +1 -0
- package/dist/esm/start-server-routes-plugin/template.d.ts +34 -0
- package/dist/esm/start-server-routes-plugin/template.js +111 -0
- package/dist/esm/start-server-routes-plugin/template.js.map +1 -0
- package/package.json +72 -0
- package/src/compilers.ts +759 -0
- package/src/extractHtmlScripts.ts +19 -0
- package/src/index.ts +15 -0
- package/src/nitro/build-nitro.ts +27 -0
- package/src/nitro/build-sitemap.ts +79 -0
- package/src/nitro/dev-server-plugin.ts +159 -0
- package/src/nitro/nitro-plugin.ts +161 -0
- package/src/plugin.ts +145 -0
- package/src/prerender.ts +245 -0
- package/src/queue.ts +153 -0
- package/src/routesManifestPlugin.ts +216 -0
- package/src/schema.ts +193 -0
- package/src/start-compiler-plugin.ts +111 -0
- package/src/start-server-routes-plugin/config.ts +8 -0
- package/src/start-server-routes-plugin/plugin.ts +890 -0
- package/src/start-server-routes-plugin/template.ts +164 -0
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const fs = require("node:fs");
|
|
4
|
+
const os = require("node:os");
|
|
5
|
+
const path = require("node:path");
|
|
6
|
+
const rollup = require("nitropack/rollup");
|
|
7
|
+
const nitropack = require("nitropack");
|
|
8
|
+
const ufo = require("ufo");
|
|
9
|
+
const queue = require("./queue.cjs");
|
|
10
|
+
const buildNitro = require("./nitro/build-nitro.cjs");
|
|
11
|
+
async function prerender({
|
|
12
|
+
options,
|
|
13
|
+
nitro,
|
|
14
|
+
builder
|
|
15
|
+
}) {
|
|
16
|
+
var _a;
|
|
17
|
+
nitro.logger.info("Prendering pages...");
|
|
18
|
+
if (((_a = options.prerender) == null ? void 0 : _a.enabled) && !options.pages.length) {
|
|
19
|
+
options.pages = [
|
|
20
|
+
{
|
|
21
|
+
path: "/"
|
|
22
|
+
}
|
|
23
|
+
];
|
|
24
|
+
}
|
|
25
|
+
const serverEnv = builder.environments["server"];
|
|
26
|
+
if (!serverEnv) {
|
|
27
|
+
throw new Error(`Vite's "server" environment not found`);
|
|
28
|
+
}
|
|
29
|
+
const prerenderOutputDir = path.resolve(
|
|
30
|
+
options.root,
|
|
31
|
+
".tanstack-start/build/prerenderer"
|
|
32
|
+
);
|
|
33
|
+
const nodeNitro = await nitropack.createNitro({
|
|
34
|
+
...nitro.options._config,
|
|
35
|
+
preset: "nitro-prerender",
|
|
36
|
+
logLevel: 0,
|
|
37
|
+
output: {
|
|
38
|
+
dir: prerenderOutputDir,
|
|
39
|
+
serverDir: path.resolve(prerenderOutputDir, "server"),
|
|
40
|
+
publicDir: path.resolve(prerenderOutputDir, "public")
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
const nodeNitroRollupOptions = rollup.getRollupConfig(nodeNitro);
|
|
44
|
+
const build = serverEnv.config.build;
|
|
45
|
+
build.outDir = prerenderOutputDir;
|
|
46
|
+
build.rollupOptions = {
|
|
47
|
+
...build.rollupOptions,
|
|
48
|
+
...nodeNitroRollupOptions,
|
|
49
|
+
output: {
|
|
50
|
+
...build.rollupOptions.output,
|
|
51
|
+
...nodeNitroRollupOptions.output,
|
|
52
|
+
sourcemap: void 0
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
await buildNitro.buildNitroEnvironment(nodeNitro, () => nitropack.build(nodeNitro));
|
|
56
|
+
const serverFilename = typeof nodeNitroRollupOptions.output.entryFileNames === "string" ? nodeNitroRollupOptions.output.entryFileNames : "index.mjs";
|
|
57
|
+
const serverEntrypoint = path.resolve(
|
|
58
|
+
path.join(nodeNitro.options.output.serverDir, serverFilename)
|
|
59
|
+
);
|
|
60
|
+
const { closePrerenderer, localFetch } = await import(serverEntrypoint);
|
|
61
|
+
try {
|
|
62
|
+
const pages = await prerenderPages();
|
|
63
|
+
nitro.logger.info(`Prerendered ${pages.length} pages:`);
|
|
64
|
+
pages.forEach((page) => {
|
|
65
|
+
nitro.logger.info(`- ${page}`);
|
|
66
|
+
});
|
|
67
|
+
} catch (error) {
|
|
68
|
+
nitro.logger.error(error);
|
|
69
|
+
} finally {
|
|
70
|
+
closePrerenderer();
|
|
71
|
+
}
|
|
72
|
+
function extractLinks(html) {
|
|
73
|
+
const linkRegex = /<a[^>]+href=["']([^"']+)["'][^>]*>/g;
|
|
74
|
+
const links = [];
|
|
75
|
+
let match;
|
|
76
|
+
while ((match = linkRegex.exec(html)) !== null) {
|
|
77
|
+
const href = match[1];
|
|
78
|
+
if (href && (href.startsWith("/") || href.startsWith("./"))) {
|
|
79
|
+
links.push(href);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
return links;
|
|
83
|
+
}
|
|
84
|
+
async function prerenderPages() {
|
|
85
|
+
var _a2;
|
|
86
|
+
const seen = /* @__PURE__ */ new Set();
|
|
87
|
+
const retriesByPath = /* @__PURE__ */ new Map();
|
|
88
|
+
const concurrency = ((_a2 = options.prerender) == null ? void 0 : _a2.concurrency) ?? os.cpus().length;
|
|
89
|
+
nitro.logger.info(`Concurrency: ${concurrency}`);
|
|
90
|
+
const queue$1 = new queue.Queue({ concurrency });
|
|
91
|
+
options.pages.forEach((_page) => {
|
|
92
|
+
let page = _page;
|
|
93
|
+
if (typeof _page === "string") {
|
|
94
|
+
page = { path: _page };
|
|
95
|
+
}
|
|
96
|
+
addCrawlPageTask(page);
|
|
97
|
+
});
|
|
98
|
+
await queue$1.start();
|
|
99
|
+
return Array.from(seen);
|
|
100
|
+
function addCrawlPageTask(page) {
|
|
101
|
+
var _a3, _b;
|
|
102
|
+
if (seen.has(page.path)) return;
|
|
103
|
+
seen.add(page.path);
|
|
104
|
+
if (page.fromCrawl) {
|
|
105
|
+
options.pages.push(page);
|
|
106
|
+
}
|
|
107
|
+
if (!(((_a3 = page.prerender) == null ? void 0 : _a3.enabled) ?? true)) return;
|
|
108
|
+
if (((_b = options.prerender) == null ? void 0 : _b.filter) && !options.prerender.filter(page)) return;
|
|
109
|
+
const prerenderOptions = {
|
|
110
|
+
...options.prerender,
|
|
111
|
+
...page.prerender
|
|
112
|
+
};
|
|
113
|
+
queue$1.add(async () => {
|
|
114
|
+
var _a4;
|
|
115
|
+
nitro.logger.info(`Crawling: ${page.path}`);
|
|
116
|
+
const retries = retriesByPath.get(page.path) || 0;
|
|
117
|
+
try {
|
|
118
|
+
const encodedRoute = encodeURI(page.path);
|
|
119
|
+
const res = await localFetch(
|
|
120
|
+
ufo.withBase(encodedRoute, nodeNitro.options.baseURL),
|
|
121
|
+
{
|
|
122
|
+
headers: { "x-nitro-prerender": encodedRoute }
|
|
123
|
+
}
|
|
124
|
+
);
|
|
125
|
+
if (!res.ok) {
|
|
126
|
+
throw new Error(`Failed to fetch ${page.path}: ${res.statusText}`);
|
|
127
|
+
}
|
|
128
|
+
const contentType = res.headers.get("content-type") || "";
|
|
129
|
+
const isImplicitHTML = !page.path.endsWith(".html") && contentType.includes("html");
|
|
130
|
+
const routeWithIndex = page.path.endsWith("/") ? page.path + "index" : page.path;
|
|
131
|
+
const htmlPath = page.path.endsWith("/") || prerenderOptions.autoSubfolderIndex ? ufo.joinURL(page.path, "index.html") : page.path + ".html";
|
|
132
|
+
const filename = ufo.withoutBase(
|
|
133
|
+
isImplicitHTML ? htmlPath : routeWithIndex,
|
|
134
|
+
nitro.options.baseURL
|
|
135
|
+
);
|
|
136
|
+
const html = await res.text();
|
|
137
|
+
const filepath = path.join(nitro.options.output.publicDir, filename);
|
|
138
|
+
await fs.promises.mkdir(path.dirname(filepath), {
|
|
139
|
+
recursive: true
|
|
140
|
+
});
|
|
141
|
+
await fs.promises.writeFile(filepath, html);
|
|
142
|
+
const newPage = await ((_a4 = prerenderOptions.onSuccess) == null ? void 0 : _a4.call(prerenderOptions, { page, html }));
|
|
143
|
+
if (newPage) {
|
|
144
|
+
Object.assign(page, newPage);
|
|
145
|
+
}
|
|
146
|
+
if (prerenderOptions.crawlLinks ?? true) {
|
|
147
|
+
const links = extractLinks(html);
|
|
148
|
+
for (const link of links) {
|
|
149
|
+
addCrawlPageTask({ path: link, fromCrawl: true });
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
} catch (error) {
|
|
153
|
+
if (retries < (prerenderOptions.retryCount ?? 0)) {
|
|
154
|
+
nitro.logger.warn(
|
|
155
|
+
`Encountered error, retrying: ${page.path} in 500ms`
|
|
156
|
+
);
|
|
157
|
+
await new Promise(
|
|
158
|
+
(resolve) => setTimeout(resolve, prerenderOptions.retryDelay)
|
|
159
|
+
);
|
|
160
|
+
retriesByPath.set(page.path, retries + 1);
|
|
161
|
+
addCrawlPageTask(page);
|
|
162
|
+
} else {
|
|
163
|
+
throw error;
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
exports.prerender = prerender;
|
|
171
|
+
//# sourceMappingURL=prerender.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prerender.cjs","sources":["../../src/prerender.ts"],"sourcesContent":["import { promises as fsp } from 'node:fs'\nimport os from 'node:os'\nimport path from 'node:path'\nimport { getRollupConfig } from 'nitropack/rollup'\nimport { build as buildNitro, createNitro } from 'nitropack'\nimport { joinURL, withBase, withoutBase } from 'ufo'\nimport { Queue } from './queue'\nimport { buildNitroEnvironment } from './nitro/build-nitro'\nimport type { ViteBuilder } from 'vite'\nimport type { $Fetch, Nitro } from 'nitropack'\nimport type { TanStackStartOutputConfig } from './plugin'\nimport type { Page } from './schema'\n\nexport async function prerender({\n options,\n nitro,\n builder,\n}: {\n options: TanStackStartOutputConfig\n nitro: Nitro\n builder: ViteBuilder\n}) {\n nitro.logger.info('Prendering pages...')\n\n // If prerender is enabled but no pages are provided, default to prerendering the root page\n if (options.prerender?.enabled && !options.pages.length) {\n options.pages = [\n {\n path: '/',\n },\n ]\n }\n\n const serverEnv = builder.environments['server']\n\n if (!serverEnv) {\n throw new Error(`Vite's \"server\" environment not found`)\n }\n\n const prerenderOutputDir = path.resolve(\n options.root,\n '.tanstack-start/build/prerenderer',\n )\n\n const nodeNitro = await createNitro({\n ...nitro.options._config,\n preset: 'nitro-prerender',\n logLevel: 0,\n output: {\n dir: prerenderOutputDir,\n serverDir: path.resolve(prerenderOutputDir, 'server'),\n publicDir: path.resolve(prerenderOutputDir, 'public'),\n },\n })\n\n const nodeNitroRollupOptions = getRollupConfig(nodeNitro)\n\n const build = serverEnv.config.build\n\n build.outDir = prerenderOutputDir\n\n build.rollupOptions = {\n ...build.rollupOptions,\n ...nodeNitroRollupOptions,\n output: {\n ...build.rollupOptions.output,\n ...nodeNitroRollupOptions.output,\n sourcemap: undefined,\n },\n }\n\n await buildNitroEnvironment(nodeNitro, () => buildNitro(nodeNitro))\n\n // Import renderer entry\n const serverFilename =\n typeof nodeNitroRollupOptions.output.entryFileNames === 'string'\n ? nodeNitroRollupOptions.output.entryFileNames\n : 'index.mjs'\n\n const serverEntrypoint = path.resolve(\n path.join(nodeNitro.options.output.serverDir, serverFilename),\n )\n\n const { closePrerenderer, localFetch } = (await import(serverEntrypoint)) as {\n closePrerenderer: () => void\n localFetch: $Fetch\n }\n\n try {\n // Crawl all pages\n const pages = await prerenderPages()\n\n nitro.logger.info(`Prerendered ${pages.length} pages:`)\n pages.forEach((page) => {\n nitro.logger.info(`- ${page}`)\n })\n\n // TODO: Write the prerendered pages to the output directory\n } catch (error) {\n nitro.logger.error(error)\n } finally {\n // Ensure server is always closed\n // server.process.kill()\n closePrerenderer()\n }\n\n function extractLinks(html: string): Array<string> {\n const linkRegex = /<a[^>]+href=[\"']([^\"']+)[\"'][^>]*>/g\n const links: Array<string> = []\n let match\n\n while ((match = linkRegex.exec(html)) !== null) {\n const href = match[1]\n if (href && (href.startsWith('/') || href.startsWith('./'))) {\n links.push(href)\n }\n }\n\n return links\n }\n\n async function prerenderPages() {\n const seen = new Set<string>()\n const retriesByPath = new Map<string, number>()\n const concurrency = options.prerender?.concurrency ?? os.cpus().length\n nitro.logger.info(`Concurrency: ${concurrency}`)\n const queue = new Queue({ concurrency })\n\n options.pages.forEach((_page) => {\n let page = _page as Page\n\n if (typeof _page === 'string') {\n page = { path: _page }\n }\n\n addCrawlPageTask(page)\n })\n\n await queue.start()\n\n return Array.from(seen)\n\n function addCrawlPageTask(page: Page) {\n // Was the page already seen?\n if (seen.has(page.path)) return\n\n // Add the page to the seen set\n seen.add(page.path)\n\n if (page.fromCrawl) {\n options.pages.push(page)\n }\n\n // If not enabled, skip\n if (!(page.prerender?.enabled ?? true)) return\n\n // If there is a filter link, check if the page should be prerendered\n if (options.prerender?.filter && !options.prerender.filter(page)) return\n\n // Resolve the merged default and page-specific prerender options\n const prerenderOptions = {\n ...options.prerender,\n ...page.prerender,\n }\n\n // Add the task\n queue.add(async () => {\n nitro.logger.info(`Crawling: ${page.path}`)\n const retries = retriesByPath.get(page.path) || 0\n try {\n // Fetch the route\n const encodedRoute = encodeURI(page.path)\n\n const res = await localFetch<Response>(\n withBase(encodedRoute, nodeNitro.options.baseURL),\n {\n headers: { 'x-nitro-prerender': encodedRoute },\n },\n )\n\n if (!res.ok) {\n throw new Error(`Failed to fetch ${page.path}: ${res.statusText}`)\n }\n\n // Guess route type and populate fileName\n const contentType = res.headers.get('content-type') || ''\n const isImplicitHTML =\n !page.path.endsWith('.html') && contentType.includes('html')\n // &&\n // !JsonSigRx.test(dataBuff.subarray(0, 32).toString('utf8'))\n const routeWithIndex = page.path.endsWith('/')\n ? page.path + 'index'\n : page.path\n\n const htmlPath =\n page.path.endsWith('/') || prerenderOptions.autoSubfolderIndex\n ? joinURL(page.path, 'index.html')\n : page.path + '.html'\n\n const filename = withoutBase(\n isImplicitHTML ? htmlPath : routeWithIndex,\n nitro.options.baseURL,\n )\n\n const html = await res.text()\n\n const filepath = path.join(nitro.options.output.publicDir, filename)\n\n await fsp.mkdir(path.dirname(filepath), {\n recursive: true,\n })\n\n await fsp.writeFile(filepath, html)\n\n const newPage = await prerenderOptions.onSuccess?.({ page, html })\n\n if (newPage) {\n Object.assign(page, newPage)\n }\n\n // Find new links\n if (prerenderOptions.crawlLinks ?? true) {\n const links = extractLinks(html)\n for (const link of links) {\n addCrawlPageTask({ path: link, fromCrawl: true })\n }\n }\n } catch (error) {\n if (retries < (prerenderOptions.retryCount ?? 0)) {\n nitro.logger.warn(\n `Encountered error, retrying: ${page.path} in 500ms`,\n )\n await new Promise((resolve) =>\n setTimeout(resolve, prerenderOptions.retryDelay),\n )\n retriesByPath.set(page.path, retries + 1)\n addCrawlPageTask(page)\n } else {\n throw error\n }\n }\n })\n }\n }\n}\n"],"names":["createNitro","getRollupConfig","buildNitroEnvironment","buildNitro","_a","queue","Queue","withBase","joinURL","withoutBase","fsp"],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ViteBuilder } from 'vite';
|
|
2
|
+
import { Nitro } from 'nitropack';
|
|
3
|
+
import { TanStackStartOutputConfig } from './plugin.cjs';
|
|
4
|
+
export declare function prerender({ options, nitro, builder, }: {
|
|
5
|
+
options: TanStackStartOutputConfig;
|
|
6
|
+
nitro: Nitro;
|
|
7
|
+
builder: ViteBuilder;
|
|
8
|
+
}): Promise<void>;
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
4
|
+
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
5
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
6
|
+
const defaultConfig = {
|
|
7
|
+
concurrency: 5,
|
|
8
|
+
started: false,
|
|
9
|
+
tasks: []
|
|
10
|
+
};
|
|
11
|
+
class Queue {
|
|
12
|
+
constructor(config = defaultConfig) {
|
|
13
|
+
__publicField(this, "onSettles", []);
|
|
14
|
+
__publicField(this, "onErrors", []);
|
|
15
|
+
__publicField(this, "onSuccesses", []);
|
|
16
|
+
__publicField(this, "running");
|
|
17
|
+
__publicField(this, "active", []);
|
|
18
|
+
__publicField(this, "pending");
|
|
19
|
+
__publicField(this, "currentConcurrency");
|
|
20
|
+
const { concurrency, started, tasks } = {
|
|
21
|
+
...defaultConfig,
|
|
22
|
+
...config
|
|
23
|
+
};
|
|
24
|
+
this.running = started;
|
|
25
|
+
this.pending = tasks;
|
|
26
|
+
this.currentConcurrency = concurrency;
|
|
27
|
+
}
|
|
28
|
+
tick() {
|
|
29
|
+
if (!this.running) {
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
while (this.active.length < this.currentConcurrency && this.pending.length) {
|
|
33
|
+
const nextFn = this.pending.shift();
|
|
34
|
+
if (!nextFn) {
|
|
35
|
+
throw new Error("Found task that is not a function");
|
|
36
|
+
}
|
|
37
|
+
this.active.push(nextFn);
|
|
38
|
+
(async () => {
|
|
39
|
+
let success = false;
|
|
40
|
+
let res;
|
|
41
|
+
let error;
|
|
42
|
+
try {
|
|
43
|
+
res = await nextFn();
|
|
44
|
+
success = true;
|
|
45
|
+
} catch (e) {
|
|
46
|
+
error = e;
|
|
47
|
+
}
|
|
48
|
+
this.active = this.active.filter((d) => d !== nextFn);
|
|
49
|
+
if (success) {
|
|
50
|
+
this.onSuccesses.forEach((d) => d(res, nextFn));
|
|
51
|
+
} else {
|
|
52
|
+
this.onErrors.forEach((d) => d(error, nextFn));
|
|
53
|
+
}
|
|
54
|
+
this.onSettles.forEach((d) => d(res, error));
|
|
55
|
+
this.tick();
|
|
56
|
+
})();
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
add(fn, { priority } = {}) {
|
|
60
|
+
return new Promise((resolve, reject) => {
|
|
61
|
+
const task = () => Promise.resolve(fn()).then((res) => {
|
|
62
|
+
resolve(res);
|
|
63
|
+
return res;
|
|
64
|
+
}).catch((err) => {
|
|
65
|
+
reject(err);
|
|
66
|
+
throw err;
|
|
67
|
+
});
|
|
68
|
+
if (priority) {
|
|
69
|
+
this.pending.unshift(task);
|
|
70
|
+
} else {
|
|
71
|
+
this.pending.push(task);
|
|
72
|
+
}
|
|
73
|
+
this.tick();
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
throttle(n) {
|
|
77
|
+
this.currentConcurrency = n;
|
|
78
|
+
}
|
|
79
|
+
onSettled(cb) {
|
|
80
|
+
this.onSettles.push(cb);
|
|
81
|
+
return () => {
|
|
82
|
+
this.onSettles = this.onSettles.filter((d) => d !== cb);
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
onError(cb) {
|
|
86
|
+
this.onErrors.push(cb);
|
|
87
|
+
return () => {
|
|
88
|
+
this.onErrors = this.onErrors.filter((d) => d !== cb);
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
onSuccess(cb) {
|
|
92
|
+
this.onSuccesses.push(cb);
|
|
93
|
+
return () => {
|
|
94
|
+
this.onSuccesses = this.onSuccesses.filter((d) => d !== cb);
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
stop() {
|
|
98
|
+
this.running = false;
|
|
99
|
+
}
|
|
100
|
+
start() {
|
|
101
|
+
this.running = true;
|
|
102
|
+
this.tick();
|
|
103
|
+
return new Promise((resolve) => {
|
|
104
|
+
this.onSettled(() => {
|
|
105
|
+
if (this.isSettled()) {
|
|
106
|
+
resolve();
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
clear() {
|
|
112
|
+
this.pending = [];
|
|
113
|
+
}
|
|
114
|
+
getActive() {
|
|
115
|
+
return this.active;
|
|
116
|
+
}
|
|
117
|
+
getPending() {
|
|
118
|
+
return this.pending;
|
|
119
|
+
}
|
|
120
|
+
getAll() {
|
|
121
|
+
return [...this.active, ...this.pending];
|
|
122
|
+
}
|
|
123
|
+
isRunning() {
|
|
124
|
+
return this.running;
|
|
125
|
+
}
|
|
126
|
+
isSettled() {
|
|
127
|
+
return !this.active.length && !this.pending.length;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
exports.Queue = Queue;
|
|
131
|
+
//# sourceMappingURL=queue.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queue.cjs","sources":["../../src/queue.ts"],"sourcesContent":["interface PoolConfig {\n concurrency?: number\n started?: boolean\n tasks?: Array<() => Promise<any>>\n}\n\nconst defaultConfig: PoolConfig = {\n concurrency: 5,\n started: false,\n tasks: [],\n}\n\nexport class Queue<T> {\n private onSettles: Array<(res: any, error: any) => void> = []\n private onErrors: Array<(error: any, task: () => Promise<any>) => void> = []\n private onSuccesses: Array<(result: any, task: () => Promise<any>) => void> =\n []\n private running: boolean\n private active: Array<() => Promise<any>> = []\n private pending: Array<() => Promise<any>>\n private currentConcurrency: number\n\n constructor(config: PoolConfig = defaultConfig) {\n const { concurrency, started, tasks } = {\n ...defaultConfig,\n ...config,\n }\n this.running = started!\n this.pending = tasks as Array<() => Promise<any>>\n this.currentConcurrency = concurrency!\n }\n\n private tick() {\n if (!this.running) {\n return\n }\n while (\n this.active.length < this.currentConcurrency &&\n this.pending.length\n ) {\n const nextFn = this.pending.shift()\n if (!nextFn) {\n throw new Error('Found task that is not a function')\n }\n this.active.push(nextFn)\n ;(async () => {\n let success = false\n let res!: T\n let error: any\n try {\n res = await nextFn()\n success = true\n } catch (e) {\n error = e\n }\n this.active = this.active.filter((d) => d !== nextFn)\n if (success) {\n this.onSuccesses.forEach((d) => d(res, nextFn))\n } else {\n this.onErrors.forEach((d) => d(error, nextFn))\n }\n this.onSettles.forEach((d) => d(res, error))\n this.tick()\n })()\n }\n }\n\n add(fn: () => Promise<T> | T, { priority }: { priority?: boolean } = {}) {\n return new Promise<any>((resolve, reject) => {\n const task = () =>\n Promise.resolve(fn())\n .then((res) => {\n resolve(res)\n return res\n })\n .catch((err) => {\n reject(err)\n throw err\n })\n if (priority) {\n this.pending.unshift(task)\n } else {\n this.pending.push(task)\n }\n this.tick()\n })\n }\n\n throttle(n: number) {\n this.currentConcurrency = n\n }\n\n onSettled(cb: () => void) {\n this.onSettles.push(cb)\n return () => {\n this.onSettles = this.onSettles.filter((d) => d !== cb)\n }\n }\n\n onError(cb: (error: any, task: () => Promise<any>) => void) {\n this.onErrors.push(cb)\n return () => {\n this.onErrors = this.onErrors.filter((d) => d !== cb)\n }\n }\n\n onSuccess(cb: (result: any, task: () => Promise<any>) => void) {\n this.onSuccesses.push(cb)\n return () => {\n this.onSuccesses = this.onSuccesses.filter((d) => d !== cb)\n }\n }\n\n stop() {\n this.running = false\n }\n\n start() {\n this.running = true\n this.tick()\n return new Promise<void>((resolve) => {\n this.onSettled(() => {\n if (this.isSettled()) {\n resolve()\n }\n })\n })\n }\n\n clear() {\n this.pending = []\n }\n\n getActive() {\n return this.active\n }\n\n getPending() {\n return this.pending\n }\n\n getAll() {\n return [...this.active, ...this.pending]\n }\n\n isRunning() {\n return this.running\n }\n\n isSettled() {\n return !this.active.length && !this.pending.length\n }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
interface PoolConfig {
|
|
2
|
+
concurrency?: number;
|
|
3
|
+
started?: boolean;
|
|
4
|
+
tasks?: Array<() => Promise<any>>;
|
|
5
|
+
}
|
|
6
|
+
export declare class Queue<T> {
|
|
7
|
+
private onSettles;
|
|
8
|
+
private onErrors;
|
|
9
|
+
private onSuccesses;
|
|
10
|
+
private running;
|
|
11
|
+
private active;
|
|
12
|
+
private pending;
|
|
13
|
+
private currentConcurrency;
|
|
14
|
+
constructor(config?: PoolConfig);
|
|
15
|
+
private tick;
|
|
16
|
+
add(fn: () => Promise<T> | T, { priority }?: {
|
|
17
|
+
priority?: boolean;
|
|
18
|
+
}): Promise<any>;
|
|
19
|
+
throttle(n: number): void;
|
|
20
|
+
onSettled(cb: () => void): () => void;
|
|
21
|
+
onError(cb: (error: any, task: () => Promise<any>) => void): () => void;
|
|
22
|
+
onSuccess(cb: (result: any, task: () => Promise<any>) => void): () => void;
|
|
23
|
+
stop(): void;
|
|
24
|
+
start(): Promise<void>;
|
|
25
|
+
clear(): void;
|
|
26
|
+
getActive(): (() => Promise<any>)[];
|
|
27
|
+
getPending(): (() => Promise<any>)[];
|
|
28
|
+
getAll(): (() => Promise<any>)[];
|
|
29
|
+
isRunning(): boolean;
|
|
30
|
+
isSettled(): boolean;
|
|
31
|
+
}
|
|
32
|
+
export {};
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const fs = require("node:fs");
|
|
4
|
+
const path = require("node:path");
|
|
5
|
+
const ufo = require("ufo");
|
|
6
|
+
const routerCore = require("@tanstack/router-core");
|
|
7
|
+
function startManifestPlugin(opts) {
|
|
8
|
+
let config;
|
|
9
|
+
return {
|
|
10
|
+
name: "tsr-routes-manifest",
|
|
11
|
+
enforce: "pre",
|
|
12
|
+
configResolved(resolvedConfig) {
|
|
13
|
+
config = resolvedConfig;
|
|
14
|
+
},
|
|
15
|
+
// configEnvironment(env, envConfig) {
|
|
16
|
+
// config = envConfig.
|
|
17
|
+
// },
|
|
18
|
+
resolveId(id) {
|
|
19
|
+
if (id === "tanstack:start-manifest") {
|
|
20
|
+
return id;
|
|
21
|
+
}
|
|
22
|
+
return;
|
|
23
|
+
},
|
|
24
|
+
load(id) {
|
|
25
|
+
var _a, _b;
|
|
26
|
+
if (id === "tanstack:start-manifest") {
|
|
27
|
+
if (this.environment.config.consumer !== "server") {
|
|
28
|
+
return `export default {}`;
|
|
29
|
+
}
|
|
30
|
+
if (config.command === "serve") {
|
|
31
|
+
return `export const tsrStartManifest = () => ({
|
|
32
|
+
entry: "$${process.env.TSS_CLIENT_BASE}/",
|
|
33
|
+
routes: {}
|
|
34
|
+
})`;
|
|
35
|
+
}
|
|
36
|
+
const clientViteManifestPath = path.resolve(
|
|
37
|
+
opts.root,
|
|
38
|
+
".tanstack-start/build/client-dist/.vite/manifest.json"
|
|
39
|
+
);
|
|
40
|
+
let viteManifest;
|
|
41
|
+
try {
|
|
42
|
+
viteManifest = JSON.parse(
|
|
43
|
+
fs.readFileSync(clientViteManifestPath, "utf-8")
|
|
44
|
+
);
|
|
45
|
+
} catch (err) {
|
|
46
|
+
console.error(err);
|
|
47
|
+
throw new Error(
|
|
48
|
+
`Could not find the production client vite manifest at '${clientViteManifestPath}'!`
|
|
49
|
+
);
|
|
50
|
+
}
|
|
51
|
+
const routeTreePath = path.resolve(opts.tsr.generatedRouteTree);
|
|
52
|
+
let routeTreeContent;
|
|
53
|
+
try {
|
|
54
|
+
routeTreeContent = fs.readFileSync(routeTreePath, "utf-8");
|
|
55
|
+
} catch (err) {
|
|
56
|
+
console.error(err);
|
|
57
|
+
throw new Error(
|
|
58
|
+
`Could not find the generated route tree at '${routeTreePath}'!`
|
|
59
|
+
);
|
|
60
|
+
}
|
|
61
|
+
const routerManifest = JSON.parse(
|
|
62
|
+
((_a = routeTreeContent.match(
|
|
63
|
+
/\/\* ROUTE_MANIFEST_START([\s\S]*?)ROUTE_MANIFEST_END \*\//
|
|
64
|
+
)) == null ? void 0 : _a[1]) || "{ routes: {} }"
|
|
65
|
+
);
|
|
66
|
+
const routes = routerManifest.routes;
|
|
67
|
+
let entryFile;
|
|
68
|
+
const filesByRouteFilePath = Object.fromEntries(
|
|
69
|
+
Object.entries(viteManifest).map(([k, v]) => {
|
|
70
|
+
if (v.isEntry) {
|
|
71
|
+
entryFile = v;
|
|
72
|
+
}
|
|
73
|
+
const rPath = k.split("?")[0];
|
|
74
|
+
return [rPath, v];
|
|
75
|
+
}, {})
|
|
76
|
+
);
|
|
77
|
+
const routesDirectoryFromRoot = path.relative(
|
|
78
|
+
opts.root,
|
|
79
|
+
opts.tsr.routesDirectory
|
|
80
|
+
);
|
|
81
|
+
Object.entries(routes).forEach(([k, v]) => {
|
|
82
|
+
const file = filesByRouteFilePath[path.join(routesDirectoryFromRoot, v.filePath)];
|
|
83
|
+
if (file) {
|
|
84
|
+
const preloads = (file.imports ?? []).map(
|
|
85
|
+
(d) => path.join("/", viteManifest[d].file)
|
|
86
|
+
);
|
|
87
|
+
if (file.file) {
|
|
88
|
+
preloads.unshift(path.join("/", file.file));
|
|
89
|
+
}
|
|
90
|
+
const cssFiles = file.css ?? [];
|
|
91
|
+
const cssAssetsList = cssFiles.map(
|
|
92
|
+
(cssFile) => ({
|
|
93
|
+
tag: "link",
|
|
94
|
+
attrs: {
|
|
95
|
+
rel: "stylesheet",
|
|
96
|
+
href: ufo.joinURL("/", cssFile),
|
|
97
|
+
type: "text/css"
|
|
98
|
+
}
|
|
99
|
+
})
|
|
100
|
+
);
|
|
101
|
+
routes[k] = {
|
|
102
|
+
...v,
|
|
103
|
+
assets: [...v.assets || [], ...cssAssetsList],
|
|
104
|
+
preloads
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
if (entryFile) {
|
|
109
|
+
routes[routerCore.rootRouteId].preloads = [
|
|
110
|
+
path.join("/", entryFile.file),
|
|
111
|
+
...((_b = entryFile.imports) == null ? void 0 : _b.map(
|
|
112
|
+
(d) => path.join("/", viteManifest[d].file)
|
|
113
|
+
)) || []
|
|
114
|
+
];
|
|
115
|
+
const entryCssFiles = entryFile.css ?? [];
|
|
116
|
+
const entryCssAssetsList = entryCssFiles.map(
|
|
117
|
+
(cssFile) => ({
|
|
118
|
+
tag: "link",
|
|
119
|
+
attrs: {
|
|
120
|
+
rel: "stylesheet",
|
|
121
|
+
href: ufo.joinURL("/", cssFile),
|
|
122
|
+
type: "text/css"
|
|
123
|
+
}
|
|
124
|
+
})
|
|
125
|
+
);
|
|
126
|
+
routes[routerCore.rootRouteId].assets = [
|
|
127
|
+
...routes[routerCore.rootRouteId].assets || [],
|
|
128
|
+
...entryCssAssetsList,
|
|
129
|
+
{
|
|
130
|
+
tag: "script",
|
|
131
|
+
attrs: {
|
|
132
|
+
src: ufo.joinURL("/", entryFile.file),
|
|
133
|
+
type: "module"
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
];
|
|
137
|
+
}
|
|
138
|
+
const recurseRoute = (route, seenPreloads = {}) => {
|
|
139
|
+
var _a2;
|
|
140
|
+
route.preloads = (_a2 = route.preloads) == null ? void 0 : _a2.filter((preload) => {
|
|
141
|
+
if (seenPreloads[preload]) {
|
|
142
|
+
return false;
|
|
143
|
+
}
|
|
144
|
+
seenPreloads[preload] = true;
|
|
145
|
+
return true;
|
|
146
|
+
});
|
|
147
|
+
if (route.children) {
|
|
148
|
+
route.children.forEach((child) => {
|
|
149
|
+
const childRoute = routes[child];
|
|
150
|
+
recurseRoute(childRoute, { ...seenPreloads });
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
};
|
|
154
|
+
recurseRoute(routes[routerCore.rootRouteId]);
|
|
155
|
+
const routesManifest = {
|
|
156
|
+
routes
|
|
157
|
+
};
|
|
158
|
+
return `export const tsrStartManifest = () => (${JSON.stringify(routesManifest)})`;
|
|
159
|
+
}
|
|
160
|
+
return;
|
|
161
|
+
}
|
|
162
|
+
};
|
|
163
|
+
}
|
|
164
|
+
exports.startManifestPlugin = startManifestPlugin;
|
|
165
|
+
//# sourceMappingURL=routesManifestPlugin.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"routesManifestPlugin.cjs","sources":["../../src/routesManifestPlugin.ts"],"sourcesContent":["import { readFileSync } from 'node:fs'\nimport path from 'node:path'\nimport { joinURL } from 'ufo'\nimport { rootRouteId } from '@tanstack/router-core'\nimport type {\n PluginOption,\n ResolvedConfig,\n Manifest as ViteManifest,\n ManifestChunk as ViteManifestChunk,\n} from 'vite'\nimport type { Manifest, RouterManagedTag } from '@tanstack/router-core'\nimport type { TanStackStartOutputConfig } from './plugin'\n\nexport function startManifestPlugin(\n opts: TanStackStartOutputConfig,\n): PluginOption {\n let config: ResolvedConfig\n\n return {\n name: 'tsr-routes-manifest',\n enforce: 'pre',\n\n configResolved(resolvedConfig) {\n config = resolvedConfig\n },\n // configEnvironment(env, envConfig) {\n // config = envConfig.\n // },\n resolveId(id) {\n if (id === 'tanstack:start-manifest') {\n return id\n }\n return\n },\n load(id) {\n if (id === 'tanstack:start-manifest') {\n if (this.environment.config.consumer !== 'server') {\n // this will ultimately fail the build if the plugin is used outside the server environment\n // TODO: do we need special handling for `serve`?\n return `export default {}`\n }\n // If we're in development, return a dummy manifest\n\n if (config.command === 'serve') {\n return `export const tsrStartManifest = () => ({\n entry: \"$${process.env.TSS_CLIENT_BASE}/\",\n routes: {}\n })`\n }\n\n const clientViteManifestPath = path.resolve(\n opts.root,\n '.tanstack-start/build/client-dist/.vite/manifest.json',\n )\n\n let viteManifest: ViteManifest\n try {\n viteManifest = JSON.parse(\n readFileSync(clientViteManifestPath, 'utf-8'),\n )\n } catch (err) {\n console.error(err)\n throw new Error(\n `Could not find the production client vite manifest at '${clientViteManifestPath}'!`,\n )\n }\n\n const routeTreePath = path.resolve(opts.tsr.generatedRouteTree)\n\n let routeTreeContent: string\n try {\n routeTreeContent = readFileSync(routeTreePath, 'utf-8')\n } catch (err) {\n console.error(err)\n throw new Error(\n `Could not find the generated route tree at '${routeTreePath}'!`,\n )\n }\n\n // Extract the routesManifest JSON from the route tree file.\n // It's located between the /* ROUTE_MANIFEST_START and ROUTE_MANIFEST_END */ comment block.\n\n const routerManifest = JSON.parse(\n routeTreeContent.match(\n /\\/\\* ROUTE_MANIFEST_START([\\s\\S]*?)ROUTE_MANIFEST_END \\*\\//,\n )?.[1] || '{ routes: {} }',\n ) as Manifest\n\n const routes = routerManifest.routes\n\n let entryFile: ViteManifestChunk | undefined\n\n const filesByRouteFilePath: ViteManifest = Object.fromEntries(\n Object.entries(viteManifest).map(([k, v]) => {\n if (v.isEntry) {\n entryFile = v\n }\n\n const rPath = k.split('?')[0]\n\n return [rPath, v]\n }, {}),\n )\n\n const routesDirectoryFromRoot = path.relative(\n opts.root,\n opts.tsr.routesDirectory,\n )\n\n // Add preloads to the routes from the vite manifest\n Object.entries(routes).forEach(([k, v]) => {\n const file =\n filesByRouteFilePath[\n path.join(routesDirectoryFromRoot, v.filePath as string)\n ]\n\n if (file) {\n const preloads = (file.imports ?? []).map((d) =>\n path.join('/', viteManifest[d]!.file),\n )\n\n if (file.file) {\n preloads.unshift(path.join('/', file.file))\n }\n\n const cssFiles = file.css ?? []\n const cssAssetsList: Array<RouterManagedTag> = cssFiles.map(\n (cssFile) => ({\n tag: 'link',\n attrs: {\n rel: 'stylesheet',\n href: joinURL('/', cssFile),\n type: 'text/css',\n },\n }),\n )\n\n routes[k] = {\n ...v,\n assets: [...(v.assets || []), ...cssAssetsList],\n preloads,\n }\n }\n })\n\n if (entryFile) {\n routes[rootRouteId]!.preloads = [\n path.join('/', entryFile.file),\n ...(entryFile.imports?.map((d) =>\n path.join('/', viteManifest[d]!.file),\n ) || []),\n ]\n\n // Gather all the CSS files from the entry file in\n // the `css` key and add them to the root route\n const entryCssFiles = entryFile.css ?? []\n const entryCssAssetsList: Array<RouterManagedTag> = entryCssFiles.map(\n (cssFile) => ({\n tag: 'link',\n attrs: {\n rel: 'stylesheet',\n href: joinURL('/', cssFile),\n type: 'text/css',\n },\n }),\n )\n\n routes[rootRouteId]!.assets = [\n ...(routes[rootRouteId]!.assets || []),\n ...entryCssAssetsList,\n {\n tag: 'script',\n attrs: {\n src: joinURL('/', entryFile.file),\n type: 'module',\n },\n },\n ]\n }\n\n const recurseRoute = (\n route: {\n preloads?: Array<string>\n children?: Array<any>\n },\n seenPreloads = {} as Record<string, true>,\n ) => {\n route.preloads = route.preloads?.filter((preload) => {\n if (seenPreloads[preload]) {\n return false\n }\n seenPreloads[preload] = true\n return true\n })\n\n if (route.children) {\n route.children.forEach((child) => {\n const childRoute = routes[child]!\n recurseRoute(childRoute, { ...seenPreloads })\n })\n }\n }\n\n // @ts-expect-error\n recurseRoute(routes[rootRouteId])\n\n const routesManifest = {\n routes,\n }\n\n return `export const tsrStartManifest = () => (${JSON.stringify(routesManifest)})`\n }\n return\n },\n }\n}\n"],"names":["readFileSync","joinURL","rootRouteId","_a"],"mappings":";;;;;;AAaO,SAAS,oBACd,MACc;AACV,MAAA;AAEG,SAAA;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,IAET,eAAe,gBAAgB;AACpB,eAAA;AAAA,IACX;AAAA;AAAA;AAAA;AAAA,IAIA,UAAU,IAAI;AACZ,UAAI,OAAO,2BAA2B;AAC7B,eAAA;AAAA,MAAA;AAET;AAAA,IACF;AAAA,IACA,KAAK,IAAI;;AACP,UAAI,OAAO,2BAA2B;AACpC,YAAI,KAAK,YAAY,OAAO,aAAa,UAAU;AAG1C,iBAAA;AAAA,QAAA;AAIL,YAAA,OAAO,YAAY,SAAS;AACvB,iBAAA;AAAA,uBACM,QAAQ,IAAI,eAAe;AAAA;AAAA;AAAA,QAAA;AAK1C,cAAM,yBAAyB,KAAK;AAAA,UAClC,KAAK;AAAA,UACL;AAAA,QACF;AAEI,YAAA;AACA,YAAA;AACF,yBAAe,KAAK;AAAA,YAClBA,GAAA,aAAa,wBAAwB,OAAO;AAAA,UAC9C;AAAA,iBACO,KAAK;AACZ,kBAAQ,MAAM,GAAG;AACjB,gBAAM,IAAI;AAAA,YACR,0DAA0D,sBAAsB;AAAA,UAClF;AAAA,QAAA;AAGF,cAAM,gBAAgB,KAAK,QAAQ,KAAK,IAAI,kBAAkB;AAE1D,YAAA;AACA,YAAA;AACiB,6BAAAA,GAAAA,aAAa,eAAe,OAAO;AAAA,iBAC/C,KAAK;AACZ,kBAAQ,MAAM,GAAG;AACjB,gBAAM,IAAI;AAAA,YACR,+CAA+C,aAAa;AAAA,UAC9D;AAAA,QAAA;AAMF,cAAM,iBAAiB,KAAK;AAAA,YAC1B,sBAAiB;AAAA,YACf;AAAA,UACF,MAFA,mBAEI,OAAM;AAAA,QACZ;AAEA,cAAM,SAAS,eAAe;AAE1B,YAAA;AAEJ,cAAM,uBAAqC,OAAO;AAAA,UAChD,OAAO,QAAQ,YAAY,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,MAAM;AAC3C,gBAAI,EAAE,SAAS;AACD,0BAAA;AAAA,YAAA;AAGd,kBAAM,QAAQ,EAAE,MAAM,GAAG,EAAE,CAAC;AAErB,mBAAA,CAAC,OAAO,CAAC;AAAA,UAAA,GACf,CAAE,CAAA;AAAA,QACP;AAEA,cAAM,0BAA0B,KAAK;AAAA,UACnC,KAAK;AAAA,UACL,KAAK,IAAI;AAAA,QACX;AAGO,eAAA,QAAQ,MAAM,EAAE,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM;AACzC,gBAAM,OACJ,qBACE,KAAK,KAAK,yBAAyB,EAAE,QAAkB,CACzD;AAEF,cAAI,MAAM;AACR,kBAAM,YAAY,KAAK,WAAW,CAAI,GAAA;AAAA,cAAI,CAAC,MACzC,KAAK,KAAK,KAAK,aAAa,CAAC,EAAG,IAAI;AAAA,YACtC;AAEA,gBAAI,KAAK,MAAM;AACb,uBAAS,QAAQ,KAAK,KAAK,KAAK,KAAK,IAAI,CAAC;AAAA,YAAA;AAGtC,kBAAA,WAAW,KAAK,OAAO,CAAC;AAC9B,kBAAM,gBAAyC,SAAS;AAAA,cACtD,CAAC,aAAa;AAAA,gBACZ,KAAK;AAAA,gBACL,OAAO;AAAA,kBACL,KAAK;AAAA,kBACL,MAAMC,IAAAA,QAAQ,KAAK,OAAO;AAAA,kBAC1B,MAAM;AAAA,gBAAA;AAAA,cAEV;AAAA,YACF;AAEA,mBAAO,CAAC,IAAI;AAAA,cACV,GAAG;AAAA,cACH,QAAQ,CAAC,GAAI,EAAE,UAAU,CAAC,GAAI,GAAG,aAAa;AAAA,cAC9C;AAAA,YACF;AAAA,UAAA;AAAA,QACF,CACD;AAED,YAAI,WAAW;AACN,iBAAAC,WAAAA,WAAW,EAAG,WAAW;AAAA,YAC9B,KAAK,KAAK,KAAK,UAAU,IAAI;AAAA,YAC7B,KAAI,eAAU,YAAV,mBAAmB;AAAA,cAAI,CAAC,MAC1B,KAAK,KAAK,KAAK,aAAa,CAAC,EAAG,IAAI;AAAA,kBACjC,CAAA;AAAA,UACP;AAIM,gBAAA,gBAAgB,UAAU,OAAO,CAAC;AACxC,gBAAM,qBAA8C,cAAc;AAAA,YAChE,CAAC,aAAa;AAAA,cACZ,KAAK;AAAA,cACL,OAAO;AAAA,gBACL,KAAK;AAAA,gBACL,MAAMD,IAAAA,QAAQ,KAAK,OAAO;AAAA,gBAC1B,MAAM;AAAA,cAAA;AAAA,YAEV;AAAA,UACF;AAEO,iBAAAC,WAAAA,WAAW,EAAG,SAAS;AAAA,YAC5B,GAAI,OAAOA,WAAAA,WAAW,EAAG,UAAU,CAAC;AAAA,YACpC,GAAG;AAAA,YACH;AAAA,cACE,KAAK;AAAA,cACL,OAAO;AAAA,gBACL,KAAKD,IAAA,QAAQ,KAAK,UAAU,IAAI;AAAA,gBAChC,MAAM;AAAA,cAAA;AAAA,YACR;AAAA,UAEJ;AAAA,QAAA;AAGF,cAAM,eAAe,CACnB,OAIA,eAAe,CAAA,MACZ;;AACH,gBAAM,YAAWE,MAAA,MAAM,aAAN,gBAAAA,IAAgB,OAAO,CAAC,YAAY;AAC/C,gBAAA,aAAa,OAAO,GAAG;AAClB,qBAAA;AAAA,YAAA;AAET,yBAAa,OAAO,IAAI;AACjB,mBAAA;AAAA,UAAA;AAGT,cAAI,MAAM,UAAU;AACZ,kBAAA,SAAS,QAAQ,CAAC,UAAU;AAC1B,oBAAA,aAAa,OAAO,KAAK;AAC/B,2BAAa,YAAY,EAAE,GAAG,cAAc;AAAA,YAAA,CAC7C;AAAA,UAAA;AAAA,QAEL;AAGa,qBAAA,OAAOD,WAAAA,WAAW,CAAC;AAEhC,cAAM,iBAAiB;AAAA,UACrB;AAAA,QACF;AAEA,eAAO,0CAA0C,KAAK,UAAU,cAAc,CAAC;AAAA,MAAA;AAEjF;AAAA,IAAA;AAAA,EAEJ;AACF;;"}
|