Harry potter App Built with Jetpack Compose using HP-API


Harry potter is Built with Jetpack Compose using HP-API. The app follows mvvm clean architecture design pattern. The app also supports material you


  • Light Mode


  • Dark Mode


Tech Stack

  • Kotlin – Kotlin is a cross-platform, statically typed, general-purpose programming language with type inference. Kotlin is designed to interoperate fully with Java, and the JVM version of Kotlin’s standard library depends on the Java Class Library, but type inference allows its syntax to be more concise
  • Jetpack Components:
    • Jetpack Compose – Android’s modern toolkit for building native UI. It simplifies and accelerates UI development on Android
    • View Model– store and manage UI-related data in a lifecycle conscious way.
    • Lifecycle – Perform actions in response to a change in the lifecycle status of another component, such as activities and fragments.
    • Android KTX – Android KTX is a set of Kotlin extensions that are included with Android Jetpack and other Android libraries. KTX extensions provide concise, idiomatic Kotlin to Jetpack, Android platform, and other APIs.
  • Retrofit– A type-safe HTTP client for Android and Java.
  • Dagger-Hilt– a dependency injection library for Android that reduces the boilerplate of doing manual dependency injection in your project
  • Coroutines – a concurrency design pattern that you can use on Android to simplify code that executes asynchronously
  • Flow– In coroutines, a flow is a type that can emit multiple values sequentially, as opposed to suspend functions that return only a single value.
  • Coil – Image Loader library.
  • Lottie – Lottie is a mobile library for Android and iOS that parses Adobe After Effects animations exported as json with Bodymovin and renders them natively on mobile!
  • Mock web server – A scriptable web server for testing HTTP clients.

Data Source

This application fetches its data from the HP-API.


View Github

Leave a Reply

Your email address will not be published. Required fields are marked *