@qwik.dev/router 0.0.0 → 2.0.0-alpha.0

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.
Files changed (98) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +15 -0
  3. package/adapters/azure-swa/vite.d.ts +2 -0
  4. package/adapters/bun-server/vite.d.ts +2 -0
  5. package/adapters/cloud-run/vite.d.ts +2 -0
  6. package/adapters/cloudflare-pages/vite.d.ts +2 -0
  7. package/adapters/deno-server/vite.d.ts +2 -0
  8. package/adapters/netlify-edge/vite.d.ts +2 -0
  9. package/adapters/node-server/vite.d.ts +2 -0
  10. package/adapters/shared/vite.d.ts +2 -0
  11. package/adapters/static/vite.d.ts +2 -0
  12. package/adapters/vercel-edge/vite.d.ts +2 -0
  13. package/index.d.ts +2 -0
  14. package/lib/adapters/azure-swa/vite/index.cjs +96 -0
  15. package/lib/adapters/azure-swa/vite/index.d.ts +13 -0
  16. package/lib/adapters/azure-swa/vite/index.mjs +61 -0
  17. package/lib/adapters/bun-server/vite/index.cjs +50 -0
  18. package/lib/adapters/bun-server/vite/index.d.ts +14 -0
  19. package/lib/adapters/bun-server/vite/index.mjs +25 -0
  20. package/lib/adapters/cloud-run/vite/index.cjs +47 -0
  21. package/lib/adapters/cloud-run/vite/index.d.ts +13 -0
  22. package/lib/adapters/cloud-run/vite/index.mjs +22 -0
  23. package/lib/adapters/cloudflare-pages/vite/index.cjs +115 -0
  24. package/lib/adapters/cloudflare-pages/vite/index.d.ts +27 -0
  25. package/lib/adapters/cloudflare-pages/vite/index.mjs +80 -0
  26. package/lib/adapters/deno-server/vite/index.cjs +62 -0
  27. package/lib/adapters/deno-server/vite/index.d.ts +14 -0
  28. package/lib/adapters/deno-server/vite/index.mjs +37 -0
  29. package/lib/adapters/netlify-edge/vite/index.cjs +129 -0
  30. package/lib/adapters/netlify-edge/vite/index.d.ts +44 -0
  31. package/lib/adapters/netlify-edge/vite/index.mjs +92 -0
  32. package/lib/adapters/node-server/vite/index.cjs +50 -0
  33. package/lib/adapters/node-server/vite/index.d.ts +14 -0
  34. package/lib/adapters/node-server/vite/index.mjs +25 -0
  35. package/lib/adapters/shared/vite/index.cjs +371 -0
  36. package/lib/adapters/shared/vite/index.d.ts +114 -0
  37. package/lib/adapters/shared/vite/index.mjs +331 -0
  38. package/lib/adapters/static/vite/index.cjs +361 -0
  39. package/lib/adapters/static/vite/index.d.ts +10 -0
  40. package/lib/adapters/static/vite/index.mjs +324 -0
  41. package/lib/adapters/vercel-edge/vite/index.cjs +118 -0
  42. package/lib/adapters/vercel-edge/vite/index.d.ts +45 -0
  43. package/lib/adapters/vercel-edge/vite/index.mjs +83 -0
  44. package/lib/index.d.ts +803 -0
  45. package/lib/index.qwik.cjs +1876 -0
  46. package/lib/index.qwik.mjs +1857 -0
  47. package/lib/middleware/aws-lambda/index.d.ts +50 -0
  48. package/lib/middleware/aws-lambda/index.mjs +55 -0
  49. package/lib/middleware/azure-swa/index.d.ts +28 -0
  50. package/lib/middleware/azure-swa/index.mjs +297 -0
  51. package/lib/middleware/bun/index.d.ts +35 -0
  52. package/lib/middleware/bun/index.mjs +208 -0
  53. package/lib/middleware/cloudflare-pages/index.d.ts +35 -0
  54. package/lib/middleware/cloudflare-pages/index.mjs +107 -0
  55. package/lib/middleware/deno/index.d.ts +47 -0
  56. package/lib/middleware/deno/index.mjs +195 -0
  57. package/lib/middleware/firebase/index.d.ts +26 -0
  58. package/lib/middleware/firebase/index.mjs +36 -0
  59. package/lib/middleware/netlify-edge/index.d.ts +27 -0
  60. package/lib/middleware/netlify-edge/index.mjs +83 -0
  61. package/lib/middleware/node/index.cjs +314 -0
  62. package/lib/middleware/node/index.d.ts +66 -0
  63. package/lib/middleware/node/index.mjs +287 -0
  64. package/lib/middleware/request-handler/index.cjs +1544 -0
  65. package/lib/middleware/request-handler/index.d.ts +681 -0
  66. package/lib/middleware/request-handler/index.mjs +1501 -0
  67. package/lib/middleware/vercel-edge/index.d.ts +26 -0
  68. package/lib/middleware/vercel-edge/index.mjs +109 -0
  69. package/lib/modules.d.ts +38 -0
  70. package/lib/service-worker.cjs +267 -0
  71. package/lib/service-worker.d.ts +4 -0
  72. package/lib/service-worker.mjs +265 -0
  73. package/lib/static/deno.mjs +8 -0
  74. package/lib/static/index.cjs +67 -0
  75. package/lib/static/index.d.ts +98 -0
  76. package/lib/static/index.mjs +48 -0
  77. package/lib/static/node.cjs +1124 -0
  78. package/lib/static/node.mjs +1086 -0
  79. package/lib/vite/index.cjs +27496 -0
  80. package/lib/vite/index.d.ts +154 -0
  81. package/lib/vite/index.mjs +27484 -0
  82. package/middleware/aws-lambda.d.ts +2 -0
  83. package/middleware/azure-swa.d.ts +2 -0
  84. package/middleware/bun.d.ts +2 -0
  85. package/middleware/cloudflare-pages.d.ts +2 -0
  86. package/middleware/deno.d.ts +2 -0
  87. package/middleware/firebase.d.ts +2 -0
  88. package/middleware/netlify-edge.d.ts +2 -0
  89. package/middleware/node.d.ts +2 -0
  90. package/middleware/request-handler/generated/not-found-paths.ts +7 -0
  91. package/middleware/request-handler/generated/static-paths.ts +35 -0
  92. package/middleware/request-handler.d.ts +2 -0
  93. package/middleware/vercel-edge.d.ts +2 -0
  94. package/modules.d.ts +38 -0
  95. package/package.json +171 -165
  96. package/service-worker.d.ts +2 -0
  97. package/static.d.ts +2 -0
  98. package/vite.d.ts +2 -0
@@ -0,0 +1,324 @@
1
+ // packages/qwik-router/src/adapters/shared/vite/index.ts
2
+ import fs2 from "node:fs";
3
+ import { basename, dirname, join as join2, resolve } from "node:path";
4
+
5
+ // packages/qwik-router/src/adapters/shared/vite/post-build.ts
6
+ import { getErrorHtml } from "@qwik.dev/router/middleware/request-handler";
7
+ import fs from "node:fs";
8
+ import { join } from "node:path";
9
+ async function postBuild(clientOutDir, pathName, userStaticPaths, format, cleanStatic) {
10
+ if (pathName && !pathName.endsWith("/")) {
11
+ pathName += "/";
12
+ }
13
+ const ignorePathnames = /* @__PURE__ */ new Set([pathName + "build/", pathName + "assets/"]);
14
+ const staticPaths = new Set(userStaticPaths.map(normalizeTrailingSlash));
15
+ const notFounds = [];
16
+ const loadItem = async (fsDir, fsName, pathname) => {
17
+ pathname = normalizeTrailingSlash(pathname);
18
+ if (ignorePathnames.has(pathname)) {
19
+ return;
20
+ }
21
+ const fsPath = join(fsDir, fsName);
22
+ if (fsName === "index.html" || fsName === "q-data.json") {
23
+ if (!staticPaths.has(pathname) && cleanStatic) {
24
+ await fs.promises.unlink(fsPath);
25
+ }
26
+ return;
27
+ }
28
+ if (fsName === "404.html") {
29
+ const notFoundHtml = await fs.promises.readFile(fsPath, "utf-8");
30
+ notFounds.push([pathname, notFoundHtml]);
31
+ return;
32
+ }
33
+ const stat = await fs.promises.stat(fsPath);
34
+ if (stat.isDirectory()) {
35
+ await loadDir(fsPath, pathname + fsName + "/");
36
+ } else if (stat.isFile()) {
37
+ staticPaths.add(pathname + fsName);
38
+ }
39
+ };
40
+ const loadDir = async (fsDir, pathname) => {
41
+ const itemNames = await fs.promises.readdir(fsDir);
42
+ await Promise.all(itemNames.map((i) => loadItem(fsDir, i, pathname)));
43
+ };
44
+ if (fs.existsSync(clientOutDir)) {
45
+ await loadDir(clientOutDir, pathName);
46
+ }
47
+ const notFoundPathsCode = createNotFoundPathsModule(pathName, notFounds, format);
48
+ const staticPathsCode = createStaticPathsModule(pathName, staticPaths, format);
49
+ return {
50
+ notFoundPathsCode,
51
+ staticPathsCode
52
+ };
53
+ }
54
+ function normalizeTrailingSlash(pathname) {
55
+ if (!pathname.endsWith("/")) {
56
+ return pathname + "/";
57
+ }
58
+ return pathname;
59
+ }
60
+ function createNotFoundPathsModule(basePathname, notFounds, format) {
61
+ notFounds.sort((a, b) => {
62
+ if (a[0].length > b[0].length) {
63
+ return -1;
64
+ }
65
+ if (a[0].length < b[0].length) {
66
+ return 1;
67
+ }
68
+ if (a[0] < b[0]) {
69
+ return -1;
70
+ }
71
+ if (a[0] > b[0]) {
72
+ return 1;
73
+ }
74
+ return 0;
75
+ });
76
+ if (!notFounds.some((r) => r[0] === basePathname)) {
77
+ const html = getErrorHtml(404, "Resource Not Found");
78
+ notFounds.push([basePathname, html]);
79
+ }
80
+ const c = [];
81
+ c.push(`const notFounds = ${JSON.stringify(notFounds, null, 2)};`);
82
+ c.push(`function getNotFound(p) {`);
83
+ c.push(` for (const r of notFounds) {`);
84
+ c.push(` if (p.startsWith(r[0])) {`);
85
+ c.push(` return r[1];`);
86
+ c.push(` }`);
87
+ c.push(` }`);
88
+ c.push(` return "Resource Not Found";`);
89
+ c.push(`}`);
90
+ if (format === "cjs") {
91
+ c.push("exports.getNotFound = getNotFound;");
92
+ } else {
93
+ c.push("export { getNotFound };");
94
+ }
95
+ return c.join("\n");
96
+ }
97
+ function createStaticPathsModule(basePathname, staticPaths, format) {
98
+ const assetsPath = basePathname + "assets/";
99
+ const baseBuildPath = basePathname + "build/";
100
+ const c = [];
101
+ c.push(
102
+ `const staticPaths = new Set(${JSON.stringify(
103
+ Array.from(new Set(staticPaths)).sort()
104
+ )});`
105
+ );
106
+ c.push(`function isStaticPath(method, url) {`);
107
+ c.push(` if (method.toUpperCase() !== 'GET') {`);
108
+ c.push(` return false;`);
109
+ c.push(` }`);
110
+ c.push(` const p = url.pathname;`);
111
+ c.push(` if (p.startsWith(${JSON.stringify(baseBuildPath)})) {`);
112
+ c.push(` return true;`);
113
+ c.push(` }`);
114
+ c.push(` if (p.startsWith(${JSON.stringify(assetsPath)})) {`);
115
+ c.push(` return true;`);
116
+ c.push(` }`);
117
+ c.push(` if (staticPaths.has(p)) {`);
118
+ c.push(` return true;`);
119
+ c.push(` }`);
120
+ c.push(` if (p.endsWith('/q-data.json')) {`);
121
+ c.push(` const pWithoutQdata = p.replace(/\\/q-data.json$/, '');`);
122
+ c.push(` if (staticPaths.has(pWithoutQdata + '/')) {`);
123
+ c.push(` return true;`);
124
+ c.push(` }`);
125
+ c.push(` if (staticPaths.has(pWithoutQdata)) {`);
126
+ c.push(` return true;`);
127
+ c.push(` }`);
128
+ c.push(` }`);
129
+ c.push(` return false;`);
130
+ c.push(`}`);
131
+ if (format === "cjs") {
132
+ c.push("exports.isStaticPath = isStaticPath;");
133
+ } else {
134
+ c.push("export { isStaticPath };");
135
+ }
136
+ return c.join("\n");
137
+ }
138
+
139
+ // packages/qwik-router/src/adapters/shared/vite/index.ts
140
+ function viteAdapter(opts) {
141
+ let qwikRouterPlugin = null;
142
+ let qwikVitePlugin = null;
143
+ let serverOutDir = null;
144
+ let renderModulePath = null;
145
+ let qwikRouterConfigModulePath = null;
146
+ let isSsrBuild = false;
147
+ let format = "esm";
148
+ const outputEntries = [];
149
+ const plugin = {
150
+ name: `vite-plugin-qwik-router-${opts.name}`,
151
+ enforce: "post",
152
+ apply: "build",
153
+ config(config) {
154
+ if (typeof opts.config === "function") {
155
+ config = opts.config(config);
156
+ }
157
+ config.define = {
158
+ "process.env.NODE_ENV": JSON.stringify(process.env.NODE_ENV || "production"),
159
+ ...config.define
160
+ };
161
+ return config;
162
+ },
163
+ configResolved(config) {
164
+ var _a, _b, _c, _d;
165
+ isSsrBuild = !!config.build.ssr;
166
+ if (isSsrBuild) {
167
+ qwikRouterPlugin = config.plugins.find(
168
+ (p) => p.name === "vite-plugin-qwik-router"
169
+ );
170
+ if (!qwikRouterPlugin) {
171
+ throw new Error("Missing vite-plugin-qwik-router");
172
+ }
173
+ qwikVitePlugin = config.plugins.find(
174
+ (p) => p.name === "vite-plugin-qwik"
175
+ );
176
+ if (!qwikVitePlugin) {
177
+ throw new Error("Missing vite-plugin-qwik");
178
+ }
179
+ serverOutDir = config.build.outDir;
180
+ if (((_a = config.build) == null ? void 0 : _a.ssr) !== true) {
181
+ throw new Error(
182
+ `"build.ssr" must be set to "true" in order to use the "${opts.name}" adapter.`
183
+ );
184
+ }
185
+ if (!((_c = (_b = config.build) == null ? void 0 : _b.rollupOptions) == null ? void 0 : _c.input)) {
186
+ throw new Error(
187
+ `"build.rollupOptions.input" must be set in order to use the "${opts.name}" adapter.`
188
+ );
189
+ }
190
+ if (((_d = config.ssr) == null ? void 0 : _d.format) === "cjs") {
191
+ format = "cjs";
192
+ }
193
+ }
194
+ },
195
+ generateBundle(_, bundles) {
196
+ if (isSsrBuild) {
197
+ outputEntries.length = 0;
198
+ for (const fileName in bundles) {
199
+ const chunk = bundles[fileName];
200
+ if (chunk.type === "chunk" && chunk.isEntry) {
201
+ outputEntries.push(fileName);
202
+ if (chunk.name === "entry.ssr") {
203
+ renderModulePath = join2(serverOutDir, fileName);
204
+ } else if (chunk.name === "@qwik-router-config") {
205
+ qwikRouterConfigModulePath = join2(serverOutDir, fileName);
206
+ }
207
+ }
208
+ }
209
+ if (!renderModulePath) {
210
+ throw new Error(
211
+ 'Unable to find "entry.ssr" entry point. Did you forget to add it to "build.rollupOptions.input"?'
212
+ );
213
+ }
214
+ if (!qwikRouterConfigModulePath) {
215
+ throw new Error(
216
+ 'Unable to find "@qwik-router-config" entry point. Did you forget to add it to "build.rollupOptions.input"?'
217
+ );
218
+ }
219
+ }
220
+ },
221
+ closeBundle: {
222
+ sequential: true,
223
+ async handler() {
224
+ var _a;
225
+ if (isSsrBuild && opts.ssg !== null && serverOutDir && (qwikRouterPlugin == null ? void 0 : qwikRouterPlugin.api) && (qwikVitePlugin == null ? void 0 : qwikVitePlugin.api)) {
226
+ const staticPaths = opts.staticPaths || [];
227
+ const routes = qwikRouterPlugin.api.getRoutes();
228
+ const basePathname = qwikRouterPlugin.api.getBasePathname();
229
+ const clientOutDir = qwikVitePlugin.api.getClientOutDir();
230
+ const clientPublicOutDir = qwikVitePlugin.api.getClientPublicOutDir();
231
+ const assetsDir = qwikVitePlugin.api.getAssetsDir();
232
+ const rootDir = qwikVitePlugin.api.getRootDir() ?? void 0;
233
+ if (renderModulePath && qwikRouterConfigModulePath && clientOutDir && clientPublicOutDir) {
234
+ let ssgOrigin = ((_a = opts.ssg) == null ? void 0 : _a.origin) ?? opts.origin;
235
+ if (!ssgOrigin) {
236
+ ssgOrigin = `https://yoursite.qwik.dev`;
237
+ }
238
+ if (ssgOrigin.length > 0 && !/:\/\//.test(ssgOrigin)) {
239
+ ssgOrigin = `https://${ssgOrigin}`;
240
+ }
241
+ if (ssgOrigin.startsWith("//")) {
242
+ ssgOrigin = `https:${ssgOrigin}`;
243
+ }
244
+ try {
245
+ ssgOrigin = new URL(ssgOrigin).origin;
246
+ } catch (e) {
247
+ this.warn(
248
+ `Invalid "origin" option: "${ssgOrigin}". Using default origin: "https://yoursite.qwik.dev"`
249
+ );
250
+ ssgOrigin = `https://yoursite.qwik.dev`;
251
+ }
252
+ const staticGenerate = await import("../../../static/index.mjs");
253
+ const generateOpts = {
254
+ maxWorkers: opts.maxWorkers,
255
+ basePathname,
256
+ outDir: clientPublicOutDir,
257
+ rootDir,
258
+ ...opts.ssg,
259
+ origin: ssgOrigin,
260
+ renderModulePath,
261
+ qwikRouterConfigModulePath
262
+ };
263
+ const staticGenerateResult = await staticGenerate.generate(generateOpts);
264
+ if (staticGenerateResult.errors > 0) {
265
+ const err = new Error(
266
+ `Error while running SSG from "${opts.name}" adapter. At least one path failed to render.`
267
+ );
268
+ err.stack = void 0;
269
+ this.error(err);
270
+ }
271
+ staticPaths.push(...staticGenerateResult.staticPaths);
272
+ const { staticPathsCode, notFoundPathsCode } = await postBuild(
273
+ clientPublicOutDir,
274
+ assetsDir ? join2(basePathname, assetsDir) : basePathname,
275
+ staticPaths,
276
+ format,
277
+ !!opts.cleanStaticGenerated
278
+ );
279
+ await Promise.all([
280
+ fs2.promises.writeFile(join2(serverOutDir, RESOLVED_STATIC_PATHS_ID), staticPathsCode),
281
+ fs2.promises.writeFile(
282
+ join2(serverOutDir, RESOLVED_NOT_FOUND_PATHS_ID),
283
+ notFoundPathsCode
284
+ )
285
+ ]);
286
+ if (typeof opts.generate === "function") {
287
+ await opts.generate({
288
+ outputEntries,
289
+ serverOutDir,
290
+ clientOutDir,
291
+ clientPublicOutDir,
292
+ basePathname,
293
+ routes,
294
+ assetsDir,
295
+ warn: (message) => this.warn(message),
296
+ error: (message) => this.error(message)
297
+ });
298
+ }
299
+ }
300
+ }
301
+ }
302
+ }
303
+ };
304
+ return plugin;
305
+ }
306
+ var STATIC_PATHS_ID = "@qwik-router-static-paths";
307
+ var RESOLVED_STATIC_PATHS_ID = `${STATIC_PATHS_ID}.js`;
308
+ var NOT_FOUND_PATHS_ID = "@qwik-router-not-found-paths";
309
+ var RESOLVED_NOT_FOUND_PATHS_ID = `${NOT_FOUND_PATHS_ID}.js`;
310
+
311
+ // packages/qwik-router/src/adapters/static/vite/index.ts
312
+ function staticAdapter(opts) {
313
+ return viteAdapter({
314
+ name: "static-generate",
315
+ origin: opts.origin,
316
+ ssg: {
317
+ include: ["/*"],
318
+ ...opts
319
+ }
320
+ });
321
+ }
322
+ export {
323
+ staticAdapter
324
+ };
@@ -0,0 +1,118 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+
30
+ // packages/qwik-router/src/adapters/vercel-edge/vite/index.ts
31
+ var vite_exports = {};
32
+ __export(vite_exports, {
33
+ vercelEdgeAdapter: () => vercelEdgeAdapter
34
+ });
35
+ module.exports = __toCommonJS(vite_exports);
36
+ var import_node_fs = __toESM(require("node:fs"), 1);
37
+ var import_node_path = require("node:path");
38
+ var import_vite = require("../../shared/vite/index.cjs");
39
+ function vercelEdgeAdapter(opts = {}) {
40
+ var _a;
41
+ return (0, import_vite.viteAdapter)({
42
+ name: "vercel-edge",
43
+ origin: ((_a = process == null ? void 0 : process.env) == null ? void 0 : _a.VERCEL_URL) || "https://yoursitename.vercel.app",
44
+ ssg: opts.ssg,
45
+ staticPaths: opts.staticPaths,
46
+ cleanStaticGenerated: true,
47
+ config(config) {
48
+ var _a2;
49
+ const outDir = ((_a2 = config.build) == null ? void 0 : _a2.outDir) || (0, import_node_path.join)(".vercel", "output", "functions", "_qwik-router.func");
50
+ return {
51
+ resolve: {
52
+ conditions: opts.target === "node" ? ["node", "import", "module", "browser", "default"] : ["edge-light", "webworker", "worker", "browser", "module", "main"]
53
+ },
54
+ ssr: {
55
+ target: opts.target === "node" ? "node" : "webworker",
56
+ noExternal: true
57
+ },
58
+ build: {
59
+ ssr: true,
60
+ outDir,
61
+ rollupOptions: {
62
+ output: {
63
+ format: "es",
64
+ hoistTransitiveImports: false
65
+ }
66
+ }
67
+ },
68
+ publicDir: false
69
+ };
70
+ },
71
+ async generate({ clientPublicOutDir, serverOutDir, basePathname, outputEntries }) {
72
+ const vercelOutputDir = (0, import_vite.getParentDir)(serverOutDir, "output");
73
+ if (opts.outputConfig !== false) {
74
+ const vercelOutputConfig = {
75
+ routes: [
76
+ { handle: "filesystem" },
77
+ {
78
+ src: basePathname + ".*",
79
+ dest: "/_qwik-router"
80
+ }
81
+ ],
82
+ version: 3
83
+ };
84
+ await import_node_fs.default.promises.writeFile(
85
+ (0, import_node_path.join)(vercelOutputDir, "config.json"),
86
+ JSON.stringify(vercelOutputConfig, null, 2)
87
+ );
88
+ }
89
+ let entrypoint = opts.vcConfigEntryPoint;
90
+ if (!entrypoint) {
91
+ if (outputEntries.some((n) => n === "entry.vercel-edge.mjs")) {
92
+ entrypoint = "entry.vercel-edge.mjs";
93
+ } else {
94
+ entrypoint = "entry.vercel-edge.js";
95
+ }
96
+ }
97
+ const vcConfigPath = (0, import_node_path.join)(serverOutDir, ".vc-config.json");
98
+ const vcConfig = {
99
+ runtime: "edge",
100
+ entrypoint,
101
+ envVarsInUse: opts.vcConfigEnvVarsInUse
102
+ };
103
+ await import_node_fs.default.promises.writeFile(vcConfigPath, JSON.stringify(vcConfig, null, 2));
104
+ let vercelStaticDir = (0, import_node_path.join)(vercelOutputDir, "static");
105
+ const basePathnameParts = basePathname.split("/").filter((p) => p.length > 0);
106
+ if (basePathnameParts.length > 0) {
107
+ vercelStaticDir = (0, import_node_path.join)(vercelStaticDir, ...basePathnameParts);
108
+ }
109
+ await import_node_fs.default.promises.rm(vercelStaticDir, { recursive: true, force: true });
110
+ await import_node_fs.default.promises.mkdir((0, import_node_path.dirname)(vercelStaticDir), { recursive: true });
111
+ await import_node_fs.default.promises.rename(clientPublicOutDir, vercelStaticDir);
112
+ }
113
+ });
114
+ }
115
+ // Annotate the CommonJS export names for ESM import in node:
116
+ 0 && (module.exports = {
117
+ vercelEdgeAdapter
118
+ });
@@ -0,0 +1,45 @@
1
+ import { ServerAdapterOptions } from '../../shared/vite';
2
+ import type { StaticGenerateRenderOptions } from '@qwik.dev/router/static';
3
+
4
+ export { StaticGenerateRenderOptions }
5
+
6
+ /** @public */
7
+ export declare function vercelEdgeAdapter(opts?: VercelEdgeAdapterOptions): any;
8
+
9
+ /** @public */
10
+ export declare interface VercelEdgeAdapterOptions extends ServerAdapterOptions {
11
+ /**
12
+ * Determines if the build should auto-generate the `.vercel/output/config.json` config.
13
+ *
14
+ * Defaults to `true`.
15
+ */
16
+ outputConfig?: boolean;
17
+ /**
18
+ * The `entrypoint` property in the `.vc-config.json` file. Indicates the initial file where code
19
+ * will be executed for the Edge Function.
20
+ *
21
+ * Defaults to `entry.vercel-edge.js`.
22
+ */
23
+ vcConfigEntryPoint?: string;
24
+ /**
25
+ * The `envVarsInUse` property in the `.vc-config.json` file. List of environment variable names
26
+ * that will be available for the Edge Function to utilize.
27
+ *
28
+ * Defaults to `undefined`.
29
+ */
30
+ vcConfigEnvVarsInUse?: string[];
31
+ /**
32
+ * Manually add pathnames that should be treated as static paths and not SSR. For example, when
33
+ * these pathnames are requested, their response should come from a static file, rather than a
34
+ * server-side rendered response.
35
+ */
36
+ staticPaths?: string[];
37
+ /**
38
+ * Define the `target` property in the `ssr` object in the `vite.config.mts` file.
39
+ *
40
+ * Defaults to `webworker`.
41
+ */
42
+ target?: 'webworker' | 'node';
43
+ }
44
+
45
+ export { }
@@ -0,0 +1,83 @@
1
+ // packages/qwik-router/src/adapters/vercel-edge/vite/index.ts
2
+ import fs from "node:fs";
3
+ import { dirname, join } from "node:path";
4
+ import { getParentDir, viteAdapter } from "../../shared/vite/index.mjs";
5
+ function vercelEdgeAdapter(opts = {}) {
6
+ var _a;
7
+ return viteAdapter({
8
+ name: "vercel-edge",
9
+ origin: ((_a = process == null ? void 0 : process.env) == null ? void 0 : _a.VERCEL_URL) || "https://yoursitename.vercel.app",
10
+ ssg: opts.ssg,
11
+ staticPaths: opts.staticPaths,
12
+ cleanStaticGenerated: true,
13
+ config(config) {
14
+ var _a2;
15
+ const outDir = ((_a2 = config.build) == null ? void 0 : _a2.outDir) || join(".vercel", "output", "functions", "_qwik-router.func");
16
+ return {
17
+ resolve: {
18
+ conditions: opts.target === "node" ? ["node", "import", "module", "browser", "default"] : ["edge-light", "webworker", "worker", "browser", "module", "main"]
19
+ },
20
+ ssr: {
21
+ target: opts.target === "node" ? "node" : "webworker",
22
+ noExternal: true
23
+ },
24
+ build: {
25
+ ssr: true,
26
+ outDir,
27
+ rollupOptions: {
28
+ output: {
29
+ format: "es",
30
+ hoistTransitiveImports: false
31
+ }
32
+ }
33
+ },
34
+ publicDir: false
35
+ };
36
+ },
37
+ async generate({ clientPublicOutDir, serverOutDir, basePathname, outputEntries }) {
38
+ const vercelOutputDir = getParentDir(serverOutDir, "output");
39
+ if (opts.outputConfig !== false) {
40
+ const vercelOutputConfig = {
41
+ routes: [
42
+ { handle: "filesystem" },
43
+ {
44
+ src: basePathname + ".*",
45
+ dest: "/_qwik-router"
46
+ }
47
+ ],
48
+ version: 3
49
+ };
50
+ await fs.promises.writeFile(
51
+ join(vercelOutputDir, "config.json"),
52
+ JSON.stringify(vercelOutputConfig, null, 2)
53
+ );
54
+ }
55
+ let entrypoint = opts.vcConfigEntryPoint;
56
+ if (!entrypoint) {
57
+ if (outputEntries.some((n) => n === "entry.vercel-edge.mjs")) {
58
+ entrypoint = "entry.vercel-edge.mjs";
59
+ } else {
60
+ entrypoint = "entry.vercel-edge.js";
61
+ }
62
+ }
63
+ const vcConfigPath = join(serverOutDir, ".vc-config.json");
64
+ const vcConfig = {
65
+ runtime: "edge",
66
+ entrypoint,
67
+ envVarsInUse: opts.vcConfigEnvVarsInUse
68
+ };
69
+ await fs.promises.writeFile(vcConfigPath, JSON.stringify(vcConfig, null, 2));
70
+ let vercelStaticDir = join(vercelOutputDir, "static");
71
+ const basePathnameParts = basePathname.split("/").filter((p) => p.length > 0);
72
+ if (basePathnameParts.length > 0) {
73
+ vercelStaticDir = join(vercelStaticDir, ...basePathnameParts);
74
+ }
75
+ await fs.promises.rm(vercelStaticDir, { recursive: true, force: true });
76
+ await fs.promises.mkdir(dirname(vercelStaticDir), { recursive: true });
77
+ await fs.promises.rename(clientPublicOutDir, vercelStaticDir);
78
+ }
79
+ });
80
+ }
81
+ export {
82
+ vercelEdgeAdapter
83
+ };