-
Notifications
You must be signed in to change notification settings - Fork 0
/
dynamic.d.ts
36 lines (36 loc) · 1.59 KB
/
dynamic.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
import React from 'react';
export declare type LoaderComponent<P = {}> = Promise<React.ComponentType<P> | {
default: React.ComponentType<P>;
}>;
export declare type Loader<P = {}> = (() => LoaderComponent<P>) | LoaderComponent<P>;
export declare type LoaderMap = {
[mdule: string]: () => Loader<any>;
};
export declare type LoadableGeneratedOptions = {
webpack?(): any;
modules?(): LoaderMap;
};
export declare type LoadableBaseOptions<P = {}> = LoadableGeneratedOptions & {
loading?: ({ error, isLoading, pastDelay, }: {
error?: Error | null;
isLoading?: boolean;
pastDelay?: boolean;
timedOut?: boolean;
}) => JSX.Element | null;
loader?: Loader<P> | LoaderMap;
loadableGenerated?: LoadableGeneratedOptions;
ssr?: boolean;
};
export declare type LoadableOptions<P = {}> = LoadableBaseOptions<P> & {
render?(loader: any, props: any): JSX.Element;
};
export declare type DynamicOptions<P = {}> = LoadableBaseOptions<P> & {
/**
* @deprecated the modules option has been planned for removal
*/
render?(props: P, loaded: any): JSX.Element;
};
export declare type LoadableFn<P = {}> = (opts: LoadableOptions<P>) => React.ComponentType<P>;
export declare type LoadableComponent<P = {}> = React.ComponentType<P>;
export declare function noSSR<P = {}>(LoadableInitializer: LoadableFn<P>, loadableOptions: LoadableOptions<P>): React.ComponentClass<P, any> | React.FunctionComponent<P> | (() => JSX.Element);
export default function dynamic<P = {}>(dynamicOptions: DynamicOptions<P> | Loader<P>, options?: DynamicOptions<P>): React.ComponentType<P>;