2 * Custom Type Definitions
3 * When including 3rd party modules you also need to include the type definition for the module
4 * if they don't provide one within the module. You can try to install it with @types
6 npm install @types/node
7 npm install @types/lodash
9 * If you can't find the type definition in the registry we can make an ambient/global definition in
10 * this file for now. For example
12 declare module 'my-module' {
13 export function doesSomething(value: string): string;
16 * If you are using a CommonJS module that is using module.exports then you will have to write your
17 * types using export = yourObjectOrFunction with a namespace above it
18 * notice how we have to create a namespace that is equal to the function we're
19 * assigning the export to
21 declare module 'jwt-decode' {
22 function jwtDecode(token: string): any;
23 namespace jwtDecode {}
28 * If you're prototying and you will fix the types later you can also declare it as type any
31 declare var assert: any;
36 * If you're importing a module that uses Node.js modules which are CommonJS you need to import as
37 * in the files such as main.browser.ts or any file within app/
40 import * as _ from 'lodash'
42 * You can include your type definitions in this file until you create one for the @types
46 // support NodeJS modules without type definitions
50 // for legacy tslint etc to understand rename 'modern-lru' with your package
51 // then comment out `declare module '*';`. For each new module copy/paste
52 // this method of creating an `any` module type definition
53 declare module 'modern-lru' {
59 // Extra variables that live on Global that will be replaced by webpack DefinePlugin
60 declare var ENV: string;
61 declare var API_URL: string;
62 declare var HMR: boolean;
63 declare var System: SystemJS;
66 import: (path?: string) => Promise<any>;
69 interface GlobalEnvironment {
77 interface Es6PromiseLoader {
78 (id: string): (exportName?: string) => Promise<any>;
81 type FactoryEs6PromiseLoader = () => Es6PromiseLoader;
82 type FactoryPromise = () => Promise<any>;
85 [component: string]: Es6PromiseLoader |
87 FactoryEs6PromiseLoader |
91 type IdleCallbacks = Es6PromiseLoader |
93 FactoryEs6PromiseLoader |
96 interface WebpackModule {
100 accept(dependencies?: string | string[], callback?: (updatedDependencies?: any) => void): void;
101 decline(deps?: any | string | string[]): void;
102 dispose(callback?: (data?: any) => void): void;
103 addDisposeHandler(callback?: (data?: any) => void): void;
104 removeDisposeHandler(callback?: (data?: any) => void): void;
105 check(autoApply?: any, callback?: (err?: Error, outdatedModules?: any[]) => void): void;
106 apply(options?: any, callback?: (err?: Error, outdatedModules?: any[]) => void): void;
107 status(callback?: (status?: string) => void): void | string;
108 removeStatusHandler(callback?: (status?: string) => void): void;
112 interface WebpackRequire {
114 (paths: string[], callback: (...modules: any[]) => void): void;
115 ensure(ids: string[], callback: (req: WebpackRequire) => void, chunkName?: string): void;
116 context(directory: string, useSubDirectories?: boolean, regExp?: RegExp): WebpackContext;
119 interface WebpackContext extends WebpackRequire {
123 interface ErrorStackTraceLimit {
124 stackTraceLimit: number;
128 interface NodeRequire extends WebpackRequire {}
129 interface ErrorConstructor extends ErrorStackTraceLimit {}
130 interface NodeRequireFunction extends Es6PromiseLoader {}
131 interface NodeModule extends WebpackModule {}
132 interface Global extends GlobalEnvironment {}