@qwik.dev/router 2.0.0-beta.1 → 2.0.0-beta.10

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 (149) hide show
  1. package/adapters/static/vite.d.ts +1 -1
  2. package/lib/adapters/azure-swa/vite/index-BqUeglYs.cjs +1 -0
  3. package/lib/adapters/azure-swa/vite/index-CBIchDYq.js +651 -0
  4. package/lib/adapters/azure-swa/vite/index-ClHGw5z1.js +6 -0
  5. package/lib/adapters/azure-swa/vite/index-CrwlB95_.js +22 -0
  6. package/lib/adapters/azure-swa/vite/index-DTIOTwZo.cjs +11 -0
  7. package/lib/adapters/azure-swa/vite/index-vQuPcef3.cjs +1 -0
  8. package/lib/adapters/azure-swa/vite/index.cjs +5 -96
  9. package/lib/adapters/azure-swa/vite/index.d.ts +2 -2
  10. package/lib/adapters/azure-swa/vite/index.mjs +201 -26
  11. package/lib/adapters/bun-server/vite/index-BqUeglYs.cjs +1 -0
  12. package/lib/adapters/bun-server/vite/index-CBIchDYq.js +651 -0
  13. package/lib/adapters/bun-server/vite/index-ClHGw5z1.js +6 -0
  14. package/lib/adapters/bun-server/vite/index-CrwlB95_.js +22 -0
  15. package/lib/adapters/bun-server/vite/index-DTIOTwZo.cjs +11 -0
  16. package/lib/adapters/bun-server/vite/index-vQuPcef3.cjs +1 -0
  17. package/lib/adapters/bun-server/vite/index.cjs +5 -50
  18. package/lib/adapters/bun-server/vite/index.d.ts +2 -2
  19. package/lib/adapters/bun-server/vite/index.mjs +196 -12
  20. package/lib/adapters/cloud-run/vite/index-BqUeglYs.cjs +1 -0
  21. package/lib/adapters/cloud-run/vite/index-CBIchDYq.js +651 -0
  22. package/lib/adapters/cloud-run/vite/index-ClHGw5z1.js +6 -0
  23. package/lib/adapters/cloud-run/vite/index-CrwlB95_.js +22 -0
  24. package/lib/adapters/cloud-run/vite/index-DTIOTwZo.cjs +11 -0
  25. package/lib/adapters/cloud-run/vite/index-vQuPcef3.cjs +1 -0
  26. package/lib/adapters/cloud-run/vite/index.cjs +5 -47
  27. package/lib/adapters/cloud-run/vite/index.d.ts +2 -2
  28. package/lib/adapters/cloud-run/vite/index.mjs +195 -11
  29. package/lib/adapters/cloudflare-pages/vite/index-BIeHg2Cj.cjs +5 -0
  30. package/lib/adapters/cloudflare-pages/vite/index-C455V8_A.cjs +1 -0
  31. package/lib/adapters/cloudflare-pages/vite/index-ClHGw5z1.js +6 -0
  32. package/lib/adapters/cloudflare-pages/vite/index-D3HITboM.js +645 -0
  33. package/lib/adapters/cloudflare-pages/vite/index-DKcVHRBy.cjs +11 -0
  34. package/lib/adapters/cloudflare-pages/vite/index-DwovcBp3.js +22 -0
  35. package/lib/adapters/cloudflare-pages/vite/index-bogwy7wh.js +250 -0
  36. package/lib/adapters/cloudflare-pages/vite/index-vQuPcef3.cjs +1 -0
  37. package/lib/adapters/cloudflare-pages/vite/index.cjs +1 -115
  38. package/lib/adapters/cloudflare-pages/vite/index.d.ts +2 -2
  39. package/lib/adapters/cloudflare-pages/vite/index.mjs +4 -78
  40. package/lib/adapters/deno-server/vite/index-BqUeglYs.cjs +1 -0
  41. package/lib/adapters/deno-server/vite/index-CBIchDYq.js +651 -0
  42. package/lib/adapters/deno-server/vite/index-ClHGw5z1.js +6 -0
  43. package/lib/adapters/deno-server/vite/index-CrwlB95_.js +22 -0
  44. package/lib/adapters/deno-server/vite/index-DTIOTwZo.cjs +11 -0
  45. package/lib/adapters/deno-server/vite/index-vQuPcef3.cjs +1 -0
  46. package/lib/adapters/deno-server/vite/index.cjs +5 -62
  47. package/lib/adapters/deno-server/vite/index.d.ts +2 -2
  48. package/lib/adapters/deno-server/vite/index.mjs +198 -14
  49. package/lib/adapters/netlify-edge/vite/index-BqUeglYs.cjs +1 -0
  50. package/lib/adapters/netlify-edge/vite/index-CBIchDYq.js +651 -0
  51. package/lib/adapters/netlify-edge/vite/index-ClHGw5z1.js +6 -0
  52. package/lib/adapters/netlify-edge/vite/index-CrwlB95_.js +22 -0
  53. package/lib/adapters/netlify-edge/vite/index-DTIOTwZo.cjs +11 -0
  54. package/lib/adapters/netlify-edge/vite/index-vQuPcef3.cjs +1 -0
  55. package/lib/adapters/netlify-edge/vite/index.cjs +6 -129
  56. package/lib/adapters/netlify-edge/vite/index.d.ts +2 -2
  57. package/lib/adapters/netlify-edge/vite/index.mjs +240 -60
  58. package/lib/adapters/node-server/vite/index-BqUeglYs.cjs +1 -0
  59. package/lib/adapters/node-server/vite/index-CBIchDYq.js +651 -0
  60. package/lib/adapters/node-server/vite/index-ClHGw5z1.js +6 -0
  61. package/lib/adapters/node-server/vite/index-CrwlB95_.js +22 -0
  62. package/lib/adapters/node-server/vite/index-DTIOTwZo.cjs +11 -0
  63. package/lib/adapters/node-server/vite/index-vQuPcef3.cjs +1 -0
  64. package/lib/adapters/node-server/vite/index.cjs +5 -50
  65. package/lib/adapters/node-server/vite/index.d.ts +2 -2
  66. package/lib/adapters/node-server/vite/index.mjs +196 -12
  67. package/lib/adapters/shared/vite/index-BqUeglYs.cjs +1 -0
  68. package/lib/adapters/shared/vite/index-CBIchDYq.js +651 -0
  69. package/lib/adapters/shared/vite/index-ClHGw5z1.js +6 -0
  70. package/lib/adapters/shared/vite/index-CrwlB95_.js +22 -0
  71. package/lib/adapters/shared/vite/index-DTIOTwZo.cjs +11 -0
  72. package/lib/adapters/shared/vite/index-vQuPcef3.cjs +1 -0
  73. package/lib/adapters/shared/vite/index.cjs +2 -375
  74. package/lib/adapters/shared/vite/index.d.ts +9 -15
  75. package/lib/adapters/shared/vite/index.mjs +155 -292
  76. package/lib/adapters/ssg/vite/index-BqUeglYs.cjs +1 -0
  77. package/lib/adapters/ssg/vite/index-CBIchDYq.js +651 -0
  78. package/lib/adapters/ssg/vite/index-ClHGw5z1.js +6 -0
  79. package/lib/adapters/ssg/vite/index-CrwlB95_.js +22 -0
  80. package/lib/adapters/ssg/vite/index-DTIOTwZo.cjs +11 -0
  81. package/lib/adapters/ssg/vite/index-vQuPcef3.cjs +1 -0
  82. package/lib/adapters/ssg/vite/index.cjs +5 -0
  83. package/lib/adapters/ssg/vite/index.d.ts +13 -0
  84. package/lib/adapters/ssg/vite/index.mjs +201 -0
  85. package/lib/adapters/vercel-edge/vite/index-BqUeglYs.cjs +1 -0
  86. package/lib/adapters/vercel-edge/vite/index-CBIchDYq.js +651 -0
  87. package/lib/adapters/vercel-edge/vite/index-ClHGw5z1.js +6 -0
  88. package/lib/adapters/vercel-edge/vite/index-CrwlB95_.js +22 -0
  89. package/lib/adapters/vercel-edge/vite/index-DTIOTwZo.cjs +11 -0
  90. package/lib/adapters/vercel-edge/vite/index-vQuPcef3.cjs +1 -0
  91. package/lib/adapters/vercel-edge/vite/index.cjs +5 -118
  92. package/lib/adapters/vercel-edge/vite/index.d.ts +2 -2
  93. package/lib/adapters/vercel-edge/vite/index.mjs +230 -51
  94. package/lib/index.d.ts +172 -50
  95. package/lib/index.qwik.cjs +333 -160
  96. package/lib/index.qwik.mjs +335 -162
  97. package/lib/middleware/aws-lambda/index.cjs +1 -0
  98. package/lib/middleware/aws-lambda/index.d.ts +3 -2
  99. package/lib/middleware/aws-lambda/index.mjs +27 -41
  100. package/lib/middleware/azure-swa/index.cjs +1 -0
  101. package/lib/middleware/azure-swa/index.mjs +46 -269
  102. package/lib/middleware/bun/index.cjs +1 -0
  103. package/lib/middleware/bun/index.mjs +68 -120
  104. package/lib/middleware/cloudflare-pages/index.cjs +1 -0
  105. package/lib/middleware/cloudflare-pages/index.mjs +48 -80
  106. package/lib/middleware/deno/index.cjs +1 -0
  107. package/lib/middleware/deno/index.mjs +63 -110
  108. package/lib/middleware/firebase/index.cjs +1 -0
  109. package/lib/middleware/firebase/index.mjs +16 -28
  110. package/lib/middleware/netlify-edge/index.cjs +1 -0
  111. package/lib/middleware/netlify-edge/index.mjs +36 -64
  112. package/lib/middleware/node/index.cjs +1 -314
  113. package/lib/middleware/node/index.mjs +116 -198
  114. package/lib/middleware/request-handler/index.cjs +11 -1607
  115. package/lib/middleware/request-handler/index.d.ts +63 -62
  116. package/lib/middleware/request-handler/index.mjs +879 -1333
  117. package/lib/middleware/vercel-edge/index.cjs +1 -0
  118. package/lib/middleware/vercel-edge/index.mjs +47 -82
  119. package/lib/modules.d.ts +4 -12
  120. package/lib/service-worker.cjs +1 -17
  121. package/lib/service-worker.mjs +5 -15
  122. package/lib/ssg/deno.cjs +1 -0
  123. package/lib/ssg/deno.mjs +6 -0
  124. package/lib/ssg/index-CBIchDYq.js +651 -0
  125. package/lib/ssg/index-ClHGw5z1.js +6 -0
  126. package/lib/ssg/index-DTIOTwZo.cjs +11 -0
  127. package/lib/ssg/index-vQuPcef3.cjs +1 -0
  128. package/lib/ssg/index.cjs +1 -0
  129. package/lib/{static → ssg}/index.d.ts +17 -17
  130. package/lib/ssg/index.mjs +22 -0
  131. package/lib/ssg/node.cjs +11 -0
  132. package/lib/ssg/node.mjs +651 -0
  133. package/lib/vite/index.cjs +28 -27431
  134. package/lib/vite/index.d.ts +16 -0
  135. package/lib/vite/index.mjs +1413 -27227
  136. package/modules.d.ts +4 -12
  137. package/package.json +50 -39
  138. package/ssg.d.ts +2 -0
  139. package/static.d.ts +1 -1
  140. package/lib/adapters/static/vite/index.cjs +0 -368
  141. package/lib/adapters/static/vite/index.d.ts +0 -10
  142. package/lib/adapters/static/vite/index.mjs +0 -331
  143. package/lib/static/deno.mjs +0 -8
  144. package/lib/static/index.cjs +0 -67
  145. package/lib/static/index.mjs +0 -48
  146. package/lib/static/node.cjs +0 -1124
  147. package/lib/static/node.mjs +0 -1086
  148. package/middleware/request-handler/generated/not-found-paths.ts +0 -7
  149. package/middleware/request-handler/generated/static-paths.ts +0 -35
@@ -0,0 +1,11 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const E=require("node:fs"),q=require("node:path"),X=require("node:os"),_=require("node:worker_threads"),Y=require("@qwik.dev/core/internal"),U=require("@qwik.dev/router/middleware/request-handler"),Z=require("node:stream/web"),C=require("node:url"),x=require("kleur/colors"),ee=require("vite");var N=typeof document<"u"?document.currentScript:null;function j(e){return e<1?e.toFixed(2)+" ms":e<1e3?e.toFixed(1)+" ms":e<6e4?(e/1e3).toFixed(1)+" s":(e/6e4).toFixed(1)+" m"}function te(e,t,s){let r=e;if(t&&s)for(const i of t){const o=`[${i}]`,n=`[...${i}]`,c=s[i];r=r.replace(n,c),r=r.replace(o,c)}return r}function A(e){return re(q.normalize(e))}function re(e){const t=/^\\\\\?\\/.test(e),s=/[^\u0000-\u0080]+/.test(e);return t||s||(e=e.replace(/\\/g,"/"),e.endsWith("/")&&(e=e.slice(0,e.length-1))),e}async function ne(e){delete globalThis.__qwik;const t=e.getOptions(),s=new Set,r={...t,render:(await import(C.pathToFileURL(t.renderModulePath).href)).default,qwikRouterConfig:(await import(C.pathToFileURL(t.qwikRouterConfigModulePath).href)).default};e.createWorkerProcess(async i=>{switch(i.type){case"render":return new Promise(o=>{H(e,r,i,s,o)});case"close":{const o=Array.from(s);return s.clear(),await Promise.all(o),{type:"close"}}}})}async function se(e){delete globalThis.__qwik;const t=e.getOptions(),s=new Set,r={...t,render:(await import(C.pathToFileURL(t.renderModulePath).href)).default,qwikRouterConfig:(await import(C.pathToFileURL(t.qwikRouterConfigModulePath).href)).default};return i=>new Promise(o=>{H(e,r,i,s,o)})}async function H(e,t,s,r,i){const o=new URL(s.pathname,t.origin),n={type:"render",pathname:s.pathname,url:o.href,ok:!1,error:null,filePath:null,contentType:null,resourceType:null};try{let c=null,l;const g=new Promise(u=>{l=u}),P=new Request(o),y={mode:"static",locale:void 0,url:o,request:P,env:{get(u){return e.getEnv(u)}},platform:e.platform,getClientConn:()=>({}),getWritableStream:(u,v,$,p,W)=>{if(n.ok=u>=200&&u<300,!n.ok)return ie;n.contentType=(v.get("Content-Type")||"").toLowerCase();const h=n.contentType.includes("text/html"),w=o.pathname.endsWith("/404.html"),T=e.getRouteFilePath(o.pathname,h);w?n.resourceType="404":h&&(n.resourceType="page");const b=h?t.emitHtml!==!1:!0,m=h&&t.emitData!==!1;return new Z.WritableStream({async start(){try{(b||m)&&await e.ensureDir(T),b&&(c=e.createWriteStream(T),c.on("error",a=>{console.error(a),c=null,n.error={message:a.message,stack:a.stack}}))}catch(a){c=null,n.error={message:String(a),stack:a.stack||""}}},write(a){try{c&&c.write(Buffer.from(a.buffer))}catch(d){c=null,n.error={message:String(d),stack:d.stack||""}}},async close(){const a=[];try{if(m){const d=W.sharedMap.get(U.RequestEvShareQData);if(d&&!w){const k=e.getDataFilePath(o.pathname),R=e.createWriteStream(k);R.on("error",S=>{console.error(S),n.error={message:S.message,stack:S.stack}});const F=await Y._serialize([d]);R.write(F),a.push(new Promise(S=>{n.filePath=T,R.end(S)}))}}c&&a.push(new Promise(d=>{n.filePath=T,c.end(d)}).finally(l)),a.length>0&&await Promise.all(a)}catch(d){c=null,n.error={message:String(d),stack:d.stack||""}}}})}},f=U.requestHandler(y,t).then(u=>{if(u!=null)return u.completion.then(v=>c?g.then(()=>v):v)}).then(u=>{u!==void 0&&(u instanceof Error?n.error={message:u.message,stack:u.stack}:n.error={message:String(u),stack:void 0})}).finally(()=>{r.delete(f),i(n)});r.add(f)}catch(c){c instanceof Error?n.error={message:c.message,stack:c.stack}:n.error={message:String(c),stack:void 0},i(n)}}const oe={closed:Promise.resolve(void 0),ready:Promise.resolve(void 0),desiredSize:0,async close(){},async abort(){},async write(){},releaseLock(){}},ie={get locked(){return!1},set locked(e){},async abort(){},async close(){},getWriter(){return oe}};async function ae(e,t){const s=[],r=[];let i=null;t={...t};let o=t.outDir;if(typeof o!="string")throw new Error('Missing "outDir" option');if(!q.isAbsolute(o))throw new Error(`"outDir" must be an absolute file path, received: ${o}`);o=A(o);let n=X.cpus().length;typeof t.maxWorkers=="number"&&(n=Math.max(1,Math.min(t.maxWorkers,n)));let c=20;typeof t.maxTasksPerWorker=="number"&&(c=Math.max(1,Math.min(t.maxTasksPerWorker,50)));let l=t.sitemapOutFile;l!==null&&(typeof l!="string"&&(l="sitemap.xml"),q.isAbsolute(l)||(l=q.resolve(o,l)));const g=await se(e),P=p=>{if(p===0){const m={activeTasks:0,totalTasks:0,render:async M=>{m.activeTasks++,m.totalTasks++;const a=await g(M);return m.activeTasks--,a},terminate:async()=>{}};return m}let W=null;const h=new Map;let w;typeof __filename=="string"?w=__filename:w=typeof document>"u"?require("url").pathToFileURL(__filename).href:N&&N.tagName.toUpperCase()==="SCRIPT"&&N.src||new URL("index-DTIOTwZo.cjs",document.baseURI).href,typeof w=="string"&&w.startsWith("file://")&&(w=new URL(w));const T=new _.Worker(w,{workerData:t}),b={activeTasks:0,totalTasks:0,render:m=>new Promise((M,a)=>{try{b.activeTasks++,b.totalTasks++,h.set(m.pathname,M),T.postMessage(m)}catch(d){b.activeTasks--,h.delete(m.pathname),a(d)}}),terminate:async()=>{h.clear();const m={type:"close"};await new Promise(M=>{W=M,T.postMessage(m)}),await T.terminate()}};return T.on("message",m=>{switch(m.type){case"render":{const M=h.get(m.pathname);M&&(h.delete(m.pathname),b.activeTasks--,M(m));break}case"close":{W&&(W(),W=null);break}}}),T.on("error",m=>{console.error("worker error",m)}),T.on("exit",m=>{m!==1&&console.error(`worker exit ${m}`)}),b},y=()=>s.sort(ce)[0],f=()=>y().activeTasks<c,u=async p=>{const h=await y().render(p);if(l&&h.ok&&h.resourceType==="page"&&(r.push(`<url><loc>${h.url}</loc></url>`),r.length>50)){i&&await i;const w=r.join(`
2
+ `)+`
3
+ `;r.length=0,i=E.promises.appendFile(l,w)}return h},v=async()=>{const p=[];l&&(i&&await i,r.push("</urlset>"),p.push(E.promises.appendFile(l,r.join(`
4
+ `))),r.length=0);for(const W of s)try{p.push(W.terminate())}catch(h){console.error(h)}s.length=0,await Promise.all(p)};l&&(await B(l),await E.promises.writeFile(l,`<?xml version="1.0" encoding="UTF-8"?>
5
+ <urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
6
+ `));for(let p=0;p<n;p++)s.push(P(p));return{hasAvailableWorker:f,render:u,close:v}}function ce(e,t){return e.activeTasks<t.activeTasks?-1:e.activeTasks>t.activeTasks?1:e.totalTasks<t.totalTasks?-1:1}async function le(e){_.parentPort?.on("message",async t=>{_.parentPort?.postMessage(await e(t))})}async function Q(e){const t=f=>E.createWriteStream(f,{flags:"w"}),i=()=>{const f=process.hrtime();return()=>{const u=process.hrtime(f);return(u[0]*1e9+u[1])*1e-6}},o=async()=>({debug:e.log==="debug"?console.debug.bind(console):()=>{},error:console.error.bind(console),info:console.info.bind(console)}),n=A(e.outDir),l=(e.basePathname||"/").length,y={createMainProcess:null,createWorkerProcess:le,createLogger:o,getOptions:()=>e,ensureDir:B,createWriteStream:t,createTimer:i,access:ue,getRouteFilePath:(f,u)=>(f=f.slice(l),u?f.endsWith(".html")||(f.endsWith("/")?f+="index.html":f+="/index.html"):f.endsWith("/")&&(f=f.slice(0,-1)),q.join(n,f)),getDataFilePath:f=>(f=f.slice(l),f.endsWith("/")?f+="q-data.json":f+="/q-data.json",q.join(n,f)),getEnv:f=>process.env[f],platform:{static:!0,node:process.versions.node}};return y.createMainProcess=()=>ae(y,e),y}const B=async e=>{await E.promises.mkdir(q.dirname(e),{recursive:!0})},ue=async e=>{try{return await E.promises.access(e),!0}catch{return!1}},fe=e=>{const t=e.stack;if(typeof t=="string"){const s=t.split(`
7
+ `).filter(r=>!r.includes("/node_modules/")&&!r.includes("(node:"));for(let r=1;r<s.length;r++){const i=s[r].replace("file:///","/");if(/^\s+at/.test(i)){const o=i.indexOf("/"),n=i.lastIndexOf(")",o);if(o>0){const l=i.slice(o,n).split(":"),g=G(l[l.length-1]),P=G(l[l.length-2]);return typeof g=="number"&&typeof P=="number"?(l.length-=2,{file:l.join(":"),line:P,column:g}):typeof g=="number"?(l.length-=1,{file:l.join(":"),line:g,column:void 0}):{file:l.join(":"),line:void 0,column:void 0}}}}}},G=e=>{try{return parseInt(e,10)}catch{return}},V=/\r?\n/,z=2;function de(e,t){if(typeof t=="number")return t;if(t.lo!=null)return t.lo;const s=e.split(V),{line:r,column:i}=t;let o=0;for(let n=0;n<r-1&&n<s.length;n++)o+=s[n].length+1;return o+i}function me(e,t=0,s){t=de(e,t),s=s||t;const r=e.split(V);let i=0;const o=[];for(let n=0;n<r.length;n++)if(i+=r[n].length+1,i>=t){for(let c=n-z;c<=n+z||s>i;c++){if(c<0||c>=r.length)continue;const l=c+1;o.push(`${l}${" ".repeat(Math.max(3-String(l).length,0))}| ${r[c]}`);const g=r[c].length;if(c===n){const P=Math.max(t-(i-g)+1,0),y=Math.max(1,s>i?g-P:s-t);o.push(" | "+" ".repeat(P)+"^".repeat(y))}else if(c>n){if(s>i){const P=Math.max(Math.min(s-i,g),1);o.push(" | "+"^".repeat(P))}i+=g+1}}break}return o.join(`
8
+ `)}function he(e){if(e instanceof Error){const t=e;let s=t.loc;if(!t.frame&&!t.plugin&&(s||(s=fe(t)),s&&(t.loc=s,s.file))){t.id=A(t.loc.file);try{const r=E.readFileSync(t.loc.file,"utf-8");t.frame=me(r,t.loc)}catch{}}}return e}function ge(e){const t=[];let s=0;for(;s<e.length;){const r=e.indexOf("[",s);if(r!==-1){const i=e.indexOf("]",r),o=e.slice(r+1,i);t.push(o.startsWith("...")?o.substring(3):o),s=i+1}else s=e.length}return t}var K=(e=>(e[e.RouteName=0]="RouteName",e[e.Loaders=1]="Loaders",e[e.OriginalPathname=2]="OriginalPathname",e[e.RouteBundleNames=3]="RouteBundleNames",e))(K||{});async function we(e,t,s){if(t.emit404Pages!==!1){const i=(t.basePathname||"/")+"404.html";if(!s.some(n=>n[K.OriginalPathname]===i)){const n=e.getRouteFilePath(i,!0),c=U.getErrorHtml(404,"Resource Not Found");return await e.ensureDir(n),new Promise(l=>{const g=e.createWriteStream(n);g.write(c),g.end(l)})}}}function pe(e,t,s){const r=I(t),i=I(s);return o=>{if(o.endsWith("404.html"))return!0;e!=="/"&&(o=o.slice(e.length-1));for(const n of i)if(n.test(o))return!1;for(const n of r)if(n.test(o))return!0;return!1}}function I(e){return Array.isArray(e)?e.filter(t=>typeof t=="string").map(ke):[]}function ke(e){let t;return e==="/"||e==="/*"?t=e:e.endsWith("/*")?t=`${e.substring(0,e.length-2)}(/*)?`:e.endsWith("/")?t=`${e.substring(0,e.length-1)}(/)?`:e.endsWith("*")?t=e:t=`${e}(/)?`,t=`^${t.replace(/\*/g,".*")}$`,new RegExp(t)}async function Pe(e){const t=e.getOptions();ye(t);const s=await e.createMainProcess(),r=await e.createLogger();r.info(`
9
+ `+x.bold(x.green("Starting Qwik Router SSG...")));const i=(await import(C.pathToFileURL(t.qwikRouterConfigModulePath).href)).default,o=[],n=new Set,c=i.routes||[],l=!!i.trailingSlash,g=pe(t.basePathname||"/",t.include,t.exclude);return new Promise((P,y)=>{try{const f=e.createTimer(),u={duration:0,rendered:0,errors:0,staticPaths:[]};let v=!1,$=!1;const p=async()=>{const a=s.close();if(await we(e,t,c),u.duration=f(),u.errors===0){r.info(`
10
+ ${x.green("SSG results")}`),u.rendered>0&&r.info(`- Generated: ${x.dim(`${u.rendered} page${u.rendered===1?"":"s"}`)}`),r.info(`- Duration: ${x.dim(j(u.duration))}`);const d=u.rendered+u.errors;d>0&&r.info(`- Average: ${x.dim(j(u.duration/d)+" per page")}`),r.info("")}a.then(()=>{setTimeout(()=>P(u))}).catch(y)},W=()=>{for(;!v&&s.hasAvailableWorker()&&o.length>0;){const a=o.shift();a&&T(a)}!v&&$&&o.length===0&&n.size===0&&(v=!0,p())};let h=!1;const w=()=>{h||(h=!0,setTimeout(()=>{h=!1,W()}))},T=async a=>{try{n.add(a.pathname);const d=await s.render({type:"render",...a});if(n.delete(a.pathname),d.error){const k=new Error(d.error.message);k.stack=d.error.stack,r.error(`
11
+ ${x.bold(x.red(`!!! ${d.pathname}: Error during SSG`))}`),r.error(x.red(k.message)),r.error(` Pathname: ${x.magenta(a.pathname)}`),Object.assign(he(k),{plugin:"qwik-ssg"}),r.error(ee.buildErrorMessage(k)),u.errors++}if(d.filePath!=null){u.rendered++,u.staticPaths.push(d.pathname);const k=t.rootDir??t.outDir,R=q.relative(k,d.filePath),F=R.lastIndexOf("/");r.info(`${x.dim(R.slice(0,F+1))}${R.slice(F+1)}`)}w()}catch(d){v=!0,y(d)}},b=(a,d)=>{if(a){if(a=new URL(a,"https://qwik.dev").pathname,a!==t.basePathname)if(l){if(!a.endsWith("/")){const k=a.split("/");k[k.length-1].includes(".")||(a+="/")}}else a.endsWith("/")&&(a=a.slice(0,a.length-1));g(a)&&!o.some(k=>k.pathname===a)&&(o.push({pathname:a,params:d}),w())}},m=async a=>{const[d,k,R]=a,F=await Promise.all(k.map(O=>O())),S=F[F.length-1],L=ge(d);if(S&&(S.default||S.onRequest||S.onGet))if(Array.isArray(L)&&L.length>0){if(typeof S.onStaticGenerate=="function"&&L.length>0){const O=await S.onStaticGenerate({env:{get(D){return e.getEnv(D)}}});if(Array.isArray(O.params))for(const D of O.params){const J=te(R,L,D);b(J,D)}}}else b(R,void 0)};(async()=>{await Promise.all(c.map(m)),$=!0,w()})()}catch(f){y(f)}})}function ye(e){if(!e.qwikRouterConfigModulePath)if(e.qwikCityPlanModulePath)console.warn("`qwikCityPlanModulePath` is deprecated. Use `qwikRouterConfigModulePath` instead.");else throw new Error('Missing "qwikRouterConfigModulePath" option');if(!e.renderModulePath)throw new Error('Missing "renderModulePath" option');let t=e.origin;if(typeof t!="string"||t.trim().length===0)throw new Error('Missing "origin" option');if(t=t.trim(),!/:\/\//.test(t)||t.startsWith("://"))throw new Error(`"origin" must start with a valid protocol, such as "https://" or "http://", received "${t}"`);try{new URL(t)}catch(s){throw new Error(`Invalid "origin": ${s}`)}}async function Te(e){if(_.isMainThread){const t=await Q(e);return await Pe(t)}throw new Error("generate() cannot be called from a worker thread")}!_.isMainThread&&_.workerData&&(async()=>{const e=await Q(_.workerData);await ne(e)})();exports.generate=Te;
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});async function e(t){console.error("Deno not implemented"),Deno.exit(1)}exports.generate=e;
@@ -1,118 +1,5 @@
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 index_exports = {};
32
- __export(index_exports, {
33
- vercelEdgeAdapter: () => vercelEdgeAdapter
34
- });
35
- module.exports = __toCommonJS(index_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
- });
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const g=require("node:fs"),l=require("node:path"),q=require("@qwik.dev/router/middleware/request-handler");async function b(e,n,t,r,w){t&&!t.endsWith("/")&&(t+="/");const m=new Set([t+"/"+(globalThis.__QWIK_BUILD_DIR__||"build")+"/",t+"/"+(globalThis.__QWIK_ASSETS_DIR__||"assets")+"/"]),s=new Set(r.map(_)),h=[],p=async(c,d,f)=>{if(f=_(f),m.has(f))return;const y=l.join(c,d);if(d==="index.html"||d==="q-data.json"){!s.has(f)&&w&&await g.promises.unlink(y);return}if(d==="404.html"){const v=await g.promises.readFile(y,"utf-8");h.push([f,v]);return}const o=await g.promises.stat(y);o.isDirectory()?await i(y,f+d+"/"):o.isFile()&&s.add(f+d)},i=async(c,d)=>{const f=await g.promises.readdir(c);await Promise.all(f.map(y=>p(c,y,d)))};g.existsSync(e)&&await i(e,t);const u=j(t,h),a=D(s);await E(a,u,n)}function _(e){return e.endsWith("/")?e:e+"/"}function j(e,n){if(n.sort((t,r)=>t[0].length>r[0].length?-1:t[0].length<r[0].length?1:t[0]<r[0]?-1:t[0]>r[0]?1:0),!n.some(t=>t[0]===e)){const t=q.getErrorHtml(404,"Resource Not Found");n.push([e,t])}return JSON.stringify(n,null,2).slice(1,-1)}function D(e){return JSON.stringify(Array.from(new Set(e)).sort()).slice(1,-1)}const E=async(e,n,t)=>{const r=new Set,w=async s=>{const h=await g.promises.readFile(s,"utf-8");let p=!1;const i=h.replace(/(['"])__QWIK_ROUTER_(STATIC_PATHS|NOT_FOUND)_ARRAY__\1/g,(u,a,c)=>(p=!0,c==="STATIC_PATHS"?e:n));p&&await g.promises.writeFile(s,i)},m=async s=>{const h=await g.promises.readdir(s,{withFileTypes:!0});for(const p of h)if(p.isDirectory())await m(l.join(s,p.name));else if(p.name.endsWith("js")){const i=w(l.join(s,p.name)).finally(()=>{r.delete(i)});r.add(i)}};await m(t),await Promise.all(r)};function O(e){let n=null,t=null,r=null,w=null,m=null,s=!1;const h=[];return{name:`vite-plugin-qwik-router-ssg-${e.name}`,enforce:"post",apply:"build",config(i){return typeof e.config=="function"&&(i=e.config(i)),i.define={"process.env.NODE_ENV":JSON.stringify("production"),...i.define},i},configResolved(i){if(s=!!i.build.ssr,s){if(n=i.plugins.find(u=>u.name==="vite-plugin-qwik-router"),!n)throw new Error("Missing vite-plugin-qwik-router");if(t=i.plugins.find(u=>u.name==="vite-plugin-qwik"),!t)throw new Error("Missing vite-plugin-qwik");if(r=i.build.outDir,i.build?.ssr!==!0)throw new Error(`"build.ssr" must be set to "true" in order to use the "${e.name}" adapter.`);if(!i.build?.rollupOptions?.input)throw new Error(`"build.rollupOptions.input" must be set in order to use the "${e.name}" adapter.`)}},buildStart(){if(s&&e.ssg!==null){const{srcDir:i}=t.api.getOptions();this.emitFile({id:"@qwik-router-config",type:"chunk",fileName:"@qwik-router-config.js"}),this.emitFile({id:`${i}/entry.ssr`,type:"chunk",fileName:"entry.ssr.js"})}},generateBundle(i,u){if(s){h.length=0;for(const a in u){const c=u[a];c.type==="chunk"&&c.isEntry&&(h.push(a),c.name==="entry.ssr"?w=l.join(r,a):c.name==="@qwik-router-config"&&(m=l.join(r,a)))}}},closeBundle:{sequential:!0,async handler(){if(s&&r&&n?.api&&t?.api){const i=e.staticPaths||[],u=n.api.getRoutes(),a=n.api.getBasePathname(),c=t.api.getClientOutDir(),d=t.api.getClientPublicOutDir(),f=t.api.getAssetsDir(),y=t.api.getRootDir()??void 0;if(e.ssg!==null&&w&&m&&c&&d){let o=e.ssg?.origin??e.origin;o||(o="https://yoursite.qwik.dev"),o.length>0&&!/:\/\//.test(o)&&(o=`https://${o}`),o.startsWith("//")&&(o=`https:${o}`);try{o=new URL(o).origin}catch{this.warn(`Invalid "origin" option: "${o}". Using default origin: "https://yoursite.qwik.dev"`),o="https://yoursite.qwik.dev"}const v=await Promise.resolve().then(()=>require("./index-BqUeglYs.cjs")),P={maxWorkers:e.maxWorkers,basePathname:a,outDir:d,rootDir:y,...e.ssg,origin:o,renderModulePath:w,qwikRouterConfigModulePath:m},k=await v.generate(P);if(k.errors>0){const S=new Error(`Error while running SSG from "${e.name}" adapter. At least one path failed to render.`);S.stack=void 0,this.error(S)}i.push(...k.staticPaths)}await b(d,r,f?l.join(a,f):a,i,!!e.cleanStaticGenerated),typeof e.generate=="function"&&await e.generate({outputEntries:h,serverOutDir:r,clientOutDir:c,clientPublicOutDir:d,basePathname:a,routes:u,assetsDir:f,warn:o=>this.warn(o),error:o=>this.error(o)}),this.warn(`
2
+ ==============================================
3
+ Note: Make sure that you are serving the built files with proper cache headers.
4
+ See https://qwik.dev/docs/deployments/#cache-headers for more information.
5
+ ==============================================`),e.ssg!==null&&setTimeout(()=>{process.exit(0)},5e3).unref()}}}}}function C(e,n){const t=l.resolve("/");let r=e;for(let w=0;w<20;w++){if(r=l.dirname(r),l.basename(r)===n)return r;if(r===t)break}throw new Error(`Unable to find "${n}" directory from "${e}"`)}function R(e={}){return O({name:"vercel-edge",origin:process?.env?.VERCEL_URL||"https://yoursitename.vercel.app",ssg:e.ssg,staticPaths:e.staticPaths,cleanStaticGenerated:!0,config(n){const t=n.build?.outDir||l.join(".vercel","output","functions","_qwik-router.func");return{resolve:{conditions:e.target==="node"?["node","import","module","browser","default"]:["edge-light","webworker","worker","browser","module","main"]},ssr:{target:e.target==="node"?"node":"webworker",noExternal:!0},build:{ssr:!0,outDir:t,rollupOptions:{output:{format:"es",hoistTransitiveImports:!1}}},publicDir:!1}},async generate({clientPublicOutDir:n,serverOutDir:t,basePathname:r,outputEntries:w}){const m=C(t,"output");if(e.outputConfig!==!1){const a={routes:[{handle:"filesystem"},{src:r+".*",dest:"/_qwik-router"}],version:3};await g.promises.writeFile(l.join(m,"config.json"),JSON.stringify(a,null,2))}let s=e.vcConfigEntryPoint;s||(w.some(a=>a==="entry.vercel-edge.mjs")?s="entry.vercel-edge.mjs":s="entry.vercel-edge.js");const h=l.join(t,".vc-config.json"),p={runtime:"edge",entrypoint:s,envVarsInUse:e.vcConfigEnvVarsInUse};await g.promises.writeFile(h,JSON.stringify(p,null,2));let i=l.join(m,"static");const u=r.split("/").filter(a=>a.length>0);u.length>0&&(i=l.join(i,...u)),await g.promises.rm(i,{recursive:!0,force:!0}),await g.promises.mkdir(l.dirname(i),{recursive:!0}),await g.promises.rename(n,i)}})}exports.vercelEdgeAdapter=R;
@@ -1,7 +1,7 @@
1
1
  import { ServerAdapterOptions } from '../../shared/vite';
2
- import type { StaticGenerateRenderOptions } from '@qwik.dev/router/static';
2
+ import type { SsgRenderOptions } from 'packages/qwik-router/src/ssg';
3
3
 
4
- export { StaticGenerateRenderOptions }
4
+ export { SsgRenderOptions }
5
5
 
6
6
  /** @public */
7
7
  export declare function vercelEdgeAdapter(opts?: VercelEdgeAdapterOptions): any;
@@ -1,83 +1,262 @@
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({
1
+ import d from "node:fs";
2
+ import { join as m, resolve as D, dirname as P, basename as q } from "node:path";
3
+ import { getErrorHtml as E } from "@qwik.dev/router/middleware/request-handler";
4
+ async function O(e, n, t, r, g) {
5
+ t && !t.endsWith("/") && (t += "/");
6
+ const p = /* @__PURE__ */ new Set([
7
+ t + "/" + (globalThis.__QWIK_BUILD_DIR__ || "build") + "/",
8
+ t + "/" + (globalThis.__QWIK_ASSETS_DIR__ || "assets") + "/"
9
+ ]), s = new Set(r.map(S)), w = [], h = async (u, c, f) => {
10
+ if (f = S(f), p.has(f))
11
+ return;
12
+ const y = m(u, c);
13
+ if (c === "index.html" || c === "q-data.json") {
14
+ !s.has(f) && g && await d.promises.unlink(y);
15
+ return;
16
+ }
17
+ if (c === "404.html") {
18
+ const v = await d.promises.readFile(y, "utf-8");
19
+ w.push([f, v]);
20
+ return;
21
+ }
22
+ const o = await d.promises.stat(y);
23
+ o.isDirectory() ? await i(y, f + c + "/") : o.isFile() && s.add(f + c);
24
+ }, i = async (u, c) => {
25
+ const f = await d.promises.readdir(u);
26
+ await Promise.all(f.map((y) => h(u, y, c)));
27
+ };
28
+ d.existsSync(e) && await i(e, t);
29
+ const l = C(t, w), a = R(s);
30
+ await T(a, l, n);
31
+ }
32
+ function S(e) {
33
+ return e.endsWith("/") ? e : e + "/";
34
+ }
35
+ function C(e, n) {
36
+ if (n.sort((t, r) => t[0].length > r[0].length ? -1 : t[0].length < r[0].length ? 1 : t[0] < r[0] ? -1 : t[0] > r[0] ? 1 : 0), !n.some((t) => t[0] === e)) {
37
+ const t = E(404, "Resource Not Found");
38
+ n.push([e, t]);
39
+ }
40
+ return JSON.stringify(n, null, 2).slice(1, -1);
41
+ }
42
+ function R(e) {
43
+ return JSON.stringify(Array.from(new Set(e)).sort()).slice(1, -1);
44
+ }
45
+ const T = async (e, n, t) => {
46
+ const r = /* @__PURE__ */ new Set(), g = async (s) => {
47
+ const w = await d.promises.readFile(s, "utf-8");
48
+ let h = !1;
49
+ const i = w.replace(
50
+ /(['"])__QWIK_ROUTER_(STATIC_PATHS|NOT_FOUND)_ARRAY__\1/g,
51
+ (l, a, u) => (h = !0, u === "STATIC_PATHS" ? e : n)
52
+ );
53
+ h && await d.promises.writeFile(s, i);
54
+ }, p = async (s) => {
55
+ const w = await d.promises.readdir(s, { withFileTypes: !0 });
56
+ for (const h of w)
57
+ if (h.isDirectory())
58
+ await p(m(s, h.name));
59
+ else if (h.name.endsWith("js")) {
60
+ const i = g(m(s, h.name)).finally(() => {
61
+ r.delete(i);
62
+ });
63
+ r.add(i);
64
+ }
65
+ };
66
+ await p(t), await Promise.all(r);
67
+ };
68
+ function I(e) {
69
+ let n = null, t = null, r = null, g = null, p = null, s = !1;
70
+ const w = [];
71
+ return {
72
+ name: `vite-plugin-qwik-router-ssg-${e.name}`,
73
+ enforce: "post",
74
+ apply: "build",
75
+ config(i) {
76
+ return typeof e.config == "function" && (i = e.config(i)), i.define = {
77
+ "process.env.NODE_ENV": JSON.stringify("production"),
78
+ ...i.define
79
+ }, i;
80
+ },
81
+ configResolved(i) {
82
+ if (s = !!i.build.ssr, s) {
83
+ if (n = i.plugins.find(
84
+ (l) => l.name === "vite-plugin-qwik-router"
85
+ ), !n)
86
+ throw new Error("Missing vite-plugin-qwik-router");
87
+ if (t = i.plugins.find(
88
+ (l) => l.name === "vite-plugin-qwik"
89
+ ), !t)
90
+ throw new Error("Missing vite-plugin-qwik");
91
+ if (r = i.build.outDir, i.build?.ssr !== !0)
92
+ throw new Error(
93
+ `"build.ssr" must be set to "true" in order to use the "${e.name}" adapter.`
94
+ );
95
+ if (!i.build?.rollupOptions?.input)
96
+ throw new Error(
97
+ `"build.rollupOptions.input" must be set in order to use the "${e.name}" adapter.`
98
+ );
99
+ }
100
+ },
101
+ buildStart() {
102
+ if (s && e.ssg !== null) {
103
+ const { srcDir: i } = t.api.getOptions();
104
+ this.emitFile({
105
+ id: "@qwik-router-config",
106
+ type: "chunk",
107
+ fileName: "@qwik-router-config.js"
108
+ }), this.emitFile({
109
+ id: `${i}/entry.ssr`,
110
+ type: "chunk",
111
+ fileName: "entry.ssr.js"
112
+ });
113
+ }
114
+ },
115
+ generateBundle(i, l) {
116
+ if (s) {
117
+ w.length = 0;
118
+ for (const a in l) {
119
+ const u = l[a];
120
+ u.type === "chunk" && u.isEntry && (w.push(a), u.name === "entry.ssr" ? g = m(r, a) : u.name === "@qwik-router-config" && (p = m(r, a)));
121
+ }
122
+ }
123
+ },
124
+ closeBundle: {
125
+ sequential: !0,
126
+ async handler() {
127
+ if (s && r && n?.api && t?.api) {
128
+ const i = e.staticPaths || [], l = n.api.getRoutes(), a = n.api.getBasePathname(), u = t.api.getClientOutDir(), c = t.api.getClientPublicOutDir(), f = t.api.getAssetsDir(), y = t.api.getRootDir() ?? void 0;
129
+ if (e.ssg !== null && g && p && u && c) {
130
+ let o = e.ssg?.origin ?? e.origin;
131
+ o || (o = "https://yoursite.qwik.dev"), o.length > 0 && !/:\/\//.test(o) && (o = `https://${o}`), o.startsWith("//") && (o = `https:${o}`);
132
+ try {
133
+ o = new URL(o).origin;
134
+ } catch {
135
+ this.warn(
136
+ `Invalid "origin" option: "${o}". Using default origin: "https://yoursite.qwik.dev"`
137
+ ), o = "https://yoursite.qwik.dev";
138
+ }
139
+ const v = await import("./index-CrwlB95_.js"), b = {
140
+ maxWorkers: e.maxWorkers,
141
+ basePathname: a,
142
+ outDir: c,
143
+ rootDir: y,
144
+ ...e.ssg,
145
+ origin: o,
146
+ renderModulePath: g,
147
+ qwikRouterConfigModulePath: p
148
+ }, k = await v.generate(b);
149
+ if (k.errors > 0) {
150
+ const _ = new Error(
151
+ `Error while running SSG from "${e.name}" adapter. At least one path failed to render.`
152
+ );
153
+ _.stack = void 0, this.error(_);
154
+ }
155
+ i.push(...k.staticPaths);
156
+ }
157
+ await O(
158
+ c,
159
+ r,
160
+ f ? m(a, f) : a,
161
+ i,
162
+ !!e.cleanStaticGenerated
163
+ ), typeof e.generate == "function" && await e.generate({
164
+ outputEntries: w,
165
+ serverOutDir: r,
166
+ clientOutDir: u,
167
+ clientPublicOutDir: c,
168
+ basePathname: a,
169
+ routes: l,
170
+ assetsDir: f,
171
+ warn: (o) => this.warn(o),
172
+ error: (o) => this.error(o)
173
+ }), this.warn(
174
+ `
175
+ ==============================================
176
+ Note: Make sure that you are serving the built files with proper cache headers.
177
+ See https://qwik.dev/docs/deployments/#cache-headers for more information.
178
+ ==============================================`
179
+ ), e.ssg !== null && setTimeout(() => {
180
+ process.exit(0);
181
+ }, 5e3).unref();
182
+ }
183
+ }
184
+ }
185
+ };
186
+ }
187
+ function A(e, n) {
188
+ const t = D("/");
189
+ let r = e;
190
+ for (let g = 0; g < 20; g++) {
191
+ if (r = P(r), q(r) === n)
192
+ return r;
193
+ if (r === t)
194
+ break;
195
+ }
196
+ throw new Error(`Unable to find "${n}" directory from "${e}"`);
197
+ }
198
+ function U(e = {}) {
199
+ return I({
8
200
  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");
201
+ origin: process?.env?.VERCEL_URL || "https://yoursitename.vercel.app",
202
+ ssg: e.ssg,
203
+ staticPaths: e.staticPaths,
204
+ cleanStaticGenerated: !0,
205
+ config(n) {
206
+ const t = n.build?.outDir || m(".vercel", "output", "functions", "_qwik-router.func");
16
207
  return {
17
208
  resolve: {
18
- conditions: opts.target === "node" ? ["node", "import", "module", "browser", "default"] : ["edge-light", "webworker", "worker", "browser", "module", "main"]
209
+ conditions: e.target === "node" ? ["node", "import", "module", "browser", "default"] : ["edge-light", "webworker", "worker", "browser", "module", "main"]
19
210
  },
20
211
  ssr: {
21
- target: opts.target === "node" ? "node" : "webworker",
22
- noExternal: true
212
+ target: e.target === "node" ? "node" : "webworker",
213
+ noExternal: !0
23
214
  },
24
215
  build: {
25
- ssr: true,
26
- outDir,
216
+ ssr: !0,
217
+ outDir: t,
27
218
  rollupOptions: {
28
219
  output: {
29
220
  format: "es",
30
- hoistTransitiveImports: false
221
+ hoistTransitiveImports: !1
31
222
  }
32
223
  }
33
224
  },
34
- publicDir: false
225
+ publicDir: !1
35
226
  };
36
227
  },
37
- async generate({ clientPublicOutDir, serverOutDir, basePathname, outputEntries }) {
38
- const vercelOutputDir = getParentDir(serverOutDir, "output");
39
- if (opts.outputConfig !== false) {
40
- const vercelOutputConfig = {
228
+ async generate({ clientPublicOutDir: n, serverOutDir: t, basePathname: r, outputEntries: g }) {
229
+ const p = A(t, "output");
230
+ if (e.outputConfig !== !1) {
231
+ const a = {
41
232
  routes: [
42
233
  { handle: "filesystem" },
43
234
  {
44
- src: basePathname + ".*",
235
+ src: r + ".*",
45
236
  dest: "/_qwik-router"
46
237
  }
47
238
  ],
48
239
  version: 3
49
240
  };
50
- await fs.promises.writeFile(
51
- join(vercelOutputDir, "config.json"),
52
- JSON.stringify(vercelOutputConfig, null, 2)
241
+ await d.promises.writeFile(
242
+ m(p, "config.json"),
243
+ JSON.stringify(a, null, 2)
53
244
  );
54
245
  }
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 = {
246
+ let s = e.vcConfigEntryPoint;
247
+ s || (g.some((a) => a === "entry.vercel-edge.mjs") ? s = "entry.vercel-edge.mjs" : s = "entry.vercel-edge.js");
248
+ const w = m(t, ".vc-config.json"), h = {
65
249
  runtime: "edge",
66
- entrypoint,
67
- envVarsInUse: opts.vcConfigEnvVarsInUse
250
+ entrypoint: s,
251
+ envVarsInUse: e.vcConfigEnvVarsInUse
68
252
  };
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);
253
+ await d.promises.writeFile(w, JSON.stringify(h, null, 2));
254
+ let i = m(p, "static");
255
+ const l = r.split("/").filter((a) => a.length > 0);
256
+ l.length > 0 && (i = m(i, ...l)), await d.promises.rm(i, { recursive: !0, force: !0 }), await d.promises.mkdir(P(i), { recursive: !0 }), await d.promises.rename(n, i);
78
257
  }
79
258
  });
80
259
  }
81
260
  export {
82
- vercelEdgeAdapter
261
+ U as vercelEdgeAdapter
83
262
  };