There are a number of kinds of source package which you may write typings for:
-
Packages that, when loaded, extend the global scope environment with a number of new functions / variables / classes etc. An example is mocha which has an global type definition and is listed in the Typings Registry under env.
-
Packages that should be loaded using a script tag. An example is knockout which has this global type definition and is listed in the Typings Registry under global.
-
Packages that should be loaded with a CommonJs / NodeJs compatible loader such as npm, browserify, webpack etc. An example is knockout on npm which has an external module type definition and is listed in the Typings Registry under npm)
-
Packages that are written in ES6+
-
Packages that are written in TypeScript and compiled to JavaScript with declaration
.d.ts
files (eg globalize-so-what-cha-want)
For 1 and 2, you would create an global type definition.
For 3, you would create an external module type definition using export =
.
For 4, you would create an external module type definition using ES6 module syntax (default export and named export).
For 5, there should be no need to write a type definition. The declaration files included in the package should be automatically detected and used by the TypeScript compiler upon consumption of the package.
For cases 1-4, here are some examples you can use as a model when writing your typings:
// ABC.d.ts
declare namespace ABC {
export function foo(): void;
}
// Consumer.ts
ABC.foo();
Exposing a single function.
declare function domready (...): any;
export = domready
Function with overloads.
declare function xtend <A> (a: A): A;
declare function xtend <A, B> (a: A, b: B): A & B;
export = xtend;
Exposing a collection of utility functions and classes.
declare namespace JsDiff {
class Diff {}
function diffChars(): any;
}
export = JsDiff;
Exposing a function, with utility methods.
declare function tape (): any;
declare namespace tape {
export function skip (): any;
}
export = tape;
declare class Promise <R> {
static resolve(): Promise<void>;
}
declare namespace Promise {
export interface SpreadOption {}
export function setScheduler (): any;
}
export = Promise;
Export directly using ES6 semantics without a module or namespace.
export function valid(): any;
export class SemVer {}