@qwik.dev/router 2.0.0-alpha.9 → 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 (159) hide show
  1. package/README.md +1 -1
  2. package/adapters/static/vite.d.ts +1 -1
  3. package/lib/adapters/azure-swa/vite/index-BqUeglYs.cjs +1 -0
  4. package/lib/adapters/azure-swa/vite/index-CBIchDYq.js +651 -0
  5. package/lib/adapters/azure-swa/vite/index-ClHGw5z1.js +6 -0
  6. package/lib/adapters/azure-swa/vite/index-CrwlB95_.js +22 -0
  7. package/lib/adapters/azure-swa/vite/index-DTIOTwZo.cjs +11 -0
  8. package/lib/adapters/azure-swa/vite/index-vQuPcef3.cjs +1 -0
  9. package/lib/adapters/azure-swa/vite/index.cjs +5 -96
  10. package/lib/adapters/azure-swa/vite/index.d.ts +13 -13
  11. package/lib/adapters/azure-swa/vite/index.mjs +201 -26
  12. package/lib/adapters/bun-server/vite/index-BqUeglYs.cjs +1 -0
  13. package/lib/adapters/bun-server/vite/index-CBIchDYq.js +651 -0
  14. package/lib/adapters/bun-server/vite/index-ClHGw5z1.js +6 -0
  15. package/lib/adapters/bun-server/vite/index-CrwlB95_.js +22 -0
  16. package/lib/adapters/bun-server/vite/index-DTIOTwZo.cjs +11 -0
  17. package/lib/adapters/bun-server/vite/index-vQuPcef3.cjs +1 -0
  18. package/lib/adapters/bun-server/vite/index.cjs +5 -50
  19. package/lib/adapters/bun-server/vite/index.d.ts +14 -14
  20. package/lib/adapters/bun-server/vite/index.mjs +196 -12
  21. package/lib/adapters/cloud-run/vite/index-BqUeglYs.cjs +1 -0
  22. package/lib/adapters/cloud-run/vite/index-CBIchDYq.js +651 -0
  23. package/lib/adapters/cloud-run/vite/index-ClHGw5z1.js +6 -0
  24. package/lib/adapters/cloud-run/vite/index-CrwlB95_.js +22 -0
  25. package/lib/adapters/cloud-run/vite/index-DTIOTwZo.cjs +11 -0
  26. package/lib/adapters/cloud-run/vite/index-vQuPcef3.cjs +1 -0
  27. package/lib/adapters/cloud-run/vite/index.cjs +5 -47
  28. package/lib/adapters/cloud-run/vite/index.d.ts +13 -13
  29. package/lib/adapters/cloud-run/vite/index.mjs +195 -11
  30. package/lib/adapters/cloudflare-pages/vite/index-BIeHg2Cj.cjs +5 -0
  31. package/lib/adapters/cloudflare-pages/vite/index-C455V8_A.cjs +1 -0
  32. package/lib/adapters/cloudflare-pages/vite/index-ClHGw5z1.js +6 -0
  33. package/lib/adapters/cloudflare-pages/vite/index-D3HITboM.js +645 -0
  34. package/lib/adapters/cloudflare-pages/vite/index-DKcVHRBy.cjs +11 -0
  35. package/lib/adapters/cloudflare-pages/vite/index-DwovcBp3.js +22 -0
  36. package/lib/adapters/cloudflare-pages/vite/index-bogwy7wh.js +250 -0
  37. package/lib/adapters/cloudflare-pages/vite/index-vQuPcef3.cjs +1 -0
  38. package/lib/adapters/cloudflare-pages/vite/index.cjs +1 -115
  39. package/lib/adapters/cloudflare-pages/vite/index.d.ts +27 -27
  40. package/lib/adapters/cloudflare-pages/vite/index.mjs +4 -78
  41. package/lib/adapters/deno-server/vite/index-BqUeglYs.cjs +1 -0
  42. package/lib/adapters/deno-server/vite/index-CBIchDYq.js +651 -0
  43. package/lib/adapters/deno-server/vite/index-ClHGw5z1.js +6 -0
  44. package/lib/adapters/deno-server/vite/index-CrwlB95_.js +22 -0
  45. package/lib/adapters/deno-server/vite/index-DTIOTwZo.cjs +11 -0
  46. package/lib/adapters/deno-server/vite/index-vQuPcef3.cjs +1 -0
  47. package/lib/adapters/deno-server/vite/index.cjs +5 -62
  48. package/lib/adapters/deno-server/vite/index.d.ts +14 -14
  49. package/lib/adapters/deno-server/vite/index.mjs +198 -14
  50. package/lib/adapters/netlify-edge/vite/index-BqUeglYs.cjs +1 -0
  51. package/lib/adapters/netlify-edge/vite/index-CBIchDYq.js +651 -0
  52. package/lib/adapters/netlify-edge/vite/index-ClHGw5z1.js +6 -0
  53. package/lib/adapters/netlify-edge/vite/index-CrwlB95_.js +22 -0
  54. package/lib/adapters/netlify-edge/vite/index-DTIOTwZo.cjs +11 -0
  55. package/lib/adapters/netlify-edge/vite/index-vQuPcef3.cjs +1 -0
  56. package/lib/adapters/netlify-edge/vite/index.cjs +6 -129
  57. package/lib/adapters/netlify-edge/vite/index.d.ts +44 -44
  58. package/lib/adapters/netlify-edge/vite/index.mjs +240 -60
  59. package/lib/adapters/node-server/vite/index-BqUeglYs.cjs +1 -0
  60. package/lib/adapters/node-server/vite/index-CBIchDYq.js +651 -0
  61. package/lib/adapters/node-server/vite/index-ClHGw5z1.js +6 -0
  62. package/lib/adapters/node-server/vite/index-CrwlB95_.js +22 -0
  63. package/lib/adapters/node-server/vite/index-DTIOTwZo.cjs +11 -0
  64. package/lib/adapters/node-server/vite/index-vQuPcef3.cjs +1 -0
  65. package/lib/adapters/node-server/vite/index.cjs +5 -50
  66. package/lib/adapters/node-server/vite/index.d.ts +14 -14
  67. package/lib/adapters/node-server/vite/index.mjs +196 -12
  68. package/lib/adapters/shared/vite/index-BqUeglYs.cjs +1 -0
  69. package/lib/adapters/shared/vite/index-CBIchDYq.js +651 -0
  70. package/lib/adapters/shared/vite/index-ClHGw5z1.js +6 -0
  71. package/lib/adapters/shared/vite/index-CrwlB95_.js +22 -0
  72. package/lib/adapters/shared/vite/index-DTIOTwZo.cjs +11 -0
  73. package/lib/adapters/shared/vite/index-vQuPcef3.cjs +1 -0
  74. package/lib/adapters/shared/vite/index.cjs +5 -371
  75. package/lib/adapters/shared/vite/index.d.ts +108 -114
  76. package/lib/adapters/shared/vite/index.mjs +158 -288
  77. package/lib/adapters/ssg/vite/index-BqUeglYs.cjs +1 -0
  78. package/lib/adapters/ssg/vite/index-CBIchDYq.js +651 -0
  79. package/lib/adapters/ssg/vite/index-ClHGw5z1.js +6 -0
  80. package/lib/adapters/ssg/vite/index-CrwlB95_.js +22 -0
  81. package/lib/adapters/ssg/vite/index-DTIOTwZo.cjs +11 -0
  82. package/lib/adapters/ssg/vite/index-vQuPcef3.cjs +1 -0
  83. package/lib/adapters/ssg/vite/index.cjs +5 -0
  84. package/lib/adapters/ssg/vite/index.d.ts +13 -0
  85. package/lib/adapters/ssg/vite/index.mjs +201 -0
  86. package/lib/adapters/vercel-edge/vite/index-BqUeglYs.cjs +1 -0
  87. package/lib/adapters/vercel-edge/vite/index-CBIchDYq.js +651 -0
  88. package/lib/adapters/vercel-edge/vite/index-ClHGw5z1.js +6 -0
  89. package/lib/adapters/vercel-edge/vite/index-CrwlB95_.js +22 -0
  90. package/lib/adapters/vercel-edge/vite/index-DTIOTwZo.cjs +11 -0
  91. package/lib/adapters/vercel-edge/vite/index-vQuPcef3.cjs +1 -0
  92. package/lib/adapters/vercel-edge/vite/index.cjs +5 -118
  93. package/lib/adapters/vercel-edge/vite/index.d.ts +45 -45
  94. package/lib/adapters/vercel-edge/vite/index.mjs +230 -51
  95. package/lib/index.d.ts +1000 -810
  96. package/lib/index.qwik.cjs +438 -203
  97. package/lib/index.qwik.mjs +440 -205
  98. package/lib/middleware/aws-lambda/index.cjs +1 -0
  99. package/lib/middleware/aws-lambda/index.d.ts +49 -48
  100. package/lib/middleware/aws-lambda/index.mjs +27 -41
  101. package/lib/middleware/azure-swa/index.cjs +1 -0
  102. package/lib/middleware/azure-swa/index.d.ts +28 -28
  103. package/lib/middleware/azure-swa/index.mjs +46 -269
  104. package/lib/middleware/bun/index.cjs +1 -0
  105. package/lib/middleware/bun/index.d.ts +35 -35
  106. package/lib/middleware/bun/index.mjs +68 -120
  107. package/lib/middleware/cloudflare-pages/index.cjs +1 -0
  108. package/lib/middleware/cloudflare-pages/index.d.ts +35 -35
  109. package/lib/middleware/cloudflare-pages/index.mjs +48 -80
  110. package/lib/middleware/deno/index.cjs +1 -0
  111. package/lib/middleware/deno/index.d.ts +47 -47
  112. package/lib/middleware/deno/index.mjs +63 -110
  113. package/lib/middleware/firebase/index.cjs +1 -0
  114. package/lib/middleware/firebase/index.d.ts +26 -26
  115. package/lib/middleware/firebase/index.mjs +16 -28
  116. package/lib/middleware/netlify-edge/index.cjs +1 -0
  117. package/lib/middleware/netlify-edge/index.d.ts +27 -27
  118. package/lib/middleware/netlify-edge/index.mjs +36 -64
  119. package/lib/middleware/node/index.cjs +1 -314
  120. package/lib/middleware/node/index.d.ts +64 -64
  121. package/lib/middleware/node/index.mjs +116 -198
  122. package/lib/middleware/request-handler/index.cjs +11 -1538
  123. package/lib/middleware/request-handler/index.d.ts +711 -676
  124. package/lib/middleware/request-handler/index.mjs +895 -1281
  125. package/lib/middleware/vercel-edge/index.cjs +1 -0
  126. package/lib/middleware/vercel-edge/index.d.ts +26 -26
  127. package/lib/middleware/vercel-edge/index.mjs +47 -82
  128. package/lib/modules.d.ts +4 -12
  129. package/lib/service-worker.cjs +1 -267
  130. package/lib/service-worker.d.ts +15 -4
  131. package/lib/service-worker.mjs +3 -263
  132. package/lib/ssg/deno.cjs +1 -0
  133. package/lib/ssg/deno.mjs +6 -0
  134. package/lib/ssg/index-CBIchDYq.js +651 -0
  135. package/lib/ssg/index-ClHGw5z1.js +6 -0
  136. package/lib/ssg/index-DTIOTwZo.cjs +11 -0
  137. package/lib/ssg/index-vQuPcef3.cjs +1 -0
  138. package/lib/ssg/index.cjs +1 -0
  139. package/lib/{static → ssg}/index.d.ts +96 -96
  140. package/lib/ssg/index.mjs +22 -0
  141. package/lib/ssg/node.cjs +11 -0
  142. package/lib/ssg/node.mjs +651 -0
  143. package/lib/vite/index.cjs +29 -27484
  144. package/lib/vite/index.d.ts +170 -154
  145. package/lib/vite/index.mjs +1422 -27288
  146. package/modules.d.ts +4 -12
  147. package/package.json +51 -40
  148. package/ssg.d.ts +2 -0
  149. package/static.d.ts +1 -1
  150. package/lib/adapters/static/vite/index.cjs +0 -361
  151. package/lib/adapters/static/vite/index.d.ts +0 -10
  152. package/lib/adapters/static/vite/index.mjs +0 -324
  153. package/lib/static/deno.mjs +0 -8
  154. package/lib/static/index.cjs +0 -67
  155. package/lib/static/index.mjs +0 -48
  156. package/lib/static/node.cjs +0 -1124
  157. package/lib/static/node.mjs +0 -1086
  158. package/middleware/request-handler/generated/not-found-paths.ts +0 -7
  159. 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,129 +1,6 @@
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/netlify-edge/vite/index.ts
31
- var vite_exports = {};
32
- __export(vite_exports, {
33
- netlifyEdgeAdapter: () => netlifyEdgeAdapter
34
- });
35
- module.exports = __toCommonJS(vite_exports);
36
-
37
- // packages/qwik-router/src/runtime/src/qwik-router-config.ts
38
- var basePathname = "/";
39
-
40
- // packages/qwik-router/src/adapters/netlify-edge/vite/index.ts
41
- var import_node_fs = __toESM(require("node:fs"), 1);
42
- var import_node_path = require("node:path");
43
- var import_vite = require("../../shared/vite/index.cjs");
44
- function netlifyEdgeAdapter(opts = {}) {
45
- const env = process == null ? void 0 : process.env;
46
- return (0, import_vite.viteAdapter)({
47
- name: "netlify-edge",
48
- origin: (env == null ? void 0 : env.ORIGIN) ?? (env == null ? void 0 : env.URL) ?? "https://yoursitename.netlify.app",
49
- ssg: opts.ssg,
50
- staticPaths: opts.staticPaths,
51
- cleanStaticGenerated: true,
52
- config(config) {
53
- var _a;
54
- const outDir = ((_a = config.build) == null ? void 0 : _a.outDir) || ".netlify/edge-functions/entry.netlify-edge";
55
- return {
56
- resolve: {
57
- conditions: ["webworker", "worker"]
58
- },
59
- ssr: {
60
- target: "webworker",
61
- noExternal: true,
62
- external: ["node:async_hooks"]
63
- },
64
- build: {
65
- ssr: true,
66
- outDir,
67
- rollupOptions: {
68
- output: {
69
- format: "es",
70
- hoistTransitiveImports: false
71
- }
72
- }
73
- },
74
- publicDir: false
75
- };
76
- },
77
- async generate({ serverOutDir }) {
78
- if (opts.functionRoutes !== false) {
79
- const excludedPath = [];
80
- if (typeof opts.excludedPath === "string") {
81
- excludedPath.push(opts.excludedPath);
82
- } else if (Array.isArray(opts.excludedPath)) {
83
- excludedPath.push(...opts.excludedPath);
84
- } else {
85
- excludedPath.push(
86
- "/build/*",
87
- "/favicon.ico",
88
- "/robots.txt",
89
- "/mainifest.json",
90
- "/~partytown/*",
91
- "/service-worker.js",
92
- "/sitemap.xml"
93
- );
94
- }
95
- const netlifyEdgeManifest = {
96
- functions: [
97
- {
98
- path: basePathname + "*",
99
- function: "entry.netlify-edge",
100
- cache: "manual",
101
- excludedPath
102
- }
103
- ],
104
- version: 1
105
- };
106
- const jsPath = (0, import_node_path.join)(serverOutDir, "entry.netlify-edge.js");
107
- const mjsPath = (0, import_node_path.join)(serverOutDir, "entry.netlify-edge.mjs");
108
- if ((0, import_node_fs.existsSync)(mjsPath)) {
109
- await import_node_fs.default.promises.writeFile(
110
- jsPath,
111
- [
112
- `import entry_netlifyEdge from './entry.netlify-edge.mjs';`,
113
- `export default entry_netlifyEdge;`
114
- ].join("\n")
115
- );
116
- }
117
- const netlifyEdgeFnsDir = (0, import_vite.getParentDir)(serverOutDir, "edge-functions");
118
- await import_node_fs.default.promises.writeFile(
119
- (0, import_node_path.join)(netlifyEdgeFnsDir, "manifest.json"),
120
- JSON.stringify(netlifyEdgeManifest, null, 2)
121
- );
122
- }
123
- }
124
- });
125
- }
126
- // Annotate the CommonJS export names for ESM import in node:
127
- 0 && (module.exports = {
128
- netlifyEdgeAdapter
129
- });
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const y=require("node:fs"),h=require("node:path"),b=require("@qwik.dev/router/middleware/request-handler");async function j(e,s,t,i,a){t&&!t.endsWith("/")&&(t+="/");const p=new Set([t+"/"+(globalThis.__QWIK_BUILD_DIR__||"build")+"/",t+"/"+(globalThis.__QWIK_ASSETS_DIR__||"assets")+"/"]),o=new Set(i.map(S)),d=[],f=async(l,u,c)=>{if(c=S(c),p.has(c))return;const m=h.join(l,u);if(u==="index.html"||u==="q-data.json"){!o.has(c)&&a&&await y.promises.unlink(m);return}if(u==="404.html"){const P=await y.promises.readFile(m,"utf-8");d.push([c,P]);return}const r=await y.promises.stat(m);r.isDirectory()?await n(m,c+u+"/"):r.isFile()&&o.add(c+u)},n=async(l,u)=>{const c=await y.promises.readdir(l);await Promise.all(c.map(m=>f(l,m,u)))};y.existsSync(e)&&await n(e,t);const w=q(t,d),g=E(o);await D(g,w,s)}function S(e){return e.endsWith("/")?e:e+"/"}function q(e,s){if(s.sort((t,i)=>t[0].length>i[0].length?-1:t[0].length<i[0].length?1:t[0]<i[0]?-1:t[0]>i[0]?1:0),!s.some(t=>t[0]===e)){const t=b.getErrorHtml(404,"Resource Not Found");s.push([e,t])}return JSON.stringify(s,null,2).slice(1,-1)}function E(e){return JSON.stringify(Array.from(new Set(e)).sort()).slice(1,-1)}const D=async(e,s,t)=>{const i=new Set,a=async o=>{const d=await y.promises.readFile(o,"utf-8");let f=!1;const n=d.replace(/(['"])__QWIK_ROUTER_(STATIC_PATHS|NOT_FOUND)_ARRAY__\1/g,(w,g,l)=>(f=!0,l==="STATIC_PATHS"?e:s));f&&await y.promises.writeFile(o,n)},p=async o=>{const d=await y.promises.readdir(o,{withFileTypes:!0});for(const f of d)if(f.isDirectory())await p(h.join(o,f.name));else if(f.name.endsWith("js")){const n=a(h.join(o,f.name)).finally(()=>{i.delete(n)});i.add(n)}};await p(t),await Promise.all(i)};function O(e){let s=null,t=null,i=null,a=null,p=null,o=!1;const d=[];return{name:`vite-plugin-qwik-router-ssg-${e.name}`,enforce:"post",apply:"build",config(n){return typeof e.config=="function"&&(n=e.config(n)),n.define={"process.env.NODE_ENV":JSON.stringify("production"),...n.define},n},configResolved(n){if(o=!!n.build.ssr,o){if(s=n.plugins.find(w=>w.name==="vite-plugin-qwik-router"),!s)throw new Error("Missing vite-plugin-qwik-router");if(t=n.plugins.find(w=>w.name==="vite-plugin-qwik"),!t)throw new Error("Missing vite-plugin-qwik");if(i=n.build.outDir,n.build?.ssr!==!0)throw new Error(`"build.ssr" must be set to "true" in order to use the "${e.name}" adapter.`);if(!n.build?.rollupOptions?.input)throw new Error(`"build.rollupOptions.input" must be set in order to use the "${e.name}" adapter.`)}},buildStart(){if(o&&e.ssg!==null){const{srcDir:n}=t.api.getOptions();this.emitFile({id:"@qwik-router-config",type:"chunk",fileName:"@qwik-router-config.js"}),this.emitFile({id:`${n}/entry.ssr`,type:"chunk",fileName:"entry.ssr.js"})}},generateBundle(n,w){if(o){d.length=0;for(const g in w){const l=w[g];l.type==="chunk"&&l.isEntry&&(d.push(g),l.name==="entry.ssr"?a=h.join(i,g):l.name==="@qwik-router-config"&&(p=h.join(i,g)))}}},closeBundle:{sequential:!0,async handler(){if(o&&i&&s?.api&&t?.api){const n=e.staticPaths||[],w=s.api.getRoutes(),g=s.api.getBasePathname(),l=t.api.getClientOutDir(),u=t.api.getClientPublicOutDir(),c=t.api.getAssetsDir(),m=t.api.getRootDir()??void 0;if(e.ssg!==null&&a&&p&&l&&u){let r=e.ssg?.origin??e.origin;r||(r="https://yoursite.qwik.dev"),r.length>0&&!/:\/\//.test(r)&&(r=`https://${r}`),r.startsWith("//")&&(r=`https:${r}`);try{r=new URL(r).origin}catch{this.warn(`Invalid "origin" option: "${r}". Using default origin: "https://yoursite.qwik.dev"`),r="https://yoursite.qwik.dev"}const P=await Promise.resolve().then(()=>require("./index-BqUeglYs.cjs")),v={maxWorkers:e.maxWorkers,basePathname:g,outDir:u,rootDir:m,...e.ssg,origin:r,renderModulePath:a,qwikRouterConfigModulePath:p},k=await P.generate(v);if(k.errors>0){const _=new Error(`Error while running SSG from "${e.name}" adapter. At least one path failed to render.`);_.stack=void 0,this.error(_)}n.push(...k.staticPaths)}await j(u,i,c?h.join(g,c):g,n,!!e.cleanStaticGenerated),typeof e.generate=="function"&&await e.generate({outputEntries:d,serverOutDir:i,clientOutDir:l,clientPublicOutDir:u,basePathname:g,routes:w,assetsDir:c,warn:r=>this.warn(r),error:r=>this.error(r)}),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 R(e,s){const t=h.resolve("/");let i=e;for(let a=0;a<20;a++){if(i=h.dirname(i),h.basename(i)===s)return i;if(i===t)break}throw new Error(`Unable to find "${s}" directory from "${e}"`)}function x(e={}){const s=process?.env;return O({name:"netlify-edge",origin:s?.ORIGIN??s?.URL??"https://yoursitename.netlify.app",ssg:e.ssg,staticPaths:e.staticPaths,cleanStaticGenerated:!0,config(t){const i=t.build?.outDir||".netlify/edge-functions/entry.netlify-edge";return{resolve:{conditions:["webworker","worker"]},ssr:{target:"webworker",noExternal:!0,external:["node:async_hooks"]},build:{ssr:!0,outDir:i,rollupOptions:{output:{format:"es",hoistTransitiveImports:!1}}},publicDir:!1}},async generate({serverOutDir:t,basePathname:i}){if(e.functionRoutes!==!1){const a=[];typeof e.excludedPath=="string"?a.push(e.excludedPath):Array.isArray(e.excludedPath)?a.push(...e.excludedPath):a.push("/build/*","/favicon.ico","/robots.txt","/mainifest.json","/~partytown/*","/service-worker.js","/sitemap.xml");const p={functions:[{path:i+"*",function:"entry.netlify-edge",cache:"manual",excludedPath:a}],version:1},o=h.join(t,"entry.netlify-edge.js"),d=h.join(t,"entry.netlify-edge.mjs");y.existsSync(d)&&await y.promises.writeFile(o,["import entry_netlifyEdge from './entry.netlify-edge.mjs';","export default entry_netlifyEdge;"].join(`
6
+ `));const f=R(t,"edge-functions");await y.promises.writeFile(h.join(f,"manifest.json"),JSON.stringify(p,null,2))}}})}exports.netlifyEdgeAdapter=x;
@@ -1,44 +1,44 @@
1
- import { ServerAdapterOptions } from '../../shared/vite';
2
- import type { StaticGenerateRenderOptions } from '@qwik.dev/router/static';
3
-
4
- /** @public */
5
- export declare function netlifyEdgeAdapter(opts?: NetlifyEdgeAdapterOptions): any;
6
-
7
- /** @public */
8
- export declare interface NetlifyEdgeAdapterOptions extends ServerAdapterOptions {
9
- /**
10
- * Determines if the build should generate the edge functions declarations `manifest.json` file.
11
- *
12
- * https://docs.netlify.com/edge-functions/declarations/
13
- *
14
- * Defaults to `true`.
15
- */
16
- functionRoutes?: boolean;
17
- /**
18
- * Manually add pathnames that should be treated as static paths and not SSR. For example, when
19
- * these pathnames are requested, their response should come from a static file, rather than a
20
- * server-side rendered response.
21
- */
22
- staticPaths?: string[];
23
- /**
24
- * Manually add path pattern that should be excluded from the edge function routes that are
25
- * created by the 'manifest.json' file.
26
- *
27
- * If not specified, the following paths are excluded by default:
28
- *
29
- * - /build/*
30
- * - /favicon.ico
31
- * - /robots.txt
32
- * - /mainifest.json
33
- * - /~partytown/*
34
- * - /service-worker.js
35
- * - /sitemap.xml
36
- *
37
- * https://docs.netlify.com/edge-functions/declarations/#declare-edge-functions-in-netlify-toml
38
- */
39
- excludedPath?: string | string[];
40
- }
41
-
42
- export { StaticGenerateRenderOptions }
43
-
44
- export { }
1
+ import { ServerAdapterOptions } from '../../shared/vite';
2
+ import type { SsgRenderOptions } from 'packages/qwik-router/src/ssg';
3
+
4
+ /** @public */
5
+ export declare function netlifyEdgeAdapter(opts?: NetlifyEdgeAdapterOptions): any;
6
+
7
+ /** @public */
8
+ export declare interface NetlifyEdgeAdapterOptions extends ServerAdapterOptions {
9
+ /**
10
+ * Determines if the build should generate the edge functions declarations `manifest.json` file.
11
+ *
12
+ * https://docs.netlify.com/edge-functions/declarations/
13
+ *
14
+ * Defaults to `true`.
15
+ */
16
+ functionRoutes?: boolean;
17
+ /**
18
+ * Manually add pathnames that should be treated as static paths and not SSR. For example, when
19
+ * these pathnames are requested, their response should come from a static file, rather than a
20
+ * server-side rendered response.
21
+ */
22
+ staticPaths?: string[];
23
+ /**
24
+ * Manually add path pattern that should be excluded from the edge function routes that are
25
+ * created by the 'manifest.json' file.
26
+ *
27
+ * If not specified, the following paths are excluded by default:
28
+ *
29
+ * - /build/*
30
+ * - /favicon.ico
31
+ * - /robots.txt
32
+ * - /mainifest.json
33
+ * - /~partytown/*
34
+ * - /service-worker.js
35
+ * - /sitemap.xml
36
+ *
37
+ * https://docs.netlify.com/edge-functions/declarations/#declare-edge-functions-in-netlify-toml
38
+ */
39
+ excludedPath?: string | string[];
40
+ }
41
+
42
+ export { SsgRenderOptions }
43
+
44
+ export { }
@@ -1,92 +1,272 @@
1
- // packages/qwik-router/src/runtime/src/qwik-router-config.ts
2
- var basePathname = "/";
3
-
4
- // packages/qwik-router/src/adapters/netlify-edge/vite/index.ts
5
- import fs, { existsSync } from "node:fs";
6
- import { join } from "node:path";
7
- import { getParentDir, viteAdapter } from "../../shared/vite/index.mjs";
8
- function netlifyEdgeAdapter(opts = {}) {
9
- const env = process == null ? void 0 : process.env;
10
- return viteAdapter({
1
+ import y, { existsSync as b } from "node:fs";
2
+ import { join as p, resolve as D, dirname as E, basename as q } from "node:path";
3
+ import { getErrorHtml as R } from "@qwik.dev/router/middleware/request-handler";
4
+ async function x(e, s, t, i, a) {
5
+ t && !t.endsWith("/") && (t += "/");
6
+ const w = /* @__PURE__ */ new Set([
7
+ t + "/" + (globalThis.__QWIK_BUILD_DIR__ || "build") + "/",
8
+ t + "/" + (globalThis.__QWIK_ASSETS_DIR__ || "assets") + "/"
9
+ ]), o = new Set(i.map(S)), f = [], d = async (l, u, c) => {
10
+ if (c = S(c), w.has(c))
11
+ return;
12
+ const m = p(l, u);
13
+ if (u === "index.html" || u === "q-data.json") {
14
+ !o.has(c) && a && await y.promises.unlink(m);
15
+ return;
16
+ }
17
+ if (u === "404.html") {
18
+ const k = await y.promises.readFile(m, "utf-8");
19
+ f.push([c, k]);
20
+ return;
21
+ }
22
+ const n = await y.promises.stat(m);
23
+ n.isDirectory() ? await r(m, c + u + "/") : n.isFile() && o.add(c + u);
24
+ }, r = async (l, u) => {
25
+ const c = await y.promises.readdir(l);
26
+ await Promise.all(c.map((m) => d(l, m, u)));
27
+ };
28
+ y.existsSync(e) && await r(e, t);
29
+ const h = O(t, f), g = j(o);
30
+ await T(g, h, s);
31
+ }
32
+ function S(e) {
33
+ return e.endsWith("/") ? e : e + "/";
34
+ }
35
+ function O(e, s) {
36
+ if (s.sort((t, i) => t[0].length > i[0].length ? -1 : t[0].length < i[0].length ? 1 : t[0] < i[0] ? -1 : t[0] > i[0] ? 1 : 0), !s.some((t) => t[0] === e)) {
37
+ const t = R(404, "Resource Not Found");
38
+ s.push([e, t]);
39
+ }
40
+ return JSON.stringify(s, null, 2).slice(1, -1);
41
+ }
42
+ function j(e) {
43
+ return JSON.stringify(Array.from(new Set(e)).sort()).slice(1, -1);
44
+ }
45
+ const T = async (e, s, t) => {
46
+ const i = /* @__PURE__ */ new Set(), a = async (o) => {
47
+ const f = await y.promises.readFile(o, "utf-8");
48
+ let d = !1;
49
+ const r = f.replace(
50
+ /(['"])__QWIK_ROUTER_(STATIC_PATHS|NOT_FOUND)_ARRAY__\1/g,
51
+ (h, g, l) => (d = !0, l === "STATIC_PATHS" ? e : s)
52
+ );
53
+ d && await y.promises.writeFile(o, r);
54
+ }, w = async (o) => {
55
+ const f = await y.promises.readdir(o, { withFileTypes: !0 });
56
+ for (const d of f)
57
+ if (d.isDirectory())
58
+ await w(p(o, d.name));
59
+ else if (d.name.endsWith("js")) {
60
+ const r = a(p(o, d.name)).finally(() => {
61
+ i.delete(r);
62
+ });
63
+ i.add(r);
64
+ }
65
+ };
66
+ await w(t), await Promise.all(i);
67
+ };
68
+ function A(e) {
69
+ let s = null, t = null, i = null, a = null, w = null, o = !1;
70
+ const f = [];
71
+ return {
72
+ name: `vite-plugin-qwik-router-ssg-${e.name}`,
73
+ enforce: "post",
74
+ apply: "build",
75
+ config(r) {
76
+ return typeof e.config == "function" && (r = e.config(r)), r.define = {
77
+ "process.env.NODE_ENV": JSON.stringify("production"),
78
+ ...r.define
79
+ }, r;
80
+ },
81
+ configResolved(r) {
82
+ if (o = !!r.build.ssr, o) {
83
+ if (s = r.plugins.find(
84
+ (h) => h.name === "vite-plugin-qwik-router"
85
+ ), !s)
86
+ throw new Error("Missing vite-plugin-qwik-router");
87
+ if (t = r.plugins.find(
88
+ (h) => h.name === "vite-plugin-qwik"
89
+ ), !t)
90
+ throw new Error("Missing vite-plugin-qwik");
91
+ if (i = r.build.outDir, r.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 (!r.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 (o && e.ssg !== null) {
103
+ const { srcDir: r } = 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: `${r}/entry.ssr`,
110
+ type: "chunk",
111
+ fileName: "entry.ssr.js"
112
+ });
113
+ }
114
+ },
115
+ generateBundle(r, h) {
116
+ if (o) {
117
+ f.length = 0;
118
+ for (const g in h) {
119
+ const l = h[g];
120
+ l.type === "chunk" && l.isEntry && (f.push(g), l.name === "entry.ssr" ? a = p(i, g) : l.name === "@qwik-router-config" && (w = p(i, g)));
121
+ }
122
+ }
123
+ },
124
+ closeBundle: {
125
+ sequential: !0,
126
+ async handler() {
127
+ if (o && i && s?.api && t?.api) {
128
+ const r = e.staticPaths || [], h = s.api.getRoutes(), g = s.api.getBasePathname(), l = t.api.getClientOutDir(), u = t.api.getClientPublicOutDir(), c = t.api.getAssetsDir(), m = t.api.getRootDir() ?? void 0;
129
+ if (e.ssg !== null && a && w && l && u) {
130
+ let n = e.ssg?.origin ?? e.origin;
131
+ n || (n = "https://yoursite.qwik.dev"), n.length > 0 && !/:\/\//.test(n) && (n = `https://${n}`), n.startsWith("//") && (n = `https:${n}`);
132
+ try {
133
+ n = new URL(n).origin;
134
+ } catch {
135
+ this.warn(
136
+ `Invalid "origin" option: "${n}". Using default origin: "https://yoursite.qwik.dev"`
137
+ ), n = "https://yoursite.qwik.dev";
138
+ }
139
+ const k = await import("./index-CrwlB95_.js"), v = {
140
+ maxWorkers: e.maxWorkers,
141
+ basePathname: g,
142
+ outDir: u,
143
+ rootDir: m,
144
+ ...e.ssg,
145
+ origin: n,
146
+ renderModulePath: a,
147
+ qwikRouterConfigModulePath: w
148
+ }, P = await k.generate(v);
149
+ if (P.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
+ r.push(...P.staticPaths);
156
+ }
157
+ await x(
158
+ u,
159
+ i,
160
+ c ? p(g, c) : g,
161
+ r,
162
+ !!e.cleanStaticGenerated
163
+ ), typeof e.generate == "function" && await e.generate({
164
+ outputEntries: f,
165
+ serverOutDir: i,
166
+ clientOutDir: l,
167
+ clientPublicOutDir: u,
168
+ basePathname: g,
169
+ routes: h,
170
+ assetsDir: c,
171
+ warn: (n) => this.warn(n),
172
+ error: (n) => this.error(n)
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 F(e, s) {
188
+ const t = D("/");
189
+ let i = e;
190
+ for (let a = 0; a < 20; a++) {
191
+ if (i = E(i), q(i) === s)
192
+ return i;
193
+ if (i === t)
194
+ break;
195
+ }
196
+ throw new Error(`Unable to find "${s}" directory from "${e}"`);
197
+ }
198
+ function W(e = {}) {
199
+ const s = process?.env;
200
+ return A({
11
201
  name: "netlify-edge",
12
- origin: (env == null ? void 0 : env.ORIGIN) ?? (env == null ? void 0 : env.URL) ?? "https://yoursitename.netlify.app",
13
- ssg: opts.ssg,
14
- staticPaths: opts.staticPaths,
15
- cleanStaticGenerated: true,
16
- config(config) {
17
- var _a;
18
- const outDir = ((_a = config.build) == null ? void 0 : _a.outDir) || ".netlify/edge-functions/entry.netlify-edge";
202
+ origin: s?.ORIGIN ?? s?.URL ?? "https://yoursitename.netlify.app",
203
+ ssg: e.ssg,
204
+ staticPaths: e.staticPaths,
205
+ cleanStaticGenerated: !0,
206
+ config(t) {
207
+ const i = t.build?.outDir || ".netlify/edge-functions/entry.netlify-edge";
19
208
  return {
20
209
  resolve: {
21
210
  conditions: ["webworker", "worker"]
22
211
  },
23
212
  ssr: {
24
213
  target: "webworker",
25
- noExternal: true,
214
+ noExternal: !0,
26
215
  external: ["node:async_hooks"]
27
216
  },
28
217
  build: {
29
- ssr: true,
30
- outDir,
218
+ ssr: !0,
219
+ outDir: i,
31
220
  rollupOptions: {
32
221
  output: {
33
222
  format: "es",
34
- hoistTransitiveImports: false
223
+ hoistTransitiveImports: !1
35
224
  }
36
225
  }
37
226
  },
38
- publicDir: false
227
+ publicDir: !1
39
228
  };
40
229
  },
41
- async generate({ serverOutDir }) {
42
- if (opts.functionRoutes !== false) {
43
- const excludedPath = [];
44
- if (typeof opts.excludedPath === "string") {
45
- excludedPath.push(opts.excludedPath);
46
- } else if (Array.isArray(opts.excludedPath)) {
47
- excludedPath.push(...opts.excludedPath);
48
- } else {
49
- excludedPath.push(
50
- "/build/*",
51
- "/favicon.ico",
52
- "/robots.txt",
53
- "/mainifest.json",
54
- "/~partytown/*",
55
- "/service-worker.js",
56
- "/sitemap.xml"
57
- );
58
- }
59
- const netlifyEdgeManifest = {
230
+ async generate({ serverOutDir: t, basePathname: i }) {
231
+ if (e.functionRoutes !== !1) {
232
+ const a = [];
233
+ typeof e.excludedPath == "string" ? a.push(e.excludedPath) : Array.isArray(e.excludedPath) ? a.push(...e.excludedPath) : a.push(
234
+ "/build/*",
235
+ "/favicon.ico",
236
+ "/robots.txt",
237
+ "/mainifest.json",
238
+ "/~partytown/*",
239
+ "/service-worker.js",
240
+ "/sitemap.xml"
241
+ );
242
+ const w = {
60
243
  functions: [
61
244
  {
62
- path: basePathname + "*",
245
+ path: i + "*",
63
246
  function: "entry.netlify-edge",
64
247
  cache: "manual",
65
- excludedPath
248
+ excludedPath: a
66
249
  }
67
250
  ],
68
251
  version: 1
69
- };
70
- const jsPath = join(serverOutDir, "entry.netlify-edge.js");
71
- const mjsPath = join(serverOutDir, "entry.netlify-edge.mjs");
72
- if (existsSync(mjsPath)) {
73
- await fs.promises.writeFile(
74
- jsPath,
75
- [
76
- `import entry_netlifyEdge from './entry.netlify-edge.mjs';`,
77
- `export default entry_netlifyEdge;`
78
- ].join("\n")
79
- );
80
- }
81
- const netlifyEdgeFnsDir = getParentDir(serverOutDir, "edge-functions");
82
- await fs.promises.writeFile(
83
- join(netlifyEdgeFnsDir, "manifest.json"),
84
- JSON.stringify(netlifyEdgeManifest, null, 2)
252
+ }, o = p(t, "entry.netlify-edge.js"), f = p(t, "entry.netlify-edge.mjs");
253
+ b(f) && await y.promises.writeFile(
254
+ o,
255
+ [
256
+ "import entry_netlifyEdge from './entry.netlify-edge.mjs';",
257
+ "export default entry_netlifyEdge;"
258
+ ].join(`
259
+ `)
260
+ );
261
+ const d = F(t, "edge-functions");
262
+ await y.promises.writeFile(
263
+ p(d, "manifest.json"),
264
+ JSON.stringify(w, null, 2)
85
265
  );
86
266
  }
87
267
  }
88
268
  });
89
269
  }
90
270
  export {
91
- netlifyEdgeAdapter
271
+ W as netlifyEdgeAdapter
92
272
  };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});async function t(r){return await(await o()).generate(r)}function o(){if(e())return Promise.resolve().then(()=>require("./index-vQuPcef3.cjs"));if(n()||s())return Promise.resolve().then(()=>require("./index-DTIOTwZo.cjs"));throw new Error("Unsupported platform")}function e(){return typeof Deno<"u"}function n(){return typeof Bun<"u"}function s(){return!n()&&!e()&&typeof process<"u"&&!!process.versions?.node}exports.generate=t;