StateFlow and SharedFlow in ViewModels
Collecting State and Shared Flows from ViewModels while respecting lifecycle of the collector views
Compose by example: BoxWithConstraints
A practical example of using BoxWithConstraints in Jetpack Compose to build responsive layouts
Slim down your Android components with LifecycleObserver
Learn to create custom LifecycleObserver components and inject them with Dagger/Hilt
Show BottomBar conditionally in Compose
Conditionally show BottomBar with bottom navigation in Jetpack Compose
Basic Auth with OkHttp and Retrofit
Basic Auth example using OkHttp, Retrofit, Dagger in a Kotlin project
Animation in Jetpack Compose
Foundational overview of Compose Animation APIs to help you choose most suitable API for your animation task.
data:image/s3,"s3://crabby-images/9ccdd/9ccdd735f3101412e2c983efe680c47caa397068" alt="Compose sample app: UI state with Flow, offline first"
Compose sample app: UI state with Flow, offline first
Sample repo implementing state using Flow, Offline First repository, unit tests using Turbine.
data:image/s3,"s3://crabby-images/3d14c/3d14cd9f5c43b0edc0aaf285a13a045dec444d76" alt="Test Coroutine Scheduler"
Test Coroutine Scheduler
Using TestCoroutineScheduler, a scheduler for coroutines used in tests, that provides the delay-skipping behavior.
Animating visibility vs alpha in Compose
Covers example when animateFloatAsState is what you need instead of AnimatedVisibility
data:image/s3,"s3://crabby-images/15484/154848f0a458b57f9729ee731054ebf804ec80dd" alt="Practical Compose Slot API example"
Practical Compose Slot API example
Learn how to manage screen sections using Slot API pattern in Compose
Lazy Grid layouts in Compose
Covers 3 ways to build lazy grid layouts using fixed, adaptive and custom configuration
data:image/s3,"s3://crabby-images/5232b/5232b503449a29b0b8ffea08e9124b55623b82f4" alt="Lazy layouts contentPadding"
Lazy layouts contentPadding
Controlling padding for first and last item in a lazy layout in Compose
Composable functions and return types
Exploring composable function characteristics and return types
data:image/s3,"s3://crabby-images/8b7d5/8b7d5db52071d7b21243621e64d391f9fd15ce29" alt="Compose phases and optimizations"
Compose phases and optimizations
Learn about Compose Phases and optimizing UI by controlling what Phases get executed when data in composable changes
Using MotionLayout in Compose
A demo of using MotionLayout with Jetpack Compose with motion scene set up as a JSON5
Making reusable composables using Generics
Using Java Generics to create reusable shared components in Compose
data:image/s3,"s3://crabby-images/041d9/041d973da381ba16d768d41ff23ada12ee988234" alt="Getting started with Canvas in Compose"
Getting started with Canvas in Compose
Explore DrawScope and create your first custom component using Canvas in Jetpack Compose
data:image/s3,"s3://crabby-images/c811e/c811ee0462821afdcb073eb9567e27dd38bbbed6" alt="Compose Row, Column and Scoped Modifiers"
Compose Row, Column and Scoped Modifiers
Explore the power of Row and Column composables and their respective RowScope and ColumnScope modifiers to layout child composables