A utility to easily create flavors in your Expo/RN applications
Let's start by setting up our environment in order to run expo-flavorizer
Side note: this tool works better on a new and clean expo project. Since some processors reference some existing files and a specific base structure, it could be possible that running expo-flavorizer over an existing project could throw errors.
Before running expo-flavorizer, you must install the following software:
These prerequisites are needed to manipulate the iOS and macOS projects and schemes. If you are interested in flavorizing Android only, you can skip this step.
This package is intended to support development of react native projects. In general, you can install it globally using:
yarn global add @reservamos/expo-flavorizer
or using NPM
npm -g install @reservamos/expo-flavorizer
Once all of the prerequisites have been installed and you have added
a flavorizer.config.json
file and define the
flavors.
Create a new file named flavorizer.config.json
and define the name of the
flavors, in our example apple and banana. For each flavor you have
to specify the app name, the applicationId and the bundleId.
or you can use the command for initialize the project:
flavorizer init
when you already created the configuration file you can use:
flavorizer add
to create new flavors, below you can see an example configuration.
{
"app": {
"android": {
"flavorDimensions": "dimensions-app"
},
"ios": {
"buildSettings": {
"IPHONEOS_DEPLOYMENT_TARGET": "13.0",
"MINIMUM_IPHONEOS_VERSION": "13.0"
}
}
},
"flavors": [
{
"flavorName": "apple",
"appName": "Apple App",
"defaultIcon": "testResources/assets/icon-apple.png",
"android": {
"applicationId": "com.example.apple",
"adaptiveIcon": {
"background": "testResources/assets/bg-apple.png",
"foreground": "testResources/assets/fg-apple.png",
"foregroundScale": "0.6"
},
"splash": {
"image": "testResources/assets/fg-apple.png",
"imageScale": "0.6",
"imageWidth": "300",
"imageHeight": "300",
"resizeMode": "cover",
"backgroundColor": "#C35955"
}
},
"ios": {
"bundleId": "com.example.apple",
"launchScreen": {
"backgroundColor": "#C35955",
"image": "testResources/assets/fg-apple.png"
}
}
},
{
"flavorName": "banana",
"appName": "Banana App",
"defaultIcon": "testResources/assets/icon-banana.png",
"android": {
"applicationId": "com.example.banana",
"adaptiveIcon": {
"background": "testResources/assets/bg-banana.png",
"foreground": "testResources/assets/fg-banana.png",
"foregroundScale": "0.6"
},
"splash": {
"image": "testResources/assets/fg-banana.png",
"imageScale": "0.6",
"imageWidth": "300",
"imageHeight": "300",
"resizeMode": "cover",
"backgroundColor": "#E4C65C"
},
"resValues": {
"variableOne": {
"type": "string",
"value": "test variable one"
},
"variableTwo": {
"type": "string",
"value": "test variable two"
}
},
"buildConfigFields": {
"fieldOne": {
"type": "String",
"value": "test field one"
},
"fieldTwo": {
"type": "char",
"value": "y"
},
"fieldThree": {
"type": "double",
"value": "20.0"
}
}
},
"ios": {
"bundleId": "com.example.banana",
"launchScreen": {
"backgroundColor": "#E4C65C",
"image": "testResources/assets/fg-banana.png"
}
}
}
],
"instructions": [
"android:androidManifest",
"android:buildGradle",
"android:icons",
"android:splashScreen",
"ios:icons",
"ios:launchScreen",
"ios:podfile",
"ios:buildTargets",
"ios:plist"
]
}
Usage: flavorizer [options] [command]
Expo Flavorizer CLI
Options:
-V, --version output the version number
-h, --help display help for command
Commands:
list List all flavors existing in the configuration file
init Initialize the flavorizer configuration file
add Add a new flavor to the configuration file
remove [flavorName] Remove an existing flavor from the configuration file
apply Apply all changes to the expo project
help [command] display help for command
It is recommended that you use all the instructions and maintain the order of the configuration template.
Processor | Description |
---|---|
android:androidManifest | Modifies the AndroidManifest.xml file |
android:buildGradle | Updates the build.gradle file |
android:icons | Generates flavor-specific icons for Android |
android:splashScreen | Creates flavor-specific splash screens for Android |
ios:icons | Generates flavor-specific icons for iOS |
ios:launchScreen | Creates flavor-specific launch screens for iOS |
ios:podfile | Updates the Podfile |
ios:buildTargets | Configures build targets for iOS |
ios:plist | Modifies the Info.plist file |
After setting up your flavorizer.config.json
, run:
flavorizer apply
and wait the final result.
I haven't found yet a good groovy parser to guarantee the idempotency of the AndroidBuildGradleProcessor.
The only way to keep track of the autogenerated flavorDimensions is to mark up the beginning and the end of the section with magic comments.
Please do not erase these comments otherwise you will break down the AndroidBuildGradleProcessor.
Please feel free to submit new issues if you encounter problems while using this library.
If you need help with the use of the library or you just want to request new features, please use the Discussions section of the repository. Issues opened as questions will be automatically closed.