Skip to content

Samples of Kotlin multiplatform projects multi-module architecture

Notifications You must be signed in to change notification settings

VasilyRylov/architecture-samples

Repository files navigation

Compose Multiplatform Application architecture samples

Frameworks and libraries

Key concepts

  • FSM based MVI and MVVM+
  • Navigation is abstracted from Decompose
  • Decompose components are separated into own modules
  • Business logic and UI modules do not depend on Component modules
  • Multi-module DI, each module can use its own DI framework
  • Component modules are only responsible for routers implementation, DI setup and lifecycle.
  • Features are allocated into separate groups of modules, each of which is divided into modules with business logic, UI and components with a life cycle.

Module Graph

%%{
  init: {
    'theme': 'neutral'
  }
}%%

graph TB
  subgraph :common
    :common:common-component["common-component"]
    :common:common-domain["common-domain"]
    :common:common-ui["common-ui"]
    :common:common-data["common-data"]
  end
  subgraph :data
    :data:preferences["preferences"]
    :data:database["database"]
  end
  subgraph :feature:auth
    :feature:auth:auth-ui["auth-ui"]
    :feature:auth:auth-domain["auth-domain"]
    :feature:auth:auth-component["auth-component"]
    :feature:auth:auth-data["auth-data"]
  end
  subgraph :feature:root
    :feature:root:root-domain["root-domain"]
    :feature:root:root-ui["root-ui"]
    :feature:root:root-component["root-component"]
  end
  subgraph :feature:todo
    :feature:todo:todo-component["todo-component"]
    :feature:todo:todo-ui["todo-ui"]
    :feature:todo:todo-domain["todo-domain"]
    :feature:todo:todo-data["todo-data"]
  end
  :feature:todo:todo-component --> :feature:todo:todo-ui
  :feature:todo:todo-component --> :feature:todo:todo-domain
  :feature:todo:todo-component --> :feature:todo:todo-data
  :feature:todo:todo-component --> :common:common-component
  :feature:todo:todo-component --> :common:common-domain
  :feature:todo:todo-component --> :common:common-ui
  :feature:todo:todo-component --> :common:common-data
  :feature:auth:auth-ui --> :common:common-ui
  :feature:auth:auth-ui --> :feature:auth:auth-domain
  :feature:root:root-domain --> :common:common-domain
  :feature:root:root-domain --> :feature:auth:auth-domain
  :feature:root:root-domain --> :feature:todo:todo-domain
  :common:common-component --> :common:common-ui
  :feature:todo:todo-ui --> :common:common-ui
  :feature:todo:todo-ui --> :common:common-domain
  :feature:todo:todo-ui --> :feature:todo:todo-domain
  :feature:root:root-ui --> :common:common-ui
  :feature:root:root-ui --> :feature:root:root-domain
  :data:preferences --> :common:common-domain
  :composeApp --> :feature:root:root-component
  :composeApp --> :common:common-ui
  :composeApp --> :common:common-data
  :feature:auth:auth-component --> :feature:auth:auth-ui
  :feature:auth:auth-component --> :feature:auth:auth-domain
  :feature:auth:auth-component --> :feature:auth:auth-data
  :feature:auth:auth-component --> :common:common-component
  :feature:auth:auth-component --> :common:common-ui
  :feature:auth:auth-component --> :common:common-domain
  :feature:auth:auth-component --> :common:common-data
  :feature:auth:auth-data --> :feature:auth:auth-domain
  :feature:auth:auth-data --> :common:common-domain
  :feature:auth:auth-data --> :common:common-data
  :common:common-data --> :data:preferences
  :common:common-data --> :data:database
  :common:common-data --> :common:common-domain
  :feature:todo:todo-data --> :feature:todo:todo-domain
  :feature:todo:todo-data --> :common:common-domain
  :feature:todo:todo-data --> :common:common-data
  :feature:todo:todo-domain --> :common:common-domain
  :feature:root:root-component --> :feature:root:root-ui
  :feature:root:root-component --> :feature:root:root-domain
  :feature:root:root-component --> :feature:auth:auth-component
  :feature:root:root-component --> :feature:auth:auth-domain
  :feature:root:root-component --> :feature:todo:todo-component
  :feature:root:root-component --> :feature:todo:todo-domain
  :feature:root:root-component --> :common:common-component
  :feature:root:root-component --> :common:common-domain
  :feature:root:root-component --> :common:common-ui
  :feature:root:root-component --> :common:common-data
  :feature:auth:auth-domain --> :common:common-domain
Loading

Variants and ready status

Sample Description Ready status
fsm mvi, mvvm plus, kotlin-inject Fsm-based MVI(root and auth features), MVVM+(todo feature), kotlin-inject DI Ready
fsm mvi, mvvm plus, Koin Fsm-based MVI(root and auth features), MVVM+(todo feature), Koin DI Ready

Root module FSM

graph

Auth module FSM

graph

Screenshots

Login Registration ConfirmationRequested
Add new todo Todo list Todo details

Before running!

  • check your system with KDoctor
  • install JDK 21 or higher on your machine

Android

To run the application on android device/emulator:

  • open project in Android Studio and run imported android run configuration

Desktop

Run the desktop application: ./gradlew :composeApp:run

iOS

To run the application on iPhone device/simulator:

  • Open iosApp/iosApp.xcproject in Xcode and run standard configuration
  • Or use Kotlin Multiplatform Mobile plugin for Android Studio Run iOS simulator UI tests: ./gradlew :composeApp:iosSimulatorArm64Test