Skip to content

Extension to use conductor with the new dagger.android module.

License

Notifications You must be signed in to change notification settings

wurstnudl/conductor-dagger

 
 

Repository files navigation

dagger-conductor

Extension to use conductor with the new dagger.android (com.google.dagger:dagger-android-support) module.

Used libraries:

Install

Download

dependencies {
    compile 'com.christianbahl.conductor:conductor-dagger-android:1.0.0'
    annotationProcessor 'com.google.dagger:dagger-compiler:2.11-rc2'
}

Changelog

The changelog can be found in the release section

Issues

Please fill any issues here issue page

Usage

  1. Install ConductorInjectionModule in your application component to ensure that all bindings necessary for these base types are available

    @Singleton @Component(modules = { ConductorInjectionModule.class, ... }) public interface AppComponent {
      void inject(CustomApplication application);
    }
  2. Next you hav to write a @Subcomponent that implements AndroidInjector, with a @Subcomponent.Builder that extends AndroidInjector.Builder

    @ScreenScope @Subcomponent public interface YourControllerComponent extends AndroidInjector<YourController> {
      @Subcomponent.Builder abstract class Builder extends AndroidInjector.Builder<YourController> {
      }
    }

    If your controller depends on controller specific stuff you can set this stuff by overriding the seedInstance method in the builder (e.g. YourControllerModule provides the simple class name of the controller)

    @ScreenScope @Subcomponent(modules = { YourControllerModule.class }) public interface MainComponent extends AndroidInjector<YourController> {
      @Subcomponent.Builder abstract class Builder extends AndroidInjector.Builder<YourController> {
        public abstract Builder yourControllerModule(YourControllerModule yourControllerModule);
    
        @Override public void seedInstance(YourController yourController) {
          yourControllerModule(new YourControllerModule(yourController.getClass().getSimpleName()));
        }
      }
    }
  3. After defining the @Subcomponent, add it to your component hierarchy by defining a module that binds the subcomponent builder and adding it to the component that injects your Application

    @Module(subcomponents = { YourControllerComponent.class }) public abstract class YourControllerModule {
      @Binds @IntoMap @ControllerKey(YourController.class)
      abstract AndroidInjector.Factory<? extends Controller> bindYourControllerInjectorFactory(YourControllerComponent.Builder builder);
    }
    @Component(modules = {..., YourControllerModule.class})
    interface YourApplicationComponent {}
  4. Next, make your Application implement HasDispatchingControllerInjector and @Inject a DispatchingAndroidInjector to return from the controllerInjector() method

    public class YourApplication extends Application implements HasDispatchingControllerInjector {
       @Inject DispatchingAndroidInjector<Controller> dispatchingControllerInjector;
    
       @Override public void onCreate() {
         super.onCreate();
         DaggerYourApplicationComponent.create().inject(this);
       }
    
       @Override public DispatchingAndroidInjector<Controller> controllerInjector() {
         return dispatchingControllerInjector;
       }
    }

    You can also use your Activity as HasDispatchingControllerInjector

    public class MainActivity extends AppCompatActivity implements HasDispatchingControllerInjector {
       @Inject DispatchingAndroidInjector<Controller> dispatchingControllerInjector;
       private Router router;
    
       @Override protected void onCreate(Bundle savedInstanceState) {
         super.onCreate(savedInstanceState);
         DaggerYourActivityComponent.create().inject(this);
         setContentView(R.layout.activity_main);
         
         router = Conductor.attachRouter(this, container, savedInstanceState);
         if (!router.hasRootController()) {
           router.setRoot(RouterTransaction.with(new MainController()));
         }
       }
    
       @Override public void onBackPressed() {
         if (!router.handleBack()) {
           super.onBackPressed();
         }
       }
     }
  5. Finally, in your Controller.onCreateView() method, call ConductorInjection.inject(this) at the beginning

    public class YourController extends Controller {
      @Inject @Named("controllerName") String controllerName;
    
      @NonNull @Override protected View onCreateView(@NonNull LayoutInflater layoutInflater, @NonNull ViewGroup viewGroup) {
        ConductorInjection.inject(this);
        View view = layoutInflater.inflate(R.layout.controller_your, viewGroup, false);
        ((TextView) view.findViewById(R.id.textView)).setText("Injected value = " + controllerName);
        return view;
      }
    }

#License

Copyright 2017 Christian Bahl

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License. 

About

Extension to use conductor with the new dagger.android module.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Java 100.0%