Android App White-labeling

Prev Next

Like iOS, we have build flavors to generate our Official and Experimental app versions. To see these flavors, navigate to android > app > src folder.

  • experimental and official folders contain app icons and splash screens.

  • main folder contains core implementations.

  • debug folder contains code to run the app in debug mode.

To build the Experimental app using experimental, debug, and main folders:

  • Set APPLICATION_ID, VERSIONCODE and BugsnagAPIKey on ./android/gradle.properties

  • Generate a new image asset for ic_notification and target main.

  • Generate a new image asset for ic_launcher and target experimental.

  • Splash screen uses the same asset as the ic_launcher, and you can change the background on splashBackground.

  • Change the app name and share the extension name on ./android/app/src/main/res/values/strings.xml

Follow these steps to generate the Keystore for verifying your app on Google Play:

  1. Run the following commands:

    cd android/app
    keytool -genkeypair -v -keystore my-upload-key.keystore -alias my-key-alias -keyalg RSA -keysize 2048 -validity 10000
    Bash

    To learn more about generating an upload key in ReactNative, see the official documentation.

  2. The command prompts you for some credentials.

  3. Set KEYSTORE_PASSWORD and KEY_PASSWORD on ./android/gradle.properties with the passwords you were prompted for.

  1. Go to the project overview on Firebase.

  2. Navigate to Settings > Project settings.

  3. On the General tab, click on Add app under Your apps.

  4. Enter your bundle ID as the Android package name and click Register app.

  5. Download the config file and move it as instructed.

To run the app, execute the following commands:

yarn
yarn android-whitelabel <YOURAPPID>
Bash

For example, the app created on this document would use:

yarn android-whitelabel chat.rocket.whitelabel
Bash

This script uses experimentalDebug build flavor. When you build your app on release mode, use experimentalRelease. See the official documentation for more info.