The registry of type definitions for TypeScript.
- Fork the project and run
npm install
- Write a typings definition and upload to GitHub - here's an example using debug
- Use semver to specify the minimum version the typing is valid for - here's debug again
- Run
npm test
to check that the registry is valid, and make a pull request - Once the pull request is merged, it is used as the canonical reference -
typings install debug
An up-to-date list of typings requests are labelled in the registry.
- Initialize a new repository (usually
typed-<package name>
to differentiate from your other projects) - Create a
typings.json
file, setmain
(and other valid options) - Make sure there's a license with your work
- A README can help explain what people are looking at when they land on your repo
The registry uses subdirectories to denote "sources". These sources are essentially mappings to package managers, and contain either ambient or external typings (depending on the "source").
/<source>/<name>.json
Where "source" is one of:
- npm for NPM dependencies (external)
- github for Duo, JSPM, etc. that use GitHub as the registry (external)
- bower for Bower dependencies (external)
- common for "standard" JS libraries without a "source" (external)
- shared for shared library functionality (external)
- lib for shared environment functionality (ambient)
- env for programming environment typings (ambient)
- global for global libraries (ambient)
And "name" is the name of the package from the source. For GitHub and scoped NPM packages, it's valid to make a folder such as @example/entry.json
. The schema for package files is described using JSON schema in schema.json
.
For typings issues, questions or general help, you can always open an issue in the discussions repo. To add an entry to the registry, please open a pull request with the change.