@modern-js/server-core
Version:
A Progressive React Framework for modern web development.
61 lines (60 loc) • 1.84 kB
JavaScript
import { createRender } from "./render";
const injectRenderHandlerPlugin = ({ staticGenerate, cacheConfig }) => ({
name: "@modern-js/plugin-inject-render",
setup(api) {
return {
async prepare() {
const { distDirectory: pwd, routes, metaName } = api.useAppContext();
const config = api.useConfigContext();
const hookRunner = api.useHookRunners();
if (!routes) {
return;
}
const onFallback = async (reason, utils, error) => {
await hookRunner.fallback({
reason,
...utils,
error
});
};
const getRenderHandlerOptions = {
pwd,
routes,
config,
metaName,
// TODO: support modern.server.ts cache config
cacheConfig,
staticGenerate,
onFallback
};
const render = await getRenderHandler(getRenderHandlerOptions);
api.setAppContext({
...api.useAppContext(),
render,
getRenderOptions: getRenderHandlerOptions
});
}
};
}
});
async function getRenderHandler({ pwd, routes, config, cacheConfig, metaName, staticGenerate, onFallback }) {
var _config_server, _config_security;
const ssrConfig = (_config_server = config.server) === null || _config_server === void 0 ? void 0 : _config_server.ssr;
const forceCSR = typeof ssrConfig === "object" ? ssrConfig.forceCSR : false;
const render = createRender({
routes,
pwd,
config,
staticGenerate,
cacheConfig,
forceCSR,
nonce: (_config_security = config.security) === null || _config_security === void 0 ? void 0 : _config_security.nonce,
metaName: metaName || "modern-js",
onFallback
});
return render;
}
export {
getRenderHandler,
injectRenderHandlerPlugin
};