UNPKG

one

Version:

One is a new React Framework that makes Vite serve both native and web.

80 lines 2.96 kB
var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var ServerContextScript_exports = {}; __export(ServerContextScript_exports, { ServerContextScript: () => ServerContextScript }); module.exports = __toCommonJS(ServerContextScript_exports); var import_constants = require("../constants.cjs"); var import_htmlEscape = require("../utils/htmlEscape.cjs"); var import_constants2 = require("../vite/constants.cjs"); var import_one_server_only = require("../vite/one-server-only.cjs"); var import_jsx_runtime = require("react/jsx-runtime"); function ServerContextScript() { if (process.env.VITE_ENVIRONMENT === "client") { return /* @__PURE__ */(0, import_jsx_runtime.jsx)("script", { async: true, href: import_constants.SERVER_CONTEXT_KEY, suppressHydrationWarning: true, dangerouslySetInnerHTML: { __html: `` } }); } if (process.env.VITE_ENVIRONMENT === "ssr") { const context = (0, import_one_server_only.useServerContext)(); const cssUrls = context?.css || []; const { cssContents, ...restContext } = context || {}; const compactMatches = restContext.matches?.map(m => ({ routeId: m.routeId, pathname: m.pathname, params: m.params, ...(m.loaderData !== restContext.loaderData ? { loaderData: m.loaderData } : {}) })); const clientContext = { ...restContext, matches: compactMatches, cssInlineCount: cssContents?.length || 0, // use placeholder — postRenderData is set during render (after this component) // and replaced in the HTML string after rendering completes postRenderData: import_constants2.SERVER_CONTEXT_POST_RENDER_STRING }; return /* @__PURE__ */(0, import_jsx_runtime.jsx)("script", { async: true, href: import_constants.SERVER_CONTEXT_KEY, suppressHydrationWarning: true, dangerouslySetInnerHTML: { __html: ` globalThis["${import_constants.SERVER_CONTEXT_KEY}"] = ${(0, import_htmlEscape.safeJsonStringify)(clientContext)}; globalThis.__oneLoadedCSS = new Set(${(0, import_htmlEscape.safeJsonStringify)(cssUrls)}); ` } }); } return null; }