Display the nightly popup only once a day

This commit is contained in:
Benoit Marty 2022-07-26 14:23:11 +02:00
parent e9bd271642
commit 1e8a8d4da0
2 changed files with 29 additions and 4 deletions

View File

@ -16,13 +16,21 @@
package im.vector.app.nightly package im.vector.app.nightly
import android.content.Context
import androidx.core.content.edit
import com.google.firebase.appdistribution.FirebaseAppDistribution import com.google.firebase.appdistribution.FirebaseAppDistribution
import com.google.firebase.appdistribution.FirebaseAppDistributionException import com.google.firebase.appdistribution.FirebaseAppDistributionException
import im.vector.app.core.di.DefaultSharedPreferences
import im.vector.app.core.time.Clock
import timber.log.Timber import timber.log.Timber
import javax.inject.Inject import javax.inject.Inject
class NightlyProxy @Inject constructor() { class NightlyProxy @Inject constructor(
private val clock: Clock,
private val context: Context,
) {
fun updateIfNewReleaseAvailable() { fun updateIfNewReleaseAvailable() {
if (!canDisplayPopup()) return
val firebaseAppDistribution = FirebaseAppDistribution.getInstance() val firebaseAppDistribution = FirebaseAppDistribution.getInstance()
firebaseAppDistribution.updateIfNewReleaseAvailable() firebaseAppDistribution.updateIfNewReleaseAvailable()
.addOnProgressListener { up -> .addOnProgressListener { up ->
@ -44,4 +52,23 @@ class NightlyProxy @Inject constructor() {
} }
} }
} }
private fun canDisplayPopup(): Boolean {
val sharedPreferences = DefaultSharedPreferences.getInstance(context)
val today = clock.epochMillis() / A_DAY_IN_MILLIS
val lastDisplayPopupDay = sharedPreferences.getLong(SHARED_PREF_KEY, 0)
return (today > lastDisplayPopupDay)
.also { canDisplayPopup ->
if (canDisplayPopup) {
sharedPreferences.edit {
putLong(SHARED_PREF_KEY, today)
}
}
}
}
companion object {
private const val A_DAY_IN_MILLIS = 8_600_000L
private const val SHARED_PREF_KEY = "LAST_NIGHTLY_POPUP_DAY"
}
} }

View File

@ -537,9 +537,7 @@ class HomeActivity :
serverBackupStatusViewModel.refreshRemoteStateIfNeeded() serverBackupStatusViewModel.refreshRemoteStateIfNeeded()
// Check nightly // Check nightly
if (isFirstCreation()) { nightlyProxy.updateIfNewReleaseAvailable()
nightlyProxy.updateIfNewReleaseAvailable()
}
} }
override fun getMenuRes() = R.menu.home override fun getMenuRes() = R.menu.home