Imporve HMR Post-build function speed
This commit is contained in:
parent
2b170d24e1
commit
86d4bb8d6c
@ -14,8 +14,9 @@ export default async function serverPostBuildFn() {
|
|||||||
}
|
}
|
||||||
const target_artifact = global.BUNDLER_CTX_MAP[controller.target_map.local_path];
|
const target_artifact = global.BUNDLER_CTX_MAP[controller.target_map.local_path];
|
||||||
const mock_req = new Request(controller.page_url);
|
const mock_req = new Request(controller.page_url);
|
||||||
const { serverRes, bundledMap, module, root_module } = await grabPageComponent({
|
const { serverRes } = await grabPageComponent({
|
||||||
req: mock_req,
|
req: mock_req,
|
||||||
|
return_server_res_only: true,
|
||||||
});
|
});
|
||||||
const final_artifact = {
|
const final_artifact = {
|
||||||
..._.omit(controller, ["controller"]),
|
..._.omit(controller, ["controller"]),
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
import type { BunextPageModule, BunextPageModuleServerReturn, BunxRouteParams } from "../../../types";
|
import type { BunextPageModule, BunextPageModuleServerReturn, BunxRouteParams } from "../../../types";
|
||||||
type Params = {
|
type Params = {
|
||||||
html: string;
|
html: string;
|
||||||
module: BunextPageModule;
|
module?: BunextPageModule;
|
||||||
root_module?: BunextPageModule;
|
root_module?: BunextPageModule;
|
||||||
routeParams?: BunxRouteParams;
|
routeParams?: BunxRouteParams;
|
||||||
serverRes?: BunextPageModuleServerReturn<any, any>;
|
serverRes?: BunextPageModuleServerReturn<any, any>;
|
||||||
|
|||||||
@ -2,7 +2,7 @@ import _ from "lodash";
|
|||||||
import { log } from "../../../utils/log";
|
import { log } from "../../../utils/log";
|
||||||
import writeCache from "../../cache/write-cache";
|
import writeCache from "../../cache/write-cache";
|
||||||
export default async function generateWebPageGetCachePage({ module, routeParams, serverRes, root_module, html, }) {
|
export default async function generateWebPageGetCachePage({ module, routeParams, serverRes, root_module, html, }) {
|
||||||
const config = _.merge(root_module?.config, module.config);
|
const config = _.merge(root_module?.config, module?.config);
|
||||||
const cache_page = config?.cachePage || serverRes?.cachePage || false;
|
const cache_page = config?.cachePage || serverRes?.cachePage || false;
|
||||||
const expiry_seconds = config?.cacheExpiry || serverRes?.cacheExpiry;
|
const expiry_seconds = config?.cacheExpiry || serverRes?.cacheExpiry;
|
||||||
if (cache_page && routeParams?.url) {
|
if (cache_page && routeParams?.url) {
|
||||||
|
|||||||
12
dist/functions/server/web-pages/grab-page-combined-server-res.d.ts
vendored
Normal file
12
dist/functions/server/web-pages/grab-page-combined-server-res.d.ts
vendored
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
import type { BunextPageModuleServerReturn, BunxRouteParams } from "../../../types";
|
||||||
|
type Params = {
|
||||||
|
file_path: string;
|
||||||
|
debug?: boolean;
|
||||||
|
url?: URL;
|
||||||
|
query?: any;
|
||||||
|
routeParams?: BunxRouteParams;
|
||||||
|
};
|
||||||
|
export default function grabPageCombinedServerRes({ file_path, debug, url, query, routeParams, }: Params): Promise<{
|
||||||
|
serverRes: BunextPageModuleServerReturn;
|
||||||
|
}>;
|
||||||
|
export {};
|
||||||
42
dist/functions/server/web-pages/grab-page-combined-server-res.js
vendored
Normal file
42
dist/functions/server/web-pages/grab-page-combined-server-res.js
vendored
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
import _ from "lodash";
|
||||||
|
import { log } from "../../../utils/log";
|
||||||
|
import grabRootFilePath from "./grab-root-file-path";
|
||||||
|
import grabPageServerRes from "./grab-page-server-res";
|
||||||
|
import grabPageServerPath from "./grab-page-server-path";
|
||||||
|
export default async function grabPageCombinedServerRes({ file_path, debug, url, query, routeParams, }) {
|
||||||
|
const now = Date.now();
|
||||||
|
const { root_file_path } = grabRootFilePath();
|
||||||
|
const { server_file_path: root_server_file_path } = root_file_path
|
||||||
|
? grabPageServerPath({ file_path: root_file_path })
|
||||||
|
: {};
|
||||||
|
const root_server_module = root_server_file_path
|
||||||
|
? await import(`${root_server_file_path}?t=${now}`)
|
||||||
|
: undefined;
|
||||||
|
const root_server_fn = root_server_module?.default || root_server_module?.server;
|
||||||
|
const rootServerRes = root_server_fn
|
||||||
|
? await grabPageServerRes({
|
||||||
|
server_function: root_server_fn,
|
||||||
|
url,
|
||||||
|
query,
|
||||||
|
routeParams,
|
||||||
|
})
|
||||||
|
: undefined;
|
||||||
|
if (debug) {
|
||||||
|
log.info(`rootServerRes:`, rootServerRes);
|
||||||
|
}
|
||||||
|
const { server_file_path } = grabPageServerPath({ file_path });
|
||||||
|
const server_module = server_file_path
|
||||||
|
? await import(`${server_file_path}?t=${now}`)
|
||||||
|
: undefined;
|
||||||
|
const server_fn = server_module?.default || server_module?.server;
|
||||||
|
const serverRes = server_fn
|
||||||
|
? await grabPageServerRes({
|
||||||
|
server_function: server_fn,
|
||||||
|
url,
|
||||||
|
query,
|
||||||
|
routeParams,
|
||||||
|
})
|
||||||
|
: undefined;
|
||||||
|
const mergedServerRes = _.merge(rootServerRes || {}, serverRes || {});
|
||||||
|
return { serverRes: mergedServerRes };
|
||||||
|
}
|
||||||
@ -3,6 +3,7 @@ type Params = {
|
|||||||
req?: Request;
|
req?: Request;
|
||||||
file_path?: string;
|
file_path?: string;
|
||||||
debug?: boolean;
|
debug?: boolean;
|
||||||
|
return_server_res_only?: boolean;
|
||||||
};
|
};
|
||||||
export default function grabPageComponent({ req, file_path: passed_file_path, debug, }: Params): Promise<GrabPageComponentRes>;
|
export default function grabPageComponent({ req, file_path: passed_file_path, debug, return_server_res_only, }: Params): Promise<GrabPageComponentRes>;
|
||||||
export {};
|
export {};
|
||||||
|
|||||||
@ -7,9 +7,10 @@ import grabRootFilePath from "./grab-root-file-path";
|
|||||||
import grabPageServerRes from "./grab-page-server-res";
|
import grabPageServerRes from "./grab-page-server-res";
|
||||||
import grabPageServerPath from "./grab-page-server-path";
|
import grabPageServerPath from "./grab-page-server-path";
|
||||||
import grabPageModules from "./grab-page-modules";
|
import grabPageModules from "./grab-page-modules";
|
||||||
|
import grabPageCombinedServerRes from "./grab-page-combined-server-res";
|
||||||
class NotFoundError extends Error {
|
class NotFoundError extends Error {
|
||||||
}
|
}
|
||||||
export default async function grabPageComponent({ req, file_path: passed_file_path, debug, }) {
|
export default async function grabPageComponent({ req, file_path: passed_file_path, debug, return_server_res_only, }) {
|
||||||
const url = req?.url ? new URL(req.url) : undefined;
|
const url = req?.url ? new URL(req.url) : undefined;
|
||||||
const router = global.ROUTER;
|
const router = global.ROUTER;
|
||||||
let routeParams = undefined;
|
let routeParams = undefined;
|
||||||
@ -45,6 +46,16 @@ export default async function grabPageComponent({ req, file_path: passed_file_pa
|
|||||||
if (debug) {
|
if (debug) {
|
||||||
log.info(`bundledMap:`, bundledMap);
|
log.info(`bundledMap:`, bundledMap);
|
||||||
}
|
}
|
||||||
|
if (return_server_res_only) {
|
||||||
|
const { serverRes } = await grabPageCombinedServerRes({
|
||||||
|
file_path,
|
||||||
|
debug,
|
||||||
|
query: match?.query,
|
||||||
|
routeParams,
|
||||||
|
url,
|
||||||
|
});
|
||||||
|
return { serverRes };
|
||||||
|
}
|
||||||
const { component, module, serverRes, root_module } = await grabPageModules({
|
const { component, module, serverRes, root_module } = await grabPageModules({
|
||||||
file_path,
|
file_path,
|
||||||
debug,
|
debug,
|
||||||
|
|||||||
@ -4,55 +4,28 @@ import { log } from "../../../utils/log";
|
|||||||
import grabRootFilePath from "./grab-root-file-path";
|
import grabRootFilePath from "./grab-root-file-path";
|
||||||
import grabPageServerRes from "./grab-page-server-res";
|
import grabPageServerRes from "./grab-page-server-res";
|
||||||
import grabPageServerPath from "./grab-page-server-path";
|
import grabPageServerPath from "./grab-page-server-path";
|
||||||
|
import grabPageCombinedServerRes from "./grab-page-combined-server-res";
|
||||||
export default async function grabPageModules({ file_path, debug, url, query, routeParams, }) {
|
export default async function grabPageModules({ file_path, debug, url, query, routeParams, }) {
|
||||||
const now = Date.now();
|
const now = Date.now();
|
||||||
const { root_file_path } = grabRootFilePath();
|
const { root_file_path } = grabRootFilePath();
|
||||||
const root_module = root_file_path
|
const root_module = root_file_path
|
||||||
? await import(`${root_file_path}?t=${now}`)
|
? await import(`${root_file_path}?t=${now}`)
|
||||||
: undefined;
|
: undefined;
|
||||||
const { server_file_path: root_server_file_path } = root_file_path
|
|
||||||
? grabPageServerPath({ file_path: root_file_path })
|
|
||||||
: {};
|
|
||||||
const root_server_module = root_server_file_path
|
|
||||||
? await import(`${root_server_file_path}?t=${now}`)
|
|
||||||
: undefined;
|
|
||||||
const root_server_fn = root_server_module?.default || root_server_module?.server;
|
|
||||||
const rootServerRes = root_server_fn
|
|
||||||
? await grabPageServerRes({
|
|
||||||
server_function: root_server_fn,
|
|
||||||
url,
|
|
||||||
query,
|
|
||||||
routeParams,
|
|
||||||
})
|
|
||||||
: undefined;
|
|
||||||
if (debug) {
|
|
||||||
log.info(`rootServerRes:`, rootServerRes);
|
|
||||||
}
|
|
||||||
const module = await import(`${file_path}?t=${now}`);
|
const module = await import(`${file_path}?t=${now}`);
|
||||||
const { server_file_path } = grabPageServerPath({ file_path });
|
|
||||||
const server_module = server_file_path
|
|
||||||
? await import(`${server_file_path}?t=${now}`)
|
|
||||||
: undefined;
|
|
||||||
if (debug) {
|
if (debug) {
|
||||||
log.info(`module:`, module);
|
log.info(`module:`, module);
|
||||||
}
|
}
|
||||||
const server_fn = server_module?.default || server_module?.server;
|
const { serverRes } = await grabPageCombinedServerRes({
|
||||||
const serverRes = server_fn
|
file_path,
|
||||||
? await grabPageServerRes({
|
debug,
|
||||||
server_function: server_fn,
|
|
||||||
url,
|
|
||||||
query,
|
query,
|
||||||
routeParams,
|
routeParams,
|
||||||
})
|
url,
|
||||||
: undefined;
|
});
|
||||||
if (debug) {
|
|
||||||
log.info(`serverRes:`, serverRes);
|
|
||||||
}
|
|
||||||
const mergedServerRes = _.merge(rootServerRes || {}, serverRes || {});
|
|
||||||
const { component } = (await grabPageBundledReactComponent({
|
const { component } = (await grabPageBundledReactComponent({
|
||||||
file_path,
|
file_path,
|
||||||
root_file_path,
|
root_file_path,
|
||||||
server_res: mergedServerRes,
|
server_res: serverRes,
|
||||||
})) || {};
|
})) || {};
|
||||||
if (!component) {
|
if (!component) {
|
||||||
throw new Error(`Couldn't grab page component`);
|
throw new Error(`Couldn't grab page component`);
|
||||||
@ -62,7 +35,7 @@ export default async function grabPageModules({ file_path, debug, url, query, ro
|
|||||||
}
|
}
|
||||||
return {
|
return {
|
||||||
component,
|
component,
|
||||||
serverRes: mergedServerRes,
|
serverRes,
|
||||||
module,
|
module,
|
||||||
root_module,
|
root_module,
|
||||||
};
|
};
|
||||||
|
|||||||
4
dist/types/index.d.ts
vendored
4
dist/types/index.d.ts
vendored
@ -245,11 +245,11 @@ export type BunextPageModuleMetadata = {
|
|||||||
description?: string;
|
description?: string;
|
||||||
};
|
};
|
||||||
export type GrabPageComponentRes = {
|
export type GrabPageComponentRes = {
|
||||||
component: JSX.Element;
|
component?: JSX.Element;
|
||||||
serverRes?: BunextPageModuleServerReturn;
|
serverRes?: BunextPageModuleServerReturn;
|
||||||
routeParams?: BunxRouteParams;
|
routeParams?: BunxRouteParams;
|
||||||
bundledMap?: BundlerCTXMap;
|
bundledMap?: BundlerCTXMap;
|
||||||
module: BunextPageModule;
|
module?: BunextPageModule;
|
||||||
root_module?: BunextRootModule;
|
root_module?: BunextRootModule;
|
||||||
debug?: boolean;
|
debug?: boolean;
|
||||||
};
|
};
|
||||||
|
|||||||
@ -2,7 +2,7 @@
|
|||||||
"name": "@moduletrace/bunext",
|
"name": "@moduletrace/bunext",
|
||||||
"module": "index.ts",
|
"module": "index.ts",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"version": "1.0.41",
|
"version": "1.0.42",
|
||||||
"main": "dist/index.js",
|
"main": "dist/index.js",
|
||||||
"types": "dist/index.d.ts",
|
"types": "dist/index.d.ts",
|
||||||
"exports": {
|
"exports": {
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
import _ from "lodash";
|
import _ from "lodash";
|
||||||
import type { BundlerCTXMap, GlobalHMRControllerObject } from "../../types";
|
import type { GlobalHMRControllerObject } from "../../types";
|
||||||
import grabPageComponent from "./web-pages/grab-page-component";
|
import grabPageComponent from "./web-pages/grab-page-component";
|
||||||
|
|
||||||
export default async function serverPostBuildFn() {
|
export default async function serverPostBuildFn() {
|
||||||
@ -23,9 +23,9 @@ export default async function serverPostBuildFn() {
|
|||||||
|
|
||||||
const mock_req = new Request(controller.page_url);
|
const mock_req = new Request(controller.page_url);
|
||||||
|
|
||||||
const { serverRes, bundledMap, module, root_module } =
|
const { serverRes } = await grabPageComponent({
|
||||||
await grabPageComponent({
|
|
||||||
req: mock_req,
|
req: mock_req,
|
||||||
|
return_server_res_only: true,
|
||||||
});
|
});
|
||||||
|
|
||||||
const final_artifact: Omit<GlobalHMRControllerObject, "controller"> = {
|
const final_artifact: Omit<GlobalHMRControllerObject, "controller"> = {
|
||||||
|
|||||||
@ -9,7 +9,7 @@ import writeCache from "../../cache/write-cache";
|
|||||||
|
|
||||||
type Params = {
|
type Params = {
|
||||||
html: string;
|
html: string;
|
||||||
module: BunextPageModule;
|
module?: BunextPageModule;
|
||||||
root_module?: BunextPageModule;
|
root_module?: BunextPageModule;
|
||||||
routeParams?: BunxRouteParams;
|
routeParams?: BunxRouteParams;
|
||||||
serverRes?: BunextPageModuleServerReturn<any, any>;
|
serverRes?: BunextPageModuleServerReturn<any, any>;
|
||||||
@ -22,7 +22,7 @@ export default async function generateWebPageGetCachePage({
|
|||||||
root_module,
|
root_module,
|
||||||
html,
|
html,
|
||||||
}: Params) {
|
}: Params) {
|
||||||
const config = _.merge(root_module?.config, module.config);
|
const config = _.merge(root_module?.config, module?.config);
|
||||||
|
|
||||||
const cache_page = config?.cachePage || serverRes?.cachePage || false;
|
const cache_page = config?.cachePage || serverRes?.cachePage || false;
|
||||||
const expiry_seconds = config?.cacheExpiry || serverRes?.cacheExpiry;
|
const expiry_seconds = config?.cacheExpiry || serverRes?.cacheExpiry;
|
||||||
|
|||||||
@ -0,0 +1,73 @@
|
|||||||
|
import type {
|
||||||
|
BunextPageModuleServerReturn,
|
||||||
|
BunextPageServerModule,
|
||||||
|
BunxRouteParams,
|
||||||
|
} from "../../../types";
|
||||||
|
import _ from "lodash";
|
||||||
|
import { log } from "../../../utils/log";
|
||||||
|
import grabRootFilePath from "./grab-root-file-path";
|
||||||
|
import grabPageServerRes from "./grab-page-server-res";
|
||||||
|
import grabPageServerPath from "./grab-page-server-path";
|
||||||
|
|
||||||
|
type Params = {
|
||||||
|
file_path: string;
|
||||||
|
debug?: boolean;
|
||||||
|
url?: URL;
|
||||||
|
query?: any;
|
||||||
|
routeParams?: BunxRouteParams;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default async function grabPageCombinedServerRes({
|
||||||
|
file_path,
|
||||||
|
debug,
|
||||||
|
url,
|
||||||
|
query,
|
||||||
|
routeParams,
|
||||||
|
}: Params) {
|
||||||
|
const now = Date.now();
|
||||||
|
|
||||||
|
const { root_file_path } = grabRootFilePath();
|
||||||
|
const { server_file_path: root_server_file_path } = root_file_path
|
||||||
|
? grabPageServerPath({ file_path: root_file_path })
|
||||||
|
: {};
|
||||||
|
const root_server_module: BunextPageServerModule = root_server_file_path
|
||||||
|
? await import(`${root_server_file_path}?t=${now}`)
|
||||||
|
: undefined;
|
||||||
|
|
||||||
|
const root_server_fn =
|
||||||
|
root_server_module?.default || root_server_module?.server;
|
||||||
|
|
||||||
|
const rootServerRes: BunextPageModuleServerReturn | undefined =
|
||||||
|
root_server_fn
|
||||||
|
? await grabPageServerRes({
|
||||||
|
server_function: root_server_fn,
|
||||||
|
url,
|
||||||
|
query,
|
||||||
|
routeParams,
|
||||||
|
})
|
||||||
|
: undefined;
|
||||||
|
|
||||||
|
if (debug) {
|
||||||
|
log.info(`rootServerRes:`, rootServerRes);
|
||||||
|
}
|
||||||
|
|
||||||
|
const { server_file_path } = grabPageServerPath({ file_path });
|
||||||
|
const server_module: BunextPageServerModule = server_file_path
|
||||||
|
? await import(`${server_file_path}?t=${now}`)
|
||||||
|
: undefined;
|
||||||
|
|
||||||
|
const server_fn = server_module?.default || server_module?.server;
|
||||||
|
|
||||||
|
const serverRes: BunextPageModuleServerReturn | undefined = server_fn
|
||||||
|
? await grabPageServerRes({
|
||||||
|
server_function: server_fn,
|
||||||
|
url,
|
||||||
|
query,
|
||||||
|
routeParams,
|
||||||
|
})
|
||||||
|
: undefined;
|
||||||
|
|
||||||
|
const mergedServerRes = _.merge(rootServerRes || {}, serverRes || {});
|
||||||
|
|
||||||
|
return { serverRes: mergedServerRes };
|
||||||
|
}
|
||||||
@ -15,6 +15,7 @@ import grabRootFilePath from "./grab-root-file-path";
|
|||||||
import grabPageServerRes from "./grab-page-server-res";
|
import grabPageServerRes from "./grab-page-server-res";
|
||||||
import grabPageServerPath from "./grab-page-server-path";
|
import grabPageServerPath from "./grab-page-server-path";
|
||||||
import grabPageModules from "./grab-page-modules";
|
import grabPageModules from "./grab-page-modules";
|
||||||
|
import grabPageCombinedServerRes from "./grab-page-combined-server-res";
|
||||||
|
|
||||||
class NotFoundError extends Error {}
|
class NotFoundError extends Error {}
|
||||||
|
|
||||||
@ -22,12 +23,14 @@ type Params = {
|
|||||||
req?: Request;
|
req?: Request;
|
||||||
file_path?: string;
|
file_path?: string;
|
||||||
debug?: boolean;
|
debug?: boolean;
|
||||||
|
return_server_res_only?: boolean;
|
||||||
};
|
};
|
||||||
|
|
||||||
export default async function grabPageComponent({
|
export default async function grabPageComponent({
|
||||||
req,
|
req,
|
||||||
file_path: passed_file_path,
|
file_path: passed_file_path,
|
||||||
debug,
|
debug,
|
||||||
|
return_server_res_only,
|
||||||
}: Params): Promise<GrabPageComponentRes> {
|
}: Params): Promise<GrabPageComponentRes> {
|
||||||
const url = req?.url ? new URL(req.url) : undefined;
|
const url = req?.url ? new URL(req.url) : undefined;
|
||||||
const router = global.ROUTER;
|
const router = global.ROUTER;
|
||||||
@ -78,6 +81,18 @@ export default async function grabPageComponent({
|
|||||||
log.info(`bundledMap:`, bundledMap);
|
log.info(`bundledMap:`, bundledMap);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (return_server_res_only) {
|
||||||
|
const { serverRes } = await grabPageCombinedServerRes({
|
||||||
|
file_path,
|
||||||
|
debug,
|
||||||
|
query: match?.query,
|
||||||
|
routeParams,
|
||||||
|
url,
|
||||||
|
});
|
||||||
|
|
||||||
|
return { serverRes };
|
||||||
|
}
|
||||||
|
|
||||||
const { component, module, serverRes, root_module } =
|
const { component, module, serverRes, root_module } =
|
||||||
await grabPageModules({
|
await grabPageModules({
|
||||||
file_path,
|
file_path,
|
||||||
|
|||||||
@ -12,6 +12,7 @@ import grabRootFilePath from "./grab-root-file-path";
|
|||||||
import grabPageServerRes from "./grab-page-server-res";
|
import grabPageServerRes from "./grab-page-server-res";
|
||||||
import grabPageServerPath from "./grab-page-server-path";
|
import grabPageServerPath from "./grab-page-server-path";
|
||||||
import type { JSX } from "react";
|
import type { JSX } from "react";
|
||||||
|
import grabPageCombinedServerRes from "./grab-page-combined-server-res";
|
||||||
|
|
||||||
type Params = {
|
type Params = {
|
||||||
file_path: string;
|
file_path: string;
|
||||||
@ -34,62 +35,26 @@ export default async function grabPageModules({
|
|||||||
const root_module: BunextRootModule | undefined = root_file_path
|
const root_module: BunextRootModule | undefined = root_file_path
|
||||||
? await import(`${root_file_path}?t=${now}`)
|
? await import(`${root_file_path}?t=${now}`)
|
||||||
: undefined;
|
: undefined;
|
||||||
const { server_file_path: root_server_file_path } = root_file_path
|
|
||||||
? grabPageServerPath({ file_path: root_file_path })
|
|
||||||
: {};
|
|
||||||
const root_server_module: BunextPageServerModule = root_server_file_path
|
|
||||||
? await import(`${root_server_file_path}?t=${now}`)
|
|
||||||
: undefined;
|
|
||||||
|
|
||||||
const root_server_fn =
|
|
||||||
root_server_module?.default || root_server_module?.server;
|
|
||||||
|
|
||||||
const rootServerRes: BunextPageModuleServerReturn | undefined =
|
|
||||||
root_server_fn
|
|
||||||
? await grabPageServerRes({
|
|
||||||
server_function: root_server_fn,
|
|
||||||
url,
|
|
||||||
query,
|
|
||||||
routeParams,
|
|
||||||
})
|
|
||||||
: undefined;
|
|
||||||
|
|
||||||
if (debug) {
|
|
||||||
log.info(`rootServerRes:`, rootServerRes);
|
|
||||||
}
|
|
||||||
|
|
||||||
const module: BunextPageModule = await import(`${file_path}?t=${now}`);
|
const module: BunextPageModule = await import(`${file_path}?t=${now}`);
|
||||||
const { server_file_path } = grabPageServerPath({ file_path });
|
|
||||||
const server_module: BunextPageServerModule = server_file_path
|
|
||||||
? await import(`${server_file_path}?t=${now}`)
|
|
||||||
: undefined;
|
|
||||||
|
|
||||||
if (debug) {
|
if (debug) {
|
||||||
log.info(`module:`, module);
|
log.info(`module:`, module);
|
||||||
}
|
}
|
||||||
|
|
||||||
const server_fn = server_module?.default || server_module?.server;
|
const { serverRes } = await grabPageCombinedServerRes({
|
||||||
|
file_path,
|
||||||
const serverRes: BunextPageModuleServerReturn | undefined = server_fn
|
debug,
|
||||||
? await grabPageServerRes({
|
|
||||||
server_function: server_fn,
|
|
||||||
url,
|
|
||||||
query,
|
query,
|
||||||
routeParams,
|
routeParams,
|
||||||
})
|
url,
|
||||||
: undefined;
|
});
|
||||||
|
|
||||||
if (debug) {
|
|
||||||
log.info(`serverRes:`, serverRes);
|
|
||||||
}
|
|
||||||
|
|
||||||
const mergedServerRes = _.merge(rootServerRes || {}, serverRes || {});
|
|
||||||
|
|
||||||
const { component } =
|
const { component } =
|
||||||
(await grabPageBundledReactComponent({
|
(await grabPageBundledReactComponent({
|
||||||
file_path,
|
file_path,
|
||||||
root_file_path,
|
root_file_path,
|
||||||
server_res: mergedServerRes,
|
server_res: serverRes,
|
||||||
})) || {};
|
})) || {};
|
||||||
|
|
||||||
if (!component) {
|
if (!component) {
|
||||||
@ -102,7 +67,7 @@ export default async function grabPageModules({
|
|||||||
|
|
||||||
return {
|
return {
|
||||||
component,
|
component,
|
||||||
serverRes: mergedServerRes,
|
serverRes,
|
||||||
module,
|
module,
|
||||||
root_module,
|
root_module,
|
||||||
};
|
};
|
||||||
|
|||||||
@ -278,11 +278,11 @@ export type BunextPageModuleMetadata = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
export type GrabPageComponentRes = {
|
export type GrabPageComponentRes = {
|
||||||
component: JSX.Element;
|
component?: JSX.Element;
|
||||||
serverRes?: BunextPageModuleServerReturn;
|
serverRes?: BunextPageModuleServerReturn;
|
||||||
routeParams?: BunxRouteParams;
|
routeParams?: BunxRouteParams;
|
||||||
bundledMap?: BundlerCTXMap;
|
bundledMap?: BundlerCTXMap;
|
||||||
module: BunextPageModule;
|
module?: BunextPageModule;
|
||||||
root_module?: BunextRootModule;
|
root_module?: BunextRootModule;
|
||||||
debug?: boolean;
|
debug?: boolean;
|
||||||
};
|
};
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user