55 lines
2.7 KiB
TypeScript
55 lines
2.7 KiB
TypeScript
import React, { ReactNode } from 'react';
|
|
import type { DocumentContext, DocumentInitialProps, DocumentProps } from '../shared/lib/utils';
|
|
import type { HtmlProps } from '../shared/lib/html-context.shared-runtime';
|
|
export { DocumentContext, DocumentInitialProps, DocumentProps };
|
|
export type OriginProps = {
|
|
nonce?: string;
|
|
crossOrigin?: 'anonymous' | 'use-credentials' | '' | undefined;
|
|
children?: React.ReactNode;
|
|
};
|
|
type DocumentFiles = {
|
|
sharedFiles: readonly string[];
|
|
pageFiles: readonly string[];
|
|
allFiles: readonly string[];
|
|
};
|
|
type HeadHTMLProps = React.DetailedHTMLProps<React.HTMLAttributes<HTMLHeadElement>, HTMLHeadElement>;
|
|
type HeadProps = OriginProps & HeadHTMLProps;
|
|
export declare class Head extends React.Component<HeadProps> {
|
|
static contextType: React.Context<HtmlProps | undefined>;
|
|
context: HtmlProps;
|
|
getCssLinks(files: DocumentFiles): JSX.Element[] | null;
|
|
getPreloadDynamicChunks(): (React.JSX.Element | null)[];
|
|
getPreloadMainLinks(files: DocumentFiles): JSX.Element[] | null;
|
|
getBeforeInteractiveInlineScripts(): React.JSX.Element[];
|
|
getDynamicChunks(files: DocumentFiles): (React.JSX.Element | null)[];
|
|
getPreNextScripts(): React.JSX.Element;
|
|
getScripts(files: DocumentFiles): React.JSX.Element[];
|
|
getPolyfillScripts(): React.JSX.Element[];
|
|
makeStylesheetInert(node: ReactNode[]): ReactNode[];
|
|
render(): React.JSX.Element;
|
|
}
|
|
export declare class NextScript extends React.Component<OriginProps> {
|
|
static contextType: React.Context<HtmlProps | undefined>;
|
|
context: HtmlProps;
|
|
getDynamicChunks(files: DocumentFiles): (React.JSX.Element | null)[];
|
|
getPreNextScripts(): React.JSX.Element;
|
|
getScripts(files: DocumentFiles): React.JSX.Element[];
|
|
getPolyfillScripts(): React.JSX.Element[];
|
|
static getInlineScriptSource(context: Readonly<HtmlProps>): string;
|
|
render(): React.JSX.Element | null;
|
|
}
|
|
export declare function Html(props: React.DetailedHTMLProps<React.HtmlHTMLAttributes<HTMLHtmlElement>, HTMLHtmlElement>): React.JSX.Element;
|
|
export declare function Main(): React.JSX.Element;
|
|
/**
|
|
* `Document` component handles the initial `document` markup and renders only on the server side.
|
|
* Commonly used for implementing server side rendering for `css-in-js` libraries.
|
|
*/
|
|
export default class Document<P = {}> extends React.Component<DocumentProps & P> {
|
|
/**
|
|
* `getInitialProps` hook returns the context object with the addition of `renderPage`.
|
|
* `renderPage` callback executes `React` rendering logic synchronously to support server-rendering wrappers
|
|
*/
|
|
static getInitialProps(ctx: DocumentContext): Promise<DocumentInitialProps>;
|
|
render(): React.JSX.Element;
|
|
}
|