feat: init
This commit is contained in:
6
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/app.d.mts
generated
vendored
Normal file
6
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/app.d.mts
generated
vendored
Normal file
@@ -0,0 +1,6 @@
|
||||
import type { H3Event } from "h3";
|
||||
import type { NuxtPayload, NuxtSSRContext } from "nuxt/app";
|
||||
export declare function createSSRContext(event: H3Event): NuxtSSRContext;
|
||||
export declare function setSSRError(ssrContext: NuxtSSRContext, error: NuxtPayload["error"] & {
|
||||
url: string;
|
||||
}): void;
|
||||
38
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/app.mjs
generated
vendored
Normal file
38
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/app.mjs
generated
vendored
Normal file
@@ -0,0 +1,38 @@
|
||||
import { useRuntimeConfig } from "nitropack/runtime";
|
||||
import { createHead } from "@unhead/vue/server";
|
||||
import { sharedPrerenderCache } from "../cache.mjs";
|
||||
// @ts-expect-error virtual file
|
||||
import unheadOptions from "#internal/unhead-options.mjs";
|
||||
// @ts-expect-error virtual file
|
||||
import { NUXT_NO_SSR, NUXT_SHARED_DATA } from "#internal/nuxt/nitro-config.mjs";
|
||||
const PRERENDER_NO_SSR_ROUTES = new Set([
|
||||
"/index.html",
|
||||
"/200.html",
|
||||
"/404.html"
|
||||
]);
|
||||
export function createSSRContext(event) {
|
||||
const ssrContext = {
|
||||
url: event.path,
|
||||
event,
|
||||
runtimeConfig: useRuntimeConfig(event),
|
||||
noSSR: !!NUXT_NO_SSR || event.context.nuxt?.noSSR || (import.meta.prerender ? PRERENDER_NO_SSR_ROUTES.has(event.path) : false),
|
||||
head: createHead(unheadOptions),
|
||||
error: false,
|
||||
nuxt: undefined,
|
||||
payload: {},
|
||||
["~payloadReducers"]: Object.create(null),
|
||||
modules: new Set()
|
||||
};
|
||||
if (import.meta.prerender) {
|
||||
if (NUXT_SHARED_DATA) {
|
||||
ssrContext["~sharedPrerenderCache"] = sharedPrerenderCache;
|
||||
}
|
||||
ssrContext.payload.prerenderedAt = Date.now();
|
||||
}
|
||||
return ssrContext;
|
||||
}
|
||||
export function setSSRError(ssrContext, error) {
|
||||
ssrContext.error = true;
|
||||
ssrContext.payload = { error };
|
||||
ssrContext.url = error.url;
|
||||
}
|
||||
16
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/build-files.d.mts
generated
vendored
Normal file
16
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/build-files.d.mts
generated
vendored
Normal file
@@ -0,0 +1,16 @@
|
||||
import type { RendererContext } from "vue-bundle-renderer/runtime";
|
||||
import type { NuxtSSRContext } from "nuxt/app";
|
||||
interface Renderer {
|
||||
rendererContext: RendererContext;
|
||||
renderToString(ssrContext: NuxtSSRContext): Promise<{
|
||||
html: string;
|
||||
renderResourceHeaders: () => Record<string, string>;
|
||||
renderResourceHints: () => string;
|
||||
renderStyles: () => string;
|
||||
renderScripts: () => string;
|
||||
}>;
|
||||
}
|
||||
export declare const getSSRRenderer: unknown;
|
||||
export declare function getRenderer(ssrContext: NuxtSSRContext): Promise<Renderer>;
|
||||
export declare const getSSRStyles: unknown;
|
||||
export {};
|
||||
100
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/build-files.mjs
generated
vendored
Normal file
100
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/build-files.mjs
generated
vendored
Normal file
@@ -0,0 +1,100 @@
|
||||
import { createRenderer } from "vue-bundle-renderer/runtime";
|
||||
import { renderToString as _renderToString } from "vue/server-renderer";
|
||||
import { propsToString } from "@unhead/vue/server";
|
||||
import { useRuntimeConfig } from "nitropack/runtime";
|
||||
// @ts-expect-error virtual file
|
||||
import { NUXT_NO_SSR } from "#internal/nuxt/nitro-config.mjs";
|
||||
// @ts-expect-error virtual file
|
||||
import { appRootAttrs, appRootTag, appSpaLoaderAttrs, appSpaLoaderTag, spaLoadingTemplateOutside } from "#internal/nuxt.config.mjs";
|
||||
// @ts-expect-error virtual file
|
||||
import { buildAssetsURL } from "#internal/nuxt/paths";
|
||||
const APP_ROOT_OPEN_TAG = `<${appRootTag}${propsToString(appRootAttrs)}>`;
|
||||
const APP_ROOT_CLOSE_TAG = `</${appRootTag}>`;
|
||||
// @ts-expect-error file will be produced after app build
|
||||
const getServerEntry = () => import("#build/dist/server/server.mjs").then((r) => r.default || r);
|
||||
// @ts-expect-error file will be produced after app build
|
||||
const getClientManifest = () => import("#build/dist/server/client.manifest.mjs").then((r) => r.default || r).then((r) => typeof r === "function" ? r() : r);
|
||||
// @ts-expect-error file will be produced after app build
|
||||
const getPrecomputedDependencies = () => import("#build/dist/server/client.precomputed.mjs").then((r) => r.default || r).then((r) => typeof r === "function" ? r() : r);
|
||||
// -- SSR Renderer --
|
||||
export const getSSRRenderer = lazyCachedFunction(async () => {
|
||||
// Load server bundle
|
||||
const createSSRApp = await getServerEntry();
|
||||
if (!createSSRApp) {
|
||||
throw new Error("Server bundle is not available");
|
||||
}
|
||||
// Load precomputed dependencies
|
||||
const precomputed = import.meta.dev ? undefined : await getPrecomputedDependencies();
|
||||
// Create renderer
|
||||
const renderer = createRenderer(createSSRApp, {
|
||||
precomputed,
|
||||
manifest: import.meta.dev ? await getClientManifest() : undefined,
|
||||
renderToString,
|
||||
buildAssetsURL
|
||||
});
|
||||
async function renderToString(input, context) {
|
||||
const html = await _renderToString(input, context);
|
||||
// In development with vite-node, the manifest is on-demand and will be available after rendering
|
||||
// eslint-disable-next-line no-restricted-globals
|
||||
if (import.meta.dev && process.env.NUXT_VITE_NODE_OPTIONS) {
|
||||
renderer.rendererContext.updateManifest(await getClientManifest());
|
||||
}
|
||||
return APP_ROOT_OPEN_TAG + html + APP_ROOT_CLOSE_TAG;
|
||||
}
|
||||
return renderer;
|
||||
});
|
||||
// -- SPA Renderer --
|
||||
const getSPARenderer = lazyCachedFunction(async () => {
|
||||
const precomputed = import.meta.dev ? undefined : await getPrecomputedDependencies();
|
||||
// @ts-expect-error virtual file
|
||||
const spaTemplate = await import("#spa-template").then((r) => r.template).catch(() => "").then((r) => {
|
||||
if (spaLoadingTemplateOutside) {
|
||||
const APP_SPA_LOADER_OPEN_TAG = `<${appSpaLoaderTag}${propsToString(appSpaLoaderAttrs)}>`;
|
||||
const APP_SPA_LOADER_CLOSE_TAG = `</${appSpaLoaderTag}>`;
|
||||
const appTemplate = APP_ROOT_OPEN_TAG + APP_ROOT_CLOSE_TAG;
|
||||
const loaderTemplate = r ? APP_SPA_LOADER_OPEN_TAG + r + APP_SPA_LOADER_CLOSE_TAG : "";
|
||||
return appTemplate + loaderTemplate;
|
||||
} else {
|
||||
return APP_ROOT_OPEN_TAG + r + APP_ROOT_CLOSE_TAG;
|
||||
}
|
||||
});
|
||||
// Create SPA renderer and cache the result for all requests
|
||||
const renderer = createRenderer(() => () => {}, {
|
||||
precomputed,
|
||||
manifest: import.meta.dev ? await getClientManifest() : undefined,
|
||||
renderToString: () => spaTemplate,
|
||||
buildAssetsURL
|
||||
});
|
||||
const result = await renderer.renderToString({});
|
||||
const renderToString = (ssrContext) => {
|
||||
const config = useRuntimeConfig(ssrContext.event);
|
||||
ssrContext.modules ||= new Set();
|
||||
ssrContext.payload.serverRendered = false;
|
||||
ssrContext.config = {
|
||||
public: config.public,
|
||||
app: config.app
|
||||
};
|
||||
return Promise.resolve(result);
|
||||
};
|
||||
return {
|
||||
rendererContext: renderer.rendererContext,
|
||||
renderToString
|
||||
};
|
||||
});
|
||||
function lazyCachedFunction(fn) {
|
||||
let res = null;
|
||||
return () => {
|
||||
if (res === null) {
|
||||
res = fn().catch((err) => {
|
||||
res = null;
|
||||
throw err;
|
||||
});
|
||||
}
|
||||
return res;
|
||||
};
|
||||
}
|
||||
export function getRenderer(ssrContext) {
|
||||
return NUXT_NO_SSR || ssrContext.noSSR ? getSPARenderer() : getSSRRenderer();
|
||||
}
|
||||
// @ts-expect-error file will be produced after app build
|
||||
export const getSSRStyles = lazyCachedFunction(() => import("#build/dist/server/styles.mjs").then((r) => r.default || r));
|
||||
2
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/inline-styles.d.mts
generated
vendored
Normal file
2
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/inline-styles.d.mts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
import type { Style } from "@unhead/vue/types";
|
||||
export declare function renderInlineStyles(usedModules: Set<string> | string[]): Promise<Style[]>;
|
||||
13
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/inline-styles.mjs
generated
vendored
Normal file
13
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/inline-styles.mjs
generated
vendored
Normal file
@@ -0,0 +1,13 @@
|
||||
import { getSSRStyles } from "./build-files.mjs";
|
||||
export async function renderInlineStyles(usedModules) {
|
||||
const styleMap = await getSSRStyles();
|
||||
const inlinedStyles = new Set();
|
||||
for (const mod of usedModules) {
|
||||
if (mod in styleMap && styleMap[mod]) {
|
||||
for (const style of await styleMap[mod]()) {
|
||||
inlinedStyles.add(style);
|
||||
}
|
||||
}
|
||||
}
|
||||
return Array.from(inlinedStyles).map((style) => ({ innerHTML: style }));
|
||||
}
|
||||
9
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/islands.d.mts
generated
vendored
Normal file
9
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/islands.d.mts
generated
vendored
Normal file
@@ -0,0 +1,9 @@
|
||||
import type { NuxtIslandResponse, NuxtSSRContext } from "nuxt/app";
|
||||
/**
|
||||
* remove the root node from the html body
|
||||
*/
|
||||
export declare function getServerComponentHTML(body: string): string;
|
||||
export declare function getSlotIslandResponse(ssrContext: NuxtSSRContext): NuxtIslandResponse["slots"];
|
||||
export declare function getClientIslandResponse(ssrContext: NuxtSSRContext): NuxtIslandResponse["components"];
|
||||
export declare function getComponentSlotTeleport(clientUid: string, teleports: Record<string, string>): Record<string, string>;
|
||||
export declare function replaceIslandTeleports(ssrContext: NuxtSSRContext, html: string): string;
|
||||
87
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/islands.mjs
generated
vendored
Normal file
87
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/islands.mjs
generated
vendored
Normal file
@@ -0,0 +1,87 @@
|
||||
// @ts-expect-error virtual file
|
||||
import { appRootTag } from "#internal/nuxt.config.mjs";
|
||||
const ROOT_NODE_REGEX = new RegExp(`^<${appRootTag}[^>]*>([\\s\\S]*)<\\/${appRootTag}>$`);
|
||||
/**
|
||||
* remove the root node from the html body
|
||||
*/
|
||||
export function getServerComponentHTML(body) {
|
||||
const match = body.match(ROOT_NODE_REGEX);
|
||||
return match?.[1] || body;
|
||||
}
|
||||
const SSR_SLOT_TELEPORT_MARKER = /^uid=([^;]*);slot=(.*)$/;
|
||||
const SSR_CLIENT_TELEPORT_MARKER = /^uid=([^;]*);client=(.*)$/;
|
||||
const SSR_CLIENT_SLOT_MARKER = /^island-slot=([^;]*);(.*)$/;
|
||||
export function getSlotIslandResponse(ssrContext) {
|
||||
if (!ssrContext.islandContext || !Object.keys(ssrContext.islandContext.slots).length) {
|
||||
return undefined;
|
||||
}
|
||||
const response = {};
|
||||
for (const [name, slot] of Object.entries(ssrContext.islandContext.slots)) {
|
||||
response[name] = {
|
||||
...slot,
|
||||
fallback: ssrContext.teleports?.[`island-fallback=${name}`]
|
||||
};
|
||||
}
|
||||
return response;
|
||||
}
|
||||
export function getClientIslandResponse(ssrContext) {
|
||||
if (!ssrContext.islandContext || !Object.keys(ssrContext.islandContext.components).length) {
|
||||
return undefined;
|
||||
}
|
||||
const response = {};
|
||||
for (const [clientUid, component] of Object.entries(ssrContext.islandContext.components)) {
|
||||
// remove teleport anchor to avoid hydration issues
|
||||
const html = ssrContext.teleports?.[clientUid]?.replaceAll("<!--teleport start anchor-->", "") || "";
|
||||
response[clientUid] = {
|
||||
...component,
|
||||
html,
|
||||
slots: getComponentSlotTeleport(clientUid, ssrContext.teleports ?? {})
|
||||
};
|
||||
}
|
||||
return response;
|
||||
}
|
||||
export function getComponentSlotTeleport(clientUid, teleports) {
|
||||
const entries = Object.entries(teleports);
|
||||
const slots = {};
|
||||
for (const [key, value] of entries) {
|
||||
const match = key.match(SSR_CLIENT_SLOT_MARKER);
|
||||
if (match) {
|
||||
const [, id, slot] = match;
|
||||
if (!slot || clientUid !== id) {
|
||||
continue;
|
||||
}
|
||||
slots[slot] = value;
|
||||
}
|
||||
}
|
||||
return slots;
|
||||
}
|
||||
export function replaceIslandTeleports(ssrContext, html) {
|
||||
const { teleports, islandContext } = ssrContext;
|
||||
if (islandContext || !teleports) {
|
||||
return html;
|
||||
}
|
||||
for (const key in teleports) {
|
||||
const matchClientComp = key.match(SSR_CLIENT_TELEPORT_MARKER);
|
||||
if (matchClientComp) {
|
||||
const [, uid, clientId] = matchClientComp;
|
||||
if (!uid || !clientId) {
|
||||
continue;
|
||||
}
|
||||
html = html.replace(new RegExp(` data-island-uid="${uid}" data-island-component="${clientId}"[^>]*>`), (full) => {
|
||||
return full + teleports[key];
|
||||
});
|
||||
continue;
|
||||
}
|
||||
const matchSlot = key.match(SSR_SLOT_TELEPORT_MARKER);
|
||||
if (matchSlot) {
|
||||
const [, uid, slot] = matchSlot;
|
||||
if (!uid || !slot) {
|
||||
continue;
|
||||
}
|
||||
html = html.replace(new RegExp(` data-island-uid="${uid}" data-island-slot="${slot}"[^>]*>`), (full) => {
|
||||
return full + teleports[key];
|
||||
});
|
||||
}
|
||||
}
|
||||
return html;
|
||||
}
|
||||
24
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/payload.d.mts
generated
vendored
Normal file
24
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/payload.d.mts
generated
vendored
Normal file
@@ -0,0 +1,24 @@
|
||||
import type { NitroRouteRules, RenderResponse } from "nitropack/types";
|
||||
import type { Script } from "@unhead/vue";
|
||||
import type { NuxtPayload, NuxtSSRContext } from "nuxt/app";
|
||||
export declare function renderPayloadResponse(ssrContext: NuxtSSRContext): RenderResponse;
|
||||
export declare function renderPayloadJsonScript(opts: {
|
||||
ssrContext: NuxtSSRContext;
|
||||
data?: any;
|
||||
src?: string;
|
||||
}): Script[];
|
||||
export declare function renderPayloadScript(opts: {
|
||||
ssrContext: NuxtSSRContext;
|
||||
routeOptions: NitroRouteRules;
|
||||
data?: any;
|
||||
src?: string;
|
||||
}): Script[];
|
||||
interface SplitPayload {
|
||||
initial: Omit<NuxtPayload, "data">;
|
||||
payload: {
|
||||
data?: NuxtPayload["data"];
|
||||
prerenderedAt?: NuxtPayload["prerenderedAt"];
|
||||
};
|
||||
}
|
||||
export declare function splitPayload(ssrContext: NuxtSSRContext): SplitPayload;
|
||||
export {};
|
||||
64
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/payload.mjs
generated
vendored
Normal file
64
node_modules/@nuxt/nitro-server/dist/runtime/utils/renderer/payload.mjs
generated
vendored
Normal file
@@ -0,0 +1,64 @@
|
||||
import { getResponseStatus, getResponseStatusText } from "h3";
|
||||
import devalue from "@nuxt/devalue";
|
||||
import { stringify, uneval } from "devalue";
|
||||
// @ts-expect-error virtual file
|
||||
import { appId, multiApp } from "#internal/nuxt.config.mjs";
|
||||
// @ts-expect-error virtual file
|
||||
import { NUXT_JSON_PAYLOADS, NUXT_NO_SSR, NUXT_PAYLOAD_EXTRACTION, NUXT_RUNTIME_PAYLOAD_EXTRACTION } from "#internal/nuxt/nitro-config.mjs";
|
||||
export function renderPayloadResponse(ssrContext) {
|
||||
return {
|
||||
body: NUXT_JSON_PAYLOADS ? stringify(splitPayload(ssrContext).payload, ssrContext["~payloadReducers"]) : `export default ${devalue(splitPayload(ssrContext).payload)}`,
|
||||
statusCode: getResponseStatus(ssrContext.event),
|
||||
statusMessage: getResponseStatusText(ssrContext.event),
|
||||
headers: {
|
||||
"content-type": NUXT_JSON_PAYLOADS ? "application/json;charset=utf-8" : "text/javascript;charset=utf-8",
|
||||
"x-powered-by": "Nuxt"
|
||||
}
|
||||
};
|
||||
}
|
||||
export function renderPayloadJsonScript(opts) {
|
||||
const contents = opts.data ? stringify(opts.data, opts.ssrContext["~payloadReducers"]) : "";
|
||||
const payload = {
|
||||
"type": "application/json",
|
||||
"innerHTML": contents,
|
||||
"data-nuxt-data": appId,
|
||||
"data-ssr": !(NUXT_NO_SSR || opts.ssrContext.noSSR)
|
||||
};
|
||||
if (!multiApp) {
|
||||
payload.id = "__NUXT_DATA__";
|
||||
}
|
||||
if (opts.src) {
|
||||
payload["data-src"] = opts.src;
|
||||
}
|
||||
const config = uneval(opts.ssrContext.config);
|
||||
return [payload, { innerHTML: multiApp ? `window.__NUXT__=window.__NUXT__||{};window.__NUXT__[${JSON.stringify(appId)}]={config:${config}}` : `window.__NUXT__={};window.__NUXT__.config=${config}` }];
|
||||
}
|
||||
export function renderPayloadScript(opts) {
|
||||
opts.data.config = opts.ssrContext.config;
|
||||
const _PAYLOAD_EXTRACTION = !opts.ssrContext.noSSR && (import.meta.prerender && NUXT_PAYLOAD_EXTRACTION || NUXT_RUNTIME_PAYLOAD_EXTRACTION && (opts.routeOptions.isr || opts.routeOptions.cache));
|
||||
const nuxtData = devalue(opts.data);
|
||||
if (_PAYLOAD_EXTRACTION) {
|
||||
const singleAppPayload = `import p from "${opts.src}";window.__NUXT__={...p,...(${nuxtData})}`;
|
||||
const multiAppPayload = `import p from "${opts.src}";window.__NUXT__=window.__NUXT__||{};window.__NUXT__[${JSON.stringify(appId)}]={...p,...(${nuxtData})}`;
|
||||
return [{
|
||||
type: "module",
|
||||
innerHTML: multiApp ? multiAppPayload : singleAppPayload
|
||||
}];
|
||||
}
|
||||
const singleAppPayload = `window.__NUXT__=${nuxtData}`;
|
||||
const multiAppPayload = `window.__NUXT__=window.__NUXT__||{};window.__NUXT__[${JSON.stringify(appId)}]=${nuxtData}`;
|
||||
return [{ innerHTML: multiApp ? multiAppPayload : singleAppPayload }];
|
||||
}
|
||||
export function splitPayload(ssrContext) {
|
||||
const { data, prerenderedAt, ...initial } = ssrContext.payload;
|
||||
return {
|
||||
initial: {
|
||||
...initial,
|
||||
prerenderedAt
|
||||
},
|
||||
payload: {
|
||||
data,
|
||||
prerenderedAt
|
||||
}
|
||||
};
|
||||
}
|
||||
Reference in New Issue
Block a user