Add in-app update
This commit is contained in:
parent
0c9525834e
commit
162535e3dd
4 changed files with 87 additions and 6 deletions
app
|
@ -24,7 +24,7 @@ android {
|
||||||
vectorDrawables.useSupportLibrary = true
|
vectorDrawables.useSupportLibrary = true
|
||||||
|
|
||||||
applicationId "code.name.monkey.retromusic"
|
applicationId "code.name.monkey.retromusic"
|
||||||
versionCode 418
|
versionCode 417
|
||||||
versionName '3.5.100'
|
versionName '3.5.100'
|
||||||
|
|
||||||
multiDexEnabled true
|
multiDexEnabled true
|
||||||
|
@ -33,7 +33,7 @@ android {
|
||||||
}
|
}
|
||||||
signingConfigs {
|
signingConfigs {
|
||||||
release {
|
release {
|
||||||
Properties properties = getProperties('/Users/hemanths/Desktop/KeepSafe/retro.properties')
|
Properties properties = getProperties('/Users/h4h13/Documents/Github/retro.properties')
|
||||||
storeFile file(getProperty(properties, 'storeFile'))
|
storeFile file(getProperty(properties, 'storeFile'))
|
||||||
keyAlias getProperty(properties, 'keyAlias')
|
keyAlias getProperty(properties, 'keyAlias')
|
||||||
storePassword getProperty(properties, 'storePassword')
|
storePassword getProperty(properties, 'storePassword')
|
||||||
|
@ -195,4 +195,6 @@ dependencies {
|
||||||
implementation "androidx.lifecycle:lifecycle-livedata-ktx:$lifecycle_version"
|
implementation "androidx.lifecycle:lifecycle-livedata-ktx:$lifecycle_version"
|
||||||
implementation "androidx.lifecycle:lifecycle-common-java8:$lifecycle_version"
|
implementation "androidx.lifecycle:lifecycle-common-java8:$lifecycle_version"
|
||||||
kapt "androidx.lifecycle:lifecycle-compiler:$lifecycle_version"
|
kapt "androidx.lifecycle:lifecycle-compiler:$lifecycle_version"
|
||||||
|
|
||||||
|
implementation 'com.google.android.play:core:1.7.2'
|
||||||
}
|
}
|
|
@ -19,6 +19,7 @@ import android.content.BroadcastReceiver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.IntentFilter;
|
import android.content.IntentFilter;
|
||||||
|
import android.content.IntentSender;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.content.pm.PackageInfo;
|
import android.content.pm.PackageInfo;
|
||||||
import android.content.pm.PackageManager.NameNotFoundException;
|
import android.content.pm.PackageManager.NameNotFoundException;
|
||||||
|
@ -44,7 +45,17 @@ import com.afollestad.materialcab.MaterialCab;
|
||||||
import com.afollestad.materialcab.MaterialCab.Callback;
|
import com.afollestad.materialcab.MaterialCab.Callback;
|
||||||
import com.google.android.material.appbar.AppBarLayout;
|
import com.google.android.material.appbar.AppBarLayout;
|
||||||
import com.google.android.material.card.MaterialCardView;
|
import com.google.android.material.card.MaterialCardView;
|
||||||
|
import com.google.android.material.snackbar.Snackbar;
|
||||||
import com.google.android.material.textview.MaterialTextView;
|
import com.google.android.material.textview.MaterialTextView;
|
||||||
|
import com.google.android.play.core.appupdate.AppUpdateInfo;
|
||||||
|
import com.google.android.play.core.appupdate.AppUpdateManager;
|
||||||
|
import com.google.android.play.core.appupdate.AppUpdateManagerFactory;
|
||||||
|
import com.google.android.play.core.install.InstallState;
|
||||||
|
import com.google.android.play.core.install.InstallStateUpdatedListener;
|
||||||
|
import com.google.android.play.core.install.model.AppUpdateType;
|
||||||
|
import com.google.android.play.core.install.model.InstallStatus;
|
||||||
|
import com.google.android.play.core.install.model.UpdateAvailability;
|
||||||
|
import com.google.android.play.core.tasks.Task;
|
||||||
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
@ -52,6 +63,7 @@ import org.jetbrains.annotations.Nullable;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import code.name.monkey.appthemehelper.ThemeStore;
|
||||||
import code.name.monkey.appthemehelper.util.ATHUtil;
|
import code.name.monkey.appthemehelper.util.ATHUtil;
|
||||||
import code.name.monkey.appthemehelper.util.ToolbarContentTintHelper;
|
import code.name.monkey.appthemehelper.util.ToolbarContentTintHelper;
|
||||||
import code.name.monkey.retromusic.R;
|
import code.name.monkey.retromusic.R;
|
||||||
|
@ -91,10 +103,9 @@ public class MainActivity extends AbsSlidingMusicPanelActivity
|
||||||
implements CabHolder, SharedPreferences.OnSharedPreferenceChangeListener {
|
implements CabHolder, SharedPreferences.OnSharedPreferenceChangeListener {
|
||||||
|
|
||||||
public static final String TAG = MainActivity.class.getSimpleName();
|
public static final String TAG = MainActivity.class.getSimpleName();
|
||||||
|
|
||||||
public static final int APP_INTRO_REQUEST = 100;
|
public static final int APP_INTRO_REQUEST = 100;
|
||||||
|
|
||||||
public static final String EXPAND_PANEL = "expand_panel";
|
public static final String EXPAND_PANEL = "expand_panel";
|
||||||
|
private static final int APP_UPDATE_REQUEST_CODE = 9002;
|
||||||
private final BroadcastReceiver mBroadcastReceiver = new BroadcastReceiver() {
|
private final BroadcastReceiver mBroadcastReceiver = new BroadcastReceiver() {
|
||||||
@Override
|
@Override
|
||||||
public void onReceive(final Context context, final Intent intent) {
|
public void onReceive(final Context context, final Intent intent) {
|
||||||
|
@ -118,6 +129,30 @@ public class MainActivity extends AbsSlidingMusicPanelActivity
|
||||||
private MaterialTextView mAppTitle;
|
private MaterialTextView mAppTitle;
|
||||||
private Toolbar mToolbar;
|
private Toolbar mToolbar;
|
||||||
private MaterialCardView mToolbarContainer;
|
private MaterialCardView mToolbarContainer;
|
||||||
|
private AppUpdateManager appUpdateManager;
|
||||||
|
InstallStateUpdatedListener listener = new InstallStateUpdatedListener() {
|
||||||
|
@Override
|
||||||
|
public void onStateUpdate(InstallState state) {
|
||||||
|
if (state.installStatus() == InstallStatus.DOWNLOADED) {
|
||||||
|
popupSnackBarForCompleteUpdate();
|
||||||
|
} else if (state.installStatus() == InstallStatus.INSTALLED) {
|
||||||
|
appUpdateManager.unregisterListener(listener);
|
||||||
|
} else {
|
||||||
|
Log.i(TAG, "InstallStateUpdatedListener: state: " + state.installStatus());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private void popupSnackBarForCompleteUpdate() {
|
||||||
|
Snackbar snackbar = Snackbar.make(findViewById(R.id.mainContent), "New app is ready!", Snackbar.LENGTH_INDEFINITE);
|
||||||
|
snackbar.setAction("Install", view -> {
|
||||||
|
if (appUpdateManager != null) {
|
||||||
|
appUpdateManager.completeUpdate();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
snackbar.setActionTextColor(ThemeStore.Companion.accentColor(this));
|
||||||
|
snackbar.show();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(@Nullable final Bundle savedInstanceState) {
|
protected void onCreate(@Nullable final Bundle savedInstanceState) {
|
||||||
|
@ -151,6 +186,28 @@ public class MainActivity extends AbsSlidingMusicPanelActivity
|
||||||
checkShowChangelog();
|
checkShowChangelog();
|
||||||
AppRater.appLaunched(this);
|
AppRater.appLaunched(this);
|
||||||
setupToolbar();
|
setupToolbar();
|
||||||
|
checkUpdate();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkUpdate() {
|
||||||
|
appUpdateManager = AppUpdateManagerFactory.create(this);
|
||||||
|
appUpdateManager.registerListener(listener);
|
||||||
|
|
||||||
|
Task<AppUpdateInfo> appUpdateInfoTask = appUpdateManager.getAppUpdateInfo();
|
||||||
|
appUpdateInfoTask.addOnSuccessListener(appUpdateInfo -> {
|
||||||
|
if (appUpdateInfo.updateAvailability() == UpdateAvailability.UPDATE_AVAILABLE
|
||||||
|
&& appUpdateInfo.isUpdateTypeAllowed(AppUpdateType.IMMEDIATE)) {
|
||||||
|
try {
|
||||||
|
appUpdateManager.startUpdateFlowForResult(
|
||||||
|
appUpdateInfo,
|
||||||
|
AppUpdateType.IMMEDIATE,
|
||||||
|
this,
|
||||||
|
APP_UPDATE_REQUEST_CODE);
|
||||||
|
} catch (IntentSender.SendIntentException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -161,6 +218,10 @@ public class MainActivity extends AbsSlidingMusicPanelActivity
|
||||||
if (!hasPermissions()) {
|
if (!hasPermissions()) {
|
||||||
requestPermissions();
|
requestPermissions();
|
||||||
}
|
}
|
||||||
|
} else if (requestCode == APP_UPDATE_REQUEST_CODE) {
|
||||||
|
if (resultCode != RESULT_OK) {
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -176,6 +237,23 @@ public class MainActivity extends AbsSlidingMusicPanelActivity
|
||||||
getIntent().putExtra(EXPAND_PANEL, false);
|
getIntent().putExtra(EXPAND_PANEL, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
appUpdateManager.getAppUpdateInfo()
|
||||||
|
.addOnSuccessListener(appUpdateInfo -> {
|
||||||
|
if (appUpdateInfo.installStatus() == InstallStatus.DOWNLOADED) {
|
||||||
|
popupSnackBarForCompleteUpdate();
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
if (appUpdateInfo.updateAvailability() == UpdateAvailability.DEVELOPER_TRIGGERED_UPDATE_IN_PROGRESS) {
|
||||||
|
appUpdateManager.startUpdateFlowForResult(
|
||||||
|
appUpdateInfo,
|
||||||
|
AppUpdateType.IMMEDIATE,
|
||||||
|
this,
|
||||||
|
APP_UPDATE_REQUEST_CODE);
|
||||||
|
}
|
||||||
|
} catch (IntentSender.SendIntentException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -10,7 +10,7 @@ import code.name.monkey.retromusic.providers.RepositoryImpl
|
||||||
import kotlinx.coroutines.launch
|
import kotlinx.coroutines.launch
|
||||||
|
|
||||||
class SongsViewModel(application: Application) : AndroidViewModel(application) {
|
class SongsViewModel(application: Application) : AndroidViewModel(application) {
|
||||||
lateinit var songs: MutableLiveData<List<Song>>
|
var songs = MutableLiveData<List<Song>>()
|
||||||
|
|
||||||
init {
|
init {
|
||||||
loadSongs()
|
loadSongs()
|
||||||
|
@ -19,7 +19,7 @@ class SongsViewModel(application: Application) : AndroidViewModel(application) {
|
||||||
fun loadSongs() = viewModelScope.launch {
|
fun loadSongs() = viewModelScope.launch {
|
||||||
val result = RepositoryImpl(getApplication()).allSongs()
|
val result = RepositoryImpl(getApplication()).allSongs()
|
||||||
if (result is Success) {
|
if (result is Success) {
|
||||||
songs = MutableLiveData(result.data)
|
songs.value = result.data
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -19,6 +19,7 @@
|
||||||
|
|
||||||
<androidx.coordinatorlayout.widget.CoordinatorLayout
|
<androidx.coordinatorlayout.widget.CoordinatorLayout
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
|
android:id="@+id/mainContent"
|
||||||
android:layout_height="match_parent">
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
<com.google.android.material.appbar.AppBarLayout
|
<com.google.android.material.appbar.AppBarLayout
|
||||||
|
|
Loading…
Reference in a new issue