This repository contains sources of external declarations for Kotlin/JS.
All libraries are available in the maven repository https://bintray.com/kotlin/js-externals/
with group id kotlin.js.externals
and artifact id kotlin-js-<library-name>
.
To use declarations from a library foo
, you need to add
this repository to your repository list for your build tool, and then add a dependency to kotlin-js-foo
.
Gradle:
repositories {
maven { url "https://kotlin.bintray.com/js-externals" }
}
dependencies {
compile "kotlin.js.externals:kotlin-js-foo:$foo_version"
}
Maven:
<repositories>
<repository>
<id>kotlin-js-externals</id>
<name>Kotlin/JS externals</name>
<url>https://kotlin.bintray.com/js-externals</url>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId>kotlin.js.externals</groupId>
<artifactId>kotlin-js-foo</artifactId>
<version>$foo_version</version>
</dependency>
</dependencies>
All libraries are available on npmjs.com under @kotlin-externals
scope with the original name.
To install declarations for the library foo
you must use @kotlin-externals/foo
:
npm install --save-dev @kotlin-externals/foo
For a JavaScript library of version X.Y.Z
, use an external declarations library with latest X.Y
version.
Sidenote:
This version scheme is required in order to:
- Obtain simple mapping to/from original library version.
- Have the ability to update external declarations (a version of external declarations library must have some part independent of a version of the original library).
- Not use pre-release versions by default (see https://docs.npmjs.com/misc/semver#prerelease-tags).
- Follow the three number Semver/NPM restriction.
- Report any issues you find in existing declarations.
- Or fix them and send a Pull Request.
- Request declarations that are missing.
- Or create them yourself and send a Pull Request.
Please feel free to ask any questions in #javascript channel of kotl.in/slack
To write declarations from scratch or to improve existing declarations you have to read about external modifier and JS interop annotations.
The simplest way to get external declarations is converting TypeScript declarations (d.ts) to Kotlin using ts2kt.