modelence 0.18.0-dev.0 → 0.18.0-dev.1

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,2 +0,0 @@
1
- import {a,b,c}from'./chunk-JBTEZOY2.js';import'./chunk-LDVLXJLS.js';import'./chunk-3SPXJEOR.js';import {a as a$1,m}from'./chunk-IJ5BS7PM.js';import {x,r,y}from'./chunk-VFOGVWJK.js';import'./chunk-5M6FUMUK.js';import'./chunk-DO5TZLF5.js';import {renderToPipeableStream}from'react-dom/server';import {Writable}from'stream';import {QueryClient,dehydrate}from'@tanstack/react-query';import {jsx}from'react/jsx-runtime';var w=()=>{let r=c();return r?y(r.session.user):null},O=r=>{let t=c();if(t)return t.session.configs[r]?.value};function T(){x(w),r(O);}async function K(r){let{callContext:t,loadingElement:l,routesElement:n,router:s,location:o}=r;T();let i=await a("_system.session.init",{},t),e=new QueryClient({defaultOptions:{queries:{retry:false,gcTime:0}}}),d=s?s({children:n,location:o}):n,a$2=jsx(a$1,{loadingElement:l,children:jsx(m,{client:e,children:d})}),C=await b({callContext:t,queryClient:e,session:{user:i.user,configs:i.configs??{}}},()=>_(a$2,o)),h=dehydrate(e);return e.clear(),{html:C,sessionState:JSON.stringify({session:i}),queryState:JSON.stringify(h)}}function _(r,t){return new Promise((l,n)=>{let s="",o=new Writable({write(e,d,a){s+=e.toString(),a();}}),{pipe:i}=renderToPipeableStream(r,{onAllReady(){o.on("finish",()=>l(s)),o.on("error",n),i(o);},onShellError(e){n(e);},onError(e){console.error("SSR onError (non-fatal):",{location:t,error:e});}});})}export{K as renderSsrTree};//# sourceMappingURL=render-LCYTTXNW.js.map
2
- //# sourceMappingURL=render-LCYTTXNW.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/ssr/render.tsx"],"names":["sessionResolver","ctx","getSsrContext","_parseSessionUser","configResolver","key","ensureSsrResolversInstalled","_setSsrSessionResolver","_setSsrConfigResolver","renderSsrTree","options","callContext","loadingElement","routesElement","router","location","sessionPayload","callInProcessMethod","queryClient","QueryClient","routedTree","tree","jsx","AppProvider","ModelenceQueryProvider","html","runWithSsrContext","renderToString","dehydratedState","dehydrate","resolve","reject","buffer","writable","Writable","chunk","_encoding","callback","pipe","renderToPipeableStream","error"],"mappings":"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","file":"render-LCYTTXNW.js","sourcesContent":["import React from 'react';\nimport { renderToPipeableStream } from 'react-dom/server';\nimport { Writable } from 'node:stream';\nimport { QueryClient, dehydrate, type DehydratedState } from '@tanstack/react-query';\nimport { AppProvider } from '../client/AppProvider';\nimport { ModelenceQueryProvider } from '../client/queryProvider';\nimport { getSsrContext, runWithSsrContext } from './context';\nimport { callInProcessMethod } from './callInProcess';\nimport type { Context } from '../methods/types';\nimport {\n _parseSessionUser,\n _setSsrSessionResolver,\n type SessionInitPayload,\n} from '../client/session';\nimport { _setSsrConfigResolver } from '../config/client';\nimport type { ConfigKey, Configs } from '../config/types';\nimport type { SsrRouter } from '../client/renderApp';\n\nconst sessionResolver = () => {\n const ctx = getSsrContext();\n if (!ctx) {\n return null;\n }\n return _parseSessionUser(ctx.session.user);\n};\n\nconst configResolver = (key: ConfigKey) => {\n const ctx = getSsrContext();\n if (!ctx) {\n return undefined;\n }\n return ctx.session.configs[key]?.value;\n};\n\nfunction ensureSsrResolversInstalled() {\n // Idempotent — safe to call repeatedly. Re-installs the framework's own\n // resolvers if they were swapped out (tests, future reload code).\n _setSsrSessionResolver(sessionResolver);\n _setSsrConfigResolver(configResolver);\n}\n\nexport type SsrRenderResult = {\n html: string;\n /** Inline as <script id=\"__MODELENCE_STATE__\">…</script> */\n sessionState: string;\n /** Inline as <script id=\"__MODELENCE_QUERY_STATE__\">…</script> */\n queryState: string;\n};\n\nexport type SsrRenderOptions = {\n callContext: Context;\n loadingElement: React.ReactNode;\n routesElement: React.ReactNode;\n router?: SsrRouter;\n location?: string;\n};\n\nexport async function renderSsrTree(options: SsrRenderOptions): Promise<SsrRenderResult> {\n const { callContext, loadingElement, routesElement, router, location } = options;\n\n ensureSsrResolversInstalled();\n\n const sessionPayload = await callInProcessMethod<SessionInitPayload>(\n '_system.session.init',\n {},\n callContext\n );\n\n const queryClient = new QueryClient({\n defaultOptions: {\n queries: {\n retry: false,\n // Per-request client; release cache + timers immediately after dehydrate.\n gcTime: 0,\n },\n },\n });\n\n const routedTree = router ? router({ children: routesElement, location }) : routesElement;\n\n const tree = (\n <AppProvider loadingElement={loadingElement}>\n <ModelenceQueryProvider client={queryClient}>{routedTree}</ModelenceQueryProvider>\n </AppProvider>\n );\n\n const html = await runWithSsrContext(\n {\n callContext,\n queryClient,\n session: {\n user: sessionPayload.user,\n configs: (sessionPayload.configs as Configs) ?? {},\n },\n },\n () => renderToString(tree, location)\n );\n\n // Safe to dehydrate + clear here: `onAllReady` waits for every Suspense\n // boundary to settle before resolving, so all in-flight queries have\n // populated the cache by this point.\n const dehydratedState: DehydratedState = dehydrate(queryClient);\n queryClient.clear();\n\n return {\n html,\n sessionState: JSON.stringify({ session: sessionPayload }),\n queryState: JSON.stringify(dehydratedState),\n };\n}\n\nfunction renderToString(tree: React.ReactElement, location: string | undefined): Promise<string> {\n return new Promise((resolve, reject) => {\n let buffer = '';\n const writable = new Writable({\n write(chunk, _encoding, callback) {\n buffer += chunk.toString();\n callback();\n },\n });\n\n const { pipe } = renderToPipeableStream(tree, {\n onAllReady() {\n writable.on('finish', () => resolve(buffer));\n writable.on('error', reject);\n pipe(writable);\n },\n onShellError(error) {\n reject(error);\n },\n onError(error) {\n // Non-fatal recoverable errors (Suspense fallbacks, etc.). React still\n // ships HTML, but repeated occurrences can mask real bugs — log with\n // request URL for telemetry follow-up.\n console.error('SSR onError (non-fatal):', { location, error });\n },\n });\n });\n}\n"]}
@@ -1,2 +0,0 @@
1
- export{g as getCallContext,f as startServer}from'./chunk-S3BSPKUV.js';import'./chunk-7E2S5HNK.js';import'./chunk-LDVLXJLS.js';import'./chunk-C3UESBRX.js';import'./chunk-3SPXJEOR.js';import'./chunk-5M6FUMUK.js';import'./chunk-DO5TZLF5.js';//# sourceMappingURL=server-UZKGL5C6.js.map
2
- //# sourceMappingURL=server-UZKGL5C6.js.map