Skip to content

A complete example about a multiplatform application using Kotlin and React

License

Notifications You must be signed in to change notification settings

jesty/kotlin-loves-react

Repository files navigation

Intro

This project shows how to setup a multi-platform application with Kotlin and React. This repository starts from: https://github.com/gbaldeck/react-js-jvm-kotlin-multiplatform, and it is extended writing some real examples. There are some interaction with a simple REST API built using Ktor.

The features that you can see in the files are:

  • App.kt and IndexComponent.kt: React Router setup and use.
  • AboutComponent.kt: js function, external class (AlertHelper.kt), expect/actual class (Greetings.kt) and jsStyle function.
  • MyMoviesComponent.kt: a simple ui that iterates over an array.
  • MyMoviesRemoteComponent.kt and Rpc.kt: a simple ui that iterates over an array from a REST API.
  • GithubComponent.kt: an example on how to use an existing javascript library in Kotlin.
  • HeaderComponent.kt: a React component

Kotlin/JS Module

First, run:

npm install

Then the Gradle task:

gradlew runDceJsKotlin

Then for webpack dev-server do:

npm run serve

Once it's running you can view it in the browser by going to localhost:9000

For production build do:

npm run prod-build

While the dev server is running you can run the runDceJsKotlin gradle task and it will automatically pick up the emitted Kotlin/JS files.

To automatically launch the runDceJsKotlin gradle task when the code changes, do:

gradlew runDceJsKotlin -t

The builds include JS source maps for the Kotlin/JS files as well. So you can setup a run configuration in IntelliJ to debug in the IDE or you can debug in your favorite browser's dev tools, whichever you prefer.

About

A complete example about a multiplatform application using Kotlin and React

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published