• Stars
    star
    2,899
  • Rank 15,655 (Top 0.4 %)
  • Language
    Kotlin
  • License
    Apache License 2.0
  • Created almost 5 years ago
  • Updated 4 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Kotlin Multiplatform sample with SwiftUI, Jetpack Compose, Compose for Wear, Compose for Desktop, and Compose for Web clients along with Ktor backend.

PeopleInSpace

kotlin-version1

Kotlin Multiplatform project with SwiftUI, Jetpack Compose, Compose for Wear OS, Compose for Desktop, Compose for Web, and Kotlin/JS + React clients along with Ktor backend. Currently running on

  • Android (Jetpack Compose)
  • Android App Widget (Compose based Glance API - contributed by https://github.com/yschimke)
  • Wear OS (Compose for Wear OS - primarily developed by https://github.com/yschimke)
  • iOS (SwiftUI)
  • iOS (Compose for iOS - experimental support!)
  • iOS App Widget (SwiftUI)
  • watchOS (SwiftUI) (contributed by https://github.com/nealsanche)
  • macOS (SwiftUI)
  • Desktop (Compose for Desktop)
  • Web (Compose for Web - JS based)
  • Web (Compose for Web - Wasm based)
  • Web (Kotlin/JS + React Wrapper) (contributed by https://github.com/PatilShreyas)
  • JVM (small Ktor back end service + Main.kt in common module)

It makes use of Open Notify PeopleInSpace API to show list of people currently in space and also the position of the International Space Station (inspired by https://kousenit.org/2019/12/19/a-few-astronomical-examples-in-kotlin/)!

The project is included as sample in the official Kotlin Multiplatform Mobile docs and also the Google Dev Library

Related posts:

Note that this repository very much errs on the side of minimalism to help more clearly illustrate key moving parts of a Kotlin Multiplatform project and also to hopefully help someone just starting to explore KMP to get up and running for first time (and is of course primarily focused on use of Jetpack Compose and SwiftUI). If you're at the stage of moving beyond this then I'd definitely recommend checking out KaMPKit from Touchlab. I also have the following samples that demonstrate the use of a variety of Kotlin Multiplatform libraries (and also use Jetpack Compose and SwiftUI).

Building

You need to use at least Android Studio Flamingo (note: Java 17 is now the minimum version required). Requires XCode 13.2 or later (due to use of new Swift 5.5 concurrency APIs).

Open `PeopleInSpaceSwiftUI' for iOS/watchOS/macOS projects.

To exercise (React based) web client run ./gradlew :web:browserDevelopmentRun.

To run backend you can either run ./gradlew :backend:run or run Server.kt directly from Android Studio. After doing that you should then for example be able to open http://localhost:9090/astros_local.json in a browser.

Compose for Web client (JS)

The Compose for Web client resides in the compose-web module and can be run by invoking ./gradlew :compose-web:jsBrowserDevelopmentRun

Compose for Web client (Wasm)

Similarly for Kotlin/Wasm based version ./gradlew :compose-web-wasm:wasmBrowserDevelopmentRun

Compose for Desktop client

This client is available in compose-desktop module and can be run using ./gradlew :compose-desktop:run. Note that you need to use appropriate version of JVM when running (works for example with Java 11)

Compose for iOS client

Can be run using for example ./gradlew :compose-ios:iosDeployIPhone13ProDebug

Backend code

Have tested this out in Google App Engine deployment. Using shadowJar plugin to create an "uber" jar and then deploying it as shown below. Should be possible to deploy this jar to other services as well.

./gradlew :backend:shadowJar
gcloud app deploy backend/build/libs/backend-all.jar cloud app deploy backend/build/libs/backend-all.jar --appyaml=backend/src/main/appengine/app.yaml

GraphQL backend

There's a GraphQL module (graphql-server) which can be run locally using ./gradlew :graphql-server:bootRun with "playground" then available at http://localhost:8080/playground

Screenshots

iOS (SwiftUI)
Screenshot 2021-02-27 at 12 09 02

Android (Jetpack Compose)

Screenshot 2022-11-11 at 21 24 59

watchOS (SwiftUI)
watchOS Screenshot 1 watch0S Screenshot 2

Wear OS (Wear Compose)
Wear Compose Screenshot 1 Wear Compose Screenshot 2 Wear Compose Screenshot 3

macOS (SwiftUI)
Screenshot 2021-06-01 at 20 02 31

Compose for Desktop
Screenshot 2021-10-01 at 16 45 06

Compose for Web
Compose for Web Screenshot

Web App (Kotlin/JS + React)
Screenshot 2021-06-06 at 23 50 00

Languages, libraries and tools used

More Repositories

1

Confetti

KMP GraphQL based conference project with Jetpack Compose Android, Compose for Wear, Compose Multiplatform and SwiftUI iOS clients along with GraphQL backend.
Kotlin
763
star
2

BikeShare

SwiftUI, Jetpack Compose, and Compose for Desktop based Kotlin Multiplatform project (using CityBikes API http://api.citybik.es/v2/). Uses Realm for local persistence
Kotlin
665
star
3

GalwayBus

Galway Bus Kotlin Multiplatform project using Jetpack Compose and SwiftUI
Kotlin
524
star
4

FantasyPremierLeague

Fantasy Premier League Kotlin Multiplatform sample using Jetpack Compose, Compose for Desktop and SwiftUI (and Room for local persistence)
Kotlin
468
star
5

MortyComposeKMM

GraphQL based Jetpack Compose and SwiftUI Kotlin Multiplatform project (using https://rickandmortyapi.com/graphql)
Kotlin
367
star
6

StarWars

Minimal GraphQL based Jetpack Compose, Wear Compose and SwiftUI Kotlin Multiplatform sample (using StarWars endpoint - https://graphql.org/swapi-graphql)
Kotlin
202
star
7

GeminiKMP

Kotlin Multiplatform sample that uses Gemini Generative AI APIs. Runs on Android, iOS, Desktop and Wasm based Compose for Web.
Kotlin
189
star
8

ClimateTraceKMP

Kotlin/Compose Multiplatform project to show climate related emission data from https://climatetrace.org/data.
Kotlin
156
star
9

WordMasterKMP

Kotlin Multiplatform sample with SwiftUI and Compose (Desktop and Android) clients. Heavily inspired by Wordle game.
Kotlin
63
star
10

peopleinspace-lib

Example Kotlin Multiplatform library that provides API to retrieve list of people in space and current position of International Space Station.
Kotlin
10
star
11

ConfettiSwiftUISPM

Minimal version of Confetti i0S clients that consumes shared KMM code as Swift Package
Swift
7
star
12

PeopleInSpaceGraphQLServer

Cloud Run based GraphQL backend for PeopleInSpace supporting queries and subscriptions
Kotlin
5
star
13

PeopleInSpacePackage

Swift Package for https://github.com/joreilly/PeopleInSpace.
Objective-C
5
star
14

GalwayBusAndroid

Android Client that shows Galway Bus Info (deprecated!)
Java
4
star
15

BikeShareSwiftPackage

Objective-C
4
star
16

joreilly

3
star
17

ZeoRawTest

Ruby code to test out Zeo Raw Data Library
2
star
18

google-actions-galway-bus

JavaScript
1
star