@bobtail.software/b-ssr 1.0.1 → 1.0.3

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.
@@ -33,7 +33,7 @@ interface FastifyReactSsrOptions {
33
33
  errorHandler?: (error: unknown) => {
34
34
  message: string;
35
35
  statusCode: number;
36
- };
36
+ } | null | undefined;
37
37
  }
38
38
  declare module 'fastify' {
39
39
  interface FastifyInstance {
@@ -1 +1 @@
1
- import"@fastify/multipart";import y from"fastify-plugin";import S from"path";var h=async(e,s)=>{if(!e.isMultipart())return s.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,s)=>{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){let t=await import("@fastify/middie");await e.register(t.default,{hook:"onRequest"});let r=await(await import("vite")).createServer({root:s.root,server:{middlewareMode:!0,hmr:{port:24678}},appType:"custom",...s.viteConfig});e.use(r.middlewares),e.decorate("viteServer",r),console.log("\u{1F680} [Fastify-SSR] Vite Dev Server Ready")}e.decorate("viteInitDone",!0);let l=async(t,r,f)=>{try{let a=t.raw.url;if(S.extname(a)!==""){r.status(404).send(`File not found: ${a}`);return}let n="";!p&&e.viteServer&&(n=await e.viteServer.transformIndexHtml(a,"<html><head></head><body></body></html>"),n=n.substring(n.indexOf("<head>")+6,n.indexOf("</head>"))),await(p?await import(s.prodEntryFile):await e.viteServer.ssrLoadModule(s.devEntryFile)).render({req:t,reply:r,head:n,data:f})}catch(a){e.viteServer?.ssrFixStacktrace(a),r.sent||r.status(500).send("Internal Server Error")}};e.decorate("addRpcRoute",function(t,r){let{handler:f,schema:a,...n}=r,m=`/rpc${t}`,o={...n,schema:a};if(a?.consumes?.includes("multipart/form-data")){let d=o.preValidation;o.preValidation=d?Array.isArray(d)?[h,...d]:[h,d]:h}this.route({method:"POST",url:m,...o,handler:async(d,c)=>{try{let u=await f.call(this,d,c);return c.sent?void 0:u}catch(u){if(console.error(`[RPC Error] ${m}:`,u),!c.sent){let R=s.errorHandler?s.errorHandler(u):{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:a,...n}=r||{},m=async(o,i,d)=>{try{let c=await f?.call(this,o,i);return d?c:l(o,i,c)}catch(c){if(console.error(`[Render Error] ${t}:`,c),!i.sent)if(d){let u=s.errorHandler?s.errorHandler(c):{message:"Internal Server Error",statusCode:500};i.status(u.statusCode).send({error:{message:u.message}})}else return l(o,i,{ssrError:{statusCode:500,message:"Internal Error"}})}};this.route({method:"GET",url:t,schema:a,...n,handler:(o,i)=>m(o,i,!1)}),t!=="*"&&t!=="/*"&&this.route({method:"GET",url:`/loader${t}`,schema:a,...n,handler:(o,i)=>m(o,i,!0)})})},w=y(v,{name:"fastify-react-ssr"});export{w as default};
1
+ import"@fastify/multipart";import v from"fastify-plugin";import F from"path";var y=async(e,c)=>{if(!e.isMultipart())return c.status(415).send({statusCode:415,error:"Unsupported Media Type",message:"Multipart/form-data expected"});let h=e.parts(),p={};for await(let m of h)if(m.type==="field")p[m.fieldname]=m.value;else{let t=Symbol.for("file-stream");e[t]=m}e.body=p},T=async(e,c)=>{let h=t=>{if(c.errorHandler){let r=c.errorHandler(t);if(r)return r}return{message:"Internal Server Error",statusCode:500}};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:c.root,server:{middlewareMode:!0,hmr:{port:24678}},appType:"custom",...c.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 m=async(t,r,f)=>{try{let o=t.raw.url;if(F.extname(o)!==""){r.status(404).send(`File not found: ${o}`);return}let a="";!p&&e.viteServer&&(a=await e.viteServer.transformIndexHtml(o,"<html><head></head><body></body></html>"),a=a.substring(a.indexOf("<head>")+6,a.indexOf("</head>")));let u=p?await import(c.prodEntryFile):await e.viteServer.ssrLoadModule(c.devEntryFile),n=u.render||u.default;if(typeof n!="function")throw new Error(`Entry file ${c.devEntryFile} must export a 'render' function.`);await n({req:t,reply:r,head:a,data:f})}catch(o){e.viteServer?.ssrFixStacktrace(o),console.error("[SSR Error]:",o),r.sent||r.status(500).send("Internal Server Error")}};e.decorate("addRpcRoute",function(t,r){let{handler:f,schema:o,...a}=r,u=`/rpc${t}`,n={...a,schema:o};if(o?.consumes?.includes("multipart/form-data")){let d=n.preValidation;n.preValidation=d?Array.isArray(d)?[y,...d]:[y,d]:y}this.route({method:"POST",url:u,...n,handler:async(d,i)=>{try{let l=await f.call(this,d,i);return i.sent?void 0:l}catch(l){if(console.error(`[RPC Error] ${u}:`,l),!i.sent){let{statusCode:R,message:S}=h(l);i.status(R).send({error:{message:S}})}}}})}),e.decorate("addRenderRoute",function(t,r){let{handler:f,schema:o,...a}=r||{},u=async(n,s,d)=>{try{let i=await f?.call(this,n,s);return d?i:m(n,s,i)}catch(i){if(console.error(`[Render Error] ${t}:`,i),!s.sent){let{statusCode:l,message:R}=h(i);if(d)s.status(l).send({error:{message:R}});else return m(n,s,{ssrError:{statusCode:500,message:"Internal Error"}})}}};this.route({method:"GET",url:t,schema:o,...a,handler:(n,s)=>u(n,s,!1)}),t!=="*"&&t!=="/*"&&this.route({method:"GET",url:`/loader${t}`,schema:o,...a,handler:(n,s)=>u(n,s,!0)})})},E=v(T,{name:"fastify-b-ssr"});export{E as default};
@@ -0,0 +1,9 @@
1
+ import { AnyRouter } from '@tanstack/react-router';
2
+
3
+ /**
4
+ * Hidrata la aplicación en el cliente.
5
+ * @param createRouterFn Función que crea el router
6
+ */
7
+ declare function hydrateClient(createRouterFn: () => AnyRouter): void;
8
+
9
+ export { hydrateClient };
@@ -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};