@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.
- package/README.md +1 -1
- package/adapters/static/vite.d.ts +1 -1
- package/lib/adapters/azure-swa/vite/index-BqUeglYs.cjs +1 -0
- package/lib/adapters/azure-swa/vite/index-CBIchDYq.js +651 -0
- package/lib/adapters/azure-swa/vite/index-ClHGw5z1.js +6 -0
- package/lib/adapters/azure-swa/vite/index-CrwlB95_.js +22 -0
- package/lib/adapters/azure-swa/vite/index-DTIOTwZo.cjs +11 -0
- package/lib/adapters/azure-swa/vite/index-vQuPcef3.cjs +1 -0
- package/lib/adapters/azure-swa/vite/index.cjs +5 -96
- package/lib/adapters/azure-swa/vite/index.d.ts +13 -13
- package/lib/adapters/azure-swa/vite/index.mjs +201 -26
- package/lib/adapters/bun-server/vite/index-BqUeglYs.cjs +1 -0
- package/lib/adapters/bun-server/vite/index-CBIchDYq.js +651 -0
- package/lib/adapters/bun-server/vite/index-ClHGw5z1.js +6 -0
- package/lib/adapters/bun-server/vite/index-CrwlB95_.js +22 -0
- package/lib/adapters/bun-server/vite/index-DTIOTwZo.cjs +11 -0
- package/lib/adapters/bun-server/vite/index-vQuPcef3.cjs +1 -0
- package/lib/adapters/bun-server/vite/index.cjs +5 -50
- package/lib/adapters/bun-server/vite/index.d.ts +14 -14
- package/lib/adapters/bun-server/vite/index.mjs +196 -12
- package/lib/adapters/cloud-run/vite/index-BqUeglYs.cjs +1 -0
- package/lib/adapters/cloud-run/vite/index-CBIchDYq.js +651 -0
- package/lib/adapters/cloud-run/vite/index-ClHGw5z1.js +6 -0
- package/lib/adapters/cloud-run/vite/index-CrwlB95_.js +22 -0
- package/lib/adapters/cloud-run/vite/index-DTIOTwZo.cjs +11 -0
- package/lib/adapters/cloud-run/vite/index-vQuPcef3.cjs +1 -0
- package/lib/adapters/cloud-run/vite/index.cjs +5 -47
- package/lib/adapters/cloud-run/vite/index.d.ts +13 -13
- package/lib/adapters/cloud-run/vite/index.mjs +195 -11
- package/lib/adapters/cloudflare-pages/vite/index-BIeHg2Cj.cjs +5 -0
- package/lib/adapters/cloudflare-pages/vite/index-C455V8_A.cjs +1 -0
- package/lib/adapters/cloudflare-pages/vite/index-ClHGw5z1.js +6 -0
- package/lib/adapters/cloudflare-pages/vite/index-D3HITboM.js +645 -0
- package/lib/adapters/cloudflare-pages/vite/index-DKcVHRBy.cjs +11 -0
- package/lib/adapters/cloudflare-pages/vite/index-DwovcBp3.js +22 -0
- package/lib/adapters/cloudflare-pages/vite/index-bogwy7wh.js +250 -0
- package/lib/adapters/cloudflare-pages/vite/index-vQuPcef3.cjs +1 -0
- package/lib/adapters/cloudflare-pages/vite/index.cjs +1 -115
- package/lib/adapters/cloudflare-pages/vite/index.d.ts +27 -27
- package/lib/adapters/cloudflare-pages/vite/index.mjs +4 -78
- package/lib/adapters/deno-server/vite/index-BqUeglYs.cjs +1 -0
- package/lib/adapters/deno-server/vite/index-CBIchDYq.js +651 -0
- package/lib/adapters/deno-server/vite/index-ClHGw5z1.js +6 -0
- package/lib/adapters/deno-server/vite/index-CrwlB95_.js +22 -0
- package/lib/adapters/deno-server/vite/index-DTIOTwZo.cjs +11 -0
- package/lib/adapters/deno-server/vite/index-vQuPcef3.cjs +1 -0
- package/lib/adapters/deno-server/vite/index.cjs +5 -62
- package/lib/adapters/deno-server/vite/index.d.ts +14 -14
- package/lib/adapters/deno-server/vite/index.mjs +198 -14
- package/lib/adapters/netlify-edge/vite/index-BqUeglYs.cjs +1 -0
- package/lib/adapters/netlify-edge/vite/index-CBIchDYq.js +651 -0
- package/lib/adapters/netlify-edge/vite/index-ClHGw5z1.js +6 -0
- package/lib/adapters/netlify-edge/vite/index-CrwlB95_.js +22 -0
- package/lib/adapters/netlify-edge/vite/index-DTIOTwZo.cjs +11 -0
- package/lib/adapters/netlify-edge/vite/index-vQuPcef3.cjs +1 -0
- package/lib/adapters/netlify-edge/vite/index.cjs +6 -129
- package/lib/adapters/netlify-edge/vite/index.d.ts +44 -44
- package/lib/adapters/netlify-edge/vite/index.mjs +240 -60
- package/lib/adapters/node-server/vite/index-BqUeglYs.cjs +1 -0
- package/lib/adapters/node-server/vite/index-CBIchDYq.js +651 -0
- package/lib/adapters/node-server/vite/index-ClHGw5z1.js +6 -0
- package/lib/adapters/node-server/vite/index-CrwlB95_.js +22 -0
- package/lib/adapters/node-server/vite/index-DTIOTwZo.cjs +11 -0
- package/lib/adapters/node-server/vite/index-vQuPcef3.cjs +1 -0
- package/lib/adapters/node-server/vite/index.cjs +5 -50
- package/lib/adapters/node-server/vite/index.d.ts +14 -14
- package/lib/adapters/node-server/vite/index.mjs +196 -12
- package/lib/adapters/shared/vite/index-BqUeglYs.cjs +1 -0
- package/lib/adapters/shared/vite/index-CBIchDYq.js +651 -0
- package/lib/adapters/shared/vite/index-ClHGw5z1.js +6 -0
- package/lib/adapters/shared/vite/index-CrwlB95_.js +22 -0
- package/lib/adapters/shared/vite/index-DTIOTwZo.cjs +11 -0
- package/lib/adapters/shared/vite/index-vQuPcef3.cjs +1 -0
- package/lib/adapters/shared/vite/index.cjs +5 -371
- package/lib/adapters/shared/vite/index.d.ts +108 -114
- package/lib/adapters/shared/vite/index.mjs +158 -288
- package/lib/adapters/ssg/vite/index-BqUeglYs.cjs +1 -0
- package/lib/adapters/ssg/vite/index-CBIchDYq.js +651 -0
- package/lib/adapters/ssg/vite/index-ClHGw5z1.js +6 -0
- package/lib/adapters/ssg/vite/index-CrwlB95_.js +22 -0
- package/lib/adapters/ssg/vite/index-DTIOTwZo.cjs +11 -0
- package/lib/adapters/ssg/vite/index-vQuPcef3.cjs +1 -0
- package/lib/adapters/ssg/vite/index.cjs +5 -0
- package/lib/adapters/ssg/vite/index.d.ts +13 -0
- package/lib/adapters/ssg/vite/index.mjs +201 -0
- package/lib/adapters/vercel-edge/vite/index-BqUeglYs.cjs +1 -0
- package/lib/adapters/vercel-edge/vite/index-CBIchDYq.js +651 -0
- package/lib/adapters/vercel-edge/vite/index-ClHGw5z1.js +6 -0
- package/lib/adapters/vercel-edge/vite/index-CrwlB95_.js +22 -0
- package/lib/adapters/vercel-edge/vite/index-DTIOTwZo.cjs +11 -0
- package/lib/adapters/vercel-edge/vite/index-vQuPcef3.cjs +1 -0
- package/lib/adapters/vercel-edge/vite/index.cjs +5 -118
- package/lib/adapters/vercel-edge/vite/index.d.ts +45 -45
- package/lib/adapters/vercel-edge/vite/index.mjs +230 -51
- package/lib/index.d.ts +1000 -810
- package/lib/index.qwik.cjs +438 -203
- package/lib/index.qwik.mjs +440 -205
- package/lib/middleware/aws-lambda/index.cjs +1 -0
- package/lib/middleware/aws-lambda/index.d.ts +49 -48
- package/lib/middleware/aws-lambda/index.mjs +27 -41
- package/lib/middleware/azure-swa/index.cjs +1 -0
- package/lib/middleware/azure-swa/index.d.ts +28 -28
- package/lib/middleware/azure-swa/index.mjs +46 -269
- package/lib/middleware/bun/index.cjs +1 -0
- package/lib/middleware/bun/index.d.ts +35 -35
- package/lib/middleware/bun/index.mjs +68 -120
- package/lib/middleware/cloudflare-pages/index.cjs +1 -0
- package/lib/middleware/cloudflare-pages/index.d.ts +35 -35
- package/lib/middleware/cloudflare-pages/index.mjs +48 -80
- package/lib/middleware/deno/index.cjs +1 -0
- package/lib/middleware/deno/index.d.ts +47 -47
- package/lib/middleware/deno/index.mjs +63 -110
- package/lib/middleware/firebase/index.cjs +1 -0
- package/lib/middleware/firebase/index.d.ts +26 -26
- package/lib/middleware/firebase/index.mjs +16 -28
- package/lib/middleware/netlify-edge/index.cjs +1 -0
- package/lib/middleware/netlify-edge/index.d.ts +27 -27
- package/lib/middleware/netlify-edge/index.mjs +36 -64
- package/lib/middleware/node/index.cjs +1 -314
- package/lib/middleware/node/index.d.ts +64 -64
- package/lib/middleware/node/index.mjs +116 -198
- package/lib/middleware/request-handler/index.cjs +11 -1538
- package/lib/middleware/request-handler/index.d.ts +711 -676
- package/lib/middleware/request-handler/index.mjs +895 -1281
- package/lib/middleware/vercel-edge/index.cjs +1 -0
- package/lib/middleware/vercel-edge/index.d.ts +26 -26
- package/lib/middleware/vercel-edge/index.mjs +47 -82
- package/lib/modules.d.ts +4 -12
- package/lib/service-worker.cjs +1 -267
- package/lib/service-worker.d.ts +15 -4
- package/lib/service-worker.mjs +3 -263
- package/lib/ssg/deno.cjs +1 -0
- package/lib/ssg/deno.mjs +6 -0
- package/lib/ssg/index-CBIchDYq.js +651 -0
- package/lib/ssg/index-ClHGw5z1.js +6 -0
- package/lib/ssg/index-DTIOTwZo.cjs +11 -0
- package/lib/ssg/index-vQuPcef3.cjs +1 -0
- package/lib/ssg/index.cjs +1 -0
- package/lib/{static → ssg}/index.d.ts +96 -96
- package/lib/ssg/index.mjs +22 -0
- package/lib/ssg/node.cjs +11 -0
- package/lib/ssg/node.mjs +651 -0
- package/lib/vite/index.cjs +29 -27484
- package/lib/vite/index.d.ts +170 -154
- package/lib/vite/index.mjs +1422 -27288
- package/modules.d.ts +4 -12
- package/package.json +51 -40
- package/ssg.d.ts +2 -0
- package/static.d.ts +1 -1
- package/lib/adapters/static/vite/index.cjs +0 -361
- package/lib/adapters/static/vite/index.d.ts +0 -10
- package/lib/adapters/static/vite/index.mjs +0 -324
- package/lib/static/deno.mjs +0 -8
- package/lib/static/index.cjs +0 -67
- package/lib/static/index.mjs +0 -48
- package/lib/static/node.cjs +0 -1124
- package/lib/static/node.mjs +0 -1086
- package/middleware/request-handler/generated/not-found-paths.ts +0 -7
- 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
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
-
mod
|
|
27
|
-
));
|
|
28
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
|
|
30
|
-
// packages/qwik-router/src/adapters/vercel-edge/vite/index.ts
|
|
31
|
-
var vite_exports = {};
|
|
32
|
-
__export(vite_exports, {
|
|
33
|
-
vercelEdgeAdapter: () => vercelEdgeAdapter
|
|
34
|
-
});
|
|
35
|
-
module.exports = __toCommonJS(vite_exports);
|
|
36
|
-
var import_node_fs = __toESM(require("node:fs"), 1);
|
|
37
|
-
var import_node_path = require("node:path");
|
|
38
|
-
var import_vite = require("../../shared/vite/index.cjs");
|
|
39
|
-
function vercelEdgeAdapter(opts = {}) {
|
|
40
|
-
var _a;
|
|
41
|
-
return (0, import_vite.viteAdapter)({
|
|
42
|
-
name: "vercel-edge",
|
|
43
|
-
origin: ((_a = process == null ? void 0 : process.env) == null ? void 0 : _a.VERCEL_URL) || "https://yoursitename.vercel.app",
|
|
44
|
-
ssg: opts.ssg,
|
|
45
|
-
staticPaths: opts.staticPaths,
|
|
46
|
-
cleanStaticGenerated: true,
|
|
47
|
-
config(config) {
|
|
48
|
-
var _a2;
|
|
49
|
-
const outDir = ((_a2 = config.build) == null ? void 0 : _a2.outDir) || (0, import_node_path.join)(".vercel", "output", "functions", "_qwik-router.func");
|
|
50
|
-
return {
|
|
51
|
-
resolve: {
|
|
52
|
-
conditions: opts.target === "node" ? ["node", "import", "module", "browser", "default"] : ["edge-light", "webworker", "worker", "browser", "module", "main"]
|
|
53
|
-
},
|
|
54
|
-
ssr: {
|
|
55
|
-
target: opts.target === "node" ? "node" : "webworker",
|
|
56
|
-
noExternal: true
|
|
57
|
-
},
|
|
58
|
-
build: {
|
|
59
|
-
ssr: true,
|
|
60
|
-
outDir,
|
|
61
|
-
rollupOptions: {
|
|
62
|
-
output: {
|
|
63
|
-
format: "es",
|
|
64
|
-
hoistTransitiveImports: false
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
},
|
|
68
|
-
publicDir: false
|
|
69
|
-
};
|
|
70
|
-
},
|
|
71
|
-
async generate({ clientPublicOutDir, serverOutDir, basePathname, outputEntries }) {
|
|
72
|
-
const vercelOutputDir = (0, import_vite.getParentDir)(serverOutDir, "output");
|
|
73
|
-
if (opts.outputConfig !== false) {
|
|
74
|
-
const vercelOutputConfig = {
|
|
75
|
-
routes: [
|
|
76
|
-
{ handle: "filesystem" },
|
|
77
|
-
{
|
|
78
|
-
src: basePathname + ".*",
|
|
79
|
-
dest: "/_qwik-router"
|
|
80
|
-
}
|
|
81
|
-
],
|
|
82
|
-
version: 3
|
|
83
|
-
};
|
|
84
|
-
await import_node_fs.default.promises.writeFile(
|
|
85
|
-
(0, import_node_path.join)(vercelOutputDir, "config.json"),
|
|
86
|
-
JSON.stringify(vercelOutputConfig, null, 2)
|
|
87
|
-
);
|
|
88
|
-
}
|
|
89
|
-
let entrypoint = opts.vcConfigEntryPoint;
|
|
90
|
-
if (!entrypoint) {
|
|
91
|
-
if (outputEntries.some((n) => n === "entry.vercel-edge.mjs")) {
|
|
92
|
-
entrypoint = "entry.vercel-edge.mjs";
|
|
93
|
-
} else {
|
|
94
|
-
entrypoint = "entry.vercel-edge.js";
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
const vcConfigPath = (0, import_node_path.join)(serverOutDir, ".vc-config.json");
|
|
98
|
-
const vcConfig = {
|
|
99
|
-
runtime: "edge",
|
|
100
|
-
entrypoint,
|
|
101
|
-
envVarsInUse: opts.vcConfigEnvVarsInUse
|
|
102
|
-
};
|
|
103
|
-
await import_node_fs.default.promises.writeFile(vcConfigPath, JSON.stringify(vcConfig, null, 2));
|
|
104
|
-
let vercelStaticDir = (0, import_node_path.join)(vercelOutputDir, "static");
|
|
105
|
-
const basePathnameParts = basePathname.split("/").filter((p) => p.length > 0);
|
|
106
|
-
if (basePathnameParts.length > 0) {
|
|
107
|
-
vercelStaticDir = (0, import_node_path.join)(vercelStaticDir, ...basePathnameParts);
|
|
108
|
-
}
|
|
109
|
-
await import_node_fs.default.promises.rm(vercelStaticDir, { recursive: true, force: true });
|
|
110
|
-
await import_node_fs.default.promises.mkdir((0, import_node_path.dirname)(vercelStaticDir), { recursive: true });
|
|
111
|
-
await import_node_fs.default.promises.rename(clientPublicOutDir, vercelStaticDir);
|
|
112
|
-
}
|
|
113
|
-
});
|
|
114
|
-
}
|
|
115
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
116
|
-
0 && (module.exports = {
|
|
117
|
-
vercelEdgeAdapter
|
|
118
|
-
});
|
|
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,45 +1,45 @@
|
|
|
1
|
-
import { ServerAdapterOptions } from '../../shared/vite';
|
|
2
|
-
import type {
|
|
3
|
-
|
|
4
|
-
export {
|
|
5
|
-
|
|
6
|
-
/** @public */
|
|
7
|
-
export declare function vercelEdgeAdapter(opts?: VercelEdgeAdapterOptions): any;
|
|
8
|
-
|
|
9
|
-
/** @public */
|
|
10
|
-
export declare interface VercelEdgeAdapterOptions extends ServerAdapterOptions {
|
|
11
|
-
/**
|
|
12
|
-
* Determines if the build should auto-generate the `.vercel/output/config.json` config.
|
|
13
|
-
*
|
|
14
|
-
* Defaults to `true`.
|
|
15
|
-
*/
|
|
16
|
-
outputConfig?: boolean;
|
|
17
|
-
/**
|
|
18
|
-
* The `entrypoint` property in the `.vc-config.json` file. Indicates the initial file where code
|
|
19
|
-
* will be executed for the Edge Function.
|
|
20
|
-
*
|
|
21
|
-
* Defaults to `entry.vercel-edge.js`.
|
|
22
|
-
*/
|
|
23
|
-
vcConfigEntryPoint?: string;
|
|
24
|
-
/**
|
|
25
|
-
* The `envVarsInUse` property in the `.vc-config.json` file. List of environment variable names
|
|
26
|
-
* that will be available for the Edge Function to utilize.
|
|
27
|
-
*
|
|
28
|
-
* Defaults to `undefined`.
|
|
29
|
-
*/
|
|
30
|
-
vcConfigEnvVarsInUse?: string[];
|
|
31
|
-
/**
|
|
32
|
-
* Manually add pathnames that should be treated as static paths and not SSR. For example, when
|
|
33
|
-
* these pathnames are requested, their response should come from a static file, rather than a
|
|
34
|
-
* server-side rendered response.
|
|
35
|
-
*/
|
|
36
|
-
staticPaths?: string[];
|
|
37
|
-
/**
|
|
38
|
-
* Define the `target` property in the `ssr` object in the `vite.config.mts` file.
|
|
39
|
-
*
|
|
40
|
-
* Defaults to `webworker`.
|
|
41
|
-
*/
|
|
42
|
-
target?: 'webworker' | 'node';
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
export { }
|
|
1
|
+
import { ServerAdapterOptions } from '../../shared/vite';
|
|
2
|
+
import type { SsgRenderOptions } from 'packages/qwik-router/src/ssg';
|
|
3
|
+
|
|
4
|
+
export { SsgRenderOptions }
|
|
5
|
+
|
|
6
|
+
/** @public */
|
|
7
|
+
export declare function vercelEdgeAdapter(opts?: VercelEdgeAdapterOptions): any;
|
|
8
|
+
|
|
9
|
+
/** @public */
|
|
10
|
+
export declare interface VercelEdgeAdapterOptions extends ServerAdapterOptions {
|
|
11
|
+
/**
|
|
12
|
+
* Determines if the build should auto-generate the `.vercel/output/config.json` config.
|
|
13
|
+
*
|
|
14
|
+
* Defaults to `true`.
|
|
15
|
+
*/
|
|
16
|
+
outputConfig?: boolean;
|
|
17
|
+
/**
|
|
18
|
+
* The `entrypoint` property in the `.vc-config.json` file. Indicates the initial file where code
|
|
19
|
+
* will be executed for the Edge Function.
|
|
20
|
+
*
|
|
21
|
+
* Defaults to `entry.vercel-edge.js`.
|
|
22
|
+
*/
|
|
23
|
+
vcConfigEntryPoint?: string;
|
|
24
|
+
/**
|
|
25
|
+
* The `envVarsInUse` property in the `.vc-config.json` file. List of environment variable names
|
|
26
|
+
* that will be available for the Edge Function to utilize.
|
|
27
|
+
*
|
|
28
|
+
* Defaults to `undefined`.
|
|
29
|
+
*/
|
|
30
|
+
vcConfigEnvVarsInUse?: string[];
|
|
31
|
+
/**
|
|
32
|
+
* Manually add pathnames that should be treated as static paths and not SSR. For example, when
|
|
33
|
+
* these pathnames are requested, their response should come from a static file, rather than a
|
|
34
|
+
* server-side rendered response.
|
|
35
|
+
*/
|
|
36
|
+
staticPaths?: string[];
|
|
37
|
+
/**
|
|
38
|
+
* Define the `target` property in the `ssr` object in the `vite.config.mts` file.
|
|
39
|
+
*
|
|
40
|
+
* Defaults to `webworker`.
|
|
41
|
+
*/
|
|
42
|
+
target?: 'webworker' | 'node';
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export { }
|
|
@@ -1,83 +1,262 @@
|
|
|
1
|
-
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
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:
|
|
10
|
-
ssg:
|
|
11
|
-
staticPaths:
|
|
12
|
-
cleanStaticGenerated:
|
|
13
|
-
config(
|
|
14
|
-
|
|
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:
|
|
209
|
+
conditions: e.target === "node" ? ["node", "import", "module", "browser", "default"] : ["edge-light", "webworker", "worker", "browser", "module", "main"]
|
|
19
210
|
},
|
|
20
211
|
ssr: {
|
|
21
|
-
target:
|
|
22
|
-
noExternal:
|
|
212
|
+
target: e.target === "node" ? "node" : "webworker",
|
|
213
|
+
noExternal: !0
|
|
23
214
|
},
|
|
24
215
|
build: {
|
|
25
|
-
ssr:
|
|
26
|
-
outDir,
|
|
216
|
+
ssr: !0,
|
|
217
|
+
outDir: t,
|
|
27
218
|
rollupOptions: {
|
|
28
219
|
output: {
|
|
29
220
|
format: "es",
|
|
30
|
-
hoistTransitiveImports:
|
|
221
|
+
hoistTransitiveImports: !1
|
|
31
222
|
}
|
|
32
223
|
}
|
|
33
224
|
},
|
|
34
|
-
publicDir:
|
|
225
|
+
publicDir: !1
|
|
35
226
|
};
|
|
36
227
|
},
|
|
37
|
-
async generate({ clientPublicOutDir, serverOutDir, basePathname, outputEntries }) {
|
|
38
|
-
const
|
|
39
|
-
if (
|
|
40
|
-
const
|
|
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:
|
|
235
|
+
src: r + ".*",
|
|
45
236
|
dest: "/_qwik-router"
|
|
46
237
|
}
|
|
47
238
|
],
|
|
48
239
|
version: 3
|
|
49
240
|
};
|
|
50
|
-
await
|
|
51
|
-
|
|
52
|
-
JSON.stringify(
|
|
241
|
+
await d.promises.writeFile(
|
|
242
|
+
m(p, "config.json"),
|
|
243
|
+
JSON.stringify(a, null, 2)
|
|
53
244
|
);
|
|
54
245
|
}
|
|
55
|
-
let
|
|
56
|
-
|
|
57
|
-
|
|
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:
|
|
250
|
+
entrypoint: s,
|
|
251
|
+
envVarsInUse: e.vcConfigEnvVarsInUse
|
|
68
252
|
};
|
|
69
|
-
await
|
|
70
|
-
let
|
|
71
|
-
const
|
|
72
|
-
|
|
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
|
};
|