@bobtail.software/b-ssr 1.0.0 → 1.0.2
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.
|
@@ -1 +1 @@
|
|
|
1
|
-
import"@fastify/multipart";import y from"fastify-plugin";import S from"path";var h=async(e,
|
|
1
|
+
import"@fastify/multipart";import y from"fastify-plugin";import S from"path";var h=async(e,o)=>{if(!e.isMultipart())return o.status(415).send({statusCode:415,error:"Unsupported Media Type",message:"Multipart/form-data expected"});let p=e.parts(),l={};for await(let t of p)if(t.type==="field")l[t.fieldname]=t.value;else{let r=Symbol.for("file-stream");e[r]=t}e.body=l},v=async(e,o)=>{if(e.hasDecorator("viteInitDone")&&e.viteInitDone)return;if(!e.hasContentTypeParser("multipart/form-data")){let t=await import("@fastify/multipart");await e.register(t.default)}let p=process.env.NODE_ENV==="production";if(!p){if(!e.hasDecorator("use"))try{let r=await import("@fastify/middie");await e.register(r.default,{hook:"onRequest"})}catch(r){if(r.code!=="FST_ERR_DEC_ALREADY_PRESENT")throw r}let t=await(await import("vite")).createServer({root:o.root,server:{middlewareMode:!0,hmr:{port:24678}},appType:"custom",...o.viteConfig});e.use(t.middlewares),e.hasDecorator("viteServer")||e.decorate("viteServer",t),console.log("\u{1F680} [Fastify-SSR] Vite Dev Server Ready")}e.decorate("viteInitDone",!0);let l=async(t,r,f)=>{try{let n=t.raw.url;if(S.extname(n)!==""){r.status(404).send(`File not found: ${n}`);return}let s="";!p&&e.viteServer&&(s=await e.viteServer.transformIndexHtml(n,"<html><head></head><body></body></html>"),s=s.substring(s.indexOf("<head>")+6,s.indexOf("</head>")));let u=p?await import(o.prodEntryFile):await e.viteServer.ssrLoadModule(o.devEntryFile),a=u.render||u.default;if(typeof a!="function")throw new Error(`Entry file ${o.devEntryFile} must export a 'render' function.`);await a({req:t,reply:r,head:s,data:f})}catch(n){e.viteServer?.ssrFixStacktrace(n),console.error("[SSR Error]:",n),r.sent||r.status(500).send("Internal Server Error")}};e.decorate("addRpcRoute",function(t,r){let{handler:f,schema:n,...s}=r,u=`/rpc${t}`,a={...s,schema:n};if(n?.consumes?.includes("multipart/form-data")){let d=a.preValidation;a.preValidation=d?Array.isArray(d)?[h,...d]:[h,d]:h}this.route({method:"POST",url:u,...a,handler:async(d,c)=>{try{let m=await f.call(this,d,c);return c.sent?void 0:m}catch(m){if(console.error(`[RPC Error] ${u}:`,m),!c.sent){let R=o.errorHandler?o.errorHandler(m):{message:"Internal Server Error",statusCode:500};c.status(R.statusCode).send({error:{message:R.message}})}}}})}),e.decorate("addRenderRoute",function(t,r){let{handler:f,schema:n,...s}=r||{},u=async(a,i,d)=>{try{let c=await f?.call(this,a,i);return d?c:l(a,i,c)}catch(c){if(console.error(`[Render Error] ${t}:`,c),!i.sent)if(d){let m=o.errorHandler?o.errorHandler(c):{message:"Internal Server Error",statusCode:500};i.status(m.statusCode).send({error:{message:m.message}})}else return l(a,i,{ssrError:{statusCode:500,message:"Internal Error"}})}};this.route({method:"GET",url:t,schema:n,...s,handler:(a,i)=>u(a,i,!1)}),t!=="*"&&t!=="/*"&&this.route({method:"GET",url:`/loader${t}`,schema:n,...s,handler:(a,i)=>u(a,i,!0)})})},g=y(v,{name:"fastify-react-ssr"});export{g as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{RouterClient as r}from"@tanstack/react-router/ssr/client";import c from"react";import{createRoot as m,hydrateRoot as i}from"react-dom/client";import{jsx as o}from"react/jsx-runtime";function f(n){let e=n(),t=document.getElementById("root")||document.getElementById("app");t&&!t.innerHTML?m(t).render(o(c.StrictMode,{children:o(r,{router:e})})):t&&i(document,o(r,{router:e}))}export{f as hydrateClient};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { AnyRouter } from '@tanstack/react-router';
|
|
2
|
+
import { FastifyRequest, FastifyReply } from 'fastify';
|
|
3
|
+
|
|
4
|
+
interface RenderOptions {
|
|
5
|
+
req: FastifyRequest;
|
|
6
|
+
reply: FastifyReply;
|
|
7
|
+
head: string;
|
|
8
|
+
data?: unknown;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Crea el handler de renderizado SSR para TanStack Router.
|
|
12
|
+
*
|
|
13
|
+
* @param createRouterFn Función que devuelve una instancia del Router
|
|
14
|
+
* @returns Una función `render` lista para ser exportada en entry-server.tsx
|
|
15
|
+
*/
|
|
16
|
+
declare function createServerHandler(createRouterFn: () => AnyRouter): ({ req, reply, head, data }: RenderOptions) => Promise<never>;
|
|
17
|
+
|
|
18
|
+
export { type RenderOptions, createServerHandler };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{createRequestHandler as R,renderRouterToStream as h,RouterServer as y}from"@tanstack/react-router/ssr/server";import{jsx as l}from"react/jsx-runtime";function p(e){let d=e.protocol,s=e.hostname,r=`${d}://${s}`,u=new URL(e.url,r||"http://localhost:3000").href,a=new Headers;for(let[c,o]of Object.entries(e.headers))o&&a.set(c,Array.isArray(o)?o.join(", "):o);return new Request(u,{method:e.method,headers:a})}function q(e){return async function({req:s,reply:r,head:u,data:a}){let c=p(s),i=await R({request:c,createRouter:()=>{let t=e(),n=t.options.context||{};return t.update({context:{...n,head:u,req:s,reply:r,loaderData:a}}),t}})(({request:t,responseHeaders:n,router:f})=>h({request:t,responseHeaders:n,router:f,children:l(y,{router:f})}));return r.status(i.status),i.headers.forEach((t,n)=>{r.header(n,t)}),r.send(i.body)}}export{q as createServerHandler};
|