Product Flavors in Flutter — Create admin and non-admin apps with distinct UI with a single codebase
Have you ever wondered how some mobile applications have admin and non-admin variants? The admin app has different UIs than the non-admin ones. Or have you seen some apps on the Play Store or App Store with premium and freemium versions? So, how do developers actually do it? How do they create multiple variants of the same project? Do they manage multiple codebases? Is there one team responsible for developing one variant and another team developing the other variant with 2 different codebases? And a clear and short answer to that is NO.
It would be costly for companies to hire two different teams to create two different app variants. So, how is it possible? And unsurprisingly, the answer to that is using Product Flavor.
As the name suggests, a product flavor (or a product variant) is a way to create multiple variants of your app from a single codebase. We can deploy these different apps independently in the relevant stores as well.
Implementation
Now, we will begin creating our flavors. We will have an admin flavor and a non-admin flavor. I will keep the apps very simple and have them display a text saying This is the admin UI
and This is the non-admin UI
. In a real-world application, you can follow the same techniques that I will show you and have UIs accordingly the way you want.
First, we will add a configuration in the app-level build.gradle
file inside the android
block.
Because we will have two different apps created, we want two different names for each of our applications. To do so, we will have to navigate to /android/app/src/main/AndroidManifest.xml
file and edit android:label
.
Now, we need to create two main.dart
files in our lib
directory. We shall name them main_admin.dart
and main_non_admin.dart
.
We will create our MyApp()
widget in a moment but let’s first take care of some other things.
For VS Code Users
If you are a VS Code user, then you need to follow some of the steps that I’ll show you now.
First, create a .vscode
folder in the root project directory. Then create a file launch.json
inside it and add the following snippet.
Now, if you go to the Run and Debug
option in your VS Code or hold Ctrl+Shift+D
, you will see a drop-down menu. On clicking it, you should see an option to debug your two different app variants.
For Android Studio Users
If you use Android Studio then you need to follow some of the steps that I’ll show you now.
Navigate to Edit Configurations
option under the Run
tab. It should open up a new window. Then you need to add configurations for each flavor.
In the Dart entrypoint
option, add the path to main_admin.dart
file using the browse option on the right-hand side. In the Additional run args
option, add
--flavor admin --dart-define=appType=admin
Now, add another configuration for the non-admin app.
Follow the same steps as mentioned above and in the Additional run args
option, add
--flavor non_admin --dart-define=appType=nonAdmin
Now, we can select the proper configurations that we want to run and debug.
The dart-define
option that we have attached in our command is important to find out the app type on run time. We will see how we can use it to identify the app types.
Create a new file app_config.dart
inside the lib directory.
The value of String.fromEnvironment()
comes from the dart-define
option that we set earlier for each app variant. Now, using the isAdminApp
boolean value, we can easily check if the app running currently is the admin app or the non-admin app and render UIs accordingly.
Now create a new file my_app.dart
inside the lib directory which will contain code for our MyApp()
class. I am keeping it very simple to display different UI for each app variant. You can however take the idea and create as complex UI as you want for each app variant.
As you can see, we have _AdminBody()
class and _NonAdminBody()
class which will help us render UIs depending on the app we are running.
On running both app flavors, we will have two different apps created with a single codebase.
Conclusion
We learned how we can have two different apps created with different UIs using a single codebase. I hope this blog post will be helpful for some of you reading if you ever encounter a situation where you’d have to create a similar project.
If you wish to see some Flutter projects with proper architecture, follow me on GitHub. I am also active on Twitter @b_plab.
My Socials:
Until next time, happy coding!!! 👨💻
— Biplab Dutta