IntentBuilder

Additional

Language
Java
Version
v1.1.0 (Oct 10, 2016)
Created
Oct 4, 2016
Updated
Jan 19, 2018 (Retired)
Owner
Trikke
Contributors
Trikke
Bojan Kseneman (bojankseneman)
2
Activity
Badge
Generate
Download
Source code

IntentBuilder

IntentBuilder is a type safe way of creating intents and populating them with extras. Use them with your Activities, Services, Broadcastreceivers and other components.

Installation

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.neenbedankt.gradle.plugins:android-apt:1.4'
    }
}

apply plugin: 'com.neenbedankt.android-apt'

dependencies {
    compile 'be.trikke:intentbuilder-api:1.2.1'
    apt 'be.trikke:intentbuilder-compiler:1.2.1'
}

Version History

  • v1.0 Initial release
  • v1.1 Added support for Broadcastreceivers. Changed the usage of @Nullable and created an extra annotation @ExtraOptional to use with optional values.
  • v1.2 Added ability to have urls as a usage of navigation.

Usage

Annotate your activities and services with an @BuildIntent annotation so that they are picked up by the library. For every class with an @BuildIntent annotation a class named <ComponentName>Intent will be generated. If your Component takes in parameters via extras in the intent you can now mark field with the @Extra annotation and they can be injected with the static inject method on the generated intent builder class. Extras can be marked as optional with the @ExtraOptional annotation.

Sample activity using IntentBuilder:

@BuildIntent public class DetailActivity extends AppCompatActivity {

    @Extra String requiredString;

    @Extra boolean requiredBoolean;

    @ExtraOptional String optionalString;

    @ExtraOptional int optionalInteger;

    @ExtraOptional("coolName") String optionalStringDiffName;

    @ExtraOptional boolean optionalBoolean;

    @Override public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        DetailActivityIntent.inject(getIntent(), this);
        setContentView(R.layout.activity_detail);

        // use extras
    }
}

You can also use the @BuildIntentUrl annotation to add url schemes to a certain component.

@BuildIntentUrl(value = {
  @UrlPath(name = "DETAILS",url = "test://parameters?requiredString={string}&requiredBoolean={boolean}"),
  @UrlPath(name = "MORE",url = "test://more"),
  @UrlPath(name = "STUFF",url = "test://stuff"),
}) public class DetailActivity extends AppCompatActivity {
 @Extra String requiredString;
    @Extra boolean requiredBoolean;
}

Make sure the parameters in the url scheme have the same name as the @Extra fields. Otherwise they will not be injected correctly.

Launching

Use the builder to create the Intent.

Intent i = new DetailActivityIntent("Required String", true)
                      .optionalString("Optional String")
                      .optionalInteger(102)
                      .build(MainActivity.this);
startActivity(i);

Or quickly build an intent with the provided Navigate shortcut class.

Navigate.gotoDetailActivity("i'm a required String", true)
                      .optionalString("i'm just optional")
                      .coolName("Trikke")
                      .optionalBoolean(true)
                      .flag(Intent.FLAG_ACTIVITY_CLEAR_TOP)
                      .launch(MainActivity.this);

Use the provided Navigate shortcut class to quickly launch an Intent with it's required extra's (if any).

Navigate.launchDetailActivity(MainActivity.this, "required", true)

The Navigate provides quick methods for getting all your generated Intents, and has launch methods for compatible Components.

Navigate.getMyBroadcastReceiver("A required String").action(MY_INTENT_FILTER).send(MainActivity.this);
Navigate.startMyService(MainActivity.this, "Required String");

If you have components with url schemes, the provided Navigate shortcut class contains methods to launch and resolve these urls. Make sure to only launch known urls.

Navigate.launch(MainActivity.this, "test://stuff")

Contributing

Please do! Let me know what you think, and PR's are always welcome!

Thanks

Thanks to emilsjolander and robertoestivill for their source and inspiring me to get off my butt and make this.