Navigation In Multi-Module Android Apps - Why You're Doing It Wrong!

Поделиться
HTML-код
  • Опубликовано: 27 ноя 2024

Комментарии • 44

  • @hovseparakelyan7655
    @hovseparakelyan7655 10 дней назад +2

    Great video!
    I noticed that when working with deeply nested composable functions, managing navigation through lambdas can become cumbersome.
    To address this, I implemented a modular Navigator pattern for each feature module. Here's how it works:
    1. Each feature module has its own Navigator (injected via DI) that emits navigation actions using a Channel or StateFlow.
    2. The feature module's root composable listens to the navigator and communicates with the main app (e.g., MainActivity) via a callback.
    3. Nested composables can directly trigger navigation events (e.g., navigator.event(NavAction.Back)), avoiding the need to pass lambdas all the way back to the root.
    The key benefit is that this pattern allows me to keep my feature modules completely independent of the app's NavController, as the Navigator is part of the submodule itself. This makes the modules reusable, decoupled, and easy to test.
    Let me know what you think, and thanks for sharing your insights in this video!

  • @StreetsOfBoston
    @StreetsOfBoston 28 дней назад +5

    Makes absolute sense :)
    If you have separate (and uncoupled!) features, using Dependency Inversion for navigation (and any other (shared) dependencies they may rely on) is the way to go!

  • @yashtalreja1946
    @yashtalreja1946 26 дней назад +6

    sir currently i am watching your jetpack compose playlist and i feel its very structural and very understanding but i have one request for you is that i want you to create a playlist on creating projects like E-commerce app ,Food ordering app , Cab booking etc by using kotlin and jetpack compose ,Firebase which will help us all in learning android app developer in efficient way and project based learning

  • @RanbirSingh-dl9co
    @RanbirSingh-dl9co 10 дней назад +1

    This approach works well for two to three screens per module, but as the number of screens grows, Compose Navigation might not support maintainable code. The use of lambda functions increases, and writing all the screens in the home screen will cause issues. You might consider creating feature modules for navigation control extensions and passing lambdas to those, or handling everything in the main screen. Either way, it can lead to complications.
    I recommend using Voyager, where you can access a local Navigator object that is independent of the main screen or any module

  • @fabiovokrri517
    @fabiovokrri517 28 дней назад +8

    That's exactly how the documentation tells you to develop navigation

  • @TheMikkelet
    @TheMikkelet 28 дней назад +2

    multi module is great in theory, but usually end up with giant core module (essentially an app in it self) and a few, small feature modules - too small to get benefit from compiler... mosty multimodule is good for data layer, like remote and/or local that you can use in any app your need

  •  26 дней назад

    Thanks to share this point of view.
    It makes absolute sense.

  • @ngapps
    @ngapps 28 дней назад +5

    The same as shown in Now in Android google sample app

  • @Tomas-g2j4f
    @Tomas-g2j4f 27 дней назад +2

    you should have feature level navigation files to make the navhost more readable this approach won't work if you have 50 screens

  • @warTag68
    @warTag68 28 дней назад

    Golden content as always!

  • @jakubmyka1240
    @jakubmyka1240 26 дней назад

    What's your Android Studio theme? It is really nice, is it possible to download it somewhere?

  • @unknownBoy85lover
    @unknownBoy85lover 28 дней назад

    A worthy video thank you sir ❤

  • @shreyassathya374
    @shreyassathya374 28 дней назад

    Great informative video on multi module,
    Is it possible to please make a video on Event Bus, and use case with a sample app,
    Thanks in advance.

  • @grossadmiralthrawn8769
    @grossadmiralthrawn8769 27 дней назад

    Interesting and good video.

  • @TheFlexath
    @TheFlexath 28 дней назад

    thanks Philipp

  • @AndrewDChristie
    @AndrewDChristie 28 дней назад

    Thanks!

  • @amalhanaja
    @amalhanaja 25 дней назад

    wdyt if we inject the composable navgraph into a set and using composition local to provide navigation controller?

  • @Ceisluck
    @Ceisluck 28 дней назад +1

    what if feature A or B have more than 1 screen, is a overkill to emulate navcontroller, then the options left is to pass down the naController or make a navhost inside feature A or B, wich is BS in a way to see it. But I am ok with what google is recommending in the nowInAndroid sample app

    • @ajailani4
      @ajailani4 22 дня назад

      I think so. What if the screens are going to grow to hundreds and the modules are dozens? It's kinda hard and takes so much effort to stitch them all in an app module. Looks like a boilerplate too. Or does anyone have a proper solution for that?

  • @grossadmiralthrawn8769
    @grossadmiralthrawn8769 27 дней назад

    Does anyone know an Android library for the Matrix protocol.

  • @ShivaPrasad-hm5lk
    @ShivaPrasad-hm5lk 27 дней назад

    I am making an app now using jetpack compose in which I have used single activity and then in each composable I have one or more apo calls called in coroutines foe sthis mean I am not doing a lot of work on main thread?

  • @hackmedia7755
    @hackmedia7755 12 дней назад

    why not use reflection to autogenerate a route by the class name? wouldn't need to repeat so much code.

  • @tasnimulhasan7329
    @tasnimulhasan7329 28 дней назад

    Yeah that's the way google recommend 😊

  • @deviantstudio
    @deviantstudio 23 дня назад

    just pass the interface with module navigation into the module and implement it in the app

  • @baadrqaaba9529
    @baadrqaaba9529 27 дней назад

    Thats the point of using MMA

  • @mikejawoski5904
    @mikejawoski5904 28 дней назад

    Is it possible to do shared element transition with multi module?

  • @TheCypriot09
    @TheCypriot09 23 дня назад

    Why have the common-navigation if you need to decouple the modules? the main application shouldn't care about the screens at the first place. it should care about the navigations to a different screen and not the actual screens. right?

    • @TheCypriot09
      @TheCypriot09 23 дня назад

      Maybe the common-navigation should need to have an interface (for the screens) where each module needs to use ?

  • @sebastianseno9285
    @sebastianseno9285 26 дней назад

    why people still use multi module in jetpack compose ?

  • @lale5767
    @lale5767 28 дней назад +5

    FYI philip I personally hate these kind of titles 'Why you'rr doing it wrong'.
    How are you aware of what I'm doing? Are you spying on me? 😂
    Seriously though, I find it insulting and I'm sure I'm not the only one who finds it tacky.

    • @Mike-er2ih
      @Mike-er2ih 28 дней назад +1

      Clickbaitsssss

    • @PhilippLackner
      @PhilippLackner  28 дней назад

      Thanks for the feedback

    • @viniciussantosmachado4196
      @viniciussantosmachado4196 28 дней назад

      I personally don't care if the content is good

    • @lale5767
      @lale5767 28 дней назад

      @@PhilippLackner anytime bro

    • @lale5767
      @lale5767 28 дней назад

      @@viniciussantosmachado4196 maybe if you're a heavy youtube uaer, it'll wear down on you after a while.

  • @tiltedbybox6118
    @tiltedbybox6118 27 дней назад

    9:39 isn't that what you actually deleted? 😅

  • @SiamakAshrafi
    @SiamakAshrafi 27 дней назад

    You should never pass anything complex to your Composable. It should be side effect free and stateless. The ViewModel should do all the work ... so this is obvious :-) Thanks

    • @PhilippLackner
      @PhilippLackner  27 дней назад

      @@SiamakAshrafi if you're a beginner this is everything but obvious 😄

    • @SiamakAshrafi
      @SiamakAshrafi 27 дней назад

      @@PhilippLackner Don't tell us we are doing it wrong!!! We have been doing it this way from day one ... 👎🏾