diff --git a/app/build.gradle b/app/build.gradle index 2bd90315197..a354d2e99f3 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -10,7 +10,7 @@ apply plugin: 'com.github.triplet.play' play { jsonFile = file('../files/gplay-keys.json') - track = 'alpha' + track = 'beta' errorOnSizeLimit = true uploadImages = false untrackOld = true diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index 1ae569ed39b..4135ab59fc6 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -7,7 +7,7 @@ - + diff --git a/app/src/main/kotlin/com/pitchedapps/frost/activities/ImageActivity.kt b/app/src/main/kotlin/com/pitchedapps/frost/activities/ImageActivity.kt index 509ac2cb22d..487f3a9d563 100644 --- a/app/src/main/kotlin/com/pitchedapps/frost/activities/ImageActivity.kt +++ b/app/src/main/kotlin/com/pitchedapps/frost/activities/ImageActivity.kt @@ -85,7 +85,7 @@ class ImageActivity : AppCompatActivity() { setContentView(if (!text.isNullOrBlank()) R.layout.activity_image else R.layout.activity_image_textless) container.setBackgroundColor(Prefs.bgColor.withMinAlpha(222)) caption?.setTextColor(Prefs.textColor) - caption?.setBackgroundColor(Prefs.bgColor.colorToForeground(0.1f).withAlpha(255)) + caption?.setBackgroundColor(Prefs.bgColor.colorToForeground(0.2f).withAlpha(255)) caption?.text = text progress.tint(Prefs.accentColor) panel?.addPanelSlideListener(object : SlidingUpPanelLayout.SimplePanelSlideListener() { @@ -174,16 +174,13 @@ class ImageActivity : AppCompatActivity() { val timeStamp = SimpleDateFormat("yyyyMMdd_HHmmss").format(Date()) val imageFileName = "Frost_" + timeStamp + "_" val storageDir = getExternalFilesDir(Environment.DIRECTORY_PICTURES) - return File.createTempFile( - imageFileName, /* prefix */ - ".png", /* suffix */ - storageDir /* directory */ - ) + return File.createTempFile(imageFileName, ".png", storageDir) } internal fun downloadImage() { kauRequestPermissions(PERMISSION_WRITE_EXTERNAL_STORAGE) { granted, _ -> + L.d("Download image callback granted: $granted") if (granted) { doAsync { val timeStamp = SimpleDateFormat("yyyyMMdd_HHmmss").format(Date()) @@ -199,6 +196,7 @@ class ImageActivity : AppCompatActivity() { } catch (e: Exception) { success = false } finally { + L.d("Download image async finished: $success") uiThread { snackbar(if (success) R.string.image_download_success else R.string.image_download_fail) if (success) { @@ -230,7 +228,7 @@ class ImageActivity : AppCompatActivity() { } } -internal enum class FabStates(val iicon: IIcon, val iconColor: Int = Prefs.textColor, val backgroundTint: Int = Prefs.accentBackgroundColor.withAlpha(255)) { +internal enum class FabStates(val iicon: IIcon, val iconColor: Int = Prefs.iconColor, val backgroundTint: Int = Prefs.iconBackgroundColor.withAlpha(255)) { ERROR(GoogleMaterial.Icon.gmd_error, Color.WHITE, Color.RED) { override fun onClick(activity: ImageActivity) { //todo add something @@ -240,9 +238,7 @@ internal enum class FabStates(val iicon: IIcon, val iconColor: Int = Prefs.textC override fun onClick(activity: ImageActivity) {} }, DOWNLOAD(GoogleMaterial.Icon.gmd_file_download) { - override fun onClick(activity: ImageActivity) { - activity.downloadImage() - } + override fun onClick(activity: ImageActivity) = activity.downloadImage() }, SHARE(GoogleMaterial.Icon.gmd_share) { override fun onClick(activity: ImageActivity) { diff --git a/app/src/main/kotlin/com/pitchedapps/frost/utils/Prefs.kt b/app/src/main/kotlin/com/pitchedapps/frost/utils/Prefs.kt index f8c7af563c5..63e575541fb 100644 --- a/app/src/main/kotlin/com/pitchedapps/frost/utils/Prefs.kt +++ b/app/src/main/kotlin/com/pitchedapps/frost/utils/Prefs.kt @@ -65,16 +65,10 @@ object Prefs : KPref() { get() = if (headerColor.isColorVisibleOn(bgColor, 100)) headerColor else textColor /** - * Ensures that the color is visible against both the foreground and background + * Ensures that the color is visible against the background */ - val accentBackgroundColor: Int - get() { - if (headerColor.isColorVisibleOn(textColor, 100)) { - if (headerColor.isColorVisibleOn(bgColor, 100)) return headerColor - else return headerColor.colorToForeground(0.2f) - } - return bgColor.colorToForeground(0.2f) - } + val iconBackgroundColor: Int + get() = if (headerColor.isColorVisibleOn(bgColor)) headerColor else headerColor.colorToForeground(0.2f) val themeInjector: InjectorContract get() = t.injector diff --git a/app/src/main/kotlin/com/pitchedapps/frost/utils/iab/IAB.kt b/app/src/main/kotlin/com/pitchedapps/frost/utils/iab/IAB.kt index 964e771c5f7..669b2c9ea7c 100644 --- a/app/src/main/kotlin/com/pitchedapps/frost/utils/iab/IAB.kt +++ b/app/src/main/kotlin/com/pitchedapps/frost/utils/iab/IAB.kt @@ -158,13 +158,18 @@ private fun SettingsActivity.finishRestore(snackbar: Snackbar, hasPro: Boolean) */ fun Activity.validatePro() { L.d("Play Store Validate pro") - getInventory(Prefs.pro, false, { if (Prefs.pro) playStoreNoLongerPro() }) { - inv, helper -> - val proSku = inv.hasPurchase(FROST_PRO) - L.d("Play Store Validation finished: ${Prefs.pro} should be $proSku") - if (!proSku && Prefs.pro) playStoreNoLongerPro() - else if (proSku && !Prefs.pro) playStoreFoundPro() - helper.disposeWhenFinished() + try { + getInventory(Prefs.pro, false, { if (Prefs.pro) playStoreNoLongerPro() }) { + inv, helper -> + val proSku = inv.hasPurchase(FROST_PRO) + L.d("Play Store Validation finished: ${Prefs.pro} should be $proSku") + if (!proSku && Prefs.pro) playStoreNoLongerPro() + else if (proSku && !Prefs.pro) playStoreFoundPro() + IAB.dispose(helper) + } + } catch (e: Exception) { + L.e(e, "Play store validation exception") + IAB.dispose() } } diff --git a/docs/Changelog.md b/docs/Changelog.md index 79f7d6923c2..0345bae0e3c 100644 --- a/docs/Changelog.md +++ b/docs/Changelog.md @@ -2,7 +2,8 @@ ## Beta Updates * Update IAB helper -* Implemented image viewing and downloading; long press any image! +* Create image viewing and downloading; long press any image! +* Start filtering out unnecessary loads ## v1.3 * Create toggle for notifications only from primary account diff --git a/gradle.properties b/gradle.properties index 7ac04b38510..8ae6821395f 100644 --- a/gradle.properties +++ b/gradle.properties @@ -17,7 +17,7 @@ MIN_SDK=21 TARGET_SDK=26 BUILD_TOOLS=26.0.0 -KAU=e6daff7 +KAU=eddaded KOTLIN=1.1.3-2 CRASHLYTICS=2.6.8 DBFLOW=4.0.4