Daniel Weidensdörfer
12/23/2024, 2:20 PMeygraber
12/24/2024, 2:54 AM@ComponentRealNetworkComponentAppComponentRealNetworkComponentAppComponentActivityComponentScreenComponentNetworkComponentNetworkModuleContributesToDaniel Weidensdörfer
12/24/2024, 1:30 PMdomaindatafeature1feature2appdatafeaturesappMarcelo Gobetti
05/02/2025, 9:51 PM@Component abstract classa hierarchy ofI finally got to a place that feels familiar with other projects, and while boilerplate exists in different forms, it's smaller and easier to handle than the other options, it seems. ------ @Daniel Weidensdörfer thank you for the original post, I had the same question and struggle, and was going the same route of components being 1:1 with gradle modules. I think what Eliezer is suggesting is we wouldn't have `@Component`s per module, but interfaces, and then only a few "master" components that implement them: those 3 he pointed out (where I understand,AppComponentandActivityComponentScreenComponent
ScreenComponentHomeScreenComponentSettingsScreenComponent@ApplicationScope
@Component
abstract class ApplicationComponent(
  @get:Provides val context: Context
) : DataComponent, NetworkComponent
...
@ActivityScope
@Component
abstract class ActivityComponent(
  @Component val applicationComponent: ApplicationComponent
) : InAppReviewComponent, SplashScreenComponent
...
@HomeScreenScope
@Component
abstract class HomeScreenComponent(
  @Component val activityComponent: ActivityComponent
) : HomeStuffComponentDaniel Weidensdörfer
05/06/2025, 8:10 AMDomainModuleScreenAComponentScreenBComponentDomainModuleScreenAScopeScreenBScopeeygraber
05/06/2025, 11:19 AMScreenScopeDaniel Weidensdörfer
05/06/2025, 2:41 PMeygraber
05/06/2025, 2:43 PMAppScopeMarcelo Gobetti
05/06/2025, 3:48 PMDomainModuleScreenScopeeygraber
05/06/2025, 3:50 PM