GitPedia

Kmp viewmodel

🔆 Kotlin Multiplatform ViewModel. Kotlin Multiplatform MVVM. Common/Shared ViewModel in Kotlin Multiplatform - A Kotlin Multiplatform library that provides shared MVVM for UI applications. Components are lifecycle-aware on Android. Supports Android Parcelable, Kotlin Parcelize, AndroidX SavedStateHandle for restoring state after process death.

From hoc081098·Updated June 10, 2026·View on GitHub·
·Archived

Common/ Shared ViewModel in **Kotlin Multiplatform** - A Kotlin Multiplatform library that provides shared MVVM for UI applications. Components are **lifecycle-aware on Android**. Supports **Android Parcelable**, **Kotlin Parcelize**, **AndroidX SavedStateHandle** for restoring state after process death. Easy interoperability with **Swift/Objective-C** and **SwiftUI**. Supports **Compose Multiplatform** Framework (Android, Desktop, Web, iOS, macOS, tvOS, watchOS). The project is written primarily in Kotlin, distributed under the MIT License license, first published in 2023. Key topics include: kmm, kmm-example, kmm-library, kmm-mvvm, kmm-sample.

Latest release: 0.8.0
June 9, 2024View Changelog →

kmp-viewmodel 🔆

Kotlin Multiplatform ViewModel - Kotlin Multiplatform MVVM - Compose Multiplatform ViewModel

Common/ Shared ViewModel in Kotlin Multiplatform - A Kotlin Multiplatform library that provides shared MVVM
for UI applications.
Components are lifecycle-aware on Android.
Supports Android Parcelable, Kotlin Parcelize, AndroidX SavedStateHandle for restoring state after process death.
Easy interoperability with Swift/Objective-C and SwiftUI.
Supports Compose Multiplatform Framework (Android, Desktop, Web, iOS, macOS, tvOS, watchOS).

The ViewModel class is a business logic or screen level state holder.
It exposes state to the UI and encapsulates related business logic.
Its principal advantage is that it caches state and persists it through configuration changes (on Android).

kmp-viewmodel and Navigation for JetBrains Compose Multiplatform 👉 https://github.com/hoc081098/solivagant

maven-central
<img src="https://img.shields.io/nexus/snapshots/https/s01.oss.sonatype.org/io.github.hoc081098/kmp-viewmodel.svg?label=latest%20snapshot"/>
codecov
Build and publish snapshot
Build sample
Publish Release
License: MIT
Kotlin version
KotlinX Coroutines version
Compose Multiplatform version
Hits
badge
badge
badge
badge
badge
badge
badge
badge
badge

<p align="center"> <img src="https://github.com/hoc081098/kmp-viewmodel/raw/master/logo.png" width="400"> </p>

Author: Petrus Nguyễn Thái Học

Liked some of my work? Buy me a coffee (or more likely a beer)

<a href="https://www.buymeacoffee.com/hoc081098" target="_blank"><img src="https://cdn.buymeacoffee.com/buttons/v2/default-blue.png" alt="Buy Me A Coffee" height=64></a>

Supported targets

  • android.
  • jvm (must add kotlinx-coroutines-swing/kotlinx-coroutines-javafx to your dependencies to
    make sure Dispatchers.Main available).

[!NOTE]
If you are targeting Desktop and:

  • not using JetBrains Compose Multiplatform, you should provide the dependency org.jetbrains.kotlinx:kotlinx-coroutines-swing or org.jetbrains.kotlinx:kotlinx-coroutines-javafx.
  • using JetBrains Compose Multiplatform, you should provide org.jetbrains.kotlinx:kotlinx-coroutines-swing.

Because the ViewModel.viewModelScope depends on Dispatchers.Main provided by that libraries on Desktop.

  • js (IR).
  • wasmJs.
  • Darwin targets:
    • iosArm64, iosX64, iosSimulatorArm64.
    • watchosArm32, watchosArm64, watchosX64, watchosSimulatorArm64.
    • tvosX64, tvosSimulatorArm64, tvosArm64.
    • macosX64, macosArm64.

Docs

0.x release docs: https://hoc081098.github.io/kmp-viewmodel/docs/0.x

Snapshot docs: https://hoc081098.github.io/kmp-viewmodel/docs/latest

Getting started

1. kmp-viewmodel library

For more information check out the docs.

2. kmp-viewmodel-savedstate library

For more information check out the docs.

3. kmp-viewmodel and Swift interoperability

For more information check out the docs.

4. kmp-viewmodel-compose library

For more information check out the docs.

5. kmp-viewmodel-koin-compose library

For more information check out the docs.

6. kmp-viewmodel-koject-compose library

For more information check out the docs.

7. kmp-viewmodel and Navigation for JetBrains Compose Multiplatform.

For more information check out https://github.com/hoc081098/solivagant library.

Samples

For more information check out the docs.

  • KMM sample: shares business logic and ViewHolders, using Jetpack Compose for Android and SwiftUi for iOS.
  • Compose Multiplatform Koin sample: shares ViewModels and integrates with Navigation in Compose Multiplatform. It uses Koin for DI.
  • Compose Multiplatform Koject sample: shares ViewModels and integrates with Navigation in Compose Multiplatform. It uses Koject for DI.
  • Compose Multiplatform KmpViewModel KMM Unsplash Sample: A KMP template of the Unsplash App using Compose multiplatform for Android, Desktop, iOS. Share everything including data, domain, presentation, and UI.
  • 🍭 GithubSearchKMM: Github Repos Search KMM for Android and iOS. Kotlin Multiplatform Mobile using Jetpack Compose, SwiftUI, FlowRedux, Coroutines Flow, Dagger Hilt, Koin Dependency Injection, shared KMP ViewModel, Clean Architecture.

Roadmap

  • support SaveStateHandle (since 0.2.0).
  • add extensions for Flow/StateFlow, to use the ViewModel easily on ios/macOS/tvOS/watchOS platforms
    (since 0.3.0).
  • support Compose Multiplatform Framework (since 0.5.0).
  • support Koin integration with ViewModel and JetBrains Compose Multiplatform (since 0.6.2).

License

license
MIT License Copyright (c) 2023-2024 Petrus Nguyễn Thái Học

Contributors

Showing top 3 contributors by commit count.

View all contributors on GitHub →

This article is auto-generated from hoc081098/kmp-viewmodel via the GitHub API.Last fetched: 6/19/2026