next
Version:
The React Framework
94 lines (93 loc) • 3.43 kB
TypeScript
/// <reference types="node" />
/// <reference types="node" />
/// <reference types="node" />
/// <reference types="node" />
import type { NextConfigComplete } from '../config-shared';
import type { CustomRoutes } from '../../lib/load-custom-routes';
import type { Duplex } from 'stream';
import type { Telemetry } from '../../telemetry/storage';
import { webpack } from 'next/dist/compiled/webpack/webpack';
import { IncomingMessage, ServerResponse } from 'http';
import { UrlObject } from 'url';
import getBaseWebpackConfig from '../../build/webpack-config';
import { __ApiPreviewProps } from '../api-utils';
import { UnwrapPromise } from '../../lib/coalesced-function';
import { RouteMatch } from '../future/route-matches/route-match';
export declare function renderScriptError(res: ServerResponse, error: Error, { verbose }?: {
verbose?: boolean | undefined;
}): Promise<{
finished: true | undefined;
}>;
export declare const matchNextPageBundleRequest: (pathname?: string | null | undefined, params?: any) => false | {
[key: string]: any;
};
export default class HotReloader {
private hasAmpEntrypoints;
private hasAppRouterEntrypoints;
private hasPagesRouterEntrypoints;
private dir;
private buildId;
private interceptors;
private pagesDir?;
private distDir;
private webpackHotMiddleware?;
private config;
hasServerComponents: boolean;
clientStats: webpack.Stats | null;
serverStats: webpack.Stats | null;
edgeServerStats: webpack.Stats | null;
private clientError;
private serverError;
private hmrServerError;
private serverPrevDocumentHash;
private serverChunkNames?;
private prevChunkNames?;
private onDemandEntries?;
private previewProps;
private watcher;
private rewrites;
private fallbackWatcher;
private hotReloaderSpan;
private pagesMapping;
private appDir?;
private telemetry;
private versionInfo;
private reloadAfterInvalidation;
multiCompiler?: webpack.MultiCompiler;
activeConfigs?: Array<UnwrapPromise<ReturnType<typeof getBaseWebpackConfig>>>;
constructor(dir: string, { config, pagesDir, distDir, buildId, previewProps, rewrites, appDir, telemetry, }: {
config: NextConfigComplete;
pagesDir?: string;
distDir: string;
buildId: string;
previewProps: __ApiPreviewProps;
rewrites: CustomRoutes['rewrites'];
appDir?: string;
telemetry: Telemetry;
});
run(req: IncomingMessage, res: ServerResponse, parsedUrl: UrlObject): Promise<{
finished?: true;
}>;
setHmrServerError(error: Error | null): void;
clearHmrServerError(): void;
refreshServerComponents(): Promise<void>;
onHMR(req: IncomingMessage, _socket: Duplex, head: Buffer): void;
private clean;
private getVersionInfo;
private getWebpackConfig;
buildFallbackError(): Promise<void>;
start(): Promise<void>;
invalidate({ reloadAfterInvalidation }?: {
reloadAfterInvalidation: boolean;
}): void | "" | undefined;
stop(): Promise<void>;
getCompilationErrors(page: string): Promise<any[]>;
send(action?: string | any, ...args: any[]): void;
ensurePage({ page, clientOnly, appPaths, match, isApp, }: {
page: string;
clientOnly: boolean;
appPaths?: string[] | null;
isApp?: boolean;
match?: RouteMatch;
}): Promise<void>;
}