one
Version:
One is a new React Framework that makes Vite serve both native and web.
25 lines (24 loc) • 1.47 kB
JavaScript
import { safeJsonStringify } from "./utils/htmlEscape.mjs";
const isWebClient = typeof window < "u",
isWebServer = typeof window > "u",
isNative = !1,
CACHE_KEY = `${process.env.ONE_CACHE_KEY ?? Math.round(Math.random() * 1e8)}`,
LOADER_JS_POSTFIX_UNCACHED = "_vxrn_loader.js",
LOADER_JS_POSTFIX_REGEX_STRING = `_\\d+${LOADER_JS_POSTFIX_UNCACHED}$`,
LOADER_JS_POSTFIX_REGEX = new RegExp(LOADER_JS_POSTFIX_REGEX_STRING),
LOADER_JS_POSTFIX = `_${CACHE_KEY}${LOADER_JS_POSTFIX_UNCACHED}`,
PRELOAD_JS_POSTFIX = `_${CACHE_KEY}_preload.js`,
CSS_PRELOAD_JS_POSTFIX = `_${CACHE_KEY}_preload_css.js`,
VIRTUAL_SSR_CSS_ENTRY = "virtual:ssr-css.css",
VIRTUAL_SSR_CSS_HREF = `/@id/__x00__${VIRTUAL_SSR_CSS_ENTRY}`,
SERVER_CONTEXT_KEY = "__one_server_context__",
getSpaHeaderElements = ({
serverContext = {}
} = {}) => `
<script>globalThis['global'] = globalThis</script>
<script>globalThis['__vxrnIsSPA'] = true</script>
<script>globalThis["${SERVER_CONTEXT_KEY}"] = ${safeJsonStringify(serverContext)}</script>
<script>globalThis.__oneLoadedCSS = new Set(${safeJsonStringify(serverContext.css || [])})</script>
`;
export { CACHE_KEY, CSS_PRELOAD_JS_POSTFIX, LOADER_JS_POSTFIX, LOADER_JS_POSTFIX_REGEX, LOADER_JS_POSTFIX_REGEX_STRING, LOADER_JS_POSTFIX_UNCACHED, PRELOAD_JS_POSTFIX, SERVER_CONTEXT_KEY, VIRTUAL_SSR_CSS_ENTRY, VIRTUAL_SSR_CSS_HREF, getSpaHeaderElements, isNative, isWebClient, isWebServer };
//# sourceMappingURL=constants.mjs.map