next
Version:
The React Framework
85 lines (84 loc) • 2.13 kB
TypeScript
/**
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
import { webpack } from 'next/dist/compiled/webpack/webpack';
interface Options {
dev: boolean;
appDir: string;
experimentalInlineCss: boolean;
}
/**
* Webpack module id
*/
type ModuleId = string | number;
export type ManifestChunks = Array<string>;
export interface ManifestNode {
[moduleExport: string]: {
/**
* Webpack module id
*/
id: ModuleId;
/**
* Export name
*/
name: string;
/**
* Chunks for the module. JS and CSS.
*/
chunks: ManifestChunks;
/**
* If chunk contains async module
*/
async?: boolean;
};
}
export interface ClientReferenceManifestForRsc {
clientModules: ManifestNode;
rscModuleMapping: {
[moduleId: string]: ManifestNode;
};
edgeRscModuleMapping: {
[moduleId: string]: ManifestNode;
};
}
export type CssResource = InlinedCssFile | UninlinedCssFile;
interface InlinedCssFile {
path: string;
inlined: true;
content: string;
}
interface UninlinedCssFile {
path: string;
inlined: false;
}
export interface ClientReferenceManifest extends ClientReferenceManifestForRsc {
readonly moduleLoading: {
prefix: string;
crossOrigin: string | null;
};
ssrModuleMapping: {
[moduleId: string]: ManifestNode;
};
edgeSSRModuleMapping: {
[moduleId: string]: ManifestNode;
};
entryCSSFiles: {
[entry: string]: CssResource[];
};
entryJSFiles?: {
[entry: string]: string[];
};
}
export declare class ClientReferenceManifestPlugin {
dev: Options['dev'];
appDir: Options['appDir'];
appDirBase: string;
experimentalInlineCss: Options['experimentalInlineCss'];
constructor(options: Options);
apply(compiler: webpack.Compiler): void;
createAsset(compilation: webpack.Compilation, context: string): void;
}
export {};