Fresh Air is an application update library. It is designed to check a remote location for application updates and if updates are available, it prompts the user to upgrade the application. When the new version of the application is started, a dialog can be presented that showcases the new features to the user.
Fresh Air can be set up with just a few simple steps. A working example can also be found in the sample
module of this project.
Fresh Air is available on our Bintray Maven repository and can be included in your project with the following changes.
- Include our repository in your root project
build.gradle
:
allprojects {
repositories {
jcenter()
maven { url "https://dl.bintray.com/raizlabs/Libraries" }
}
}
- Include the dependency in your module's
build.gradle
:
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
compile 'com.android.support:appcompat-v7:23.1.0'
...
compile 'com.raizlabs:FreshAir:0.1.0'
}
- Initialize the library before use, typically in your
Application
class:
public class SampleApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
FreshAir.initialize(this);
...
}
}
Fresh Air can check for new versions of your application using a remotely hosted JSON file. Just call the following method from the onCreate()
of your Application
, your first Activity
, or any other place you would like to check for updates. Note that this process is asynchronous.
public class SampleApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
FreshAir.initialize(this);
FreshAir.checkForUpdates("https://raw.githubusercontent.com/Raizlabs/FreshAir-Android/develop/Schema/release_notes.json");
...
}
}
See Schema/release_notes.json
in this repo for an example of the JSON schema
Fresh Air can present a dialog of release notes to showcase the features that you have added in new versions of your application. This dialog will include a scrollable view of features which each contain an image, title, and description. These will be shown once per version, but not again.
- Define the release information that you wish to display. This doesn't display the information, but lets Fresh Air know what you will want to display when the time comes. Typically, you want to put this information in your
Application.onCreate()
after initializing the library. The release notes follow aBuilder
pattern which takes a set ofFeatures
, which are also constructed through aBuilder
pattern:
public class SampleApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
FreshAir.initialize(this);
FreshAir.setReleaseNotes(new ReleaseNotes.Builder()
.addFeature(
new FeatureInfo.Builder()
.setImageResource(R.mipmap.ic_launcher)
.setTitleResource(R.string.Feature1_Title)
.setDescriptionResource(R.string.Feature1_Description)
)
.addFeature(
new FeatureInfo.Builder()
.setImageResource(R.drawable.feature2)
.setTitleResource(R.string.Feature2_Title)
.setDescriptionResource(R.string.Feature2_Description)
)
.addFeature(
new FeatureInfo.Builder()
.setImageResource(R.drawable.feature3)
.setTitleResource(R.string.Feature3_Title)
.setDescriptionResource(R.string.Feature3_Description)
)
// Sometimes handy for minor updates: see docs
.setVersionCode(1));
}
}
- When you would like to display the release notes dialog, call the following method. This requires a
FragmentActivity
from the support library. Typically you want to do this from your main launcherActivity
or any other entry point to your application:
public class MainActivity extends FragmentActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
...
FreshAir.showReleaseNotes(this);
}
}
Additional flexibility is available. Consult the JavaDoc for more details, but some of the higher level functionality is listed below.
- Update Prompts - You can change the text contents of the update prompt via
FreshAir.setUpdatePrompt(UpdatePromptInfo)
.UpdatePromptInfo
contains aBuilder
class for easy overriding. - Clear History - You can clear the previously shown updates, forced updates, and release notes via
FreshAir.clearFUpdatePromptVersion()
,FreshAir.clearForcedUpdateVersion()
, andFreshAir.clearReleaseNotesVersion
- App Disabling - You can manually block out the app via
FreshAir.disableApp()
. To unset this, you must callFreshAir.clearAppDisabled()
and restart the app. - Logging - You can alter the level of logging via
FreshAir.setLogLevel(int)
to clear logging or add more logging for debugging. By default, only warnings and errors are displayed.